From 26bfe3dbdc20a04600c2544b886c9aede8cce194 Mon Sep 17 00:00:00 2001 From: Dan Stillman Date: Sat, 30 Mar 2024 07:00:52 -0400 Subject: [PATCH] CI: Fix "invalid ELF header" error for libc.so in OS.File.unixSymLink() --- chrome/content/zotero/osfile.mjs | 40 +++++++++++++++++++++----------- 1 file changed, 26 insertions(+), 14 deletions(-) diff --git a/chrome/content/zotero/osfile.mjs b/chrome/content/zotero/osfile.mjs index db1c0694b5..698729115d 100644 --- a/chrome/content/zotero/osfile.mjs +++ b/chrome/content/zotero/osfile.mjs @@ -225,20 +225,32 @@ export let OS = { ); try { - const libc = ctypes.open( - Services.appinfo.OS === "Darwin" ? "libSystem.B.dylib" : "libc.so" - ); - - const symlink = libc.declare( - "symlink", - ctypes.default_abi, - ctypes.int, // return value - ctypes.char.ptr, // target - ctypes.char.ptr //linkpath - ); - - if (symlink(pathTarget, pathCreate)) { - throw new Error("Failed to create symlink at " + pathCreate); + if (Services.appinfo.OS === "Darwin") { + const libc = ctypes.open( + Services.appinfo.OS === "Darwin" ? "libSystem.B.dylib" : "libc.so" + ); + + const symlink = libc.declare( + "symlink", + ctypes.default_abi, + ctypes.int, // return value + ctypes.char.ptr, // target + ctypes.char.ptr //linkpath + ); + + if (symlink(pathTarget, pathCreate)) { + throw new Error("Failed to create symlink at " + pathCreate); + } + } + // The above is failing with "invalid ELF header" for libc.so on GitHub Actions, so + // just use ln -s on non-macOS systems + else { + let ln = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsIFile); + ln.initWithPath("/bin/ln"); + let process = Cc["@mozilla.org/process/util;1"].createInstance(Ci.nsIProcess); + process.init(ln); + let args = ["-s", pathTarget, pathCreate]; + process.run(true, args, args.length); } } catch (e) {