]> git.sesse.net Git - vlc/blobdiff - Makefile
* Fixed the BeOS compile typo.
[vlc] / Makefile
index 4097c47e43053e9a7753a0227af6e8f3b91fb9b6..85a3ea3ce009e8ac7a10e40b4f4f5a4439941142 100644 (file)
--- a/Makefile
+++ b/Makefile
-################################################################################
-# vlc (VideoLAN Client) main makefile
-# (c)1998 VideoLAN
-################################################################################
-# This makefile is the main makefile for the VideoLAN client.
-################################################################################
-
-################################################################################
-# Configuration
-################################################################################
-
-# Environment
-CC=egcc
-SHELL=/bin/sh
-
-# Audio output settings
-AUDIO = dsp
-# Not yet supported
-#AUDIO += esd
-# Fallback method that should always work
-AUDIO += dummy
-
-# Video output settings
-VIDEO = x11
-#VIDEO += fb
-#VIDEO += ggi
-#VIDEO += glide
-# Not yet supported
-#VIDEO += beos
-#VIDEO += dga
-# Fallback method that should always work
-VIDEO += dummy
-
-# Target architecture
-ARCH=X86
-#ARCH=PPC
-#ARCH=SPARC
-
-# Target operating system
-SYS=LINUX
-#SYS=BSD
-#SYS=BEOS
-
-# For x86 architecture, choose MMX support
-MMX=YES
-#MMX=NO
-
-# Decoder choice - ?? old decoder will be removed soon
-#DECODER=old
-DECODER=new
-
-# Debugging mode on or off (set to 1 to activate)
-DEBUG=0
-
-#----------------- do not change anything below this line ----------------------
-
-################################################################################
-# Configuration pre-processing
-################################################################################
-
-# Program version - may only be changed by the project leader
-PROGRAM_VERSION = 0.1.99
-
-# audio options
-audio := $(shell echo $(AUDIO) | tr 'A-Z' 'a-z')
-AUDIO := $(shell echo $(AUDIO) | tr 'a-z' 'A-Z')
-
-# video options
-video := $(shell echo $(VIDEO) | tr 'A-Z' 'a-z')
-VIDEO := $(shell echo $(VIDEO) | tr 'a-z' 'A-Z')
-
-# PROGRAM_OPTIONS is an identification string of the compilation options
-PROGRAM_OPTIONS = $(ARCH) $(SYS)
-ifeq ($(DEBUG),1)
-PROGRAM_OPTIONS += DEBUG
-endif
+###############################################################################
+# vlc (VideoLAN Client) main Makefile - (c)1998 VideoLAN
+###############################################################################
 
-# PROGRAM_BUILD is a complete identification of the build
-PROGRAM_BUILD = `date -R` $(USER)@`hostname`
-
-# DEFINE will contain some of the constants definitions decided in Makefile, 
-# including ARCH_xx and SYS_xx. It will be passed to C compiler.
-DEFINE += -DARCH_$(ARCH)
-DEFINE += -DSYS_$(SYS)
-DEFINE += -DAUDIO_OPTIONS="\"$(audio)\""
-DEFINE += -DVIDEO_OPTIONS="\"$(video)\""
-DEFINE += -DPROGRAM_VERSION="\"$(PROGRAM_VERSION)\""
-DEFINE += -DPROGRAM_OPTIONS="\"$(PROGRAM_OPTIONS)\""
-DEFINE += -DPROGRAM_BUILD="\"$(PROGRAM_BUILD)\""
-ifeq ($(DEBUG),1)
-DEFINE += -DDEBUG
-endif
+-include Makefile.opts
 
-################################################################################
-# Tuning and other variables - do not change anything except if you know
-# exactly what you are doing
-################################################################################
+###############################################################################
+# Objects and files
+###############################################################################
 
+# 
+# All possible plugin directories, needed for make clean
 #
-# C headers directories
-#
-INCLUDE += -Iinclude
+PLUGINS_DIR := alsa beos darwin dsp dummy \
+               dvd esd fb ggi glide gtk \
+               downmix idct imdct \
+               macosx mga \
+               motion \
+               mpeg null qt sdl \
+               text x11 yuv
 
 #
-# Libraries
+# All possible plugin objects
 #
