# Copyright (C) 2005-2006 Axel Liljencrantz # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License version 2 as # published by the Free Software Foundation. # # 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 General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # # # @configure_input@ # # # Makefile for the fish shell. Can build fish and associated # applications, install them, recalculate dependencies and also create # binary distributions in tar.bz2, tar.gz and rpm formats. # # # The fish buildprocess is quite complex. Do not stare directly into # the Makefile. Doing so may cause nausea, dizziness and # hallucinations. # # Used by docdir PACKAGE_TARNAME = @PACKAGE_TARNAME@ # # Programs # CXX := @CXX@ INSTALL:=@INSTALL@ # # Installation directories # prefix = @prefix@ exec_prefix = @exec_prefix@ datarootdir = @datarootdir@ datadir = @datadir@ bindir = @bindir@ mandir = @mandir@ sysconfdir = @sysconfdir@ docdir = @docdir@ localedir = @localedir@ prefix = @prefix@ optbindirs = @optbindirs@ # # Various flags # MACROS = -DLOCALEDIR=\"$(localedir)\" -DPREFIX=L\"$(prefix)\" -DDATADIR=L\"$(datadir)\" -DSYSCONFDIR=L\"$(sysconfdir)\" CXXFLAGS = @CXXFLAGS@ $(MACROS) $(EXTRA_CXXFLAGS) LDFLAGS = @LIBS@ @LDFLAGS@ LDFLAGS_FISH = ${LDFLAGS} @LIBS_FISH@ @LDFLAGS_FISH@ LDFLAGS_FISH_INDENT = ${LDFLAGS} @LIBS_FISH_INDENT@ LDFLAGS_FISH_PAGER = ${LDFLAGS} @LIBS_FISH_PAGER@ LDFLAGS_FISHD = ${LDFLAGS} @LIBS_FISHD@ LDFLAGS_MIMEDB = ${LDFLAGS} @LIBS_MIMEDB@ LDFLAGS_SET_COLOR = ${LDFLAGS} @LIBS_SET_COLOR@ # # Set to 1 if we have gettext # HAVE_GETTEXT=@HAVE_GETTEXT@ # #Additional .cpp files used by common.o. These also have a corresponding #.h file. # COMMON_FILES := util.cpp halloc.cpp halloc_util.cpp fallback.cpp # # All objects that the system needs to build fish, except fish.o # FISH_OBJS := function.o builtin.o complete.o env.o exec.o expand.o \ highlight.o history.o kill.o parser.o proc.o reader.o sanity.o \ tokenizer.o wildcard.o wgetopt.o wutil.o input.o output.o intern.o \ env_universal.o env_universal_common.o input_common.o event.o \ signal.o io.o parse_util.o common.o screen.o path.o autoload.o \ parser_keywords.o iothread.o builtin_scripts.o FISH_INDENT_OBJS := fish_indent.o print_help.o common.o \ parser_keywords.o wutil.o tokenizer.o # # Additional files used by builtin.o # BUILTIN_FILES := builtin_set.cpp builtin_commandline.cpp \ builtin_ulimit.cpp builtin_complete.cpp builtin_jobs.cpp # # All objects that the system needs to build fish_pager # FISH_PAGER_OBJS := fish_pager.o output.o wutil.o \ input_common.o env_universal.o env_universal_common.o common.o \ print_help.o iothread.o # # All objects that the system needs to build fish_tests # FISH_TESTS_OBJS := $(FISH_OBJS) fish_tests.o # # All objects that the system needs to build fishd # FISHD_OBJS := fishd.o env_universal_common.o wutil.o print_help.o \ common.o # # All objects needed to build mimedb # MIME_OBJS := mimedb.o print_help.o xdgmimealias.o xdgmime.o \ xdgmimeglob.o xdgmimeint.o xdgmimemagic.o xdgmimeparent.o wutil.o \ common.o # # Files containing user documentation # # # These files are the source files, they contain a few @FOO@-style substitutions # HDR_FILES_SRC := doc_src/index.hdr.in doc_src/commands.hdr.in doc_src/design.hdr doc_src/license.hdr doc_src/faq.hdr # # These are the generated result files # HDR_FILES := $(subst .hdr.in,.hdr,$(HDR_FILES_SRC)) # # Internalized scripts # GENERATED_INTERN_SCRIPT_FILES := builtin_scripts.h builtin_scripts.cpp # Use a pattern rule so that Make knows to only issue one invocation # per http://www.gnu.org/software/make/manual/make.html#Pattern-Intro builtin%scripts.h builtin%scripts.cpp: internalize_scripts.py ./internalize_scripts.py share/functions/*.fish share/completions/*.fish # # Files containing documentation for external commands. # HELP_SRC := $(wildcard doc_src/*.txt) # # Files in the test directory # TEST_IN := $(wildcard tests/test*.in) # # Files that should be added to the tar archives # # # Files in ./doc_src/ # DOC_SRC_DIR_FILES := $(HDR_FILES_SRC) $(HELP_SRC) # # Files in ./ # MAIN_DIR_FILES_UNSORTED := Doxyfile Doxyfile.user Doxyfile.help.in \ Makefile.in configure configure.ac config.h.in install-sh \ set_color.cpp key_reader.cpp $(MIME_OBJS:.o=.h) \ $(MIME_OBJS:.o=.cpp) $(FISH_OBJS:.o=.h) $(BUILTIN_FILES) \ $(COMMON_FILES) $(COMMON_FILES:.cpp=.h) $(FISH_OBJS:.o=.cpp) \ fish.spec.in INSTALL README user_doc.head.html xsel-0.9.6.tar \ ChangeLog config.sub config.guess fish_tests.cpp fish.cpp fish_pager.cpp \ fishd.cpp seq.in make_vcs_completions.fish $(FISH_INDENT_OBJS:.o=.cpp) # # The sorting is not meaningful in itself, but it has the side effect # of removing duplicates, which means there will be fewer warnings # during building. # MAIN_DIR_FILES := $(sort $(MAIN_DIR_FILES_UNSORTED)) # # Files in ./etc/ # ETC_DIR_FILES :=etc/config.fish.in # # Files in ./share/ # SHARE_DIR_FILES :=share/config.fish.in # # Files in ./tests/ # TESTS_DIR_FILES := $(TEST_IN) $(TEST_IN:.in=.out) $(TEST_IN:.in=.err) \ $(TEST_IN:.in=.status) tests/test.fish tests/gen_output.fish # # Files in ./share/completions/ # COMPLETIONS_DIR_FILES := $(wildcard share/completions/*.fish) # # Files in ./share/functions/ # FUNCTIONS_DIR_FILES := $(wildcard share/functions/*.fish) # # Programs to install # SIMPLE_PROGRAMS := fish set_color mimedb fish_pager fishd fish_indent PROGRAMS := $(SIMPLE_PROGRAMS) @XSEL_BIN@ @SEQ_FALLBACK@ # # Manual pages to install # MANUALS := $(addsuffix .1, $(addprefix share/man/, \ $(SIMPLE_PROGRAMS))) @XSEL_MAN_PATH@ # # All translation message catalogs # TRANSLATIONS_SRC := $(wildcard po/*.po) TRANSLATIONS := $(TRANSLATIONS_SRC:.po=.gmo) # # Extra util # XSEL := @XSEL@ XSEL_BIN := @XSEL_BIN@ # # Make everything needed for installing fish # all: $(PROGRAMS) user_doc share/man etc/config.fish share/config.fish $(TRANSLATIONS) @echo fish has now been built. @echo Use \'$(MAKE) install\' to install fish. .PHONY: all # # These dependencies make sure that autoconf and configure are run # when the source code for the build configuration has changed. # configure: configure.ac ./config.status --recheck Makefile: Makefile.in configure ./config.status # # Build fish with some debug flags specified. This is GCC specific, # and should only be used when debuging fish. # debug: $(MAKE) fish EXTRA_CXXFLAGS="-O0 -Wno-unused -g" .PHONY: debug prof: $(MAKE) all EXTRA_CXXFLAGS="-pg" LDFLAGS="-pg" .PHONY: prof # # User documentation, describing the features of the fish shell. # # Depend on the sources (*.hdr.in) and manually make the # intermediate *.hdr and doc.h files if needed user_doc: $(HDR_FILES_SRC) Doxyfile.user user_doc.head.html $(HELP_SRC) $(MAKE) doc.h $(HDR_FILES) doxygen Doxyfile.user touch user_doc # # Source code documentation. Also includes user documentation. # doc: *.h *.cpp doc.h Doxyfile doxygen; # # PDF version of the source code documentation. # doc/refman.pdf: doc cd doc/latex; make; mv refman.pdf ..; cd ../..; rm -r doc/latex; # # This target runs both the low level code tests and the high level script tests. # test: $(PROGRAMS) fish_tests ./fish_tests; cd tests; ../fish " >>command_list.tmp; \ cat $$i >>command_list.tmp; \ echo >>command_list.tmp; \ echo >>command_list.tmp; \ echo "Back to index". >>command_list.tmp; \ done mv command_list.tmp command_list.txt cat $@.in | awk '{if ($$0 ~ /@command_list@/){ system("cat command_list.txt");} else{ print $$0;}}' >$@ toc.txt: $(subst index.hdr,index.hdr.in,$(HDR_FILES)) -rm toc.tmp $@ for i in $(subst index.hdr,index.hdr.in,$(HDR_FILES)); do\ NAME=`basename $$i .hdr`; \ NAME=`basename $$NAME .hdr.in`; \ sed <$$i >>toc.tmp -n \ -e 's,.*\\page *\([^ ]*\) *\(.*\)$$,- \2,p' \ -e 's,.*\\section *\([^ ]*\) *\(.*\)$$, - \2,p'; \ done mv toc.tmp $@ doc_src/index.hdr: toc.txt doc_src/index.hdr.in cat $@.in | awk '{if ($$0 ~ /@toc@/){ system("cat toc.txt");} else{ print $$0;}}' >$@ # # doc.h is a compilation of the various snipptes of text used both for # the user documentation and for internal help functions into a single # file that can be parsed dy Doxygen to generate the user # documentation. # doc.h: $(HDR_FILES) cat $(HDR_FILES) >$@ # # This rule creates complete doxygen headers from each of the various # snipptes of text used both for the user documentation and for # internal help functions, that can be parsed to Doxygen to generate # the internal help function text. # %.doxygen:%.txt echo "/** \page " `basename $*` >$@; cat $*.txt >>$@; echo "*/" >>$@ %: %.in sed <$@.in >$@ \ -e "s,@sysconfdir\@,$(sysconfdir),g" \ -e "s,@datadir\@,$(datadir),g" \ -e "s,@docdir\@,$(docdir),g" \ -e "s|@configure_input\@|$@, generated from $@.in by the Makefile. DO NOT MANUALLY EDIT THIS FILE!|g" \ -e "s,@prefix\@,$(prefix),g" \ -e "s,@optbindirs\@,$(optbindirs),g" #-e "s,@\@,$()," # # Compile translation files to binary format # %.gmo: if test "$(HAVE_GETTEXT)" = 1; then \ msgfmt -o $*.gmo $*.po; \ fi # # Update existing po file or copy messages.pot # %.po:messages.pot if test $(HAVE_GETTEXT) = 1;then \ if test -f $*.po; then \ msgmerge -U --backup=existing $*.po messages.pot;\ else \ cp messages.pot $*.po;\ fi; \ fi # # Create a template translation object # messages.pot: *.cpp *.h etc/*.in share/*.in share/completions/*.fish share/functions/*.fish seq if test $(HAVE_GETTEXT) = 1;then \ xgettext -k_ -kN_ *.cpp *.h -o messages.pot; \ if xgettext -j -k_ -kN_ -k--description -LShell etc/*.in share/*.in share/completions/*.fish share/functions/*.fish seq -o messages.pot; then true; else \ echo "Your xgettext version is too old to build the messages.pot file"\ rm messages.pot\ false;\ fi; \ fi builtin.o: $(BUILTIN_FILES) common.o: $(COMMON_FILES) # # Generate the internal help functions by making doxygen create # man-pages. The convertion path looks like this: # # .txt file # || # (make) # || # \/ # .doxygen file # || # (doxygen) # || # \/ # roff file # || # (__fish_print_help) # || # \/ # formated text # with escape # sequences # # # There ought to be something simpler. # share/man: $(HELP_SRC) -rm doc_src/*.doxygen # Remove temp files from previous run -rm -r help_doc -mkdir share/man touch share/man for i in $(HELP_SRC); do \ FILE=doc_src/`basename $$i .txt`.doxygen; \ echo "/** \page" `basename $$i .txt` >$$FILE; \ cat $$i >>$$FILE; \ echo "*/" >>$$FILE; \ done doxygen Doxyfile.help for i in $(HELP_SRC); do \ CMD_NAME=`basename $$i .txt`; \ sed -e "s/\(.\)\\.SH/\1/" -e "s/$$CMD_NAME *\\\\- *\"\(.*\)\"/\1/" share/man/$$CMD_NAME.1; \ done rm doc_src/*.doxygen # Clean up intermediate files in doc_src/ rm -r help_doc # Clean up intermediate help_doc tree # # The build rules for installing/uninstalling fish # # # Check for an incompatible installed fish version, and fail with an # error if found # check-uninstall: if test -f $(DESTDIR)$(sysconfdir)/fish.d/fish_function.fish -o -f $(DESTDIR)$(sysconfdir)/fish.d/fish_complete.fish; then \ echo;\ echo ERROR;\ echo;\ echo An older fish installation using an incompatible filesystem hierarchy was detected;\ echo You must uninstall this fish version before proceeding;\ echo type \'$(MAKE) uninstall-legacy\' to uninstall these files,;\ echo or type \'$(MAKE) force-install\' to force installation.;\ echo The latter may result in a broken installation.;\ echo;\ false;\ fi; if test -f $(DESTDIR)$(sysconfdir)/fish; then \ echo;\ echo ERROR;\ echo;\ echo An older fish installation using an incompatible filesystem hierarchy was detected;\ echo You must remove the file $(DESTDIR)$(sysconfdir)/fish before proceeding;\ echo type \'$(MAKE) uninstall-legacy\' to uninstall this file,;\ echo or remove it manually using \'rm $(DESTDIR)$(sysconfdir)/fish\'.;\ echo;\ false;\ fi; .PHONY: check-uninstall # # This check makes sure that the install-sh script is executable. The # darcs repo doesn't preserve the executable bit, so this needs to be # run after checkout. # install-sh: if test -x $@; then true; else chmod 755 $@; fi .PHONY: install-sh # # Try to install after checking for incompatible installed versions. # install: all install-sh check-uninstall install-force .PHONY: install # # Force installation, even in presense of incompatible previous # version. This may fail. # These 'true' lines are to prevent installs from failing for (e.g.) missing man pages. # install-force: all install-translations $(INSTALL) -m 755 -d $(DESTDIR)$(bindir) for i in $(PROGRAMS); do\ $(INSTALL) -m 755 $$i $(DESTDIR)$(bindir) ; \ true ;\ done; $(INSTALL) -m 755 -d $(DESTDIR)$(sysconfdir)/fish $(INSTALL) -m 755 -d $(DESTDIR)$(datadir)/fish $(INSTALL) -m 755 -d $(DESTDIR)$(datadir)/fish/completions $(INSTALL) -m 755 -d $(DESTDIR)$(datadir)/fish/functions $(INSTALL) -m 755 -d $(DESTDIR)$(datadir)/fish/man $(INSTALL) -m 644 etc/config.fish $(DESTDIR)$(sysconfdir)/fish/ $(INSTALL) -m 644 share/config.fish $(DESTDIR)$(datadir)/fish/ for i in $(COMPLETIONS_DIR_FILES); do \ $(INSTALL) -m 644 $$i $(DESTDIR)$(datadir)/fish/completions/; \ true; \ done; for i in $(FUNCTIONS_DIR_FILES); do \ $(INSTALL) -m 644 $$i $(DESTDIR)$(datadir)/fish/functions/; \ true; \ done; for i in share/man/*.1; do \ $(INSTALL) -m 644 $$i $(DESTDIR)$(datadir)/fish/man/; \ true; \ done; $(INSTALL) -m 755 -d $(DESTDIR)$(docdir) for i in user_doc/html/* ChangeLog; do \ if test -f $$i; then \ $(INSTALL) -m 644 $$i $(DESTDIR)$(docdir); \ fi; \ done; $(INSTALL) -m 755 -d $(DESTDIR)$(mandir)/man1 for i in $(MANUALS); do \ $(INSTALL) -m 644 $$i $(DESTDIR)$(mandir)/man1/; \ true; \ done; @echo fish is now installed on your system. @echo To run fish, type \'fish\' in your terminal. @echo @echo To use fish as your login shell: @echo \* add the line \'$(DESTDIR)$(bindir)/fish\' to the file \'/etc/shells\'. @echo \* use the command \'chsh -s $(DESTDIR)$(bindir)/fish\'. @echo @echo Have fun! .PHONY: install-force # # Uninstall this fish version # uninstall: uninstall-translations -for i in $(PROGRAMS); do \ rm -f $(DESTDIR)$(bindir)/$$i; \ done; -rm -f $(DESTDIR)$(bindir)/xsel -rm -f $(DESTDIR)$(sysconfdir)/fish/config.fish -rmdir $(DESTDIR)$(sysconfdir)/fish -if test -d $(DESTDIR)$(datadir)/fish; then \ rm -r $(DESTDIR)$(datadir)/fish; \ fi -if test -d $(DESTDIR)$(docdir); then \ rm -r $(DESTDIR)$(docdir);\ fi -for i in $(MANUALS); do \ rm -f $(DESTDIR)$(mandir)/man1/`basename $$i`*; \ done; .PHONY: uninstall # # Uninstall an older fish release. This is not the default uninstall # since there is a slight chance that it removes a file put in place by # the sysadmin. But if 'make install' detects a file confligt, it # suggests using this target. # uninstall-legacy: uninstall -rm -f $(DESTDIR)$(sysconfdir)/fish.d/fish_interactive.fish -rm -f $(DESTDIR)$(sysconfdir)/fish.d/fish_complete.fish -rm -f $(DESTDIR)$(sysconfdir)/fish.d/fish_function.fish -rm -f $(DESTDIR)$(sysconfdir)/fish/fish_inputrc -if test -d $(DESTDIR)$(sysconfdir)/fish.d/completions; then \ for i in $(COMPLETIONS_DIR_FILES); do \ basename=`basename $$i`; \ if test -f $(DESTDIR)$(sysconfdir)/fish.d/completions/$$basename; then \ rm $(DESTDIR)$(sysconfdir)/fish.d/completions/$$basename; \ fi; \ done; \ fi; -rmdir $(DESTDIR)$(sysconfdir)/fish.d/completions -rmdir $(DESTDIR)$(sysconfdir)/fish.d -rm $(DESTDIR)$(sysconfdir)/fish @echo The previous fish installation has been removed. .PHONY: uninstall-legacy install-translations: $(TRANSLATIONS) if test $(HAVE_GETTEXT) = 1; then \ for i in $(TRANSLATIONS); do \ $(INSTALL) -m 755 -d $(DESTDIR)$(datadir)/locale/`basename $$i .gmo`/LC_MESSAGES; \ $(INSTALL) -m 644 $$i $(DESTDIR)$(datadir)/locale/`basename $$i .gmo`/LC_MESSAGES/fish.mo; \ echo $(DESTDIR)$(datadir)/locale/`basename $$i .gmo`/LC_MESSAGES/fish.mo;\ done; \ fi; .PHONY: install-translations uninstall-translations: if test $(HAVE_GETTEXT) = 1; then \ for i in $(TRANSLATIONS_SRC); do \ rm -f $(DESTDIR)$(datadir)/locale/*/LC_MESSAGES/fish.mo; \ done; \ fi .PHONY: uninstall-translations # # The build rules for all the commands # # # Build the fish program. # fish: $(FISH_OBJS) fish.o $(CXX) $(FISH_OBJS) fish.o $(LDFLAGS_FISH) -o $@ # # Build the fish_pager program. # fish_pager: $(FISH_PAGER_OBJS) $(CXX) $(FISH_PAGER_OBJS) $(LDFLAGS_FISH_PAGER) -o $@ # # Build the fishd program. # fishd: $(FISHD_OBJS) $(CXX) $(FISHD_OBJS) $(LDFLAGS_FISHD) -o $@ # # Build the fish_tests program. # fish_tests: $(FISH_TESTS_OBJS) $(CXX) $(FISH_TESTS_OBJS) $(LDFLAGS_FISH) -o $@ # # Build the mimedb program. # # mimedb does not need any libraries, so we don't use LDFLAGS here. # mimedb: $(MIME_OBJS) $(CXX) $(MIME_OBJS) $(LDFLAGS_MIMEDB) -o $@ # # Build the set_color program # set_color: set_color.o print_help.o common.o $(CXX) set_color.o print_help.o common.o wutil.o $(LDFLAGS_SET_COLOR) -o $@ # # Test program for the tokenizer library # tokenizer_test: tokenizer.cpp tokenizer.h wutil.o common.o $(CXX) $(CXXFLAGS) tokenizer.cpp wutil.o common.o -D TOKENIZER_TEST $(LDFLAGS) -o $@ # # Build the fish_indent program. # fish_indent: $(FISH_INDENT_OBJS) $(CXX) $(FISH_INDENT_OBJS) $(LDFLAGS_FISH_INDENT) -o $@ # # Neat little program to show output from terminal # key_reader: key_reader.o input_common.o common.o env_universal.o env_universal_common.o wutil.o $(CXX) key_reader.o input_common.o common.o env_universal.o env_universal_common.o wutil.o $(LDFLAGS_FISH) -o $@ # # Update dependencies # depend: makedepend -fMakefile.in -Y *.cpp ./config.status .PHONY: depend # # Dependencies that makedepend misses # autoload.cpp function.cpp: $(GENERATED_INTERN_SCRIPT_FILES) # # Copy all the source files into a new directory and use tar to create # an archive from it. Simplest way I could think of to make an archive # witout backups, autogenerated files, etc. # # Uses install instead of mkdir so build won't fail if the directory # exists # fish-@PACKAGE_VERSION@.tar: $(DOC_SRC_DIR_FILES) $(MAIN_DIR_FILES) $(ETC_DIR_FILES) $(TEST_DIR_FILES) $(SHARE_DIR_FILES) $(FUNCTIONS_DIR_FILES) $(COMPLETIONS_DIR_FILES) ChangeLog user_doc share/man rm -rf fish-@PACKAGE_VERSION@ $(INSTALL) -d fish-@PACKAGE_VERSION@ $(INSTALL) -d fish-@PACKAGE_VERSION@/doc_src $(INSTALL) -d fish-@PACKAGE_VERSION@/user_doc $(INSTALL) -d fish-@PACKAGE_VERSION@/etc $(INSTALL) -d fish-@PACKAGE_VERSION@/share $(INSTALL) -d fish-@PACKAGE_VERSION@/share/completions $(INSTALL) -d fish-@PACKAGE_VERSION@/share/functions $(INSTALL) -d fish-@PACKAGE_VERSION@/share/man $(INSTALL) -d fish-@PACKAGE_VERSION@/tests $(INSTALL) -d fish-@PACKAGE_VERSION@/po cp -f $(DOC_SRC_DIR_FILES) fish-@PACKAGE_VERSION@/doc_src cp -f $(MAIN_DIR_FILES) fish-@PACKAGE_VERSION@/ cp -f $(ETC_DIR_FILES) fish-@PACKAGE_VERSION@/etc/ cp -f $(SHARE_DIR_FILES) fish-@PACKAGE_VERSION@/share/ cp -f $(COMPLETIONS_DIR_FILES) fish-@PACKAGE_VERSION@/share/completions/ cp -f $(FUNCTIONS_DIR_FILES) fish-@PACKAGE_VERSION@/share/functions/ cp -f $(TESTS_DIR_FILES) fish-@PACKAGE_VERSION@/tests/ cp -f $(TRANSLATIONS_SRC) fish-@PACKAGE_VERSION@/po/ cp -f share/man/*.1 fish-@PACKAGE_VERSION@/share/man/ cp -rf user_doc fish-@PACKAGE_VERSION@/ tar -c fish-@PACKAGE_VERSION@ >fish-@PACKAGE_VERSION@.tar rm -rf fish-@PACKAGE_VERSION@ # # Just an alias for fish-@PACKAGE_VERSION@.tar # tar: fish-@PACKAGE_VERSION@.tar .PHONY: tar # # Make compressed tar archives # fish-@PACKAGE_VERSION@.tar.gz: fish-@PACKAGE_VERSION@.tar gzip -f --best -c fish-@PACKAGE_VERSION@.tar >fish-@PACKAGE_VERSION@.tar.gz fish-@PACKAGE_VERSION@.tar.bz2: fish-@PACKAGE_VERSION@.tar bzip2 -f --best -k fish-@PACKAGE_VERSION@.tar dist: fish-@PACKAGE_VERSION@.tar.bz2 .PHONY: dist # # Build the RPM spec file. # fish.spec: fish.spec.in ./config.status # # Create .rpm file for the current systems architecture and an # .src.rpm file. # rpm: fish-@PACKAGE_VERSION@.tar.bz2 fish.spec @if which rpmbuild; then true; else \ echo Could not find the rpmbuild command, needed to build an rpm; \ echo You may be able to install it using the following command:; \ echo \'yum install rpm-build\'; \ false; \ fi cp fish.spec /usr/src/redhat/SPECS/ cp fish-@PACKAGE_VERSION@.tar.bz2 /usr/src/redhat/SOURCES/ rpmbuild -ba --clean /usr/src/redhat/SPECS/fish.spec mv /usr/src/redhat/RPMS/*/fish*@PACKAGE_VERSION@*.rpm . mv /usr/src/redhat/SRPMS/fish*@PACKAGE_VERSION@*.src.rpm . .PHONY: rpm # # Cleanup targets # # # distclean should restore the tree to the state right after extracting a tarball. # distclean: clean rm -f fish.spec Doxyfile.help rm -f etc/config.fish seq share/config.fish rm -f config.status config.log config.h Makefile rm -rf $(XSEL) .PHONY: distclean # # clean removes everything built by the makefile, but not things that # are created by the configure script. # clean: rm -f *.o doc.h doc.tmp doc_src/*.doxygen doc_src/*.cpp doc_src/*.o doc_src/commands.hdr rm -f $(GENERATED_INTERN_SCRIPT_FILES) rm -f tests/tmp.err tests/tmp.out tests/tmp.status tests/foo.txt rm -f $(PROGRAMS) fish_tests tokenizer_test key_reader rm -f share/config.fish etc/config.fish doc_src/index.hdr doc_src/commands.hdr rm -f fish-@PACKAGE_VERSION@.tar rm -f fish-@PACKAGE_VERSION@.tar.gz rm -f fish-@PACKAGE_VERSION@.tar.bz2 rm -rf doc; rm -rf fish-@PACKAGE_VERSION@ rm -f $(TRANSLATIONS) test ! -d "$(XSEL)" || make -C $(XSEL) clean .PHONY: clean # DO NOT DELETE THIS LINE -- make depend depends on it. autoload.o: config.h autoload.h common.h util.h wutil.h signal.h env.h exec.h autoload.o: proc.h io.h builtin.o: config.h signal.h fallback.h util.h wutil.h builtin.h io.h builtin.o: common.h function.h complete.h proc.h parser.h event.h reader.h builtin.o: env.h wgetopt.h sanity.h tokenizer.h wildcard.h input_common.h builtin.o: input.h intern.h exec.h highlight.h halloc.h halloc_util.h builtin.o: parse_util.h autoload.h parser_keywords.h expand.h path.h builtin.o: builtin_set.cpp builtin_commandline.cpp builtin_complete.cpp builtin.o: builtin_ulimit.cpp builtin_jobs.cpp builtin_commandline.o: config.h signal.h fallback.h util.h wutil.h builtin.h builtin_commandline.o: io.h common.h wgetopt.h reader.h proc.h parser.h builtin_commandline.o: event.h tokenizer.h input_common.h input.h builtin_commandline.o: parse_util.h autoload.h builtin_complete.o: config.h signal.h fallback.h util.h wutil.h builtin.h builtin_complete.o: io.h common.h complete.h wgetopt.h parser.h proc.h builtin_complete.o: event.h reader.h builtin_jobs.o: config.h fallback.h signal.h util.h wutil.h builtin.h io.h builtin_jobs.o: common.h proc.h parser.h event.h wgetopt.h builtin_set.o: config.h signal.h fallback.h util.h wutil.h builtin.h io.h builtin_set.o: common.h env.h expand.h wgetopt.h proc.h parser.h event.h builtin_ulimit.o: config.h fallback.h signal.h util.h builtin.h io.h common.h builtin_ulimit.o: wgetopt.h common.o: config.h fallback.h signal.h util.h wutil.h common.h expand.h common.o: proc.h io.h wildcard.h parser.h event.h complete.h util.cpp common.o: halloc.cpp halloc.h halloc_util.cpp fallback.cpp complete.o: config.h signal.h fallback.h util.h tokenizer.h wildcard.h complete.o: common.h proc.h io.h parser.h event.h function.h complete.h complete.o: builtin.h env.h exec.h expand.h reader.h history.h intern.h complete.o: parse_util.h autoload.h parser_keywords.h halloc.h halloc_util.h complete.o: wutil.h path.h env.o: config.h signal.h fallback.h util.h wutil.h proc.h io.h common.h env.h env.o: sanity.h expand.h history.h reader.h parser.h event.h env_universal.h env.o: env_universal_common.h input_common.h path.h halloc.h halloc_util.h env.o: complete.h env_universal.o: config.h signal.h fallback.h util.h common.h wutil.h env_universal.o: env_universal_common.h env_universal.h env_universal_common.o: config.h signal.h fallback.h util.h common.h wutil.h env_universal_common.o: env_universal_common.h event.o: config.h signal.h fallback.h util.h wutil.h function.h common.h event.o: proc.h io.h parser.h event.h halloc_util.h exec.o: config.h signal.h fallback.h util.h common.h wutil.h proc.h io.h exec.o: exec.h parser.h event.h builtin.h function.h env.h wildcard.h exec.o: sanity.h expand.h halloc.h halloc_util.h parse_util.h autoload.h expand.o: config.h signal.h fallback.h util.h common.h wutil.h env.h proc.h expand.o: io.h parser.h event.h expand.h wildcard.h exec.h tokenizer.h expand.o: complete.h parse_util.h autoload.h halloc.h halloc_util.h fallback.o: config.h fallback.h signal.h util.h fish.o: config.h signal.h fallback.h util.h common.h reader.h io.h builtin.h fish.o: function.h complete.h wutil.h env.h sanity.h proc.h parser.h event.h fish.o: expand.h intern.h exec.h output.h halloc.h halloc_util.h history.h fish.o: path.h fish_indent.o: config.h fallback.h signal.h util.h common.h wutil.h halloc.h fish_indent.o: halloc_util.h tokenizer.h print_help.h parser_keywords.h fish_pager.o: config.h signal.h fallback.h util.h wutil.h common.h complete.h fish_pager.o: output.h input_common.h env_universal.h env_universal_common.h fish_pager.o: halloc.h halloc_util.h print_help.h fish_tests.o: config.h signal.h fallback.h util.h common.h proc.h io.h fish_tests.o: reader.h builtin.h function.h autoload.h complete.h wutil.h fish_tests.o: env.h expand.h parser.h event.h tokenizer.h output.h exec.h fish_tests.o: path.h halloc.h halloc_util.h fishd.o: config.h signal.h fallback.h util.h common.h wutil.h fishd.o: env_universal_common.h halloc.h halloc_util.h path.h print_help.h function.o: config.h signal.h wutil.h fallback.h util.h function.h common.h function.o: proc.h io.h parser.h event.h intern.h reader.h parse_util.h function.o: autoload.h parser_keywords.h env.h expand.h halloc.h function.o: halloc_util.h halloc.o: config.h fallback.h signal.h util.h common.h halloc.h halloc_util.o: config.h fallback.h signal.h util.h common.h halloc.h highlight.o: config.h signal.h fallback.h util.h wutil.h highlight.h env.h highlight.o: common.h tokenizer.h proc.h io.h parser.h event.h parse_util.h highlight.o: autoload.h parser_keywords.h builtin.h function.h expand.h highlight.o: sanity.h complete.h output.h halloc.h halloc_util.h wildcard.h highlight.o: path.h history.o: config.h fallback.h signal.h util.h wutil.h history.h common.h history.o: halloc.h halloc_util.h intern.h path.h input.o: config.h signal.h fallback.h util.h wutil.h reader.h io.h proc.h input.o: common.h sanity.h input_common.h input.h parser.h event.h env.h input.o: expand.h output.h intern.h halloc.h halloc_util.h input_common.o: config.h fallback.h signal.h util.h common.h wutil.h input_common.o: input_common.h env_universal.h env_universal_common.h input_common.o: iothread.h intern.o: config.h fallback.h signal.h util.h wutil.h common.h intern.h io.o: config.h fallback.h signal.h util.h wutil.h exec.h proc.h io.h common.h io.o: halloc.h iothread.o: iothread.h signal.h key_reader.o: config.h fallback.h signal.h input_common.h kill.o: config.h signal.h fallback.h util.h wutil.h kill.h proc.h io.h kill.o: common.h sanity.h env.h exec.h halloc.h path.h mimedb.o: config.h xdgmime.h fallback.h signal.h util.h print_help.h output.o: config.h signal.h fallback.h util.h wutil.h expand.h common.h output.o: output.h halloc_util.h highlight.h env.h parse_util.o: config.h fallback.h signal.h util.h wutil.h common.h parse_util.o: tokenizer.h parse_util.h autoload.h expand.h intern.h exec.h parse_util.o: proc.h io.h env.h wildcard.h halloc_util.h parser.o: config.h signal.h fallback.h util.h common.h wutil.h proc.h io.h parser.o: parser.h event.h parser_keywords.h tokenizer.h exec.h wildcard.h parser.o: function.h builtin.h env.h expand.h reader.h sanity.h parser.o: env_universal.h env_universal_common.h intern.h parse_util.h parser.o: autoload.h halloc.h halloc_util.h path.h complete.h parser_keywords.o: config.h fallback.h signal.h common.h util.h parser_keywords.o: parser_keywords.h path.o: config.h fallback.h signal.h util.h common.h env.h wutil.h halloc.h path.o: halloc_util.h path.h expand.h print_help.o: print_help.h proc.o: config.h signal.h fallback.h util.h wutil.h proc.h io.h common.h proc.o: reader.h sanity.h env.h parser.h event.h halloc.h halloc_util.h proc.o: output.h reader.o: config.h signal.h fallback.h util.h wutil.h highlight.h env.h reader.o: common.h reader.h io.h proc.h parser.h event.h complete.h history.h reader.o: sanity.h exec.h expand.h tokenizer.h kill.h input_common.h input.h reader.o: function.h output.h screen.h halloc.h halloc_util.h iothread.h reader.o: parse_util.h autoload.h sanity.o: config.h signal.h fallback.h util.h common.h sanity.h proc.h io.h sanity.o: history.h reader.h kill.h wutil.h screen.o: config.h fallback.h signal.h common.h util.h wutil.h output.h screen.o: highlight.h env.h screen.h set_color.o: config.h fallback.h signal.h print_help.h signal.o: config.h signal.h common.h util.h fallback.h wutil.h event.h signal.o: reader.h io.h proc.h tokenizer.o: config.h fallback.h signal.h util.h wutil.h tokenizer.h common.h util.o: config.h fallback.h signal.h util.h common.h wutil.h wgetopt.o: config.h wgetopt.h wutil.h fallback.h signal.h wildcard.o: config.h fallback.h signal.h util.h wutil.h complete.h common.h wildcard.o: wildcard.h reader.h io.h expand.h exec.h proc.h halloc_util.h wutil.o: config.h fallback.h signal.h util.h common.h wutil.h halloc.h wutil.o: halloc_util.h xdgmime.o: xdgmime.h xdgmimeint.h xdgmimeglob.h xdgmimemagic.h xdgmimealias.h xdgmime.o: xdgmimeparent.h xdgmimealias.o: xdgmimealias.h xdgmime.h xdgmimeint.h xdgmimeglob.o: xdgmimeglob.h xdgmime.h xdgmimeint.h xdgmimeint.o: xdgmimeint.h xdgmime.h xdgmimemagic.o: xdgmimemagic.h xdgmime.h xdgmimeint.h xdgmimeparent.o: xdgmimeparent.h xdgmime.h xdgmimeint.h