Option to disable automatic dependencies

svn path=/branches/xmlbuildsystem/; revision=15413
This commit is contained in:
Casper Hornstrup 2005-05-19 19:53:01 +00:00
parent 2342aee312
commit 083a71c9f2
11 changed files with 72 additions and 52 deletions

View file

@ -34,8 +34,7 @@ Backend::Factory::~Factory ()
/*static*/ Backend*
Backend::Factory::Create ( const string& name,
Project& project,
bool verbose,
bool cleanAsYouGo )
Configuration& configuration )
{
string sname ( name );
strlwr ( &sname[0] );
@ -49,14 +48,12 @@ Backend::Factory::Create ( const string& name,
throw UnknownBackendException ( sname );
return NULL;
}
return (*f) ( project, verbose, cleanAsYouGo );
return (*f) ( project, configuration );
}
Backend::Backend ( Project& project,
bool verbose,
bool cleanAsYouGo )
Configuration& configuration )
: ProjectNode ( project ),
verbose ( verbose ),
cleanAsYouGo ( cleanAsYouGo )
configuration ( configuration )
{
}

View file

@ -6,7 +6,7 @@
class Backend;
typedef Backend* BackendFactory ( Project& project,
bool verbose );
Configuration& configuration );
class Backend
{
@ -22,26 +22,22 @@ public:
virtual ~Factory();
virtual Backend* operator() ( Project&,
bool verbose,
bool cleanAsYouGo ) = 0;
Configuration& configuration ) = 0;
public:
static Backend* Create ( const std::string& name,
Project& project,
bool verbose,
bool cleanAsYouGo );
Configuration& configuration );
};
protected:
Backend ( Project& project,
bool verbose,
bool cleanAsYouGo );
Configuration& configuration );
public:
virtual void Process () = 0;
Project& ProjectNode;
bool verbose;
bool cleanAsYouGo;
Configuration& configuration;
};
#endif /* __BACKEND_H */

View file

@ -35,18 +35,16 @@ static class DevCppFactory : public Backend::Factory
DevCppFactory() : Factory("devcpp") {}
Backend *operator() (Project &project,
bool verbose,
bool cleanAsYouGo)
Configuration& configuration)
{
return new DevCppBackend(project, verbose, cleanAsYouGo);
return new DevCppBackend(project, configuration);
}
} factory;
DevCppBackend::DevCppBackend(Project &project,
bool verbose,
bool cleanAsYouGo) : Backend(project, verbose, cleanAsYouGo)
Configuration& configuration) : Backend(project, configuration)
{
m_unitCount = 0;
}
@ -113,8 +111,7 @@ void DevCppBackend::Process()
Backend *backend = Backend::Factory::Create("mingw",
ProjectNode,
verbose,
cleanAsYouGo );
configuration );
backend->Process();
delete backend;

View file

@ -20,8 +20,7 @@ class DevCppBackend : public Backend
public:
DevCppBackend(Project &project,
bool verbose,
bool cleanAsYouGo);
Configuration& configuration);
virtual ~DevCppBackend() {}
virtual void Process();

View file

@ -212,20 +212,17 @@ static class MingwFactory : public Backend::Factory
public:
MingwFactory() : Factory ( "mingw" ) {}
Backend* operator() ( Project& project,
bool verbose,
bool cleanAsYouGo )
Configuration& configuration )
{
return new MingwBackend ( project,
verbose,
cleanAsYouGo );
configuration );
}
} factory;
MingwBackend::MingwBackend ( Project& project,
bool verbose,
bool cleanAsYouGo )
: Backend ( project, verbose, cleanAsYouGo ),
Configuration& configuration )
: Backend ( project, configuration ),
intermediateDirectory ( new Directory ("$(INTERMEDIATE)" ) ),
outputDirectory ( new Directory ( "$(OUTPUT)" ) ),
installDirectory ( new Directory ( "$(INSTALL)" ) )
@ -622,7 +619,7 @@ MingwBackend::UnpackWineResources ()
printf ( "Unpacking WINE resources..." );
WineResource wineResource ( ProjectNode,
GetBin2ResExecutable () );
wineResource.UnpackResources ( verbose );
wineResource.UnpackResources ( configuration.Verbose );
printf ( "done\n" );
}
@ -631,7 +628,7 @@ MingwBackend::GenerateTestSupportCode ()
{
printf ( "Generating test support code..." );
TestSupportCode testSupportCode ( ProjectNode );
testSupportCode.GenerateTestSupportCode ( verbose );
testSupportCode.GenerateTestSupportCode ( configuration.Verbose );
printf ( "done\n" );
}
@ -640,18 +637,21 @@ MingwBackend::GenerateProxyMakefiles ()
{
printf ( "Generating proxy makefiles..." );
ProxyMakefile proxyMakefile ( ProjectNode );
proxyMakefile.GenerateProxyMakefiles ( verbose );
proxyMakefile.GenerateProxyMakefiles ( configuration.Verbose );
printf ( "done\n" );
}
void
MingwBackend::CheckAutomaticDependencies ()
{
if ( configuration.AutomaticDependencies )
{
printf ( "Checking automatic dependencies..." );
AutomaticDependency automaticDependency ( ProjectNode );
automaticDependency.Process ();
automaticDependency.CheckAutomaticDependencies ( verbose );
automaticDependency.CheckAutomaticDependencies ( configuration.Verbose );
printf ( "done\n" );
}
}
bool
@ -667,9 +667,9 @@ void
MingwBackend::GenerateDirectories ()
{
printf ( "Creating directories..." );
intermediateDirectory->GenerateTree ( "", verbose );
outputDirectory->GenerateTree ( "", verbose );
installDirectory->GenerateTree ( "", verbose );
intermediateDirectory->GenerateTree ( "", configuration.Verbose );
outputDirectory->GenerateTree ( "", configuration.Verbose );
installDirectory->GenerateTree ( "", configuration.Verbose );
printf ( "done\n" );
}

