]> git.sesse.net Git - vlc/blobdiff - Makefile
* Added a make uninstall rule.
[vlc] / Makefile
index 7edce4369cd8d79fa683198ffff15ff263237632..398a67fbbea83cf70701a5a775ade3b44eddc355 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,8 +1,5 @@
 ###############################################################################
-# vlc (VideoLAN Client) main makefile
-# (c)1998 VideoLAN
-###############################################################################
-# This makefile is the main makefile for the VideoLAN client.
+# vlc (VideoLAN Client) main Makefile - (c)1998 VideoLAN
 ###############################################################################
 
 include Makefile.opts
@@ -14,115 +11,39 @@ include Makefile.opts
 # 
 # All possible plugin directories, needed for make clean
 #
-PLUGINS_DIR := alsa beos darwin dsp dummy \
-               dvd esd fb ggi glide gnome gtk \
-               idct \
-               macosx mga \
-               motion \
-               mpeg null qt sdl \
-               text x11 yuv
+PLUGINS_DIR := alsa beos darwin directx dsp dummy dvd esd fb ggi glide gtk downmix idct imdct kde macosx mga motion mpeg qt sdl text x11 yuv
 
 #
 # All possible plugin objects
 #
-PLUGINS_TARGETS := alsa/alsa beos/beos darwin/darwin dsp/dsp dummy/dummy \
-               dvd/dvd esd/esd fb/fb ggi/ggi glide/glide gnome/gnome gtk/gtk \
-               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)
+PLUGINS_TARGETS := alsa/alsa beos/beos darwin/darwin directx/directx dsp/dsp dummy/dummy dummy/null dvd/dvd esd/esd fb/fb ggi/ggi glide/glide gtk/gnome gtk/gtk downmix/downmix downmix/downmixsse downmix/downmix3dn idct/idct idct/idctclassic idct/idctmmx idct/idctmmxext imdct/imdct imdct/imdct3dn imdct/imdctsse kde/kde macosx/macosx mga/mga motion/motion motion/motionmmx motion/motionmmxext mpeg/es mpeg/ps mpeg/ts qt/qt sdl/sdl text/ncurses text/rc x11/x11 x11/xvideo yuv/yuv yuv/yuvmmx
 
 #
 # C Objects
 # 
-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 \
-               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_u8.o \
-               src/audio_output/aout_s8.o \
-               src/audio_output/aout_u16.o \
-               src/audio_output/aout_s16.o
-
-VIDEO_OUTPUT =         src/video_output/video_output.o \
-               src/video_output/video_text.o \
-               src/video_output/video_spu.o \
-               src/video_output/video_yuv.o
-
-AC3_DECODER =  src/ac3_decoder/ac3_decoder_thread.o \
-               src/ac3_decoder/ac3_decoder.o \
-               src/ac3_decoder/ac3_parse.o \
-               src/ac3_decoder/ac3_exponent.o \
-               src/ac3_decoder/ac3_bit_allocate.o \
-               src/ac3_decoder/ac3_mantissa.o \
-               src/ac3_decoder/ac3_rematrix.o \
-               src/ac3_decoder/ac3_imdct.o \
-               src/ac3_decoder/ac3_downmix.o \
-               src/ac3_decoder/ac3_downmix_c.o
-
-LPCM_DECODER = src/lpcm_decoder/lpcm_decoder_thread.o \
-               src/lpcm_decoder/lpcm_decoder.o
-
-AUDIO_DECODER =        src/audio_decoder/audio_decoder.o \
-               src/audio_decoder/adec_generic.o \
-               src/audio_decoder/adec_layer1.o \
-               src/audio_decoder/adec_layer2.o \
-               src/audio_decoder/adec_math.o
-
-SPU_DECODER =  src/spu_decoder/spu_decoder.o
-
-#GEN_DECODER = src/generic_decoder/generic_decoder.o
-
-VIDEO_PARSER =         src/video_parser/video_parser.o \
-               src/video_parser/vpar_headers.o \
-               src/video_parser/vpar_blocks.o \
-               src/video_parser/vpar_synchro.o \
-               src/video_parser/video_fifo.o
-
-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
-
-C_OBJ =                $(INTERFACE) \
-               $(INPUT) \
-               $(VIDEO_OUTPUT) \
-               $(AUDIO_OUTPUT) \
-               $(AC3_DECODER) \
-               $(LPCM_DECODER) \
-               $(AUDIO_DECODER) \
-               $(SPU_DECODER) \
-               $(GEN_DECODER) \
-               $(VIDEO_PARSER) \
-               $(VIDEO_DECODER) \
-               $(MISC)
+INTERFACE := main interface intf_msg intf_playlist intf_channels
+INPUT := input input_ext-dec input_ext-intf input_dec input_programs input_netlist input_clock mpeg_system
+VIDEO_OUTPUT := video_output video_text video_spu video_yuv
+AUDIO_OUTPUT := audio_output aout_ext-dec aout_u8 aout_s8 aout_u16 aout_s16 aout_spdif
+AC3_DECODER := ac3_decoder_thread ac3_decoder ac3_parse ac3_exponent ac3_bit_allocate ac3_mantissa ac3_rematrix ac3_imdct
+AC3_SPDIF := ac3_spdif ac3_iec958
+LPCM_DECODER := lpcm_decoder_thread
+AUDIO_DECODER := audio_decoder adec_generic adec_layer1 adec_layer2 adec_math
+SPU_DECODER := spu_decoder
+VIDEO_DECODER := video_parser vpar_headers vpar_blocks vpar_synchro vpar_pool video_decoder
+MISC := mtime tests modules netutils
+
+C_OBJ :=       $(INTERFACE:%=src/interface/%.o) \
+               $(INPUT:%=src/input/%.o) \
+               $(VIDEO_OUTPUT:%=src/video_output/%.o) \
+               $(AUDIO_OUTPUT:%=src/audio_output/%.o) \
+               $(AC3_DECODER:%=src/ac3_decoder/%.o) \
+               $(AC3_SPDIF:%=src/ac3_spdif/%.o) \
+               $(LPCM_DECODER:%=src/lpcm_decoder/%.o) \
+               $(AUDIO_DECODER:%=src/audio_decoder/%.o) \
+               $(SPU_DECODER:%=src/spu_decoder/%.o) \
+               $(VIDEO_DECODER:%=src/video_decoder/%.o) \
+               $(MISC:%=src/misc/%.o)
 
 #
 # Misc Objects
