diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-08-20 18:44:26 +0200 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-08-20 18:44:26 +0200 |
commit | c93690a68abdc6e39f2790d7960420bba46da555 (patch) | |
tree | 7b6456adc44fbaa05e5be8817b751c144cd2a19e /mk/libraries.mk | |
parent | f0610e28e8d4da86b90d10bfb85bbfc72219cf28 (diff) | |
parent | 2aa93858afee22e0c32d8f4366970976374091ac (diff) |
Merge commit '2aa93858afee22e0c32d8f4366970976374091ac'
Diffstat (limited to 'mk/libraries.mk')
-rw-r--r-- | mk/libraries.mk | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/mk/libraries.mk b/mk/libraries.mk index 4b8292cc2..3b91c699e 100644 --- a/mk/libraries.mk +++ b/mk/libraries.mk @@ -21,6 +21,9 @@ endif # # - $(1)_CXXFLAGS: additional C++ compiler flags. # +# - $(1)_ORDER_AFTER: a set of targets on which the object files of +# this libraries will have an order-only dependency. +# # - $(1)_LIBS: the symbolic names of other libraries on which this # library depends. # @@ -89,6 +92,8 @@ define build-library $(1)_LDFLAGS_USE_INSTALLED += -L$$(DESTDIR)$$($(1)_INSTALL_DIR) -l$$(patsubst lib%,%,$$(strip $$($(1)_NAME))) ifeq ($(SET_RPATH_TO_LIBS), 1) $(1)_LDFLAGS_USE_INSTALLED += -Wl,-rpath,$$($(1)_INSTALL_DIR) + else + $(1)_LDFLAGS_USE_INSTALLED += -Wl,-rpath-link,$$($(1)_INSTALL_DIR) endif ifdef $(1)_FORCE_INSTALL @@ -118,6 +123,13 @@ define build-library # Make each object file depend on the common dependencies. $$(foreach obj, $$($(1)_OBJS), $$(eval $$(obj): $$($(1)_COMMON_DEPS) $$(GLOBAL_COMMON_DEPS))) + # Make each object file have order-only dependencies on the common + # order-only dependencies. This includes the order-only dependencies + # of libraries we're depending on. + $(1)_ORDER_AFTER_CLOSED = $$($(1)_ORDER_AFTER) $$(foreach lib, $$($(1)_LIBS), $$($$(lib)_ORDER_AFTER_CLOSED)) + + $$(foreach obj, $$($(1)_OBJS), $$(eval $$(obj): | $$($(1)_ORDER_AFTER_CLOSED) $$(GLOBAL_ORDER_AFTER))) + # Include .dep files, if they exist. $(1)_DEPS := $$(foreach fn, $$($(1)_OBJS), $$(call filename-to-dep, $$(fn))) -include $$($(1)_DEPS) |