View file

@ -46,8 +46,7 @@ class MingwBackend : public Backend
{
public:
MingwBackend ( Project& project,
bool verbose,
bool cleanAsYouGo );
Configuration& configuration );
virtual ~MingwBackend ();
virtual void Process ();
std::string AddDirectoryTarget ( const std::string& directory,

View file

@ -1280,7 +1280,7 @@ MingwModuleHandler::GetObjectsVector ( const IfableData& data,
void
MingwModuleHandler::GenerateCleanObjectsAsYouGoCode () const
{
if ( backend->cleanAsYouGo )
if ( backend->configuration.CleanAsYouGo )
{
vector<string> objectFiles;
GetObjectsVector ( module.non_if_data,

View file

@ -0,0 +1,15 @@
#include "pch.h"
#include <assert.h>
#include "rbuild.h"
Configuration::Configuration ()
{
Verbose = false;
CleanAsYouGo = false;
AutomaticDependencies = true;
}
Configuration::~Configuration ()
{
}

View file

@ -18,8 +18,7 @@ using std::vector;
static string BuildSystem;
static string RootXmlFile = "ReactOS.xml";
static bool Verbose = false;
static bool CleanAsYouGo = false;
static Configuration configuration;
bool
ParseSwitch ( int argc, char** argv, int index )
@ -28,10 +27,13 @@ ParseSwitch ( int argc, char** argv, int index )
switch ( switchChar )
{
case 'v':
Verbose = true;
configuration.Verbose = true;
break;
case 'c':
CleanAsYouGo = true;
configuration.CleanAsYouGo = true;
break;
case 'd':
configuration.AutomaticDependencies = false;
break;
case 'r':
RootXmlFile = string(&argv[index][2]);
@ -74,6 +76,7 @@ main ( int argc, char** argv )
printf ( "Switches:\n" );
printf ( " -v Be verbose\n" );
printf ( " -c Clean as you go. Delete generated files as soon as they are not needed anymore\n" );
printf ( " -d Disable automatic dependencies.\n" );
printf ( " -rfile.xml Name of the root xml file. Default is ReactOS.xml\n" );
printf ( "\n" );
printf ( " buildsystem Target build system. Can be one of:\n" );
@ -91,8 +94,7 @@ main ( int argc, char** argv )
project.ExecuteInvocations ();
Backend* backend = Backend::Factory::Create ( BuildSystem,
project,
Verbose,
CleanAsYouGo );
configuration );
backend->Process ();
delete backend;

View file

@ -68,6 +68,16 @@ class StubbedSymbol;
class SourceFileTest;
class Configuration
{
public:
Configuration ();
~Configuration ();
bool Verbose;
bool CleanAsYouGo;
bool AutomaticDependencies;
};
class Environment
{
public:

View file

@ -115,6 +115,7 @@ RBUILD_COMMON_SOURCES = \
bootstrap.cpp \
cdfile.cpp \
compilerflag.cpp \
configuration.cpp \
define.cpp \
exception.cpp \
filesupportcode.cpp \
@ -225,6 +226,10 @@ $(RBUILD_INT_)compilerflag.o: $(RBUILD_BASE_)compilerflag.cpp $(RBUILD_HEADERS)
$(ECHO_CC)
${host_gpp} $(RBUILD_HOST_CXXFLAGS) -c $< -o $@
$(RBUILD_INT_)configuration.o: $(RBUILD_BASE_)configuration.cpp $(RBUILD_HEADERS) | $(RBUILD_INT)
$(ECHO_CC)
${host_gpp} $(RBUILD_HOST_CXXFLAGS) -c $< -o $@
$(RBUILD_INT_)define.o: $(RBUILD_BASE_)define.cpp $(RBUILD_HEADERS) | $(RBUILD_INT)
$(ECHO_CC)
${host_gpp} $(RBUILD_HOST_CXXFLAGS) -c $< -o $@