diff options
Diffstat (limited to 'Makefile')
| -rw-r--r-- | Makefile | 108 | 
1 files changed, 108 insertions, 0 deletions
| diff --git a/Makefile b/Makefile new file mode 100644 index 00000000..b349b879 --- /dev/null +++ b/Makefile @@ -0,0 +1,108 @@ +# baselayout Makefile +# Copyright 2006-2007 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# +# We've moved the installation logic from Gentoo ebuild into a generic +# Makefile so that the ebuild is much smaller and more simple. +# It also has the added bonus of being easier to install on systems +# without an ebuild style package manager. + +SUBDIRS = conf.d etc init.d man net sh share src + +NAME = baselayout +#VERSION = 2.0.0_alpha1 +VERSION = 1.13.99 + +PKG = $(NAME)-$(VERSION) + +ARCH = x86 +ifeq ($(OS),) +OS=$(shell uname -s) +ifneq ($(OS),Linux) +OS=BSD +endif +endif + +BASE_DIRS = /$(LIB)/rcscripts/init.d /$(LIB)/rcscripts/tmp +KEEP_DIRS = /boot /home /mnt /root \ +	/usr/local/bin /usr/local/sbin /usr/local/share/doc /usr/local/share/man \ +	/var/lock /var/run + +ifeq ($(OS),Linux) +	KEEP_DIRS += /dev /sys +	NET_LO = net.lo +endif +ifneq ($(OS),Linux) +	NET_LO = net.lo0 +endif + +TOPDIR = . +include $(TOPDIR)/default.mk + +install:: +	# These dirs may not exist from prior versions +	for x in $(BASE_DIRS) ; do \ +		$(INSTALL_DIR) $(DESTDIR)$$x || exit $$? ; \ +		touch $(DESTDIR)$$x/.keep || exit $$? ; \ +	done +	# Don't install runlevels if they already exist +	if ! test -d $(DESTDIR)/etc/runlevels ; then \ +		(cd runlevels; $(MAKE) install) ; \ +		test -d runlevels.$(OS) && (cd runlevels.$(OS); $(MAKE) install) ; \ +		$(INSTALL_DIR) $(DESTDIR)/etc/runlevels/single || exit $$? ; \ +		$(INSTALL_DIR) $(DESTDIR)/etc/runlevels/nonetwork || exit $$? ; \ +	fi +	ln -snf ../../$(LIB)/rcscripts/sh/net.sh $(DESTDIR)/etc/init.d/$(NET_LO) || exit $$? +	ln -snf ../../$(LIB)/rcscripts/sh/functions.sh $(DESTDIR)/etc/init.d || exit $$? +	# Handle lib correctly +	if test $(LIB) != "lib" ; then \ +		sed -i'.bak' -e 's,/lib/,/$(LIB)/,g' $(DESTDIR)/$(LIB)/rcscripts/sh/functions.sh || exit $$? ; \ +		rm -f $(DESTDIR)/$(LIB)/rcscripts/sh/functions.sh.bak ; \ +	fi + +.PHONY: all clean install + +layout: +	# Create base filesytem layout +	for x in $(KEEP_DIRS) ; do \ +		$(INSTALL_DIR) $(DESTDIR)$$x || exit $$? ; \ +		touch $(DESTDIR)$$x/.keep || exit $$? ; \ +	done +	# Special dirs +	install -m 0700 -d $(DESTDIR)/root || exit $$? +	touch $(DESTDIR)/root/.keep || exit $$? +	install -m 1777 -d $(DESTDIR)/var/tmp || exit $$? +	touch $(DESTDIR)/var/tmp/.keep || exit $$? +	install -m 1777 -d $(DESTDIR)/tmp || exit $$? +	touch $(DESTDIR)/tmp/.keep || exit $$? +	# FHS compatibility symlinks stuff +	ln -snf /var/tmp $(DESTDIR)/usr/tmp || exit $$? +	ln -snf share/man $(DESTDIR)/usr/local/man || exit $$? + +distcheck: +	if test -d .svn ; then \ +		svnfiles=`svn status 2>&1 | egrep -v '^(U|P)'` ; \ +		if test "x$$svnfiles" != "x" ; then \ +			echo "Refusing to package tarball until svn is in sync:" ; \ +			echo "$$svnfiles" ; \ +			echo "make distforce to force packaging" ; \ +			exit 1 ; \ +		fi \ +	fi  + +distforce: +	install -d /tmp/$(PKG) +	cp -PRp . /tmp/$(PKG) +	`which find` /tmp/$(PKG) -depth -path "*/.svn/*" -delete +	`which find` /tmp/$(PKG) -depth -path "*/.svn" -delete +	rm -rf /tmp/$(PKG)/src/core /tmp/$(PKG)/po +	$(MAKE) -C /tmp/$(PKG) clean +	sed -i'.bak' -e '/-Wl,-rpath ./ s/^/#/g' /tmp/$(PKG)/src/Makefile +	rm -f /tmp/$(PKG)/src/Makefile.bak +	tar -C /tmp -cvjpf /tmp/$(PKG).tar.bz2 $(PKG) +	rm -Rf /tmp/$(PKG) +	du /tmp/$(PKG).tar.bz2 + +dist: distcheck	distforce + +# vim: set ts=4 : | 
