]> git.sesse.net Git - vlc/blobdiff - Makefile
* Mandatory step for video output IV and the audio output quality
[vlc] / Makefile
index 75e1a2b50b357662e51e8abcccb67ad3a3995ac9..e725cfd42b38edede2f95be3476618518dbbf57d 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -2,7 +2,7 @@
 # vlc (VideoLAN Client) main Makefile - (c)1998 VideoLAN
 ###############################################################################
 
-include Makefile.opts
+-include Makefile.opts
 
 ###############################################################################
 # Objects and files
@@ -27,14 +27,8 @@ PLUGINS_TARGETS := alsa/alsa beos/beos darwin/darwin dsp/dsp dummy/dummy \
                idct/idct idct/idctclassic idct/idctmmx idct/idctmmxext \
                macosx/macosx mga/mga \
                motion/motion motion/motionmmx motion/motionmmxext \
-               mpeg/ps mpeg/ts null/null qt/qt sdl/sdl \
-               text/text x11/x11 x11/xvideo yuv/yuv yuv/yuvmmx
-
-#
-# Translate plugin names
-#
-PLUGINS_OBJ := $(shell for i in : $(PLUGINS) ; do echo " "$(PLUGINS_TARGETS)" " | sed 's@.*/\('$$i'\) .*@lib/\1.so@ ; s@^ .*@@' ; done)
-BUILTINS_OBJ := $(shell for i in : $(BUILTINS) ; do echo " "$(PLUGINS_TARGETS)" " | sed 's@.*/\('$$i'\) .*@lib/\1.a@ ; s@^ .*@@' ; done)
+               mpeg/es mpeg/ps mpeg/ts null/null qt/qt sdl/sdl \
+               text/ncurses text/rc x11/x11 x11/xvideo yuv/yuv yuv/yuvmmx
 
 #
 # C Objects
