From 8907dad99e1ab930884c5f8f71a183b83b644d6d Mon Sep 17 00:00:00 2001 From: Bill Hoffman Date: Tue, 13 Jan 2004 11:22:47 -0500 Subject: [PATCH] ENH: add no cmake option --- Source/cmCTest.cxx | 70 ++++++++++++++++++++++++++-------------------- Source/cmCTest.h | 3 +- 2 files changed, 42 insertions(+), 31 deletions(-) diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx index a985fb309..0080473e4 100644 --- a/Source/cmCTest.cxx +++ b/Source/cmCTest.cxx @@ -304,6 +304,7 @@ bool TryExecutable(const char *dir, const char *file, cmCTest::cmCTest() { + m_BuildNoCMake = false; m_BuildNoClean = false; m_BuildTwoConfig = false; m_UseIncludeRegExp = false; @@ -3703,6 +3704,11 @@ int cmCTest::Run(std::vectorconst& args, std::string* output) i++; m_BuildTarget = args[i]; } + if(arg.find("--build-nocmake",0) == 0 && i < args.size() - 1) + { + i++; + m_BuildNoCMake = true; + } if(arg.find("--build-run-dir",0) == 0 && i < args.size() - 1) { i++; @@ -3848,8 +3854,10 @@ void CMakeStdoutCallback(const char* m, int len, void* s) out->append(m, len); } + int cmCTest::RunCMakeAndTest(std::string* outstring) { + unsigned int k; cmSystemTools::ResetErrorOccuredFlag(); cmListFileCache::GetInstance()->ClearCache(); std::string cmakeOutString; @@ -3872,39 +3880,22 @@ int cmCTest::RunCMakeAndTest(std::string* outstring) cmSystemTools::MakeDirectory(m_BinaryDir.c_str()); } cmSystemTools::ChangeDirectory(m_BinaryDir.c_str()); - std::vector args; - args.push_back(m_CMakeSelf); - args.push_back(m_SourceDir); - if(m_BuildGenerator.size()) + if(!m_BuildNoCMake) { - std::string generator = "-G"; - generator += m_BuildGenerator; - args.push_back(generator); - } - - unsigned int k; - for(k=0; k < m_BuildOptions.size(); ++k) - { - args.push_back(m_BuildOptions[k]); - } - if (cm.Run(args) != 0) - { - out << "Error: cmake execution failed\n"; - out << cmakeOutString << "\n"; - // return to the original directory - cmSystemTools::ChangeDirectory(cwd.c_str()); - if(outstring) + std::vector args; + args.push_back(m_CMakeSelf); + args.push_back(m_SourceDir); + if(m_BuildGenerator.size()) { - *outstring = out.str(); + std::string generator = "-G"; + generator += m_BuildGenerator; + args.push_back(generator); } - else + + for(k=0; k < m_BuildOptions.size(); ++k) { - std::cerr << out << "\n"; + args.push_back(m_BuildOptions[k]); } - return 1; - } - if(m_BuildTwoConfig) - { if (cm.Run(args) != 0) { out << "Error: cmake execution failed\n"; @@ -3921,7 +3912,27 @@ int cmCTest::RunCMakeAndTest(std::string* outstring) } return 1; } + if(m_BuildTwoConfig) + { + if (cm.Run(args) != 0) + { + out << "Error: cmake execution failed\n"; + out << cmakeOutString << "\n"; + // return to the original directory + cmSystemTools::ChangeDirectory(cwd.c_str()); + if(outstring) + { + *outstring = out.str(); + } + else + { + std::cerr << out << "\n"; + } + return 1; + } + } } + cmSystemTools::SetErrorCallback(0, 0); out << cmakeOutString << "\n"; if(m_BuildMakeProgram.size() == 0) @@ -4029,7 +4040,7 @@ int cmCTest::RunCMakeAndTest(std::string* outstring) } // command line make program - + out << "Running make command: " << makeCommand.c_str() << "\n"; retVal = 0; std::string output; @@ -4068,7 +4079,6 @@ int cmCTest::RunCMakeAndTest(std::string* outstring) cmSystemTools::ChangeDirectory(cwd.c_str()); return 1; } - out << output; if(m_TestCommand.size() == 0) diff --git a/Source/cmCTest.h b/Source/cmCTest.h index 89361381f..cd619b36b 100644 --- a/Source/cmCTest.h +++ b/Source/cmCTest.h @@ -308,7 +308,8 @@ private: std::vector m_TestCommandArgs; bool m_BuildTwoConfig; bool m_BuildNoClean; - std::string m_NotesFiles; + bool m_BuildNoCMake; + std::string m_NotesFiles; //! Reread the configuration file void UpdateCTestConfiguration();