rbuild: correct MSVC project file generation:
- don't define _DEBUG and NDEBUG at the same time
- fix compiler flags for VC7/8
Modified: trunk/reactos/tools/rbuild/backend/msvc/msvcmaker.cpp
Modified: trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
_____
Modified: trunk/reactos/tools/rbuild/backend/msvc/msvcmaker.cpp
--- trunk/reactos/tools/rbuild/backend/msvc/msvcmaker.cpp
2006-01-29 10:39:19 UTC (rev 27)
+++ trunk/reactos/tools/rbuild/backend/msvc/msvcmaker.cpp
2006-01-29 10:41:48 UTC (rev 28)
@@ -23,6 +23,7 @@
#include <string>
#include <vector>
+#include <set>
#include <stdio.h>
@@ -30,7 +31,10 @@
using std::string;
using std::vector;
+using std::set;
+typedef set<string> StringSet;
+
#ifdef OUT
#undef OUT
#endif//OUT
@@ -79,13 +83,14 @@
// TODO FIXME - what's diff. betw. 'c_srcs' and 'source_files'?
string dsp_path = module.GetBasePath();
- vector<string> c_srcs, source_files, resource_files, includes,
libraries, defines;
+ vector<string> c_srcs, source_files, resource_files, includes,
libraries;
+ StringSet common_defines;
vector<const IfableData*> ifs_list;
ifs_list.push_back ( &module.project.non_if_data );
ifs_list.push_back ( &module.non_if_data );
// this is a define in MinGW w32api, but not Microsoft's headers
- defines.push_back ( "STDCALL=__stdcall" );
+ common_defines.insert ( "STDCALL=__stdcall" );
while ( ifs_list.size() )
{
@@ -132,9 +137,9 @@
for ( i = 0; i < defs.size(); i++ )
{
if ( defs[i]->value[0] )
- defines.push_back ( defs[i]->name + "="
+ defs[i]->value );
+ common_defines.insert( defs[i]->name +
"=" + defs[i]->value );
else
- defines.push_back ( defs[i]->name );
+ common_defines.insert( defs[i]->name );
}
}
// TODO FIXME - we don't include header files in our build
system
@@ -318,44 +323,46 @@
if ( dll ) fprintf ( OUT, "# PROP Ignore_Export_Lib
0\r\n" );
fprintf ( OUT, "# PROP Target_Dir \"\"\r\n" );
+ StringSet defines = common_defines;
+
if ( debug )
{
- defines.push_back ( "_DEBUG" );
+ defines.insert ( "_DEBUG" );
if ( lib || exe )
{
fprintf ( OUT, "# ADD BASE CPP /nologo
/W3 /Gm /GX /Zi /Od" );
- defines.push_back ( "_LIB" );
+ defines.insert ( "_LIB" );
}
else
{
fprintf ( OUT, "# ADD BASE CPP /nologo
/MTd /W3 /Gm /GX /Zi /Od" );
- defines.push_back ( "_WINDOWS" );
- defines.push_back ( "_USRDLL" );
+ defines.insert ( "_WINDOWS" );
+ defines.insert ( "_USRDLL" );
// TODO FIXME - wine hack?
- //defines.push_back ( string("\U") +
module.name + "\E_EXPORTS" );
+ //defines.insert ( string("\U") +
module.name + "\E_EXPORTS" );
}
}
else
{
- defines.push_back ( "NDEBUG" );
+ defines.insert ( "NDEBUG" );
if ( lib || exe )
{
fprintf ( OUT, "# ADD BASE CPP /nologo
/W3 /GX /O2" );
- defines.push_back ( "_LIB" );
+ defines.insert ( "_LIB" );
}
else
{
fprintf ( OUT, "# ADD BASE CPP /nologo
/MT /W3 /GX /O2" );
- defines.push_back ( "_WINDOWS" );
- defines.push_back ( "_USRDLL" );
+ defines.insert ( "_WINDOWS" );
+ defines.insert ( "_USRDLL" );
// TODO FIXME - wine hack?
- //defines.push_back ( string("\U") +
module.name + "\E_EXPORTS" );
+ //defines.insert ( string("\U") +
module.name + "\E_EXPORTS" );
}
}
- for ( i = 0; i < defines.size(); i++ )
+ for ( StringSet::const_iterator it1=defines.begin();
it1!=defines.end(); it1++ )
{
- fprintf ( OUT, " /D \"%s\"", defines[i].c_str()
);
+ fprintf ( OUT, " /D \"%s\"", it1->c_str() );
}
if ( lib || exe ) fprintf ( OUT, " /YX" );
fprintf ( OUT, " /FD" );
@@ -367,33 +374,32 @@
fprintf ( OUT, " /c" );
fprintf ( OUT, "\r\n" );
- vector<string> defines2 = defines;
if ( debug )
{
- defines2.push_back ( "_DEBUG" );
+ defines.insert ( "_DEBUG" );
if(lib)
{
fprintf ( OUT, "# ADD CPP /nologo /MTd
/W3 /Gm /GX /Zi /Od" );
- defines2.push_back ( "_LIB" );
+ defines.insert ( "_LIB" );
}
else
{
fprintf ( OUT, "# ADD CPP /nologo /MTd
/W3 /Gm /GX /Zi /Od" );
- defines2.push_back ( "_USRDLL" );
+ defines.insert ( "_USRDLL" );
}
}
else
{
- defines2.push_back ( "NDEBUG" );
+ defines.insert ( "NDEBUG" );
if(lib)
{
fprintf ( OUT, "# ADD CPP /nologo /MT
/W3 /GX /O2" );
- defines2.push_back ( "_LIB" );
+ defines.insert ( "_LIB" );
}
else
{
fprintf ( OUT, "# ADD CPP /nologo /MT
/W3 /GX /O2" );
- defines2.push_back ( "_USRDLL" );
+ defines.insert ( "_USRDLL" );
}
}
@@ -401,16 +407,16 @@
if ( wine )
{
// TODO FIXME - wine hack?
- //defines2.push_back ( string("_\U") +
module.name + "\E_" );
+ //defines.insert ( string("_\U") + module.name +
"\E_" );
// TODO FIXME - wine hack?
/*if ( module.name !~
/^(?:wine(?:build|test)|.*?_test)$/ )
- defines2.push_back ( "__WINESRC__" );*/
+ defines.insert ( "__WINESRC__" );*/
if ( msvc_headers )
- defines2.push_back (
"__WINE_USE_NATIVE_HEADERS" );
+ defines.insert (
"__WINE_USE_NATIVE_HEADERS" );
string output_dir2 =
Replace(output_dir,"\\","\\\\");
- defines2.push_back (
ssprintf("__WINETEST_OUTPUT_DIR=\\\"%s\\\"",output_dir.c_str()) );
- defines2.push_back ( "__i386__" );
- defines2.push_back ( "_X86_" );
+ defines.insert (
ssprintf("__WINETEST_OUTPUT_DIR=\\\"%s\\\"",output_dir.c_str()) );
+ defines.insert ( "__i386__" );
+ defines.insert ( "_X86_" );
// TODO FIXME - wine hacks?
/*if(module.name =~
/^gdi32_(?:enhmfdrv|mfdrv)$/) {
@@ -445,9 +451,9 @@
}
fprintf ( OUT, " /I \".\"" );
- for ( i = 0; i < defines2.size(); i++ )
+ for ( StringSet::const_iterator it2=defines.begin();
it2!=defines.end(); it2++ )
{
- const string& define = defines2[i];
+ const string& define = *it2;
if ( strpbrk ( define.c_str(), "[\\\"]" ) )
{
fprintf ( OUT, " /D \"%s\"",
define.c_str() );
@@ -486,9 +492,9 @@
}
}
- for ( i = 0; i < defines.size(); i++ )
+ for ( StringSet::const_iterator
it3=defines.begin(); it3!=defines.end(); it3++ )
{
- fprintf ( OUT, " /D \"%s\"",
defines[i].c_str() );
+ fprintf ( OUT, " /D \"%s\"",
it3->c_str() );
}
fprintf ( OUT, " /d \"_DEBUG\"\r\n" );
}
@@ -508,9 +514,9 @@
fprintf ( OUT, " /i \"%s\"",
includes[i].c_str() );
}
- for ( i = 0; i < defines.size(); i++ )
+ for ( StringSet::const_iterator
it4=defines.begin(); it4!=defines.end(); it4++ )
{
- fprintf ( OUT, " /D \"%s\"",
defines[i].c_str() );
+ fprintf ( OUT, " /D \"%s\"",
it4->c_str() );
}
_____
Modified: trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
--- trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
2006-01-29 10:39:19 UTC (rev 27)
+++ trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
2006-01-29 10:41:48 UTC (rev 28)
@@ -23,6 +23,7 @@
#include <string>
#include <vector>
+#include <set>
#include <stdio.h>
@@ -30,7 +31,10 @@
using std::string;
using std::vector;
+using std::set;
+typedef set<string> StringSet;
+
#ifdef OUT
#undef OUT
#endif//OUT
@@ -91,16 +95,17 @@
//$output->progress("$dsp_file (file $progress_current of
$progress_max)");
string vcproj_path = module.GetBasePath();
- vector<string> source_files, resource_files, includes,
libraries, defines;
+ vector<string> source_files, resource_files, includes,
libraries;
+ StringSet common_defines;
vector<const IfableData*> ifs_list;
ifs_list.push_back ( &module.project.non_if_data );
ifs_list.push_back ( &module.non_if_data );
// MinGW doesn't have a safe-string library yet
- defines.push_back ( "_CRT_SECURE_NO_DEPRECATE" );
- defines.push_back ( "_CRT_NON_CONFORMING_SWPRINTFS" );
+ common_defines.insert ( "_CRT_SECURE_NO_DEPRECATE" );
+ common_defines.insert ( "_CRT_NON_CONFORMING_SWPRINTFS" );
// this is a define in MinGW w32api, but not Microsoft's headers
- defines.push_back ( "STDCALL=__stdcall" );
+ common_defines.insert ( "STDCALL=__stdcall" );
string baseaddr;
@@ -158,9 +163,9 @@
for ( i = 0; i < defs.size(); i++ )
{
if ( defs[i]->value[0] )
- defines.push_back ( defs[i]->name + "="
+ defs[i]->value );
+ common_defines.insert( defs[i]->name +
"=" + defs[i]->value );
else
- defines.push_back ( defs[i]->name );
+ common_defines.insert( defs[i]->name );
}
for ( i = 0; i < data.properties.size(); i++ )
{
@@ -278,39 +283,45 @@
}
fprintf ( OUT, "\"\r\n " );
+ StringSet defines = common_defines;
+
if ( debug )
{
- defines.push_back ( "_DEBUG" );
+ defines.insert ( "_DEBUG" );
}
else
{
- defines.push_back ( "NDEBUG" );
+ defines.insert ( "NDEBUG" );
}
if ( lib || exe )
{
- defines.push_back ( "_LIB" );
+ defines.insert ( "_LIB" );
}
else
{
- defines.push_back ( "_WINDOWS" );
- defines.push_back ( "_USRDLL" );
+ defines.insert ( "_WINDOWS" );
+ defines.insert ( "_USRDLL" );
}
fprintf ( OUT, "\t\t\t\tPreprocessorDefinitions=\"" );
- for ( i = 0; i < defines.size(); i++ )
+ for ( StringSet::iterator it1=defines.begin();
it1!=defines.end(); it1++ )
{
if ( i > 0 )
fprintf ( OUT, ";" );
- defines[i] = _replace_str(defines[i],
"\"",""");
- fprintf ( OUT, "%s", defines[i].c_str() );
+ string unescaped = *it1;
+ defines.erase(unescaped);
+ const string& escaped = _replace_str(unescaped,
"\"",""");
+
+ defines.insert(escaped);
+ fprintf ( OUT, "%s", escaped.c_str() );
}
fprintf ( OUT, "\"\r\n" );
fprintf ( OUT, "\t\t\t\tMinimalRebuild=\"%s\"\r\n",
speed ? "FALSE" : "TRUE" );
fprintf ( OUT, "\t\t\t\tBasicRuntimeChecks=\"%s\"\r\n", sys ?
0
: (debug ? "3" : "0") );
- fprintf ( OUT, "\t\t\t\tRuntimeLibrary=\"5\"\r\n" );
+ fprintf ( OUT, "\t\t\t\tRuntimeLibrary=\"%d\"\r\n",
debug? 1: 5 ); // 1=/MTd 5=/MT
fprintf ( OUT, "\t\t\t\tBufferSecurityCheck=\"%s\"\r\n", sys
?
"FALSE" : (debug ? "TRUE" : "FALSE" ));
fprintf ( OUT,
"\t\t\t\tEnableFunctionLevelLinking=\"%s\"\r\n", debug ?
"TRUE" :
"FALSE" );
@@ -337,14 +348,13 @@
fprintf ( OUT,
"\t\t\t\tStringPooling=\"true\"\r\n" );
}
- fprintf ( OUT, "\t\t\t\tEnablePREfast=\"%s\"\r\n", debug
? "TRUE" : "FALSE");
fprintf ( OUT,
"\t\t\t\tDisableSpecificWarnings=\"4201;4127;4214\"\r\n" );
fprintf ( OUT, "\t\t\t\tWarningLevel=\"%s\"\r\n", speed
? "0" : "4" );
fprintf ( OUT,
"\t\t\t\tDetect64BitPortabilityProblems=\"%s\"\r\n", speed ?
"FALSE" :
"TRUE");
if ( !module.cplusplus )
fprintf ( OUT, "\t\t\t\tCompileAs=\"1\"\r\n" );
- fprintf ( OUT, "\t\t\t\tCallingConvention=\"%d\"\r\n", (sys
||
(exe && module.type == Kernel)) ? 2: 1);
- fprintf ( OUT,
"\t\t\t\tDebugInformationFormat=\"%s\"/>\r\n", speed ?
"0" : "4");
+ fprintf ( OUT, "\t\t\t\tCallingConvention=\"%d\"\r\n", (sys
||
(exe && module.type == Kernel)) ? 2: 0); // 2=__stdcall 0=__cdecl
+ fprintf ( OUT,
"\t\t\t\tDebugInformationFormat=\"%s\"/>\r\n", speed ?
"0" : release ?
"3": "4"); // 3=/Zi 4=ZI
fprintf ( OUT, "\t\t\t<Tool\r\n" );
fprintf ( OUT,
"\t\t\t\tName=\"VCCustomBuildTool\"/>\r\n" );
@@ -382,6 +392,7 @@
fprintf ( OUT,
"\t\t\t\tOutputFile=\"$(OutDir)/%s%s\"\r\n", module.name.c_str(),
module_type.c_str() );
fprintf ( OUT,
"\t\t\t\tLinkIncremental=\"%d\"\r\n", debug ? 2 : 1 );
fprintf ( OUT,
"\t\t\t\tGenerateDebugInformation=\"%s\"\r\n", speed ?
"FALSE" : "TRUE"
);
+ fprintf ( OUT,
"\t\t\t\tLinkTimeCodeGeneration=\"%d\"\r\n", release? 1: 0); // whole
program optimization
if ( debug )
fprintf ( OUT,
"\t\t\t\tProgramDatabaseFile=\"$(OutDir)/%s.pdb\"\r\n",
module.name.c_str() );