aboutsummaryrefslogtreecommitdiff
path: root/src/CmakeModule.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/CmakeModule.cpp')
-rw-r--r--src/CmakeModule.cpp20
1 files changed, 17 insertions, 3 deletions
diff --git a/src/CmakeModule.cpp b/src/CmakeModule.cpp
index a573e85..ed04e26 100644
--- a/src/CmakeModule.cpp
+++ b/src/CmakeModule.cpp
@@ -2,6 +2,7 @@
#include "../include/Exec.hpp"
#include "../include/GlobalLib.hpp"
#include "../include/PkgConfig.hpp"
+#include "../backend/BackendUtils.hpp"
#if OS_FAMILY == OS_FAMILY_POSIX
#define nprintf printf
@@ -10,9 +11,17 @@
#endif
using namespace std;
+using namespace backend;
namespace sibs
{
+ static FileString cmakePath = TINYDIR_STRING("cmake");
+
+ void CmakeModule::setCmakePath(const FileString &path)
+ {
+ cmakePath = path;
+ }
+
Result<bool> CmakeModule::compile(const SibsConfig &config, const FileString &buildPath, LinkerFlagCallbackFunc staticLinkerFlagCallbackFunc, LinkerFlagCallbackFunc dynamicLinkerFlagCallbackFunc, GlobalIncludeDirCallbackFunc globalIncludeDirCallback)
{
// TODO: Make packaging work with cmake projects
@@ -128,7 +137,8 @@ namespace sibs
if (createBuildDirResult.isErr())
return createBuildDirResult;
- FileString cmd = TINYDIR_STRING("cmake ");
+ FileString cmd = cmakePath;
+ cmd += TINYDIR_STRING(" ");
if(config.getCompiler() == Compiler::GCC)
{
if(config.getSanitize())
@@ -207,12 +217,16 @@ namespace sibs
if(config.getPackageType() != PackageType::EXECUTABLE)
{
+ const _tinydir_char_t *dynamicLibExtension = TINYDIR_STRING(CONFIG_DYNAMIC_LIB_FILE_EXTENSION);
+ if(config.getCompiler() == Compiler::MINGW_W64)
+ dynamicLibExtension = TINYDIR_STRING("dll");
+
string buildPathUtf8 = toUtf8(buildPath);
nprintf("Searching for libraries generate by cmake in build path: %s\n", buildPathUtf8.c_str());
walkDirFilesRecursive(buildPath.c_str(),
- [&config, &parentProjStaticLinkerFlagCallbackFunc, &parentProjDynamicLinkerFlagCallbackFunc](tinydir_file *file)
+ [&config, &parentProjStaticLinkerFlagCallbackFunc, &parentProjDynamicLinkerFlagCallbackFunc, dynamicLibExtension](tinydir_file *file)
{
- if(_tinydir_strcmp(file->extension, CONFIG_DYNAMIC_LIB_FILE_EXTENSION) == 0 || _tinydir_strcmp(file->extension, CONFIG_STATIC_LIB_FILE_EXTENSION) == 0)
+ if(_tinydir_strcmp(file->extension, dynamicLibExtension) == 0 || _tinydir_strcmp(file->extension, CONFIG_STATIC_LIB_FILE_EXTENSION) == 0)
{
string libFileUtf8 = toUtf8(file->path);
nprintf("Library generated by cmake: %s\n", libFileUtf8.c_str());