Improve building dynamic libraries
They now get a correct RPATH.
This commit is contained in:
parent
6dd74b48f8
commit
d1b3ca0b4a
2 changed files with 11 additions and 7 deletions
16
Makefile.lib
16
Makefile.lib
|
@ -50,21 +50,25 @@ endif
|
||||||
libs_list :=
|
libs_list :=
|
||||||
|
|
||||||
define LIBS_template =
|
define LIBS_template =
|
||||||
_d := $$($(1)_DIR)
|
_d := $$(strip $$($(1)_DIR))
|
||||||
_srcs := $$(foreach src, $$($(1)_SOURCES), $$(_d)/$$(src))
|
_srcs := $$(foreach src, $$($(1)_SOURCES), $$(_d)/$$(src))
|
||||||
_objs := $$(addsuffix .o, $$(basename $$(_srcs)))
|
_objs := $$(addsuffix .o, $$(basename $$(_srcs)))
|
||||||
|
|
||||||
|
$(1)_LDFLAGS_USE :=
|
||||||
|
|
||||||
ifeq ($(BUILD_SHARED_LIBS), 1)
|
ifeq ($(BUILD_SHARED_LIBS), 1)
|
||||||
_lib := $$(_d)/$(1).so
|
_lib := $$(_d)/$(1).so
|
||||||
$$(_lib): $$(_objs)
|
$$(_lib): $$(_objs)
|
||||||
$(QUIET) $(CC) -o $$@ -shared $$^ $$($(1)_LDFLAGS)
|
$(QUIET) $(CC) -o $$@ -shared $$^ $$($(1)_LDFLAGS)
|
||||||
|
$(1)_LDFLAGS_USE += -L$$(_d) -Wl,-rpath,$$(abspath $$(_d)) -l$$(patsubst lib%,%,$$(strip $(1)))
|
||||||
else
|
else
|
||||||
_lib := $$(_d)/$(1).a
|
_lib := $$(_d)/$(1).a
|
||||||
$$(_lib): $$(_objs)
|
$$(_lib): $$(_objs)
|
||||||
$(QUIET) ar crs $$@ $$?
|
$(QUIET) ar crs $$@ $$?
|
||||||
$(1)_LDFLAGS_PROPAGATED += $$($(1)_LDFLAGS)
|
$(1)_LDFLAGS_USE += $$(_lib) $$($(1)_LDFLAGS)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
$(1)_LDFLAGS_USE += $$($(1)_LDFLAGS_PROPAGATED)
|
||||||
$(1)_NAME := $$(_lib)
|
$(1)_NAME := $$(_lib)
|
||||||
|
|
||||||
# Propagate CXXFLAGS to the individual object files.
|
# Propagate CXXFLAGS to the individual object files.
|
||||||
|
@ -86,15 +90,15 @@ programs_list :=
|
||||||
define PROGRAMS_template =
|
define PROGRAMS_template =
|
||||||
_d := $$($(1)_DIR)
|
_d := $$($(1)_DIR)
|
||||||
_srcs := $$(foreach src, $$($(1)_SOURCES), $$(_d)/$$(src))
|
_srcs := $$(foreach src, $$($(1)_SOURCES), $$(_d)/$$(src))
|
||||||
_objs := $$(addsuffix .o, $$(basename $$(_srcs)))
|
$(1)_OBJS := $$(addsuffix .o, $$(basename $$(_srcs)))
|
||||||
_libs := $$(foreach lib, $$($(1)_LIBS), $$($$(lib)_NAME))
|
_libs := $$(foreach lib, $$($(1)_LIBS), $$($$(lib)_NAME))
|
||||||
_prog := $$(_d)/$(1)
|
_prog := $$(_d)/$(1)
|
||||||
|
|
||||||
$$(_prog): $$(_objs) $$(_libs)
|
$$(_prog): $$($(1)_OBJS) $$(_libs)
|
||||||
$(QUIET) $(CXX) -o $$@ -Wl,--no-copy-dt-needed-entries $$^ $$($(1)_LDFLAGS) $$(foreach lib, $$($(1)_LIBS), $$($$(lib)_LDFLAGS_PROPAGATED))
|
$(QUIET) $(CXX) -o $$@ -Wl,--no-copy-dt-needed-entries $$($(1)_OBJS) $$($(1)_LDFLAGS) $$(foreach lib, $$($(1)_LIBS), $$($$(lib)_LDFLAGS_USE))
|
||||||
|
|
||||||
# Propagate CXXFLAGS to the individual object files.
|
# Propagate CXXFLAGS to the individual object files.
|
||||||
$$(foreach obj, $$(_objs), $$(eval $$(obj)_CXXFLAGS=$$($(1)_CXXFLAGS)))
|
$$(foreach obj, $$($(1)_OBJS), $$(eval $$(obj)_CXXFLAGS=$$($(1)_CXXFLAGS)))
|
||||||
|
|
||||||
include $$(wildcard $$(_d)/*.dep)
|
include $$(wildcard $$(_d)/*.dep)
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,6 @@ PROGRAMS += nix-env
|
||||||
|
|
||||||
nix-env_DIR := $(d)
|
nix-env_DIR := $(d)
|
||||||
|
|
||||||
nix-env_SOURCES = nix-env.cc profiles.cc profiles.hh user-env.cc user-env.hh
|
nix-env_SOURCES = nix-env.cc profiles.cc user-env.cc
|
||||||
|
|
||||||
nix-env_LIBS = libexpr libmain libstore libutil libformat
|
nix-env_LIBS = libexpr libmain libstore libutil libformat
|
||||||
|
|
Loading…
Reference in a new issue