]> git.sesse.net Git - vlc/blobdiff - Makefile
* ./plugins/win32/win32.cpp: fixed `--intf intfwin' which wasn't working.
[vlc] / Makefile
index 12808f036fe24b503a5174e000f1ac77dc9ba5e3..95d42e3b82cb0abc88c810cfb7f33244e6ea4304 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -13,13 +13,17 @@ endif
 # 
 # All possible plugin directories, needed for make clean
 #
-PLUGINS_DIR := ac3_adec \
+PLUGINS_DIR := a52 \
+               aa \
+               ac3_adec \
                ac3_spdif \
+               access \
                alsa \
                arts \
                beos \
                chroma \
                directx \
+               downmix \
                dsp \
                dummy \
                dvd \
@@ -27,13 +31,14 @@ PLUGINS_DIR :=      ac3_adec \
                esd \
                fb \
                filter \
+               fx \
                ggi \
                glide \
                gtk \
-               downmix \
                idct \
                imdct \
                kde \
+               lirc \
                lpcm_adec \
                macosx \
                mad \
@@ -43,20 +48,40 @@ PLUGINS_DIR :=      ac3_adec \
                mpeg_system \
                mpeg_adec \
                mpeg_vdec \
+               network \
+               ogg \
+               qnx \
                qt \
+               satellite \
                sdl \
                spudec \
                text \
                vcd \
+               win32 \
                x11
 
-PLUGINS_TARGETS := ac3_adec/ac3_adec \
+PLUGINS_TARGETS := a52/a52 \
+               aa/aa \
+               ac3_adec/ac3_adec \
                ac3_spdif/ac3_spdif \
+               access/file \
+               access/udp \
+               access/http \
                alsa/alsa \
                arts/arts \
                beos/beos \
-               chroma/chroma_yv12_rgb8 \
+               chroma/chroma_i420_rgb \
+               chroma/chroma_i420_rgb_mmx \
+               chroma/chroma_i420_yuy2 \
+               chroma/chroma_i420_yuy2_mmx \
+               chroma/chroma_i422_yuy2 \
+               chroma/chroma_i422_yuy2_mmx \
+               chroma/chroma_i420_ymga \
+               chroma/chroma_i420_ymga_mmx \
                directx/directx \
+               downmix/downmix \
+               downmix/downmixsse \
+               downmix/downmix3dn \
                dsp/dsp \
                dummy/dummy \
                dummy/null \
@@ -64,18 +89,16 @@ PLUGINS_TARGETS := ac3_adec/ac3_adec \
                dvdread/dvdread \
                esd/esd \
                fb/fb \
-               filter/filter_bob \
+               filter/filter_deinterlace \
                filter/filter_transform \
                filter/filter_invert \
                filter/filter_distort \
                filter/filter_wall \
+               fx/fx_scope \
                ggi/ggi \
                glide/glide \
                gtk/gnome \
                gtk/gtk \
-               downmix/downmix \
-               downmix/downmixsse \
-               downmix/downmix3dn \
                idct/idct \
                idct/idctclassic \
                idct/idctmmx \
@@ -85,6 +108,7 @@ PLUGINS_TARGETS := ac3_adec/ac3_adec \
                imdct/imdct3dn \
                imdct/imdctsse \
                kde/kde \
+               lirc/lirc \
                lpcm_adec/lpcm_adec \
                macosx/macosx \
                mad/mad \
@@ -92,7 +116,9 @@ PLUGINS_TARGETS := ac3_adec/ac3_adec \
                memcpy/memcpymmx \
                memcpy/memcpymmxext \
                memcpy/memcpy3dn \
+               memcpy/memcpyaltivec \
                mga/mga \
+               mga/xmga \
                motion/motion \
                motion/motionmmx \
                motion/motionmmxext \
@@ -103,25 +129,31 @@ PLUGINS_TARGETS := ac3_adec/ac3_adec \
                mpeg_system/mpeg_ts \
                mpeg_adec/mpeg_adec \
                mpeg_vdec/mpeg_vdec \
+               network/ipv4 \
+               network/ipv6 \
+               ogg/vorbis \
+               qnx/qnx \
                qt/qt \
+               satellite/satellite \
                sdl/sdl \
                spudec/spudec \
+               text/logger \
                text/ncurses \
                text/rc \
                vcd/vcd \
+               win32/waveout \
+               win32/intfwin \
                x11/x11 \
-               x11/xvideo \
-               yuv/yuv \
-               yuv/yuvmmx
+               x11/xvideo
 
 #
 # C Objects
 # 
-INTERFACE := main interface intf_msg intf_playlist
-INPUT := input input_ext-dec input_ext-intf input_dec input_programs input_clock mpeg_system
+INTERFACE := main interface intf_msg intf_playlist intf_eject
+INPUT := input input_ext-plugins input_ext-dec input_ext-intf input_dec input_programs input_clock mpeg_system
 VIDEO_OUTPUT := video_output video_text vout_pictures vout_subpictures
-AUDIO_OUTPUT := audio_output aout_ext-dec aout_u8 aout_s8 aout_u16 aout_s16 aout_spdif
-MISC := mtime tests modules netutils iso_lang
+AUDIO_OUTPUT := audio_output aout_ext-dec aout_pcm aout_spdif
+MISC := mtime modules configuration netutils iso_lang
 
 C_OBJ :=       $(INTERFACE:%=src/interface/%.o) \
                $(INPUT:%=src/input/%.o) \
@@ -136,6 +168,10 @@ ifeq ($(NEED_GETOPT),1)
 C_OBJ += extras/GNUgetopt/getopt.o extras/GNUgetopt/getopt1.o 
 endif
 
+ifeq ($(NEED_SYMBOLS),1)
+C_OBJ += src/misc/symbols.o
+endif
+
 ifeq ($(SYS),beos)
 CPP_OBJ :=     src/misc/beos_specific.o
 endif
@@ -175,9 +211,7 @@ endif
 #
 # Misc variables
 #
-VLC_QUICKVERSION := $(shell grep '^ *VLC_VERSION=' configure.in | head -1 | sed 's/"//g' | cut -f2 -d=)
-LIBDVDCSS_QUICKVERSION := $(shell grep '^ *LIBDVDCSS_VERSION=' configure.in | head -1 | sed 's/"//g' | cut -f2 -d=)
-
+VERSION := $(shell grep '^ *VERSION=' configure.in | head -1 | sed 's/"//g' | cut -f2 -d=)
 
 # All symbols must be exported
 export
@@ -192,18 +226,20 @@ export
 all: Makefile.opts vlc ${ALIASES} vlc.app plugins po
 
 Makefile.opts:
-       @echo "**** No configuration found, running ./configure..."
-       ./configure
-       $(MAKE) $(MAKECMDGOALS)
-       exit
+       @echo "**** No configuration found, please run ./configure"
+       @exit 1
+#      ./configure
+#      $(MAKE) $(MAKECMDGOALS)
+#      exit    
 
 show:
        @echo CC: $(CC)
        @echo CFLAGS: $(CFLAGS)
-       @echo DCFLAGS: $(DCFLAGS)
-       @echo LCFLAGS: $(LCFLAGS)
-       @echo PCFLAGS: $(PCFLAGS)
-       @echo PLCFLAGS: $(PLCFLAGS)
+       @echo LDFLAGS: $(LDFLAGS)
+       @echo plugins_CFLAGS: $(plugins_CFLAGS)
+       @echo plugins_LDFLAGS: $(plugins_LDFLAGS)
+       @echo builtins_CFLAGS: $(builtins_CFLAGS)
+       @echo builtins_LDFLAGS: $(builtins_LDFLAGS)
        @echo C_OBJ: $(C_OBJ)
        @echo CPP_OBJ: $(CPP_OBJ)
        @echo PLUGIN_OBJ: $(PLUGIN_OBJ)
@@ -212,25 +248,20 @@ show:
 #
 # Cleaning rules
 #
-clean: libdvdcss-clean libdvdread-clean plugins-clean po-clean vlc-clean
+clean: plugins-clean po-clean vlc-clean
        rm -f src/*/*.o extras/*/*.o
        rm -f lib/*.so* lib/*.a
-       rm -f plugins/*.so plugins/*.a
+       rm -f plugins/*.so plugins/*.a plugins/*.lib plugins/*.tds
        rm -rf extras/MacOSX/build
 
-libdvdcss-clean:
-       -cd extras/libdvdcss && $(MAKE) clean
-
 po-clean:
        -cd po && $(MAKE) clean
 
-libdvdread-clean:
-       -cd extras/libdvdread && $(MAKE) clean
-
 plugins-clean:
        for dir in $(PLUGINS_DIR) ; do \
-               ( cd plugins/$${dir} && $(MAKE) clean ) ; done
-       rm -f plugins/*/*.o plugins/*/*.moc plugins/*/*.bak
+               ( cd plugins/$${dir} \
+                       && $(MAKE) -f ../../Makefile.modules clean ) ; done
+       rm -f plugins/*/*.o plugins/*/*.lo plugins/*/*.moc plugins/*/*.bak
 
 vlc-clean:
        rm -f $(C_OBJ) $(CPP_OBJ)
@@ -241,7 +272,7 @@ distclean: clean
        -cd po && $(MAKE) maintainer-clean
        rm -f **/*.o **/*~ *.log
        rm -f Makefile.opts
-       rm -f include/defs.h include/config.h include/modules_builtin.h
+       rm -f include/defs.h include/modules_builtin.h
        rm -f src/misc/modules_builtin.h
        rm -f config*status config*cache config*log
        rm -f gmon.out core build-stamp
@@ -251,9 +282,9 @@ distclean: clean
 #
 # Install/uninstall rules
 #
-install: libdvdcss-install vlc-install plugins-install po-install
+install: vlc-install plugins-install po-install
 
-uninstall: libdvdcss-uninstall vlc-uninstall plugins-uninstall po-uninstall
+uninstall: vlc-uninstall plugins-uninstall po-uninstall
 
 vlc-install:
        mkdir -p $(DESTDIR)$(bindir)
@@ -284,12 +315,6 @@ endif
 plugins-uninstall:
        rm -f $(DESTDIR)$(libdir)/videolan/vlc/*.so
 
-libdvdcss-install:
-       -cd extras/libdvdcss && $(MAKE) install
-
-libdvdcss-uninstall:
-       -cd extras/libdvdcss && $(MAKE) uninstall
-
 po-install:
        -cd po && $(MAKE) install
 
@@ -299,7 +324,7 @@ po-uninstall:
 #
 # Package generation rules
 #
-snapshot-common:
+dist:
        # Check that tmp isn't in the way
        @if test -e tmp; then \
                echo "Error: please remove ./tmp, it is in the way"; false; \
@@ -332,7 +357,7 @@ snapshot-common:
        cp FAQ AUTHORS COPYING TODO todo.pl ChangeLog* README* INSTALL* \
                Makefile Makefile.opts.in Makefile.dep Makefile.modules \
                configure configure.in install-sh install-win32 vlc.spec \
-               config.sub config.guess acconfig.h aclocal.m4 mkinstalldirs \
+               config.sub config.guess aclocal.m4 mkinstalldirs \
                        tmp/vlc/
        # Copy Debian control files
        for file in debian/*dirs debian/*docs debian/*menu debian/*desktop \
@@ -347,39 +372,14 @@ snapshot-common:
                cp $$file tmp/vlc/share ; done
        for file in vlc_beos.rsrc vlc.icns gvlc_win32.ico vlc_win32_rc.rc ; do \
                        cp share/$$file tmp/vlc/share/ ; done
-
-snapshot: snapshot-common
        # Build archives
-       F=vlc-${VLC_QUICKVERSION}; \
+       F=vlc-${VERSION}; \
        mv tmp/vlc tmp/$$F; (cd tmp ; tar cf $$F.tar $$F); \
        bzip2 -f -9 < tmp/$$F.tar > $$F.tar.bz2; \
        gzip -f -9 tmp/$$F.tar ; mv tmp/$$F.tar.gz .
        # Clean up
        rm -Rf tmp
 
-snapshot-nocss: snapshot-common
-       # Remove libdvdcss
-       rm -Rf tmp/vlc/extras/libdvdcss
-       rm -f tmp/vlc/*.libdvdcss
-       # Fix debian information
-       rm -f tmp/vlc/debian/libdvdcss*
-       rm -f tmp/vlc/debian/control
-       sed -e 's#^ DVDs# unencrypted DVDs#' < debian/control \
-               | awk '{if(gsub("Package: libdvdcss",$$0))a=1;if(a==0)print $$0;if(a==1&&$$0=="")a=0}' \
-               > tmp/vlc/debian/control
-       rm -f tmp/vlc/debian/rules
-       sed -e 's#^\(export LIBDVDCSS_FLAGS=\).*#\1"--without-dvdcss"#' < debian/rules \
-               | awk '{if($$0=="# libdvdcss start")a=1;if(a==0)print $$0;if($$0=="# libdvdcss stop")a=0}' \
-               > tmp/vlc/debian/rules
-       chmod +x tmp/vlc/debian/rules
-       # Build css-disabled archives
-       F=vlc-${VLC_QUICKVERSION}; G=vlc-${VLC_QUICKVERSION}-nocss; \
-       mv tmp/vlc tmp/$$F; (cd tmp ; tar cf $$G.tar $$F); \
-       bzip2 -f -9 < tmp/$$G.tar > $$G.tar.bz2; \
-       gzip -f -9 tmp/$$G.tar ; mv tmp/$$G.tar.gz .
-       # Clean up
-       rm -Rf tmp
-
 package-win32:
        # XXX: this rule is probably only useful to you if you have exactly
        # the same setup as me. Contact sam@zoy.org if you need to use it.
@@ -391,21 +391,22 @@ package-win32:
                echo "OK."; mkdir tmp; \
        fi
        # Create installation script
-       sed -e 's#@VERSION@#'${VLC_QUICKVERSION}'#' < install-win32 > tmp/nsi
+       cp install-win32 tmp/nsi
        # Copy relevant files
-       cp vlc.exe $(PLUGINS:%=plugins/%.so) tmp/ 
-       cp INSTALL-win32.txt AUTHORS COPYING ChangeLog ChangeLog.libdvdcss \
-               README README.libdvdcss FAQ TODO tmp/
-       for file in gtk-1.3.dll gdk-1.3.dll glib-1.3.dll gmodule-1.3.dll \
-               gnu-intl.dll SDL.dll README-SDL.txt ; \
-                       do cp ${DLL_PATH}/$$file tmp/ ; done
+       cp vlc.exe tmp/ 
+       $(STRIP) tmp/vlc.exe
+       cp INSTALL.win32 tmp/INSTALL.txt ; unix2dos tmp/INSTALL.txt
+       for file in AUTHORS COPYING ChangeLog README FAQ TODO ; \
+                       do cp $$file tmp/$${file}.txt ; \
+                       unix2dos tmp/$${file}.txt ; done
+       mkdir tmp/plugins
+       cp $(PLUGINS:%=plugins/%.so) tmp/plugins/ 
+       $(STRIP) tmp/$(PLUGINS:%=plugins/%.so)
        mkdir tmp/share
        for file in default8x16.psf default8x9.psf ; \
                do cp share/$$file tmp/share/ ; done
        # Create package 
-       wine ~/.wine/fake_windows/Program\ Files/NSIS/makensis.exe /CD tmp/nsi
-       mv tmp/vlc-${VLC_QUICKVERSION}.exe \
-               vlc-${VLC_QUICKVERSION}-win32-installer.exe
+       wine ~/.wine/fake_windows/Program\ Files/NSIS/makensis.exe -- /DVERSION=${VERSION} /CD tmp/nsi
        # Clean up
        rm -Rf tmp
 
@@ -421,54 +422,35 @@ package-beos:
        mkdir -p tmp/vlc/share
        # Copy relevant files
        cp vlc tmp/vlc/
-       cp AUTHORS COPYING ChangeLog ChangeLog.libdvdcss \
-               README README.libdvdcss FAQ TODO tmp/vlc/
+       cp AUTHORS COPYING ChangeLog README FAQ TODO tmp/vlc/
        for file in default8x16.psf default8x9.psf ; \
                do cp share/$$file tmp/vlc/share/ ; done
        # Create package 
-       mv tmp/vlc tmp/vlc-${VLC_QUICKVERSION}
-       (cd tmp ; find vlc-${VLC_QUICKVERSION} | \
-       zip -9 -@ vlc-${VLC_QUICKVERSION}-beos.zip )
-       mv tmp/vlc-${VLC_QUICKVERSION}-beos.zip .
+       mv tmp/vlc tmp/vlc-${VERSION}
+       (cd tmp ; find vlc-${VERSION} | \
+       zip -9 -@ vlc-${VERSION}-beos.zip )
+       mv tmp/vlc-${VERSION}-BeOS-x86.zip .
        # Clean up
        rm -Rf tmp
 
-libdvdcss-snapshot: snapshot-common
-       # Remove vlc sources and icons, doc, debian directory...
-       rm -Rf tmp/vlc/src tmp/vlc/share tmp/vlc/plugins tmp/vlc/doc
-       rm -Rf tmp/vlc/extras/GNUgetopt tmp/vlc/extras/MacOSX
-       rm -Rf tmp/vlc/debian
-       rm -Rf tmp/vlc/ipkg
-       # Remove useless headers
-       rm -f tmp/vlc/include/*
-       for file in defs.h.in config.h.in common.h int_types.h ; \
-               do cp include/$$file tmp/vlc/include/ ; done
-       # Remove misc files (??? - maybe not really needed)
-       rm -f tmp/vlc/vlc.spec tmp/vlc/INSTALL-win32.txt
-       mv tmp/vlc/INSTALL.libdvdcss tmp/vlc/INSTALL
-       mv tmp/vlc/README.libdvdcss tmp/vlc/README
-       mv tmp/vlc/ChangeLog.libdvdcss tmp/vlc/ChangeLog
-       # Fix Makefile
-       rm -f tmp/vlc/Makefile
-       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/vlc/Makefile
-       # Build archives
-       F=libdvdcss-${LIBDVDCSS_QUICKVERSION}; \
-       mv tmp/vlc tmp/$$F; (cd tmp ; tar cf $$F.tar $$F); \
-       bzip2 -f -9 < tmp/$$F.tar > $$F.tar.bz2; \
-       gzip -f -9 tmp/$$F.tar ; mv tmp/$$F.tar.gz .
+package-macosx:
+       # Check that tmp isn't in the way
+       @if test -e tmp; then \
+               echo "Error: please remove ./tmp, it is in the way"; false; \
+       else \
+               echo "OK."; mkdir tmp; \
+       fi
+
+       # Copy relevant files 
+       cp -R vlc.app tmp/
+       cp AUTHORS COPYING ChangeLog README FAQ TODO tmp/
+
+       # Create disk image 
+       ./macosx-dmg 0 "vlc-${VERSION}" tmp/* 
+
        # Clean up
        rm -Rf tmp
 
-deb:
-       dpkg-buildpackage -rfakeroot -us -uc
-
 #
 # Gtk/Gnome/* aliases and OS X application
 #
@@ -476,7 +458,7 @@ gnome-vlc gvlc kvlc qvlc: vlc
        rm -f $@ && ln -s vlc $@
 
 .PHONY: vlc.app
-vlc.app: Makefile.opts
+vlc.app: vlc plugins
 ifneq (,$(findstring darwin,$(SYS)))
        rm -Rf vlc.app
        cd extras/MacOSX ; pbxbuild | grep -v '^ ' | grep -v '^\t'
@@ -495,35 +477,42 @@ FORCE:
 #
 # Generic rules (see below)
 #
-$(C_DEP): %.d: FORCE
-       @$(MAKE) -s --no-print-directory -f Makefile.dep $@
-
-$(CPP_DEP): %.dpp: FORCE
-       @$(MAKE) -s --no-print-directory -f Makefile.dep $@
-
 $(H_OBJ): Makefile.opts Makefile.dep Makefile
-       rm -f $@ && cp $@.in $@
+#      @echo "regenerating $@"
+       @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* );" >> $@ ; \
+       @for i in $(BUILTINS) ; do \
+               echo "int InitModule__MODULE_"$$i"( module_t* );" >>$@; \
+               echo "int ActivateModule__MODULE_"$$i"( module_t* );" >>$@; \
+               echo "int DeactivateModule__MODULE_"$$i"( module_t* );" >>$@; \
        done
-       echo "" >> $@ ;
-       printf "#define ALLOCATE_ALL_BUILTINS() do { " >> $@ ;
-       for i in $(BUILTINS) ; do \
-               printf "ALLOCATE_BUILTIN("$$i"); " >> $@ ; \
+       @echo "" >> $@ ;
+endif
+       @echo "#define ALLOCATE_ALL_BUILTINS() \\" >> $@ ;
+       @echo "    do \\" >> $@ ;
+       @echo "    { \\" >> $@ ;
+ifneq (,$(BUILTINS))
+       @for i in $(BUILTINS) ; do \
+               echo "        ALLOCATE_BUILTIN("$$i"); \\" >> $@ ; \
        done
-       echo "} while( 0 );" >> $@ ;
-       echo "" >> $@ ;
 endif
+       @echo "    } while( 0 );" >> $@ ;
+       @echo "" >> $@ ;
+
+$(C_DEP): %.d: FORCE
+       @$(MAKE) -s --no-print-directory -f Makefile.dep $@
+
+$(CPP_DEP): %.dpp: FORCE
+       @$(MAKE) -s --no-print-directory -f Makefile.dep $@
 
 $(C_OBJ): %.o: Makefile.opts Makefile.dep Makefile
+$(C_OBJ): %.o: $(H_OBJ)
 $(C_OBJ): %.o: .dep/%.d
 $(C_OBJ): %.o: %.c
        $(CC) $(CFLAGS) $(CFLAGS_VLC) -c -o $@ $<
 
 $(CPP_OBJ): %.o: Makefile.opts Makefile.dep Makefile
+$(CPP_OBJ): %.o: $(H_OBJ)
 $(CPP_OBJ): %.o: .dep/%.dpp
 $(CPP_OBJ): %.o: %.cpp
        $(CC) $(CFLAGS) $(CFLAGS_VLC) -c -o $@ $<
@@ -537,8 +526,8 @@ endif
 #
 # Main application target
 #
-vlc: Makefile.opts Makefile.dep Makefile $(H_OBJ) $(VLC_OBJ) $(BUILTIN_OBJ)
-       $(CC) $(CFLAGS) -o $@ $(VLC_OBJ) $(BUILTIN_OBJ) $(LCFLAGS)
+vlc: Makefile.opts Makefile.dep Makefile $(VLC_OBJ) $(BUILTIN_OBJ)
+       $(CC) $(CFLAGS) -o $@ $(VLC_OBJ) $(BUILTIN_OBJ) $(LDFLAGS) $(vlc_LDFLAGS) $(builtins_LDFLAGS)
 ifeq ($(SYS),beos)
        xres -o $@ ./share/vlc_beos.rsrc
        mimeset -f $@
@@ -549,26 +538,14 @@ endif
 #
 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) $(@:plugins/%=../%)
+       @cd $(shell echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.* \([^/]*/\)'$(@:plugins/%.so=%)' .*@plugins/\1@' -e 's@^ .*@@') && $(MAKE) -f ../../Makefile.modules $(@:plugins/%=../%)
 
 #
 # Built-in modules target
 #
 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) $(@:plugins/%=../%)
-
-#
-# libdvdcss target
-#
-libdvdcss: Makefile.opts
-       @cd extras/libdvdcss && $(MAKE)
-
-#
-# libdvdread target
-#
-libdvdread: Makefile.opts
-       @cd extras/libdvdread && $(MAKE)
+       @cd $(shell echo " "$(PLUGINS_TARGETS)" " | sed -e 's@.* \([^/]*/\)'$(@:plugins/%.a=%)' .*@plugins/\1@' -e 's@^ .*@@') && $(MAKE) -f ../../Makefile.modules $(@:plugins/%=../%)
 
 #
 # gettext target