-LIB += -lpthread
-LIB += -lm
-LIB += -ldl
+PLUGINS_TARGETS := alsa/alsa beos/beos darwin/darwin dsp/dsp dummy/dummy \
+               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 \
+               macosx/macosx mga/mga \
+               motion/motion motion/motionmmx motion/motionmmxext \
+               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 compiler flags: compilation
+# C Objects
+# 
+INTERFACE =    src/interface/main.o \
+               src/interface/interface.o \
+               src/interface/intf_msg.o \
+               src/interface/intf_playlist.o \
+               src/interface/intf_channels.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/mpeg_system.o
+
+AUDIO_OUTPUT =         src/audio_output/audio_output.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_spdif.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
+
+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
+
+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/modules.o \
+               src/misc/netutils.o
+
+C_OBJ =                $(INTERFACE) \
+               $(INPUT) \
+               $(VIDEO_OUTPUT) \
+               $(AUDIO_OUTPUT) \
+               $(AC3_DECODER) \
+               $(AC3_SPDIF) \
+               $(LPCM_DECODER) \
+               $(AUDIO_DECODER) \
+               $(SPU_DECODER) \
+               $(GEN_DECODER) \
+               $(VIDEO_PARSER) \
+               $(VIDEO_DECODER) \
+               $(MISC)
+
 #
-CCFLAGS += $(DEFINE) $(INCLUDE)
-CCFLAGS += -Wall
-CCFLAGS += -D_REENTRANT
-CCFLAGS += -D_GNU_SOURCE
-
-# Optimizations : don't compile debug versions with them
-CCFLAGS += -O6
-CCFLAGS += -ffast-math -funroll-loops -fargument-noalias-global
-CCFLAGS += -fomit-frame-pointer
-
-# Optimizations for x86 familiy
-ifeq ($(ARCH),X86)
-CCFLAGS += -malign-double
-CCFLAGS += -march=pentiumpro
-#CCFLAGS += -march=pentium
+# Misc Objects
+# 
+ifeq ($(GETOPT),1)
+C_OBJ += extras/GNUgetopt/getopt.o extras/GNUgetopt/getopt1.o 
 endif
 
-# Optimizations for PowerPC
-ifeq ($(ARCH),PPC)
-CCFLAGS += -mcpu=604e -mmultiple -mhard-float -mstring
+ifeq ($(SYS),beos)
+CPP_OBJ =      src/misc/beos_specific.o
 endif
 
-# Optimizations for Sparc
-ifeq ($(ARCH),SPARC)
-CCFLAGS += -mhard-float
+ifneq (,$(findstring darwin,$(SYS)))
+C_OBJ +=       src/misc/darwin_specific.o
 endif
 
 #
-# C compiler flags: dependancies
-#
-DCFLAGS += $(INCLUDE)
-DCFLAGS += -MM
-
-#
-# C compiler flags: linking
-#
-LCFLAGS += $(LIB)
-LCFLAGS += -Wall
-#LCFLAGS += -s
-
-#
-# C compiler flags: common flags
+# Generated header
 #
-
-# Eventual MMX optimizations for x86
-ifeq ($(ARCH),X86)
-ifeq ($(MMX), YES)
-CFLAGS += -DHAVE_MMX
-endif
-endif
+H_OBJ =                include/modules_builtin.h
 
 #
-# Additionnal debugging flags
+# Other lists of files
 #
-
-# Debugging support
-ifeq ($(DEBUG),1)
-CFLAGS += -g
-#CFLAGS += -pg
-endif
-
-#################################################################################
-# Objects and files
-#################################################################################
+C_DEP := $(C_OBJ:%.o=.dep/%.d)
+CPP_DEP := $(CPP_OBJ:%.o=.dep/%.dpp)
 
 #
