summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmake.cxx50
-rw-r--r--Source/cmake.h5
-rw-r--r--Source/cmakemain.cxx115
-rw-r--r--Tests/CMakeBuildTest.cmake.in2
4 files changed, 105 insertions, 67 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index 9a81138..4070755 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -4394,7 +4394,7 @@ std::vector<std::string> const& cmake::GetDebugConfigs()
int cmake::Build(const std::string& dir,
const std::string& target,
const std::string& config,
- const std::string& extraBuildOptions,
+ const std::vector<std::string>& nativeOptions,
bool clean)
{
if(!cmSystemTools::FileIsDirectory(dir.c_str()))
@@ -4438,51 +4438,5 @@ int cmake::Build(const std::string& dir,
&output,
makeProgram.c_str(),
config.c_str(), clean, false, 0, true,
- extraBuildOptions.c_str());
-}
-
-int cmake::DoBuild(int ac, char* av[])
-{
-#ifndef CMAKE_BUILD_WITH_CMAKE
- std::cerr << "This cmake does not support --build\n";
- return -1;
-#else
- std::string target;
- std::string config = "Debug";
- std::string extraBuildOptions;
- std::string dir;
- bool clean = false;
- cmsys::CommandLineArguments arg;
- arg.Initialize(ac, av);
- typedef cmsys::CommandLineArguments argT;
- arg.AddArgument("--build", argT::SPACE_ARGUMENT, &dir,
- "Build a configured cmake project --build dir.");
- arg.AddArgument("--target", argT::SPACE_ARGUMENT, &target,
- "Specifiy the target to build,"
- " if missing, all targets are built.");
- arg.AddArgument("--config", argT::SPACE_ARGUMENT, &config,
- "Specify configuration to build"
- " if missing Debug is built.");
- arg.AddArgument("--extra-options", argT::SPACE_ARGUMENT, &extraBuildOptions,
- "Specify extra options to pass to build program,"
- " for example with gmake -jN.");
- arg.AddArgument("--clean", argT::NO_ARGUMENT, &clean,
- "Clean before building.");
- if ( !arg.Parse() )
- {
- std::cerr << "Problem parsing --build arguments:\n";
- std::cerr << arg.GetHelp() << "\n";
- return 1;
- }
-
- // Hack for vs6 that passes ".\Debug" as "$(IntDir)" value:
- //
- if (cmSystemTools::StringStartsWith(config.c_str(), ".\\"))
- {
- config = config.substr(2);
- }
-
- cmake cm;
- return cm.Build(dir, target, config, extraBuildOptions, clean);
-#endif
+ 0, nativeOptions);
}
diff --git a/Source/cmake.h b/Source/cmake.h
index 269db47..c9c66c2 100644
--- a/Source/cmake.h
+++ b/Source/cmake.h
@@ -357,13 +357,12 @@ class cmake
void IssueMessage(cmake::MessageType t, std::string const& text,
cmListFileBacktrace const& backtrace);
// * run the --build option
- static int DoBuild(int ac, char* av[]);
-protected:
int Build(const std::string& dir,
const std::string& target,
const std::string& config,
- const std::string& extraBuildOptions,
+ const std::vector<std::string>& nativeOptions,
bool clean);
+protected:
void InitializeProperties();
int HandleDeleteCacheVariables(const char* var);
cmPropertyMap Properties;
diff --git a/Source/cmakemain.cxx b/Source/cmakemain.cxx
index 46a17ef..61e7cce 100644
--- a/Source/cmakemain.cxx
+++ b/Source/cmakemain.cxx
@@ -61,6 +61,14 @@ static const char * cmDocumentationDescription[][3] =
{0,0,0}
};
+#define CMAKE_BUILD_OPTIONS \
+ " <dir> = Project binary directory to be built.\n" \
+ " --target <tgt> = Build <tgt> instead of default targets.\n" \
+ " --config <cfg> = For multi-configuration tools, choose <cfg>.\n" \
+ " --clean-first = Build target 'clean' first, then build.\n" \
+ " (To clean only, use --target 'clean'.)\n" \
+ " -- = Pass remaining options to the native tool.\n"
+
//----------------------------------------------------------------------------
static const char * cmDocumentationOptions[][3] =
{
@@ -85,11 +93,11 @@ static const char * cmDocumentationOptions[][3] =
"variables being created. If A is specified, then it will display also "
"advanced variables. If H is specified, it will also display help for "
"each variable."},
- {"--build dir", "Build a configured cmake tree found in dir.",
- "This option will use the native build tool from the command line to"
- " build the project. Other options that can be specified with this one"
- " are --target, --config, --extra-options, and --clean. For complete "
- "help run --build with no options."},
+ {"--build <dir>", "Build a CMake-generated project binary tree.",
+ "This abstracts a native build tool's command-line interface with the "
+ "following options:\n"
+ CMAKE_BUILD_OPTIONS
+ "Run cmake --build with no options for quick help."},
{"-N", "View mode only.",
"Only load the cache. Do not actually run configure and generate steps."},
{"-P <file>", "Process script mode.",
@@ -236,6 +244,7 @@ static const char * cmDocumentationNOTE[][3] =
#endif
int do_cmake(int ac, char** av);
+static int do_build(int ac, char** av);
static cmMakefile* cmakemainGetMakefile(void *clientdata)
{
@@ -307,6 +316,10 @@ int main(int ac, char** av)
{
cmSystemTools::EnableMSVCDebugHook();
cmSystemTools::FindExecutableDirectory(av[0]);
+ if(ac > 1 && strcmp(av[1], "--build") == 0)
+ {
+ return do_build(ac, av);
+ }
int ret = do_cmake(ac, av);
#ifdef CMAKE_BUILD_WITH_CMAKE
cmDynamicLoader::FlushCache();
@@ -412,7 +425,6 @@ int do_cmake(int ac, char** av)
bool list_help = false;
bool view_only = false;
bool script_mode = false;
- bool build = false;
std::vector<std::string> args;
for(int i =0; i < ac; ++i)
{
@@ -420,10 +432,6 @@ int do_cmake(int ac, char** av)
{
wiz = true;
}
- else if(!command && strcmp(av[i], "--build") == 0)
- {
- return cmake::DoBuild(ac, av);
- }
else if(!command && strcmp(av[i], "--system-information") == 0)
{
sysinfo = true;
@@ -475,11 +483,6 @@ int do_cmake(int ac, char** av)
args.push_back(av[i]);
}
}
- if(build)
- {
- int ret = cmake::DoBuild(ac, av);
- return ret;
- }
if(command)
{
int ret = cmake::ExecuteCMakeCommand(args);
@@ -544,3 +547,85 @@ int do_cmake(int ac, char** av)
}
}
+//----------------------------------------------------------------------------
+static int do_build(int ac, char** av)
+{
+#ifndef CMAKE_BUILD_WITH_CMAKE
+ std::cerr << "This cmake does not support --build\n";
+ return -1;
+#else
+ std::string target;
+ std::string config = "Debug";
+ std::string dir;
+ std::vector<std::string> nativeOptions;
+ bool clean = false;
+
+ enum Doing { DoingNone, DoingDir, DoingTarget, DoingConfig, DoingNative};
+ Doing doing = DoingDir;
+ for(int i=2; i < ac; ++i)
+ {
+ if(doing == DoingNative)
+ {
+ nativeOptions.push_back(av[i]);
+ }
+ else if(strcmp(av[i], "--target") == 0)
+ {
+ doing = DoingTarget;
+ }
+ else if(strcmp(av[i], "--config") == 0)
+ {
+ doing = DoingConfig;
+ }
+ else if(strcmp(av[i], "--clean-first") == 0)
+ {
+ clean = true;
+ doing = DoingNone;
+ }
+ else if(strcmp(av[i], "--") == 0)
+ {
+ doing = DoingNative;
+ }
+ else
+ {
+ switch (doing)
+ {
+ case DoingDir:
+ dir = av[i];
+ doing = DoingNone;
+ break;
+ case DoingTarget:
+ target = av[i];
+ doing = DoingNone;
+ break;
+ case DoingConfig:
+ config = av[i];
+ doing = DoingNone;
+ break;
+ default:
+ std::cerr << "Unknown argument " << av[i] << std::endl;
+ dir = "";
+ break;
+ }
+ }
+ }
+ if(dir.empty())
+ {
+ std::cerr <<
+ "Usage: cmake --build <dir> [options] [-- [native-options]]\n"
+ "Options:\n"
+ CMAKE_BUILD_OPTIONS
+ ;
+ return 1;
+ }
+
+ // Hack for vs6 that passes ".\Debug" as "$(IntDir)" value:
+ //
+ if (cmSystemTools::StringStartsWith(config.c_str(), ".\\"))
+ {
+ config = config.substr(2);
+ }
+
+ cmake cm;
+ return cm.Build(dir, target, config, nativeOptions, clean);
+#endif
+}
diff --git a/Tests/CMakeBuildTest.cmake.in b/Tests/CMakeBuildTest.cmake.in
index ebba702..9c3002b 100644
--- a/Tests/CMakeBuildTest.cmake.in
+++ b/Tests/CMakeBuildTest.cmake.in
@@ -46,7 +46,7 @@ endif(RESULT)
# build it again with clean and only COnly target
execute_process(COMMAND "${CMAKE_COMMAND}"
--build "@CMAKE_BUILD_TEST_BINARY_DIR@" --config Debug
- --clean --target COnly
+ --clean-first --target COnly
RESULT_VARIABLE RESULT)
if(RESULT)
message(FATAL_ERROR "Error running cmake --build")