X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=Makefile;h=5bfef90702ecb42883c61390be6b74db713023c8;hb=refs%2Fheads%2Fnm-one-spec;hp=599067fc5757f2e981cc7d7d286f55c98af2b836;hpb=31f225307c340dd3510da9e09737a15e5c470ed8;p=build.git diff --git a/Makefile b/Makefile index 599067fc..5bfef907 100644 --- a/Makefile +++ b/Makefile @@ -455,19 +455,20 @@ endef $(foreach package,$(ALL),$(eval $(call target_mk,$(package)))) # stores env variables in a file -# this is done at stage1. later run wont get confused -SAVED_VARS=PLDISTRO PLDISTROTAGS build-GITPATH PERSONALITY MAILTO BASE WEBPATH TESTBUILDURL WEBROOT -# also remember variable settings in alias, like sfa-GITPATH=git://git.f-lab.fr/sfa.git@generic -# but don't save stage1 -ASSIGNS=$(foreach chunk,$(MAKEFLAGS),$(if $(findstring =,$(chunk)),$(if $(findstring stage1,$(chunk)),,$(chunk)),)) +# this is done at stage1. later run won't get confused +STATIC_VARS=PLDISTRO PLDISTROTAGS build-GITPATH PERSONALITY MAILTO BASE WEBPATH TESTBUILDURL WEBROOT +# find out names for variables set on the command line +define assigned_varname +$(if $(findstring =,$(1)),$(firstword $(subst =, ,$(1))) ) +endef +ASSIGNED=$(filter-out stage1 stage1iter,$(foreach flag,$(MAKEFLAGS),$(call assigned_varname,$(flag)))) +SAVED_VARS=$(sort $(STATIC_VARS) $(ASSIGNED)) envfrompreviousrun.mk: @echo "# do not edit" > $@ @$(foreach var,$(SAVED_VARS),echo "$(var):=$($(var))" >> $@ ;) - @$(foreach chunk,$(ASSIGNS),echo "override $(chunk)" | sed -e s,=,:=, >> $@;) @echo "# do not edit" > aliases @echo -n "alias m=\"make " >> aliases @$(foreach var,$(SAVED_VARS),echo -n " $(var)=$($(var))" >> aliases ;) - @echo -n $(ASSIGNS) >> aliases @echo "\"" >> aliases @echo "alias m1=\"m stage1=true\"" >> aliases @@ -577,6 +578,10 @@ DPKGAPT-INSTALL-LOCAL := gdebi DPKGAPT-INSTALL-STOCK := apt-get -y install DPKGAPT-UNINSTALL-STOCK := echo WARNING uninstalling stock debs not implemented +define dpkgapt_install_local_debs + $(if $($(1)-LOCAL-DEVEL-DEBS), echo "Installing for $(1)-LOCAL-DEVEL-DEBS" ; $(foreach debname,$($(1)-LOCAL-DEVEL-DEBS),$(DPKGAPT-INSTALL-LOCAL) $(wildcard DEBIAN/$(debname)_*.deb);)) +endef + define dpkgapt_install_stock_debs $(if $($(1)-STOCK-DEVEL-DEBS), echo "Installing for $(1)-STOCK-DEVEL-DEBS" ; $(DPKGAPT-INSTALL-STOCK) $($(1)-STOCK-DEVEL-DEBS)) endef @@ -699,6 +704,11 @@ endef $(foreach package,$(ALL),$(eval $(call target_depends,$(package)))) +#################### +# debian meta-target +ALL-DEBIAN := $(foreach target,$(ALL),$(target)-debian) +debian: $(ALL-DEBIAN) + #################### # very rough for now (one module per package), targets only sfa for now # the general idea here is, changing the specfile (for version number and all) is enough, and this @@ -708,9 +718,10 @@ $(foreach package,$(ALL),$(eval $(call target_depends,$(package)))) # so I'm reverting to simplicity define target_debian $(1)-debian: $(1)-tarball + $(call dpkgapt_install_local_debs,$(1)) $(call dpkgapt_install_stock_debs,$(1)) mkdir -p DEBIAN/$(1) - rsync -a MODULES/$(1)/ DEBIAN/$(1)/ + rsync -a MODULES/$($(1).module)/ DEBIAN/$(1)/ make -C DEBIAN/$(1) "RPMTARBALL=$(HOME)/$($(1).tarballs)" "RPMVERSION=$($(1).rpm-version)" "RPMRELEASE=$($(1).rpm-release)" "RPMNAME=$($(1).rpm-name)" debian $(call dpkgapt_uninstall_stock_debs,$(1)) endef @@ -777,7 +788,7 @@ clean-help: distclean1: rm -rf envfrompreviousrun.mk .rpmmacros spec2make header.spec SPECS MAKE $(DISTCLEANS) distclean2: - rm -rf MODULES SOURCES BUILD BUILDROOT RPMS SRPMS tmp + rm -rf MODULES SOURCES BUILD BUILDROOT RPMS SRPMS DEBIAN tmp distclean: distclean1 distclean2 .PHONY: distclean1 distclean2 distclean