Changeset d63eeb0 for src/ResolvExpr


Ignore:
Timestamp:
Feb 9, 2016, 3:25:05 PM (9 years ago)
Author:
Rob Schluntz <rschlunt@…>
Branches:
ADT, aaron-thesis, arm-eh, ast-experimental, cleanup-dtors, ctor, deferred_resn, demangler, enum, forall-pointer-decay, gc_noraii, jacob/cs343-translation, jenkins-sandbox, master, memory, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, resolv-new, with_gc
Children:
7528ba1
Parents:
771b3c3 (diff), bd85400 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge branch 'master' into ctor

Conflicts:

src/CodeGen/CodeGenerator.cc
src/GenPoly/Box.cc
src/Makefile.in
src/Parser/ParseNode.h
src/Parser/parser.cc
src/Parser/parser.yy
src/SymTab/Validate.cc
src/SynTree/Initializer.h
src/SynTree/ObjectDecl.cc
src/SynTree/Visitor.h
src/main.cc

Location:
src/ResolvExpr
Files:
8 edited

Legend:

Unmodified
Added
Removed
  • TabularUnified src/ResolvExpr/Alternative.cc

    r771b3c3 rd63eeb0  
    1717#include "SynTree/Type.h"
    1818#include "SynTree/Expression.h"
    19 #include "utility.h"
     19#include "Common/utility.h"
    2020
    2121namespace ResolvExpr {
  • TabularUnified src/ResolvExpr/AlternativeFinder.cc

    r771b3c3 rd63eeb0  
    3838#include "Tuples/TupleAssignment.h"
    3939#include "Tuples/NameMatcher.h"
    40 #include "utility.h"
     40#include "Common/utility.h"
    4141
    4242extern bool resolvep;
     
    811811        }
    812812
     813        template< typename StructOrUnionType >
     814        void AlternativeFinder::addOffsetof( StructOrUnionType *aggInst, const std::string &name ) {
     815                std::list< Declaration* > members;
     816                aggInst->lookup( name, members );
     817                for ( std::list< Declaration* >::const_iterator i = members.begin(); i != members.end(); ++i ) {
     818                        if ( DeclarationWithType *dwt = dynamic_cast< DeclarationWithType* >( *i ) ) {
     819                                alternatives.push_back( Alternative( new OffsetofExpr( aggInst->clone(), dwt->clone() ), env, Cost::zero ) );
     820                                renameTypes( alternatives.back().expr );
     821                        } else {
     822                                assert( false );
     823                        }
     824                }
     825        }
     826       
     827        void AlternativeFinder::visit( UntypedOffsetofExpr *offsetofExpr ) {
     828                AlternativeFinder funcFinder( indexer, env );
     829                if ( StructInstType *structInst = dynamic_cast< StructInstType* >( offsetofExpr->get_type() ) ) {
     830                        addOffsetof( structInst, offsetofExpr->get_member() );
     831                } else if ( UnionInstType *unionInst = dynamic_cast< UnionInstType* >( offsetofExpr->get_type() ) ) {
     832                        addOffsetof( unionInst, offsetofExpr->get_member() );
     833                }
     834        }
     835       
     836        void AlternativeFinder::visit( OffsetofExpr *offsetofExpr ) {
     837                alternatives.push_back( Alternative( offsetofExpr->clone(), env, Cost::zero ) );
     838        }
     839
    813840        void AlternativeFinder::resolveAttr( DeclarationWithType *funcDecl, FunctionType *function, Type *argType, const TypeEnvironment &env ) {
    814841                // assume no polymorphism
  • TabularUnified src/ResolvExpr/AlternativeFinder.h

    r771b3c3 rd63eeb0  
    5656                virtual void visit( ConstantExpr *constantExpr );
    5757                virtual void visit( SizeofExpr *sizeofExpr );
    58                 virtual void visit( AlignofExpr *sizeofExpr );
     58                virtual void visit( AlignofExpr *alignofExpr );
     59                virtual void visit( UntypedOffsetofExpr *offsetofExpr );
     60                virtual void visit( OffsetofExpr *offsetofExpr );
    5961                virtual void visit( AttrExpr *attrExpr );
    6062                virtual void visit( LogicalExpr *logicalExpr );
     
    6769
    6870          private:
     71                /// Adds alternatives for member expressions, given the aggregate, conversion cost for that aggregate, and name of the member
    6972                template< typename StructOrUnionType > void addAggMembers( StructOrUnionType *aggInst, Expression *expr, const Cost &newCost, const std::string &name );
     73                /// Adds alternatives for offsetof expressions, given the base type and name of the member
     74                template< typename StructOrUnionType > void addOffsetof( StructOrUnionType *aggInst, const std::string &name );
    7075                bool instantiateFunction( std::list< DeclarationWithType* >& formals, /*const*/ AltList &actuals, bool isVarArgs, OpenVarSet& openVars, TypeEnvironment &resultEnv, AssertionSet &resultNeed, AssertionSet &resultHave );
    7176                template< typename OutputIterator >
  • TabularUnified src/ResolvExpr/AlternativePrinter.cc

    r771b3c3 rd63eeb0  
    2020#include "SynTree/Type.h"
    2121#include "SynTree/Expression.h"
    22 #include "utility.h"
     22#include "Common/utility.h"
    2323
    2424namespace ResolvExpr {
  • TabularUnified src/ResolvExpr/Resolver.cc

    r771b3c3 rd63eeb0  
    2424#include "SynTree/Initializer.h"
    2525#include "SymTab/Indexer.h"
    26 #include "utility.h"
     26#include "Common/utility.h"
    2727
    2828#include <iostream>
  • TabularUnified src/ResolvExpr/TypeEnvironment.cc

    r771b3c3 rd63eeb0  
    2020#include "SynTree/Type.h"
    2121#include "SynTree/TypeSubstitution.h"
    22 #include "utility.h"
     22#include "Common/utility.h"
    2323
    2424namespace ResolvExpr {
  • TabularUnified src/ResolvExpr/Unify.cc

    r771b3c3 rd63eeb0  
    2525#include "SynTree/Declaration.h"
    2626#include "SymTab/Indexer.h"
    27 #include "utility.h"
     27#include "Common/utility.h"
    2828
    2929
  • TabularUnified src/ResolvExpr/Unify.h

    r771b3c3 rd63eeb0  
    2424#include "SymTab/Indexer.h"
    2525#include "TypeEnvironment.h"
    26 #include "utility.h"
     26#include "Common/utility.h"
    2727
    2828namespace ResolvExpr {
Note: See TracChangeset for help on using the changeset viewer.