X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fsvn-archive%2Farchive.git;a=blobdiff_plain;f=openwrt%2Fpackage%2Frules.mk;h=504eb1518f3c2e3cc7b5e7a450350de2772adb3a;hp=ffcbe1acd8abe85d946f1f0ce567acd239b2c8c9;hb=f1e849a1381ecb77de7147ccb665d99daee9b1c6;hpb=bfb55b5eba17ec1df40f06e3a6307c99fe865cad diff --git a/openwrt/package/rules.mk b/openwrt/package/rules.mk index ffcbe1acd8..504eb1518f 100644 --- a/openwrt/package/rules.mk +++ b/openwrt/package/rules.mk @@ -1,12 +1,51 @@ +# invoke ipkg with configuration in $(STAGING_DIR)/etc/ipkg.conf + +define PKG_template +IPKG_$(1):=$(PACKAGE_DIR)/$(2)_$(3)_$(4).ipk +IDIR_$(1):=$(PKG_BUILD_DIR)/ipkg/$(2) +INFO_$(1):=$(IPKG_STATE_DIR)/info/$(2).list + +ifneq ($(BR2_PACKAGE_$(1)),) +compile-targets: $$(IPKG_$(1)) +endif +ifneq ($(DEVELOPER),) +compile-targets: $$(IPKG_$(1)) +endif +ifeq ($(BR2_PACKAGE_$(1)),y) +install-targets: $$(INFO_$(1)) +endif + +IDEPEND_$(1):=$$(strip $(5)) + +$$(IDIR_$(1))/CONTROL/control: $(PKG_BUILD_DIR)/.prepared + $(SCRIPT_DIR)/make-ipkg-dir.sh $$(IDIR_$(1)) ./ipkg/$(2).control $(3) $(4) + if [ "$$(IDEPEND_$(1))" != "" ]; then echo "Depends: $$(IDEPEND_$(1))" >> $$(IDIR_$(1))/CONTROL/control; fi + for file in conffiles preinst postinst prerm postrm; do \ + [ -f ./ipkg/$(2).$$$$file ] && cp ./ipkg/$(2).$$$$file $$(IDIR_$(1))/CONTROL/$$$$file || true; \ + done + +$$(IPKG_$(1)): $$(IDIR_$(1))/CONTROL/control $(PKG_BUILD_DIR)/.built $(PACKAGE_DIR) + +$$(INFO_$(1)): $$(IPKG_$(1)) + $(IPKG) install $$(IPKG_$(1)) + +$(2)-clean: + rm -f $$(IPKG_$(1)) +clean: $(2)-clean +endef + + ifneq ($(strip $(PKG_SOURCE)),) $(DL_DIR)/$(PKG_SOURCE): - $(SCRIPT_DIR)/download.pl $(DL_DIR) $(PKG_SOURCE) $(PKG_MD5SUM) $(PKG_SOURCE_URL) + @$(PKG_TRACE) "downloading... " + $(SCRIPT_DIR)/download.pl "$(DL_DIR)" "$(PKG_SOURCE)" "$(PKG_MD5SUM)" $(PKG_SOURCE_URL) $(MAKE_TRACE) endif ifneq ($(strip $(PKG_CAT)),) $(PKG_BUILD_DIR)/.prepared: $(DL_DIR)/$(PKG_SOURCE) rm -rf $(PKG_BUILD_DIR) - $(PKG_CAT) $(DL_DIR)/$(PKG_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + mkdir -p $(PKG_BUILD_DIR) + $(PKG_CAT) $(DL_DIR)/$(PKG_SOURCE) | tar -C $(PKG_BUILD_DIR)/.. $(TAR_OPTIONS) - if [ -d ./patches ]; then \ $(PATCH) $(PKG_BUILD_DIR) ./patches ; \ fi @@ -16,11 +55,47 @@ endif all: compile source: $(DL_DIR)/$(PKG_SOURCE) -prepare: $(PKG_BUILD_DIR)/.prepared -compile: $(COMPILE_TARGETS) -install: $(INSTALL_TARGETS) +prepare: + @[ -f $(PKG_BUILD_DIR)/.prepared ] || { \ + $(CMD_TRACE) "preparing... "; \ + $(MAKE) $(PKG_BUILD_DIR)/.prepared $(MAKE_TRACE); \ + } + +configure: prepare + @[ -f $(PKG_BUILD_DIR)/.configured ] || { \ + $(CMD_TRACE) "configuring... "; \ + $(MAKE) $(PKG_BUILD_DIR)/.configured $(MAKE_TRACE); \ + } + +compile-targets: +compile: configure + @$(CMD_TRACE) "compiling... " + @$(MAKE) compile-targets $(MAKE_TRACE) + +install-targets: +install: + @$(CMD_TRACE) "installing... " + @$(MAKE) install-targets $(MAKE_TRACE) -clean: $(CLEAN_TARGETS) - rm -rf $(PKG_FILES) $(PKG_BUILD_DIR) +mostlyclean: +rebuild: + $(CMD_TRACE) "rebuilding... " + @-$(MAKE) mostlyclean 2>&1 >/dev/null + if [ -f $(PKG_BUILD_DIR)/.built ]; then \ + $(MAKE) clean $(MAKE_TRACE); \ + fi + $(MAKE) compile $(MAKE_TRACE) + +$(PKG_BUILD_DIR)/.configured: prepare +$(PKG_BUILD_DIR)/.built: configure + +$(PACKAGE_DIR): + mkdir -p $@ + +clean-targets: +clean: + @$(CMD_TRACE) "cleaning... " + @$(MAKE) clean-targets $(MAKE_TRACE) + rm -rf $(PKG_BUILD_DIR) -.PHONY: all source prepare compile install clean \ No newline at end of file +.PHONY: all source prepare compile install clean