diff options
-rw-r--r-- | Source/cmake.cxx | 87 |
1 files changed, 49 insertions, 38 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx index f7b21b5..44e6fce 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -133,39 +133,41 @@ void cmake::AddCMakePaths(const std::vector<std::string>& args) std::string cMakeSelf = args[0]; cmSystemTools::ConvertToUnixSlashes(cMakeSelf); cMakeSelf = cmSystemTools::FindProgram(cMakeSelf.c_str()); -#ifdef CMAKE_BUILD_DIR if(!cmSystemTools::FileExists(cMakeSelf.c_str())) { - cMakeSelf = CMAKE_BUILD_DIR; - cMakeSelf += "/Source/cmake"; - } +#ifdef CMAKE_BUILD_DIR + cMakeSelf = CMAKE_BUILD_DIR; + cMakeSelf += "/Source/cmake"; #endif + } #ifdef CMAKE_PREFIX - if(!cmSystemTools::FileExists(cMakeSelf.c_str())) + else if(!cmSystemTools::FileExists(cMakeSelf.c_str())) { - cMakeSelf = CMAKE_PREFIX "/bin/cmake"; + cMakeSelf = CMAKE_PREFIX "/bin/cmake"; } #endif - if(!cmSystemTools::FileExists(cMakeSelf.c_str())) + else if(!cmSystemTools::FileExists(cMakeSelf.c_str())) { - cmSystemTools::Error("CMAKE can not find the command line program cmake. " - "Attempted path: ", cMakeSelf.c_str()); - return; + cmSystemTools::Error("CMAKE can not find the command line program cmake. " + "Attempted path: ", cMakeSelf.c_str()); + return; } - // Save the value in the cache + // Save the value in the cache cmCacheManager::GetInstance()->AddCacheEntry ("CMAKE_COMMAND", cmSystemTools::EscapeSpaces(cMakeSelf.c_str()).c_str(), "Path to CMake executable.", cmCacheManager::INTERNAL); - + // do CMAKE_ROOT, look for the environment variable first std::string cMakeRoot; + std::string modules; if (getenv("CMAKE_ROOT")) { cMakeRoot = getenv("CMAKE_ROOT"); + modules = cMakeRoot + "/Modules/FindVTK.cmake"; } - else + if(!cmSystemTools::FileExists(modules.c_str())) { // next try exe/.. cMakeRoot = cmSystemTools::GetProgramPath(cMakeSelf.c_str()); @@ -175,34 +177,43 @@ void cmake::AddCMakePaths(const std::vector<std::string>& args) cMakeRoot = cMakeRoot.substr(0, slashPos); } // is there no Modules direcory there? - std::string modules = cMakeRoot + "/Modules/FindVTK.cmake"; - if (!cmSystemTools::FileExists(modules.c_str())) - { - // try exe/../share/cmake - modules = cMakeRoot + "/share/CMake/Modules/FindVTK.cmake"; - if (!cmSystemTools::FileExists(modules.c_str())) - { + modules = cMakeRoot + "/Modules/FindVTK.cmake"; + } + + else if (!cmSystemTools::FileExists(modules.c_str())) + { + // try exe/../share/cmake + modules = cMakeRoot + "/share/CMake/Modules/FindVTK.cmake"; + } #ifdef CMAKE_ROOT_DIR - // try compiled in value on UNIX - cMakeRoot = CMAKE_ROOT_DIR; - modules = cMakeRoot + "/Modules/FindVTK.cmake"; + else if (!cmSystemTools::FileExists(modules.c_str())) + { + // try compiled in value on UNIX + cMakeRoot = CMAKE_ROOT_DIR; + modules = cMakeRoot + "/Modules/FindVTK.cmake"; + } #endif - if (!cmSystemTools::FileExists(modules.c_str())) - { - // couldn't find modules - cmSystemTools::Error("Could not find CMAKE_ROOT !!!\n", - "Modules directory not in directory:\n", - modules.c_str()); - return; - } - } - else - { - cMakeRoot = cMakeRoot + "/share/CMake"; - } - } +#ifdef CMAKE_PREFIX + else if (!cmSystemTools::FileExists(modules.c_str())) + { + // try compiled in value on UNIX + cMakeRoot = CMAKE_PREFIX "/share/CMake"; + modules = cMakeRoot + "/Modules/FindVTK.cmake"; + } +#endif + else if (!cmSystemTools::FileExists(modules.c_str())) + { + cMakeRoot = cMakeRoot + "/share/CMake"; + modules = cMakeRoot + "/Modules/FindVTK.cmake"; + } + else if (!cmSystemTools::FileExists(modules.c_str())) + { + // couldn't find modules + cmSystemTools::Error("Could not find CMAKE_ROOT !!!\n", + "Modules directory not in directory:\n", + modules.c_str()); + return; } - cmCacheManager::GetInstance()->AddCacheEntry ("CMAKE_ROOT", cMakeRoot.c_str(), "Path to CMake installation.", cmCacheManager::INTERNAL); |