# - 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
+DIST_SUBDIRS = $(SUBDIRS) debian ipkg lib
EXTRA_DIST = \
HACKING \
vlc.spec \
vlc.spec.mdk \
vlc.win32.nsi \
+ src/misc/modules_builtin.h.in \
+ $(NULL)
+
+BUILT_SOURCES = \
+ vlc-config \
+ stamp-api \
+ src/misc/modules_builtin.h \
+ src/misc/version.c \
$(NULL)
-BUILT_SOURCES =
SUFFIXES =
# Tell aclocal to use -I m4. Wonder if it really works.
# Headers
###############################################################################
-BUILT_SOURCES += \
- stamp-api \
- src/misc/modules_builtin.h \
- $(NULL)
-
pkgincludedir = $(includedir)/vlc
dist_pkginclude_HEADERS = \
$(NULL)
noinst_HEADERS = $(HEADERS_include)
+noinst_DATA = $(DATA_noinst_beos) $(DATA_noinst_libvlc)
HEADERS_include = \
include/aout_internal.h \
include/vlc_messages.h \
include/vlc_meta.h \
include/vlc_objects.h \
+ include/vlc_osd.h \
include/vlc_playlist.h \
include/vlc_spu.h \
include/vlc_stream.h \
src/misc/modules_builtin.h: Makefile src/misc/modules_builtin.h.in vlc-config
srcdir=$(srcdir) $(srcdir)/toolbox --update-includes
- touch $@
+ touch src/misc/modules_builtin.h
+
+src/misc/version.c: FORCE
+ srcdir=$(srcdir) $(srcdir)/toolbox --update-version
# These dependencies are mandatory
-$(SOURCES_libvlc): src/misc/modules_builtin.h $(LIB_intl)
+$(SOURCES_libvlc): $(LIB_intl)
###############################################################################
# Optional libintl - FIXME, bad dependencies
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/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/InfoPlist.strings \
extras/MacOSX/Resources/README \
extras/MacOSX/vlc.pbproj/project.pbxproj \
extras/MacOSX/macosx-dmg \
+ \
+ 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 $@
+ $(SHELL) ./config.status --file=vlc-config
+ chmod 0755 vlc-config
-$(SOURCES): vlc-config
+vlc-config.in: vlc-config.in.in
+ ./config.status --recheck
-CLEANFILES = $(BUILT_SOURCES)
+MOSTLYCLEANFILES = $(DATA_noinst_libvlc)
+CLEANFILES = $(BUILT_SOURCES) stamp-builtin
+DISTCLEANFILES = vlc-config.in
-lib_LIBRARIES = lib/libvlc.a $(LIBRARIES_libvlc_pic)
+if HAVE_WIN32
+lib_LIBRARIES = lib/libvlc.a
+else
+if BUILD_SHARED
+lib_LIBRARIES = lib/libvlc_pic.a
+else
+lib_LIBRARIES = lib/libvlc.a
+if BUILD_MOZILLA
+lib_LIBRARIES += lib/libvlc_pic.a
+endif
+endif
+endif
lib_libvlc_a_SOURCES = $(SOURCES_libvlc)
lib_libvlc_a_CFLAGS = `$(VLC_CONFIG) --cflags vlc`
if BUILD_GETOPT
OPT_SOURCES_libvlc_getopt = $(SOURCES_libvlc_getopt)
endif
-if BUILD_MOZILLA
-if !HAVE_WIN32
-LIBRARIES_libvlc_pic = lib/libvlc_pic.a
+
+# Build libvlc as a shared library
+if BUILD_SHARED
+DATA_noinst_libvlc = libvlc$(LIBEXT)
+if HAVE_WIN32
+OBJECTS_libvlc_so = $(lib_libvlc_a_OBJECTS)
+else
+OBJECTS_libvlc_so = $(lib_libvlc_pic_a_OBJECTS)
endif
endif
+libvlc$(LIBEXT): $(OBJECTS_libvlc_so)
+ @ldfl="`$(VLC_CONFIG) --libs plugin vlc $(pic) builtin`" ; \
+ case `$(VLC_CONFIG) --linkage vlc` in \
+ c++) ld="$(CXXLINK)" ;; \
+ objc) ld="$(OBJCLINK)" ;; \
+ c|*) ld="$(LINK)" ;; \
+ esac ; \
+ echo $$ld $(OBJECTS_libvlc_so) $$ldfl ; \
+ $$ld $(OBJECTS_libvlc_so) $$ldfl
+
EXTRA_DIST += \
$(SOURCES_libvlc_beos) \
$(SOURCES_libvlc_darwin) \
src/stream_output/announce.c \
src/stream_output/sap.c \
src/stream_output/acl.c \
+ src/osd/osd.c \
+ src/osd/osd_widgets.c \
+ src/osd/osd_parser.c \
src/misc/charset.c \
src/misc/httpd.c \
src/misc/tls.c \
src/misc/getaddrinfo.c \
src/misc/vlm.c \
src/misc/xml.c \
+ src/misc/version.c \
src/extras/libc.c \
src/control/core.c \
src/control/util.c \
# Work around a bug in the arm-wince-pe linker
if HAVE_WINCE
-vlc_WORKAROUNDLDFLAGS = lib/libvlc.a
+vlc_WORKAROUNDLDFLAGS = $(LIB_libvlc)
+endif
+
+if BUILD_SHARED
+### libvlc.so cannot be created into lib/
+LIB_libvlc = libvlc$(LIBEXT)
+LDFLAGS_libvlc =
+#-Wl,-rpath $(libdir)
+else
+LIB_libvlc = lib/libvlc.a
+LDFLAGS_libvlc = `$(VLC_CONFIG) --libs vlc builtin`
endif
-vlc_LDFLAGS = `$(VLC_CONFIG) --libs vlc builtin` $(vlc_WORKAROUNDLDFLAGS)
-vlc_LDADD = lib/libvlc.a $(DATA_win32_rc) $(LIB_intl)
+vlc_LDFLAGS = $(LDFLAGS_libvlc) $(vlc_WORKAROUNDLDFLAGS)
+vlc_LDADD = $(LIB_libvlc) $(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) $(LIB_intl)
vlc$(EXEEXT): $(vlc_OBJECTS) $(DEPENDENCIES_vlc) stamp-builtin
- @rm -f $(top_builddir)/vlc$(EXEEXT)
+ @rm -f vlc$(EXEEXT)
@case `$(VLC_CONFIG) --linkage vlc builtin` in \
- c++) echo $(CXXLINK) $(vlc_OBJECTS) $(vlc_LDFLAGS) $(LIBS) ; $(CXXLINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) $(vlc_LDADD) ;; \
- objc) echo $(OBJCLINK) $(vlc_OBJECTS) $(vlc_LDFLAGS) $(LIBS) ; $(OBJCLINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) $(vlc_LDADD) ;; \
- c|*) echo $(LINK) $(vlc_OBJECTS) $(vlc_LDFLAGS) $(LIBS) ; $(LINK) $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS) $(vlc_LDADD) ;; \
- esac
+ c++) cmd="$(CXXLINK)" ;; \
+ objc) cmd="$(OBJCLINK)" ;; \
+ c|*) cmd="$(LINK)" ;; \
+ esac ; \
+ cmd="$$cmd $(vlc_OBJECTS) $(vlc_LDADD) $(vlc_LDFLAGS) $(LIBS)" ; \
+ echo $$cmd ; \
+ eval $$cmd
if HAVE_BEOS
-noinst_DATA = vlc-bundle
+DATA_noinst_beos = 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/
find $(top_builddir)/vlc-bundle -type f -exec mimeset -f "{}" \;
endif
-# Install the modules and the symlinks
+# Install the symlinks and shared libvlc
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" ; \
fi ; done
+ test -z "$(DATA_noinst_libvlc)" || $(INSTALL_PROGRAM) "$(DATA_noinst_libvlc)" "$(DESTDIR)$(libdir)"
# 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
+ test -z "$(DATA_noinst_libvlc)" || rm -f "$(DESTDIR)$(libdir)/$(DATA_noinst_libvlc)"
if HAVE_DARWIN
# Create the MacOS X app
cd ../../../; \
cp -r $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
$(top_builddir)/VLC-release.app;; \
- *darwin8*) cd $(top_builddir)/tmp/extras/Default/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ *darwin8*) cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
cd ../../../; \
- cp -r $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
+ cp -r $(top_builddir)/tmp/extras/MacOSX/build/Default/VLC.bundle \
$(top_builddir)/VLC-release.app;; \
esac
rm -Rf $(top_builddir)/tmp
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
cd ../../../; \
cp -r $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
$(top_builddir)/VLC.app;; \
- *darwin8*) cd $(top_builddir)/tmp/extras/Default/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
+ *darwin8*) cd $(top_builddir)/tmp/extras/MacOSX && xcodebuild -target vlc | grep -v '^\([ \t]\|$$\)'; \
cd ../../../; \
- cp -r $(top_builddir)/tmp/extras/MacOSX/build/VLC.bundle \
+ cp -r $(top_builddir)/tmp/extras/MacOSX/build/Default/VLC.bundle \
$(top_builddir)/VLC.app;; \
esac
rm -Rf $(top_builddir)/tmp
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
cp $$i $(top_builddir)/vlc-${VERSION}/skins/ || true ; \
done
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/dvd"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/dvd/selected"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/dvd/unselect"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/dvd/selection"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/dvd/volume"
+ for i in $(srcdir)/share/osdmenu/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/ || true ; \
+ unix2dos $(top_builddir)/vlc-${VERSION}/osdmenu/`basename $$i` ; \
+ done
+ for i in $(srcdir)/share/osdmenu/dvd/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/dvd || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/dvd/unselect/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/dvd/unselect || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/dvd/selected/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/dvd/selected/ || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/dvd/selection/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/dvd/selection/ || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/dvd/volume/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/dvd/volume/ || true ; \
+ done
+
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/default"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/default/selected"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/default/selection"
+ mkdir -p "$(top_builddir)/vlc-${VERSION}/osdmenu/default/volume"
+ for i in $(srcdir)/share/osdmenu/default/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/default || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/default/selected/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/default/selected/ || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/default/selection/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/default/selection/ || true ; \
+ done
+ for i in $(srcdir)/share/osdmenu/default/volume/*.*; do \
+ cp $$i $(top_builddir)/vlc-${VERSION}/osdmenu/default/volume/ || 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/ ;
| 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_\)' \
+ | 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 $(top_srcdir)/../po/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
+stamp-api: Makefile.in $(HEADERS_include) vlc-config vlc-api.pl
+ ( cd $(srcdir) && cat $(HEADERS_include) ) | \
+ top_srcdir="$(top_srcdir)" perl $(top_srcdir)/vlc-api.pl
touch stamp-api
###############################################################################