void\r
MingwModuleHandler::GenerateGccModuleIncludeVariable ( const Module& module ) const\r
{\r
+#if 0\r
string name ( module.name + "_CFLAGS" );\r
fprintf ( fMakefile,\r
"%s := %s %s\n",\r
name.c_str(),\r
- GenerateGccDefineParameters(module).c_str(),\r
+ GenerateGccDefineParameters(module).c_str(),\r
GenerateGccIncludeParameters(module).c_str() );\r
+#endif\r
}\r
\r
string\r
return parameters;\r
}\r
\r
-string\r
-MingwModuleHandler::GenerateGccParameters ( const Module& module ) const\r
+void\r
+MingwModuleHandler::GenerateMacros (\r
+ const Module& module,\r
+ const char* op,\r
+ const vector<File*>& files,\r
+ const vector<Include*>* includes,\r
+ const vector<Define*>& defines,\r
+ const vector<If*>* ifs,\r
+ const string& cflags_macro,\r
+ const string& nasmflags_macro,\r
+ const string& objs_macro) const\r
{\r
- return ssprintf(" $(%s_CFLAGS)", module.name.c_str());\r
+ size_t i;\r
+\r
+ if ( (includes && includes->size()) || defines.size() )\r
+ {\r
+ fprintf (\r
+ fMakefile,\r
+ "%s %s",\r
+ cflags_macro.c_str(),\r
+ op );\r
+ if ( includes )\r
+ for ( i = 0; i < includes->size(); i++ )\r
+ fprintf (\r
+ fMakefile,\r
+ " -I%s",\r
+ (*includes)[i]->directory.c_str() );\r
+ for ( i = 0; i < module.defines.size(); i++ )\r
+ {\r
+ Define& d = *module.defines[i];\r
+ fprintf (\r
+ fMakefile,\r
+ " -D%s",\r
+ d.name.c_str() );\r
+ if ( d.value.size() )\r
+ fprintf (\r
+ fMakefile,\r
+ "=%s",\r
+ d.value.c_str() );\r
+ }\r
+ fprintf ( fMakefile, "\n" );\r
+ }\r
+\r
+ if ( files.size() )\r
+ {\r
+ fprintf (\r
+ fMakefile,\r
+ "%s %s",\r
+ objs_macro.c_str(),\r
+ op );\r
+ for ( i = 0; i < files.size(); i++ )\r
+ {\r
+ fprintf (\r
+ fMakefile,\r
+ "%s%s",\r
+ ( i%10 == 9 ? "\\\n\t" : " " ),\r
+ GetObjectFilename(files[i]->name).c_str() );\r
+ }\r
+ fprintf ( fMakefile, "\n" );\r
+ }\r
+\r
+ if ( ifs && ifs->size() )\r
+ {\r
+ for ( size_t i = 0; i < module.ifs.size(); i++ )\r
+ {\r
+ If& rIf = *(*ifs)[i];\r
+ if ( rIf.defines.size() || rIf.files.size() || rIf.ifs.size() )\r
+ {\r
+ fprintf (\r
+ fMakefile,\r
+ "ifeq ($(%s),\"%s\")\n",\r
+ rIf.property.c_str(),\r
+ rIf.value.c_str() );\r
+ GenerateMacros (\r
+ module,\r
+ "+=",\r
+ rIf.files,\r
+ NULL,\r
+ rIf.defines,\r
+ &rIf.ifs,\r
+ cflags_macro,\r
+ nasmflags_macro,\r
+ objs_macro );\r
+ fprintf ( \r
+ fMakefile,\r
+ "endif\n\n" );\r
+ }\r
+ }\r
+ }\r
}\r
\r
-string\r
-MingwModuleHandler::GenerateNasmParameters ( const Module& module ) const\r
-{\r
- return "";\r
+void\r
+MingwModuleHandler::GenerateMacros (\r
+ const Module& module,\r
+ const string& cflags_macro,\r
+ const string& nasmflags_macro,\r
+ const string& objs_macro) const\r
+{\r
+ GenerateMacros (\r
+ module,\r
+ "=",\r
+ module.files,\r
+ &module.includes,\r
+ module.defines,\r
+ NULL,\r
+ cflags_macro,\r
+ nasmflags_macro,\r
+ objs_macro );\r
+ fprintf ( fMakefile, "\n" );\r
+\r
+ for ( size_t i = 0; i < module.ifs.size(); i++ )\r
+ {\r
+ If& rIf = *module.ifs[i];\r
+ if ( rIf.defines.size() || rIf.files.size() || rIf.ifs.size() )\r
+ {\r
+ fprintf (\r
+ fMakefile,\r
+ "ifeq ($(%s),\"%s\")\n",\r
+ rIf.property.c_str(),\r
+ rIf.value.c_str() );\r
+ GenerateMacros (\r
+ module,\r
+ "+=",\r
+ rIf.files,\r
+ NULL,\r
+ rIf.defines,\r
+ &rIf.ifs,\r
+ cflags_macro,\r
+ nasmflags_macro,\r
+ objs_macro );\r
+ fprintf ( \r
+ fMakefile,\r
+ "endif\n\n" );\r
+ }\r
+ }\r
}\r
\r
string\r
MingwModuleHandler::GenerateGccCommand ( const Module& module,\r
- const string& sourceFilename,\r
- const string& cc ) const\r
+ const string& sourceFilename,\r
+ const string& cc,\r
+ const string& cflagsMacro ) const\r
{\r
string objectFilename = GetObjectFilename ( sourceFilename );\r
return ssprintf ( "%s -c %s -o %s %s\n",\r
cc.c_str (),\r
sourceFilename.c_str (),\r
objectFilename.c_str (),\r
- GenerateGccParameters ( module ).c_str () );\r
+ cflagsMacro.c_str () );\r
}\r
\r
string\r
MingwModuleHandler::GenerateGccAssemblerCommand ( const Module& module,\r
- const string& sourceFilename,\r
- const string& cc ) const\r
+ const string& sourceFilename,\r
+ const string& cc,\r
+ const string& cflagsMacro ) const\r
{\r
string objectFilename = GetObjectFilename ( sourceFilename );\r
return ssprintf ( "%s -x assembler-with-cpp -c %s -o %s -D__ASM__ %s\n",\r
- cc.c_str (),\r
- sourceFilename.c_str (),\r
- objectFilename.c_str (),\r
- GenerateGccParameters ( module ).c_str () );\r
+ cc.c_str (),\r
+ sourceFilename.c_str (),\r
+ objectFilename.c_str (),\r
+ cflagsMacro.c_str () );\r
}\r
\r
string\r
MingwModuleHandler::GenerateNasmCommand ( const Module& module,\r
- const string& sourceFilename ) const\r
+ const string& sourceFilename,\r
+ const string& nasmflagsMacro ) const\r
{\r
string objectFilename = GetObjectFilename ( sourceFilename );\r
return ssprintf ( "%s -f win32 %s -o %s %s\n",\r
"nasm",\r
sourceFilename.c_str (),\r
objectFilename.c_str (),\r
- GenerateNasmParameters ( module ).c_str () );\r
+ nasmflagsMacro.c_str () );\r
}\r
\r
string\r
MingwModuleHandler::GenerateCommand ( const Module& module,\r
- const string& sourceFilename,\r
- const string& cc ) const\r
+ const string& sourceFilename,\r
+ const string& cc,\r
+ const string& cflagsMacro,\r
+ const string& nasmflagsMacro ) const\r
{\r
string extension = GetExtension ( sourceFilename );\r
if ( extension == ".c" || extension == ".C" )\r
return GenerateGccCommand ( module,\r
sourceFilename,\r
- cc );\r
+ cc,\r
+ cflagsMacro );\r
else if ( extension == ".s" || extension == ".S" )\r
return GenerateGccAssemblerCommand ( module,\r
sourceFilename,\r
- cc );\r
+ cc,\r
+ cflagsMacro );\r
else if ( extension == ".asm" || extension == ".ASM" )\r
return GenerateNasmCommand ( module,\r
- sourceFilename );\r
+ sourceFilename,\r
+ nasmflagsMacro );\r
\r
throw InvalidOperationException ( __FILE__,\r
__LINE__,\r
\r
void\r
MingwModuleHandler::GenerateObjectFileTargets ( const Module& module,\r
- const string& cc) const\r
+ const vector<File*>& files,\r
+ const string& cc,\r
+ const string& cflagsMacro,\r
+ const string& nasmflagsMacro ) const\r
{\r
- if ( module.files.size () == 0 )\r
+ if ( files.size () == 0 )\r
return;\r
- \r
- GenerateGccModuleIncludeVariable ( module );\r
\r
- for ( size_t i = 0; i < module.files.size (); i++ )\r
+ for ( size_t i = 0; i < files.size (); i++ )\r
{\r
- string sourceFilename = module.files[i]->name;\r
+ string sourceFilename = files[i]->name;\r
string objectFilename = GetObjectFilename ( sourceFilename );\r
fprintf ( fMakefile,\r
"%s: %s\n",\r
"\t%s\n",\r
GenerateCommand ( module,\r
sourceFilename,\r
- cc ).c_str () );\r
+ cc,\r
+ cflagsMacro,\r
+ nasmflagsMacro ).c_str () );\r
}\r
\r
fprintf ( fMakefile, "\n" );\r
}\r
\r
void\r
-MingwModuleHandler::GenerateObjectFileTargetsHost ( const Module& module ) const\r
-{\r
- GenerateObjectFileTargets ( module,\r
- "${host_gcc}" );\r
-}\r
-\r
-void\r
-MingwModuleHandler::GenerateObjectFileTargetsTarget ( const Module& module ) const\r
+MingwModuleHandler::GenerateObjectFileTargets ( const Module& module,\r
+ const string& cc,\r
+ const string& cflagsMacro,\r
+ const string& nasmflagsMacro ) const\r
{\r
- GenerateObjectFileTargets ( module,\r
- "${gcc}" );\r
+ GenerateObjectFileTargets ( module, module.files, cc, cflagsMacro, nasmflagsMacro );\r
+ for ( size_t i = 0; i < module.ifs.size(); i++ )\r
+ GenerateObjectFileTargets ( module, module.ifs[i]->files, cc, cflagsMacro, nasmflagsMacro );\r
}\r
\r
void\r
MingwModuleHandler::GenerateArchiveTarget ( const Module& module,\r
- const string& ar ) const\r
+ const string& ar,\r
+ const string& objs_macro ) const\r
{\r
string archiveFilename = GetModuleArchiveFilename ( module );\r
string sourceFilenames = GetSourceFilenames ( module );\r
- string objectsMacro = GenerateObjectList ( module );\r
\r
fprintf ( fMakefile,\r
"%s: %s\n",\r
archiveFilename.c_str (),\r
- objectsMacro.c_str ());\r
+ objs_macro.c_str ());\r
\r
fprintf ( fMakefile,\r
"\t%s -rc %s %s\n\n",\r
ar.c_str (),\r
archiveFilename.c_str (),\r
- objectsMacro.c_str ());\r
+ objs_macro.c_str ());\r
}\r
\r
void\r
-MingwModuleHandler::GenerateArchiveTargetHost ( const Module& module ) const\r
+MingwModuleHandler::GenerateMacrosAndTargets (\r
+ const Module& module,\r
+ const string& cc,\r
+ const string& ar ) const\r
{\r
- GenerateArchiveTarget ( module,\r
- "${host_ar}" );\r
+ string cflagsMacro = ssprintf("%s_CFLAGS",module.name.c_str());\r
+ string nasmflagsMacro = ssprintf("%s_NASMFLAGS",module.name.c_str());\r
+ string objectsMacro = ssprintf("%s_OBJS",module.name.c_str());\r
+\r
+ GenerateMacros ( module, cflagsMacro, nasmflagsMacro, objectsMacro );\r
+\r
+ // future references to the macros will be to get their values\r
+ cflagsMacro = ssprintf("$(%s)",cflagsMacro.c_str());\r
+ nasmflagsMacro = ssprintf("$(%s)",nasmflagsMacro.c_str());\r
+ objectsMacro = ssprintf("$(%s)",objectsMacro.c_str());\r
+\r
+ GenerateArchiveTarget ( module, ar, objectsMacro );\r
+ GenerateObjectFileTargets ( module, cc, cflagsMacro, nasmflagsMacro );\r
}\r
\r
void\r
-MingwModuleHandler::GenerateArchiveTargetTarget ( const Module& module ) const\r
+MingwModuleHandler::GenerateMacrosAndTargetsHost ( const Module& module ) const\r
{\r
- GenerateArchiveTarget ( module,\r
- "${ar}" );\r
+ GenerateMacrosAndTargets ( module, "${host_gcc}", "${host_ar}" );\r
+}\r
+\r
+void\r
+MingwModuleHandler::GenerateMacrosAndTargetsTarget ( const Module& module ) const\r
+{\r
+ GenerateMacrosAndTargets ( module, "${gcc}", "${ar}" );\r
}\r
\r
string\r
dependencies += s;\r
}\r
\r
+ fprintf ( fMakefile,\r
+ ".PHONY: %s\n\n",\r
+ preconditionDependenciesName.c_str () );\r
fprintf ( fMakefile,\r
"%s: %s\n\n",\r
preconditionDependenciesName.c_str (),\r
dependencies.c_str () );\r
- fprintf ( fMakefile,\r
- "%s: %s\n\n",\r
- sourceFilenames.c_str (),\r
- preconditionDependenciesName.c_str ());\r
- fprintf ( fMakefile,\r
- ".PHONY: %s\n\n",\r
- preconditionDependenciesName.c_str () );\r
-}\r
-\r
-string MingwModuleHandler::GenerateObjectList ( const Module& module ) const\r
-{\r
- string macro ( ssprintf("%s_OBJS",module.name.c_str()) );\r
- fprintf (\r
- fMakefile,\r
- "%s = %s\n",\r
- macro.c_str(),\r
- GetObjectFilenames(module).c_str() );\r
- return ssprintf("$(%s)",macro.c_str());\r
+ const char* p = sourceFilenames.c_str();\r
+ const char* end = p + strlen(p);\r
+ while ( p < end )\r
+ {\r
+ const char* p2 = &p[512];\r
+ if ( p2 > end )\r
+ p2 = end;\r
+ while ( p2 > p && !isspace(*p2) )\r
+ --p2;\r
+ if ( p == p2 )\r
+ {\r
+ p2 = strpbrk ( p, " \t" );\r
+ if ( !p2 )\r
+ p2 = end;\r
+ }\r
+ fprintf ( fMakefile,\r
+ "%.*s: %s\n",\r
+ p2-p,\r
+ p,\r
+ preconditionDependenciesName.c_str ());\r
+ p = p2;\r
+ p += strspn ( p, " \t" );\r
+ }\r
+ fprintf ( fMakefile, "\n" );\r
}\r
\r
\r
target.c_str (),\r
archiveFilename.c_str () );\r
fprintf ( fMakefile,\r
- "\t${host_gcc} -o %s %s\n",\r
+ "\t${host_gcc} -o %s %s\n\n",\r
target.c_str (),\r
archiveFilename.c_str () );\r
- GenerateArchiveTargetHost ( module );\r
- GenerateObjectFileTargetsHost ( module );\r
+ GenerateMacrosAndTargetsHost ( module );\r
}\r
\r
static MingwKernelModuleHandler kernelmodule_handler;\r
archiveFilename.c_str (),\r
importLibraryDependencies.c_str () );\r
fprintf ( fMakefile,\r
- "\t${rm} %s\n",\r
+ "\t${rm} %s\n\n",\r
temp_exp.c_str () );\r
\r
- GenerateArchiveTargetTarget ( module );\r
- GenerateObjectFileTargetsTarget ( module );\r
+ GenerateMacrosAndTargetsTarget ( module );\r
}\r
\r
\r
void\r
MingwStaticLibraryModuleHandler::GenerateStaticLibraryModuleTarget ( const Module& module )\r
{\r
- GenerateArchiveTargetTarget ( module );\r
- GenerateObjectFileTargetsTarget ( module );\r
+ GenerateMacrosAndTargetsTarget ( module );\r
}\r
\r
\r
importLibraryDependencies.c_str () );\r
\r
fprintf ( fMakefile,\r
- "\t${gcc} -Wl,--subsystem,native -Wl,--entry,_DriverEntry@8 -Wl,--image-base,0x10000 -Wl,--file-alignment,0x1000 -Wl,--section-alignment,0x1000 -nostartfiles -mdll -o %s %s %s\n",\r
+ "\t${gcc} -Wl,--subsystem,native -Wl,--entry,_DriverEntry@8 -Wl,--image-base,0x10000 -Wl,--file-alignment,0x1000 -Wl,--section-alignment,0x1000 -nostartfiles -mdll -o %s %s %s\n\n",\r
target.c_str (),\r
archiveFilename.c_str (),\r
importLibraryDependencies.c_str () );\r
\r
- GenerateArchiveTargetTarget ( module );\r
- GenerateObjectFileTargetsTarget ( module );\r
+ GenerateMacrosAndTargetsTarget ( module );\r
}\r
else\r
{\r
- fprintf ( fMakefile, "%s:\n\n",\r
+ fprintf ( fMakefile, "%s:\n",\r
target.c_str ());\r
fprintf ( fMakefile, ".PHONY: %s\n\n",\r
target.c_str ());\r
importLibraryDependencies.c_str () );\r
\r
fprintf ( fMakefile,\r
- "\t${gcc} -Wl,--subsystem,native -Wl,--entry,_DllMainCRTStartup@12 -Wl,--image-base,0x10000 -Wl,--file-alignment,0x1000 -Wl,--section-alignment,0x1000 -nostartfiles -nostdlib -mdll -o %s %s %s\n",\r
+ "\t${gcc} -Wl,--subsystem,native -Wl,--entry,_DllMainCRTStartup@12 -Wl,--image-base,0x10000 -Wl,--file-alignment,0x1000 -Wl,--section-alignment,0x1000 -nostartfiles -nostdlib -mdll -o %s %s %s\n\n",\r
target.c_str (),\r
archiveFilename.c_str (),\r
importLibraryDependencies.c_str () );\r
\r
- GenerateArchiveTargetTarget ( module );\r
- GenerateObjectFileTargetsTarget ( module );\r
+ GenerateMacrosAndTargetsTarget ( module );\r
}\r
else\r
{\r