generate separate dependency files per object file
Originally committed as revision 12775 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
95c76e1180
commit
caec74dd65
20
Makefile
20
Makefile
@ -14,7 +14,7 @@ PROGS-$(CONFIG_FFSERVER) += ffserver
|
|||||||
|
|
||||||
PROGS = $(addsuffix $(EXESUF), $(PROGS-yes))
|
PROGS = $(addsuffix $(EXESUF), $(PROGS-yes))
|
||||||
PROGS_G = $(addsuffix _g$(EXESUF), $(PROGS-yes))
|
PROGS_G = $(addsuffix _g$(EXESUF), $(PROGS-yes))
|
||||||
PROGS_SRCS = $(addsuffix .c, $(PROGS-yes)) cmdutils.c
|
OBJS = $(addsuffix .o, $(PROGS-yes)) cmdutils.o
|
||||||
MANPAGES = $(addprefix doc/, $(addsuffix .1, $(PROGS-yes)))
|
MANPAGES = $(addprefix doc/, $(addsuffix .1, $(PROGS-yes)))
|
||||||
|
|
||||||
BASENAMES = ffmpeg ffplay ffserver
|
BASENAMES = ffmpeg ffplay ffserver
|
||||||
@ -52,8 +52,6 @@ $(PROGS): %$(EXESUF): %_g$(EXESUF)
|
|||||||
cp -p $< $@
|
cp -p $< $@
|
||||||
$(STRIP) $@
|
$(STRIP) $@
|
||||||
|
|
||||||
.depend: version.h $(PROGS_SRCS)
|
|
||||||
|
|
||||||
SUBDIR_VARS := OBJS ASM_OBJS CPP_OBJS FFLIBS CLEANFILES
|
SUBDIR_VARS := OBJS ASM_OBJS CPP_OBJS FFLIBS CLEANFILES
|
||||||
|
|
||||||
define RESET
|
define RESET
|
||||||
@ -89,9 +87,7 @@ output_example$(EXESUF): output_example.o $(DEP_LIBS)
|
|||||||
tools/%$(EXESUF): tools/%.c
|
tools/%$(EXESUF): tools/%.c
|
||||||
$(CC) $(CFLAGS) $(FF_LDFLAGS) -o $@ $< $(FF_EXTRALIBS)
|
$(CC) $(CFLAGS) $(FF_LDFLAGS) -o $@ $< $(FF_EXTRALIBS)
|
||||||
|
|
||||||
ffplay.o .depend: CFLAGS += $(SDL_CFLAGS)
|
ffplay.o: CFLAGS += $(SDL_CFLAGS)
|
||||||
|
|
||||||
ffmpeg.o ffplay.o ffserver.o: version.h
|
|
||||||
|
|
||||||
VHOOKCFLAGS += $(filter-out -mdynamic-no-pic,$(CFLAGS))
|
VHOOKCFLAGS += $(filter-out -mdynamic-no-pic,$(CFLAGS))
|
||||||
|
|
||||||
@ -113,7 +109,7 @@ LIBS_drawtext$(SLIBSUF) = `freetype-config --libs`
|
|||||||
|
|
||||||
VHOOKCFLAGS += $(VHOOKCFLAGS-yes)
|
VHOOKCFLAGS += $(VHOOKCFLAGS-yes)
|
||||||
|
|
||||||
vhook/%.o: CFLAGS:=$(VHOOKCFLAGS)
|
vhook/%.o vhook/%.d: CFLAGS:=$(VHOOKCFLAGS)
|
||||||
|
|
||||||
# vhooks compile fine without libav*, but need them nonetheless.
|
# vhooks compile fine without libav*, but need them nonetheless.
|
||||||
videohook: $(DEP_LIBS) $(HOOKS)
|
videohook: $(DEP_LIBS) $(HOOKS)
|
||||||
@ -121,10 +117,8 @@ videohook: $(DEP_LIBS) $(HOOKS)
|
|||||||
vhook/%$(SLIBSUF): vhook/%.o
|
vhook/%$(SLIBSUF): vhook/%.o
|
||||||
$(CC) $(LDFLAGS) -o $@ $(VHOOKSHFLAGS) $< $(VHOOKLIBS) $(LIBS_$(@F))
|
$(CC) $(LDFLAGS) -o $@ $(VHOOKSHFLAGS) $< $(VHOOKLIBS) $(LIBS_$(@F))
|
||||||
|
|
||||||
.vhookdep: $(ALLHOOKS_SRCS) version.h
|
VHOOK_DEPS = $(HOOKS:$(SLIBSUF)=.d)
|
||||||
$(VHOOK_DEPEND_CMD) > $@
|
depend dep: $(VHOOK_DEPS)
|
||||||
|
|
||||||
depend dep: .vhookdep
|
|
||||||
|
|
||||||
documentation: $(addprefix doc/, ffmpeg-doc.html faq.html ffserver-doc.html \
|
documentation: $(addprefix doc/, ffmpeg-doc.html faq.html ffserver-doc.html \
|
||||||
ffplay-doc.html general.html hooks.html \
|
ffplay-doc.html general.html hooks.html \
|
||||||
@ -176,7 +170,7 @@ clean::
|
|||||||
rm -f vhook/*.o vhook/*~ vhook/*.so vhook/*.dylib vhook/*.dll
|
rm -f vhook/*.o vhook/*~ vhook/*.so vhook/*.dylib vhook/*.dll
|
||||||
|
|
||||||
distclean::
|
distclean::
|
||||||
rm -f .vhookdep version.h config.* *.pc
|
rm -f version.h config.* *.pc vhook/*.d
|
||||||
|
|
||||||
# regression tests
|
# regression tests
|
||||||
|
|
||||||
@ -352,4 +346,4 @@ tests/seek_test$(EXESUF): tests/seek_test.c $(DEP_LIBS)
|
|||||||
.PHONY: codectest libavtest seektest test-server fulltest test
|
.PHONY: codectest libavtest seektest test-server fulltest test
|
||||||
.PHONY: $(CODEC_TESTS) $(LAVF_TESTS) regtest-ref swscale-error
|
.PHONY: $(CODEC_TESTS) $(LAVF_TESTS) regtest-ref swscale-error
|
||||||
|
|
||||||
-include .vhookdep
|
-include $(VHOOK_DEPS)
|
||||||
|
19
common.mak
19
common.mak
@ -24,6 +24,15 @@ CFLAGS = -DHAVE_AV_CONFIG_H -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE \
|
|||||||
%.ho: %.h
|
%.ho: %.h
|
||||||
$(CC) $(CFLAGS) $(LIBOBJFLAGS) -Wno-unused -c -o $@ -x c $<
|
$(CC) $(CFLAGS) $(LIBOBJFLAGS) -Wno-unused -c -o $@ -x c $<
|
||||||
|
|
||||||
|
%.d: %.c
|
||||||
|
$(DEPEND_CMD) > $@
|
||||||
|
|
||||||
|
%.d: %.S
|
||||||
|
$(DEPEND_CMD) > $@
|
||||||
|
|
||||||
|
%.d: %.cpp
|
||||||
|
$(DEPEND_CMD) > $@
|
||||||
|
|
||||||
install: install-libs install-headers
|
install: install-libs install-headers
|
||||||
|
|
||||||
uninstall: uninstall-libs uninstall-headers
|
uninstall: uninstall-libs uninstall-headers
|
||||||
@ -51,7 +60,8 @@ TESTS := $(addprefix $(SUBDIR),$(TESTS))
|
|||||||
ALLHEADERS := $(subst $(SRC_DIR)/,$(SUBDIR),$(wildcard $(SRC_DIR)/*.h))
|
ALLHEADERS := $(subst $(SRC_DIR)/,$(SUBDIR),$(wildcard $(SRC_DIR)/*.h))
|
||||||
checkheaders: $(filter-out %_template.ho,$(ALLHEADERS:.h=.ho))
|
checkheaders: $(filter-out %_template.ho,$(ALLHEADERS:.h=.ho))
|
||||||
|
|
||||||
depend dep: $(SUBDIR).depend
|
DEPS := $(OBJS:.o=.d)
|
||||||
|
depend dep: $(DEPS)
|
||||||
|
|
||||||
CLEANFILES += *.o *~ *.a *.lib *.so *.so.* *.dylib *.dll \
|
CLEANFILES += *.o *~ *.a *.lib *.so *.so.* *.dylib *.dll \
|
||||||
*.def *.dll.a *.exp *.ho *.map
|
*.def *.dll.a *.exp *.ho *.map
|
||||||
@ -63,18 +73,15 @@ $(SUBDIR)%: $(SUBDIR)%.o $(LIBNAME)
|
|||||||
$(SUBDIR)%-test$(EXESUF): $(SUBDIR)%.c $(LIBNAME)
|
$(SUBDIR)%-test$(EXESUF): $(SUBDIR)%.c $(LIBNAME)
|
||||||
$(CC) $(CFLAGS) $(FFLDFLAGS) -DTEST -o $$@ $$^ $(FFEXTRALIBS)
|
$(CC) $(CFLAGS) $(FFLDFLAGS) -DTEST -o $$@ $$^ $(FFEXTRALIBS)
|
||||||
|
|
||||||
$(SUBDIR).depend: $(SRCS)
|
|
||||||
$(DEPEND_CMD) > $$@
|
|
||||||
|
|
||||||
clean::
|
clean::
|
||||||
rm -f $(TESTS) $(addprefix $(SUBDIR),$(CLEANFILES))
|
rm -f $(TESTS) $(addprefix $(SUBDIR),$(CLEANFILES))
|
||||||
|
|
||||||
distclean:: clean
|
distclean:: clean
|
||||||
rm -f $(SUBDIR).depend
|
rm -f $(DEPS)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
$(eval $(RULES))
|
$(eval $(RULES))
|
||||||
|
|
||||||
tests: $(TESTS)
|
tests: $(TESTS)
|
||||||
|
|
||||||
-include $(SUBDIR).depend
|
-include $(DEPS)
|
||||||
|
4
configure
vendored
4
configure
vendored
@ -940,8 +940,7 @@ SLIBNAME_WITH_MAJOR='$(SLIBNAME).$(LIBMAJOR)'
|
|||||||
LIB_INSTALL_EXTRA_CMD='$(RANLIB) "$(LIBDIR)/$(LIBNAME)"'
|
LIB_INSTALL_EXTRA_CMD='$(RANLIB) "$(LIBDIR)/$(LIBNAME)"'
|
||||||
|
|
||||||
# gcc stupidly only outputs the basename of targets with -MM
|
# gcc stupidly only outputs the basename of targets with -MM
|
||||||
DEPEND_CMD='$(CC) -MM $(CFLAGS) $(filter-out %.h,$$^) | sed "s,[0-9a-z._-]*: \($(SRC_DIR)/\)*\([a-z0-9]*/\)[^/]* ,\\2&,;s,^.*:,\$$$$(SUBDIR)&,"'
|
DEPEND_CMD='$(CC) $(CFLAGS) -MM -MG $< | sed "1s,^,$(@D)/,"'
|
||||||
VHOOK_DEPEND_CMD='$(CC) -MM $(VHOOKCFLAGS) $(filter-out %.h,$^) | sed "s,^\([a-z]\),vhook/\\1,"'
|
|
||||||
|
|
||||||
# find source path
|
# find source path
|
||||||
source_path="`dirname \"$0\"`"
|
source_path="`dirname \"$0\"`"
|
||||||
@ -1983,7 +1982,6 @@ echo "SLIBPREF=$SLIBPREF" >> config.mak
|
|||||||
echo "SLIBSUF=$SLIBSUF" >> config.mak
|
echo "SLIBSUF=$SLIBSUF" >> config.mak
|
||||||
echo "EXESUF=$EXESUF" >> config.mak
|
echo "EXESUF=$EXESUF" >> config.mak
|
||||||
echo "DEPEND_CMD=$DEPEND_CMD" >> config.mak
|
echo "DEPEND_CMD=$DEPEND_CMD" >> config.mak
|
||||||
echo "VHOOK_DEPEND_CMD=$VHOOK_DEPEND_CMD" >> config.mak
|
|
||||||
|
|
||||||
if enabled bigendian; then
|
if enabled bigendian; then
|
||||||
echo "WORDS_BIGENDIAN=yes" >> config.mak
|
echo "WORDS_BIGENDIAN=yes" >> config.mak
|
||||||
|
Loading…
x
Reference in New Issue
Block a user