[ros-diffs] [hpoussin] 22343: - Add a MSVCConfiguration class, to keep trace of parameters instead of parsing each time the configuration name - When building with MSVC headers, win32api and Wine directories are omitted and some defines are added

hpoussin at svn.reactos.org hpoussin at svn.reactos.org
Tue Jun 13 23:23:25 CEST 2006


Author: hpoussin
Date: Wed Jun 14 01:23:25 2006
New Revision: 22343

URL: http://svn.reactos.ru/svn/reactos?rev=22343&view=rev
Log:
- Add a MSVCConfiguration class, to keep trace of parameters instead of parsing each time the configuration name
- When building with MSVC headers, win32api and Wine directories are omitted and some defines are added

Modified:
    trunk/reactos/tools/rbuild/backend/msvc/msvc.h
    trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp

Modified: trunk/reactos/tools/rbuild/backend/msvc/msvc.h
URL: http://svn.reactos.ru/svn/reactos/trunk/reactos/tools/rbuild/backend/msvc/msvc.h?rev=22343&r1=22342&r2=22343&view=diff
==============================================================================
--- trunk/reactos/tools/rbuild/backend/msvc/msvc.h (original)
+++ trunk/reactos/tools/rbuild/backend/msvc/msvc.h Wed Jun 14 01:23:25 2006
@@ -30,6 +30,31 @@
 	public:
 		std::string filename;
 		std::string folder;
+};
+
+enum OptimizationType
+{
+	Debug,
+	Release,
+	Speed
+};
+
+enum HeadersType
+{
+	MSVCHeaders,
+	WineHeaders
+};
+
+class MSVCConfiguration
+{
+	public:
+		MSVCConfiguration(const OptimizationType optimization,
+		                  const HeadersType headers = MSVCHeaders,
+		                  const std::string &name = "");
+		virtual ~MSVCConfiguration() {}
+		std::string name;
+		OptimizationType optimization;
+		HeadersType headers;
 };
 
 class MSVCBackend : public Backend

