source: src/MakeLibCfa.cc @ 843054c2

aaron-thesisarm-ehcleanup-dtorsctordeferred_resndemanglergc_noraiijacob/cs343-translationjenkins-sandboxmemorynew-astnew-ast-unique-exprnew-envno_listpersistent-indexerresolv-newstringwith_gc
Last change on this file since 843054c2 was 843054c2, checked in by Peter A. Buhr <pabuhr@…>, 7 years ago

licencing: seventh groups of files

  • Property mode set to 100644
File size: 3.5 KB
Line 
1//
2// Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
7// MakeLibCfa.cc --
8//
9// Author           : Richard C. Bilson
10// Created On       : Sat May 16 10:33:33 2015
11// Last Modified By : Peter A. Buhr
12// Last Modified On : Sat May 16 10:40:44 2015
13// Update Count     : 13
14//
15
16#include "MakeLibCfa.h"
17#include "SynTree/Visitor.h"
18#include "SynTree/Declaration.h"
19#include "SynTree/Type.h"
20#include "SynTree/Expression.h"
21#include "SynTree/Statement.h"
22#include "SynTree/Initializer.h"
23#include "CodeGen/OperatorTable.h"
24#include "UniqueName.h"
25
26namespace LibCfa {
27        class MakeLibCfa : public Visitor {
28          public:
29                void visit( FunctionDecl* funcDecl );
30                void visit( ObjectDecl* objDecl );
31 
32                std::list< Declaration* > &get_newDecls() { return newDecls; }
33          private:
34                std::list< Declaration* > newDecls;
35        };
36
37        void makeLibCfa( std::list< Declaration* > &prelude ) {
38                MakeLibCfa maker;
39                acceptAll( prelude, maker );
40                prelude.splice( prelude.end(), maker.get_newDecls() );
41        }
42
43        void MakeLibCfa::visit( FunctionDecl* origFuncDecl ) {
44                if ( origFuncDecl->get_linkage() != LinkageSpec::Intrinsic ) return;
45 
46                FunctionDecl *funcDecl = origFuncDecl->clone();
47                CodeGen::OperatorInfo opInfo;
48                bool lookResult = CodeGen::operatorLookup( funcDecl->get_name(), opInfo );
49                assert( lookResult );
50                assert( ! funcDecl->get_statements() );
51                UntypedExpr *newExpr = new UntypedExpr( new NameExpr( funcDecl->get_name() ) );
52                UniqueName paramNamer( "_p" );
53                std::list< DeclarationWithType* >::iterator param = funcDecl->get_functionType()->get_parameters().begin();
54                assert( param != funcDecl->get_functionType()->get_parameters().end() );
55
56                if ( (*param)->get_name() == "" ) {
57                        (*param)->set_name( paramNamer.newName() );
58                        (*param)->set_linkage( LinkageSpec::C );
59                } // if
60
61                switch ( opInfo.type ) {
62                  case CodeGen::OT_INDEX:
63                  case CodeGen::OT_CALL:
64                  case CodeGen::OT_PREFIX:
65                  case CodeGen::OT_POSTFIX:
66                  case CodeGen::OT_INFIX:
67                        newExpr->get_args().push_back( new VariableExpr( *param ) );
68                        break;
69                  case CodeGen::OT_PREFIXASSIGN:
70                  case CodeGen::OT_POSTFIXASSIGN:
71                  case CodeGen::OT_INFIXASSIGN:
72                        {
73                                newExpr->get_args().push_back( new VariableExpr( *param ) );
74                                // UntypedExpr *deref = new UntypedExpr( new NameExpr( "*?" ) );
75                                // deref->get_args().push_back( new VariableExpr( *param ) );
76                                // newExpr->get_args().push_back( deref );
77                                break;
78                        }
79                  case CodeGen::OT_CONSTANT:
80                        assert( false );
81                } // switch
82
83                for ( param++; param != funcDecl->get_functionType()->get_parameters().end(); ++param ) {
84                        if ( (*param)->get_name() == "" ) {
85                                (*param)->set_name( paramNamer.newName() );
86                                (*param)->set_linkage( LinkageSpec::C );
87                        }
88                        newExpr->get_args().push_back( new VariableExpr( *param ) );
89                } // for
90                funcDecl->set_statements( new CompoundStmt( std::list< Label >() ) );
91                funcDecl->get_statements()->get_kids().push_back( new ReturnStmt( std::list< Label >(), newExpr ) );
92                newDecls.push_back( funcDecl );
93        }
94
95        void MakeLibCfa::visit( ObjectDecl* origObjDecl ) {
96                if ( origObjDecl->get_linkage() != LinkageSpec::Intrinsic ) return;
97 
98                ObjectDecl *objDecl = origObjDecl->clone();
99                assert( ! objDecl->get_init() );
100                std::list< Expression* > noDesignators;
101                objDecl->set_init( new SingleInit( new NameExpr( objDecl->get_name() ), noDesignators ) );
102                newDecls.push_back( objDecl );
103        }
104} // namespace LibCfa
105
106// Local Variables: //
107// tab-width: 4 //
108// mode: c++ //
109// compile-command: "make install" //
110// End: //
Note: See TracBrowser for help on using the repository browser.