@@ -132,25 +53,37 @@ C_OBJ += extras/GNUgetopt/getopt.o extras/GNUgetopt/getopt1.o
 endif
 
 ifeq ($(SYS),beos)
-CPP_OBJ      src/misc/beos_specific.o
+CPP_OBJ :=     src/misc/beos_specific.o
 endif
 
 ifneq (,$(findstring darwin,$(SYS)))
 C_OBJ +=       src/misc/darwin_specific.o
 endif
 
+ifneq (,$(findstring mingw32,$(SYS)))
+RESOURCE_OBJ :=        share/vlc_win32_rc.o
+endif
+
 #
 # Generated header
 #
-H_OBJ =                include/modules_builtin.h
+H_OBJ :=       src/misc/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'\) .*@plugins/\1.so@' -e 's@^ .*@@' ; done)
+endif
+ifneq (,$(BUILTINS))
+BUILTIN_OBJ := $(shell for i in $(BUILTINS) ; do echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.*/\('$$i'\) .*@plugins/\1.a@' -e 's@^ .*@@' ; done)
+endif
 
 # All symbols must be exported
 export
@@ -164,34 +97,75 @@ export
 #
 all: vlc ${ALIASES} plugins vlc.app
 
-clean:
-       for d in $(PLUGINS_DIR) ; do ( cd plugins/$${d} && make clean ) ; done
-       rm -f $(C_OBJ) $(CPP_OBJ)
+clean: libdvdcss-clean plugins-clean vlc-clean
        rm -f src/*/*.o extras/*/*.o
-       rm -f lib/*.so lib/*.a vlc gnome-vlc gvlc kvlc qvlc
-       rm -rf vlc.app
+       rm -f lib/*.so lib/*.so.* lib/*.a
+       rm -f plugins/*.so plugins/*.so.* plugins/*.a
+
+libdvdcss-clean:
+       cd extras/libdvdcss && $(MAKE) clean
+
+plugins-clean:
+       for dir in $(PLUGINS_DIR) ; do \
+               ( cd plugins/$${dir} && $(MAKE) clean ) ; done
+       rm -f plugins/*/*.o plugins/*/*.moc plugins/*/*.bak
+
+vlc-clean:
+       rm -f $(C_OBJ) $(CPP_OBJ)
+       rm -f vlc gnome-vlc gvlc kvlc qvlc vlc.exe
+       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 src/misc/modules_builtin.h
+       rm -f config*status config*cache config*log
        rm -f gmon.out core build-stamp
        rm -Rf .dep
        rm -f .gdb_history
 
-install:
+install: libdvdcss-install vlc-install plugins-install
+
+uninstall: libdvdcss-uninstall vlc-uninstall plugins-uninstall
+
+vlc-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
-       mkdir -p $(DESTDIR)$(libdir)/videolan/vlc
-       $(INSTALL) -m 644 $(PLUGINS:%=lib/%.so) $(DESTDIR)$(libdir)/videolan/vlc
+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)$(datadir)/videolan
        $(INSTALL) -m 644 share/*.psf $(DESTDIR)$(datadir)/videolan
        $(INSTALL) -m 644 share/*.png $(DESTDIR)$(datadir)/videolan
        $(INSTALL) -m 644 share/*.xpm $(DESTDIR)$(datadir)/videolan
 
+vlc-uninstall:
+       rm vlc $(DESTDIR)$(bindir)/vlc
+ifneq (,$(ALIASES))
+       for alias in $(ALIASES) ; do if test $$alias ; then rm -f $(DESTDIR)$(bindir)/$$alias ; fi ; done
+endif
+       rm -f $(DESTDIR)$(datadir)/videolan/*.psf
+       rm -f $(DESTDIR)$(datadir)/videolan/*.png
+       rm -f $(DESTDIR)$(datadir)/videolan/*.xpm
+
+plugins-install:
+       mkdir -p $(DESTDIR)$(libdir)/videolan/vlc
+ifneq (,$(PLUGINS))
+       $(INSTALL) -m 644 $(PLUGINS:%=plugins/%.so) $(DESTDIR)$(libdir)/videolan/vlc
+endif
+
+plugins-uninstall:
+ifneq (,$(PLUGINS))
+       rm -f $(DESTDIR)$(libdir)/videolan/vlc/*.so
+endif
+
+libdvdcss-install:
+       cd extras/libdvdcss && $(MAKE) install
+
+libdvdcss-uninstall:
+       cd extras/libdvdcss && $(MAKE) uninstall
+
 show:
        @echo CC: $(CC)
        @echo CFLAGS: $(CFLAGS)
@@ -201,11 +175,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: clean 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 ; \
@@ -213,10 +188,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
@@ -226,17 +203,20 @@ snapshot:
                        do rm -Rf $$i ; \
                done
        # copy misc files
-       cp vlc.spec AUTHORS COPYING ChangeLog INSTALL README TODO todo.pl \
-               Makefile Makefile.opts.in Makefile.dep Makefile.modules \
+       cp vlc.spec AUTHORS COPYING ChangeLog INSTALL INSTALL.libdvdcss \
+               INSTALL-win32.txt README TODO todo.pl \
+               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 \
-               cp share/$$file /tmp/vlc-${PROGRAM_VERSION}/share/ ; done
+       for file in default8x16.psf default8x9.psf vlc_beos.rsrc vlc.icns \
+               gvlc_win32.ico vlc_win32_rc.rc ; 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 \
                        /tmp/vlc-${PROGRAM_VERSION}/share/ ; done
@@ -252,10 +232,56 @@ snapshot:
        # clean up
        rm -Rf /tmp/vlc-${PROGRAM_VERSION}*
 
+libdvdcss-snapshot: clean Makefile.opts
+       rm -Rf /tmp/libdvdcss-${LIBDVDCSS_VERSION}* \
+               /tmp/libdvdcss-${LIBDVDCSS_VERSION}nocss*
+       # copy archive in /tmp
+       find include extras doc lib -type d | grep -v CVS | grep -v '\.dep' | \
+               while read i ; do \
+                       mkdir -p /tmp/libdvdcss-${LIBDVDCSS_VERSION}/$$i ; \
+               done
+       # .c .h .in .cpp .glade
+       find include extras -type f -name '*.[chig]*' | while read i ; \
+               do cp $$i /tmp/libdvdcss-${LIBDVDCSS_VERSION}/$$i ; done
+       # Makefiles
+       sed -e 's#^install:#install-unused:#' \
+               -e 's#^uninstall:#uninstall-unused:#' \
+               -e 's#^clean:#clean-unused:#' \
+               -e 's#^all:.*#all: libdvdcss#' \
+               -e 's#^libdvdcss-install:#install:#' \
+               -e 's#^libdvdcss-uninstall:#uninstall:#' \
+               -e 's#^libdvdcss-clean:#clean:#' \
+               < Makefile > /tmp/libdvdcss-${LIBDVDCSS_VERSION}/Makefile
+       # extra files
+       cp -a extras/* /tmp/libdvdcss-${LIBDVDCSS_VERSION}/extras
+       cp -a doc/* /tmp/libdvdcss-${LIBDVDCSS_VERSION}/doc
+       find /tmp/libdvdcss-${LIBDVDCSS_VERSION}/extras \
+               /tmp/libdvdcss-${LIBDVDCSS_VERSION}/doc \
+               -type d -name CVS | while read i ; \
+                       do rm -Rf $$i ; \
+               done
+       # copy misc files
+       cp AUTHORS COPYING ChangeLog INSTALL INSTALL.libdvdcss README \
+               TODO todo.pl Makefile.opts.in Makefile.dep Makefile.modules \
+               configure configure.in install-sh config.sub config.guess \
+                       /tmp/libdvdcss-${LIBDVDCSS_VERSION}/
+
+       # build css-enabled archives
+       (cd /tmp ; tar cf libdvdcss-${LIBDVDCSS_VERSION}.tar \
+               libdvdcss-${LIBDVDCSS_VERSION} ; \
+               bzip2 -f -9 < libdvdcss-${LIBDVDCSS_VERSION}.tar \
+                       > libdvdcss-${LIBDVDCSS_VERSION}.tar.bz2 ; \
+               gzip -f -9 libdvdcss-${LIBDVDCSS_VERSION}.tar )
+       mv /tmp/libdvdcss-${LIBDVDCSS_VERSION}.tar.gz \
+               /tmp/libdvdcss-${LIBDVDCSS_VERSION}.tar.bz2 ..
+
+       # clean up
+       rm -Rf /tmp/libdvdcss-${LIBDVDCSS_VERSION}*
+
 .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
@@ -263,7 +289,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/
-       $(INSTALL) $(PLUGINS:%=lib/%.so) vlc.app/Contents/MacOS/lib
+ifneq (,$(PLUGINS))
+       $(INSTALL) $(PLUGINS:%=plugins/%.so) vlc.app/Contents/MacOS/plugins
+endif
        $(INSTALL) -m 644 share/*.psf vlc.app/Contents/MacOS/share
 endif
 
@@ -279,49 +307,53 @@ 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
+ifneq (,$(BUILTINS))
+       echo "" >> $@ ;
+       printf "#define ALLOCATE_ALL_BUILTINS() do { " >> $@ ;
        for i in $(BUILTINS) ; do \
-       echo "    ALLOCATE_BUILTIN("$$i"); \\" >> $@ ; \
+               printf "ALLOCATE_BUILTIN("$$i"); " >> $@ ; \
        done
-       echo "};" >> $@ ;
+       echo "} while( 0 );" >> $@ ;
+endif
+       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)))
-#this is uglier of all
-       @if test "src/ac3_decoder/ac3_imdct.c" = "$<"; then $(CC) `echo $(CFLAGS) | sed -e 's/-O3/-O/'` -c -o $@ $<; echo "(CC) `echo $(CFLAGS) | sed -e 's/-O3/-O/'` -c -o $@ $<"; else $(CC) $(CFLAGS) -c -o $@ $<; echo "$(CC) $(CFLAGS) -c -o $@ $<"; fi
-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 $@ $<
 
+$(RESOURCE_OBJ): %.o: Makefile.dep Makefile
+ifneq (,(findstring mingw32,$(SYS)))
+$(RESOURCE_OBJ): %.o: %.rc
+       $(WINDRES) -i $< -o $@
+endif
+
 #
 # 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) $(RESOURCE_OBJ)
+       $(CC) $(CFLAGS) -o $@ $(C_OBJ) $(CPP_OBJ) $(BUILTIN_OBJ) $(RESOURCE_OBJ) $(LCFLAGS)
 ifeq ($(SYS),beos)
-       rm -f ./lib/_APP_
-       ln -s ../vlc ./lib/_APP_
        xres -o $@ ./share/vlc_beos.rsrc
        mimeset -f $@
 endif
@@ -329,14 +361,20 @@ 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@.* \([^/]*/\)'$(@:plugins/%.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@.* \([^/]*/\)'$(@:plugins/%.a=%)' .*@plugins/\1@' -e 's@^ .*@@') && $(MAKE) $(@:%=../../%)
+
+#
+# libdvdcss target
+#
+libdvdcss:
+       cd extras/libdvdcss && $(MAKE)