- Put output from MSVC into the relevant output-i386 / obj-i386 files
- #if 0'd out the code to use ReactOS' internal libs until ReactOS can be fully built with MSVC. We must continue to rely on PSDK until this time.
- code by Brezenbak (IRC)
Modified: trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
Modified: trunk/reactos/tools/rbuild/module.cpp
Modified: trunk/reactos/tools/rbuild/rbuild.h

Modified: trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp
--- trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp	2005-12-04 19:31:02 UTC (rev 19883)
+++ trunk/reactos/tools/rbuild/backend/msvc/vcprojmaker.cpp	2005-12-04 20:15:45 UTC (rev 19884)
@@ -47,16 +47,28 @@
 	FILE* OUT = fopen ( vcproj_file.c_str(), "wb" );
 
 	vector<string> imports;
-	for ( i = 0; i < module.non_if_data.libraries.size(); i++ )
-	{
-		imports.push_back ( module.non_if_data.libraries[i]->name );
-	}
-
 	string module_type = GetExtension(module.GetTargetName());
 	bool lib = (module.type == ObjectLibrary) || (module_type == ".lib") || (module_type == ".a");
 	bool dll = (module_type == ".dll") || (module_type == ".cpl");
 	bool exe = (module_type == ".exe");
 	bool sys = (module_type == ".sys");
+
+	string path_basedir = module.GetPathToBaseDir ();
+	string intenv = Environment::GetIntermediatePath ();
+	string outenv = Environment::GetOutputPath ();
+	string outdir;
+	string intdir;
+	
+	if ( intenv == "obj-i386" )
+		intdir = path_basedir + "obj-i386"; /* append relative dir from project dir */
+	else
+		intdir = intenv;
+
+	if ( outenv == "output-i386" )
+		outdir = path_basedir + "output-i386";
+	else
+		outdir = outenv;
+
 	// TODO FIXME - need more checks here for 'sys' and possibly 'drv'?
 
 	bool console = exe && (module.type == Win32CUI);
@@ -130,7 +142,19 @@
 		const vector<Library*>& libs = data.libraries;
 		for ( i = 0; i < libs.size(); i++ )
 		{
-			libraries.push_back ( libs[i]->name + ".lib" );
+#if 0
+			// this code is deactivated untill the tree builds fine with msvc
+			// --- is appended to each library path which is later
+			// replaced by the configuration
+			// i.e. ../output-i386/lib/rtl/---/rtl.lib becomes
+			//      ../output-i386/lib/rtl/Debug/rtl.lib 
+			// etc
+			libs[i]->importedModule->
+			string libpath = outdir + "\\" + libs[i]->importedModule->GetBasePath() + "\\---\\" + libs[i]->name + ".lib";
+			libraries.push_back ( libpath );
+#else
+		libraries.push_back ( libs[i]->name + ".lib" );
+#endif
 		}
 		const vector<Define*>& defs = data.defines;
 		for ( i = 0; i < defs.size(); i++ )
@@ -229,8 +253,8 @@
 
 		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\"\r\n", cfg.c_str() );
-		fprintf ( OUT, "\t\t\tIntermediateDirectory=\"%s\"\r\n", cfg.c_str() );
+		fprintf ( OUT, "\t\t\tOutputDirectory=\"%s\\%s\\%s\"\r\n", outdir.c_str (), module.GetBasePath ().c_str (), cfg.c_str() );
+		fprintf ( OUT, "\t\t\tIntermediateDirectory=\"%s\\%s\\%s\"\r\n", intdir.c_str (), module.GetBasePath ().c_str (), cfg.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" );
 
@@ -316,6 +340,8 @@
 		fprintf ( OUT, "\t\t\t\tDisableSpecificWarnings=\"4201;4127\"\r\n" );
 		fprintf ( OUT, "\t\t\t\tWarningLevel=\"%s\"\r\n", release ? "0" : "4" );
 		fprintf ( OUT, "\t\t\t\tDetect64BitPortabilityProblems=\"%s\"\r\n", release ? "FALSE" : "TRUE");
+		if ( !module.cplusplus )
+			fprintf ( OUT, "\t\t\t\tCompileAs=\"1\"\r\n" );
 		fprintf ( OUT, "\t\t\t\tDebugInformationFormat=\"%s\"/>\r\n", speed ? "0" : "4");
 
 		fprintf ( OUT, "\t\t\t<Tool\r\n" );
@@ -337,7 +363,17 @@
 			{
 				if ( i > 0 )
 					fprintf ( OUT, " " );
+#if 0 
+				// this code is deactivated untill 
+				// msvc can build the whole tree
+				string libpath = libraries[i].c_str();
+				libpath.replace (libpath.find("---"), //See HACK
+					             3,
+								 cfg);
+				fprintf ( OUT, "%s", libpath.c_str() );
+#else
 				fprintf ( OUT, "%s", libraries[i].c_str() );
+#endif
 			}
 			fprintf ( OUT, "\"\r\n" );
 

Modified: trunk/reactos/tools/rbuild/module.cpp
--- trunk/reactos/tools/rbuild/module.cpp	2005-12-04 19:31:02 UTC (rev 19883)
+++ trunk/reactos/tools/rbuild/module.cpp	2005-12-04 20:15:45 UTC (rev 19884)
@@ -997,6 +997,19 @@
 }
 
 string
+Module::GetPathToBaseDir () const
+{
+	string temp_path = path;
+	string result = "..\\";
+	while(temp_path.find ('\\') != string::npos)
+	{
+		temp_path.erase (0, temp_path.find('\\')+1);
+		result += "..\\";
+	}
+	return result;
+}
+
+string
 Module::GetInvocationTarget ( const int index ) const
 {
 	return ssprintf ( "%s_invoke_%d",

Modified: trunk/reactos/tools/rbuild/rbuild.h
--- trunk/reactos/tools/rbuild/rbuild.h	2005-12-04 19:31:02 UTC (rev 19883)
+++ trunk/reactos/tools/rbuild/rbuild.h	2005-12-04 20:15:45 UTC (rev 19884)
@@ -322,6 +322,7 @@
 	std::string GetBasePath () const; // "path"
 	std::string GetPath () const; // "path/foo.exe"
 	std::string GetPathWithPrefix ( const std::string& prefix ) const; // "path/prefixfoo.exe"
+	std::string GetPathToBaseDir() const; // "../" offset to rootdirectory
 	void GetTargets ( string_list& ) const;
 	std::string GetInvocationTarget ( const int index ) const;
 	bool HasFileWithExtension ( const IfableData&, const std::string& extension ) const;