X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=Makefile;h=1bf8ca3432dc93f8d7a14a0940d30b2e84f92d74;hb=19a6be34631080b763c87cd2371e00b06ff1efd9;hp=42e4d41ea1b5c3cb6cf207e86c81c1159296bcac;hpb=4b65d88fd7a19a75215de74d7c6e2f664e40df26;p=ffmpeg diff --git a/Makefile b/Makefile index 42e4d41ea1b..1bf8ca3432d 100644 --- a/Makefile +++ b/Makefile @@ -4,18 +4,18 @@ # 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 \ +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 ($(CONFIG_FFMPEG),yes) MANPAGES=doc/ffmpeg.1 PROGS_G+=ffmpeg_g$(EXESUF) PROGS+=ffmpeg$(EXESUF) -PROGTEST=output_example$(EXESUF) -QTFASTSTART=qt-faststart$(EXESUF) +endif ifeq ($(CONFIG_FFSERVER),yes) MANPAGES+=doc/ffserver.1 @@ -26,7 +26,6 @@ ifeq ($(CONFIG_FFPLAY),yes) MANPAGES+=doc/ffplay.1 PROGS_G+=ffplay_g$(EXESUF) PROGS+=ffplay$(EXESUF) -FFPLAY_O=ffplay.o endif BASENAMES=ffmpeg ffplay ffserver @@ -34,31 +33,33 @@ ALLPROGS=$(addsuffix $(EXESUF), $(BASENAMES)) ALLPROGS_G=$(addsuffix _g$(EXESUF), $(BASENAMES)) ALLMANPAGES=$(addsuffix .1, $(BASENAMES)) -ifeq ($(CONFIG_AUDIO_BEOS),yes) -EXTRALIBS+=-lmedia -lbe -endif - 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) endif -ifeq ($(BUILD_VHOOK),yes) +ifeq ($(CONFIG_VHOOK),yes) VHOOK=videohook INSTALLVHOOK=install-vhook 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) -FFLIBDIRS = -L./libavformat -L./libavcodec -L./libavutil -FFLIBS = -lavformat$(BUILDSUF) -lavcodec$(BUILDSUF) -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: version.h lib $(PROGS_G) $(PROGS) $(PROGTEST) $(VHOOK) $(QTFASTSTART) $(DOC) +all: lib $(PROGS_G) $(PROGS) $(VHOOK) $(DOC) lib: $(MAKE) -C libavutil all @@ -67,36 +68,40 @@ lib: 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) $(FFLIBDIRS) $(LDFLAGS) -o $@ ffmpeg.o cmdutils.o $(FFLIBS) $(EXTRALIBS) + $(CC) $(LDFLAGS) -o $@ ffmpeg.o cmdutils.o $(EXTRALIBS) ffserver$(EXESUF): ffserver.o .libs - $(CC) $(FFLIBDIRS) $(LDFLAGS) $(FFSLDFLAGS) -o $@ ffserver.o $(FFLIBS) $(EXTRALIBS) + $(CC) $(LDFLAGS) $(FFSERVERLDFLAGS) -o $@ ffserver.o $(EXTRALIBS) ffplay_g$(EXESUF): ffplay.o cmdutils.o .libs - $(CC) $(FFLIBDIRS) $(LDFLAGS) -o $@ ffplay.o cmdutils.o $(FFLIBS) $(EXTRALIBS) $(SDL_LIBS) + $(CC) $(LDFLAGS) -o $@ ffplay.o cmdutils.o $(EXTRALIBS) $(SDL_LIBS) %$(EXESUF): %_g$(EXESUF) cp -p $< $@ $(STRIP) $@ -.PHONY: version.h version.h: - $(SRC_PATH)/version.sh "$(SRC_PATH)" + $(SRC_PATH)/version.sh $(SRC_PATH) output_example$(EXESUF): output_example.o .libs - $(CC) $(FFLIBDIRS) $(LDFLAGS) -o $@ output_example.o $(FFLIBS) $(EXTRALIBS) + $(CC) $(LDFLAGS) -o $@ output_example.o $(EXTRALIBS) qt-faststart$(EXESUF): qt-faststart.c - $(CC) $(CFLAGS) $(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 $@ $< +ffmpeg.o ffplay.o ffserver.o: version.h + %.o: %.c $(CC) $(CFLAGS) -c -o $@ $< @@ -106,9 +111,7 @@ videohook: .libs documentation: $(MAKE) -C doc all -.PHONY: install - -install: install-progs install-libs install-headers install-man $(INSTALLVHOOK) +install: install-progs install-libs install-headers $(INSTALLMAN) $(INSTALLVHOOK) ifeq ($(BUILD_SHARED),yes) install-progs: $(PROGS) install-libs @@ -122,14 +125,9 @@ endif wininstaller: all install makensis ffinstall.nsi -# install man from source dir if available install-man: -ifneq ($(CONFIG_MINGW),yes) - if [ -f doc/ffmpeg.1 ] ; then \ - install -d "$(mandir)/man1" ; \ - install -m 644 $(MANPAGES) "$(mandir)/man1" ; \ - fi -endif + install -d "$(mandir)/man1" + install -m 644 $(MANPAGES) "$(mandir)/man1" install-vhook: $(MAKE) -C vhook install @@ -141,6 +139,10 @@ install-libs: ifeq ($(CONFIG_PP),yes) $(MAKE) -C libpostproc install-libs endif +ifeq ($(CONFIG_SWSCALER),yes) + $(MAKE) -C libswscale install-libs +endif + ifeq ($(BUILD_SHARED),yes) -$(LDCONFIG) endif @@ -152,6 +154,7 @@ 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 @@ -159,9 +162,7 @@ uninstall-progs: rm -f $(addprefix $(bindir)/, $(ALLPROGS)) uninstall-man: -ifneq ($(CONFIG_MINGW),yes) rm -f $(addprefix $(mandir)/man1/,$(ALLMANPAGES)) -endif uninstall-vhook: $(MAKE) -C vhook uninstall @@ -180,40 +181,46 @@ uninstall-headers: -rmdir "$(incdir)" -rmdir "$(prefix)/include/postproc" -dep: depend - -depend: .depend +depend dep: .depend $(MAKE) -C libavutil depend $(MAKE) -C libavcodec depend $(MAKE) -C libavformat depend -ifeq ($(BUILD_VHOOK),yes) +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) version.h - $(CC) -MM $(CFLAGS) $(SDL_CFLAGS) $^ 1>.depend + $(CC) -MM $(CFLAGS) $(SDL_CFLAGS) $(filter-out %.h,$^) 1>.depend + +$(DEP_LIBS): lib -.libs: lib - @test -f .libs || touch .libs - @for i in $(DEP_LIBS) ; do if test $$i -nt .libs ; then touch .libs; fi ; done +.libs: $(DEP_LIBS) + touch $@ 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) $(PROGTEST) $(QTFASTSTART) + 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 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 @@ -223,20 +230,12 @@ TAGS: # regression tests -libavtest test mpeg4 mpeg test-server fulltest: $(PROGS) +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 .svn ) - 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