diff options
author | David Cantrell <dcantrell@redhat.com> | 2009-06-09 11:30:00 -1000 |
---|---|---|
committer | David Cantrell <dcantrell@redhat.com> | 2009-06-09 12:26:55 -1000 |
commit | 8289217588d4916f595894dcec136e9ab738097e (patch) | |
tree | a5c7dbca3051d578f60bd16d0e02ed0f9a04c4bd /Makefile.am | |
parent | 99dce090dd668d81a796b51d8503435a66f0e1f9 (diff) | |
download | anaconda-8289217588d4916f595894dcec136e9ab738097e.tar.gz anaconda-8289217588d4916f595894dcec136e9ab738097e.tar.xz anaconda-8289217588d4916f595894dcec136e9ab738097e.zip |
Add toplevel Makefile.am and configure.ac
Add main Makefile.am and configure.ac files. Add config.rpath, which is
required for the gettext template macros. Added a bootstrap script to
generate the configure script and Makefile.in templates.
Diffstat (limited to 'Makefile.am')
-rw-r--r-- | Makefile.am | 178 |
1 files changed, 178 insertions, 0 deletions
diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 000000000..67e4e2f3a --- /dev/null +++ b/Makefile.am @@ -0,0 +1,178 @@ +# Makefile.am for anaconda +# +# Copyright (C) 2009 Red Hat, Inc. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License as published +# by the Free Software Foundation; either version 2.1 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. +# +# Author: David Cantrell <dcantrell@redhat.com> + +ACLOCAL_AMFLAGS = -I m4 + +SUBDIRS = isys po loader booty storage textw utils scripts bootdisk \ + installclasses iw command-stubs ui docs pixmaps tests fonts \ + gptsync liveinst + +EXTRA_DIST = ChangeLog config.rpath COPYING pychecker-false-positives \ + pycheckrc-for-anaconda runpychecker.sh lang-table \ + anaconda.spec.in + +MAINTAINERCLEANFILES = Makefile.in config.guess config.h.in config.sub \ + depcomp install-sh ltmain.sh missing ABOUT-NLS \ + INSTALL aclocal.m4 configure *.pyc py-compile + +CLEANFILES = *~ ChangeLog lang-names anaconda.spec + +MOSTLYCLEANDIRS = m4 + +dist_noinst_DATA = $(PACKAGE_NAME).spec + +bin_PROGRAMS = mini-wm +dist_sbin_SCRIPTS = anaconda + +mini_wm_CFLAGS = $(GTK_X11_CFLAGS) +mini_wm_LDFLAGS = $(GTK_X11_LIBS) +mini_wm_SOURCES = mini-wm.c + +udevdir = /lib/udev/rules.d +dist_udev_DATA = 70-anaconda.rules + +langdir = $(libdir)/$(PACKAGE_NAME) +lang_DATA = lang-names +dist_lang_DATA = lang-table + +pkgpyexecdir = $(libdir)/$(PACKAGE_NAME) +pkgpythondir = $(libdir)/$(PACKAGE_NAME) + +pkgpyexec_LTLIBRARIES = xutils.la +xutils_la_CFLAGS = $(PYTHON_INCLUDES) $(GDK_CFLAGS) -fno-strict-aliasing +xutils_la_LDFLAGS = -module -avoid-version $(PYTHON_LDFLAGS) $(GDK_LDFLAGS) +xutils_la_LIBADD = $(PYTHON_LIBS) $(GDK_LIBS) +xutils_la_SOURCES = xutils.c + +# anaconda Python code +anacondadir = $(libdir)/$(PACKAGE_NAME) +anaconda_PYTHON = *.py + +PYCHECKERPATH = isys:textw:iw:installclasses:/usr/share/system-config-date +PYCHECKEROPTS = -F pycheckrc-for-anaconda +ARCHIVE_TAG = $(PACKAGE_NAME)-$(PACKAGE_VERSION)-$(PACKAGE_RELEASE) + +$(PACKAGE_NAME).spec: $(PACKAGE_NAME).spec.in + sed -e 's/#VERSION#/$(PACKAGE_VERSION)/' < $< > $@ + +lang-names: lang-table + PYTHONPATH="." $(PYTHON) scripts/getlangnames.py > lang-names + +testiso: install + @if [ "$(REPO)" = "" ]; then echo "ERROR: Need a repo to pull packages from!" ; exit 1 ; fi + @pushd scripts ; sudo ./buildinstall --version $(PACKAGE_VERSION) --product $(PACKAGE_NAME) --release $(PACKAGE_NAME)-$(PACKAGE_VERSION) --output $(shell pwd)/outiso --updates $(DESTDIR) $(REPO) ; popd ; cp outiso/images/boot.iso ./boot.iso ; sudo rm -rf outiso + @echo + @echo "Test iso is located at ./boot.iso" + +tag: + @git tag -s -a -m "Tag as $(ARCHIVE_TAG)" $(ARCHIVE_TAG) + @echo "Tagged as $(ARCHIVE_TAG)" + +scratch: + $(MAKE) ARCHIVE_TAG=HEAD dist + +archive: + $(MAKE) tag + $(MAKE) dist + +src: archive + @rpmbuild -ts --nodeps $(PACKAGE_NAME)-$(PACKAGE_VERSION).tar.bz2 || exit 1 + @rm -f $(PACKAGE_NAME)-$(PACKAGE_VERSION).tar.bz2 + +ChangeLog: + (GIT_DIR=.git git log > .changelog.tmp && mv .changelog.tmp ChangeLog; rm -f .changelog.tmp) || (touch ChangeLog; echo 'git directory not found: installing possibly empty changelog.' >&2) + +pycheck: + PYTHONPATH=$(PYCHECKERPATH) pychecker $(PYCHECKEROPTS) *.py textw/*.py iw/*.py installclasses/*.py storage/*.py | grep -v "__init__() not called" + +pycheck-file: + PYTHONPATH=.:$(PYCHECKERPATH) pychecker $(PYCHECKEROPTS) $(CHECK) | grep -v "__init__() not called" + +api: + doxygen docs/api.cfg + +rpmlog: + @git log --pretty="format:- %s (%ae)" $(PACKAGE_NAME)-$(PACKAGE_VERSION)-$(PACKAGE_RELEASE).. | sed -e 's/@.*)/)/' | sed -e 's/%/%%/g' + @echo + +bumpver: + @NEWSUBVER=$$((`echo $(PACKAGE_VERSION) |cut -d . -f 4` + 1)) ; \ + NEWVERSION=`echo $(PACKAGE_VERSION).$$NEWSUBVER |cut -d . -f 1-3,5` ; \ + DATELINE="* `date "+%a %b %d %Y"` `git config user.name` <`git config user.email`> - $$NEWVERSION-1" ; \ + cl=`grep -n %changelog anaconda.spec.in |cut -d : -f 1` ; \ + tail --lines=+$$(($$cl + 1)) anaconda.spec.in > speclog ; \ + make --quiet rpmlog 2>/dev/null | fold -s -w 77 | while read line ; do \ + if [ ! "$$(echo $$line | cut -c-2)" = "- " ]; then \ + echo " $$line" ; \ + else \ + echo "$$line" ; \ + fi ; \ + done > newspeclog ; \ + (head -n $$cl anaconda.spec.in ; echo "$$DATELINE" ; cat newspeclog ; echo ""; cat speclog) > anaconda.spec.in.new ; \ + mv anaconda.spec.in.new anaconda.spec.in ; rm -f speclog ; rm -f newspeclog ; \ + sed -i "s/AC_INIT(\[$(PACKAGE_NAME)\], \[$(PACKAGE_VERSION)\], \[$(PACKAGE_BUGREPORT\])/AC_INIT(\[$(PACKAGE_NAME)\], \[$$NEWVERSION\], \[$(PACKAGE_BUGREPORT\])/" configure.ac + +install-buildrequires: + yum install $$(grep BuildRequires: anaconda.spec.in | cut -d ' ' -f 2) + +# Generate an updates.img based on the changed files since the release +# was tagged. Updates are copied to ./updates-img and then the image is +# created. By default, the updates subdirectory is removed after the +# image is made, but if you want to keep it around, run: +# make updates.img KEEP=y +# And since shell is both stupid and amusing, I only match the first +# character to be a 'y' or 'Y', so you can do: +# make updates.img KEEP=yosemite +# Ahh, shell. +updates: + @if [ ! -d updates-img ]; then \ + mkdir updates-img ; \ + fi ; \ + build_isys="$$(git diff --stat $(ARCHIVE_TAG) isys | grep " | " | cut -d ' ' -f 2 | egrep "(Makefile|\.h|\.c)$$")" ; \ + git diff --stat $(ARCHIVE_TAG) | grep " | " | \ + grep -v "\.spec" | grep -v "Makefile" | grep -v "\.c\ " | \ + grep -v "\.h" | grep -v "\.sh" | \ + while read sourcefile stuff ; do \ + dn="$$(echo $$sourcefile | cut -d '/' -f 1)" ; \ + case $$dn in \ + installclasses|storage|booty) \ + rm -rf updates-img/$$dn ; \ + cp -a $$dn updates-img ; \ + find updates-img/$$dn -type f | egrep 'Makefile|\.pyc' | xargs rm -f ;; \ + loader|po|scripts|command-stubs|tests|bootdisk|docs|fonts|utils|gptsync) \ + continue ;; \ + *) \ + cp -a $$sourcefile updates-img ;; \ + esac ; \ + done ; \ + if [ ! -z "$$build_isys" ]; then \ + make -C isys ; \ + cp isys/_isys.so updates-img ; \ + fi ; \ + cd updates-img ; \ + echo -n "Creating updates.img..." ; \ + ( find . | cpio -c -o | gzip -9c ) > ../updates.img ; \ + cd .. ; \ + keep="$$(echo $(KEEP) | cut -c1 | tr [a-z] [A-Z])" ; \ + if [ ! "$$keep" = "Y" ]; then \ + rm -rf updates-img ; \ + fi + +# DEPRECATED TARGETS: +archive-no-tag: dist |