X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/878d2d742f50b178d3cf63570da1fe9c0383aad2..b0d5d40866d48b5bb7d866b5bc69af8b11644bb3:/package/rules.mk diff --git a/package/rules.mk b/package/rules.mk index 53b868d1a..cd63983bd 100644 --- a/package/rules.mk +++ b/package/rules.mk @@ -1,20 +1,25 @@ +# 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: $$(IPKG_$(1)) +compile-targets: $$(IPKG_$(1)) endif ifneq ($(DEVELOPER),) -compile: $$(IPKG_$(1)) +compile-targets: $$(IPKG_$(1)) endif ifeq ($(BR2_PACKAGE_$(1)),y) -install: $$(INFO_$(1)) +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 @@ -27,17 +32,13 @@ $$(INFO_$(1)): $$(IPKG_$(1)) $(2)-clean: rm -f $$(IPKG_$(1)) clean: $(2)-clean -mostlyclean: -rebuild: mostlyclean - if [ -f $(PKG_BUILD_DIR)/.built ]; then \ - $(MAKE) clean; \ - fi - $(MAKE) compile 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)),) @@ -54,18 +55,51 @@ endif all: compile source: $(DL_DIR)/$(PKG_SOURCE) -prepare: $(PKG_BUILD_DIR)/.prepared -compile: +prepare: + @[ -f $(PKG_BUILD_DIR)/.prepared ] || { \ + $(PKG_TRACE) Preparing...; \ + $(MAKE) $(PKG_BUILD_DIR)/.prepared $(MAKE_TRACE); \ + } + +configure: + @[ -f $(PKG_BUILD_DIR)/.configured ] || { \ + $(PKG_TRACE) Configuring...; \ + $(MAKE) $(PKG_BUILD_DIR)/.configured $(MAKE_TRACE); \ + } + +compile-targets: +compile: prepare + @[ -f $(PKG_BUILD_DIR)/.configured ] || { \ + $(PKG_TRACE) Configuring...; \ + $(MAKE) $(PKG_BUILD_DIR)/.configured $(MAKE_TRACE); \ + } + @$(PKG_TRACE) Compiling... + @$(MAKE) compile-targets $(MAKE_TRACE) + +install-targets: install: + @$(PKG_TRACE) Installing... + @$(MAKE) install-targets $(MAKE_TRACE) -$(PKG_BUILD_DIR)/.configured: $(PKG_BUILD_DIR)/.prepared -$(PKG_BUILD_DIR)/.built: $(PKG_BUILD_DIR)/.configured +mostlyclean: +rebuild: + $(PKG_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: + @$(PKG_TRACE) Cleaning... + @$(MAKE) clean-targets $(MAKE_TRACE) rm -rf $(PKG_BUILD_DIR) .PHONY: all source prepare compile install clean