X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=Makefile;h=31545899dc8f4094cd8685684b69a0976d13119b;hb=b355c7a532a58c557fa56b545b40bba8185bb55c;hp=c5afc1aaca9ca418d0ddf77ed1d23f860df5553a;hpb=2931eaa800dd747093d79c1d8d65bc283755b242;p=thirdparty%2Fdracut.git diff --git a/Makefile b/Makefile index c5afc1aac..31545899d 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,8 @@ -include dracut-version.sh -VERSION ?= $(shell [ -d .git ] && git describe --abbrev=0 --tags 2>/dev/null || echo $(DRACUT_VERSION)) -GITVERSION ?= $(shell [ -d .git ] && { v=$$(git describe --tags 2>/dev/null); [ -n "$$v" ] && [ $${v\#*-} != $$v ] && echo -$${v\#*-}; } ) +DRACUT_MAIN_VERSION ?= $(shell [ -d .git ] && git describe --abbrev=0 --tags --always 2>/dev/null || :) +DRACUT_MAIN_VERSION ?= $(DRACUT_VERSION) +GITVERSION ?= $(shell [ -d .git ] && { v=$$(git describe --tags --always 2>/dev/null); [ -n "$$v" ] && [ $${v\#*-} != $$v ] && echo -$${v\#*-}; } ) -include Makefile.inc @@ -12,8 +13,8 @@ pkglibdir ?= ${libdir}/dracut sysconfdir ?= ${prefix}/etc bindir ?= ${prefix}/bin mandir ?= ${prefix}/share/man -CFLAGS ?= -O2 -g -Wall $(KMOD_CFLAGS) -CFLAGS += -std=gnu99 -D_FILE_OFFSET_BITS=64 -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 +CFLAGS ?= -O2 -g -Wall +CFLAGS += -std=gnu99 -D_FILE_OFFSET_BITS=64 -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 $(KMOD_CFLAGS) bashcompletiondir ?= ${datadir}/bash-completion/completions pkgconfigdatadir ?= $(datadir)/pkgconfig @@ -40,7 +41,7 @@ man8pages = dracut.8 \ manpages = $(man1pages) $(man5pages) $(man7pages) $(man8pages) -.PHONY: install clean archive rpm testimage test all check AUTHORS doc dracut-version.sh +.PHONY: install clean archive rpm srpm testimage test all check AUTHORS doc dracut-version.sh all: dracut-version.sh dracut.pc dracut-install skipcpio/skipcpio @@ -63,6 +64,9 @@ install/strv.o: install/strv.c install/strv.h install/util.h install/macro.h ins install/dracut-install: $(DRACUT_INSTALL_OBJECTS) $(CC) $(LDFLAGS) -o $@ $(DRACUT_INSTALL_OBJECTS) $(LDLIBS) $(KMOD_LIBS) +logtee: logtee.c + $(CC) $(LDFLAGS) -o $@ $< + dracut-install: install/dracut-install ln -fs $< $@ @@ -105,7 +109,7 @@ dracut.html: dracut.asc $(manpages) dracut.css dracut.usage.asc dracut.pc: Makefile.inc Makefile @echo "Name: dracut" > dracut.pc @echo "Description: dracut" >> dracut.pc - @echo "Version: $(VERSION)$(GITVERSION)" >> dracut.pc + @echo "Version: $(DRACUT_MAIN_VERSION)$(GITVERSION)" >> dracut.pc @echo "dracutdir=$(pkglibdir)" >> dracut.pc @echo "dracutmodulesdir=$(pkglibdir)/modules.d" >> dracut.pc @echo "dracutconfdir=$(pkglibdir)/dracut.conf.d" >> dracut.pc @@ -175,7 +179,7 @@ endif dracut-version.sh: @rm -f dracut-version.sh - @echo "DRACUT_VERSION=$(VERSION)$(GITVERSION)" > dracut-version.sh + @echo "DRACUT_VERSION=$(DRACUT_MAIN_VERSION)$(GITVERSION)" > dracut-version.sh clean: $(RM) *~ @@ -190,28 +194,39 @@ clean: $(RM) $(manpages) dracut.html $(MAKE) -C test clean -dist: dracut-$(VERSION).tar.xz +dist: dracut-$(DRACUT_MAIN_VERSION).tar.xz -dracut-$(VERSION).tar.xz: doc syncheck - @echo "DRACUT_VERSION=$(VERSION)" > dracut-version.sh - git archive --format=tar $(VERSION) --prefix=dracut-$(VERSION)/ > dracut-$(VERSION).tar - mkdir -p dracut-$(VERSION) - for i in $(manpages) dracut.html dracut-version.sh; do [ "$${i%/*}" != "$$i" ] && mkdir -p "dracut-$(VERSION)/$${i%/*}"; cp "$$i" "dracut-$(VERSION)/$$i"; done - tar --owner=root --group=root -rf dracut-$(VERSION).tar $$(find dracut-$(VERSION) -type f) - rm -fr -- dracut-$(VERSION).tar.xz dracut-$(VERSION) - xz -9 dracut-$(VERSION).tar - rm -f -- dracut-$(VERSION).tar +dracut-$(DRACUT_MAIN_VERSION).tar.xz: doc syncheck + @echo "DRACUT_VERSION=$(DRACUT_MAIN_VERSION)" > dracut-version.sh + git archive --format=tar $(DRACUT_MAIN_VERSION) --prefix=dracut-$(DRACUT_MAIN_VERSION)/ > dracut-$(DRACUT_MAIN_VERSION).tar + mkdir -p dracut-$(DRACUT_MAIN_VERSION) + for i in $(manpages) dracut.html dracut-version.sh; do [ "$${i%/*}" != "$$i" ] && mkdir -p "dracut-$(DRACUT_MAIN_VERSION)/$${i%/*}"; cp "$$i" "dracut-$(DRACUT_MAIN_VERSION)/$$i"; done + tar --owner=root --group=root -rf dracut-$(DRACUT_MAIN_VERSION).tar $$(find dracut-$(DRACUT_MAIN_VERSION) -type f) + rm -fr -- dracut-$(DRACUT_MAIN_VERSION).tar.xz dracut-$(DRACUT_MAIN_VERSION) + xz -9 dracut-$(DRACUT_MAIN_VERSION).tar + rm -f -- dracut-$(DRACUT_MAIN_VERSION).tar -rpm: dracut-$(VERSION).tar.xz syncheck +rpm: dracut-$(DRACUT_MAIN_VERSION).tar.xz syncheck rpmbuild=$$(mktemp -d -t rpmbuild-dracut.XXXXXX); src=$$(pwd); \ - cp dracut-$(VERSION).tar.xz "$$rpmbuild"; \ - LC_MESSAGES=C $$src/git2spec.pl $(VERSION) "$$rpmbuild" < dracut.spec > $$rpmbuild/dracut.spec; \ + cp dracut-$(DRACUT_MAIN_VERSION).tar.xz "$$rpmbuild"; \ + LC_MESSAGES=C $$src/git2spec.pl $(DRACUT_MAIN_VERSION) "$$rpmbuild" < dracut.spec > $$rpmbuild/dracut.spec; \ (cd "$$rpmbuild"; \ wget https://www.gnu.org/licenses/lgpl-2.1.txt; \ rpmbuild --define "_topdir $$PWD" --define "_sourcedir $$PWD" \ --define "_specdir $$PWD" --define "_srcrpmdir $$PWD" \ --define "_rpmdir $$PWD" -ba dracut.spec; ) && \ - ( mv "$$rpmbuild"/$$(arch)/*.rpm $(DESTDIR).; mv "$$rpmbuild"/*.src.rpm $(DESTDIR).;rm -fr -- "$$rpmbuild"; ls $(DESTDIR)*.rpm ) + ( mv "$$rpmbuild"/{,$$(uname -m)/}*.rpm $(DESTDIR).; rm -fr -- "$$rpmbuild"; ls $(DESTDIR)*.rpm ) + +srpm: dracut-$(DRACUT_MAIN_VERSION).tar.xz syncheck + rpmbuild=$$(mktemp -d -t rpmbuild-dracut.XXXXXX); src=$$(pwd); \ + cp dracut-$(DRACUT_MAIN_VERSION).tar.xz "$$rpmbuild"; \ + LC_MESSAGES=C $$src/git2spec.pl $(DRACUT_MAIN_VERSION) "$$rpmbuild" < dracut.spec > $$rpmbuild/dracut.spec; \ + (cd "$$rpmbuild"; \ + [ -f $$src/lgpl-2.1.txt ] && cp $$src/lgpl-2.1.txt . || wget https://www.gnu.org/licenses/lgpl-2.1.txt; \ + rpmbuild --define "_topdir $$PWD" --define "_sourcedir $$PWD" \ + --define "_specdir $$PWD" --define "_srcrpmdir $$PWD" \ + --define "_rpmdir $$PWD" -bs dracut.spec; ) && \ + ( mv "$$rpmbuild"/*.src.rpm $(DESTDIR).; rm -fr -- "$$rpmbuild"; ls $(DESTDIR)*.rpm ) syncheck: @ret=0;for i in dracut-initramfs-restore.sh modules.d/*/*.sh; do \ @@ -259,9 +274,9 @@ efi: all AUTHORS: git shortlog --numbered --summary -e |while read a rest || [ -n "$$rest" ]; do echo $$rest;done > AUTHORS -dracut.html.sign: dracut-$(VERSION).tar.xz dracut.html - gpg-sign-all dracut-$(VERSION).tar.xz dracut.html +dracut.html.sign: dracut-$(DRACUT_MAIN_VERSION).tar.xz dracut.html + gpg-sign-all dracut-$(DRACUT_MAIN_VERSION).tar.xz dracut.html upload: dracut.html.sign - kup put dracut-$(VERSION).tar.xz dracut-$(VERSION).tar.sign /pub/linux/utils/boot/dracut/ + kup put dracut-$(DRACUT_MAIN_VERSION).tar.xz dracut-$(DRACUT_MAIN_VERSION).tar.sign /pub/linux/utils/boot/dracut/ kup put dracut.html dracut.html.sign /pub/linux/utils/boot/dracut/