X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=Makefile;h=a4b0a37f6ea02a9d6c1a770e7adbb652ec02fc86;hb=ecfc4f44369553be8671beba2a8a5b295b09975a;hp=df3d5ec8dbaf3f2070e9bd2acde309c1953c7f19;hpb=6870a440cee9c142c5d99b44e6c93348b901c4d0;p=ffmpeg diff --git a/Makefile b/Makefile index df3d5ec8dba..a4b0a37f6ea 100644 --- a/Makefile +++ b/Makefile @@ -4,137 +4,111 @@ # include config.mak -VPATH=$(SRC_PATH) +VPATH=$(SRC_PATH_BARE) -CFLAGS=$(OPTFLAGS) -I. -I$(SRC_PATH) -I$(SRC_PATH)/libavutil -I$(SRC_PATH)/libavcodec -I$(SRC_PATH)/libavformat -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_GNU_SOURCE -LDFLAGS+= -g +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 +LDFLAGS+= -g -ifeq ($(TARGET_GPROF),yes) -CFLAGS+=-p -LDFLAGS+=-p +ifeq ($(CONFIG_FFMPEG),yes) +MANPAGES=doc/ffmpeg.1 +PROGS_G+=ffmpeg_g$(EXESUF) +PROGS+=ffmpeg$(EXESUF) endif -MANPAGE=doc/ffmpeg.1 -PROG=ffmpeg$(EXESUF) -PROGTEST=output_example$(EXESUF) -QTFASTSTART=qt-faststart$(EXESUF) - ifeq ($(CONFIG_FFSERVER),yes) -MANPAGE+=doc/ffserver.1 -PROG+=ffserver$(EXESUF) +MANPAGES+=doc/ffserver.1 +PROGS+=ffserver$(EXESUF) endif ifeq ($(CONFIG_FFPLAY),yes) -MANPAGE+=doc/ffplay.1 -PROG+=ffplay$(EXESUF) -FFPLAY_O=ffplay.o +MANPAGES+=doc/ffplay.1 +PROGS_G+=ffplay_g$(EXESUF) +PROGS+=ffplay$(EXESUF) endif -ifeq ($(CONFIG_AUDIO_BEOS),yes) -EXTRALIBS+=-lmedia -lbe -endif +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) else DEP_LIBS=libavcodec/$(LIBPREF)avcodec$(LIBSUF) libavformat/$(LIBPREF)avformat$(LIBSUF) -ifeq ($(CONFIG_MP3LAME),yes) -EXTRALIBS+=-lmp3lame -endif -endif - -ifeq ($(CONFIG_LIBOGG),yes) -ifeq ($(CONFIG_LIBVORBIS),yes) -EXTRALIBS+= -lvorbisenc -lvorbis -endif -ifeq ($(CONFIG_LIBTHEORA),yes) -EXTRALIBS+= -ltheora -endif -EXTRALIBS+= -logg -endif - -ifeq ($(CONFIG_FAAD),yes) -ifeq ($(CONFIG_FAADBIN),yes) -# no libs needed -else -EXTRALIBS += -lfaad -endif -endif - -ifeq ($(CONFIG_FAAC),yes) -EXTRALIBS+=-lfaac -endif - -ifeq ($(CONFIG_XVID),yes) -EXTRALIBS+=-lxvidcore -endif - -ifeq ($(CONFIG_LIBGSM),yes) -EXTRALIBS+=-lgsm endif -ifeq ($(CONFIG_DC1394),yes) -EXTRALIBS+=-ldc1394_control -lraw1394 -endif - -ifeq ($(BUILD_VHOOK),yes) +ifeq ($(CONFIG_VHOOK),yes) VHOOK=videohook INSTALLVHOOK=install-vhook -CLEANVHOOK=clean-vhook -endif - -ifeq ($(TARGET_OS), SunOS) -TEST=/usr/bin/test -else -TEST=test endif ifeq ($(BUILD_DOC),yes) DOC=documentation +INSTALLMAN=install-man endif -OBJS = ffmpeg.o ffserver.o cmdutils.o $(FFPLAY_O) +OBJS = ffmpeg.o ffserver.o cmdutils.o ffplay.o SRCS = $(OBJS:.o=.c) $(ASM_OBJS:.o=.s) -FFLIBS = -L./libavformat -lavformat$(BUILDSUF) -L./libavcodec -lavcodec$(BUILDSUF) -L./libavutil -lavutil$(BUILDSUF) +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 +EXTRALIBS+=-lswscale$(BUILDSUF) +endif -all: lib $(PROG) $(PROGTEST) $(VHOOK) $(QTFASTSTART) $(DOC) +all: lib $(PROGS) $(VHOOK) $(DOC) lib: - $(MAKE) -C libavutil all - $(MAKE) -C libavcodec all + $(MAKE) -C libavutil all + $(MAKE) -C libavcodec all $(MAKE) -C libavformat all +ifeq ($(CONFIG_PP),yes) + $(MAKE) -C libpostproc all +endif +ifeq ($(CONFIG_SWSCALER),yes) + $(MAKE) -C libswscale all +endif ffmpeg_g$(EXESUF): ffmpeg.o cmdutils.o .libs - $(CC) $(LDFLAGS) -o $@ ffmpeg.o cmdutils.o $(FFLIBS) $(EXTRALIBS) - -ffmpeg$(EXESUF): ffmpeg_g$(EXESUF) - cp -p $< $@ - $(STRIP) $@ + $(CC) $(LDFLAGS) -o $@ ffmpeg.o cmdutils.o $(EXTRALIBS) ffserver$(EXESUF): ffserver.o .libs - $(CC) $(LDFLAGS) $(FFSLDFLAGS) -o $@ ffserver.o $(FFLIBS) $(EXTRALIBS) + $(CC) $(LDFLAGS) $(FFSERVERLDFLAGS) -o $@ ffserver.o $(EXTRALIBS) ffplay_g$(EXESUF): ffplay.o cmdutils.o .libs - $(CC) $(LDFLAGS) -o $@ ffplay.o cmdutils.o $(FFLIBS) $(EXTRALIBS) $(SDL_LIBS) + $(CC) $(LDFLAGS) -o $@ ffplay.o cmdutils.o $(EXTRALIBS) $(SDL_LIBS) -ffplay$(EXESUF): ffplay_g$(EXESUF) +%$(EXESUF): %_g$(EXESUF) 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 $(FFLIBS) $(EXTRALIBS) + $(CC) $(LDFLAGS) -o $@ output_example.o $(EXTRALIBS) qt-faststart$(EXESUF): qt-faststart.c - $(CC) $(SRC_PATH)/qt-faststart.c -o qt-faststart$(EXESUF) + $(CC) $(CFLAGS) $< -o $@ cws2fws$(EXESUF): cws2fws.c - $(CC) $(SRC_PATH)/cws2fws.c -o cws2fws$(EXESUF) -lz + $(CC) $< -o $@ -lz ffplay.o: ffplay.c - $(CC) $(CFLAGS) $(SDL_CFLAGS) -c -o $@ $< + $(CC) $(CFLAGS) $(SDL_CFLAGS) -c -o $@ $< + +ffmpeg.o ffplay.o ffserver.o: version.h %.o: %.c - $(CC) $(CFLAGS) -c -o $@ $< + $(CC) $(CFLAGS) -c -o $@ $< videohook: .libs $(MAKE) -C vhook all @@ -142,87 +116,131 @@ videohook: .libs documentation: $(MAKE) -C doc all -.PHONY: install +install: install-progs install-libs install-headers $(INSTALLMAN) $(INSTALLVHOOK) -install: all install-man $(INSTALLVHOOK) - $(MAKE) -C libavutil install - $(MAKE) -C libavcodec install - $(MAKE) -C libavformat install +ifeq ($(BUILD_SHARED),yes) +install-progs: $(PROGS) install-libs +else +install-progs: $(PROGS) +endif install -d "$(bindir)" - install -c $(INSTALLSTRIP) -m 755 $(PROG) "$(bindir)" + install -c -m 755 $(PROGS) "$(bindir)" -# create the window installer +# Create the Windows installer. wininstaller: all install makensis ffinstall.nsi -# install man from source dir if available install-man: -ifneq ($(CONFIG_WIN32),yes) - if [ -f doc/ffmpeg.1 ] ; then \ - install -d "$(mandir)/man1" ; \ - install -m 644 $(MANPAGE) "$(mandir)/man1" ; \ - fi -endif + install -d "$(mandir)/man1" + install -m 644 $(MANPAGES) "$(mandir)/man1" install-vhook: $(MAKE) -C vhook install -installlib: - $(MAKE) -C libavutil installlib - $(MAKE) -C libavcodec installlib - $(MAKE) -C libavformat installlib +install-libs: + $(MAKE) -C libavutil install-libs + $(MAKE) -C libavcodec install-libs + $(MAKE) -C libavformat install-libs +ifeq ($(CONFIG_PP),yes) + $(MAKE) -C libpostproc install-libs +endif +ifeq ($(CONFIG_SWSCALER),yes) + $(MAKE) -C libswscale install-libs +endif -dep: depend +ifeq ($(BUILD_SHARED),yes) + -$(LDCONFIG) +endif -depend: .depend - $(MAKE) -C libavcodec depend +install-headers: + $(MAKE) -C libavutil install-headers + $(MAKE) -C libavcodec install-headers + $(MAKE) -C libavformat install-headers +ifeq ($(CONFIG_PP),yes) + $(MAKE) -C libpostproc install-headers +endif + $(MAKE) -C libswscale install-headers + +uninstall: uninstall-progs uninstall-libs uninstall-headers uninstall-man uninstall-vhook + +uninstall-progs: + rm -f $(addprefix $(bindir)/, $(ALLPROGS)) + +uninstall-man: + rm -f $(addprefix $(mandir)/man1/,$(ALLMANPAGES)) + +uninstall-vhook: + $(MAKE) -C vhook uninstall + +uninstall-libs: + $(MAKE) -C libavutil uninstall-libs + $(MAKE) -C libavcodec uninstall-libs + $(MAKE) -C libavformat uninstall-libs + $(MAKE) -C libpostproc uninstall-libs + +uninstall-headers: + $(MAKE) -C libavutil uninstall-headers + $(MAKE) -C libavcodec uninstall-headers + $(MAKE) -C libavformat uninstall-headers + $(MAKE) -C libpostproc uninstall-headers + -rmdir "$(incdir)" + -rmdir "$(prefix)/include/postproc" + +depend dep: .depend + $(MAKE) -C libavutil depend + $(MAKE) -C libavcodec depend $(MAKE) -C libavformat depend -ifeq ($(BUILD_VHOOK),yes) - $(MAKE) -C vhook depend +ifeq ($(CONFIG_PP),yes) + $(MAKE) -C libpostproc depend +endif +ifeq ($(CONFIG_SWSCALER),yes) + $(MAKE) -C libswscale depend +endif +ifeq ($(CONFIG_VHOOK),yes) + $(MAKE) -C vhook depend endif -.depend: $(SRCS) - $(CC) -MM $(CFLAGS) $(SDL_CFLAGS) $^ 1>.depend +.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 +$(DEP_LIBS): lib -clean: $(CLEANVHOOK) - $(MAKE) -C libavutil clean - $(MAKE) -C libavcodec clean - $(MAKE) -C libavformat clean - $(MAKE) -C tests clean - rm -f *.o *.d *~ .libs .depend gmon.out TAGS ffmpeg_g$(EXESUF) \ - ffplay_g$(EXESUF) $(PROG) $(PROGTEST) $(QTFASTSTART) +.libs: $(DEP_LIBS) + touch $@ -clean-vhook: - $(MAKE) -C vhook clean +clean: + $(MAKE) -C libavutil clean + $(MAKE) -C libavcodec 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) \ + output_example$(EXESUF) qt-faststart$(EXESUF) cws2fws$(EXESUF) -# Note well: config.log is NOT removed. distclean: clean - $(MAKE) -C libavcodec distclean - rm -f config.mak config.h + $(MAKE) -C libavutil distclean + $(MAKE) -C libavcodec distclean + $(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: etags *.[ch] libavformat/*.[ch] libavcodec/*.[ch] # regression tests -libavtest test mpeg4 mpeg test-server fulltest: ffmpeg$(EXESUF) +codectest libavtest test-server fulltest test mpeg4 mpeg: $(PROGS) $(MAKE) -C tests $@ -# tar release (use 'make -k tar' on a checkouted tree) -FILE=ffmpeg-$(shell grep "\#define FFMPEG_VERSION " libavcodec/avcodec.h | \ - cut -d "\"" -f 2 ) - -tar: - rm -rf /tmp/$(FILE) - cp -r . /tmp/$(FILE) - ( cd /tmp ; tar zcvf ~/$(FILE).tar.gz $(FILE) --exclude CVS ) - rm -rf /tmp/$(FILE) - -.PHONY: lib +.PHONY: all lib videohook documentation install* wininstaller uninstall* +.PHONY: dep depend clean distclean TAGS +.PHONY: codectest libavtest test-server fulltest test mpeg4 mpeg ifneq ($(wildcard .depend),) include .depend