summaryrefslogtreecommitdiff
path: root/src/configure.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/configure.cc')
-rw-r--r--src/configure.cc38
1 files changed, 38 insertions, 0 deletions
diff --git a/src/configure.cc b/src/configure.cc
index 910b878..471afd5 100644
--- a/src/configure.cc
+++ b/src/configure.cc
@@ -9,6 +9,8 @@
#include <optional>
#include <span>
#include <cstring>
+#include <vector>
+#include <deque>
#include "execute.h"
#include "ctor.h"
@@ -25,7 +27,11 @@ const std::filesystem::path configHeaderFile("config.h");
std::map<std::string, std::string> external_includedir;
std::map<std::string, std::string> external_libdir;
+#if !defined(_WIN32)
const ctor::configuration& __attribute__((weak)) ctor::get_configuration()
+#else
+const ctor::configuration& default_get_configuration()
+#endif
{
static ctor::configuration cfg;
static bool initialised{false};
@@ -40,6 +46,14 @@ const ctor::configuration& __attribute__((weak)) ctor::get_configuration()
}
return cfg;
}
+#if defined(_WIN32)
+// Hack to make ctor::get_configuration "weak" linked
+// See:
+// https://stackoverflow.com/questions/2290587/gcc-style-weak-linking-in-visual-studio
+// and
+// https://stackoverflow.com/questions/11849853/how-to-list-functions-present-in-object-file
+#pragma comment(linker, "/alternatename:?get_configuration@ctor@@YAABUconfiguration@1@XZ=?default_get_configuration@@YAABUconfiguration@ctor@@XZ")
+#endif
namespace ctor {
std::optional<std::string> includedir;
@@ -174,6 +188,9 @@ std::ostream& operator<<(std::ostream& stream, const ctor::toolchain& toolchain)
case ctor::toolchain::gcc:
stream << "ctor::toolchain::gcc";
break;
+ case ctor::toolchain::msvc:
+ stream << "ctor::toolchain::msvc";
+ break;
case ctor::toolchain::clang:
stream << "ctor::toolchain::clang";
break;
@@ -966,6 +983,27 @@ int configure(const ctor::settings& global_settings, int argc, char* argv[])
env["PATH"] = value;
}
+ // Env vars for msvc
+ if(get_env("CL", value))
+ {
+ env["CL"] = value;
+ }
+
+ if(get_env("LIB", value))
+ {
+ env["LIB"] = value;
+ }
+
+ if(get_env("LINK", value))
+ {
+ env["LINK"] = value;
+ }
+
+ if(get_env("INCLUDE", value))
+ {
+ env["INCLUDE"] = value;
+ }
+
auto ret = regenerateCache(settings, args_span[0], args, env);
if(ret != 0)
{