Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/SynTree/TupleExpr.cc

    r3c13c03 rd3b7937  
    55// file "LICENCE" distributed with Cforall.
    66//
    7 // TupleExpr.cc --
     7// TupleExpr.cc -- 
    88//
    99// Author           : Richard C. Bilson
     
    1616#include "Expression.h"
    1717#include "Common/utility.h"
    18 #include "Type.h"
    19 #include "Declaration.h"
    20 #include "Tuples/Tuples.h"
    2118
    22 TupleExpr::TupleExpr( const std::list< Expression * > & exprs, Expression *_aname ) : Expression( _aname ), exprs( exprs ) {
    23         if ( ! exprs.empty() ) {
    24                 if ( std::all_of( exprs.begin(), exprs.end(), [](Expression * expr) { return expr->get_result(); } ) ) {
    25                         set_result( Tuples::makeTupleType( exprs ) );
    26                 }
    27         }
     19TupleExpr::TupleExpr( Expression *_aname ) : Expression( _aname ) {
    2820}
    2921
     
    3729
    3830void TupleExpr::print( std::ostream &os, int indent ) const {
    39         os << "Tuple:" << std::endl;
     31        os << std::string( indent, ' ' ) << "Tuple:" << std::endl;
    4032        printAll( exprs, os, indent+2 );
    4133        Expression::print( os, indent );
    4234}
    4335
    44 TupleIndexExpr::TupleIndexExpr( Expression * tuple, unsigned int index ) : tuple( tuple ), index( index )  {
    45         TupleType * type = safe_dynamic_cast< TupleType * >( tuple->get_result() );
    46         assert( type->size() > index );
    47         set_result( (*std::next( type->get_types().begin(), index ))->clone() );
     36SolvedTupleExpr::SolvedTupleExpr( std::list<Expression *> &_exprs, Expression *_aname ) : Expression( _aname ) {
     37        std::copy(_exprs.begin(), _exprs.end(), back_inserter(exprs));
    4838}
    4939
    50 TupleIndexExpr::TupleIndexExpr( const TupleIndexExpr &other ) : Expression( other ), tuple( other.tuple->clone() ), index( other.index ) {
     40SolvedTupleExpr::SolvedTupleExpr( const SolvedTupleExpr &other ) : Expression( other ) {
     41        cloneAll( other.exprs, exprs );
    5142}
    5243
    53 TupleIndexExpr::~TupleIndexExpr() {
    54         delete tuple;
    55 }
    56 
    57 void TupleIndexExpr::print( std::ostream &os, int indent ) const {
    58         os << "Tuple Index Expression, with tuple:" << std::endl;
    59         os << std::string( indent+2, ' ' );
    60         tuple->print( os, indent+2 );
    61         os << std::string( indent+2, ' ' ) << "with index: " << index << std::endl;
     44void SolvedTupleExpr::print( std::ostream &os, int indent ) const {
     45        os << std::string( indent, ' ' ) << "Solved Tuple:" << std::endl;
     46        printAll( exprs, os, indent+2 );
    6247        Expression::print( os, indent );
    6348}
    64 
    65 MemberTupleExpr::MemberTupleExpr( Expression * member, Expression * aggregate, Expression * _aname ) : Expression( _aname ) {
    66         set_result( maybeClone( member->get_result() ) ); // xxx - ???
    67 }
    68 
    69 MemberTupleExpr::MemberTupleExpr( const MemberTupleExpr &other ) : Expression( other ), member( other.member->clone() ), aggregate( other.aggregate->clone() ) {
    70 }
    71 
    72 MemberTupleExpr::~MemberTupleExpr() {
    73         delete member;
    74         delete aggregate;
    75 }
    76 
    77 void MemberTupleExpr::print( std::ostream &os, int indent ) const {
    78         os << "Member Tuple Expression, with aggregate:" << std::endl;
    79         os << std::string( indent+2, ' ' );
    80         aggregate->print( os, indent+2 );
    81         os << std::string( indent+2, ' ' ) << "with member: " << std::endl;
    82         os << std::string( indent+2, ' ' );
    83         member->print( os, indent+2 );
    84         Expression::print( os, indent );
    85 }
    86 
    87 
    88 TupleAssignExpr::TupleAssignExpr( const std::list< Expression * > & assigns, const std::list< ObjectDecl * > & tempDecls, Expression * _aname ) : Expression( _aname ), assigns( assigns ), tempDecls( tempDecls ) {
    89         TupleType * type = new TupleType( Type::Qualifiers() );
    90         for ( Expression * expr : assigns ) {
    91                 assert( expr->has_result() );
    92                 type->get_types().push_back( expr->get_result()->clone() );
    93         }
    94         set_result( type );
    95 }
    96 
    97 TupleAssignExpr::TupleAssignExpr( const TupleAssignExpr &other ) : Expression( other ), tempDecls( other.tempDecls ) /* temporary */ {
    98         cloneAll( other.assigns, assigns );
    99         // xxx - clone needs to go into assigns and replace tempDecls
    100 }
    101 
    102 TupleAssignExpr::~TupleAssignExpr() {
    103         deleteAll( assigns );
    104         // deleteAll( tempDecls );
    105 }
    106 
    107 void TupleAssignExpr::print( std::ostream &os, int indent ) const {
    108         os << "Tuple Assignment Expression, with temporaries:" << std::endl;
    109         printAll( tempDecls, os, indent+4 );
    110         os << std::string( indent+2, ' ' ) << "with assignments: " << std::endl;
    111         printAll( assigns, os, indent+4 );
    112         Expression::print( os, indent );
    113 }
    114 
    115 
    11649
    11750// Local Variables: //
Note: See TracChangeset for help on using the changeset viewer.