[cfe-dev] Typo in RecursiveASTVisitor.h?

Benoit Perrot benoit at lrde.epita.fr
Tue Dec 7 05:06:22 PST 2010


Hello,

When playing with (inheriting from) "RecursiveASTVisitor", I observed
that "::TraverseBinAssign" and other traversers of binary operators were
never called, except "::TraverseBinPtrMemD".

My investigations led me to the implementation of
"RecursiveASTVisitor<Derived>::TraverseStmt" (line 386 of
RecursiveASTVisitor.h), which says (line 393):

        if (BinaryOperator *BinOp = dyn_cast<BinaryOperator>(S)) {
          switch (BinOp->getOpcode()) {
      #define OPERATOR(NAME) \
          case BO_##NAME: DISPATCH(Bin##PtrMemD, BinaryOperator, S);

(See how every case of the switch actually dispatch to BinPtrMemD functions
only)

Shouldn't it be the following?

      #define OPERATOR(NAME) \
          case BO_##NAME: DISPATCH(Bin##NAME, BinaryOperator, S);


Regards,
-- 
Benoit PERROT


----------------------------------------------------------------
This message was sent using IMP, the Internet Messaging Program.

-------------- next part --------------
(TraverseStmt) Effectively dispatch binary operators to specialized Traversers.

--- cfe/trunk/include/clang/AST/RecursiveASTVisitor.h (original)
+++ cfe/trunk/include/clang/AST/RecursiveASTVisitor.h Tue Dec  7 09:56:06 2010
@@ -393,7 +393,7 @@
   if (BinaryOperator *BinOp = dyn_cast<BinaryOperator>(S)) {
     switch (BinOp->getOpcode()) {
 #define OPERATOR(NAME) \
-    case BO_##NAME: DISPATCH(Bin##PtrMemD, BinaryOperator, S);
+    case BO_##NAME: DISPATCH(Bin##NAME, BinaryOperator, S);
 
     BINOP_LIST()
 #undef OPERATOR


More information about the cfe-dev mailing list