# which have makefiles with distribution information.
# - 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
+# - . should come before mozilla/bindings because the plugin needs libvlc_pic.a
# - po should come before . because VLC.app needs the pofiles
# - loader should come before modules because some plugins need it
-SUBDIRS = intl loader modules po . mozilla activex share m4 doc
-DIST_SUBDIRS = $(SUBDIRS) src debian ipkg lib
+SUBDIRS = intl loader src modules po . mozilla bindings activex share m4 doc
+DIST_SUBDIRS = $(SUBDIRS) debian ipkg
EXTRA_DIST = \
HACKING \
INSTALL.win32 \
+ INSTALL.wince \
vlc.exe.manifest \
MAINTAINERS \
README.MacOSX.rtf \
bootstrap \
- src/extras/COPYING \
toolbox \
vlc-api.pl \
vlc-config.in.in \
vlc.win32.nsi \
$(NULL)
-BUILT_SOURCES =
+BUILT_SOURCES_distclean = vlc-config compile
+BUILT_SOURCES_clean = macosx-sdk
+
+BUILT_SOURCES = $(BUILT_SOURCES_distclean) $(BUILT_SOURCES_clean)
+
SUFFIXES =
+DISTCHECK_CONFIGURE_FLAGS = --disable-dvd --disable-mad --disable-libmpeg2 \
+ --disable-ffmpeg --disable-faad --disable-skins2
+
# Tell aclocal to use -I m4. Wonder if it really works.
ACLOCAL_AMFLAGS = -I m4
# because old versions of automake don't support them in configure.ac.
AUTOMAKE_OPTIONS = dist-bzip2 subdir-objects
-###############################################################################
-# Headers
-###############################################################################
-
-BUILT_SOURCES += \
- stamp-api \
- src/misc/modules_builtin.h \
- $(NULL)
-
-pkgincludedir = $(includedir)/vlc
-
-dist_pkginclude_HEADERS = \
- include/vlc/vlc.h \
- include/vlc/aout.h \
- include/vlc/vout.h \
- include/vlc/sout.h \
- include/vlc/decoder.h \
- include/vlc/input.h \
- include/vlc/intf.h \
- include/vlc/control.h \
- $(NULL)
-
-noinst_HEADERS = $(HEADERS_include)
-
-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/intf_eject.h \
- include/iso_lang.h \
- include/main.h \
- include/mmx.h \
- include/modules.h \
- include/modules_inner.h \
- include/mtime.h \
- include/network.h \
- include/osd.h \
- include/os_specific.h \
- include/snapshot.h \
- include/stream_output.h \
- include/variables.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_md5.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_spu.h \
- include/vlc_stream.h \
- include/vlc_symbols.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 \
- $(NULL)
-
-src/misc/modules_builtin.h: Makefile src/misc/modules_builtin.h.in vlc-config
- srcdir=$(srcdir) $(srcdir)/toolbox --update-includes
- touch $@
-
-# These dependencies are mandatory
-$(SOURCES_libvlc): src/misc/modules_builtin.h $(LIB_intl)
-
-###############################################################################
-# Optional libintl - FIXME, bad dependencies
-###############################################################################
-
-intl/libintl.a: FORCE
- cd $(top_builddir)/intl && $(MAKE) $(AM_MAKEFLAGS)
-
-if BUILD_INTL
-LIB_intl = intl/libintl.a
-endif
-
###############################################################################
# MacOS X project
###############################################################################
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/MainMenu.nib/keyedobjects.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/Wizard.nib/classes.nib \
extras/MacOSX/Resources/English.lproj/Wizard.nib/info.nib \
extras/MacOSX/Resources/English.lproj/Wizard.nib/keyedobjects.nib \
+ extras/MacOSX/Resources/English.lproj/Bookmarks.nib/classes.nib \
+ extras/MacOSX/Resources/English.lproj/Bookmarks.nib/info.nib \
+ extras/MacOSX/Resources/English.lproj/Bookmarks.nib/keyedobjects.nib \
+ extras/MacOSX/Resources/English.lproj/Extended.nib/classes.nib \
+ extras/MacOSX/Resources/English.lproj/Extended.nib/info.nib \
+ extras/MacOSX/Resources/English.lproj/Extended.nib/keyedobjects.nib \
+ extras/MacOSX/Resources/English.lproj/SFilters.nib/classes.nib \
+ extras/MacOSX/Resources/English.lproj/SFilters.nib/info.nib \
+ extras/MacOSX/Resources/English.lproj/SFilters.nib/keyedobjects.nib \
+ extras/MacOSX/Resources/English.lproj/Update.nib/classes.nib \
+ extras/MacOSX/Resources/English.lproj/Update.nib/info.nib \
+ extras/MacOSX/Resources/English.lproj/Update.nib/keyedobjects.nib \
+ extras/MacOSX/Resources/English.lproj/Interaction.nib/classes.nib \
+ extras/MacOSX/Resources/English.lproj/Interaction.nib/info.nib \
+ extras/MacOSX/Resources/English.lproj/Interaction.nib/keyedobjects.nib \
extras/MacOSX/Resources/English.lproj/InfoPlist.strings \
extras/MacOSX/Resources/a52.icns \
extras/MacOSX/Resources/aac.icns \
extras/MacOSX/Resources/vlc.scriptTerminology \
extras/MacOSX/Resources/README \
extras/MacOSX/vlc.pbproj/project.pbxproj \
- extras/MacOSX/macosx-dmg \
+ extras/MacOSX/Delete_Preferences.app/Contents/Info.plist \
+ extras/MacOSX/Delete_Preferences.app/Contents/PkgInfo \
+ extras/MacOSX/Delete_Preferences.app/Contents/MacOS/applet \
+ extras/MacOSX/Delete_Preferences.app/Contents/Resources/description.rtfd/TXT.rtf \
+ extras/MacOSX/Delete_Preferences.app/Contents/Resources/applet.icns \
+ extras/MacOSX/Delete_Preferences.app/Contents/Resources/applet.rsrc \
+ extras/MacOSX/Delete_Preferences.app/Contents/Resources/Scripts/main.scpt \
+ extras/Makefile \
+ extras/zsh.cpp \
$(NULL)
###############################################################################
$(NULL)
dist-hook:
- cd $(distdir) && srcdir=$(srcdir) $(srcdir)/toolbox --update-vc
- distdir=$(distdir) srcdir=$(srcdir) $(srcdir)/toolbox --dist-contrib
+ cd $(distdir) && srcdir=. $(SHELL) ./toolbox --update-vc
+ distdir=$(distdir) srcdir=$(srcdir) $(SHELL) $(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
-
-CLEANFILES = $(BUILT_SOURCES)
-
-lib_LIBRARIES = lib/libvlc.a $(LIBRARIES_libvlc_pic)
-
-lib_libvlc_a_SOURCES = $(SOURCES_libvlc)
-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 = `$(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)
-endif
-if HAVE_DARWIN
-OPT_SOURCES_libvlc_darwin = $(SOURCES_libvlc_darwin)
-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
-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) \
- $(SOURCES_libvlc_darwin) \
- $(SOURCES_libvlc_win32) \
- $(SOURCES_libvlc_dirent) \
- $(SOURCES_libvlc_getopt) \
- $(NULL)
-
-SOURCES_libvlc_beos = \
- src/misc/beos_specific.cpp \
- $(NULL)
+ $(SHELL) ./config.status --file=$@
+ chmod 0755 $@
-SOURCES_libvlc_darwin = \
- src/misc/darwin_specific.m \
- $(NULL)
+vlc-config.in: vlc-config.in.in
+ ./config.status --recheck
-SOURCES_libvlc_win32 = \
- src/misc/win32_specific.c \
- $(NULL)
-
-SOURCES_libvlc_dirent = \
- src/extras/dirent.c \
- $(NULL)
-
-SOURCES_libvlc_getopt = \
- src/extras/getopt.c \
- src/extras/getopt.h \
- src/extras/getopt1.c \
- $(NULL)
-
-SOURCES_libvlc_common = \
- src/libvlc.c \
- src/libvlc.h \
- 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_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_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 \
- src/audio_output/input.c \
- src/audio_output/mixer.c \
- 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/md5.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/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/getaddrinfo.c \
- src/misc/vlm.c \
- src/misc/xml.c \
- src/extras/libc.c \
- src/control/core.c \
- src/control/util.c \
- src/control/audio_video.c \
- $(NULL)
-
-SOURCES_libvlc = \
- $(SOURCES_libvlc_common) \
- $(OPT_SOURCES_libvlc_beos) \
- $(OPT_SOURCES_libvlc_darwin) \
- $(OPT_SOURCES_libvlc_win32) \
- $(OPT_SOURCES_libvlc_dirent) \
- $(OPT_SOURCES_libvlc_getopt) \
- $(NULL)
+CLEANFILES = $(BUILT_SOURCES_clean) stamp-builtin
+DISTCLEANFILES = $(BUILT_SOURCES_distclean) vlc-config.in compile
###############################################################################
# Building vlc
###############################################################################
+.PHONY: libvlc
+
+# Shortcut for developpers to rebuild the core (libvlc + vlc)
+# Don't use it if you don't know what it is about.
+# Don't complain if it doesn't work. -- Courmisch
+core: libvlc vlc$(EXEEXT)
+
+libvlc:
+ cd src && $(MAKE) all
+
bin_PROGRAMS = vlc
vlc_SOURCES = src/vlc.c
+# Ugly kludge so that automake defines $(CXXLINK)
+EXTRA_vlc_SOURCES = extras/zsh.cpp
# Work around a bug in the arm-wince-pe linker
if HAVE_WINCE
-vlc_WORKAROUNDLDFLAGS = lib/libvlc.a
+vlc_WORKAROUNDLDFLAGS = $(LIB_libvlc)
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 $(DATA_win32_rc) $(LIB_intl)
+DEPENDENCIES_vlc = $(LIB_libvlc) $(DATA_win32_rc)
+
+vlc_CFLAGS = `$(VLC_CONFIG) --cflags vlc`
+if USE_LIBTOOL
+vlc_LDFLAGS = `$(VLC_CONFIG) --libs vlc`
+LIB_libvlc = src/libvlc.la
+LIBVLC = $(LIB_libvlc)
+else
+if BUILD_SHARED
+vlc_LDFLAGS = `$(VLC_CONFIG) --libs vlc` -Wl,-rpath $(libdir) -L$(top_builddir)/src -lvlc
+if HAVE_WIN32
+LIB_libvlc = src/libvlc.dll.a
+else
+LIB_libvlc = src/libvlc$(LIBEXT)
+endif
+LIBVLC =
+else
+vlc_LDFLAGS = $(vlc_WORKAROUNDLFDLAGS) `$(VLC_CONFIG) --libs vlc builtin`
+LIB_libvlc = src/libvlc.a
+LIBVLC = $(LIB_libvlc)
+DEPENDENCIES_vlc += stamp-builtin
+endif
+endif
+vlc_LDADD = $(DATA_win32_rc) $(LIBVLC) $(INCLUDED_LIBINTL)
-vlc$(EXEEXT): $(vlc_OBJECTS) $(DEPENDENCIES_vlc) stamp-builtin
- @rm -f $(top_builddir)/vlc$(EXEEXT)
+vlc$(EXEEXT): $(vlc_OBJECTS) $(DEPENDENCIES_vlc)
+ @rm -f 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
+ c++) cmd="$(CXXLINK)" ;; \
+ objc) cmd="$(OBJCLINK)" ;; \
+ c|*) cmd="$(LINK)" ;; \
+ esac ; \
+ cmd="$$cmd $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS)" ; \
+ echo $$cmd ; \
+ eval $$cmd
if HAVE_BEOS
noinst_DATA = vlc-bundle
find $(top_builddir)/vlc-bundle -type f -exec mimeset -f "{}" \;
endif
-# Install the modules and the symlinks
+# Install the symlinks
install-exec-local:
- 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" ; \
+ ln -sf vlc "$(DESTDIR)$(bindir)/$$i" ; \
fi ; done
# the opposite of install-{data,exec}-local
uninstall-local:
- @for i in "" `$(VLC_CONFIG) --target plugin` ; do if test -n "$$i" ; then \
- echo rm -f "$(DESTDIR)$(libdir)/vlc/`echo $$i | sed -e 's,.*modules/\([^/]*\).*,\1,'`/$$(basename $$i$(LIBEXT))" ; \
- rm -f "$(DESTDIR)$(libdir)/vlc/`echo $$i | sed -e 's,.*modules/\([^/]*\).*,\1,'`/$$(basename $$i$(LIBEXT))" ; \
- fi ; done
- @for i in "" `$(VLC_CONFIG) --target builtin` ; do if test -n "$$i" ; then \
- echo rm -f "$(DESTDIR)$(libdir)/vlc/$$(basename $$i)" ; \
- rm -f "$(DESTDIR)$(libdir)/vlc/$$(basename $$i)" ; \
- fi ; done
-if BUILD_MOZILLA
- @for i in "" `$(VLC_CONFIG) --target builtin pic` ; do if test -n "$$i" ; then \
- echo rm -f "$$i" "$(DESTDIR)$(libdir)/vlc/$$(basename $$i)" ; \
- rm -f "$$i" "$(DESTDIR)$(libdir)/vlc/$$(basename $$i)" ; \
- fi ; done
-endif
for i in "" $(ALIASES) ; do if test -n "$$i" ; then \
rm -f "$(DESTDIR)$(bindir)/$$i" ; \
fi ; done
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
+ 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 \
voutgl.m \
wizard.h \
wizard.m \
+ extended.h \
+ extended.m \
+ bookmarks.h \
+ bookmarks.m \
+ sfilters.h \
+ sfilters.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
+ case $(target_triplet) in \
+ *darwin6*) cd $(top_builddir)/tmp/extras/MacOSX && pbxbuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ cd ../../../; \
+ cp -R $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
+ $(top_builddir)/VLC-release.app;; \
+ *darwin7*) cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ cd ../../../; \
+ cp -R $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
+ $(top_builddir)/VLC-release.app;; \
+ *darwin8*) cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ cd ../../../; \
+ cp -R $(top_builddir)/tmp/extras/MacOSX/build/Default/VLC.bundle \
+ $(top_builddir)/VLC-release.app;; \
+ esac
rm -Rf $(top_builddir)/tmp
$(INSTALL) -d $(top_builddir)/VLC-release.app/Contents/MacOS
$(INSTALL) $(top_builddir)/vlc \
then $(INSTALL) "$$i$(LIBEXT)" \
"$(top_builddir)/VLC-release.app/Contents/MacOS/modules" ; \
fi ; done
- if test -d $(top_builddir)/extras/contrib/vlc-lib; then \
+ if test -d $(srcdir)/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 \
+ for i in $(srcdir)/extras/contrib/vlc-lib/*.dylib ; do \
$(INSTALL) -m 644 $${i} $(top_builddir)/VLC-release.app/Contents/MacOS/lib/vlc_`basename $${i}` ; \
done ; \
fi
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 ; \
echo "OK."; mkdir -p "$(top_builddir)/tmp/extras"; \
fi
rm -Rf $(top_builddir)/VLC.app
- cp -r $(srcdir)/extras/MacOSX $(top_builddir)/tmp/extras
+ 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 \
voutgl.m \
wizard.h \
wizard.m \
+ extended.h \
+ extended.m \
+ bookmarks.h \
+ bookmarks.m \
+ sfilters.h \
+ sfilters.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
+ case $(target_triplet) in \
+ *darwin6*) cd $(top_builddir)/tmp/extras/MacOSX && pbxbuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ cd ../../../; \
+ cp -R $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
+ $(top_builddir)/VLC.app;; \
+ *darwin7*) cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ cd ../../../; \
+ cp -R $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
+ $(top_builddir)/VLC.app;; \
+ *darwin8*) cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ cd ../../../; \
+ cp -R $(top_builddir)/tmp/extras/MacOSX/build/Default/VLC.bundle \
+ $(top_builddir)/VLC.app;; \
+ esac
rm -Rf $(top_builddir)/tmp
$(INSTALL) -d $(top_builddir)/VLC.app/Contents/MacOS
$(INSTALL) $(top_builddir)/vlc \
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 \
+ if test -d $(srcdir)/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 \
+ for i in $(srcdir)/extras/contrib/vlc-lib/*.dylib ; do \
ln -sfn `pwd`/$${i} $(top_builddir)/VLC.app/Contents/MacOS/lib/vlc_`basename $${i}` ; \
done ; \
fi
$(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
###############################################################################
# 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:
+
+package-win-common:
# Check that tmp isn't in the way
@if test -e "$(top_builddir)/vlc-${VERSION}"; then \
echo "Error: please remove $(top_builddir)/vlc-${VERSION}, it is in the way"; \
fi
# Copy relevant files
- 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)"
+if BUILD_SHARED
+ cp "src/libvlc$(LIBEXT)" "vlc-${VERSION}/"
+ $(STRIP) "vlc-${VERSION}/libvlc$(LIBEXT)"
+endif
for file in AUTHORS MAINTAINERS THANKS NEWS COPYING README ; \
do sed 's/@/_AT_/' < "$(srcdir)/$$file" > "$(top_builddir)/vlc-${VERSION}/$${file}.txt" ; \
unix2dos "$(top_builddir)/vlc-${VERSION}/$${file}.txt" ; 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 "" $(top_builddir)/vlc-${VERSION}/plugins/*$(LIBEXT) ; \
- do if test -n "$$i" ; then $(STRIP) "$$i" ; fi ; done
-
mkdir $(top_builddir)/vlc-${VERSION}/locale
for i in $(ALL_LINGUAS); do \
mkdir -p "$(top_builddir)/vlc-${VERSION}/locale/$${i}/LC_MESSAGES" ; \
|| true ; \
done
- 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"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/images"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/requests"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/js"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/dialogs"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/old"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/old/vlm"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/http/old/admin"
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/js/*.js $(top_builddir)/vlc-${VERSION}/http/js/ ;
+ unix2dos $(top_builddir)/vlc-${VERSION}/http/js/*.js ;
+ cp $(srcdir)/share/http/dialogs/* $(top_builddir)/vlc-${VERSION}/http/dialogs/ ;
+ unix2dos $(top_builddir)/vlc-${VERSION}/http/dialogs/* ;
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/vlc48x48new.ico $(top_builddir)/vlc-${VERSION}/ ;
+ cp $(srcdir)/share/http/images/*.png $(top_builddir)/vlc-${VERSION}/http/images/
+ cp $(srcdir)/share/http/requests/*.xml $(top_builddir)/vlc-${VERSION}/http/requests/ ;
+ unix2dos $(top_builddir)/vlc-${VERSION}/http/requests/*.xml ;
+
+ cp $(srcdir)/share/http/old/*.html $(top_builddir)/vlc-${VERSION}/http/old/ ;
+ unix2dos $(top_builddir)/vlc-${VERSION}/http/old/*.html ;
+ cp $(srcdir)/share/http/old/*.ico $(top_builddir)/vlc-${VERSION}/http/old/ ;
+ cp $(srcdir)/share/http/old/*.css $(top_builddir)/vlc-${VERSION}/http/old/ ;
+ cp $(srcdir)/share/http/old/*.png $(top_builddir)/vlc-${VERSION}/http/old/ ;
+ cp $(srcdir)/share/http/old/vlm/*.html $(top_builddir)/vlc-${VERSION}/http/old/vlm/ ;
+ unix2dos $(top_builddir)/vlc-${VERSION}/http/old/vlm/*.html ;
+ cp $(srcdir)/share/http/old/admin/*.html $(top_builddir)/vlc-${VERSION}/http/old/admin/ ;
+ unix2dos $(top_builddir)/vlc-${VERSION}/http/old/admin/*.html ;
+
+ cp $(srcdir)/share/vlc48x48.ico $(top_builddir)/vlc-${VERSION}/ ;
- mkdir -p "$(top_builddir)/vlc-${VERSION}/mozilla"
if BUILD_MOZILLA
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/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
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/activex"
cp $(srcdir)/activex/README.TXT $(top_builddir)/vlc-${VERSION}/activex/ ;
cp $(srcdir)/activex/test.html $(top_builddir)/vlc-${VERSION}/activex/ ;
unix2dos $(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 \
+ if rebase -b 0x42 /dev/null >/dev/null 2>&1; then \
find $(top_builddir)/vlc-${VERSION} -type f -name '*.dll' -print | rebase -b 0x70000000 -T -; \
fi
+package-win32-base-debug: package-win-common
+# Copy relevant files
+ cp "$(srcdir)/vlc.win32.nsi" "$(top_builddir)/vlc-${VERSION}/"
+
+ 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
+
+ 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}/osdmenu"
+ cp $(srcdir)/share/osdmenu/*.* "$(top_builddir)/vlc-${VERSION}/osdmenu"
+ for dir in dvd dvd/selected dvd/unselect dvd/selection dvd/volume default default/selected default/selection default/volume;do \
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/$$dir"; \
+ for file in $(srcdir)/share/osdmenu/$${dir}/*.*;do \
+ cp $$file "$(top_builddir)/vlc-${VERSION}/osdmenu/$$dir" || true; \
+ done; \
+ done
+ unix2dos $(top_builddir)/vlc-${VERSION}/osdmenu/*.cfg;
+ sed -i 's%share/osdmenu%osdmenu%g' $(top_builddir)/vlc-${VERSION}/osdmenu/*.cfg
+ sed -i 's%/%\\%g' $(top_builddir)/vlc-${VERSION}/osdmenu/*.cfg
+
+
+package-win32-base: package-win32-base-debug
+ for i in "" $(top_builddir)/vlc-${VERSION}/plugins/*$(LIBEXT) ; \
+ do if test -n "$$i" ; then $(STRIP) "$$i" ; fi ; done
+
+
package-win32-base-exe:
# Create package
- wine C:/Program\ Files/NSIS/makensis.exe \
- /DVERSION=${VERSION} $(top_builddir)/vlc-${VERSION}/vlc.win32.nsi
+ if makensis -VERSION >/dev/null 2>&1; then \
+ MAKENSIS="makensis -DVERSION=${VERSION}"; \
+ elif [ -x "/cygdrive/c/Program Files/NSIS/makensis" ]; then \
+ MAKENSIS="/cygdrive/c/Program\ Files/NSIS/makensis /DVERSION=${VERSION}"; \
+ elif wine --version >dev/null 2>&1; then \
+ MAKENSIS="wine C:/Program\ Files/NSIS/makensis.exe /DVERSION=${VERSION}"; \
+ else \
+ echo 'Error: cannot locate makensis tool'; exit 1; \
+ fi; \
+ eval "$$MAKENSIS $(top_builddir)/vlc-${VERSION}/vlc.win32.nsi"
-package-win32-base-exe-cygwin:
+package-win32-base-exe-cygwin: package-win32-base-exe
# Create package
- C:/Program\ Files/NSIS/makensis.exe \
- /DVERSION=${VERSION} $(top_builddir)/vlc-${VERSION}/vlc.win32.nsi
package-win32-base-exe-linux:
# Create package
# Clean up
rm -Rf $(top_builddir)/vlc-${VERSION}
+package-wince-base: package-win-common
+
+package-wince-base-zip:
+# Create package
+ zip -r vlc-${VERSION}-wince.zip vlc-${VERSION}
+
+package-wince: package-wince-base package-wince-base-zip
+# Clean up
+ rm -Rf $(top_builddir)/vlc-${VERSION}
+
+
package-beos:
# Check that tmp isn't in the way
@if test -e $(srcdir)/tmp; then \
rm -Rf $(srcdir)/tmp ;
package-macosx:
-# Check that tmp isn't in the way
- @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"; \
+# Check that the temporary location isn't in the way
+ @if test -e "$(top_builddir)/vlc-${VERSION}/"; then \
+ rm -Rf "$(top_builddir)/vlc-${VERSION}/" ; \
fi
+ echo "Create package directory: vlc-${VERSION}/";
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/";
+
# Copy relevant files
- 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/
+ cp -R "$(top_builddir)/VLC-release.app" "$(top_builddir)/vlc-${VERSION}/VLC.app"
+ cd "$(srcdir)" && cp AUTHORS COPYING ChangeLog README README.MacOSX.rtf THANKS NEWS $(top_builddir)/vlc-${VERSION}/ && cp -R extras/MacOSX/Delete_Preferences.app $(top_builddir)/vlc-${VERSION}/
# Create disk image
- $(srcdir)/extras/MacOSX/macosx-dmg "vlc-${VERSION}" $(top_builddir)/tmp
+ echo "Creating disk image" ;
+ rm -f "$(top_builddir)/vlc-${VERSION}.dmg" ;
+ hdiutil create -srcfolder "$(top_builddir)/vlc-${VERSION}" \
+ "$(top_builddir)/vlc-${VERSION}.dmg" -format UDZO -quiet ;
+ echo; echo "Disk image creation completed:" ;
+ ls -la "$(top_builddir)/vlc-${VERSION}.dmg" ; echo ;
# Clean up
- rm -Rf $(top_builddir)/tmp
+ rm -Rf "$(top_builddir)/vlc-${VERSION}" ;
package-translations:
@if test -e "$(srcdir)/vlc-translations-${VERSION}"; then \
| GZIP=$(GZIP_ENV) gzip -c >$(srcdir)/vlc-translations-$(VERSION).tar.gz
###############################################################################
-# Stamp rules
+# PO translation files update
###############################################################################
-clean: clean-stamp clean-recursive
-clean-stamp:
- rm -f stamp-builtin stamp-api
+.PHONY: update-po
+
+update-po:
+ rm -f $(top_srcdir)/po/POTFILES.in
+ { \
+ cd $(top_srcdir) ; \
+ echo "# automatically created by make update-po" ; \
+ echo "" ; \
+ echo "# main sources" ; \
+ find include src -name '*.[chm]' -o -name '*.[ch]pp' \
+ | grep -v '\(vlc_symbols\|misc/modules_\|src/misc/version.c\)' \
+ | sort ; \
+ echo "" ; \
+ echo "# modules" ; \
+ find modules -name '*.[chm]' -o -name '*.[ch]pp' \
+ | grep -v '\(\.moc\.\|gui/gtk2/\)' \
+ | sort ; \
+ } > $(top_srcdir)/po/POTFILES.in
+ rm -f $(top_srcdir)/po/vlc.pot
+ cd po && $(MAKE) POTFILES vlc.pot update-po
+
+#cd po && $(MAKE) update-po
+###############################################################################
+# Stamp rules
+###############################################################################
stamp-builtin: FORCE
@for dep in "" `$(VLC_CONFIG) --target builtin`; do \
if test "$${dep}" -nt "$(top_builddir)/vlc$(EXEEXT)"; then \
done
@if test ! -f $@; then printf "" > $@; fi
-stamp-api: Makefile.in $(HEADERS_include) vlc-config vlc-api.pl src/misc/modules_builtin.h.in
- cd $(srcdir) && cat $(HEADERS_include) | perl ./vlc-api.pl
- touch stamp-api
+###############################################################################
+# Enforce Mac OS X deployment target environment variable
+###############################################################################
+macosx-sdk: Makefile.in $(HEADERS_include) vlc-config vlc-api.pl
+ export MACOSX_DEPLOYMENT_TARGET=$(MACOSX_DEPLOYMENT_TARGET)
###############################################################################
# Force rule