Unverified Commit 8d1a3db9 authored by Mauricio Collares's avatar Mauricio Collares Committed by GitHub
Browse files

elan: fix for Lean >= 4.16.0 (#362062)

parents bdbcd8fc f317e28d
Loading
Loading
Loading
Loading
+26 −11
Original line number Diff line number Diff line
@@ -2,7 +2,7 @@ diff --git a/src/elan-dist/src/component/package.rs b/src/elan-dist/src/componen
index c51e76d..ae8159e 100644
--- a/src/elan-dist/src/component/package.rs
+++ b/src/elan-dist/src/component/package.rs
@@ -56,6 +56,37 @@ fn unpack_without_first_dir<R: Read>(archive: &mut tar::Archive<R>, path: &Path)
@@ -56,6 +56,52 @@ fn unpack_without_first_dir<R: Read>(archive: &mut tar::Archive<R>, path: &Path)
         entry
             .unpack(&full_path)
             .chain_err(|| ErrorKind::ExtractingPackage)?;
@@ -14,13 +14,12 @@ index c51e76d..ae8159e 100644
+
+fn nix_patch_if_needed(dest_path: &Path) -> Result<()> {
+    let is_bin = matches!(dest_path.parent(), Some(p) if p.ends_with("bin"));
+    if is_bin {
+    if !is_bin { return Ok(()) }
+    let _ = ::std::process::Command::new("@patchelf@/bin/patchelf")
+        .arg("--set-interpreter")
+        .arg("@dynamicLinker@")
+        .arg(dest_path)
+        .output();
+    }
+
+    if dest_path.file_name() == Some(::std::ffi::OsStr::new("leanc")) {
+        use std::os::unix::fs::PermissionsExt;
@@ -32,9 +31,25 @@ index c51e76d..ae8159e 100644
+LEAN_CC="${LEAN_CC:-@cc@}" exec -a "$0" "$dir/leanc.orig" "$@" -L"$dir/../lib"
+"#)?;
+        ::std::fs::set_permissions(dest_path, ::std::fs::Permissions::from_mode(0o755))?;
+    }
+    } else if dest_path.file_name() == Some(::std::ffi::OsStr::new("lake")) {
+        // since Lean 4.16.0, `lake` calls `LEAN_CC` directly instead of through `leanc`
+        use std::os::unix::fs::PermissionsExt;
+        ::std::fs::write(dest_path.with_file_name("cc"), r#"#! @shell@
+dir="$(dirname "${BASH_SOURCE[0]}")"
+# use bundled libraries, but not bundled compiler that doesn't know about NIX_LDFLAGS
+exec "@cc@" "$@" -L"$dir/../lib"
+"#)?;
+        ::std::fs::set_permissions(dest_path.with_file_name("cc"), ::std::fs::Permissions::from_mode(0o755))?;
+
+    if dest_path.file_name() == Some(::std::ffi::OsStr::new("llvm-ar")) {
+        let new_path = dest_path.with_extension("orig");
+        ::std::fs::rename(dest_path, &new_path)?;
+        ::std::fs::write(dest_path, r#"#! @shell@
+dir="$(dirname "${BASH_SOURCE[0]}")"
+# use custom `cc`
+LEAN_CC="${LEAN_CC:-"$dir/cc"}" exec -a "$0" "$dir/lake.orig" "$@"
+"#)?;
+        ::std::fs::set_permissions(dest_path, ::std::fs::Permissions::from_mode(0o755))?;
+    } else if dest_path.file_name() == Some(::std::ffi::OsStr::new("llvm-ar")) {
+        ::std::fs::remove_file(dest_path)?;
+        ::std::os::unix::fs::symlink("@ar@", dest_path)?;
     }