[vlc-devel] commit: Put common modules Makefiles stuff to an include file ( Rémi Denis-Courmont )

git version control git at videolan.org
Mon Apr 21 19:41:37 CEST 2008


vlc | branch: master | Rémi Denis-Courmont <rem at videolan.org> | Mon Apr 21 20:42:38 2008 +0300| [a6c428f6f35e2c5600c9fb8ad568e0d2ec9b00f4]

Put common modules Makefiles stuff to an include file

Less escaping, less stuff that Makefile.am's depend on

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=a6c428f6f35e2c5600c9fb8ad568e0d2ec9b00f4
---

 modules/common.am |   82 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 modules/genmf     |   77 +------------------------------------------------
 2 files changed, 84 insertions(+), 75 deletions(-)

diff --git a/modules/common.am b/modules/common.am
new file mode 100644
index 0000000..9ca22b6
--- /dev/null
+++ b/modules/common.am
@@ -0,0 +1,82 @@
+# Common code for VLC modules/.../Makefile.am
+#
+# Copyright (C) 2005-2007 the VideoLAN team
+# Copyright (C) 2005-2008 Rémi Denis-Courmont
+#
+# Authors: Sam Hocevar <sam at zoy.org>
+
+NULL =
+SUFFIXES = _plugin$(LIBEXT) _plugin.la
+
+libvlcdir = $(libdir)/vlc/$(basedir)
+libvlc_LTLIBRARIES =
+EXTRA_DIST = Modules.am
+BUILT_SOURCES =
+CLEANFILES =
+
+include $(srcdir)/Modules.am
+
+if HAVE_PLUGINS
+LTLIBVLC = $(top_builddir)/src/libvlc.la
+
+AM_LDFLAGS = -rpath '$(libvlcdir)' \
+	-avoid-version -module -no-undefined \
+	-shrext $(LIBEXT)
+if HAVE_COMPILER_EXPORT
+AM_LDFLAGS += -export-dynamic
+else
+AM_LDFLAGS += -export-symbol-regex ^vlc_entry
+endif
+AM_LIBADD = $(LTLIBVLC)
+endif
+
+all: all-modules
+
+nice:
+	$(top_builddir)/compile
+
+# Find out which modules were enabled and tell make to build them
+all-modules:
+	@set fnord $$MAKEFLAGS; amf=$$2; targets=`\
+	z=$$($(VLC_CONFIG) --list plugin); for mod in $(mods); do case "$$z " in *\ $${mod}\ *) echo lib$${mod}_plugin.la;; esac; done; \
+	`; case "$$targets" in *lib*) $(MAKE) $(AM_MAKEFLAGS) $$targets || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; ;; esac; \
+	test -z "$$fail"
+
+# Build a plugin with the adequate linker and linker's flags
+_plugin.la_plugin$(LIBEXT):
+	@mod="$*" ; mod=$${mod#lib} ; \
+	ldfl="`$(VLC_CONFIG) --libs plugin $$mod` $(LIBVLC) -u $(SYMPREF)$(VLC_ENTRY)" ; \
+	case `$(VLC_CONFIG) --linkage $$mod` in \
+	  c++)  ld="$(CXXLINK)" ;; \
+	  objc) ld="$(OBJCLINK)" ;; \
+	  c|*)  ld="$(LINK)" ;; \
+	esac ; \
+	echo $$ld $< $$ldfl ; \
+	$$ld $< $$ldfl
+
+if MAINTAINER_MODE
+$(srcdir)/Makefile.am: $(srcdir)/Modules.am $(top_srcdir)/modules/genmf
+	cd \$(top_srcdir) && \$(SHELL) modules/genmf ${dir}
+endif
+
+mostlyclean-local:
+	-rm -f -- *.la
+
+### automake creates libvlcdir after running install-*-local
+### so we have to create it ourselves first
+install-exec-local: all-modules
+	@if test -z "$(libvlc_LTLIBRARIES)"; then \
+	  z=$$($(VLC_CONFIG) --list plugin); \
+	  m=`for mod in $(mods); do case "$$z " in *\ $${mod}\ *) printf " lib$${mod}_plugin.la" ;; esac; done` ; \
+	  test -z "$$m" || \
+	    $(MAKE) $(AM_MAKEFLAGS) libvlc_LTLIBRARIES="$$m" install-libvlcLTLIBRARIES || exit $$? ; \
+	fi
+
+uninstall-local:
+	@if test -z "$(libvlc_LTLIBRARIES)"; then \
+	  z=$$($(VLC_CONFIG) --list plugin); \
+	  m=`for mod in $(mods); do case "$$z " in *\ $${mod}\ *) printf " lib$${mod}_plugin.la" ;; esac; done` ; \
+	  test -z "$$m" || \
+	    $(MAKE) $(AM_MAKEFLAGS) libvlc_LTLIBRARIES="$$m" uninstall-libvlcLTLIBRARIES || exit $$?; \
+	fi
+
diff --git a/modules/genmf b/modules/genmf
index 156b886..e8030b9 100755
--- a/modules/genmf
+++ b/modules/genmf
@@ -30,83 +30,10 @@ do
 
 basedir = ${basedir}
 mods = ${mods}
