scale.clef.expr
Class IncrementOp
java.lang.Object
   scale.common.Root
scale.common.Root
       scale.clef.Node
scale.clef.Node
           scale.clef.expr.Expression
scale.clef.expr.Expression
               scale.clef.expr.MonadicOp
scale.clef.expr.MonadicOp
                   scale.clef.expr.IncrementOp
scale.clef.expr.IncrementOp
- All Implemented Interfaces: 
- AnnotationInterface, DisplayNode
- Direct Known Subclasses: 
- PostDecrementOp, PostIncrementOp, PreDecrementOp, PreIncrementOp
- public abstract class IncrementOp 
- extends MonadicOp
This is the base class for all modify and replace operations such as x++.
 
 $Id: IncrementOp.java,v 1.23 2005-03-17 14:11:32 burrill Exp $
 
 Copyright 2005 by the Scale Compiler Group,
 Department of Computer Science
 University of Massachusetts,
 Amherst MA. 01003, USA
 All Rights Reserved.
 
| Method Summary | 
|  boolean | isSimpleOp()Return true if compilation of this expression will not result in
 the generation of a
 CFG node. | 
|  void | visit(Predicate p)Process a node by calling its associated routine.
 | 
 
 
| Methods inherited from class scale.clef.expr.Expression | 
| canonical, getConstantValue, getCoreType, getDisplayColorHint, getDisplayLabel, getDisplayShapeHint, getPointedToCore, getType, hasTrueFalseResult, setType, toStringSpecial | 
 
 
| Methods inherited from class scale.common.Root | 
| addAnnotation, allAnnotations, allMatchingAnnotations, getAnnotation, getDisplayName, getDisplayString, getNodeCount, getNodeID, hasAnnotation, hasEqualAnnotation, hashCode, removeAnnotation, removeAnnotations, toStringAnnotations, toStringClass, trace, trace, trace | 
 
| Methods inherited from class java.lang.Object | 
| clone, equals, finalize, getClass, notify, notifyAll, wait, wait, wait | 
 
IncrementOp
public IncrementOp(Type type,
                   Expression e)
isSimpleOp
public boolean isSimpleOp()
- Description copied from class: Expression
- Return true if compilation of this expression will not result in
 the generation of a CFG node.
 For example,(a && b)may require abranchto represent andi++requires astore.
 
- 
- Overrides:
- isSimpleOpin class- MonadicOp
 
- 
 
visit
public void visit(Predicate p)
- Description copied from class: Node
- Process a node by calling its associated routine.
 See the "visitor" design pattern in Design Patterns:
 Elements of Reusable Object-Oriented Software by E. Gamma,
 et al, Addison Wesley, ISBN 0-201-63361-2.
 
 Each class has a visit(Predicate p)method.  For
 example, inclass ABC:
 
   public void visit(Predicate p)
   {
     p.visitABC(this);
   }
 and the class that implementsPredicatehas a method
   public void visitABC(Node n)
   {
     ABC a = (ABC) n;
     ...
   }
 Thus, the class that implementsPredicatecan call
   n.visit(this);
  wherenis aNodesub-class without
 determining which specific sub-classnis.
 The visit pattern basically avoids implementing a largeswitchstatement or defining different methods
 in each class for some purpose.
 
- 
- Overrides:
- visitin class- MonadicOp
 
- 
- See Also:
- Predicate