fix(ci): attempt to fix m1 compilation problem
This commit is contained in:
parent
0afa3f4208
commit
82d1b2f4e1
|
@ -17,10 +17,10 @@
|
||||||
* along with espanso. If not, see <https://www.gnu.org/licenses/>.
|
* along with espanso. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use std::path::{PathBuf};
|
use std::path::PathBuf;
|
||||||
|
|
||||||
#[cfg(not(target_os = "windows"))]
|
#[cfg(not(target_os = "windows"))]
|
||||||
use std::path::{Path};
|
use std::path::Path;
|
||||||
|
|
||||||
#[cfg(not(target_os = "linux"))]
|
#[cfg(not(target_os = "linux"))]
|
||||||
const WX_WIDGETS_ARCHIVE_NAME: &str = "wxWidgets-3.1.5.zip";
|
const WX_WIDGETS_ARCHIVE_NAME: &str = "wxWidgets-3.1.5.zip";
|
||||||
|
@ -89,7 +89,11 @@ fn build_native() {
|
||||||
])
|
])
|
||||||
.spawn()
|
.spawn()
|
||||||
.expect("failed to execute nmake");
|
.expect("failed to execute nmake");
|
||||||
if !handle.wait().expect("unable to wait for nmake command").success() {
|
if !handle
|
||||||
|
.wait()
|
||||||
|
.expect("unable to wait for nmake command")
|
||||||
|
.success()
|
||||||
|
{
|
||||||
panic!("nmake returned non-zero exit code!");
|
panic!("nmake returned non-zero exit code!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -164,52 +168,72 @@ fn build_native() {
|
||||||
let build_dir = out_wx_dir.join("build-cocoa");
|
let build_dir = out_wx_dir.join("build-cocoa");
|
||||||
std::fs::create_dir_all(&build_dir).expect("unable to create build-cocoa directory");
|
std::fs::create_dir_all(&build_dir).expect("unable to create build-cocoa directory");
|
||||||
|
|
||||||
let target_arch = match std::env::var("CARGO_CFG_TARGET_ARCH").expect("unable to read target arch").as_str() {
|
let target_arch = match std::env::var("CARGO_CFG_TARGET_ARCH")
|
||||||
|
.expect("unable to read target arch")
|
||||||
|
.as_str()
|
||||||
|
{
|
||||||
"x86_64" => "x86_64",
|
"x86_64" => "x86_64",
|
||||||
"aarch64" => "arm64",
|
"aarch64" => "arm64",
|
||||||
arch => panic!("unsupported arch {}", arch),
|
arch => panic!("unsupported arch {}", arch),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let mut handle = if std::env::var("CI").unwrap_or_default() == "true" {
|
||||||
// Because of a configuration problem on the GitHub CI pipeline, we need
|
// Because of a configuration problem on the GitHub CI pipeline, we need
|
||||||
// to set the target architecture manually.
|
// to compile for both architectures manually, as well as setting some flags.
|
||||||
// See: https://github.com/actions/virtual-environments/issues/3288#issuecomment-830207746
|
// See: https://github.com/actions/virtual-environments/issues/3288#issuecomment-830207746
|
||||||
let xcode_sdk_path = Command::new("xcrun").args(&["--sdk", "macosx", "--show-sdk-path"]).output().expect("unable to obtain XCode sdk path");
|
let xcode_sdk_path = Command::new("xcrun")
|
||||||
|
.args(&["--sdk", "macosx", "--show-sdk-path"])
|
||||||
|
.output()
|
||||||
|
.expect("unable to obtain XCode sdk path");
|
||||||
let xcode_sdk_path = String::from_utf8_lossy(&xcode_sdk_path.stdout);
|
let xcode_sdk_path = String::from_utf8_lossy(&xcode_sdk_path.stdout);
|
||||||
let xcode_sdk_path = xcode_sdk_path.trim();
|
let xcode_sdk_path = xcode_sdk_path.trim();
|
||||||
|
|
||||||
if xcode_sdk_path.is_empty() {
|
if xcode_sdk_path.is_empty() {
|
||||||
panic!("could not query XCode sdk path");
|
panic!("could not query XCode sdk path");
|
||||||
}
|
}
|
||||||
|
|
||||||
println!("Using SDK path: {}", xcode_sdk_path);
|
println!("Using SDK path: {}", xcode_sdk_path);
|
||||||
|
|
||||||
let configure_cxx_flags = format!("-isysroot {} -isystem {} -DSTDC_HEADERS=1 -DHAVE_FCNTL_H -arch {}", xcode_sdk_path, xcode_sdk_path, target_arch);
|
let configure_cxx_flags = format!(
|
||||||
|
"-isysroot {} -isystem {} -DSTDC_HEADERS=1 -DHAVE_FCNTL_H -arch arm64 -arch x86_64",
|
||||||
|
xcode_sdk_path, xcode_sdk_path
|
||||||
|
);
|
||||||
|
|
||||||
let mut handle = Command::new(out_wx_dir.join("configure"))
|
Command::new(out_wx_dir.join("configure"))
|
||||||
.current_dir(
|
.current_dir(build_dir.to_string_lossy().to_string())
|
||||||
build_dir.to_string_lossy().to_string()
|
.args(&["--disable-shared", "--without-libtiff"])
|
||||||
)
|
.env("CXXFLAGS", &configure_cxx_flags)
|
||||||
|
.spawn()
|
||||||
|
.expect("failed to execute configure")
|
||||||
|
} else {
|
||||||
|
Command::new(out_wx_dir.join("configure"))
|
||||||
|
.current_dir(build_dir.to_string_lossy().to_string())
|
||||||
.args(&[
|
.args(&[
|
||||||
"--disable-shared",
|
"--disable-shared",
|
||||||
"--without-libtiff",
|
"--without-libtiff",
|
||||||
|
&format!("--enable-macosx_arch={}", target_arch),
|
||||||
])
|
])
|
||||||
.env("CXXFLAGS", &configure_cxx_flags)
|
|
||||||
.spawn()
|
.spawn()
|
||||||
.expect("failed to execute configure");
|
.expect("failed to execute configure")
|
||||||
if !handle.wait().expect("unable to wait for configure command").success() {
|
};
|
||||||
|
|
||||||
|
if !handle
|
||||||
|
.wait()
|
||||||
|
.expect("unable to wait for configure command")
|
||||||
|
.success()
|
||||||
|
{
|
||||||
panic!("configure returned non-zero exit code!");
|
panic!("configure returned non-zero exit code!");
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut handle = Command::new("make")
|
let mut handle = Command::new("make")
|
||||||
.current_dir(
|
.current_dir(build_dir.to_string_lossy().to_string())
|
||||||
build_dir.to_string_lossy().to_string()
|
.args(&["-j8"])
|
||||||
)
|
|
||||||
.args(&[
|
|
||||||
"-j8",
|
|
||||||
])
|
|
||||||
.spawn()
|
.spawn()
|
||||||
.expect("failed to execute make");
|
.expect("failed to execute make");
|
||||||
if !handle.wait().expect("unable to wait for make command").success() {
|
if !handle
|
||||||
|
.wait()
|
||||||
|
.expect("unable to wait for make command")
|
||||||
|
.success()
|
||||||
|
{
|
||||||
panic!("make returned non-zero exit code!");
|
panic!("make returned non-zero exit code!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -355,7 +379,8 @@ fn build_native() {
|
||||||
// Make sure wxWidgets is installed
|
// Make sure wxWidgets is installed
|
||||||
if std::process::Command::new("wx-config")
|
if std::process::Command::new("wx-config")
|
||||||
.arg("--version")
|
.arg("--version")
|
||||||
.output().is_err()
|
.output()
|
||||||
|
.is_err()
|
||||||
{
|
{
|
||||||
panic!("wxWidgets is not installed, as `wx-config` cannot be exectued")
|
panic!("wxWidgets is not installed, as `wx-config` cannot be exectued")
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user