X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=toolbox;h=5fc742046613c2ec41859de316dd06e929d1c05b;hb=95a7988d4f9715267c8881cbdfa4b02f2b5bdd06;hp=b02808268cf0fa3c83881b4183c442ab1dab49f2;hpb=7965eb30e5577fbee26d8270be72059643c487a6;p=vlc diff --git a/toolbox b/toolbox index b02808268c..5fc7420466 100755 --- a/toolbox +++ b/toolbox @@ -3,7 +3,10 @@ ## toolbox for the VLC media player ## $Id$ ## +## Copyright (C) 2005 the VideoLAN team +## ## Authors: Samuel Hocevar +## Rémi Denis-Courmont ### ### Get a sane environment, just in case @@ -25,10 +28,12 @@ recognized flags are: --update-vc update Microsoft Visual Studio files --update-po update translation files --update-includes generate various include files + --update-version generate src/misc/version.c --update-glade generate and fix Glade code --update-glade2 generate and fix Glade 2 code --update-flexml generate and fix flexml and flex code --distclean "make distclean" on steroids + --dist-contrib add the contrib dir to MAKE_DIST --make-woody change distdir to a woody distdir EOF exit 1 @@ -67,6 +72,9 @@ case "$1" in --update-includes) action=includes ;; + --update-version) + action=version + ;; --update-flexml) action=flexml ;; @@ -85,6 +93,9 @@ case "$1" in --add-include) action=include ;; + --dist-contrib) + action=contrib + ;; --help) help ;; @@ -212,6 +223,12 @@ SOURCE="..\\`echo ${file} | sed -e 's%/%\\\\%g'`"${M} !ELSEIF "\$(CFG)" == "libvlc - Win32 (WCE ARM) Debug"${M} # PROP Output_Dir "ARMDbg\\${subdir}"${M} # PROP Intermediate_Dir "ARMDbg\\${subdir}"${M} +!ELSEIF "\$(CFG)" == "libvlc - Win32 (WCE ARMV4) Release"${M} +# PROP Output_Dir "ARMV4Rel\\${subdir}"${M} +# PROP Intermediate_Dir "ARMV4Rel\\${subdir}"${M} +!ELSEIF "\$(CFG)" == "libvlc - Win32 (WCE ARMV4) Debug"${M} +# PROP Output_Dir "ARMV4Dbg\\${subdir}"${M} +# PROP Intermediate_Dir "ARMV4Dbg\\${subdir}"${M} !ELSEIF "\$(CFG)" == "libvlc - Win32 (WCE x86em) Release"${M} # PROP Output_Dir "X86EMRel\\${subdir}"${M} # PROP Intermediate_Dir "X86EMRel\\${subdir}"${M} @@ -338,20 +355,11 @@ EOF # Top of the project file perl -pe 'if(/§SOURCES§/){last;}' < ${target}.in > ${target} # The source files - if test "${target}" = "evc/vlc.vcp" - then - cat >> ${target} << EOF -# Begin Source File${M} -SOURCE="..\\evc\\vlc.c"${M} -# End Source File${M} -EOF - else cat >> ${target} << EOF # Begin Source File${M} SOURCE="..\\src\\vlc.c"${M} # End Source File${M} EOF - fi # Bottom of the project file - handles resource files too perl -e 'while(<>){if(/§SOURCES§/){last;}}while(<>){print $_}' < ${target}.in >> ${target} done @@ -365,36 +373,10 @@ fi ## if test "${action}" = "po" then - # create a fake file containing win32 strings - rm -f modules/gui/win32/strings.cpp - #printf "/* Automatically generated by 'toolbox --update-po', please don't compile */\n" > modules/gui/win32/strings.cpp - #find modules/gui/win32 -name '*.dfm' | while read file - #do - # printf "\n/*\n * from $file:\n */\n\n" >> modules/gui/win32/strings.cpp - # perl -ne 'chop; chop; if( / (Caption|Text|Hint) / || $buffer =~ /[+=] *$/ ) { $buffer =~ s/\+ *$//; $buffer .= $_; } if( $buffer =~ /'"'"' *$/) { $buffer =~ s/'"'"'/"/g; $buffer =~ s/\\/\\\\/g; $buffer =~ s/=/= _(/; print $buffer." );\n"; $buffer = "";}' < $file | grep -v '"-*"' | grep -v '"http://' | grep -v '"vlcs"' >> modules/gui/win32/strings.cpp || exit 1 - #done # find out the source files - rm -f po/POTFILES.in - echo "# automatically created by toolbox --update-po" > po/POTFILES.in - echo "" >> po/POTFILES.in - echo "# main sources" >> po/POTFILES.in - find include src -name '*.[chm]' -o -name '*.[ch]pp' \ - | grep -v '\(vlc_symbols\|misc/modules_\)' \ - | sort >> po/POTFILES.in - echo "" >> po/POTFILES.in - echo "# modules" >> po/POTFILES.in - find modules -name '*.[chm]' -o -name '*.[ch]pp' \ - | grep -v '\(\.moc\.\|gui/gtk2/\)' \ - | sort >> po/POTFILES.in - # clean old potfiles - cd po - rm -f vlc.pot - # update - make vlc.pot || exit 1 - make update-po || exit 1 - cd .. - - exit 0 + echo "WARNING: you should run \"make update-po\" instead!" >&2 + make update-po + exit $? fi ## @@ -407,45 +389,14 @@ then if test -z "${srcdir}"; then srcdir="`sed -ne 's/^srcdir *= *//p' < Makefile`" fi - LIBVLC_HEADERS=`getfiles HEADERS_include` - BUILTINS=`sed -ne 's/.*builtins *= *" *\([^"]*\)".*/\1/p' vlc-config` - - file="${srcdir}/include/vlc_symbols.h" - - rm -f ${file}.in - echo '/* DO NOT EDIT THIS FILE! See Makefile.am */' >> ${file}.in - echo 'struct module_symbols_t {' >> ${file}.in - cat ${LIBVLC_HEADERS} | grep '^ *VLC_EXPORT.*;' | sed -e 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/ \1 (* \2_inner) \3;/' >> ${file}.in - echo '};' >> ${file}.in - echo '#ifdef __PLUGIN__' >> ${file}.in - cat ${LIBVLC_HEADERS} | grep '^ *VLC_EXPORT.*;' | sed -e 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/# define \2 p_symbols->\2_inner/' >> ${file}.in - echo '#endif /* __PLUGIN__ */' >> ${file}.in - if diff >/dev/null 2>&1 ${file} ${file}.in - then - rm -f ${file}.in - else - echo "creating new ${file}" - mv -f ${file}.in ${file} - fi - - file="${srcdir}/src/misc/modules_plugin.h" - - rm -f ${file}.tmp && cp ${file}.in ${file}.tmp - sed -e 's#.*\$[I][d]:.*# * Automatically generated from '${file}'.in by bootstrap#' < ${file}.in > ${file}.tmp - echo '#define STORE_SYMBOLS( p_symbols ) \' >> ${file}.tmp - cat ${LIBVLC_HEADERS} | grep '^ *VLC_EXPORT.*;' | sed -e 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/ (p_symbols)->\2_inner = \2; \\/' >> ${file}.tmp - echo '' >> ${file}.tmp - if diff >/dev/null 2>&1 ${file} ${file}.tmp - then - rm -f ${file}.tmp - else - echo "creating new ${file}" - mv -f ${file}.tmp ${file} + if test -z "${builddir}"; then + builddir="`sed -ne 's/^top_builddir *= *//p' < Makefile`" fi + BUILTINS=`sed -ne 's/.*builtins *= *" *\([^"]*\)".*/\1/p' vlc-config` - file="${srcdir}/src/misc/modules_builtin.h" + file="${builddir}/src/misc/modules_builtin.h" - rm -f ${file}.tmp && cp ${file}.in ${file}.tmp + rm -f ${file}.tmp && cp ${srcdir}/src/misc/modules_builtin.h.in ${file}.tmp if test -n "${BUILTINS}" then for i in `echo ${BUILTINS}` @@ -477,6 +428,49 @@ then exit 0 fi +## +## Create version file +## +if test "${action}" = "version" +then + if test -z "${srcdir}"; then + srcdir="`sed -ne 's/^srcdir *= *//p' < Makefile`" + fi + if test -z "${builddir}"; then + builddir="`sed -ne 's/^top_builddir *= *//p' < Makefile`" + fi + if test -z "${CC}"; then + CC="`sed -ne 's/^CC *= *//p' < Makefile`" + fi + + file="${builddir}/src/misc/version.c" + if which svnversion 2>&1 >/dev/null; then + VLC_CHANGESET=`svnversion $srcdir` + else + VLC_CHANGESET='exported' + fi + + rm -f ${file}.tmp + cat > ${file}.tmp << EOF +/* DO NOT EDIT THIS FILE - IT IS REGENERATED AT EVERY COMPILE - + * IT GIVES BETTER TRACKING OF VLC STABLE AND DEVELOPMENT VERSIONS + * WHETHER THEY ARE BUILT BY OTHERS OR DURING DEVELOPMENT OR FOR THE + * OFFICIAL VLC STABLE RELEASES. + */ +const char psz_vlc_changeset[] = "${VLC_CHANGESET}"; + +EOF + if diff >/dev/null 2>&1 ${file} ${file}.tmp + then + rm -f ${file}.tmp + else + echo "creating new ${file}" + mv -f ${file}.tmp ${file} + fi + + exit 0 +fi + ## ## Fix glade-generated files ## @@ -575,12 +569,12 @@ then # a naive sanity check to make sure we are in a VLC tree test -f vlc.spec.mdk -a -f debian/rules || exit 1 # let's rock! - find . -type f '(' -name '*.[oa]' -o -name '*.so' -o -name '*.sl' -o -name '*.dylib' -o -name '*.dll' -o -name .dirstamp -o -name Makefile.in -o -name 'stamp-h*' -o -name '*~' -o -name '*.bak' -o -name '*.moc.cpp' ')' -exec rm -f '{}' ';' + find . -type f '(' -name '*.[oa]' -o -name '*.so' -o -name '*.sl' -o -name '*.dylib' -o -name '*.dll' -o -name .dirstamp -o '(' '(' ! -path '\./doc/developer/Makefile\.in' ')' -a -name Makefile.in ')' -o -name 'stamp-h*' -o -name '*~' -o -name '*.bak' -o -name '*.moc.cpp' ')' -exec rm -f '{}' ';' (cd autotools && find . -name '[a-z]*' -maxdepth 1 -exec rm -f '{}' ';') - (cd debian && find . -type d -name '[a-z]*' -maxdepth 1 -exec rm -Rf '{}' ';') + (cd debian && find . -type d '(' -name '[a-z]*' ! -name 'patches' ')' -maxdepth 1 -exec rm -Rf '{}' ';') find msvc -type f -name '*.dsp' -exec rm -f '{}' ';' find evc -type f -name '*.vcp' -exec rm -f '{}' ';' - #find . -type d -name '.deps' -exec rm -Rf '{}' ';' + find . -type d -name '.deps' -exec rm -Rf '{}' ';' # there's some more cruft all around rm -f config.h config.log config.status rm -f vlc vlc-config Makefile Modules.am @@ -589,6 +583,37 @@ then # FIXME: a lot of Makefiles are still there fi +## +## Add the extras/contrib dir to the distribution +## +if test "${action}" = "contrib" +then + set -x + if test ! -d "${distdir}/extras" + then + mkdir "${distdir}/extras" + fi + if test ! -d "${distdir}/extras/contrib" + then + mkdir "${distdir}/extras/contrib" + fi + cp "${srcdir}/extras/contrib/Makefile" "${distdir}/extras/contrib/Makefile" + cp "${srcdir}/extras/contrib/README" "${distdir}/extras/contrib/README" + cp "${srcdir}/extras/contrib/bootstrap" "${distdir}/extras/contrib/bootstrap" + cp "${srcdir}/extras/contrib/change_prefix.sh" "${distdir}/extras/contrib/change_prefix.sh" + if test ! -d "${distdir}/extras/contrib/src" + then + mkdir "${distdir}/extras/contrib/src" + fi + cp "${srcdir}/extras/contrib/src/Makefile" "${distdir}/extras/contrib/src/Makefile" + cp "${srcdir}/extras/contrib/src/packages.mak" "${distdir}/extras/contrib/src/packages.mak" + if test ! -d "${distdir}/extras/contrib/src/Patches" + then + mkdir "${distdir}/extras/contrib/src/Patches" + fi + cp ${srcdir}/extras/contrib/src/Patches/* "${distdir}/extras/contrib/src/Patches/" +fi + ## ## Build a woody-friendly package ##