X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=Makefile.real;h=cc8225ba07852de3779fd21742b59442ba0cf336;hp=269babaf0aa73db9acc9c7aa926f7a01b821a470;hb=5ff80e887a99a192bab3339c4339f8202733f031;hpb=a91893a665e0b016235f3994ac563b502cfefb29 diff --git a/Makefile.real b/Makefile.real index 269babaf..cc8225ba 100644 --- a/Makefile.real +++ b/Makefile.real @@ -1,5 +1,14 @@ -VARDIR := /var/paraslash -MANDIR := $(datarootdir)/man/man1 +# Implicit rules are implemented in make as suffix rules. The following rule +# empties the suffix list to disable the predefined implicit rules. This +# increases performance and avoids hard-to-debug behaviour. +.SUFFIXES: +MAKEFLAGS += -Rr +ifeq ("$(origin CC)", "default") + CC := cc +endif + +vardir := /var/paraslash +mandir := $(datarootdir)/man/man1 STRIP := $(CROSS_COMPILE)strip HOSTCC ?= cc MKDIR_P := mkdir -p @@ -81,12 +90,11 @@ $(subst p,P,$(subst q,Q,$(subst r,R,$(subst s,S,$(subst t,T,\ $(subst u,U,$(subst v,V,$(subst w,W,$(subst x,X,$(subst y,Y,\ $(subst z,Z,$1)))))))))))))))))))))))))) -CPPFLAGS += -DBINDIR='"$(BINDIR)"' +CPPFLAGS += -DBINDIR='"$(bindir)"' CPPFLAGS += -DBUILD_DATE='"$(build_date)"' CPPFLAGS += -DUNAME_RS='"$(uname_rs)"' CPPFLAGS += -DCC_VERSION='"$(cc_version)"' CPPFLAGS += -DMAIN_INPUT_FILE_IS_$(*F) -CPPFLAGS += $(arch_cppflags) CPPFLAGS += -I/usr/local/include CPPFLAGS += -I$(cmdline_dir) CPPFLAGS += -I$(cmdlist_dir) @@ -110,6 +118,7 @@ LDFLAGS += $(clock_gettime_ldflags) ifeq ($(uname_s),Linux) # these cause warnings on *BSD + CPPFLAGS += -Wunused-macros STRICT_CFLAGS += -fdata-sections -ffunction-sections STRICT_CFLAGS += -Wstrict-prototypes STRICT_CFLAGS += -Wshadow @@ -131,7 +140,7 @@ $(cmdlist_dir)/%.command_list.h: %.cmd %.c | $(cmdlist_dir) $(cmdlist_dir)/%.command_list.man: %.cmd %.c | $(cmdlist_dir) @[ -z "$(Q)" ] || echo 'GEN $@' $(Q) ./command_util.bash man < $< > $@ -$(cmdlist_dir)/%.completion.h: %.cmd %.c | $(cmdlist_dir) +$(cmdlist_dir)/%.completion.h: %.cmd | $(cmdlist_dir) @[ -z "$(Q)" ] || echo 'GEN $@' $(Q) ./command_util.bash compl $(strip $(call TOUPPER,$(*F)))_COMPLETERS \ $(strip $(call TOUPPER,$(*F)))_COMMANDS < $< > $@ @@ -146,9 +155,9 @@ $(cmdlist_dir)/afs.command_list.man \ $(cmdlist_dir)/afs.completion.h \ : afs.c aft.c attribute.c -$(cmdlist_dir)/audiod,command_list.h \ -$(cmdlist_dir)/audiod,command_list.man \ -$(cmdlist_dir)/audiod,completion.h \ +$(cmdlist_dir)/audiod.command_list.h \ +$(cmdlist_dir)/audiod.command_list.man \ +$(cmdlist_dir)/audiod.completion.h \ : audiod_command.c server_command_lists := $(cmdlist_dir)/server.command_list.man \ @@ -164,7 +173,8 @@ $(man_dir)/para_server.1: man_util_command_lists := $(server_command_lists) $(man_dir)/para_audiod.1: man_util_command_lists := $(audiod_command_lists) $(man_dir)/para_play.1: man_util_command_lists := $(play_command_lists) -$(man_dir)/para_%.1: $(ggo_dir)/%.ggo man_util.bash | $(man_dir) $(help2man_dir) +$(man_dir)/para_%.1: $(ggo_dir)/%.ggo man_util.bash \ + git-version.h | $(man_dir) $(help2man_dir) @[ -z "$(Q)" ] || echo 'MAN $<' $(Q) \ COMMAND_LISTS="$(man_util_command_lists)" \ @@ -197,6 +207,8 @@ $(object_dir)/mp3_afh.o $(dep_dir)/mp3_afh.d: CPPFLAGS += $(id3tag_cppflags) $(object_dir)/crypt.o $(dep_dir)/crypt.d: CPPFLAGS += $(openssl_cppflags) $(object_dir)/gcrypt.o $(dep_dir)/gcrypt.d: CPPFLAGS += $(gcrypt_cppflags) $(object_dir)/ao_write.o $(dep_dir)/ao_write.d: CPPFLAGS += $(ao_cppflags) +$(object_dir)/aac_afh.o $(dep_dir)/aac_afh.d: CPPFLAGS += $(mp4v2_cppflags) +$(object_dir)/alsa%.o $(dep_dir)/alsa%.d: CPPFLAGS += $(alsa_cppflags) $(object_dir)/interactive.o $(dep_dir)/interactive.d \ : CPPFLAGS += $(readline_cppflags) @@ -204,6 +216,12 @@ $(object_dir)/interactive.o $(dep_dir)/interactive.d \ $(object_dir)/resample_filter.o $(dep_dir)/resample_filter.d \ : CPPFLAGS += $(samplerate_cppflags) +$(object_dir)/oss_write.o $(dep_dir)/oss_write.d \ +: CPPFLAGS += $(oss_cppflags) + +$(object_dir)/ao_write.o $(dep_dir)/ao_write.d \ +: CPPFLAGS += $(ao_cppflags) $(pthread_cppflags) + $(object_dir)/mp3dec_filter.o $(dep_dir)/mp3dec_filter.d \ : CPPFLAGS += $(mad_cppflags) @@ -264,7 +282,8 @@ $(dep_dir)/%.d: %.c error2.h | $(dep_dir) -e "s@ \([a-zA-Z0-9_]\{1,\}\.completion.h\)@ $(cmdlist_dir)/\1@g" > $@ para_recv para_afh para_play para_server: LDFLAGS += $(id3tag_ldflags) -para_write para_play para_audiod: LDFLAGS += $(ao_ldflags) $(core_audio_ldflags) +para_write para_play para_audiod \ +: LDFLAGS += $(ao_ldflags) $(pthread_ldflags) $(core_audio_ldflags) para_client para_audioc para_play : LDFLAGS += $(readline_ldflags) para_server: LDFLAGS += $(osl_ldflags) para_gui: LDFLAGS += $(curses_ldflags) @@ -279,6 +298,7 @@ para_filter \ para_play \ : LDFLAGS += \ $(mad_ldflags) \ + $(faad_ldflags) \ $(samplerate_ldflags) \ -lm @@ -304,6 +324,13 @@ para_recv \ $(faad_ldflags) \ $(flac_ldflags) +para_server \ +para_play \ +para_afh \ +para_recv \ +: LDFLAGS += \ + $(mp4v2_ldflags) + para_server \ para_client \ para_audioc \ @@ -312,6 +339,8 @@ para_recv \ : LDFLAGS += \ $(socket_ldflags) $(nsl_ldflags) +para_afh para_recv para_server para_play: LDFLAGS += $(iconv_ldflags) + $(foreach exe,$(executables),$(eval para_$(exe): $$($(exe)_objs))) $(prefixed_executables): @[ -z "$(Q)" ] || echo 'LD $@' @@ -333,14 +362,13 @@ distclean: clean2 test-clean maintainer-clean: distclean @[ -z "$(Q)" ] || echo 'MAINTAINER-CLEAN' $(Q) rm -f *.tar.bz2 config.h configure config.h.in - $(Q) rm -rf web_sync install: all man - $(MKDIR_P) $(BINDIR) $(MANDIR) + $(MKDIR_P) $(bindir) $(mandir) $(INSTALL) -s --strip-program $(STRIP) -m 755 \ - $(prefixed_executables) $(BINDIR) - $(INSTALL) -m 644 $(man_pages) $(MANDIR) - $(MKDIR_P) $(VARDIR) >/dev/null 2>&1 || true # not fatal, so don't complain + $(prefixed_executables) $(bindir) + $(INSTALL) -m 644 $(man_pages) $(mandir) + $(MKDIR_P) $(vardir) >/dev/null 2>&1 || true # not fatal, so don't complain $(tarball): $(Q) rm -rf $(tarball) $(tarball_pfx)