Browse Source

STYLE: move the code for writing the initial cache into its own separate
function, makes the long ProcessHandler() a little bit shorter

Alex

Alexander Neundorf 16 years ago
parent
commit
46f99c6565
2 changed files with 31 additions and 12 deletions
  1. 26 12
      Source/CTest/cmCTestScriptHandler.cxx
  2. 5 0
      Source/CTest/cmCTestScriptHandler.h

+ 26 - 12
Source/CTest/cmCTestScriptHandler.cxx

@@ -881,22 +881,12 @@ int cmCTestScriptHandler::RunConfigurationDashboard()
   // put the initial cache into the bin dir
   // put the initial cache into the bin dir
   if (!this->InitialCache.empty())
   if (!this->InitialCache.empty())
     {
     {
-    std::string cacheFile = this->BinaryDir;
-    cacheFile += "/CMakeCache.txt";
-    cmGeneratedFileStream fout(cacheFile.c_str());
-    if(!fout)
+    if (!this->WriteInitialCache(this->BinaryDir.c_str(), 
+         this->InitialCache.c_str()))
       {
       {
       this->RestoreBackupDirectories();
       this->RestoreBackupDirectories();
       return 9;
       return 9;
       }
       }
-
-    fout.write(this->InitialCache.c_str(), this->InitialCache.size());
-
-    // Make sure the operating system has finished writing the file
-    // before closing it.  This will ensure the file is finished before
-    // the check below.
-    fout.flush();
-    fout.close();
     }
     }
 
 
   // do an initial cmake to setup the DartConfig file
   // do an initial cmake to setup the DartConfig file
@@ -995,6 +985,30 @@ int cmCTestScriptHandler::RunConfigurationDashboard()
   return 0;
   return 0;
 }
 }
 
 
+//-------------------------------------------------------------------------
+bool cmCTestScriptHandler::WriteInitialCache(const char* directory, 
+                                             const char* text)
+{
+  std::string cacheFile = directory;
+  cacheFile += "/CMakeCache.txt";
+  cmGeneratedFileStream fout(cacheFile.c_str());
+  if(!fout)
+    {
+    return false;
+    }
+
+  if (text!=0)
+    {
+    fout.write(text, strlen(text));
+    }
+
+  // Make sure the operating system has finished writing the file
+  // before closing it.  This will ensure the file is finished before
+  // the check below.
+  fout.flush();
+  fout.close();
+  return true;
+}
 
 
 //-------------------------------------------------------------------------
 //-------------------------------------------------------------------------
 void cmCTestScriptHandler::RestoreBackupDirectories()
 void cmCTestScriptHandler::RestoreBackupDirectories()

+ 5 - 0
Source/CTest/cmCTestScriptHandler.h

@@ -90,6 +90,11 @@ public:
    */
    */
   static bool EmptyBinaryDirectory(const char *dir);
   static bool EmptyBinaryDirectory(const char *dir);
 
 
+  /*
+   * Write an initial CMakeCache.txt from the given contents.
+   */
+  static bool WriteInitialCache(const char* directory, const char* text);
+
   /*
   /*
    * Some elapsed time handling functions
    * Some elapsed time handling functions
    */
    */