Files
dotfiles/overlays/patches/talloc-satic.patch
2024-04-11 15:50:15 +02:00

38 lines
1.7 KiB
Diff

diff --git a/buildtools/wafsamba/wscript b/buildtools/wafsamba/wscript
index 30cb366..d9abf06 100644
--- a/buildtools/wafsamba/wscript
+++ b/buildtools/wafsamba/wscript
@@ -304,6 +304,15 @@ def configure(conf):
conf.load('compiler_c')
+ # This seems to be the only way to not include the -Wl,-Bdynamic in the linker gcc cmdline
+ # because it is assumed as a common gcc flag in $src/third_party/waf/waflib/Tools/gcc.py
+ # and disabled only for certain platforms with no way to disable it from eg an ENV Variable
+ # export SHLIB_MARKER = "" is picked up by waf (just before conf.load conf.env.SHLIB_MARKER is "")
+ # but the conf.load("compiler_c") overwrites that
+ # on the alpine static build it is no problem to have both -Wl,-Bdynamic and -Wl,-Bstatic
+ # but on nix it is a problem
+ conf.env.SHLIB_MARKER = ""
+
conf.CHECK_STANDARD_LIBPATH()
# we need git for 'waf dist'
diff --git a/wscript b/wscript
index 075f1ec..79ea64b 100644
--- a/wscript
+++ b/wscript
@@ -81,6 +81,13 @@ def configure(conf):
def build(bld):
bld.RECURSE('lib/replace')
+ # without this following line the tasks: talloc-compat1-$VERSION, talloc_testsuite, talloc_test_magic_differs_helper
+ # have the -Wl,-Bstatic set before the -ltalloc, so the linker would look for a libtalloc.a, which isn't made anywhere
+ # copying the libtalloc made in postInstall manually to /build/talloc-x.x.x/bin/default would also make those commands work
+ # so another solution would be to run this ar command after all the .o files are made and before those 3 tasks
+ # but i am too lazy to make a task for this ar command and shedule it properly
+ bld.env.STLIB_MARKER = ""
+
if bld.env.standalone_talloc:
private_library = False