Modified: trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
URL: http://svn.reactos.ru/svn/reactos/trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp?rev=22343&r1=22342&r2=22343&view=diff
==============================================================================
--- trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp (original)
+++ trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp Wed Jun 14 01:23:25 2006
@@ -1,6 +1,7 @@
 /*
  * Copyright (C) 2002 Patrik Stridvall
  * Copyright (C) 2005 Royce Mitchell III
+ * Copyright (C) 2006 Hervé Poussineau
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -39,12 +40,34 @@
 #undef OUT
 #endif//OUT
 
+MSVCConfiguration::MSVCConfiguration ( const OptimizationType optimization, const HeadersType headers, const std::string &name )
+{
+	this->optimization = optimization;
+	this->headers = headers;
+	if ( name != "" )
+		this->name = name;
+	else
+	{
+		std::string headers_name;
+		if ( headers == MSVCHeaders )
+			headers_name = "";
+		else
+			headers_name = " - Wine headers";
+		if ( optimization == Debug )
+			this->name = "Debug" + headers_name;
+		else if ( optimization == Release )
+			this->name = "Release" + headers_name;
+		else if ( optimization == Speed )
+			this->name = "Speed" + headers_name;
+		else
+			this->name = "Unknown" + headers_name;
+	}
+}
+
 void
 MSVCBackend::_generate_vcproj ( const Module& module )
 {
 	size_t i;
-	// TODO FIXME wine hack?
-	//const bool wine = false;
 
 	string vcproj_file = VcprojFileName(module);
 	printf ( "Creating MSVC.NET project: '%s'\n", vcproj_file.c_str() );
@@ -95,18 +118,12 @@
 	//$output->progress("$dsp_file (file $progress_current of $progress_max)");
 
 	string vcproj_path = module.GetBasePath();
-	vector<string> source_files, resource_files, includes, libraries;
+	vector<string> source_files, resource_files, includes, includes_wine, 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
-	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
-	common_defines.insert ( "STDCALL=__stdcall" );
-
 	string baseaddr;
 
 	while ( ifs_list.size() )
@@ -136,24 +153,22 @@
 		const vector<Include*>& incs = data.includes;
 		for ( i = 0; i < incs.size(); i++ )
 		{
-			// explicitly omit win32api directories
-			if ( !strncmp(incs[i]->directory.c_str(), "include\\ddk", 11 ) )
- 				continue;
- 
-			if ( !strncmp(incs[i]->directory.c_str(), "include\\crt", 11 ) )
-				continue;
-
-			if ( !strncmp(incs[i]->directory.c_str(), "include\\GL", 10 ) )
-				continue;
-
-			// explicitly omit include/wine directories
-			if ( !strncmp(incs[i]->directory.c_str(), "include\\reactos\\wine", 20 ) )
-				continue;
-
 			string path = Path::RelativeFromDirectory (
 				incs[i]->directory,
 				module.GetBasePath() );
-			includes.push_back ( path );
+
+			// add to another list win32api and include/wine directories
+			if ( !strncmp(incs[i]->directory.c_str(), "include\\ddk", 11 ) ||
+			     !strncmp(incs[i]->directory.c_str(), "include\\crt", 11 ) ||
+			     !strncmp(incs[i]->directory.c_str(), "include\\GL", 10 ) ||
+			     !strncmp(incs[i]->directory.c_str(), "include\\reactos\\wine", 20 ) )
+			{
+				includes_wine.push_back ( path );
+			}
+			else
+			{
+				includes.push_back ( path );
+			}
 		}
 		const vector<Library*>& libs = data.libraries;
 		for ( i = 0; i < libs.size(); i++ )
@@ -179,40 +194,22 @@
 
 	vector<string> header_files;
 
-	bool no_cpp = true;
+	// TODO FIXME wine hack?
 	bool no_msvc_headers = true;
 
-	std::vector<std::string> cfgs;
-
-	cfgs.push_back ( "Debug" );
-	cfgs.push_back ( "Release" );
-	cfgs.push_back ( "Speed" );
-
-	if (!no_cpp)
-	{
-		std::vector<std::string> _cfgs;
-		for ( i = 0; i < cfgs.size(); i++ )
-		{
-			_cfgs.push_back ( cfgs[i] + " C" );
-			_cfgs.push_back ( cfgs[i] + " C++" );
-		}
-		cfgs.resize(0);
-		cfgs = _cfgs;
-	}
+	std::vector<MSVCConfiguration*> cfgs;
+
+	cfgs.push_back ( new MSVCConfiguration( Debug ));
+	cfgs.push_back ( new MSVCConfiguration( Release ));
+	cfgs.push_back ( new MSVCConfiguration( Speed ));
 
 	if (!no_msvc_headers)
 	{
-		std::vector<std::string> _cfgs;
-		for ( i = 0; i < cfgs.size(); i++ )
-		{
-			_cfgs.push_back ( cfgs[i] + " MSVC Headers" );
-			_cfgs.push_back ( cfgs[i] + " Wine Headers" );
-		}
-		cfgs.resize(0);
-		cfgs = _cfgs;
-	}
-
-	string default_cfg = cfgs.back();
+		cfgs.push_back ( new MSVCConfiguration( Debug, WineHeaders ));
+		cfgs.push_back ( new MSVCConfiguration( Release, WineHeaders ));
+		cfgs.push_back ( new MSVCConfiguration( Speed, WineHeaders ));
+	}
+
 	string include_string;
 
 	fprintf ( OUT, "<?xml version=\"1.0\" encoding = \"Windows-1252\"?>\r\n" );
@@ -248,18 +245,16 @@
 	fprintf ( OUT, "\t<Configurations>\r\n" );
 	for ( size_t icfg = 0; icfg < cfgs.size(); icfg++ )
 	{
-		std::string& cfg = cfgs[icfg];
-
-		bool debug = strstr ( cfg.c_str(), "Debug" ) != NULL;
-		bool speed = strstr ( cfg.c_str(), "Speed" ) != NULL;
-		bool release = (!debug && !speed );
-
-		//bool msvc_headers = ( 0 != strstr ( cfg.c_str(), "MSVC Headers" ) );
+		const MSVCConfiguration& cfg = *cfgs[icfg];
+
+		bool debug = ( cfg.optimization == Debug );
+		bool release = ( cfg.optimization == Release );
+		bool speed = ( cfg.optimization == Speed );
 
 		fprintf ( OUT, "\t\t<Configuration\r\n" );
-		fprintf ( OUT, "\t\t\tName=\"%s|Win32\"\r\n", cfg.c_str() );
-		fprintf ( OUT, "\t\t\tOutputDirectory=\"%s\\%s\\%s\\%s\"\r\n", outdir.c_str (), module.GetBasePath ().c_str (), _get_vc_dir().c_str (), cfg.c_str() );
-		fprintf ( OUT, "\t\t\tIntermediateDirectory=\"%s\\%s\\%s\\%s\"\r\n", intdir.c_str (), module.GetBasePath ().c_str (), _get_vc_dir().c_str (), cfg.c_str() );
+		fprintf ( OUT, "\t\t\tName=\"%s|Win32\"\r\n", cfg.name.c_str() );
+		fprintf ( OUT, "\t\t\tOutputDirectory=\"%s\\%s\\%s\\%s\"\r\n", outdir.c_str (), module.GetBasePath ().c_str (), _get_vc_dir().c_str (), cfg.name.c_str() );
+		fprintf ( OUT, "\t\t\tIntermediateDirectory=\"%s\\%s\\%s\\%s\"\r\n", intdir.c_str (), module.GetBasePath ().c_str (), _get_vc_dir().c_str (), cfg.name.c_str() );
 		fprintf ( OUT, "\t\t\tConfigurationType=\"%d\"\r\n", exe ? 1 : dll ? 2 : lib ? 4 : -1 );
 		fprintf ( OUT, "\t\t\tCharacterSet=\"2\">\r\n" );
 
@@ -272,7 +267,7 @@
 		fprintf ( OUT, "./;" );
 		for ( i = 0; i < includes.size(); i++ )
 		{
-			const string& include = includes[i];
+			const std::string& include = includes[i];
 			if ( strcmp ( include.c_str(), "." ) )
 			{
 				if ( multiple_includes )
@@ -283,6 +278,18 @@
 				multiple_includes = true;
 			}
 		}
+		if ( cfg.headers == WineHeaders )
+		{
+			for ( i = 0; i < includes_wine.size(); i++ )
+			{
+				const std::string& include = includes_wine[i];
+				if ( multiple_includes )
+					fprintf ( OUT, ";" );
+				fprintf ( OUT, "%s", include.c_str() );
+				//include_string += " /I " + include;
+				multiple_includes = true;
+			}
+		}
 		fprintf ( OUT, "\"\r\n" );
 
 		StringSet defines = common_defines;
@@ -294,6 +301,15 @@
 		else
 		{
 			defines.insert ( "NDEBUG" );
+		}
+
+		if ( cfg.headers == MSVCHeaders )
+		{
+			// this is a define in MinGW w32api, but not Microsoft's headers
+			defines.insert ( "STDCALL=__stdcall" );
+			// MinGW doesn't have a safe-string library yet
+			defines.insert ( "_CRT_SECURE_NO_DEPRECATE" );
+			defines.insert ( "_CRT_NON_CONFORMING_SWPRINTFS" );
 		}
 
 		if ( lib || exe )
@@ -390,9 +406,7 @@
 					fprintf ( OUT, ";" );
 
 				string libpath = libraries[i].c_str();
-				libpath.replace (libpath.find("---"),
-					             3,
-								 cfg);
+				libpath.replace (libpath.find("---"), 3, cfg.name);
 				libpath = libpath.substr (0, libpath.find_last_of ("\\") );
 				fprintf ( OUT, "%s", libpath.c_str() );
 			}
@@ -457,9 +471,20 @@
 		fprintf ( OUT, "./;" );
 		for ( i = 0; i < includes.size(); i++ )
 		{
-			const string& include = includes[i];
+			const std::string& include = includes[i];
 			if ( strcmp ( include.c_str(), "." ) )
 			{
+				if ( multiple_includes )
+					fprintf ( OUT, ";" );
+				fprintf ( OUT, "%s", include.c_str() );
+				multiple_includes = true;
+			}
+		}
+		if ( cfg.headers == WineHeaders )
+		{
+			for ( i = 0; i < includes_wine.size(); i++ )
+			{
+				const std::string& include = includes_wine[i];
 				if ( multiple_includes )
 					fprintf ( OUT, ";" );
 				fprintf ( OUT, "%s", include.c_str() );
@@ -500,14 +525,14 @@
 
 		for ( size_t iconfig = 0; iconfig < cfgs.size(); iconfig++ )
 		{
-			std::string& config = cfgs[iconfig];
+			const MSVCConfiguration& config = *cfgs[iconfig];
 
 			if (( isrcfile == 0 ) && ( module.pch != NULL ))
 			{
 				/* little hack to speed up PCH */
 				fprintf ( OUT, "\t\t\t\t<FileConfiguration\r\n" );
 				fprintf ( OUT, "\t\t\t\t\tName=\"" );
-				fprintf ( OUT, config.c_str() );
+				fprintf ( OUT, config.name.c_str() );
 				fprintf ( OUT, "|Win32\">\r\n" );
 				fprintf ( OUT, "\t\t\t\t\t<Tool\r\n" );
 				fprintf ( OUT, "\t\t\t\t\t\tName=\"VCCLCompilerTool\"\r\n" );
@@ -520,7 +545,7 @@
 				{
 					fprintf ( OUT, "\t\t\t\t<FileConfiguration\r\n" );
 					fprintf ( OUT, "\t\t\t\t\tName=\"" );
-					fprintf ( OUT, config.c_str() );
+					fprintf ( OUT, config.name.c_str() );
 					fprintf ( OUT, "|Win32\">\r\n" );
 					fprintf ( OUT, "\t\t\t\t\t<Tool\r\n" );
 					if (source_file.find(".idl") != string::npos)




More information about the Ros-diffs mailing list