-# C Objects
-# 
-interface_obj =                interface/main.o \
-                                               interface/interface.o \
-                                               interface/intf_msg.o \
-                                               interface/intf_cmd.o \
-                                               interface/intf_ctrl.o \
-                                               interface/intf_console.o
-
-input_obj =                    input/input_vlan.o \
-                                               input/input_file.o \
-                                               input/input_netlist.o \
-                                               input/input_network.o \
-                                               input/input_ctrl.o \
-                                               input/input_pcr.o \
-                                               input/input_psi.o \
-                                               input/input.o
-
-audio_output_obj =             audio_output/audio_output.o
-
-video_output_obj =             video_output/video_output.o \
-                                               video_output/video_text.o \
-                                               video_output/video_yuv.o
-
-ac3_decoder_obj =              ac3_decoder/ac3_decoder_thread.o \
-                                               ac3_decoder/ac3_decoder.o \
-                                               ac3_decoder/ac3_parse.o \
-                                               ac3_decoder/ac3_exponent.o \
-                                               ac3_decoder/ac3_bit_allocate.o \
-                                               ac3_decoder/ac3_mantissa.o \
-                                               ac3_decoder/ac3_rematrix.o \
-                                               ac3_decoder/ac3_imdct.o \
-                                               ac3_decoder/ac3_downmix.o
-
-audio_decoder_obj =            audio_decoder/audio_decoder.o \
-                                               audio_decoder/audio_math.o
-
-spu_decoder_obj =              spu_decoder/spu_decoder.o
-
-#??generic_decoder_obj =               generic_decoder/generic_decoder.o
-# remeber to add it to OBJ 
-
-ifeq ($(DECODER),old)
-CFLAGS += -DOLD_DECODER
-video_decoder_obj =            video_decoder_ref/video_decoder.o \
-                                               video_decoder_ref/display.o \
-                                               video_decoder_ref/getblk.o \
-                                               video_decoder_ref/gethdr.o \
-                                               video_decoder_ref/getpic.o \
-                                               video_decoder_ref/getvlc.o \
-                                               video_decoder_ref/idct.o \
-                                               video_decoder_ref/motion.o \
-                                               video_decoder_ref/mpeg2dec.o \
-                                               video_decoder_ref/recon.o \
-                                               video_decoder_ref/spatscal.o
-else
-video_parser_obj =             video_parser/video_parser.o \
-                                               video_parser/vpar_headers.o \
-                                               video_parser/vpar_blocks.o \
-                                               video_parser/vpar_synchro.o \
-                                               video_parser/video_fifo.o
-
-video_decoder_obj =            video_decoder/video_decoder.o \
-                                               video_decoder/vdec_motion.o \
-                                               video_decoder/vdec_idct.o
-endif
-
-misc_obj =                     misc/mtime.o \
-                                               misc/rsc_files.o \
-                                               misc/netutils.o \
-                                               misc/decoder_fifo.o
-
-C_OBJ = $(interface_obj) \
-               $(input_obj) \
-               $(audio_output_obj) \
-               $(video_output_obj) \
-               $(ac3_decoder_obj) \
-               $(audio_decoder_obj) \
-               $(spu_decoder_obj) \
-               $(generic_decoder_obj) \
-               $(video_parser_obj) \
-               $(video_decoder_obj) \
-               $(vlan_obj) \
-               $(misc_obj)
-
+# Translate plugin names
 #
-# Assembler Objects
-# 
-ifeq ($(ARCH),X86)
-ifeq ($(MMX), YES)
-ifeq ($(DECODER),new)
-ASM_OBJ =                      video_decoder/vdec_idctmmx.o \
-                                               video_output/video_yuv_mmx.o
-else
-ASM_OBJ =                      video_decoder_ref/vdec_idctmmx.o \
-                                               video_output/video_yuv_mmx.o
-endif
+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
 
-#
-# Plugins
-#
-interface_plugin =     $(video:%=interface/intf_%.so)
-audio_plugin =         $(audio:%=audio_output/aout_%.so)
-video_plugin =                 $(video:%=video_output/vout_%.so)
-
-PLUGIN_OBJ = $(interface_plugin) \
-                $(audio_plugin) \
-                $(video_plugin) \
-
-#
-# Other lists of files
-#
-sources := $(C_OBJ:%.o=%.c) $(PLUGIN_OBJ:%.so=%.c)
-dependancies := $(sources:%.c=dep/%.d)
-
 # All symbols must be exported
 export
 
-################################################################################
+###############################################################################
 # Targets
-################################################################################
+###############################################################################
 
 #
 # Virtual targets
 #
-all: vlc
+all: vlc ${ALIASES} plugins vlc.app
 
 clean:
-       rm -f $(C_OBJ) $(ASM_OBJ) $(PLUGIN_OBJ)
+       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
 
 distclean: clean
