X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=Makefile.am;h=250d45779bc251b0fcf53776ea7b6fbd9e63357d;hb=e2b261ca0b3f8587f11ba96092231b338a419552;hp=53a737a8b14cb16acebd31db24514d2052117a19;hpb=866a81496587cf7d2f583e08f0e71bcf12e4459f;p=vlc diff --git a/Makefile.am b/Makefile.am index 53a737a8b1..250d45779b 100644 --- a/Makefile.am +++ b/Makefile.am @@ -2,135 +2,43 @@ # Automake targets and declarations ############################################################################### +NULL = + # SUBDIRS stores the directories where a "make" is required when building # something. DIST_SUBDIRS stores the directories where nothing is built but # which have makefiles with distribution information. -SUBDIRS = po intl m4 share -DIST_SUBDIRS = $(SUBDIRS) modules src debian doc ipkg lib autotools - -EXTRA_DIST = HACKING MAINTAINERS src/extras/COPYING \ - INSTALL.win32 README.MacOSX.rtf vlc.spec install-win32 \ - Modules.am \ - configure.ac.in mkinstalldirs bootstrap -MOSTLYCLEANFILES = +# - intl should come before modules and . because all the code uses gettext +# - modules should come before . because vlc needs the builtins +# - . should come before mozilla because the plugin needs libvlc_pic.a +# - po should come before . because VLC.app needs the pofiles +SUBDIRS = intl modules po . mozilla activex share m4 doc +DIST_SUBDIRS = $(SUBDIRS) src debian ipkg lib + +EXTRA_DIST = \ + HACKING \ + INSTALL.win32 \ + vlc.exe.manifest \ + MAINTAINERS \ + README.MacOSX.rtf \ + bootstrap \ + src/extras/COPYING \ + toolbox \ + vlc-config.in.in \ + vlc.spec \ + vlc.spec.mdk \ + vlc.win32.nsi \ + $(NULL) + BUILT_SOURCES = SUFFIXES = -NULL = - -# List of programs, libraries and headers that need to be built and/or -# distributed. Initialized to empty because we'll use += later. -bin_PROGRAMS = - -lib_LIBRARIES = -libvlc_LIBRARIES = -noinst_LIBRARIES = - -noinst_HEADERS = # Tell aclocal to use -I m4. Wonder if it really works. ACLOCAL_AMFLAGS = -I m4 -# XXX: these flags could be set in configure.ac.in, but we set them here +# XXX: these flags could be set in configure.ac, but we set them here # because old versions of automake don't support them in configure.ac. AUTOMAKE_OPTIONS = dist-bzip2 subdir-objects -############################################################################### -# Compilation flags for debug mode, profiling, and others -############################################################################### - -# Standard flags used everywhere to build things in the distribution. Some -# of them are empty but might be extended later in the Makefile. *_default -# is the default flag list for all files in the distribution, for instance -# the vlc code. *_pic is for PIC code, such as the Mozilla plugin. *_plugin -# is for plugin code, *_builtin is for builtin code, and *_builtin_pic is -# for PIC builtin code, for instance builtin modules in the mozilla plugin. - -CPPFLAGS_default = -I$(top_srcdir)/include -CFLAGS_default = -CXXFLAGS_default = -OBJCFLAGS_default = -LDFLAGS_default = - -CPPFLAGS_pic = $(CPPFLAGS_default) -CFLAGS_pic = $(CFLAGS_default) @CFLAGS_pics@ -CXXFLAGS_pic = $(CXXFLAGS_default) @CFLAGS_pics@ -OBJCFLAGS_pic = $(OBJCFLAGS_default) @CFLAGS_pics@ -LDFLAGS_pic = $(LDFLAGS_default) - -CPPFLAGS_plugin = $(CPPFLAGS_default) -D__VLC__ -D__PLUGIN__ -CFLAGS_plugin = $(CFLAGS_default) @CFLAGS_plugins@ -CXXFLAGS_plugin = $(CXXFLAGS_default) @CFLAGS_plugins@ -OBJCFLAGS_plugin = $(OBJCFLAGS_default) @CFLAGS_plugins@ -LDFLAGS_plugin = @LDFLAGS_plugins@ - -CPPFLAGS_builtin = $(CPPFLAGS_default) -D__VLC__ -D__BUILTIN__ -CFLAGS_builtin = $(CFLAGS_default) @CFLAGS_builtins@ -CXXFLAGS_builtin = $(CXXFLAGS_default) @CFLAGS_builtins@ -OBJCFLAGS_builtin = $(OBJCFLAGS_default) @CFLAGS_builtins@ -LDFLAGS_builtin = -L_builtin = - -CPPFLAGS_builtin_pic = $(CPPFLAGS_builtin) $(CPPFLAGS_pic) -CFLAGS_builtin_pic = $(CFLAGS_builtin) $(CFLAGS_pic) -CXXFLAGS_builtin_pic = $(CXXFLAGS_builtin) $(CXXFLAGS_pic) -OBJCFLAGS_builtin_pic = $(OBJCFLAGS_builtin) $(OBJCFLAGS_pic) -LDFLAGS_builtin_pic = $(LDFLAGS_builtin) $(LDFLAGS_pic) -L_builtin_pic = $(L_builtin) $(L_pic) - -# On Linux and Solaris, activate 64-bit off_t (by default under BSD) -CPPFLAGS_default += -D_FILE_OFFSET_BITS=64 -D__USE_UNIX98 -D_LARGEFILE64_SOURCE -CPPFLAGS_default += -D_REENTRANT -D_THREAD_SAFE -CPPFLAGS_default += -D_GNU_SOURCE - -# Gettext support -CPPFLAGS_default += -DLOCALEDIR=\"$(datadir)/locale\" - -# Data and plugin location -CPPFLAGS_default += -DDATA_PATH=\"@prefix@/share/vlc\" -CPPFLAGS_default += -DPLUGIN_PATH=\"@prefix@/lib/vlc\" - -# Conditional flags that get added to *FLAGS_default -if RELEASE -CPPFLAGS_release = -DHAVE_RELEASE -endif -if DEBUG -CPPFLAGS_debug = -DDEBUG -CFLAGS_debug = -g -endif -if GPROF -CPPFLAGS_gprof = -DGPROF -CFLAGS_gprof = -finstrument-functions -endif -if CPROF -CPPFLAGS_cprof = -DCPROF -CFLAGS_cprof = -pg -endif -if OPTIM -CFLAGS_optim = @CFLAGS_OPTIM@ @CFLAGS_TUNING@ -if DEBUG -else -if GPROF -else -if CPROF -else -CFLAGS_nodebug = @CFLAGS_OPTIM_NODEBUG@ -endif -endif -endif -else -# !OPTIM -CFLAGS_optim = @CFLAGS_NOOPTIM@ -endif - -CPPFLAGS_default += $(CPPFLAGS_release) \ - $(CPPFLAGS_debug) $(CPPFLAGS_gprof) $(CPPFLAGS_cprof) -CFLAGS_default += $(CFLAGS_optim) $(CFLAGS_nodebug) \ - $(CFLAGS_debug) $(CFLAGS_gprof) $(CFLAGS_cprof) -CXXFLAGS_default += $(CFLAGS_optim) $(CFLAGS_nodebug) \ - $(CFLAGS_debug) $(CFLAGS_gprof) $(CFLAGS_cprof) -OBJCFLAGS_default += $(CFLAGS_optim) $(CFLAGS_nodebug) \ - $(CFLAGS_debug) $(CFLAGS_gprof) $(CFLAGS_cprof) - ############################################################################### # Headers ############################################################################### @@ -153,61 +61,78 @@ dist_pkginclude_HEADERS = \ include/vlc/intf.h \ $(NULL) -noinst_HEADERS += $(HEADERS_include) $(HEADERS_include_built) +noinst_HEADERS = $(HEADERS_include) $(HEADERS_include_built) HEADERS_include = \ include/aout_internal.h \ include/audio_output.h \ include/beos_specific.h \ + include/charset.h \ + include/codecs.h \ include/configuration.h \ include/darwin_specific.h \ - include/codecs.h \ - include/error.h \ - include/encoder.h \ - include/input_ext-dec.h \ - include/input_ext-intf.h \ - include/input_ext-plugins.h \ - include/interface.h \ include/intf_eject.h \ include/iso_lang.h \ - include/httpd.h \ include/main.h \ include/mmx.h \ include/modules.h \ include/modules_inner.h \ include/mtime.h \ - include/netutils.h \ include/network.h \ + include/osd.h \ include/os_specific.h \ - include/stream_control.h \ + include/snapshot.h \ include/stream_output.h \ include/variables.h \ - include/video.h \ include/video_output.h \ + include/vlc_access.h \ + include/vlc_bits.h \ + include/vlc_block.h \ + include/vlc_block_helper.h \ + include/vlc_codec.h \ include/vlc_common.h \ include/vlc_config.h \ include/vlc_cpu.h \ + include/vlc_demux.h \ + include/vlc_error.h \ + include/vlc_es.h \ + include/vlc_es_out.h \ + include/vlc_filter.h \ + include/vlc_config_cat.h \ + include/vlc_httpd.h \ + include/vlc_tls.h \ + include/vlc_image.h \ + include/vlc_input.h \ + include/vlc_interface.h \ + include/vlc_keys.h \ include/vlc_messages.h \ + include/vlc_meta.h \ include/vlc_objects.h \ include/vlc_playlist.h \ - include/vlc_threads.h \ + include/vlc_spu.h \ + include/vlc_stream.h \ include/vlc_threads_funcs.h \ + include/vlc_threads.h \ + include/vlc_video.h \ + include/vlc_vlm.h \ + include/vlc_vod.h \ + include/vlc_xml.h \ + include/vout_synchro.h \ include/win32_specific.h \ - include/osd.h \ $(NULL) HEADERS_include_built = \ include/vlc_symbols.h \ $(NULL) -include/vlc_symbols.h: Makefile $(HEADERS_include) - ./toolbox --update-includes $(BUILTINS) - -src/misc/modules_plugin.h: Makefile src/misc/modules_plugin.h.in $(HEADERS_include) - ./toolbox --update-includes $(BUILTINS) +# Common dependencies for these 3 files : Makefile vlc-config +# Specific dependencies : +# include/vlc_symbols.h: $(HEADERS_include) +# src/misc/modules_plugin.h: src/misc/modules_plugin.h.in $(HEADERS_include) +# src/misc/modules_builtin.h: src/misc/modules_builtin.h.in -src/misc/modules_builtin.h: Makefile src/misc/modules_builtin.h.in - ./toolbox --update-includes $(BUILTINS) +include/vlc_symbols.h src/misc/modules_plugin.h src/misc/modules_builtin.h: Makefile $(HEADERS_include) vlc-config src/misc/modules_plugin.h.in src/misc/modules_builtin.h.in + srcdir=$(srcdir) $(srcdir)/toolbox --update-includes # These dependencies are mandatory $(SOURCES): include/vlc_symbols.h @@ -218,7 +143,7 @@ $(SOURCES_libvlc): src/misc/modules_plugin.h src/misc/modules_builtin.h $(LIB_in ############################################################################### intl/libintl.a: FORCE - cd intl && $(MAKE) + cd $(top_builddir)/intl && $(MAKE) $(AM_MAKEFLAGS) if BUILD_INTL LIB_intl = intl/libintl.a @@ -232,27 +157,77 @@ EXTRA_DIST += \ extras/MacOSX/Resources/English.lproj/MainMenu.nib/classes.nib \ extras/MacOSX/Resources/English.lproj/MainMenu.nib/info.nib \ extras/MacOSX/Resources/English.lproj/MainMenu.nib/objects.nib \ + extras/MacOSX/Resources/English.lproj/About.nib/classes.nib \ + extras/MacOSX/Resources/English.lproj/About.nib/info.nib \ + extras/MacOSX/Resources/English.lproj/About.nib/keyedobjects.nib \ + extras/MacOSX/Resources/English.lproj/Open.nib/classes.nib \ + extras/MacOSX/Resources/English.lproj/Open.nib/info.nib \ + extras/MacOSX/Resources/English.lproj/Open.nib/keyedobjects.nib \ + extras/MacOSX/Resources/English.lproj/Preferences.nib/classes.nib \ + extras/MacOSX/Resources/English.lproj/Preferences.nib/info.nib \ + extras/MacOSX/Resources/English.lproj/Preferences.nib/keyedobjects.nib \ extras/MacOSX/Resources/English.lproj/InfoPlist.strings \ + extras/MacOSX/Resources/a52.icns \ + extras/MacOSX/Resources/aac.icns \ + extras/MacOSX/Resources/asf.icns \ + extras/MacOSX/Resources/asx.icns \ + extras/MacOSX/Resources/avi.icns \ + extras/MacOSX/Resources/bin.icns \ + extras/MacOSX/Resources/cue.icns \ + extras/MacOSX/Resources/dat.icns \ extras/MacOSX/Resources/divx.icns \ + extras/MacOSX/Resources/dv.icns \ extras/MacOSX/Resources/generic.icns \ + extras/MacOSX/Resources/m3u.icns \ + extras/MacOSX/Resources/mov.icns \ + extras/MacOSX/Resources/mp3.icns \ + extras/MacOSX/Resources/mp4.icns \ extras/MacOSX/Resources/mpeg.icns \ extras/MacOSX/Resources/mpeg1.icns \ extras/MacOSX/Resources/mpeg2.icns \ extras/MacOSX/Resources/mpeg4.icns \ + extras/MacOSX/Resources/mpg.icns \ + extras/MacOSX/Resources/ogg.icns \ + extras/MacOSX/Resources/ogm.icns \ + extras/MacOSX/Resources/pls.icns \ + extras/MacOSX/Resources/srt.icns \ + extras/MacOSX/Resources/sub.icns \ extras/MacOSX/Resources/vlc.icns \ - extras/MacOSX/Resources/back.png \ - extras/MacOSX/Resources/begin.png \ - extras/MacOSX/Resources/end.png \ - extras/MacOSX/Resources/forw.png \ - extras/MacOSX/Resources/list.png \ + extras/MacOSX/Resources/vob.icns \ + extras/MacOSX/Resources/wma.icns \ + extras/MacOSX/Resources/wmv.icns \ extras/MacOSX/Resources/pause.png \ + extras/MacOSX/Resources/pause_blue.png \ extras/MacOSX/Resources/play.png \ - extras/MacOSX/Resources/prefs.png \ - extras/MacOSX/Resources/slow.png \ + extras/MacOSX/Resources/play_blue.png \ extras/MacOSX/Resources/stop.png \ - extras/MacOSX/Resources/vlc_hg.png \ + extras/MacOSX/Resources/stop_blue.png \ + extras/MacOSX/Resources/display.png \ + extras/MacOSX/Resources/display_slider.png \ + extras/MacOSX/Resources/display_track.png \ + extras/MacOSX/Resources/equalizerdrawer_active.png \ + extras/MacOSX/Resources/equalizerdrawer_blue.png \ + extras/MacOSX/Resources/fullscreen_active.png \ + extras/MacOSX/Resources/fullscreen_blue.png \ + extras/MacOSX/Resources/next_active.png \ + extras/MacOSX/Resources/next_blue.png \ + extras/MacOSX/Resources/playlistdrawer_active.png \ + extras/MacOSX/Resources/playlistdrawer_blue.png \ + extras/MacOSX/Resources/previous_active.png \ + extras/MacOSX/Resources/previous_blue.png \ + extras/MacOSX/Resources/skip_forward_active.png \ + extras/MacOSX/Resources/skip_forward_blue.png \ + extras/MacOSX/Resources/skip_previous_active.png \ + extras/MacOSX/Resources/skip_previous_blue.png \ + extras/MacOSX/Resources/volume_high.png \ + extras/MacOSX/Resources/volume_low.png \ + extras/MacOSX/Resources/volumeslider_blue.png \ + extras/MacOSX/Resources/volumeslider_normal.png \ + extras/MacOSX/Resources/volumetrack.png \ + extras/MacOSX/Resources/about_bg.png \ extras/MacOSX/Resources/vlc.scriptSuite \ - extras/MacOSX/Resources/English.lproj/vlc.scriptTerminology \ + extras/MacOSX/Resources/vlc.scriptTerminology \ + extras/MacOSX/Resources/README \ extras/MacOSX/vlc.pbproj/project.pbxproj \ extras/MacOSX/macosx-dmg \ $(NULL) @@ -272,37 +247,40 @@ EXTRA_DIST += \ evc/libvlc.vcp.in \ evc/vlc.vcp.in \ evc/plugins.vcp.in \ - evc/vlc.c \ + evc/errno.h \ evc/config.h.in \ evc/modules_builtin_evc.h \ $(NULL) -show-libvlc-sources: FORCE - @echo X: $(SOURCES_libvlc_common) $(SOURCES_libvlc_win32) $(SOURCES_libvlc_dirent) $(SOURCES_libvlc_getopt) - -show-libvlc-headers: FORCE - @echo X: $(HEADERS_include) $(HEADERS_include_built) - -show-libvlc-pkg-headers: FORCE - @echo X: $(dist_pkginclude_HEADERS) +dist-hook: + cd $(distdir) && srcdir=$(srcdir) $(srcdir)/toolbox --update-vc + distdir=$(distdir) srcdir=$(srcdir) $(srcdir)/toolbox --dist-contrib ############################################################################### # Building libvlc ############################################################################### bin_SCRIPTS = vlc-config +vlc-config: $(top_builddir)/config.status $(top_builddir)/vlc-config.in + cd $(top_builddir) && $(SHELL) ./config.status --file=$@ + -cd $(top_builddir) && chmod 0755 $@ + +$(SOURCES): vlc-config -lib_LIBRARIES += lib/libvlc.a $(LIBRARIES_libvlc_pic) +CLEANFILES = $(BUILT_SOURCES) + +lib_LIBRARIES = lib/libvlc.a $(LIBRARIES_libvlc_pic) lib_libvlc_a_SOURCES = $(SOURCES_libvlc) -lib_libvlc_a_CFLAGS = $(CPPFLAGS_default) -D__VLC__ $(CFLAGS_default) @CFLAGS_vlc@ -lib_libvlc_a_CXXFLAGS = $(CPPFLAGS_default) -D__VLC__ $(CXXFLAGS_default) -lib_libvlc_a_OBJCFLAGS = $(CPPFLAGS_default) -D__VLC__ $(OBJCFLAGS_default) +dist_lib_libvlc_a_SOURCES = src/misc/modules_plugin.h +lib_libvlc_a_CFLAGS = `$(VLC_CONFIG) --cflags vlc` +lib_libvlc_a_CXXFLAGS = `$(VLC_CONFIG) --cxxflags vlc` +lib_libvlc_a_OBJCFLAGS = `$(VLC_CONFIG) --objcflags vlc` lib_libvlc_pic_a_SOURCES = $(SOURCES_libvlc) -lib_libvlc_pic_a_CFLAGS = $(CPPFLAGS_pic) -D__VLC__ $(CFLAGS_pic) @CFLAGS_vlc@ -lib_libvlc_pic_a_CXXFLAGS = $(CPPFLAGS_pic) -D__VLC__ $(CXXFLAGS_pic) -lib_libvlc_pic_a_OBJCFLAGS = $(CPPFLAGS_pic) -D__VLC__ $(OBJCFLAGS_pic) +lib_libvlc_pic_a_CFLAGS = `$(VLC_CONFIG) --cflags vlc pic` +lib_libvlc_pic_a_CXXFLAGS = `$(VLC_CONFIG) --cxxflags vlc pic` +lib_libvlc_pic_a_OBJCFLAGS = `$(VLC_CONFIG) --objcflags vlc pic` if HAVE_BEOS OPT_SOURCES_libvlc_beos = $(SOURCES_libvlc_beos) @@ -313,6 +291,9 @@ endif if HAVE_WIN32 OPT_SOURCES_libvlc_win32 = $(SOURCES_libvlc_win32) endif +if HAVE_WINCE +OPT_SOURCES_libvlc_win32 = $(SOURCES_libvlc_win32) +endif if BUILD_DIRENT OPT_SOURCES_libvlc_dirent = $(SOURCES_libvlc_dirent) endif @@ -320,8 +301,10 @@ if BUILD_GETOPT OPT_SOURCES_libvlc_getopt = $(SOURCES_libvlc_getopt) endif if BUILD_MOZILLA +if !HAVE_WIN32 LIBRARIES_libvlc_pic = lib/libvlc_pic.a endif +endif EXTRA_DIST += \ $(SOURCES_libvlc_beos) \ @@ -345,7 +328,6 @@ SOURCES_libvlc_win32 = \ SOURCES_libvlc_dirent = \ src/extras/dirent.c \ - src/extras/dirent.h \ $(NULL) SOURCES_libvlc_getopt = \ @@ -360,20 +342,32 @@ SOURCES_libvlc_common = \ src/interface/interface.c \ src/interface/intf_eject.c \ src/playlist/playlist.c \ + src/playlist/sort.c \ + src/playlist/loadsave.c \ + src/playlist/view.c \ + src/playlist/item.c \ + src/playlist/item-ext.c \ + src/playlist/services_discovery.c \ + src/input/access.c \ + src/input/clock.c \ + src/input/control.c \ + src/input/decoder.c \ + src/input/demux.c \ + src/input/es_out.c \ src/input/input.c \ - src/input/input_ext-plugins.c \ - src/input/input_ext-dec.c \ - src/input/input_ext-intf.c \ - src/input/input_dec.c \ - src/input/input_programs.c \ - src/input/input_clock.c \ - src/input/input_info.c \ + src/input/input_internal.h \ + src/input/stream.c \ + src/input/mem_stream.c \ + src/input/subtitles.c \ + src/input/var.c \ src/video_output/video_output.c \ src/video_output/vout_pictures.c \ src/video_output/vout_pictures.h \ src/video_output/video_text.c \ - src/video_output/video_text.h \ + src/video_output/video_widgets.c \ src/video_output/vout_subpictures.c \ + src/video_output/vout_synchro.c \ + src/video_output/vout_intf.c \ src/audio_output/common.c \ src/audio_output/dec.c \ src/audio_output/filters.c \ @@ -382,18 +376,27 @@ SOURCES_libvlc_common = \ src/audio_output/output.c \ src/audio_output/intf.c \ src/stream_output/stream_output.c \ + src/stream_output/announce.c \ + src/stream_output/sap.c \ + src/misc/charset.c \ + src/misc/httpd.c \ + src/misc/tls.c \ src/misc/mtime.c \ + src/misc/block.c \ src/misc/modules.c \ src/misc/threads.c \ src/misc/cpu.c \ src/misc/configuration.c \ - src/misc/netutils.c \ + src/misc/image.c \ src/misc/iso_lang.c \ src/misc/iso-639_def.h \ src/misc/messages.c \ src/misc/objects.c \ src/misc/variables.c \ src/misc/error.c \ + src/misc/net.c \ + src/misc/vlm.c \ + src/misc/xml.c \ src/extras/libc.c \ $(NULL) @@ -410,58 +413,261 @@ SOURCES_libvlc = \ # Building vlc ############################################################################### -bin_PROGRAMS += vlc +bin_PROGRAMS = vlc vlc_SOURCES = src/vlc.c -# @AUTOMAKE_SUCKS@ gets expanded to $(L_builtin) $(LDFLAGS_builtin) -# but we don't write it directly, otherwise automake will go amok and eat all -# the memory because of its 2^N crap algorithm. So we fool him. Nuahaha. -vlc_LDADD = lib/libvlc.a $(LDFLAGS_vlc) \ - $(DATA_win32_rc) $(LIB_intl) @AUTOMAKE_SUCKS@ -vlc_CFLAGS = $(CPPFLAGS_default) $(CFLAGS_default) +# Work around a bug in the arm-wince-pe linker +if HAVE_WINCE +vlc_WORKAROUNDLDFLAGS = lib/libvlc.a +endif + +vlc_LDFLAGS = `$(VLC_CONFIG) --libs vlc builtin` $(vlc_WORKAROUNDLDFLAGS) +vlc_LDADD = lib/libvlc.a $(DATA_win32_rc) $(LIB_intl) +vlc_CFLAGS = `$(VLC_CONFIG) --cflags vlc` # We use DEPENDENCIES_vlc instead of vlc_DEPENDENCIES because of an # old automake-1.5 bug (automake/279). -DEPENDENCIES_vlc = lib/libvlc.a $(L_builtin) $(DATA_win32_rc) $(LIB_intl) +DEPENDENCIES_vlc = lib/libvlc.a $(DATA_win32_rc) $(LIB_intl) + +vlc$(EXEEXT): $(vlc_OBJECTS) $(DEPENDENCIES_vlc) stamp-builtin + @rm -f $(top_builddir)/vlc$(EXEEXT) + @case `$(VLC_CONFIG) --linkage vlc builtin` in \ + c++) echo $(CXXLINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) ; $(CXXLINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) ;; \ + objc) echo $(OBJCLINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) ; $(OBJCLINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) ;; \ + c|*) echo $(LINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) ; $(LINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) ;; \ + esac -vlc$(EXEEXT): $(vlc_OBJECTS) $(DEPENDENCIES_vlc) - @rm -f vlc$(EXEEXT) - $(LINK) $(vlc_LDFLAGS) $(vlc_OBJECTS) $(vlc_LDADD) $(LIBS) if HAVE_BEOS - xres -o $@ ./share/vlc_beos.rsrc - mimeset -f $@ +noinst_DATA = vlc-bundle +vlc-bundle: vlc + rm -Rf $(top_builddir)/vlc-bundle ; mkdir -p $(top_builddir)/vlc-bundle + cp $(top_builddir)/vlc $(top_builddir)/vlc-bundle/ + xres -o $(top_builddir)/vlc-bundle/vlc $(srcdir)/share/vlc_beos.rsrc + for i in "" `$(VLC_CONFIG) --target plugin` ; do \ + if test -n "$$i" ; then \ + mkdir -p $(top_builddir)/vlc-bundle/plugins ; \ + cp "$$i$(LIBEXT)" $(top_builddir)/vlc-bundle/plugins/ ; \ + fi ; \ + done + if test -d $(top_builddir)/extras/contrib/vlc-lib ; then \ + mkdir -p $(top_builddir)/vlc-bundle/lib ; \ + for i in $(top_builddir)/extras/contrib/vlc-lib/*.so ; do \ + cp $$i $(top_builddir)/vlc-bundle/lib/ ; \ + done ; \ + fi + for i in $(ALL_LINGUAS); do \ + mkdir -p "$(top_builddir)/vlc-bundle/locale/$$i/LC_MESSAGES" ; \ + cp "$(top_builddir)/po/$$i.gmo" \ + "$(top_builddir)/vlc-bundle/locale/$$i/LC_MESSAGES/vlc.mo" || true ; \ + done + find $(top_builddir)/vlc-bundle -type f -exec mimeset -f "{}" \; endif -# Install the symlinks +# Install the modules and the symlinks install-exec-local: - for i in dummy $(ALIASES) ; do if test "x$$i" != "xdummy" ; then \ - rm -f $(DESTDIR)$(bindir)/$$i && \ - ln -s vlc $(DESTDIR)$(bindir)/$$i ; \ + for i in "" `$(VLC_CONFIG) --target plugin` ; do if test -n "$$i" ; then \ + echo $(INSTALL) -m 755 "$$i$(LIBEXT)" "$(DESTDIR)$(libdir)/vlc/`echo $$i | sed -e 's,.*modules/\([^/]*\).*,\1,'`" ; \ + $(INSTALL) -m 755 "$$i$(LIBEXT)" "$(DESTDIR)$(libdir)/vlc/`echo $$i | sed -e 's,.*modules/\([^/]*\).*,\1,'`" ; \ + fi ; done + for i in "" `$(VLC_CONFIG) --target builtin` ; do if test -n "$$i" ; then \ + echo $(INSTALL) -m 644 "$$i" "$(DESTDIR)$(libdir)/vlc" ; \ + $(INSTALL) -m 644 "$$i" "$(DESTDIR)$(libdir)/vlc" ; \ + fi ; done +if BUILD_MOZILLA + for i in "" `$(VLC_CONFIG) --target builtin pic` ; do if test -n "$$i" ; then \ + echo $(INSTALL) -m 644 "$$i" "$(DESTDIR)$(libdir)/vlc" ; \ + $(INSTALL) -m 644 "$$i" "$(DESTDIR)$(libdir)/vlc" ; \ + fi ; done +endif + for i in "" $(ALIASES) ; do if test -n "$$i" ; then \ + rm -f "$(DESTDIR)$(bindir)/$$i" && \ + ln -s vlc "$(DESTDIR)$(bindir)/$$i" ; \ fi ; done if HAVE_DARWIN # Create the MacOS X app vlc_app_DATA = VLC.app vlc_appdir = $(bindir) -VLC.app: vlc $(PLUGIN_FILES) - rm -Rf VLC.app - cd extras/MacOSX ; pbxbuild | grep -v '^[ \t]' | grep -v "^$$" - cp -r extras/MacOSX/build/vlc.bundle ./VLC.app - $(INSTALL) -d VLC.app/Contents/MacOS - $(INSTALL) vlc VLC.app/Contents/MacOS/VLC - $(INSTALL) -d VLC.app/Contents/MacOS/modules - for i in dummy $(PLUGIN_FILES) ; do if test "x$$i" != "xdummy" ; then \ - $(INSTALL) $$i VLC.app/Contents/MacOS/modules/ ; \ - fi ; done - $(INSTALL) -d VLC.app/Contents/MacOS/share - $(INSTALL) -m 644 share/*.psf share/*.rle VLC.app/Contents/MacOS/share - $(INSTALL) -d VLC.app/Contents/MacOS/locale +# VLC-release.app is the old VLC.app target +VLC-release.app: vlc + @if test -e "$(top_builddir)/tmp"; then \ + echo "Error: please remove $(top_builddir)/tmp, it is in the way"; \ + false; \ + else \ + echo "OK."; mkdir -p "$(top_builddir)/tmp/extras"; \ + fi + rm -Rf $(top_builddir)/VLC-release.app + cp -r $(srcdir)/extras/MacOSX $(top_builddir)/tmp/extras + for i in AUTHORS COPYING README.MacOSX.rtf THANKS; do \ + cp "$(srcdir)/$$i" $(top_builddir)/tmp; \ + done + mkdir -p $(top_builddir)/tmp/modules/audio_output + cp $(srcdir)/modules/audio_output/coreaudio.c \ + $(top_builddir)/tmp/modules/audio_output/coreaudio.c + mkdir -p $(top_builddir)/tmp/modules/gui/macosx + for i in \ + about.h \ + about.m \ + applescript.h \ + applescript.m \ + controls.h \ + controls.m \ + equalizer.h \ + equalizer.m \ + intf.h \ + intf.m \ + macosx.m \ + misc.h \ + misc.m \ + open.h \ + open.m \ + output.h \ + output.m \ + playlist.h \ + playlist.m \ + playlistinfo.h \ + playlistinfo.m \ + prefs_widgets.h \ + prefs_widgets.m \ + prefs.h \ + prefs.m \ + vout.h \ + voutqt.m \ + voutgl.m \ + vout.m; do \ + cp "$(srcdir)/modules/gui/macosx/$$i" \ + $(top_builddir)/tmp/modules/gui/macosx; \ + done + cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)' + cp -r $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \ + $(top_builddir)/VLC-release.app + rm -Rf $(top_builddir)/tmp + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS + $(INSTALL) $(top_builddir)/vlc \ + $(top_builddir)/VLC-release.app/Contents/MacOS/VLC + ln -sf ./VLC $(top_builddir)/VLC-release.app/Contents/MacOS/clivlc + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS/modules + for i in "" `$(VLC_CONFIG) --target plugin` ; do \ + if test -n "$$i" ; \ + then $(INSTALL) "$$i$(LIBEXT)" \ + "$(top_builddir)/VLC-release.app/Contents/MacOS/modules" ; \ + fi ; done + if test -d $(top_builddir)/extras/contrib/vlc-lib; then \ + mkdir -p $(top_builddir)/VLC-release.app/Contents/MacOS/lib ; \ + for i in $(top_builddir)/extras/contrib/vlc-lib/*.dylib ; do \ + $(INSTALL) -m 644 $${i} $(top_builddir)/VLC-release.app/Contents/MacOS/lib/vlc_`basename $${i}` ; \ + done ; \ + fi + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS/share + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS/share/http + for i in $(srcdir)/share/http/* ; do \ + $(INSTALL) -m 644 $${i} $(top_builddir)/VLC-release.app/Contents/MacOS/share/http/`basename $${i}` ; \ + done ; \ + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS/share/http/vlm + for i in $(srcdir)/share/http/vlm/* ; do \ + $(INSTALL) -m 644 $${i} $(top_builddir)/VLC-release.app/Contents/MacOS/share/http/vlm/`basename $${i}` ; \ + done ; \ + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS/share/http/admin + for i in $(srcdir)/share/http/admin/* ; do \ + $(INSTALL) -m 644 $${i} $(top_builddir)/VLC-release.app/Contents/MacOS/share/http/admin/`basename $${i}` ; \ + done ; \ + $(INSTALL) -m 644 $(srcdir)/share/http/admin/.access $(top_builddir)/VLC-release.app/Contents/MacOS/share/http/admin/.access + $(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS/locale + for i in $(ALL_LINGUAS); do \ + mkdir -p $(top_builddir)/VLC-release.app/Contents/MacOS/locale/$${i}/LC_MESSAGES ; \ + cp $(srcdir)/po/$${i}.gmo $(top_builddir)/VLC-release.app/Contents/MacOS/locale/$${i}/LC_MESSAGES/vlc.mo || true ; \ + mkdir -p $(top_builddir)/VLC-release.app/Contents/Resources/$${i}.lproj ; \ + ln -sf ../English.lproj/InfoPlist.strings \ + $(top_builddir)/VLC-release.app/Contents/Resources/$${i}.lproj ; \ + ln -sf ../English.lproj/MainMenu.nib \ + $(top_builddir)/VLC-release.app/Contents/Resources/$${i}.lproj ; \ + ln -sf ../English.lproj/vlc.scriptTerminology \ + $(top_builddir)/VLC-release.app/Contents/Resources/$${i}.lproj ; \ + done + printf "APPLVLC#" >| $(top_builddir)/VLC-release.app/Contents/PkgInfo + +VLC.app: vlc + @if test -e "$(top_builddir)/tmp"; then \ + echo "Error: please remove $(top_builddir)/tmp, it is in the way"; \ + false; \ + else \ + echo "OK."; mkdir -p "$(top_builddir)/tmp/extras"; \ + fi + rm -Rf $(top_builddir)/VLC.app + cp -r $(srcdir)/extras/MacOSX $(top_builddir)/tmp/extras + for i in AUTHORS COPYING README.MacOSX.rtf THANKS; do \ + cp "$(srcdir)/$$i" $(top_builddir)/tmp; \ + done + mkdir -p $(top_builddir)/tmp/modules/audio_output + cp $(srcdir)/modules/audio_output/coreaudio.c \ + $(top_builddir)/tmp/modules/audio_output/coreaudio.c + mkdir -p $(top_builddir)/tmp/modules/gui/macosx + for i in \ + about.h \ + about.m \ + applescript.h \ + applescript.m \ + controls.h \ + controls.m \ + equalizer.h \ + equalizer.m \ + intf.h \ + intf.m \ + macosx.m \ + misc.h \ + misc.m \ + open.h \ + open.m \ + output.h \ + output.m \ + playlist.h \ + playlist.m \ + playlistinfo.h \ + playlistinfo.m \ + prefs_widgets.h \ + prefs_widgets.m \ + prefs.h \ + prefs.m \ + vout.h \ + voutqt.m \ + voutgl.m \ + vout.m; do \ + cp "$(srcdir)/modules/gui/macosx/$$i" \ + $(top_builddir)/tmp/modules/gui/macosx; \ + done + cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)' + cp -r $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \ + $(top_builddir)/VLC.app + rm -Rf $(top_builddir)/tmp + $(INSTALL) -d $(top_builddir)/VLC.app/Contents/MacOS + $(INSTALL) $(top_builddir)/vlc \ + $(top_builddir)/VLC.app/Contents/MacOS/VLC + ln -sf ./VLC $(top_builddir)/VLC.app/Contents/MacOS/clivlc + $(INSTALL) -d $(top_builddir)/VLC.app/Contents/MacOS/modules + for i in "" `$(VLC_CONFIG) --target plugin` ; do \ + if test -n "$$i" ; \ + then ln -sfn "`pwd`/$$i$(LIBEXT)" \ + "$(top_builddir)/VLC.app/Contents/MacOS/modules" ; \ + fi ; done + if test -d $(top_builddir)/extras/contrib/vlc-lib; then \ + mkdir -p $(top_builddir)/VLC.app/Contents/MacOS/lib ; \ + for i in $(top_builddir)/extras/contrib/vlc-lib/*.dylib ; do \ + ln -sfn `pwd`/$${i} $(top_builddir)/VLC.app/Contents/MacOS/lib/vlc_`basename $${i}` ; \ + done ; \ + fi + ln -sfn `pwd`/share $(top_builddir)/VLC.app/Contents/MacOS/ + $(INSTALL) -d $(top_builddir)/VLC.app/Contents/MacOS/locale for i in $(ALL_LINGUAS); do \ - mkdir -p VLC.app/Contents/MacOS/locale/$${i%}/LC_MESSAGES ; \ - cp po/$${i}.gmo VLC.app/Contents/MacOS/locale/$${i}/LC_MESSAGES/vlc.mo || true ; \ + mkdir -p $(top_builddir)/VLC.app/Contents/MacOS/locale/$${i}/LC_MESSAGES ; \ + ln -sfn `pwd`/po/$${i}.gmo $(top_builddir)/VLC.app/Contents/MacOS/locale/$${i}/LC_MESSAGES/vlc.mo || true ; \ + mkdir -p $(top_builddir)/VLC.app/Contents/Resources/$${i}.lproj ; \ + ln -sf ../English.lproj/InfoPlist.strings \ + $(top_builddir)/VLC.app/Contents/Resources/$${i}.lproj ; \ + ln -sf ../English.lproj/MainMenu.nib \ + $(top_builddir)/VLC.app/Contents/Resources/$${i}.lproj ; \ done - echo -n "APPLVLC#" >| VLC.app/Contents/PkgInfo + printf "APPLVLC#" >| $(top_builddir)/VLC.app/Contents/PkgInfo endif if HAVE_WIN32 @@ -469,9 +675,27 @@ DATA_win32_rc = $(noinst_share_vlc_win32_rc_DATA) noinst_share_vlc_win32_rc_DATA = share/vlc_win32_rc.$(OBJEXT) noinst_share_vlc_win32_rcdir = $(libdir) share/vlc_win32_rc.$(OBJEXT): share/vlc_win32_rc.rc - $(WINDRES) --include-dir share -i $< -o $@ + $(WINDRES) -DVERSION=$(VERSION) -DVERSION_NUMBER=`echo $(VERSION).0.0.0 | sed 's/\([0-9]*\)[^.]*\.*\([0-9]*\)[^.]*\.*\([0-9]*\)[^.]*\.*\([0-9]*\).*/\1,\2,\3,\4/'` --include-dir $(srcdir)/share -i $< -o $@ endif +############################################################################### +# Building specific source packages +############################################################################### + +dist-woody: distdir + $(remove_distdir_woody) + mv $(distdir) $(PACKAGE)-woody-$(VERSION) + $(srcdir)/toolbox --make-woody $(PACKAGE)-woody-$(VERSION) + $(AMTAR) chof - $(PACKAGE)-woody-$(VERSION) \ + | GZIP=$(GZIP_ENV) gzip -c >$(PACKAGE)-woody-$(VERSION).tar.gz + $(remove_distdir_woody) + +remove_distdir_woody = \ + { test ! -d $(PACKAGE)-woody-$(VERSION) \ + || { find $(PACKAGE)-woody-$(VERSION) -type d ! -perm -200 \ + -exec chmod u+w {} ';' \ + && rm -fr $(PACKAGE)-woody-$(VERSION); }; } + ############################################################################### # Building architecture-specific binary packages ############################################################################### @@ -479,185 +703,225 @@ endif # 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. # +package-win32-base: # Check that tmp isn't in the way -package-win32: - @if test -e tmp; then \ - echo "Error: please remove ./tmp, it is in the way"; false; \ + @if test -e "$(top_builddir)/vlc-${VERSION}"; then \ + echo "Error: please remove $(top_builddir)/vlc-${VERSION}, it is in the way"; \ + false; \ else \ - echo "OK."; mkdir tmp; \ + echo "OK."; mkdir -p "$(top_builddir)/vlc-${VERSION}"; \ fi -# Create installation script - cp install-win32 tmp/nsi + # Copy relevant files - cp vlc.exe tmp/ - $(STRIP) tmp/vlc.exe - cp INSTALL.win32 tmp/INSTALL.txt ; unix2dos tmp/INSTALL.txt + cp "$(srcdir)/vlc.win32.nsi" "$(top_builddir)/vlc-${VERSION}/" + cp "$(top_builddir)/vlc$(EXEEXT)" "$(top_builddir)/vlc-${VERSION}/" + cp "$(top_srcdir)/vlc.exe.manifest" "$(top_builddir)/vlc-${VERSION}/" + $(STRIP) "$(top_builddir)/vlc-${VERSION}/vlc$(EXEEXT)" + for file in AUTHORS MAINTAINERS THANKS NEWS COPYING README ; \ - do cp $$file tmp/$${file}.txt ; \ - unix2dos tmp/$${file}.txt ; done + do sed 's/@/_AT_/' < "$(srcdir)/$$file" > "$(top_builddir)/vlc-${VERSION}/$${file}.txt" ; \ + unix2dos "$(top_builddir)/vlc-${VERSION}/$${file}.txt" ; done - mkdir tmp/plugins - for i in dummy $(PLUGIN_FILES) ; do if test "x$$i" != "xdummy" ; then \ - $(INSTALL) $$i tmp/plugins/ ; \ - fi ; done + mkdir -p "$(top_builddir)/vlc-${VERSION}/plugins" + for i in "" `$(VLC_CONFIG) --target plugin` ; do \ + if test -n "$$i" ; then \ + $(INSTALL) "$(top_builddir)/$$i$(LIBEXT)" \ + "$(top_builddir)/vlc-${VERSION}/plugins/" ; \ + fi ; done - for i in dummy tmp/plugins/*$(LIBEXT) ; \ - do if test $$i != tmp/plugins/libwin32_plugin$(LIBEXT) \ - -a $$i != dummy ; then $(STRIP) $$i ; fi ; done - mkdir tmp/share - cp share/*.rle tmp/share/ ; + for i in "" $(top_builddir)/vlc-${VERSION}/plugins/*$(LIBEXT) ; \ + do if test -n "$$i" ; then $(STRIP) "$$i" ; fi ; done - mkdir tmp/locale + mkdir $(top_builddir)/vlc-${VERSION}/locale for i in $(ALL_LINGUAS); do \ - mkdir -p tmp/locale/$${i}/LC_MESSAGES ; \ - cp po/$${i}.gmo tmp/locale/$${i}/LC_MESSAGES/vlc.mo || true ; \ + mkdir -p "$(top_builddir)/vlc-${VERSION}/locale/$${i}/LC_MESSAGES" ; \ + cp "$(srcdir)/po/$${i}.gmo" \ + "$(top_builddir)/vlc-${VERSION}/locale/$${i}/LC_MESSAGES/vlc.mo" \ + || true ; \ done - cd doc/faq ; $(MAKE) html ; cd ../.. ; - cp doc/faq/index.html tmp/FAQ.htm ; + mkdir -p $(top_builddir)/vlc-${VERSION}/skins/fonts + for i in $(srcdir)/share/skins2/fonts/*.*; do \ + cp $$i $(top_builddir)/vlc-${VERSION}/skins/fonts/ || true ; \ + done + for i in $(srcdir)/share/skins2/*.*; do \ + cp $$i $(top_builddir)/vlc-${VERSION}/skins/ || true ; \ + done + mkdir -p "$(top_builddir)/vlc-${VERSION}/http/admin" + mkdir -p "$(top_builddir)/vlc-${VERSION}/http/vlm" + cp $(srcdir)/share/http/*.html $(top_builddir)/vlc-${VERSION}/http/ ; + unix2dos $(top_builddir)/vlc-${VERSION}/http/*.html ; + cp $(srcdir)/share/http/*.css $(top_builddir)/vlc-${VERSION}/http/ ; + unix2dos $(top_builddir)/vlc-${VERSION}/http/*.css ; + cp $(srcdir)/share/http/*.png $(top_builddir)/vlc-${VERSION}/http/ + cp $(srcdir)/share/http/*.ico $(top_builddir)/vlc-${VERSION}/http/ ; + cp $(srcdir)/share/http/admin/*.html \ + $(top_builddir)/vlc-${VERSION}/http/admin/ ; + unix2dos $(top_builddir)/vlc-${VERSION}/http/admin/*.html ; + cp $(srcdir)/share/http/admin/dboxfiles.html \ + $(top_builddir)/vlc-${VERSION}/http/admin/ ; + cp $(srcdir)/share/http/admin/.access \ + $(top_builddir)/vlc-${VERSION}/http/admin/ ; + unix2dos $(top_builddir)/vlc-${VERSION}/http/admin/.access ; + cp $(srcdir)/share/http/vlm/*.html \ + $(top_builddir)/vlc-${VERSION}/http/vlm/ ; + unix2dos $(top_builddir)/vlc-${VERSION}/http/vlm/*.html ; + + cp $(srcdir)/share/vlc48x48.ico $(top_builddir)/vlc-${VERSION}/ ; + + mkdir -p "$(top_builddir)/vlc-${VERSION}/mozilla" +if BUILD_MOZILLA + cp $(top_builddir)/mozilla/*$(LIBEXT) $(top_builddir)/vlc-${VERSION}/mozilla/ ; + $(STRIP) $(top_builddir)/vlc-${VERSION}/mozilla/*$(LIBEXT); + cp $(top_builddir)/mozilla/vlcintf.xpt $(top_builddir)/vlc-${VERSION}/mozilla/ ; +endif + + mkdir -p "$(top_builddir)/vlc-${VERSION}/activex" +if BUILD_ACTIVEX + cp $(top_builddir)/activex/README.TXT $(top_builddir)/vlc-${VERSION}/activex/ ; + cp $(top_builddir)/activex/test.html $(top_builddir)/vlc-${VERSION}/activex/ ; + unix2dos $(top_builddir)/vlc-${VERSION}/activex/* ; + + cp $(top_builddir)/activex/*$(LIBEXT) $(top_builddir)/vlc-${VERSION}/activex/ ; + $(STRIP) $(top_builddir)/vlc-${VERSION}/activex/*$(LIBEXT); +endif +# Rebase all those DLLs to speed up loading (need cygwin rebase) + if [ -x rebase ]; then \ + find $(top_builddir)/vlc-${VERSION} -type f -name '*.dll' -print | rebase -b 0x70000000 -T -; \ + fi + +package-win32-base-exe: +# Create package + wine C:/Program\ Files/NSIS/makensis.exe \ + /DVERSION=${VERSION} $(top_builddir)/vlc-${VERSION}/vlc.win32.nsi + +package-win32-base-exe-cygwin: +# Create package + C:/Program\ Files/NSIS/makensis.exe \ + /DVERSION=${VERSION} $(top_builddir)/vlc-${VERSION}/vlc.win32.nsi + +package-win32-base-exe-linux: +# Create package + makensis -DVERSION=${VERSION} $(top_builddir)/vlc-${VERSION}/vlc.win32.nsi + +package-win32-base-zip: # Create package - wine ~/.wine/fake_windows/Program\ Files/NSIS/makensis.exe -- /DVERSION=${VERSION} tmp/nsi + zip -r vlc-${VERSION}-win32.zip vlc-${VERSION} + +package-win32-exe: package-win32-base package-win32-base-exe +# Clean up + rm -Rf $(top_builddir)/vlc-${VERSION} + +package-win32-exe-linux: package-win32-base package-win32-base-exe-linux +# Clean up + rm -Rf $(top_builddir)/vlc-${VERSION} + +package-win32-zip: package-win32-base package-win32-base-zip +# Clean up + rm -Rf $(top_builddir)/vlc-${VERSION} + +package-win32: package-win32-base package-win32-base-exe package-win32-base-zip # Clean up - rm -Rf tmp + rm -Rf $(top_builddir)/vlc-${VERSION} package-beos: # Check that tmp isn't in the way - @if test -e tmp; then \ - echo "Error: please remove ./tmp, it is in the way"; false; \ + @if test -e $(srcdir)/tmp; then \ + echo "Error: please remove $(srcdir)/tmp, it is in the way"; \ + false ; \ else \ - echo "OK."; mkdir tmp; \ + echo "OK." ; mkdir $(srcdir)/tmp ; \ fi - -# Create dir - mkdir -p tmp/vlc/share + # Copy relevant files - cp vlc tmp/vlc/ - $(STRIP) tmp/vlc/vlc - xres -o tmp/vlc/vlc ./share/vlc_beos.rsrc - cp AUTHORS COPYING ChangeLog README THANKS NEWS tmp/vlc/ - for file in default8x16.psf default8x9.psf ; \ - do cp share/$$file tmp/vlc/share/ ; done - mkdir tmp/vlc/plugins - for i in dummy $(PLUGIN_FILES) ; do if test "x$$i" != "xdummy" ; then \ - $(INSTALL) $$i tmp/vlc/plugins/ ; \ - fi ; done - for i in dummy tmp/vlc/plugins/*$(LIBEXT) ; do if test $$i != dummy ; then $(STRIP) $$i ; fi ; done -# Create package - mv tmp/vlc tmp/vlc-${VERSION} - (cd tmp ; find vlc-${VERSION} | \ - zip -9 -@ vlc-${VERSION}-BeOS-x86.zip ) - mv tmp/vlc-${VERSION}-BeOS-x86.zip . + mkdir -p $(srcdir)/tmp/vlc ; + cd $(srcdir) && cp -R vlc-bundle/* AUTHORS COPYING ChangeLog README \ + THANKS NEWS tmp/vlc/ ; + +# Create debug package + xres -o $(srcdir)/tmp/vlc/vlc $(srcdir)/share/vlc_beos.rsrc ; + find $(srcdir)/tmp/vlc -exec mimeset -f {} \; ; + mv $(srcdir)/tmp/vlc $(srcdir)/tmp/vlc-${VERSION} ; + (cd $(srcdir)/tmp ; zip -9 -r vlc-${VERSION}-BeOS-debug.zip vlc-${VERSION} ) + mv $(srcdir)/tmp/vlc-${VERSION}-BeOS-debug.zip $(srcdir)/ ; + mv $(srcdir)/tmp/vlc-${VERSION} $(srcdir)/tmp/vlc ; + +# Create normal package + $(STRIP) --strip-debug --strip-unneeded $(srcdir)/tmp/vlc/vlc ; + find $(srcdir)/tmp/vlc -name 'lib*.so' -exec $(STRIP) \ + --strip-debug --strip-unneeded "{}" \; ; + xres -o $(srcdir)/tmp/vlc/vlc $(srcdir)/share/vlc_beos.rsrc ; + find $(srcdir)/tmp/vlc -exec mimeset -f {} \; ; + mv $(srcdir)/tmp/vlc $(srcdir)/tmp/vlc-${VERSION} ; + (cd $(srcdir)/tmp ; zip -9 -r vlc-${VERSION}-BeOS.zip vlc-${VERSION} ) + mv $(srcdir)/tmp/vlc-${VERSION}-BeOS.zip $(srcdir)/ ; + # Clean up - rm -Rf tmp + rm -Rf $(srcdir)/tmp ; 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; \ + @if test -e "$(top_builddir)/tmp"; then \ + echo "Error: please remove $(top_builddir)/tmp, it is in the way"; \ + false; \ else \ - echo "OK."; mkdir tmp; \ + echo "OK."; mkdir -p "$(top_builddir)/tmp"; \ fi # Copy relevant files - cp -R VLC.app tmp/ - cp AUTHORS COPYING ChangeLog README README.MacOSX.rtf THANKS NEWS tmp/ + cp -R "$(top_builddir)/VLC-release.app" "$(top_builddir)/tmp/VLC.app" + cd "$(srcdir)" && cp AUTHORS COPYING ChangeLog README README.MacOSX.rtf THANKS NEWS $(top_builddir)/tmp/ # Create disk image - ./extras/MacOSX/macosx-dmg 18 "vlc-${VERSION}" tmp/* + $(srcdir)/extras/MacOSX/macosx-dmg "vlc-${VERSION}" $(top_builddir)/tmp # Clean up - rm -Rf tmp - -############################################################################### -# Building the Mozilla plugin -############################################################################### + rm -Rf $(top_builddir)/tmp -noinst_LIBRARIES += $(noinst_LIBRARIES_mozilla) - -MOSTLYCLEANFILES += $(LIBRARIES_mozilla) - -EXTRA_DIST += $(SOURCES_mozilla) mozilla/vlcintf.idl - -BUILT_SOURCES += $(BUILT_SOURCES_mozilla) - -SOURCES_mozilla = \ - mozilla/vlcshell.cpp \ - mozilla/vlcplugin.cpp \ - mozilla/vlcplugin.h \ - mozilla/vlcpeer.cpp \ - mozilla/vlcpeer.h \ - mozilla/classinfo.h \ - $(SOURCES_mozilla_win32) \ - $(SOURCES_mozilla_unix) \ - $(NULL) - -# Under Win32, Mozilla plugins need to be named NP******.DLL, but under Unix -# the common naming scheme is lib******plugin.so. Also, we need npwin.cpp -# under Win32 and npunix.c under Unix. -if HAVE_WIN32 -LIBRARIES_mozilla = mozilla/npvlc$(LIBEXT) -SOURCES_mozilla_win32 = mozilla/npwin.cpp -CPPFLAGS_mozilla_EXTRA = -DXP_WIN -DXP_WIN32 -else -LIBRARIES_mozilla = mozilla/libvlcplugin$(LIBEXT) -SOURCES_mozilla_unix = mozilla/npunix.c -endif - -if BUILD_MOZILLA -if UNTRUE -noinst_LIBRARIES_mozilla = mozilla/libplugin.a -endif +package-translations: + @if test -e "$(srcdir)/vlc-translations-${VERSION}"; then \ + echo "Error: please remove $(srcdir)/vlc-translations-${VERSION}, it is in the way"; \ + false; \ + else \ + echo "OK."; mkdir -p "$(srcdir)/vlc-translations-${VERSION}"; \ + fi +# Copy translations + for i in $(ALL_LINGUAS); do \ + cp "$(srcdir)/po/$${i}.po" \ + "$(srcdir)/vlc-translations-${VERSION}/$${i}.po" \ + || true ; \ + done + cp "$(srcdir)/doc/translations.txt" \ + "$(srcdir)/vlc-translations-${VERSION}/README.txt" -mozilla_libplugin_a_SOURCES = $(SOURCES_mozilla) -mozilla_libplugin_a_CFLAGS = $(CPPFLAGS_pic) $(CFLAGS_pic) \ - $(CPPFLAGS_mozilla) $(CFLAGS_mozilla) \ - $(CPPFLAGS_mozilla_EXTRA) -mozilla_libplugin_a_CXXFLAGS = $(CPPFLAGS_pic) $(CXXFLAGS_pic) \ - $(CPPFLAGS_mozilla) $(CXXFLAGS_mozilla) \ - $(CPPFLAGS_mozilla_EXTRA) -mozilla_libplugin_a_DEPENDENCIES = lib/libvlc_pic.a $(L_builtin_pic) $(DATA_npvlc_rc) - -BUILT_SOURCES_mozilla = mozilla/vlcintf.h -$(SOURCES_mozilla): mozilla/vlcintf.h - -mozilla_plugin_DATA = $(LIBRARIES_mozilla) -mozilla_plugindir = $(libdir)/mozilla/plugins -$(LIBRARIES_mozilla): $(mozilla_libplugin_a_OBJECTS) \ - $(mozilla_libplugin_a_DEPENDENCIES) \ - $(L_builtin_pic) - $(CXXLINK) $(mozilla_libplugin_a_OBJECTS) $(DATA_npvlc_rc) \ - lib/libvlc_pic.a $(L_builtin_pic) -shared $(LDFLAGS) \ - $(LDFLAGS_vlc) $(LDFLAGS_mozilla) $(LDFLAGS_builtin_pic) - -mozilla_vlcintf_xpt_DATA = mozilla/vlcintf.xpt -mozilla_vlcintf_xptdir = $(libdir)/mozilla/components -mozilla/vlcintf.xpt: Makefile mozilla/vlcintf.idl - $(XPIDL) -I/usr/share/idl/mozilla -m typelib \ - -o mozilla/vlcintf mozilla/vlcintf.idl - -mozilla/vlcintf.h: Makefile mozilla/vlcintf.idl - $(XPIDL) -I/usr/share/idl/mozilla -m header \ - -o mozilla/vlcintf mozilla/vlcintf.idl + echo "#!/bin/sh" >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo "" >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo 'if test $$# != 1; then' >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo " echo \"Usage: convert-po.sh <.po file>\"" >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo " exit 1" >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo "fi" >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo "" >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" + echo 'msgfmt --statistics -o vlc.mo $$1' >>"$(srcdir)/vlc-translations-$(VERSION)/convert.po.sh" -if HAVE_WIN32 -DATA_npvlc_rc = $(noinst_mozilla_npvlc_rc_DATA) -noinst_mozilla_npvlc_rc_DATA = mozilla/npvlc_rc.$(OBJEXT) -noinst_mozilla_npvlc_rcdir = $(libdir) -mozilla/npvlc_rc.$(OBJEXT): mozilla/npvlc_rc.rc - $(WINDRES) --include-dir mozilla -i $< -o $@ -endif -endif + $(AMTAR) chof - $(srcdir)/vlc-translations-$(VERSION) \ + | GZIP=$(GZIP_ENV) gzip -c >$(srcdir)/vlc-translations-$(VERSION).tar.gz ############################################################################### -# Modules +# Stamp rules ############################################################################### -MOSTLYCLEANFILES += $(PLUGIN_FILES) -PLUGIN_FILES = - -libvlcdir = $(libdir)/vlc - -include Modules.am +clean: clean-stamp clean-recursive +clean-stamp: + rm -f stamp-builtin + +stamp-builtin: FORCE + @for dep in "" `$(VLC_CONFIG) --target builtin`; do \ + if test "$${dep}" -nt "$(top_builddir)/vlc$(EXEEXT)"; then \ + rm -f $@; \ + break; \ + fi; \ + done + @if test ! -f $@; then printf "" > $@; fi ############################################################################### # Force rule