Fix missing type traversals.
authorIan Lance Taylor <ian@gcc.gnu.org>
Wed, 23 Feb 2011 04:54:27 +0000 (04:54 +0000)
committerIan Lance Taylor <ian@gcc.gnu.org>
Wed, 23 Feb 2011 04:54:27 +0000 (04:54 +0000)
From-SVN: r170427

gcc/go/gofrontend/expressions.cc
gcc/go/gofrontend/statements.cc

index 6440ee1393e39ffa50fcea8277d4f0fa77994126..264dd579b6f4fe2184247c864206068e5813e0ef 100644 (file)
@@ -2357,6 +2357,9 @@ class Const_expression : public Expression
   check_for_init_loop();
 
  protected:
+  int
+  do_traverse(Traverse*);
+
   Expression*
   do_lower(Gogo*, Named_object*, int);
 
@@ -2412,6 +2415,16 @@ class Const_expression : public Expression
   mutable bool seen_;
 };
 
+// Traversal.
+
+int
+Const_expression::do_traverse(Traverse* traverse)
+{
+  if (this->type_ != NULL)
+    return Type::traverse(this->type_, traverse);
+  return TRAVERSE_CONTINUE;
+}
+
 // Lower a constant expression.  This is where we convert the
 // predeclared constant iota into an integer value.
 
index 99ed6653914efd39b5d07bf9226929c3768fd67a..45e45a381b7e3ffeb8c4e5f1262eb8ce87aff54f 100644 (file)
@@ -318,6 +318,9 @@ Temporary_statement::get_decl() const
 int
 Temporary_statement::do_traverse(Traverse* traverse)
 {
+  if (this->type_ != NULL
+      && this->traverse_type(traverse, this->type_) == TRAVERSE_EXIT)
+    return TRAVERSE_EXIT;
   if (this->init_ == NULL)
     return TRAVERSE_CONTINUE;
   else