-       rm -f **/*.o **/*.so **/*~ *.log
-       rm -f vlc gmon.out core
-       rm -rf dep
+       rm -f **/*.o **/*~ *.log
+       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 gmon.out core build-stamp
+       rm -Rf .dep
+       rm -f .gdb_history
+
+install:
+       mkdir -p $(DESTDIR)$(bindir)
+       $(INSTALL) vlc $(DESTDIR)$(bindir)
+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
+       $(INSTALL) -m 644 share/*.xpm $(DESTDIR)$(datadir)/videolan
 
 show:
-       @echo "Command line for C objects:"
-       @echo $(CC) $(CCFLAGS) $(CFLAGS) -c -o "<dest.o>" "<src.c>"
-       @echo
-       @echo "Command line for assembler objects:"
-       @echo $(CC) $(CFLAGS) -c -o "<dest.o>" "<src.S>"
+       @echo CC: $(CC)
+       @echo CFLAGS: $(CFLAGS)
+       @echo DCFLAGS: $(DCFLAGS)
+       @echo LCFLAGS: $(LCFLAGS)
+       @echo C_OBJ: $(C_OBJ)
+       @echo CPP_OBJ: $(CPP_OBJ)
+       @echo objects: $(objects)
+       @echo cppobjects: $(cppobjects)
+       @echo PLUGIN_OBJ: $(PLUGIN_OBJ)
+       @echo BUILTIN_OBJ: $(BUILTIN_OBJ)
+
+
+# ugliest of all, but I have no time to do it -- sam
+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 ; \
+               do mkdir -p /tmp/vlc-${PROGRAM_VERSION}/$$i ; \
+       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 .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
+       find /tmp/vlc-${PROGRAM_VERSION}/extras \
+               /tmp/vlc-${PROGRAM_VERSION}/doc \
+               -type d -name CVS | while read i ; \
+                       do rm -Rf $$i ; \
+               done
+       # copy misc files
+       cp vlc.spec AUTHORS COPYING ChangeLog INSTALL 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.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 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 \
+                       /tmp/vlc-${PROGRAM_VERSION}/share/ ; done
+
+       # build css-enabled archives
+       (cd /tmp ; tar cf vlc-${PROGRAM_VERSION}.tar vlc-${PROGRAM_VERSION} ; \
+               bzip2 -f -9 < vlc-${PROGRAM_VERSION}.tar \
+                       > vlc-${PROGRAM_VERSION}.tar.bz2 ; \
+               gzip -f -9 vlc-${PROGRAM_VERSION}.tar )
+       mv /tmp/vlc-${PROGRAM_VERSION}.tar.gz \
+               /tmp/vlc-${PROGRAM_VERSION}.tar.bz2 ..
+
+       # clean up
+       rm -Rf /tmp/vlc-${PROGRAM_VERSION}*
+
+.PHONY: vlc.app
+vlc.app:
+ifneq (,$(findstring darwin,$(SYS)))
+       rm -Rf vlc.app
+       mkdir -p vlc.app/Contents/Resources
+       mkdir -p vlc.app/Contents/MacOS/lib
+       mkdir -p vlc.app/Contents/MacOS/share
+       $(INSTALL) -m 644 extras/MacOSX_app/Contents/Info.plist vlc.app/Contents/
+       $(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
 
 FORCE:
 
 #
-# Real targets
+# GTK/Gnome aliases - don't add too many aliases which could bloat
+# the namespace
 #
-vlc: $(C_OBJ) $(ASM_OBJ) $(PLUGIN_OBJ)
-       $(CC) $(LCFLAGS) $(CFLAGS) --export-dynamic -rdynamic -o $@ $(C_OBJ) $(ASM_OBJ) 
+gnome-vlc gvlc kvlc qvlc: vlc
+       rm -f $@ && ln -s vlc $@
 
 #
 # Generic rules (see below)
 #
-$(dependancies): %.d: FORCE
+$(C_DEP): %.d: FORCE
        @$(MAKE) -s --no-print-directory -f Makefile.dep $@
 
-$(C_OBJ): %.o: Makefile.dep
-$(C_OBJ): %.o: dep/%.d
+$(CPP_DEP): %.dpp: FORCE
+       @$(MAKE) -s --no-print-directory -f Makefile.dep $@
+
+$(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* );" >> $@ ; \
+       done
+endif
+       echo "" >> $@ ;
+       printf "#define ALLOCATE_ALL_BUILTINS() do { " >> $@ ;
+ifneq (,$(BUILTINS))
+       for i in $(BUILTINS) ; do \
+               printf "ALLOCATE_BUILTIN("$$i"); " >> $@ ; \
+       done
+endif
+       echo "} while( 0 );" >> $@ ;
+       echo "" >> $@ ;
+
+$(C_OBJ): %.o: Makefile.opts Makefile.dep Makefile
+$(C_OBJ): %.o: .dep/%.d
 $(C_OBJ): %.o: %.c
-       @echo "compiling $*.o from $*.c"
-       @$(CC) $(CCFLAGS) $(CFLAGS) -c -o $@ $<
-
-$(ASM_OBJ): %.o: Makefile.dep
-$(ASM_OBJ): %.o: %.S
-       @echo "assembling $*.o from $*.S"
-       @$(CC) $(CFLAGS) -c -o $@ $<
-
-$(PLUGIN_OBJ): %.so: Makefile.dep
-$(PLUGIN_OBJ): %.so: dep/%.d
-
-# audio plugins
-audio_output/aout_dummy.so \
-       audio_output/aout_dsp.so: %.so: %.c
-               @echo "compiling $*.so from $*.c"
-               @$(CC) $(CCFLAGS) $(CFLAGS) -shared -o $@ $<
-
-audio_output/aout_esd.so: %.so: %.c
-               @echo "compiling $*.so from $*.c"
-               @$(CC) $(CCFLAGS) $(CFLAGS) -laudiofile -lesd -shared -o $@ $<
-
-# video plugins
-interface/intf_dummy.so \
-       video_output/vout_dummy.so \
-       interface/intf_fb.so \
-       video_output/vout_fb.so: %.so: %.c
-               @echo "compiling $*.so from $*.c"
-               @$(CC) $(CCFLAGS) $(CFLAGS) -shared -o $@ $<
-
-interface/intf_x11.so \
-       video_output/vout_x11.so: %.so: %.c
-               @echo "compiling $*.so from $*.c"
-               @$(CC) $(CCFLAGS) $(CFLAGS) -I/usr/X11R6/include -L/usr/X11R6/lib -lX11 -lXext -shared -o $@ $<
-
-interface/intf_glide.so \
-       video_output/vout_glide.so: %.so: %.c
-               @echo "compiling $*.so from $*.c"
-               @$(CC) $(CCFLAGS) $(CFLAGS) -I/usr/include/glide -lglide2x -shared -o $@ $<
-
-interface/intf_ggi.so \
-       video_output/vout_ggi.so: %.so: %.c
-               @echo "compiling $*.so from $*.c"
-               @$(CC) $(CCFLAGS) $(CFLAGS) -lggi -shared -o $@ $<
-
-
-################################################################################
-# Note on generic rules and dependancies
-################################################################################
-
-# Note on dependancies: each .c file is associated with a .d file, which
-# depends of it. The .o file associated with a .c file depends of the .d, of the 
-# .c itself, and of Makefile. The .d files are stored in a separate dep/ 
-# directory.
-# The dep directory should be ignored by CVS.
-
-# Note on inclusions: depending of the target, the dependancies files must 
-# or must not be included. The problem is that if we ask make to include a file,
-# and this file does not exist, it is made before it can be included. In a 
-# general way, a .d file should be included if and only if the corresponding .o 
-# needs to be re-made.
-
-# Two makefiles are used: the main one (this one) has regular generic rules,
-# except for .o files, for which it calls the object Makefile. Dependancies
-# are not included in this file.
-# The object Makefile known how to make a .o from a .c, and includes
-# dependancies for the target, but only those required.
+       $(CC) $(CFLAGS) -c -o $@ $<
+
+$(CPP_OBJ): %.o: Makefile.opts Makefile.dep Makefile
+$(CPP_OBJ): %.o: .dep/%.dpp
+$(CPP_OBJ): %.o: %.cpp
+       $(CC) $(CFLAGS) -c -o $@ $<
+
+#
+# Main application target
+#
+vlc: Makefile.opts Makefile.dep Makefile $(H_OBJ) $(C_OBJ) $(CPP_OBJ) $(BUILTIN_OBJ)
+       $(CC) $(CFLAGS) -o $@ $(C_OBJ) $(CPP_OBJ) $(BUILTIN_OBJ) $(LCFLAGS) $(LIB)
+ifeq ($(SYS),beos)
+       rm -f ./lib/_APP_
+       ln -s ../vlc ./lib/_APP_
+       xres -o $@ ./share/vlc_beos.rsrc
+       mimeset -f $@
+endif
+
+#
+# Plugins target
+#
+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: 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) $(@:%=../../%)
+