Generate pre-compiled headers in intermediate directory tree

svn path=/trunk/; revision=16459
This commit is contained in:
Casper Hornstrup 2005-07-06 16:56:28 +00:00
parent c82da07ee2
commit 8a1b2d5c2b
4 changed files with 53 additions and 39 deletions

View file

@ -24,7 +24,7 @@
<file>sysinfo.c</file> <file>sysinfo.c</file>
<file>time.c</file> <file>time.c</file>
<file>timer.c</file> <file>timer.c</file>
<pch>../include/hal.h</pch> <pch>../include/hal.h</pch>
</module> </module>
<module name="hal_generic_up" type="objectlibrary"> <module name="hal_generic_up" type="objectlibrary">
<include base="hal_generic_up">../include</include> <include base="hal_generic_up">../include</include>

View file

@ -15,5 +15,4 @@
<file>part_xbox.c</file> <file>part_xbox.c</file>
<file>pci_xbox.c</file> <file>pci_xbox.c</file>
<file>halxbox.rc</file> <file>halxbox.rc</file>
<pch>../include/hal.h</pch>
</module> </module>

View file

@ -633,12 +633,23 @@ MingwModuleHandler::GenerateMacro (
const IfableData& data ) const IfableData& data )
{ {
size_t i; size_t i;
bool generateAssignment;
fprintf ( generateAssignment = (use_pch && module.pch != NULL ) || data.includes.size () > 0 || data.defines.size () > 0 || data.compilerFlags.size () > 0;
fMakefile, if ( generateAssignment )
"%s %s", {
macro.c_str(), fprintf ( fMakefile,
assignmentOperation ); "%s %s",
macro.c_str(),
assignmentOperation );
}
if ( use_pch && module.pch != NULL )
{
fprintf ( fMakefile,
" -I %s",
GetDirectory ( GetPrecompiledHeaderFilename () ).c_str () );
}
string compilerParameters = GenerateCompilerParametersFromVector ( data.compilerFlags ); string compilerParameters = GenerateCompilerParametersFromVector ( data.compilerFlags );
if ( compilerParameters.size () > 0 ) if ( compilerParameters.size () > 0 )
@ -669,7 +680,10 @@ MingwModuleHandler::GenerateMacro (
"=%s", "=%s",
d.value.c_str() ); d.value.c_str() );
} }
fprintf ( fMakefile, "\n" ); if ( generateAssignment )
{
fprintf ( fMakefile, "\n" );
}
} }
void void
@ -680,15 +694,12 @@ MingwModuleHandler::GenerateMacros (
{ {
size_t i; size_t i;
if ( data.includes.size () > 0 || data.defines.size () > 0 || data.compilerFlags.size () > 0 ) GenerateMacro ( assignmentOperation,
{ cflagsMacro,
GenerateMacro ( assignmentOperation, data );
cflagsMacro, GenerateMacro ( assignmentOperation,
data ); windresflagsMacro,
GenerateMacro ( assignmentOperation, data );
windresflagsMacro,
data );
}
if ( linkerFlags != NULL ) if ( linkerFlags != NULL )
{ {
@ -844,6 +855,14 @@ MingwModuleHandler::GenerateObjectMacros (
CleanupFileVector ( sourceFiles ); CleanupFileVector ( sourceFiles );
} }
string
MingwModuleHandler::GetPrecompiledHeaderFilename () const
{
const string& basePchFilename = module.pch->file.name + ".gch";
return PassThruCacheDirectory ( NormalizeFilename ( basePchFilename ),
backend->intermediateDirectory );
}
void void
MingwModuleHandler::GenerateGccCommand ( MingwModuleHandler::GenerateGccCommand (
const string& sourceFilename, const string& sourceFilename,
@ -852,7 +871,7 @@ MingwModuleHandler::GenerateGccCommand (
{ {
string dependencies = sourceFilename; string dependencies = sourceFilename;
if ( module.pch && use_pch ) if ( module.pch && use_pch )
dependencies += " " + module.pch->file.name + ".gch"; dependencies += " " + GetPrecompiledHeaderFilename ();
/* WIDL generated headers may be used */ /* WIDL generated headers may be used */
dependencies += " " + GetLinkingDependenciesMacro (); dependencies += " " + GetLinkingDependenciesMacro ();
@ -1458,27 +1477,22 @@ MingwModuleHandler::GenerateObjectFileTargets (
const string& windresflagsMacro, const string& windresflagsMacro,
const string& widlflagsMacro ) const string& widlflagsMacro )
{ {
if ( module.pch ) if ( module.pch && use_pch )
{ {
const string& pch_file = module.pch->file.name; const string& baseHeaderFilename = module.pch->file.name;
string gch_file = pch_file + ".gch"; const string& pchFilename = GetPrecompiledHeaderFilename ();
CLEAN_FILE(gch_file); CLEAN_FILE(pchFilename);
if ( use_pch ) fprintf ( fMakefile,
{ "%s: %s\n",
fprintf ( pchFilename.c_str(),
fMakefile, baseHeaderFilename.c_str() );
"%s: %s\n", fprintf ( fMakefile, "\t$(ECHO_PCH)\n" );
gch_file.c_str(), fprintf ( fMakefile,
pch_file.c_str() ); "\t%s -o %s %s -g %s\n\n",
fprintf ( fMakefile, "\t$(ECHO_PCH)\n" ); module.cplusplus ? cppc.c_str() : cc.c_str(),
fprintf ( pchFilename.c_str(),
fMakefile, cflagsMacro.c_str(),
"\t%s -o %s %s -g %s\n\n", baseHeaderFilename.c_str() );
( module.cplusplus ? cppc.c_str() : cc.c_str() ),
gch_file.c_str(),
cflagsMacro.c_str(),
pch_file.c_str() );
}
} }
GenerateObjectFileTargets ( module.non_if_data, GenerateObjectFileTargets ( module.non_if_data,

View file

@ -124,6 +124,7 @@ private:
std::string GenerateGccIncludeParameters () const; std::string GenerateGccIncludeParameters () const;
std::string GenerateGccParameters () const; std::string GenerateGccParameters () const;
std::string GenerateNasmParameters () const; std::string GenerateNasmParameters () const;
std::string MingwModuleHandler::GetPrecompiledHeaderFilename () const;
void GenerateGccCommand ( const std::string& sourceFilename, void GenerateGccCommand ( const std::string& sourceFilename,
const std::string& cc, const std::string& cc,
const std::string& cflagsMacro ); const std::string& cflagsMacro );