add support for a common shell include file, which is evaluated for every make shell call, simplify variable passing to the shell with shvar and shexport templates, use Package/<pkgname>/config for adding config.in data

SVN-Revision: 5014
This commit is contained in:
Felix Fietkau 2006-10-10 15:30:50 +00:00
parent c2527c7204
commit af7a470f9c
4 changed files with 44 additions and 20 deletions

View file

@ -12,6 +12,15 @@ endif
include $(INCLUDE_DIR)/prereq.mk include $(INCLUDE_DIR)/prereq.mk
define shvar
V_$(subst .,_,$(subst -,_,$(subst /,_,$(1))))
endef
define shexport
$(call shvar,$(1))=$$(call $(1))
export $(call shvar,$(1))
endef
define Build/DefaultTargets define Build/DefaultTargets
ifeq ($(DUMP),) ifeq ($(DUMP),)
ifeq ($(CONFIG_AUTOREBUILD),y) ifeq ($(CONFIG_AUTOREBUILD),y)
@ -98,9 +107,8 @@ define BuildDescription
endef endef
define BuildIPKGVariable define BuildIPKGVariable
pkg_$(subst .,_,$(subst -,_,$(1)))_$(2) = $$(Package/$(1)/$(2)) $(call shexport,Package/$(1)/$(2))
export pkg_$(subst .,_,$(subst -,_,$(1))_$(2)) $(1)_COMMANDS += var2file "$(call shvar,Package/$(1)/$(2))" $(2);
$(1)_COMMANDS += if [ -n "$$$$$$$$pkg_$(subst .,_,$(subst -,_,$(1)))_$(2)" ]; then echo "$$$$$$$$pkg_$(subst .,_,$(subst -,_,$(1)))_$(2)" > $(2); fi;
endef endef
define BuildPackage define BuildPackage
@ -168,22 +176,22 @@ define BuildPackage
echo "Build-Depends: $(PKG_BUILDDEP)"; \ echo "Build-Depends: $(PKG_BUILDDEP)"; \
echo "Category: $(CATEGORY)"; \ echo "Category: $(CATEGORY)"; \
echo "Title: $(TITLE)"; \ echo "Title: $(TITLE)"; \
echo "Description: $(DESCRIPTION)" | sed -e 's,\\,\n,g'; echo "Description: $(DESCRIPTION)" | sed -e 's,\\,\n,g'; \
ifneq ($(URL),) ifneq ($(URL),)
DUMPINFO += \ DUMPINFO += \
echo; \ echo; \
echo "$(URL)"; echo "$(URL)";
endif endif
DUMPINFO += \ DUMPINFO += \
echo "@@"; echo "@@";
$(call shexport,Package/$(1)/config)
DUMPINFO += \
if isset $(call shvar,Package/$(1)/config); then echo "Config: "; getvar $(call shvar,Package/$(1)/config); fi; \
echo "@@";
ifneq ($(CONFIG),)
DUMPINFO += \
echo "Config: $(CONFIG)" | sed -e 's,\\,\n,g'; \
echo "@@";
endif
endif endif
$(eval $(call BuildIPKGVariable,$(1),conffiles)) $(eval $(call BuildIPKGVariable,$(1),conffiles))

15
openwrt/include/shell.sh Normal file
View file

@ -0,0 +1,15 @@
getvar() {
eval "echo \"\${$1}\""
}
var2file() {
local var
eval "var=\"\${$1}\""
if [ -n "$var" ]; then echo "$var" > "$2"; fi
}
isset() {
local var
eval "var=\"\${$1}\""
[ -n "$var" ]
}

View file

@ -31,10 +31,12 @@ define Package/busybox
It slices, it dices, it makes Julian Fries. It slices, it dices, it makes Julian Fries.
URL:=http://busybox.net/ URL:=http://busybox.net/
MENU:=1 MENU:=1
CONFIG:=\\\ endef
menu "Configuration" \\\
depends on PACKAGE_busybox \\\ define Package/busybox/config
source "$(SOURCE)/config/Config.in" \\\ menu "Configuration"
depends on PACKAGE_busybox
source "$(SOURCE)/config/Config.in"
endmenu endmenu
endef endef

View file

@ -8,8 +8,7 @@
-include $(TOPDIR)/.config -include $(TOPDIR)/.config
include $(TOPDIR)/include/verbose.mk include $(TOPDIR)/include/verbose.mk
export SHELL=/bin/bash export SHELL=/usr/bin/env bash -c '. $(TOPDIR)/include/shell.sh; eval "$$2"' --
ARCH:=$(strip $(subst ",, $(CONFIG_ARCH))) ARCH:=$(strip $(subst ",, $(CONFIG_ARCH)))
TARGET_OPTIMIZATION:=$(strip $(subst ",, $(CONFIG_TARGET_OPTIMIZATION))) TARGET_OPTIMIZATION:=$(strip $(subst ",, $(CONFIG_TARGET_OPTIMIZATION)))
WGET:=$(strip $(subst ",, $(CONFIG_WGET))) WGET:=$(strip $(subst ",, $(CONFIG_WGET)))