Changes in / [e58be8e:f2b2029]
- Location:
- src
- Files:
-
- 2 deleted
- 3 edited
-
GenPoly/DeclMutator.cc (deleted)
-
GenPoly/DeclMutator.h (deleted)
-
GenPoly/InstantiateGeneric.cc (modified) (13 diffs)
-
GenPoly/module.mk (modified) (1 diff)
-
Makefile.in (modified) (6 diffs)
Legend:
- Unmodified
- Added
- Removed
-
src/GenPoly/InstantiateGeneric.cc
re58be8e rf2b2029 5 5 // file "LICENCE" distributed with Cforall. 6 6 // 7 // InstantiateGeneric. cc--7 // InstantiateGeneric.h -- 8 8 // 9 9 // Author : Aaron B. Moss … … 21 21 22 22 #include "InstantiateGeneric.h" 23 #include " DeclMutator.h"23 #include "PolyMutator.h" 24 24 25 25 #include "ResolvExpr/typeops.h" … … 44 44 ConcreteType(const ConcreteType& that) : base(that.base), params() { cloneAll(that.params, params); } 45 45 46 /// Extracts types from a list of TypeExpr* 47 ConcreteType(AggregateDecl *_base, const std::list< TypeExpr* >& _params) : base(_base), params() { 48 for ( std::list< TypeExpr* >::const_iterator param = _params.begin(); param != _params.end(); ++param ) { 49 params.push_back( (*param)->get_type()->clone() ); 46 /// Extracts types from a list of Expression* (which should be TypeExpr*) 47 ConcreteType(AggregateDecl *_base, const std::list< Expression* >& _params) : base(_base), params() { 48 for ( std::list< Expression* >::const_iterator it = _params.begin(); it != _params.end(); ++it ) { 49 TypeExpr *param = dynamic_cast< TypeExpr* >(*it); 50 assert(param && "Aggregate parameters should be type expressions"); 51 params.push_back( param->get_type()->clone() ); 50 52 } 51 53 } … … 64 66 65 67 bool operator== (const ConcreteType& that) const { 68 SymTab::Indexer dummy; 69 66 70 if ( base != that.base ) return false; 67 68 SymTab::Indexer dummy;69 71 if ( params.size() != that.params.size() ) return false; 70 72 for ( std::list< Type* >::const_iterator it = params.begin(), jt = that.params.begin(); it != params.end(); ++it, ++jt ) { … … 80 82 /// Maps a concrete type to the instantiated struct type, accounting for scope 81 83 class InstantiationMap { 82 /// Instantiation of a generic type, with key information to find it 83 struct Instantiation { 84 ConcreteType key; ///< Instantiation parameters for this type 85 AggregateDecl *decl; ///< Declaration of the instantiated generic type 86 87 Instantiation() : key(), decl(0) {} 88 Instantiation(const ConcreteType &_key, AggregateDecl *_decl) : key(_key), decl(_decl) {} 89 }; 84 /// Pair of concrete type and declaration that instantiates it 85 typedef std::pair< ConcreteType, AggregateDecl* > Instantiation; 90 86 /// Map of generic types to instantiations of them 91 87 typedef std::map< AggregateDecl*, std::vector< Instantiation > > Scope; … … 111 107 /// Gets the declaration for the concrete instantiation of this type, assuming it has already been instantiated in the current scope. 112 108 /// Returns NULL on none such. 113 AggregateDecl* lookup( AggregateDecl *generic, const std::list< TypeExpr* >& params ) {109 AggregateDecl* lookup( AggregateDecl *generic, std::list< Expression* >& params ) { 114 110 ConcreteType key(generic, params); 115 111 // scan scopes from innermost out … … 120 116 // look through instantiations for matches to concrete type 121 117 for ( std::vector< Instantiation >::const_iterator inst = insts->second.begin(); inst != insts->second.end(); ++inst ) { 122 if ( inst-> key == key ) return inst->decl;118 if ( inst->first == key ) return inst->second; 123 119 } 124 120 } … … 127 123 } 128 124 public: 129 StructDecl* lookup( StructInstType *inst , const std::list< TypeExpr* > &typeSubs ) { return (StructDecl*)lookup( inst->get_baseStruct(), typeSubs); }130 UnionDecl* lookup( UnionInstType *inst , const std::list< TypeExpr* > &typeSubs ) { return (UnionDecl*)lookup( inst->get_baseUnion(), typeSubs); }125 StructDecl* lookup( StructInstType *inst ) { return (StructDecl*)lookup( inst->get_baseStruct(), inst->get_parameters() ); } 126 UnionDecl* lookup( UnionInstType *inst ) { return (UnionDecl*)lookup( inst->get_baseUnion(), inst->get_parameters() ); } 131 127 132 128 private: 133 129 /// Adds a declaration for a concrete type to the current scope 134 void insert( AggregateDecl *generic, const std::list< TypeExpr* > ¶ms, AggregateDecl *decl ) {130 void insert( AggregateDecl *generic, std::list< Expression* >& params, AggregateDecl *decl ) { 135 131 ConcreteType key(generic, params); 136 scopes.back()[generic].push_back( Instantiation( key, decl ) );137 } 138 public: 139 void insert( StructInstType *inst, const std::list< TypeExpr* > &typeSubs, StructDecl *decl ) { insert( inst->get_baseStruct(), typeSubs, decl ); }140 void insert( UnionInstType *inst, const std::list< TypeExpr* > &typeSubs, UnionDecl *decl ) { insert( inst->get_baseUnion(), typeSubs, decl ); }132 scopes.back()[generic].push_back( std::make_pair( key, decl ) ); 133 } 134 public: 135 void insert( StructInstType *inst, StructDecl *decl ) { insert( inst->get_baseStruct(), inst->get_parameters(), decl ); } 136 void insert( UnionInstType *inst, UnionDecl *decl ) { insert( inst->get_baseUnion(), inst->get_parameters(), decl ); } 141 137 }; 142 138 143 139 /// Mutator pass that replaces concrete instantiations of generic types with actual struct declarations, scoped appropriately 144 class Instantiate : public DeclMutator {140 class Instantiate : public PolyMutator { 145 141 InstantiationMap instantiations; 146 142 UniqueName typeNamer; 147 143 148 144 public: 149 Instantiate() : DeclMutator(),instantiations(), typeNamer("_conc_") {}150 151 // virtual Declaration* mutate( StructDecl *aggregateDecl ); 152 // virtual Declaration* mutate( UnionDecl *aggregateDecl);153 145 Instantiate() : instantiations(), typeNamer("_conc_") {} 146 147 /// Mutates the whole translation unit, inserting new struct declarations as appropriate 148 void mutateAll( std::list< Declaration* >& translationUnit ); 149 154 150 virtual Type* mutate( StructInstType *inst ); 155 151 virtual Type* mutate( UnionInstType *inst ); … … 157 153 virtual void doBeginScope(); 158 154 virtual void doEndScope(); 155 156 private: 157 /// Adds a declaration to the current environment and the statements to add 158 void addDeclaration( AggregateDecl *decl ) { 159 std::list< Label > nolabels; 160 DeclStmt *stmt = new DeclStmt( nolabels, decl ); 161 PolyMutator::stmtsToAdd.push_back( stmt ); 162 } 159 163 }; 160 164 161 165 void instantiateGeneric( std::list< Declaration* >& translationUnit ) { 162 166 Instantiate instantiator; 163 instantiator.mutateDeclarationList( translationUnit ); 164 } 165 166 /// Makes substitutions of params into baseParams; returns true if all parameters substituted for a concrete type 167 bool makeSubstitutions( const std::list< TypeDecl* >& baseParams, const std::list< Expression* >& params, std::list< TypeExpr* >& out ) { 168 bool allConcrete = true; // will finish the substitution list even if they're not all concrete 169 170 // substitute concrete types for given parameters, and incomplete types for placeholders 171 std::list< TypeDecl* >::const_iterator baseParam = baseParams.begin(); 172 std::list< Expression* >::const_iterator param = params.begin(); 173 for ( ; baseParam != baseParams.end() && param != params.end(); ++baseParam, ++param ) { 174 switch ( (*baseParam)->get_kind() ) { 175 case TypeDecl::Any: { // any type is a valid substitution here; complete types can be used to instantiate generics 176 TypeExpr *paramType = dynamic_cast< TypeExpr* >( *param ); 177 assert(paramType && "Aggregate parameters should be type expressions"); 178 out.push_back( paramType->clone() ); 179 // check that the substituted type isn't a type variable itself 180 if ( dynamic_cast< TypeInstType* >( paramType->get_type() ) ) { 181 allConcrete = false; 182 } 183 break; 184 } 185 case TypeDecl::Dtype: // dtype can be consistently replaced with void [only pointers, which become void*] 186 out.push_back( new TypeExpr( new VoidType( Type::Qualifiers() ) ) ); 187 break; 188 case TypeDecl::Ftype: // pointer-to-ftype can be consistently replaced with void (*)(void) [similar to dtype] 189 out.push_back( new TypeExpr( new FunctionType( Type::Qualifiers(), false ) ) ); 190 break; 191 } 192 } 193 194 // if not enough parameters given, substitute remaining incomplete types for placeholders 195 for ( ; baseParam != baseParams.end(); ++baseParam ) { 196 switch ( (*baseParam)->get_kind() ) { 197 case TypeDecl::Any: // no more substitutions here, fail early 198 return false; 199 case TypeDecl::Dtype: // dtype can be consistently replaced with void [only pointers, which become void*] 200 out.push_back( new TypeExpr( new VoidType( Type::Qualifiers() ) ) ); 201 break; 202 case TypeDecl::Ftype: // pointer-to-ftype can be consistently replaced with void (*)(void) [similar to dtype] 203 out.push_back( new TypeExpr( new FunctionType( Type::Qualifiers(), false ) ) ); 204 break; 205 } 206 } 207 208 return allConcrete; 209 } 210 211 /// Substitutes types of members of in according to baseParams => typeSubs, appending the result to out 212 void substituteMembers( const std::list< Declaration* >& in, const std::list< TypeDecl* >& baseParams, const std::list< TypeExpr* >& typeSubs, 167 // mutateAll( translationUnit, instantiator ); 168 instantiator.mutateAll( translationUnit ); 169 } 170 171 void Instantiate::mutateAll( std::list< Declaration* >& translationUnit ) { 172 // below copied and modified from Mutator.h:mutateAll() 173 SemanticError errors; 174 for ( std::list< Declaration* >::iterator decl = translationUnit.begin(); decl != translationUnit.end(); ++decl ) { 175 try { 176 if ( *decl ) { 177 *decl = dynamic_cast< Declaration* >( (*decl)->acceptMutator( *this ) ); 178 assert( *decl ); 179 // account for missing top-level declarations 180 for ( std::list< Statement* >::const_iterator stmt = PolyMutator::stmtsToAdd.begin(); stmt != PolyMutator::stmtsToAdd.end(); ++stmt ) { 181 DeclStmt *declStmt = dynamic_cast< DeclStmt* >( *stmt ); 182 assert( declStmt ); 183 translationUnit.insert( decl, declStmt->get_decl() ); 184 } 185 PolyMutator::stmtsToAdd.clear(); 186 } // if 187 } catch( SemanticError &e ) { 188 errors.append( e ); 189 } // try 190 } // for 191 if ( ! errors.isEmpty() ) { 192 throw errors; 193 } // if 194 } 195 196 /// Substitutes types of members of in according to baseParams => params, appending the result to out 197 void substituteMembers( const std::list< Declaration* >& in, 198 const std::list< TypeDecl * >& baseParams, const std::list< Expression* >& params, 213 199 std::list< Declaration* >& out ) { 214 200 // substitute types into new members 215 TypeSubstitution subs( baseParams.begin(), baseParams.end(), typeSubs.begin() );201 TypeSubstitution subs( baseParams.begin(), baseParams.end(), params.begin() ); 216 202 for ( std::list< Declaration* >::const_iterator member = in.begin(); member != in.end(); ++member ) { 217 203 Declaration *newMember = (*member)->clone(); … … 229 215 // exit early if no need for further mutation 230 216 if ( inst->get_parameters().empty() ) return inst; 231 assert( inst->get_baseParameters() && "Base struct has parameters" );232 233 // check if type can be concretely instantiated; put substitutions into typeSubs234 std::list< TypeExpr* > typeSubs;235 if ( ! makeSubstitutions( *inst->get_baseParameters(), inst->get_parameters(), typeSubs ) ) {236 deleteAll( typeSubs );237 return inst;238 }239 217 240 218 // make concrete instantiation of generic type 241 StructDecl *concDecl = instantiations.lookup( inst , typeSubs);219 StructDecl *concDecl = instantiations.lookup( inst ); 242 220 if ( ! concDecl ) { 221 assert( inst->get_baseParameters() && "Base struct has parameters" ); 243 222 // set concDecl to new type, insert type declaration into statements to add 244 223 concDecl = new StructDecl( typeNamer.newName( inst->get_name() ) ); 245 substituteMembers( inst->get_baseStruct()->get_members(), *inst->get_baseParameters(), typeSubs, concDecl->get_members() ); 246 DeclMutator::addDeclaration( concDecl ); 247 instantiations.insert( inst, typeSubs, concDecl ); 224 substituteMembers( inst->get_baseStruct()->get_members(), 225 *inst->get_baseParameters(), inst->get_parameters(), 226 concDecl->get_members() ); 227 addDeclaration( concDecl ); 228 instantiations.insert( inst, concDecl ); 248 229 } 249 230 StructInstType *newInst = new StructInstType( inst->get_qualifiers(), concDecl->get_name() ); 250 231 newInst->set_baseStruct( concDecl ); 251 252 deleteAll( typeSubs );253 232 delete inst; 254 233 return newInst; … … 263 242 // exit early if no need for further mutation 264 243 if ( inst->get_parameters().empty() ) return inst; 265 assert( inst->get_baseParameters() && "Base union has parameters" ); 266 267 // check if type can be concretely instantiated; put substitutions into typeSubs 268 std::list< TypeExpr* > typeSubs; 269 if ( ! makeSubstitutions( *inst->get_baseParameters(), inst->get_parameters(), typeSubs ) ) { 270 deleteAll( typeSubs ); 271 return inst; 272 } 273 244 274 245 // make concrete instantiation of generic type 275 UnionDecl *concDecl = instantiations.lookup( inst , typeSubs);246 UnionDecl *concDecl = instantiations.lookup( inst ); 276 247 if ( ! concDecl ) { 277 248 // set concDecl to new type, insert type declaration into statements to add 249 assert( inst->get_baseParameters() && "Base union has parameters" ); 278 250 concDecl = new UnionDecl( typeNamer.newName( inst->get_name() ) ); 279 substituteMembers( inst->get_baseUnion()->get_members(), *inst->get_baseParameters(), typeSubs, concDecl->get_members() ); 280 DeclMutator::addDeclaration( concDecl ); 281 instantiations.insert( inst, typeSubs, concDecl ); 251 substituteMembers( inst->get_baseUnion()->get_members(), 252 *inst->get_baseParameters(), inst->get_parameters(), 253 concDecl->get_members() ); 254 addDeclaration( concDecl ); 255 instantiations.insert( inst, concDecl ); 282 256 } 283 257 UnionInstType *newInst = new UnionInstType( inst->get_qualifiers(), concDecl->get_name() ); 284 258 newInst->set_baseUnion( concDecl ); 285 286 deleteAll( typeSubs );287 259 delete inst; 288 260 return newInst; … … 290 262 291 263 void Instantiate::doBeginScope() { 292 DeclMutator::doBeginScope();293 264 // push a new concrete type scope 294 265 instantiations.beginScope(); … … 296 267 297 268 void Instantiate::doEndScope() { 298 DeclMutator::doEndScope();299 269 // pop the last concrete type scope 300 270 instantiations.endScope(); -
src/GenPoly/module.mk
re58be8e rf2b2029 23 23 GenPoly/CopyParams.cc \ 24 24 GenPoly/FindFunction.cc \ 25 GenPoly/InstantiateGeneric.cc \ 26 GenPoly/DeclMutator.cc 25 GenPoly/InstantiateGeneric.cc -
src/Makefile.in
re58be8e rf2b2029 122 122 GenPoly/cfa_cpp-FindFunction.$(OBJEXT) \ 123 123 GenPoly/cfa_cpp-InstantiateGeneric.$(OBJEXT) \ 124 GenPoly/cfa_cpp-DeclMutator.$(OBJEXT) \125 124 InitTweak/cfa_cpp-InitModel.$(OBJEXT) \ 126 125 InitTweak/cfa_cpp-InitExpander.$(OBJEXT) \ … … 349 348 GenPoly/ScrubTyVars.cc GenPoly/Lvalue.cc GenPoly/Specialize.cc \ 350 349 GenPoly/CopyParams.cc GenPoly/FindFunction.cc \ 351 GenPoly/InstantiateGeneric.cc GenPoly/DeclMutator.cc \ 352 InitTweak/InitModel.cc InitTweak/InitExpander.cc \ 353 InitTweak/Mutate.cc InitTweak/Association.cc \ 354 InitTweak/RemoveInit.cc Parser/parser.yy Parser/lex.ll \ 355 Parser/TypedefTable.cc Parser/ParseNode.cc \ 356 Parser/DeclarationNode.cc Parser/ExpressionNode.cc \ 357 Parser/StatementNode.cc Parser/InitializerNode.cc \ 358 Parser/TypeData.cc Parser/LinkageSpec.cc \ 359 Parser/parseutility.cc Parser/Parser.cc \ 350 GenPoly/InstantiateGeneric.cc InitTweak/InitModel.cc \ 351 InitTweak/InitExpander.cc InitTweak/Mutate.cc \ 352 InitTweak/Association.cc InitTweak/RemoveInit.cc \ 353 Parser/parser.yy Parser/lex.ll Parser/TypedefTable.cc \ 354 Parser/ParseNode.cc Parser/DeclarationNode.cc \ 355 Parser/ExpressionNode.cc Parser/StatementNode.cc \ 356 Parser/InitializerNode.cc Parser/TypeData.cc \ 357 Parser/LinkageSpec.cc Parser/parseutility.cc Parser/Parser.cc \ 360 358 ResolvExpr/AlternativeFinder.cc ResolvExpr/Alternative.cc \ 361 359 ResolvExpr/Unify.cc ResolvExpr/PtrsAssignable.cc \ … … 558 556 GenPoly/$(DEPDIR)/$(am__dirstamp) 559 557 GenPoly/cfa_cpp-InstantiateGeneric.$(OBJEXT): GenPoly/$(am__dirstamp) \ 560 GenPoly/$(DEPDIR)/$(am__dirstamp)561 GenPoly/cfa_cpp-DeclMutator.$(OBJEXT): GenPoly/$(am__dirstamp) \562 558 GenPoly/$(DEPDIR)/$(am__dirstamp) 563 559 InitTweak/$(am__dirstamp): … … 789 785 -rm -f GenPoly/cfa_cpp-Box.$(OBJEXT) 790 786 -rm -f GenPoly/cfa_cpp-CopyParams.$(OBJEXT) 791 -rm -f GenPoly/cfa_cpp-DeclMutator.$(OBJEXT)792 787 -rm -f GenPoly/cfa_cpp-FindFunction.$(OBJEXT) 793 788 -rm -f GenPoly/cfa_cpp-GenPoly.$(OBJEXT) … … 900 895 @AMDEP_TRUE@@am__include@ @am__quote@GenPoly/$(DEPDIR)/cfa_cpp-Box.Po@am__quote@ 901 896 @AMDEP_TRUE@@am__include@ @am__quote@GenPoly/$(DEPDIR)/cfa_cpp-CopyParams.Po@am__quote@ 902 @AMDEP_TRUE@@am__include@ @am__quote@GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Po@am__quote@903 897 @AMDEP_TRUE@@am__include@ @am__quote@GenPoly/$(DEPDIR)/cfa_cpp-FindFunction.Po@am__quote@ 904 898 @AMDEP_TRUE@@am__include@ @am__quote@GenPoly/$(DEPDIR)/cfa_cpp-GenPoly.Po@am__quote@ … … 1382 1376 @am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(cfa_cpp_CXXFLAGS) $(CXXFLAGS) -c -o GenPoly/cfa_cpp-InstantiateGeneric.obj `if test -f 'GenPoly/InstantiateGeneric.cc'; then $(CYGPATH_W) 'GenPoly/InstantiateGeneric.cc'; else $(CYGPATH_W) '$(srcdir)/GenPoly/InstantiateGeneric.cc'; fi` 1383 1377 1384 GenPoly/cfa_cpp-DeclMutator.o: GenPoly/DeclMutator.cc1385 @am__fastdepCXX_TRUE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(cfa_cpp_CXXFLAGS) $(CXXFLAGS) -MT GenPoly/cfa_cpp-DeclMutator.o -MD -MP -MF GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Tpo -c -o GenPoly/cfa_cpp-DeclMutator.o `test -f 'GenPoly/DeclMutator.cc' || echo '$(srcdir)/'`GenPoly/DeclMutator.cc1386 @am__fastdepCXX_TRUE@ $(am__mv) GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Tpo GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Po1387 @AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='GenPoly/DeclMutator.cc' object='GenPoly/cfa_cpp-DeclMutator.o' libtool=no @AMDEPBACKSLASH@1388 @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@1389 @am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(cfa_cpp_CXXFLAGS) $(CXXFLAGS) -c -o GenPoly/cfa_cpp-DeclMutator.o `test -f 'GenPoly/DeclMutator.cc' || echo '$(srcdir)/'`GenPoly/DeclMutator.cc1390 1391 GenPoly/cfa_cpp-DeclMutator.obj: GenPoly/DeclMutator.cc1392 @am__fastdepCXX_TRUE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(cfa_cpp_CXXFLAGS) $(CXXFLAGS) -MT GenPoly/cfa_cpp-DeclMutator.obj -MD -MP -MF GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Tpo -c -o GenPoly/cfa_cpp-DeclMutator.obj `if test -f 'GenPoly/DeclMutator.cc'; then $(CYGPATH_W) 'GenPoly/DeclMutator.cc'; else $(CYGPATH_W) '$(srcdir)/GenPoly/DeclMutator.cc'; fi`1393 @am__fastdepCXX_TRUE@ $(am__mv) GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Tpo GenPoly/$(DEPDIR)/cfa_cpp-DeclMutator.Po1394 @AMDEP_TRUE@@am__fastdepCXX_FALSE@ source='GenPoly/DeclMutator.cc' object='GenPoly/cfa_cpp-DeclMutator.obj' libtool=no @AMDEPBACKSLASH@1395 @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@1396 @am__fastdepCXX_FALSE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(cfa_cpp_CXXFLAGS) $(CXXFLAGS) -c -o GenPoly/cfa_cpp-DeclMutator.obj `if test -f 'GenPoly/DeclMutator.cc'; then $(CYGPATH_W) 'GenPoly/DeclMutator.cc'; else $(CYGPATH_W) '$(srcdir)/GenPoly/DeclMutator.cc'; fi`1397 1398 1378 InitTweak/cfa_cpp-InitModel.o: InitTweak/InitModel.cc 1399 1379 @am__fastdepCXX_TRUE@ $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(cfa_cpp_CXXFLAGS) $(CXXFLAGS) -MT InitTweak/cfa_cpp-InitModel.o -MD -MP -MF InitTweak/$(DEPDIR)/cfa_cpp-InitModel.Tpo -c -o InitTweak/cfa_cpp-InitModel.o `test -f 'InitTweak/InitModel.cc' || echo '$(srcdir)/'`InitTweak/InitModel.cc
Note:
See TracChangeset
for help on using the changeset viewer.