X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=Makefile;h=56cca08849be13e9433ecc524c34fb7ea969def5;hb=f9edc2331d8c2d7fe034369c5a3c6b0e1e24362b;hp=929522c3bf11dee195ad16a24b587b8d1b03956d;hpb=cb741242a1814db071ed1b1c694352efdc7624c7;p=ffmpeg diff --git a/Makefile b/Makefile index 929522c3bf1..56cca08849b 100644 --- a/Makefile +++ b/Makefile @@ -8,30 +8,21 @@ VPATH=$(SRC_PATH_BARE) CFLAGS=$(OPTFLAGS) -I$(BUILD_ROOT) -I$(SRC_PATH) -I$(SRC_PATH)/libavutil \ -I$(SRC_PATH)/libavcodec -I$(SRC_PATH)/libavformat -I$(SRC_PATH)/libswscale \ - -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_ISOC9X_SOURCE + -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_ISOC9X_SOURCE -DHAVE_AV_CONFIG_H LDFLAGS+= -g -ifeq ($(CONFIG_FFMPEG),yes) -MANPAGES=doc/ffmpeg.1 -PROGS_G+=ffmpeg_g$(EXESUF) -PROGS+=ffmpeg$(EXESUF) -endif +PROGS-$(CONFIG_FFMPEG) += ffmpeg +PROGS-$(CONFIG_FFPLAY) += ffplay +PROGS-$(CONFIG_FFSERVER) += ffserver -ifeq ($(CONFIG_FFSERVER),yes) -MANPAGES+=doc/ffserver.1 -PROGS+=ffserver$(EXESUF) -endif +PROGS = $(addsuffix $(EXESUF), $(PROGS-yes)) +PROGS_G = $(addsuffix _g$(EXESUF), $(PROGS-yes)) +MANPAGES = $(addprefix doc/, $(addsuffix .1, $(PROGS-yes))) -ifeq ($(CONFIG_FFPLAY),yes) -MANPAGES+=doc/ffplay.1 -PROGS_G+=ffplay_g$(EXESUF) -PROGS+=ffplay$(EXESUF) -endif - -BASENAMES=ffmpeg ffplay ffserver -ALLPROGS=$(addsuffix $(EXESUF), $(BASENAMES)) -ALLPROGS_G=$(addsuffix _g$(EXESUF), $(BASENAMES)) -ALLMANPAGES=$(addsuffix .1, $(BASENAMES)) +BASENAMES = ffmpeg ffplay ffserver +ALLPROGS = $(addsuffix $(EXESUF), $(BASENAMES)) +ALLPROGS_G = $(addsuffix _g$(EXESUF), $(BASENAMES)) +ALLMANPAGES = $(addsuffix .1, $(BASENAMES)) ifeq ($(BUILD_SHARED),yes) DEP_LIBS=libavcodec/$(SLIBPREF)avcodec$(SLIBSUF) libavformat/$(SLIBPREF)avformat$(SLIBSUF) @@ -39,27 +30,42 @@ else DEP_LIBS=libavcodec/$(LIBPREF)avcodec$(LIBSUF) libavformat/$(LIBPREF)avformat$(LIBSUF) endif -ifeq ($(CONFIG_VHOOK),yes) -VHOOK=videohook -INSTALLVHOOK=install-vhook -endif +ALL_TARGETS-$(CONFIG_VHOOK) += videohook +ALL_TARGETS-$(BUILD_DOC) += documentation -ifeq ($(BUILD_DOC),yes) -DOC=documentation -INSTALLMAN=install-man -endif +INSTALL_TARGETS-$(CONFIG_VHOOK) += install-vhook +INSTALL_TARGETS-$(BUILD_DOC) += install-man + +VHOOKCFLAGS += $(filter-out -mdynamic-no-pic,$(CFLAGS)) + +BASEHOOKS = fish null watermark +ALLHOOKS = $(BASEHOOKS) drawtext imlib2 ppm +ALLHOOKS_SRCS = $(addprefix vhook/, $(addsuffix .c, $(ALLHOOKS))) + +HOOKS-$(HAVE_FORK) += ppm +HOOKS-$(HAVE_IMLIB2) += imlib2 +HOOKS-$(HAVE_FREETYPE2) += drawtext + +HOOKS = $(addprefix vhook/, $(addsuffix $(SLIBSUF), $(BASEHOOKS) $(HOOKS-yes))) -OBJS = ffmpeg.o ffserver.o cmdutils.o ffplay.o -SRCS = $(OBJS:.o=.c) $(ASM_OBJS:.o=.s) +VHOOKCFLAGS-$(HAVE_IMLIB2) += `imlib2-config --cflags` +LIBS_imlib2$(SLIBSUF) = `imlib2-config --libs` + +VHOOKCFLAGS-$(HAVE_FREETYPE2) += `freetype-config --cflags` +LIBS_drawtext$(SLIBSUF) = `freetype-config --libs` + +VHOOKCFLAGS += $(VHOOKCFLAGS-yes) + +SRCS = $(addsuffix .c, $(PROGS-yes)) cmdutils.c LDFLAGS := -L$(BUILD_ROOT)/libavformat -L$(BUILD_ROOT)/libavcodec -L$(BUILD_ROOT)/libavutil $(LDFLAGS) EXTRALIBS := -lavformat$(BUILDSUF) -lavcodec$(BUILDSUF) -lavutil$(BUILDSUF) $(EXTRALIBS) ifeq ($(CONFIG_SWSCALER),yes) -LDFLAGS+=-L./libswscale +LDFLAGS+=-L$(BUILD_ROOT)/libswscale EXTRALIBS+=-lswscale$(BUILDSUF) endif -all: lib $(PROGS_G) $(PROGS) $(VHOOK) $(DOC) +all: lib $(PROGS) $(ALL_TARGETS-yes) lib: $(MAKE) -C libavutil all @@ -75,8 +81,8 @@ endif ffmpeg_g$(EXESUF): ffmpeg.o cmdutils.o .libs $(CC) $(LDFLAGS) -o $@ ffmpeg.o cmdutils.o $(EXTRALIBS) -ffserver$(EXESUF): ffserver.o .libs - $(CC) $(LDFLAGS) $(FFSERVERLDFLAGS) -o $@ ffserver.o $(EXTRALIBS) +ffserver$(EXESUF): ffserver.o cmdutils.o .libs + $(CC) $(LDFLAGS) $(FFSERVERLDFLAGS) -o $@ ffserver.o cmdutils.o $(EXTRALIBS) ffplay_g$(EXESUF): ffplay.o cmdutils.o .libs $(CC) $(LDFLAGS) -o $@ ffplay.o cmdutils.o $(EXTRALIBS) $(SDL_LIBS) @@ -85,52 +91,72 @@ ffplay_g$(EXESUF): ffplay.o cmdutils.o .libs cp -p $< $@ $(STRIP) $@ +SVN_ENTRIES = $(SRC_PATH_BARE)/.svn/entries +ifeq ($(wildcard $(SVN_ENTRIES)),$(SVN_ENTRIES)) +version.h: $(SVN_ENTRIES) +endif + version.h: $(SRC_PATH)/version.sh $(SRC_PATH) output_example$(EXESUF): output_example.o .libs - $(CC) $(LDFLAGS) -o $@ output_example.o $(EXTRALIBS) + $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $< $(EXTRALIBS) -qt-faststart$(EXESUF): qt-faststart.c +tools/qt-faststart$(EXESUF): tools/qt-faststart.c $(CC) $(CFLAGS) $< -o $@ -cws2fws$(EXESUF): cws2fws.c - $(CC) $< -o $@ -lz +tools/cws2fws$(EXESUF): tools/cws2fws.c + $(CC) $(CFLAGS) $< -o $@ -lz -ffplay.o: ffplay.c - $(CC) $(CFLAGS) $(SDL_CFLAGS) -c -o $@ $< +ffplay.o: CFLAGS += $(SDL_CFLAGS) ffmpeg.o ffplay.o ffserver.o: version.h +videohook: .libs $(HOOKS) + +vhook/%$(SLIBSUF): vhook/%.o + $(CC) $(LDFLAGS) -o $@ $(VHOOKSHFLAGS) $< $(VHOOKLIBS) $(LIBS_$(@F)) + +vhook/%.o: vhook/%.c + $(CC) $(VHOOKCFLAGS) -c -o $@ $< + %.o: %.c $(CC) $(CFLAGS) -c -o $@ $< -videohook: .libs - $(MAKE) -C vhook all +documentation: $(addprefix doc/, ffmpeg-doc.html faq.html ffserver-doc.html \ + ffplay-doc.html hooks.html $(ALLMANPAGES)) + +doc/%.html: doc/%.texi + texi2html -monolithic -number $< + mv $(@F) $@ -documentation: - $(MAKE) -C doc all +doc/%.pod: doc/%-doc.texi + doc/texi2pod.pl $< $@ -install: install-progs install-libs install-headers $(INSTALLMAN) $(INSTALLVHOOK) +doc/%.1: doc/%.pod + pod2man --section=1 --center=" " --release=" " $< > $@ + +install: install-progs install-libs install-headers $(INSTALL_TARGETS-yes) ifeq ($(BUILD_SHARED),yes) install-progs: $(PROGS) install-libs else install-progs: $(PROGS) endif - install -d "$(bindir)" - install -c $(INSTALLSTRIP) -m 755 $(PROGS) "$(bindir)" + install -d "$(BINDIR)" + install -c -m 755 $(PROGS) "$(BINDIR)" -# create the window installer +# Create the Windows installer. wininstaller: all install makensis ffinstall.nsi install-man: - install -d "$(mandir)/man1" - install -m 644 $(MANPAGES) "$(mandir)/man1" + install -d "$(MANDIR)/man1" + install -m 644 $(MANPAGES) "$(MANDIR)/man1" -install-vhook: - $(MAKE) -C vhook install +install-vhook: videohook + install -d "$(SHLIBDIR)/vhook" + install -m 755 $(HOOKS) "$(SHLIBDIR)/vhook" install-libs: $(MAKE) -C libavutil install-libs @@ -159,13 +185,14 @@ endif uninstall: uninstall-progs uninstall-libs uninstall-headers uninstall-man uninstall-vhook uninstall-progs: - rm -f $(addprefix $(bindir)/, $(ALLPROGS)) + rm -f $(addprefix $(BINDIR)/, $(ALLPROGS)) uninstall-man: - rm -f $(addprefix $(mandir)/man1/,$(ALLMANPAGES)) + rm -f $(addprefix $(MANDIR)/man1/,$(ALLMANPAGES)) uninstall-vhook: - $(MAKE) -C vhook uninstall + rm -f $(addprefix $(SHLIBDIR)/vhook/,$(ALLHOOKS)) + -rmdir "$(SHLIBDIR)/vhook/" uninstall-libs: $(MAKE) -C libavutil uninstall-libs @@ -178,10 +205,9 @@ uninstall-headers: $(MAKE) -C libavcodec uninstall-headers $(MAKE) -C libavformat uninstall-headers $(MAKE) -C libpostproc uninstall-headers - -rmdir "$(incdir)" - -rmdir "$(prefix)/include/postproc" + -rmdir "$(INCDIR)" -depend dep: .depend +depend dep: .depend .vhookdep $(MAKE) -C libavutil depend $(MAKE) -C libavcodec depend $(MAKE) -C libavformat depend @@ -191,16 +217,18 @@ endif ifeq ($(CONFIG_SWSCALER),yes) $(MAKE) -C libswscale depend endif -ifeq ($(CONFIG_VHOOK),yes) - $(MAKE) -C vhook depend -endif .depend: $(SRCS) version.h $(CC) -MM $(CFLAGS) $(SDL_CFLAGS) $(filter-out %.h,$^) 1>.depend -.libs: lib - @test -f .libs || touch .libs - @for i in $(DEP_LIBS) ; do if test $$i -nt .libs ; then touch .libs; fi ; done +# gcc stupidly only outputs the basename of targets +.vhookdep: $(ALLHOOKS_SRCS) + $(CC) $(VHOOKCFLAGS) -MM $^ | sed 's,^\([a-z]\),vhook/\1,' > $@ + +$(DEP_LIBS): lib + +.libs: $(DEP_LIBS) + touch $@ clean: $(MAKE) -C libavutil clean @@ -208,11 +236,12 @@ clean: $(MAKE) -C libavformat clean $(MAKE) -C libpostproc clean $(MAKE) -C libswscale clean - $(MAKE) -C tests clean - $(MAKE) -C vhook clean - $(MAKE) -C doc clean - rm -f *.o *.d *~ .libs gmon.out TAGS $(ALLPROGS) $(ALLPROGS_G) \ + rm -f *.o *~ .libs gmon.out TAGS $(ALLPROGS) $(ALLPROGS_G) \ output_example$(EXESUF) qt-faststart$(EXESUF) cws2fws$(EXESUF) + rm -f doc/*.html doc/*.pod doc/*.1 + rm -rf tests/vsynth1 tests/vsynth2 tests/data tests/asynth1.sw tests/*~ + rm -f $(addprefix tests/,$(addsuffix $(EXESUF),audiogen videogen rotozoom seek_test tiny_psnr)) + rm -f vhook/*.o vhook/*~ vhook/*.so vhook/*.dylib vhook/*.dll distclean: clean $(MAKE) -C libavutil distclean @@ -220,8 +249,6 @@ distclean: clean $(MAKE) -C libavformat distclean $(MAKE) -C libpostproc distclean $(MAKE) -C libswscale distclean - $(MAKE) -C tests distclean - $(MAKE) -C vhook distclean rm -f .depend version.h config.* *.pc TAGS: @@ -229,13 +256,61 @@ TAGS: # regression tests -codectest libavtest test-server fulltest test mpeg4 mpeg: $(PROGS) - $(MAKE) -C tests $@ +fulltest test: codectest libavtest seektest + +FFMPEG_REFFILE = $(SRC_PATH)/tests/ffmpeg.regression.ref +FFSERVER_REFFILE = $(SRC_PATH)/tests/ffserver.regression.ref +LIBAV_REFFILE = $(SRC_PATH)/tests/libav.regression.ref +ROTOZOOM_REFFILE = $(SRC_PATH)/tests/rotozoom.regression.ref +SEEK_REFFILE = $(SRC_PATH)/tests/seek.regression.ref + +test-server: ffserver$(EXESUF) tests/vsynth1/00.pgm tests/asynth1.sw + @echo + @echo "Unfortunately ffserver is broken and therefore its regression" + @echo "test fails randomly. Treat the results accordingly." + @echo + $(SRC_PATH)/tests/server-regression.sh $(FFSERVER_REFFILE) $(SRC_PATH)/tests/test.conf + +codectest mpeg4 mpeg ac3 snow snowll: ffmpeg$(EXESUF) tests/vsynth1/00.pgm tests/vsynth2/00.pgm tests/asynth1.sw tests/tiny_psnr$(EXESUF) + $(SRC_PATH)/tests/regression.sh $@ $(FFMPEG_REFFILE) tests/vsynth1 + $(SRC_PATH)/tests/regression.sh $@ $(ROTOZOOM_REFFILE) tests/vsynth2 + +libavtest: ffmpeg$(EXESUF) tests/vsynth1/00.pgm tests/asynth1.sw + $(SRC_PATH)/tests/regression.sh $@ $(LIBAV_REFFILE) tests/vsynth1 +seektest: tests/seek_test$(EXESUF) + $(SRC_PATH)/tests/seek_test.sh $(SEEK_REFFILE) + +ifeq ($(CONFIG_SWSCALER),yes) +test-server codectest mpeg4 mpeg ac3 snow snowll libavtest: swscale_error +swscale_error: + @echo + @echo "This regression test is incompatible with --enable-swscaler." + @echo + @exit 1 +endif + +tests/vsynth1/00.pgm: tests/videogen$(EXESUF) + mkdir -p tests/vsynth1 + $(BUILD_ROOT)/$< 'tests/vsynth1/' + +tests/vsynth2/00.pgm: tests/rotozoom$(EXESUF) + mkdir -p tests/vsynth2 + $(BUILD_ROOT)/$< 'tests/vsynth2/' $(SRC_PATH)/tests/lena.pnm + +tests/asynth1.sw: tests/audiogen$(EXESUF) + $(BUILD_ROOT)/$< $@ + +%$(EXESUF): %.c + $(CC) $(LDFLAGS) $(CFLAGS) -o $@ $< + +tests/seek_test$(EXESUF): tests/seek_test.c + $(CC) $(LDFLAGS) $(CFLAGS) -DHAVE_AV_CONFIG_H -o $@ $< $(EXTRALIBS) + .PHONY: all lib videohook documentation install* wininstaller uninstall* .PHONY: dep depend clean distclean TAGS -.PHONY: codectest libavtest test-server fulltest test mpeg4 mpeg +.PHONY: codectest libavtest seektest test-server fulltest test +.PHONY: mpeg4 mpeg ac3 snow snowll swscale-error -ifneq ($(wildcard .depend),) -include .depend -endif +-include .depend +-include .vhookdep