-
-NULL =
-libvlc_LTLIBRARIES =
-EXTRA_DIST = Modules.am
-BUILT_SOURCES =
-CLEANFILES =
 SUBDIRS = ${subdirs}
-SUFFIXES = _plugin\$(LIBEXT) _plugin.la
-
-libvlcdir = \$(libdir)/vlc/\$(basedir)
-
 EXTRA_LTLIBRARIES = ${extra_ltlibs}
 
-include Modules.am
-
-if HAVE_PLUGINS
-LTLIBVLC = \$(top_builddir)/src/libvlc.la
-
-AM_LDFLAGS = -rpath '\$(libvlcdir)' -avoid-version \\
-	-module -no-undefined -shrext \$(LIBEXT) 
-if HAVE_COMPILER_EXPORT
-AM_LDFLAGS += -export-dynamic
-else
-AM_LDFLAGS += -export-symbol-regex ^vlc_entry
-endif
-AM_LIBADD = \$(LTLIBVLC)
-endif
-
-all: all-modules
-
-nice:
-	\$(top_builddir)/compile
-
-# Find out which modules were enabled and tell make to build them
-all-modules:
-	@set fnord \$\$MAKEFLAGS; amf=\$\$2; targets=\`\\
-	z=\$\$(\$(VLC_CONFIG) --list plugin); for mod in \$(mods); do case "\$\$z " in *\ \$\${mod}\ *) echo lib\$\${mod}_plugin.la;; esac; done; \\
-	\`; case "\$\$targets" in *lib*) \$(MAKE) \$(AM_MAKEFLAGS) \$\$targets || case "\$\$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; ;; esac; \\
-	test -z "\$\$fail"
-
-# Build a plugin with the adequate linker and linker's flags
-_plugin.la_plugin\$(LIBEXT):
-	@mod="\$*" ; mod=\$\${mod#lib} ; \
-	ldfl="\`\$(VLC_CONFIG) --libs plugin \$\$mod\` \$(LIBVLC) -u \$(SYMPREF)\$(VLC_ENTRY)" ; \
-	case \`\$(VLC_CONFIG) --linkage \$\$mod\` in \\
-	  c++)  ld="\$(CXXLINK)" ;; \
-	  objc) ld="\$(OBJCLINK)" ;; \
-	  c|*)  ld="\$(LINK)" ;; \
-	esac ; \
-	echo \$\$ld \$< \$\$ldfl ; \
-	\$\$ld \$< \$\$ldfl
-
-if MAINTAINER_MODE
-\$(srcdir)/Makefile.am: \$(srcdir)/Modules.am \$(top_srcdir)/modules/genmf
-	cd \$(top_srcdir) && \$(SHELL) modules/genmf ${dir}
-endif
-
-mostlyclean-local:
-	-rm -f -- *.la
-
-### automake creates libvlcdir after running install-*-local
-### so we have to create it ourselves first
-install-exec-local: all-modules
-	@if test -z "\$(libvlc_LTLIBRARIES)"; then \
-	  z=\$\$(\$(VLC_CONFIG) --list plugin); \
-	  m=\`for mod in \$(mods); do case "\$\$z " in *\ \$\${mod}\ *) printf " lib\$\${mod}_plugin.la" ;; esac; done\` ; \
-	  test -z "\$\$m" || \
-  	    \$(MAKE) \$(AM_MAKEFLAGS) libvlc_LTLIBRARIES="\$\$m" install-libvlcLTLIBRARIES || exit \$\$? ; \
-	fi
-
-uninstall-local:
-	@if test -z "\$(libvlc_LTLIBRARIES)"; then \
-	  z=\$\$(\$(VLC_CONFIG) --list plugin); \
-	  m=\`for mod in \$(mods); do case "\$\$z " in *\ \$\${mod}\ *) printf " lib\$\${mod}_plugin.la" ;; esac; done\` ; \
-	  test -z "\$\$m" || \
-	    \$(MAKE) \$(AM_MAKEFLAGS) libvlc_LTLIBRARIES="\$\$m" uninstall-libvlcLTLIBRARIES || exit \$\$?; \
-	fi
+include \$(top_srcdir)/modules/common.am
 
 EOF
   for mod in $mods
@@ -126,7 +53,6 @@ EOF
 #   work properly with any automake version I tested.
     cat >> "${makf}" << EOF
 # The ${mod} plugin
-
 EOF
     cat >> "${makf}" << EOF
 lib${mod}_plugin_la_SOURCES = \$(SOURCES_${mod})
@@ -147,6 +73,7 @@ lib${mod}_plugin_la_LIBADD = \$(AM_LIBADD) \\
 	\`\$(VLC_CONFIG) -libs plugin ${mod}\` 
 # Automake does not understand \`...\` very well inside LIBADD...
 lib${mod}_plugin_la_DEPENDENCIES = \$(AM_LIBADD)
+
 EOF
   done
 




More information about the vlc-devel mailing list