mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-01 19:30:13 -06:00
#pragma once is a widely supported compiler pragma, even though it is not part of the C++ standard. Many of the issues keeping #pragma once from being standardized (distributed filesystems, build farms, hard links, etc.) do not apply to CMake - it is easy to build CMake on a single machine. CMake also does not install any header files which can be consumed by other projects (though cmCPluginAPI.h has been deliberately omitted from this conversion in case anyone is still using it.) Finally, #pragma once has been required to build CMake since at least August 2017 (7f29bbe6enabled server mode unconditionally, which had been using #pragma once since September 2016 (b13d3e0d)). The fact that we now require C++11 filters out old compilers, and it is unlikely that there is a compiler which supports C++11 but does not support #pragma once.
178 lines
4.9 KiB
C++
178 lines
4.9 KiB
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
|
#pragma once
|
|
|
|
#include "cmConfigure.h" // IWYU pragma: keep
|
|
|
|
#include <chrono>
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "cmCTestGenericHandler.h"
|
|
#include "cmDuration.h"
|
|
|
|
class cmCTest;
|
|
class cmCTestCommand;
|
|
class cmGlobalGenerator;
|
|
class cmMakefile;
|
|
class cmake;
|
|
|
|
/** \class cmCTestScriptHandler
|
|
* \brief A class that handles ctest -S invocations
|
|
*
|
|
* CTest script is controlled using several variables that script has to
|
|
* specify and some optional ones. Required ones are:
|
|
* CTEST_SOURCE_DIRECTORY - Source directory of the project
|
|
* CTEST_BINARY_DIRECTORY - Binary directory of the project
|
|
* CTEST_COMMAND - Testing commands
|
|
*
|
|
* Optional variables are:
|
|
* CTEST_BACKUP_AND_RESTORE
|
|
* CTEST_CMAKE_COMMAND
|
|
* CTEST_CMAKE_OUTPUT_FILE_NAME
|
|
* CTEST_CONTINUOUS_DURATION
|
|
* CTEST_CONTINUOUS_MINIMUM_INTERVAL
|
|
* CTEST_CVS_CHECKOUT
|
|
* CTEST_CVS_COMMAND
|
|
* CTEST_UPDATE_COMMAND
|
|
* CTEST_DASHBOARD_ROOT
|
|
* CTEST_ENVIRONMENT
|
|
* CTEST_INITIAL_CACHE
|
|
* CTEST_START_WITH_EMPTY_BINARY_DIRECTORY
|
|
* CTEST_START_WITH_EMPTY_BINARY_DIRECTORY_ONCE
|
|
*
|
|
* In addition the following variables can be used. The number can be 1-10.
|
|
* CTEST_EXTRA_UPDATES_1
|
|
* CTEST_EXTRA_UPDATES_2
|
|
* ...
|
|
* CTEST_EXTRA_UPDATES_10
|
|
*
|
|
* CTest script can use the following arguments CTest provides:
|
|
* CTEST_SCRIPT_ARG
|
|
* CTEST_SCRIPT_DIRECTORY
|
|
* CTEST_SCRIPT_NAME
|
|
*
|
|
*/
|
|
class cmCTestScriptHandler : public cmCTestGenericHandler
|
|
{
|
|
public:
|
|
using Superclass = cmCTestGenericHandler;
|
|
|
|
/**
|
|
* Add a script to run, and if is should run in the current process
|
|
*/
|
|
void AddConfigurationScript(const char*, bool pscope);
|
|
|
|
/**
|
|
* Run a dashboard using a specified confiuration script
|
|
*/
|
|
int ProcessHandler() override;
|
|
|
|
/*
|
|
* Run a script
|
|
*/
|
|
static bool RunScript(cmCTest* ctest, cmMakefile* mf, const char* script,
|
|
bool InProcess, int* returnValue);
|
|
int RunCurrentScript();
|
|
|
|
/*
|
|
* Empty Binary Directory
|
|
*/
|
|
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
|
|
*/
|
|
static void SleepInSeconds(unsigned int secondsToWait);
|
|
void UpdateElapsedTime();
|
|
|
|
/**
|
|
* Return the time remaianing that the script is allowed to run in
|
|
* seconds if the user has set the variable CTEST_TIME_LIMIT. If that has
|
|
* not been set it returns a very large value.
|
|
*/
|
|
cmDuration GetRemainingTimeAllowed();
|
|
|
|
cmCTestScriptHandler();
|
|
cmCTestScriptHandler(const cmCTestScriptHandler&) = delete;
|
|
const cmCTestScriptHandler& operator=(const cmCTestScriptHandler&) = delete;
|
|
~cmCTestScriptHandler() override;
|
|
|
|
void Initialize() override;
|
|
|
|
void CreateCMake();
|
|
cmake* GetCMake() { return this->CMake.get(); }
|
|
|
|
void SetRunCurrentScript(bool value);
|
|
|
|
private:
|
|
// reads in a script
|
|
int ReadInScript(const std::string& total_script_arg);
|
|
int ExecuteScript(const std::string& total_script_arg);
|
|
|
|
// extract vars from the script to set ivars
|
|
int ExtractVariables();
|
|
|
|
// perform a CVS checkout of the source dir
|
|
int CheckOutSourceDir();
|
|
|
|
// perform any extra cvs updates that were requested
|
|
int PerformExtraUpdates();
|
|
|
|
// backup and restore dirs
|
|
int BackupDirectories();
|
|
void RestoreBackupDirectories();
|
|
|
|
int RunConfigurationScript(const std::string& script, bool pscope);
|
|
int RunConfigurationDashboard();
|
|
|
|
// Add ctest command
|
|
void AddCTestCommand(std::string const& name,
|
|
std::unique_ptr<cmCTestCommand> command);
|
|
|
|
// Try to remove the binary directory once
|
|
static bool TryToRemoveBinaryDirectoryOnce(const std::string& directoryPath);
|
|
|
|
std::vector<std::string> ConfigurationScripts;
|
|
std::vector<bool> ScriptProcessScope;
|
|
|
|
bool ShouldRunCurrentScript;
|
|
|
|
bool Backup = false;
|
|
bool EmptyBinDir = false;
|
|
bool EmptyBinDirOnce = false;
|
|
|
|
std::string SourceDir;
|
|
std::string BinaryDir;
|
|
std::string BackupSourceDir;
|
|
std::string BackupBinaryDir;
|
|
std::string CTestRoot;
|
|
std::string CVSCheckOut;
|
|
std::string CTestCmd;
|
|
std::string UpdateCmd;
|
|
std::string CTestEnv;
|
|
std::string InitialCache;
|
|
std::string CMakeCmd;
|
|
std::string CMOutFile;
|
|
std::vector<std::string> ExtraUpdates;
|
|
|
|
// the *60 is because the settings are in minutes but GetTime is seconds
|
|
double MinimumInterval = 30 * 60;
|
|
double ContinuousDuration = -1;
|
|
|
|
// what time in seconds did this script start running
|
|
std::chrono::steady_clock::time_point ScriptStartTime =
|
|
std::chrono::steady_clock::time_point();
|
|
|
|
std::unique_ptr<cmMakefile> Makefile;
|
|
cmMakefile* ParentMakefile = nullptr;
|
|
std::unique_ptr<cmGlobalGenerator> GlobalGenerator;
|
|
std::unique_ptr<cmake> CMake;
|
|
};
|