mirror of
https://github.com/Relintai/osxcross.git
synced 2025-02-03 22:45:56 +01:00
Misc pkg-config adjustments (closes #69)
This commit is contained in:
parent
13240f3bd0
commit
e3e3cfb83e
21
README.PKG-CONFIG.md
Normal file
21
README.PKG-CONFIG.md
Normal file
@ -0,0 +1,21 @@
|
||||
OSXCross' pkg-config ignores `PKG_CONFIG_*` environment variables by default and maps to `OSXCROSS_PKG_*` to `PKG_*` internally to prevent including wrong header files (`/usr/include`, etc.).
|
||||
|
||||
You can restore the default behavior by setting `OSXCROSS_PKG_CONFIG_USE_NATIVE_VARIABLES` (env) to 1.
|
||||
|
||||
Usage examples:
|
||||
|
||||
$ x86_64-apple-darwin15-pkg-config
|
||||
osxcross: warning: x86_64-apple-darwin15-pkg-config is a no-op - please see README.PKG-CONFIG.md for more
|
||||
## Explanation: No MacPorts packages installed and no OSXCROSS_PKG_* variables set = no-op. ##
|
||||
|
||||
$ x86_64-apple-darwin15-pkg-config --libs sdl2
|
||||
-L[...]/target/bin/../macports/pkgs/opt/local/lib -lSDL2
|
||||
|
||||
$ OSXCROSS_PKG_CONFIG_NO_MP_INC=1 x86_64-apple-darwin15-pkg-config --libs sdl2
|
||||
osxcross: warning: x86_64-apple-darwin15-pkg-config is a no-op - please see README.PKG-CONFIG.md for more
|
||||
|
||||
$ OSXCROSS_PKG_CONFIG_LIBDIR=<path> x86_64-apple-darwin15-pkg-config
|
||||
## Explanation: OSXCROSS_PKG_CONFIG_LIBDIR gets mapped to PKG_CONFIG_LIBDIR internally. ##
|
||||
|
||||
$ OSXCROSS_PKG_CONFIG_USE_NATIVE_VARIABLES=1 PKG_CONFIG_LIBDIR=<path> x86_64-apple-darwin15-pkg-config
|
||||
## Explanation: Restores the default behavior. PKG_CONFIG_LIBDIR is used and OSXCROSS_PKG_* variables will be ignored. ##
|
@ -48,50 +48,68 @@ int pkg_config(int argc, char **argv, Target &target) {
|
||||
std::vector<envvar> envvars;
|
||||
std::vector<envvar> unset;
|
||||
envvar evar;
|
||||
bool usenativevariables = getenv("OSXCROSS_PKG_CONFIG_USE_NATIVE_VARIABLES");
|
||||
|
||||
if (!getenv("OSXCROSS_PKG_CONFIG_NO_MP_INC")) {
|
||||
std::string MacPortsSysRoot;
|
||||
|
||||
if (target.getMacPortsSysRootDir(MacPortsSysRoot)) {
|
||||
concatEnvVariable("OSXCROSS_PKG_CONFIG_SYSROOT_DIR", MacPortsSysRoot);
|
||||
concatEnvVariable(usenativevariables ? "PKG_CONFIG_SYSROOT_DIR"
|
||||
: "OSXCROSS_PKG_CONFIG_SYSROOT_DIR",
|
||||
MacPortsSysRoot);
|
||||
|
||||
std::string MacPortsPkgConfigPath;
|
||||
|
||||
if (target.getMacPortsPkgConfigDir(MacPortsPkgConfigPath))
|
||||
concatEnvVariable("OSXCROSS_PKG_CONFIG_PATH", MacPortsPkgConfigPath);
|
||||
concatEnvVariable(usenativevariables ? "PKG_CONFIG_PATH"
|
||||
: "OSXCROSS_PKG_CONFIG_PATH",
|
||||
MacPortsPkgConfigPath);
|
||||
}
|
||||
} else {
|
||||
unsetenv("OSXCROSS_PKG_CONFIG_NO_MP_INC");
|
||||
}
|
||||
|
||||
// Map OSXCROSS_PKG_* to PKG_*.
|
||||
for (char **env = environ; *env; ++env) {
|
||||
char *p = *env;
|
||||
if (!usenativevariables) {
|
||||
// Map OSXCROSS_PKG_* to PKG_*.
|
||||
for (char **env = environ; *env; ++env) {
|
||||
char *p = *env;
|
||||
|
||||
if (!strncmp(p, "OSXCROSS_PKG_CONFIG", 19)) {
|
||||
p += 9; // skip OSXCROSS_
|
||||
envvars.push_back(var(p, evar));
|
||||
} else if (!strncmp(p, "PKG_CONFIG", 10)) {
|
||||
// Unset native pkg-config vars.
|
||||
unset.push_back(var(p, evar, true));
|
||||
if (!strncmp(p, "OSXCROSS_PKG_CONFIG", 19)) {
|
||||
p += 9; // skip OSXCROSS_
|
||||
envvars.push_back(var(p, evar));
|
||||
} else if (!strncmp(p, "PKG_CONFIG", 10)) {
|
||||
// Unset native pkg-config vars.
|
||||
unset.push_back(var(p, evar, true));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!envvars.empty()) {
|
||||
for (const envvar &evar : unset)
|
||||
unsetenv(evar.name.c_str());
|
||||
if (usenativevariables || !envvars.empty()) {
|
||||
if (!usenativevariables) {
|
||||
for (const envvar &evar : unset) {
|
||||
warn << argv[0] << ": ignoring environment variable '" << evar.name
|
||||
<< "' - please see README.PKG-CONFIG.md for more" << warn.endl();
|
||||
|
||||
for (const envvar &evar : envvars)
|
||||
setenv(evar.name.c_str(), evar.value.c_str(), 1);
|
||||
unsetenv(evar.name.c_str());
|
||||
}
|
||||
|
||||
for (const envvar &evar : envvars)
|
||||
setenv(evar.name.c_str(), evar.value.c_str(), 1);
|
||||
}
|
||||
|
||||
// Prevent pkg-config from looking for *.pc files
|
||||
// in pre-defined search paths, such as /usr.
|
||||
if (!getenv("PKG_CONFIG_LIBDIR"))
|
||||
setenv("PKG_CONFIG_LIBDIR", "", 1);
|
||||
|
||||
if (execvp("pkg-config", argv))
|
||||
err << "cannot find or execute pkg-config" << err.endl();
|
||||
execvp("pkg-config", argv);
|
||||
err << "cannot find or execute pkg-config" << err.endl();
|
||||
return 1;
|
||||
}
|
||||
|
||||
warn << argv[0] << " is a no-op - please see README.PKG-CONFIG.md for more"
|
||||
<< warn.endl();
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user