From b6c26cded2965d566ad1ad874f9dac146af4ceac Mon Sep 17 00:00:00 2001 From: Brad King Date: Fri, 11 Sep 2009 10:09:48 -0400 Subject: Initialize cmCTestRunTest instances robustly All instances of this class need a cmCTestTestHandler, so we now require one to construct it. The instance also provides the cmCTest instance too. --- Source/CTest/cmCTestMultiProcessHandler.cxx | 8 ++------ Source/CTest/cmCTestRunTest.cxx | 10 +++------- Source/CTest/cmCTestRunTest.h | 6 +----- 3 files changed, 6 insertions(+), 18 deletions(-) diff --git a/Source/CTest/cmCTestMultiProcessHandler.cxx b/Source/CTest/cmCTestMultiProcessHandler.cxx index bebaf1e..7d3a8bf 100644 --- a/Source/CTest/cmCTestMultiProcessHandler.cxx +++ b/Source/CTest/cmCTestMultiProcessHandler.cxx @@ -83,9 +83,7 @@ void cmCTestMultiProcessHandler::StartTestProcess(int test) // now remove the test itself this->EraseTest(test); - cmCTestRunTest* testRun = new cmCTestRunTest; - testRun->SetCTest(this->CTest); - testRun->SetTestHandler(this->TestHandler); + cmCTestRunTest* testRun = new cmCTestRunTest(this->TestHandler); testRun->SetIndex(test); testRun->SetTestProperties(this->Properties[test]); if(testRun->StartTest()) @@ -346,9 +344,7 @@ void cmCTestMultiProcessHandler::PrintTestList() count++; cmCTestTestHandler::cmCTestTestProperties& p = *it->second; - cmCTestRunTest testRun; - testRun.SetCTest(this->CTest); - testRun.SetTestHandler(this->TestHandler); + cmCTestRunTest testRun(this->TestHandler); testRun.SetIndex(p.Index); testRun.SetTestProperties(&p); testRun.ComputeArguments(); //logs the command in verbose mode diff --git a/Source/CTest/cmCTestRunTest.cxx b/Source/CTest/cmCTestRunTest.cxx index 92df585..86119a2 100644 --- a/Source/CTest/cmCTestRunTest.cxx +++ b/Source/CTest/cmCTestRunTest.cxx @@ -20,8 +20,10 @@ #include "cmCTest.h" #include "cmSystemTools.h" -cmCTestRunTest::cmCTestRunTest() +cmCTestRunTest::cmCTestRunTest(cmCTestTestHandler* handler) { + this->CTest = handler->CTest; + this->TestHandler = handler; } cmCTestRunTest::~cmCTestRunTest() @@ -302,12 +304,6 @@ void cmCTestRunTest::MemCheckPostProcess() } } -void cmCTestRunTest::SetTestHandler(cmCTestTestHandler * handler) -{ - this->TestHandler = handler; - this->CTest = handler->CTest; -} - //---------------------------------------------------------------------- // Starts the execution of a test. Returns once it has started bool cmCTestRunTest::StartTest() diff --git a/Source/CTest/cmCTestRunTest.h b/Source/CTest/cmCTestRunTest.h index d104d7d..ee888d3 100644 --- a/Source/CTest/cmCTestRunTest.h +++ b/Source/CTest/cmCTestRunTest.h @@ -29,7 +29,7 @@ class cmCTestRunTest { public: - cmCTestRunTest(); + cmCTestRunTest(cmCTestTestHandler* handler); ~cmCTestRunTest(); void SetTestProperties(cmCTestTestHandler::cmCTestTestProperties * prop) @@ -37,13 +37,9 @@ public: cmCTestTestHandler::cmCTestTestProperties * GetTestProperties() { return this->TestProperties; } - - void SetTestHandler(cmCTestTestHandler * handler); void SetIndex(int i) { this->Index = i; } - void SetCTest(cmCTest * ct) { this->CTest = ct; } - int GetIndex() { return this->Index; } std::string GetProcessOutput() { return this->ProcessOutput; } -- cgit v0.12