diff options
author | Emery Hemingway <ehmry@posteo.net> | 2020-08-17 16:37:29 +0200 |
---|---|---|
committer | ehmry <ehmry@posteo.net> | 2020-09-07 16:16:55 +0200 |
commit | 06ac3c1d2a4d0f9476baa660574110f64b6dbf72 (patch) | |
tree | 5aca5d1570bc865281e1f78c36f0bca3e2eb5902 /pkgs/development/compilers/nim | |
parent | a31736120c5de6e632f5a0ba1ed34e53fc1c1b00 (diff) |
nim: patch to fix dynamic library loading
Diffstat (limited to 'pkgs/development/compilers/nim')
-rw-r--r-- | pkgs/development/compilers/nim/default.nix | 4 | ||||
-rw-r--r-- | pkgs/development/compilers/nim/nixbuild.patch | 51 |
2 files changed, 55 insertions, 0 deletions
diff --git a/pkgs/development/compilers/nim/default.nix b/pkgs/development/compilers/nim/default.nix index 543a6120577f3..d497cc76e9bbc 100644 --- a/pkgs/development/compilers/nim/default.nix +++ b/pkgs/development/compilers/nim/default.nix @@ -28,6 +28,10 @@ stdenv.mkDerivation rec { openssl pcre readline boehmgc sfml sqlite ]; + patches = [ ./nixbuild.patch ]; + + postPatch = "echo define:nixbuild >> config/nim.cfg"; + buildPhase = '' runHook preBuild diff --git a/pkgs/development/compilers/nim/nixbuild.patch b/pkgs/development/compilers/nim/nixbuild.patch new file mode 100644 index 0000000000000..bdfd04744e16d --- /dev/null +++ b/pkgs/development/compilers/nim/nixbuild.patch @@ -0,0 +1,51 @@ +commit 164ba50fc74b980f77047080b2ae1ea099ae9b27 +Author: Emery Hemingway <ehmry@posteo.net> +Date: Mon Sep 7 14:09:22 2020 +0200 + + Load libaries by absolute path on NixOS + + If "nixbuild" is defined then choose dynamic runtime libraries by + searching $NIX_LDFLAGS at compile-time. + + Fix #15194 + +diff --git a/lib/pure/dynlib.nim b/lib/pure/dynlib.nim +index f31ae94dd..debed9c07 100644 +--- a/lib/pure/dynlib.nim ++++ b/lib/pure/dynlib.nim +@@ -56,6 +56,9 @@ + + import strutils + ++when defined(nixbuild): ++ import os ++ + type + LibHandle* = pointer ## a handle to a dynamically loaded library + +@@ -95,6 +98,25 @@ proc libCandidates*(s: string, dest: var seq[string]) = + libCandidates(prefix & middle & suffix, dest) + else: + add(dest, s) ++ when defined(nixbuild): ++ # Nix doesn't have a global library directory so ++ # load libraries using an absolute path if one ++ # can be derived from NIX_LDFLAGS. ++ # ++ # During Nix/NixOS packaging the line "define:nixbuild" ++ # should be appended to the ../../config/nim.cfg file ++ # to enable this behavior by default. ++ # ++ var libDirs = split(getEnv("LD_LIBRARY_PATH"), ':') ++ for flag in split(getEnv("NIX_LDFLAGS")): ++ if flag.startsWith("-L"): ++ libDirs.add(flag[2..flag.high]) ++ for lib in dest: ++ for dir in libDirs: ++ let abs = dir / lib ++ if existsFile(abs): ++ dest = @[abs] ++ return + + proc loadLibPattern*(pattern: string, globalSymbols = false): LibHandle = + ## loads a library with name matching `pattern`, similar to what `dlimport` |