X-Git-Url: http://git.ozo.com/?p=openwrt-10.03%2F.git;a=blobdiff_plain;f=include%2Fautotools.mk;h=e1535d0b16b3c61a440c92d8582578f44b02c572;hp=fd57e6472747af8cd1bf65b4cbf36e61552f0794;hb=f7aa72ae435885a8f5d5ad4c9b149c20a1e36c0d;hpb=3031854f724c406ca3756a02cad901fad622fdb0 diff --git a/include/autotools.mk b/include/autotools.mk index fd57e6472..e1535d0b1 100644 --- a/include/autotools.mk +++ b/include/autotools.mk @@ -1,30 +1,64 @@ -# -# Copyright (C) 2007 OpenWrt.org +# +# Copyright (C) 2007-2010 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # define replace - if [ -f "$(PKG_BUILD_DIR)/$(3)$(1)" -a -e "$(2)/$(1)" ]; then \ + if [ -f "$(PKG_BUILD_DIR)/$(3)$(1)" -a -e "$(2)/$(if $(4),$(4),$(1))" ]; then \ rm -f $(PKG_BUILD_DIR)/$(3)$(1); \ - ln -s $(2)/$(1) $(PKG_BUILD_DIR)/$(3); \ + ln -s $(2)/$(if $(4),$(4),$(1)) $(PKG_BUILD_DIR)/$(3)$(1); \ fi endef +PKG_LIBTOOL_PATHS?=$(CONFIGURE_PATH) + # replace copies of ltmain.sh with the build system's version -update_libtool=$(call replace,libtool,$(STAGING_DIR)/host/bin,$(CONFIGURE_PATH)/)$(call replace,ltmain.sh,$(STAGING_DIR)/host/share/libtool,$(CONFIGURE_PATH)/) +update_libtool_common = \ + $(foreach p,$(LIBTOOL_PATHS), \ + $(call replace,ltmain.sh,$(STAGING_DIR)/host/share/libtool,$(p)/) \ + $(call replace,libtool.m4,$(STAGING_DIR)/host/share/aclocal,$(p)/) \ + ) +update_libtool = \ + $(foreach p,$(PKG_LIBTOOL_PATHS), \ + $(call replace,libtool,$(STAGING_DIR)/host/bin,$(p)/) \ + ) \ + $(call update_libtool_common) +update_libtool_ucxx = \ + $(foreach p,$(PKG_LIBTOOL_PATHS), \ + $(call replace,libtool,$(STAGING_DIR)/host/bin,$(p)/,libtool-ucxx) \ + ) \ + $(call update_libtool_common) + # prevent libtool from linking against host development libraries define libtool_fixup_libdir - find $(PKG_BUILD_DIR) -name '*.la' | $(XARGS) \ - $(SED) "s,^libdir='/usr/lib',libdir='$(strip $(1))/usr/lib',g" + find $(1) -name '*.la' | $(XARGS) \ + $(SED) "s,\(^libdir='\| \|-L\|^dependency_libs='\)/usr/lib,\1$(STAGING_DIR)/usr/lib,g" \ + -e "s,$(STAGING_DIR)/usr/lib/\(libstdc++\|libsupc++\).la,$(TOOLCHAIN_DIR)/usr/lib/\1.la,g" +endef + +define remove_version_check + if [ -f "$(PKG_BUILD_DIR)/$(CONFIGURE_PATH)/configure" ]; then \ + $(SED) \ + 's,\(gentoo\|pardus\)_ltmain_version=.*,\1_ltmain_version="$$$$\1_lt_version",' \ + $(PKG_BUILD_DIR)/$(CONFIGURE_PATH)/configure; \ + fi endef ifneq ($(filter libtool,$(PKG_FIXUP)),) PKG_BUILD_DEPENDS += libtool - Hooks/Configure/Pre += update_libtool + Hooks/Configure/Pre += update_libtool remove_version_check Hooks/Configure/Post += update_libtool - Hooks/Build/Post += libtool_fixup_libdir + Hooks/InstallDev/Post += libtool_fixup_libdir endif + +ifneq ($(filter libtool-ucxx,$(PKG_FIXUP)),) + PKG_BUILD_DEPENDS += libtool + Hooks/Configure/Pre += update_libtool_ucxx remove_version_check + Hooks/Configure/Post += update_libtool_ucxx + Hooks/InstallDev/Post += libtool_fixup_libdir +endif +