expression_logical_not_pretty Class Reference

#include <pretty.h>

Inheritance diagram for expression_logical_not_pretty:

expression_logical_not expression List of all members.

Public Member Functions

virtual ~expression_logical_not_pretty ()
 expression_logical_not_pretty (const expression::pointer &operand, translator_pretty *cntxt)

Protected Member Functions

void pre_order_traversal (int pprec)
void post_order_traversal (int pprec)
expression::pointer optimize () const

Private Member Functions

 expression_logical_not_pretty ()
 expression_logical_not_pretty (const expression_logical_not_pretty &)
expression_logical_not_prettyoperator= (const expression_logical_not_pretty &)

Private Attributes

translator_prettypretty

Detailed Description

The expression_logical_not_pretty class is used to represent pretty printing a logical NOT expression.

Definition at line 32 of file pretty.h.


Constructor & Destructor Documentation

virtual expression_logical_not_pretty::~expression_logical_not_pretty (  )  [virtual]

The destructor.

expression_logical_not_pretty::expression_logical_not_pretty ( const expression::pointer operand,
translator_pretty cntxt 
)

The constructor.

expression_logical_not_pretty::expression_logical_not_pretty (  )  [private]

The default constructor.

expression_logical_not_pretty::expression_logical_not_pretty ( const expression_logical_not_pretty  )  [private]

The copy constructor.


Member Function Documentation

void expression_logical_not_pretty::pre_order_traversal ( int  pprec  )  [protected, virtual]

The pre_order_traversal method is called before the argument is traversed, by the traversal method.

Reimplemented from expression_logical_not.

void expression_logical_not_pretty::post_order_traversal ( int  pprec  )  [protected, virtual]

The post_order_traversal method is called after the argument is traversed, by the traversal method.

Reimplemented from expression_logical_not.

expression::pointer expression_logical_not_pretty::optimize (  )  const [protected, virtual]

The optimize method may be used to evaluate constant expressions, or substitute more efficient expressions.

This is intended to be called by the translator:: expression_statement method, or similar, where the expression is in its final form, and will get no deeper. In other words, when all available information has been provided.

There is no default implementation, even though most optimize implementations return self(), because this gives the compiler no opportunity to remind the authors of new classes that they have forgotten something.

Returns:
If the expression tree is not constant, or it is already as reduced as it can get, it returns itself. Otherwise, it returns a new expression node.

Implements expression.

expression_logical_not_pretty& expression_logical_not_pretty::operator= ( const expression_logical_not_pretty  )  [private]

The assignment operator.


Member Data Documentation

translator_pretty& expression_logical_not_pretty::pretty [private]

The pretty instance variable is used to remember where to send our beautified source code.

Definition at line 62 of file pretty.h.


The documentation for this class was generated from the following file:
Generated on Sun Feb 25 01:27:12 2007 for UCSDp-SystemCrossCompiler by  doxygen 1.5.1