@@ -42,28 +36,26 @@ BUILTINS_OBJ := $(shell for i in : $(BUILTINS) ; do echo " "$(PLUGINS_TARGETS)"
 INTERFACE =    src/interface/main.o \
                src/interface/interface.o \
                src/interface/intf_msg.o \
-               src/interface/intf_cmd.o \
-               src/interface/intf_ctrl.o \
                src/interface/intf_playlist.o \
                src/interface/intf_channels.o \
-               src/interface/intf_console.o \
                src/interface/intf_urldecode.o \
 
-INPUT =                src/input/input_ext-dec.o \
+INPUT =                src/input/input.o \
+               src/input/input_ext-dec.o \
                src/input/input_ext-intf.o \
                src/input/input_dec.o \
                src/input/input_programs.o \
                src/input/input_netlist.o \
                src/input/input_clock.o \
-               src/input/input.o \
                src/input/mpeg_system.o
 
 AUDIO_OUTPUT =         src/audio_output/audio_output.o \
-               src/audio_output/aout_fifo.o \
+               src/audio_output/aout_ext-dec.o \
                src/audio_output/aout_u8.o \
                src/audio_output/aout_s8.o \
                src/audio_output/aout_u16.o \
-               src/audio_output/aout_s16.o
+               src/audio_output/aout_s16.o \
+        src/audio_output/aout_spdif.o
 
 VIDEO_OUTPUT =         src/video_output/video_output.o \
                src/video_output/video_text.o \
@@ -78,9 +70,14 @@ AC3_DECODER =        src/ac3_decoder/ac3_decoder_thread.o \
                src/ac3_decoder/ac3_mantissa.o \
                src/ac3_decoder/ac3_rematrix.o \
                src/ac3_decoder/ac3_imdct.o \
+               src/ac3_decoder/ac3_imdct_c.o \
+               src/ac3_decoder/ac3_srfft.o \
                src/ac3_decoder/ac3_downmix.o \
                src/ac3_decoder/ac3_downmix_c.o
 
+AC3_SPDIF = src/ac3_spdif/ac3_spdif.o \
+        src/ac3_spdif/ac3_iec958.o
+
 LPCM_DECODER = src/lpcm_decoder/lpcm_decoder_thread.o \
                src/lpcm_decoder/lpcm_decoder.o
 
@@ -104,7 +101,6 @@ VIDEO_DECODER =     src/video_decoder/video_decoder.o
 
 MISC =         src/misc/mtime.o \
                src/misc/tests.o \
-               src/misc/rsc_files.o \
                src/misc/modules.o \
                src/misc/netutils.o
 
@@ -113,6 +109,7 @@ C_OBJ =             $(INTERFACE) \
                $(VIDEO_OUTPUT) \
                $(AUDIO_OUTPUT) \
                $(AC3_DECODER) \
+        $(AC3_SPDIF) \
                $(LPCM_DECODER) \
                $(AUDIO_DECODER) \
                $(SPU_DECODER) \
@@ -144,10 +141,18 @@ H_OBJ =           include/modules_builtin.h
 #
 # Other lists of files
 #
-objects := $(C_OBJ)
-cdependancies := $(objects:%.o=.dep/%.d)
-cppobjects := $(CPP_OBJ)
-cppdependancies := $(cppobjects:%.o=.dep/%.dpp)
+C_DEP := $(C_OBJ:%.o=.dep/%.d)
+CPP_DEP := $(CPP_OBJ:%.o=.dep/%.dpp)
+
+#
+# Translate plugin names
+#
+ifneq (,$(PLUGINS))
+PLUGIN_OBJ := $(shell for i in $(PLUGINS) ; do echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.*/\('$$i'\) .*@lib/\1.so@' -e 's@^ .*@@' ; done)
+endif
+ifneq (,$(BUILTINS))
+BUILTIN_OBJ := $(shell for i in $(BUILTINS) ; do echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.*/\('$$i'\) .*@lib/\1.a@' -e 's@^ .*@@' ; done)
+endif
 
 # All symbols must be exported
 export
@@ -161,28 +166,20 @@ export
 #
 all: vlc ${ALIASES} plugins vlc.app
 
-Makefile.opts:
-       @echo
-       @echo "Sorry, you need to run ./configure before using this makefile."
-       @echo "To make clean or make distclean, use this:"
-       @echo
-       @echo "    touch Makefile.opts Makefile.modules && make distclean"
-       @echo
-       @exit 1
-
 clean:
-       for d in $(PLUGINS_DIR) ; do ( cd plugins/$${d} && $(MAKE) clean ) ; done
+       for dir in $(PLUGINS_DIR) ; do \
+               ( cd plugins/$${dir} && $(MAKE) clean ) ; done
        rm -f plugins/*/*.o plugins/*/*.moc plugins/*/*.bak
        rm -f $(C_OBJ) $(CPP_OBJ)
        rm -f src/*/*.o extras/*/*.o
        rm -f lib/*.so lib/*.a vlc gnome-vlc gvlc kvlc qvlc
-       rm -rf vlc.app
+       rm -Rf vlc.app
 
 distclean: clean
        rm -f **/*.o **/*~ *.log
-       rm -f Makefile.opts Makefile.modules
+       rm -f Makefile.opts
        rm -f include/defs.h include/config.h include/modules_builtin.h
-       rm -f config.status config.cache config.log
+       rm -f config*status config*cache config*log
        rm -f gmon.out core build-stamp
        rm -Rf .dep
        rm -f .gdb_history
@@ -190,10 +187,13 @@ distclean: clean
 install:
        mkdir -p $(DESTDIR)$(bindir)
        $(INSTALL) vlc $(DESTDIR)$(bindir)
-# ugly
-       for alias in "" ${ALIASES} ; do if test $$alias ; then rm -f $(DESTDIR)$(bindir)/$$alias && ln -s vlc $(DESTDIR)$(bindir)/$$alias ; fi ; done
+ifneq (,$(ALIASES))
+       for alias in $(ALIASES) ; do if test $$alias ; then rm -f $(DESTDIR)$(bindir)/$$alias && ln -s vlc $(DESTDIR)$(bindir)/$$alias ; fi ; done
+endif
        mkdir -p $(DESTDIR)$(libdir)/videolan/vlc
+ifneq (,$(PLUGINS))
        $(INSTALL) -m 644 $(PLUGINS:%=lib/%.so) $(DESTDIR)$(libdir)/videolan/vlc
+endif
        mkdir -p $(DESTDIR)$(datadir)/videolan
        $(INSTALL) -m 644 share/*.psf $(DESTDIR)$(datadir)/videolan
        $(INSTALL) -m 644 share/*.png $(DESTDIR)$(datadir)/videolan
@@ -208,12 +208,12 @@ show:
        @echo CPP_OBJ: $(CPP_OBJ)
        @echo objects: $(objects)
        @echo cppobjects: $(cppobjects)
-       @echo PLUGINS_OBJ: $(PLUGINS_OBJ)
-       @echo BUILTINS_OBJ: $(BUILTINS_OBJ)
+       @echo PLUGIN_OBJ: $(PLUGIN_OBJ)
+       @echo BUILTIN_OBJ: $(BUILTIN_OBJ)
 
 
 # ugliest of all, but I have no time to do it -- sam
-snapshot:
+snapshot: Makefile.opts
        rm -Rf /tmp/vlc-${PROGRAM_VERSION}* /tmp/vlc-${PROGRAM_VERSION}nocss*
        # copy archive in /tmp
        find -type d | grep -v CVS | grep -v '\.dep' | while read i ; \
@@ -221,10 +221,12 @@ snapshot:
        done
        find debian -mindepth 1 -maxdepth 1 -type d | \
                while read i ; do rm -Rf /tmp/vlc-${PROGRAM_VERSION}/$$i ; done
-       # .c .h .in .cpp
-       find include src plugins -type f -name '*.[chi]*' | while read i ; \
-               do cp $$i /tmp/vlc-${PROGRAM_VERSION}/$$i ; \
-       done
+       # .c .h .in .cpp .glade
+       find include src plugins -type f -name '*.[chig]*' | while read i ; \
+               do cp $$i /tmp/vlc-${PROGRAM_VERSION}/$$i ; done
+       # Makefiles
+       find . plugins -type f -name Makefile | while read i ; \
+               do cp $$i /tmp/vlc-${PROGRAM_VERSION}/$$i ; done
        # extra files
        cp -a extras/* /tmp/vlc-${PROGRAM_VERSION}/extras
        cp -a doc/* /tmp/vlc-${PROGRAM_VERSION}/doc
@@ -235,15 +237,15 @@ snapshot:
                done
        # copy misc files
        cp vlc.spec AUTHORS COPYING ChangeLog INSTALL README TODO todo.pl \
-               Makefile Makefile.opts.in Makefile.dep Makefile.modules \
+               Makefile.opts.in Makefile.dep Makefile.modules \
                configure configure.in install-sh config.sub config.guess \
                        /tmp/vlc-${PROGRAM_VERSION}/
        for file in control control-css vlc-gtk.menu vlc.copyright vlc.docs \
-               changelog changelog-css rules rules-css vlc.dirs \
-               vlc.menu ; do \
+               changelog changelog-css rules rules-css vlc.dirs vlc.desktop \
+               gvlc.desktop gnome-vlc.desktop vlc.menu ; do \
                        cp debian/$$file /tmp/vlc-${PROGRAM_VERSION}/debian/ ; \
                done
-       for file in default8x16.psf default8x9.psf vlc_beos.rsrc ; do \
+       for file in default8x16.psf default8x9.psf vlc_beos.rsrc vlc.icns ; do \
                cp share/$$file /tmp/vlc-${PROGRAM_VERSION}/share/ ; done
        for icon in vlc gvlc qvlc gnome-vlc kvlc ; do \
                cp share/$$icon.xpm share/$$icon.png \
@@ -263,7 +265,7 @@ snapshot:
 .PHONY: vlc.app
 vlc.app:
 ifneq (,$(findstring darwin,$(SYS)))
-       rm -rf vlc.app
+       rm -Rf vlc.app
        mkdir -p vlc.app/Contents/Resources
        mkdir -p vlc.app/Contents/MacOS/lib
        mkdir -p vlc.app/Contents/MacOS/share
@@ -271,7 +273,9 @@ ifneq (,$(findstring darwin,$(SYS)))
        $(INSTALL) -m 644 extras/MacOSX_app/Contents/PkgInfo vlc.app/Contents/
        $(INSTALL) vlc vlc.app/Contents/MacOS/
        $(INSTALL) share/vlc.icns vlc.app/Contents/Resources/
+ifneq (,$(PLUGINS))
        $(INSTALL) $(PLUGINS:%=lib/%.so) vlc.app/Contents/MacOS/lib
+endif
        $(INSTALL) -m 644 share/*.psf vlc.app/Contents/MacOS/share
 endif
 
@@ -287,27 +291,32 @@ gnome-vlc gvlc kvlc qvlc: vlc
 #
 # Generic rules (see below)
 #
-$(cdependancies): %.d: FORCE
+$(C_DEP): %.d: FORCE
        @$(MAKE) -s --no-print-directory -f Makefile.dep $@
 
-$(cppdependancies): %.dpp: FORCE
+$(CPP_DEP): %.dpp: FORCE
        @$(MAKE) -s --no-print-directory -f Makefile.dep $@
 
-$(H_OBJ): Makefile.opts Makefile
+$(H_OBJ): Makefile.opts Makefile.dep Makefile
        rm -f $@ && cp $@.in $@
+ifneq (,$(BUILTINS))
        for i in $(BUILTINS) ; do \
-       echo "int module_"$$i"_InitModule (module_t *);" >> $@ ; \
-       echo "int module_"$$i"_ActivateModule (module_t *);" >> $@ ; \
-       echo "int module_"$$i"_DeactivateModule (module_t *);" >> $@ ; \
+               echo "int module_"$$i"_InitModule( module_t* );" >> $@ ; \
+               echo "int module_"$$i"_ActivateModule( module_t* );" >> $@ ; \
+               echo "int module_"$$i"_DeactivateModule( module_t* );" >> $@ ; \
        done
-       echo "#define ALLOCATE_ALL_BUILTINS() \\" >> $@ ;
-       echo "{ \\" >> $@ ;
+endif
+       echo "" >> $@ ;
+       printf "#define ALLOCATE_ALL_BUILTINS() do { " >> $@ ;
+ifneq (,$(BUILTINS))
        for i in $(BUILTINS) ; do \
-       echo "    ALLOCATE_BUILTIN("$$i"); \\" >> $@ ; \
+               printf "ALLOCATE_BUILTIN("$$i"); " >> $@ ; \
        done
-       echo "};" >> $@ ;
+endif
+       echo "} while( 0 );" >> $@ ;
+       echo "" >> $@ ;
 
-$(C_OBJ): %.o: Makefile.dep
+$(C_OBJ): %.o: Makefile.opts Makefile.dep Makefile
 $(C_OBJ): %.o: .dep/%.d
 $(C_OBJ): %.o: %.c
 ifneq (,$(findstring darwin,$(SYS)))
@@ -317,7 +326,7 @@ else
        $(CC) $(CFLAGS) -c -o $@ $<
 endif
 
-$(CPP_OBJ): %.o: Makefile.dep
+$(CPP_OBJ): %.o: Makefile.opts Makefile.dep Makefile
 $(CPP_OBJ): %.o: .dep/%.dpp
 $(CPP_OBJ): %.o: %.cpp
        $(CC) $(CFLAGS) -c -o $@ $<
@@ -325,8 +334,8 @@ $(CPP_OBJ): %.o: %.cpp
 #
 # Main application target
 #
-vlc: $(H_OBJ) $(C_OBJ) $(CPP_OBJ) $(BUILTINS_OBJ)
-       $(CC) $(CFLAGS) -o $@ $(C_OBJ) $(CPP_OBJ) $(BUILTINS_OBJ) $(LCFLAGS)
+vlc: Makefile.opts Makefile.dep Makefile $(H_OBJ) $(C_OBJ) $(CPP_OBJ) $(BUILTIN_OBJ)
+       $(CC) $(CFLAGS) -o $@ $(C_OBJ) $(CPP_OBJ) $(BUILTIN_OBJ) $(LCFLAGS)
 ifeq ($(SYS),beos)
        rm -f ./lib/_APP_
        ln -s ../vlc ./lib/_APP_
@@ -337,14 +346,14 @@ endif
 #
 # Plugins target
 #
-plugins: $(PLUGINS_OBJ)
-$(PLUGINS_OBJ): FORCE
-       cd $(shell echo " "$(PLUGINS_TARGETS)" " | sed 's@.* \([^/]*/\)'$(@:lib/%.so=%)' .*@plugins/\1@ ; s@^ .*@@') && $(MAKE) $(@:%=../../%)
+plugins: Makefile.modules Makefile.opts Makefile.dep Makefile $(PLUGIN_OBJ)
+$(PLUGIN_OBJ): FORCE
+       cd $(shell echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.* \([^/]*/\)'$(@:lib/%.so=%)' .*@plugins/\1@' -e 's@^ .*@@') && $(MAKE) $(@:%=../../%)
 
 #
 # Built-in modules target
 #
-builtins: $(BUILTINS_OBJ)
-$(BUILTINS_OBJ): FORCE
-       cd $(shell echo " "$(PLUGINS_TARGETS)" " | sed 's@.* \([^/]*/\)'$(@:lib/%.a=%)' .*@plugins/\1@ ; s@^ .*@@') && $(MAKE) $(@:%=../../%)
+builtins: Makefile.modules Makefile.opts Makefile.dep Makefile $(BUILTIN_OBJ)
+$(BUILTIN_OBJ): FORCE
+       cd $(shell echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.* \([^/]*/\)'$(@:lib/%.a=%)' .*@plugins/\1@' -e 's@^ .*@@') && $(MAKE) $(@:%=../../%)