static Configuration configuration;
bool
-ParseAutomaticDependencySwitch ( char switchChar2,
- char* switchStart )
+ParseAutomaticDependencySwitch (
+ char switchChar2,
+ char* switchStart )
{
switch ( switchChar2 )
{
return true;
}
+bool
+ParseCompilationUnitSwitch (
+ char switchChar2,
+ char* switchStart )
+{
+ switch ( switchChar2 )
+ {
+ case 'd':
+ configuration.CompilationUnitsEnabled = false;
+ break;
+ default:
+ printf ( "Unknown switch -u%c\n",
+ switchChar2 );
+ return false;
+ }
+ return true;
+}
+
+bool
+ParseVCProjectSwitch (
+ char switchChar2,
+ char* switchStart )
+{
+ switch ( switchChar2 )
+ {
+ case 's':
+ if ( strlen ( switchStart ) <= 3 )
+ {
+ printf ( "Switch -dm requires a module name\n" );
+ return false;
+ }
+ configuration.VSProjectVersion = string(&switchStart[3]);
+
+ if (configuration.VSProjectVersion.at(0) == '{') {
+ printf ( "Error: invalid char {\n" );
+ return false;
+ }
+
+ if (configuration.VSProjectVersion.length() == 1) //7,8
+ configuration.VSProjectVersion.append(".00");
+
+ if (configuration.VSProjectVersion.length() == 3) //7.1
+ configuration.VSProjectVersion.append("0");
+
+ break;
+ default:
+ printf ( "Unknown switch -d%c\n",
+ switchChar2 );
+ return false;
+ }
+ return true;
+}
+
bool
ParseMakeSwitch ( char switchChar2 )
{
switch ( switchChar )
{
case 'v':
- configuration.Verbose = true;
+ if (switchChar2 == 's')
+ {
+ return ParseVCProjectSwitch (
+ switchChar2,
+ argv[index] );
+ }
+ else
+ configuration.Verbose = true;
break;
case 'c':
configuration.CleanAsYouGo = true;
break;
case 'd':
- return ParseAutomaticDependencySwitch ( switchChar2,
- argv[index] );
+ return ParseAutomaticDependencySwitch (
+ switchChar2,
+ argv[index] );
+ case 'u':
+ return ParseCompilationUnitSwitch (
+ switchChar2,
+ argv[index] );
case 'r':
RootXmlFile = string(&argv[index][2]);
break;
case 'p':
return ParseProxyMakefileSwitch ( switchChar2 );
default:
- printf ( "Unknown switch -%c\n",
- switchChar );
+ printf (
+ "Unknown switch -%c\n",
+ switchChar );
return false;
}
return true;
int
main ( int argc, char** argv )
{
+ InitializeEnvironment ();
+
if ( !ParseArguments ( argc, argv ) )
{
printf ( "Generates project files for buildsystems\n\n" );
- printf ( " rbuild [switches] buildsystem\n" );
- printf ( " rbuild msvc\n" );
+ printf ( " rbuild [switches] buildsystem\n\n" );
printf ( "Switches:\n" );
printf ( " -v Be verbose.\n" );
printf ( " -c Clean as you go. Delete generated files as soon as they are not\n" );
printf ( " needed anymore.\n" );
+ printf ( " -r{file.xml} Name of the root xml file. Default is ReactOS.xml.\n" );
printf ( " -dd Disable automatic dependencies.\n" );
printf ( " -dm{module} Check only automatic dependencies for this module.\n" );
- printf ( " -r{file.xml} Name of the root xml file. Default is ReactOS.xml.\n" );
+ printf ( " -ud Disable multiple source files per compilation unit.\n" );
printf ( " -mi Let make handle creation of install directories. Rbuild will\n" );
printf ( " not generate the directories.\n" );
printf ( " -ps Generate proxy makefiles in source tree instead of the output.\n" );
printf ( " tree.\n" );
+ printf ( " -vs{version} Version of MS VS project files. Default is %s.\n", MS_VS_DEF_VERSION );
printf ( "\n" );
printf ( " buildsystem Target build system. Can be one of:\n" );
printf ( " mingw MinGW\n" );
- printf ( " devcpp DevC++\n\n" );
- printf ( " msvc Generates dsp files for MSVC" );
+ printf ( " devcpp DevC++\n" );
+ printf ( " msvc MS Visual Studio\n" );
return 1;
}
try
{
string projectFilename ( RootXmlFile );
+
printf ( "Reading build files..." );
- Project project ( projectFilename );
+ Project project ( configuration, projectFilename );
printf ( "done\n" );
+
+ project.SetBackend ( Backend::Factory::Create (
+ BuildSystem,
+ project,
+ configuration ) );
+
project.WriteConfigurationFile ();
project.ExecuteInvocations ();
- Backend* backend = Backend::Factory::Create ( BuildSystem,
- project,
- configuration );
- backend->Process ();
- delete backend;
+ project.GetBackend().Process();
return 0;
}
- catch (Exception& ex)
+ catch ( Exception& ex )
+ {
+ printf ( "%s\n", (*ex).c_str () );
+ return 1;
+ }
+ catch ( XMLException& ex )
{
- printf ( "%s\n",
- ex.Message.c_str () );
+ printf ( "%s\n", (*ex).c_str () );
return 1;
}
}