]> git.sesse.net Git - vlc/blobdiff - bootstrap
* ./bootstrap : Fixed an issue with old shell versions
[vlc] / bootstrap
index b60d3b3f16fac7ff735564837fb312df22fe5809..0ac4fbc7ebec9619eaad720787d4718fccc73fce 100755 (executable)
--- a/bootstrap
+++ b/bootstrap
@@ -1,14 +1,15 @@
 #! /bin/sh
 
 ##  bootstrap.sh file for vlc, the VideoLAN Client
-##  $Id: bootstrap,v 1.1 2002/08/25 23:18:04 sam Exp $
+##  $Id: bootstrap,v 1.13 2002/08/29 23:53:22 massiot Exp $
 ##
 ##  Authors: Samuel Hocevar <sam@zoy.org>
 
 ###
 ###  get a sane environment
 ###
-export LANG=C
+LANG=C
+export LANG
 
 ###
 ###  argument check
@@ -29,10 +30,69 @@ done
 ###
 ###  classic stuff
 ###
-aclocal -I m4
+set -x
+rm -f aclocal.m4 configure config.guess config.log config.sub ltmain.sh libtool ltconfig missing mkinstalldirs depcomp install-sh
+
+# Check for gettext
+if gettextize --version >/dev/null 2>&1
+then
+if expr `gettextize --version | sed -e '1s/[^0-9]*//' -e q` \
+        '>' 0.11.3 >/dev/null 2>&1
+then
+  # We have gettext, and a recent version! Everything is cool.
+  autopoint --force
+  GETTEXT=yes
+else
+  # What?! User is not using a recent version of gettext? We'll have to
+  # cheat a bit, then.
+  rm -f po/ChangeLog~
+  gettextize --copy --force | grep '^from the' | cut -f3 -d' '
+  # Yuck!
+  test -f po/ChangeLog~ && mv po/ChangeLog~ po/ChangeLog
+  # Yuck!
+  echo 'AC_DEFUN([AM_GNU_GETTEXT_VERSION], [])' > m4/oldgettext.m4
+  GETTEXT=old
+fi;else
+  # we don't have gettext. grmbl. try to continue anyway.
+  mkdir -p intl
+  echo > intl/Makefile.am
+  echo 'AC_DEFUN([AM_GNU_GETTEXT_VERSION], [])' > m4/oldgettext.m4
+  GETTEXT=no
+fi
+
+# Check for automake
+amvers="none"
+if automake-1.6 --version >/dev/null 2>&1
+then
+  amvers="-1.6"
+else
+  if automake-1.5 --version >/dev/null 2>&1
+  then
+    amvers="-1.5"
+  else
+    if automake --version > /dev/null 2>&1
+    then
+      amvers=`automake --version | head -1 | cut -d\  -f 4`
+
+      if expr "$amvers" "<" "1.5" > /dev/null 2>&1
+      then amvers="none"
+      else amvers=""
+      fi
+    fi
+  fi
+fi
+
+if test x$amvers = xnone
+then
+  set +x
+  echo "you need automake version 1.5 or later"
+  exit 1
+fi
+
+# Do the rest
+aclocal${amvers} -I m4
 autoheader
-echo "no" | gettextize --force --intl --copy --no-changelog
-automake --foreign --add-missing --copy
+automake${amvers} --foreign --add-missing --copy
 autoconf
 
 # nuahahahahaha !! overwriting Makefile.in with what *I* want!
@@ -42,14 +102,12 @@ cp Makefile.old Makefile.in
 ##  headers which need to be regenerated because of the VLC_EXPORT macro
 ##
 file=src/misc/modules_plugin.h
-echo -n " + creating headers: "
 rm -f $file
-sed 's#.*\$[I][d]:.*# * Automatically generated from '$file'.in by bootstrap.sh#' < $file.in > $file
+sed -e 's#.*\$[I][d]:.*# * Automatically generated from '$file'.in by bootstrap.sh#' < $file.in > $file
 echo '#define STORE_SYMBOLS( p_symbols ) \' >> $file
 cat include/*.h | grep '^ *VLC_EXPORT.*;' | \
-       sed 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/    (p_symbols)->\2_inner = \2; \\/' >> $file
+       sed -e 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/    (p_symbols)->\2_inner = \2; \\/' >> $file
 echo '' >> $file
-echo -n "$file "
 
 file=include/vlc_symbols.h
 rm -f $file && touch $file
@@ -58,21 +116,19 @@ echo '' >> $file
 echo 'struct module_symbols_t' >> $file
 echo '{' >> $file
 cat include/*.h | grep '^ *VLC_EXPORT.*;' | \
-       sed 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/    \1 (* \2_inner) \3;/' | sort >> $file
+       sed -e 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/    \1 (* \2_inner) \3;/' | sort >> $file
 echo '};' >> $file
 echo '' >> $file
 echo '#ifdef __PLUGIN__' >> $file
 cat include/*.h | grep '^ *VLC_EXPORT.*;' | \
-       sed 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/#   define \2 p_symbols->\2_inner/' | sort >> $file
+       sed -e 's/VLC_EXPORT( *\([^,]*\), *\([^,]*\), *\(.*\));.*/#   define \2 p_symbols->\2_inner/' | sort >> $file
 echo '#endif /* __PLUGIN__ */' >> $file
 echo '' >> $file
-echo "$file."
 
 
 ##
 ##  Glade sometimes sucks
 ##
-echo -n " + fixing glade bugs: "
 for file in gnome_interface.c gtk_interface.c
 do
 if grep "DO NOT EDIT THIS FILE" modules/gui/gtk/$file 2>&1 > /dev/null
@@ -83,27 +139,29 @@ then
 
 #include <vlc/vlc.h>
 EOF
-    tail +8 modules/gui/gtk/$file \
-        | sed 's#_("-:--:--")#"-:--:--"#' \
-        | sed 's#_("---")#"---"#' \
-        | sed 's#_("--")#"--"#' \
-        | sed 's#_("/dev/dvd")#"/dev/dvd"#' \
-        | sed 's#_(\("./."\))#\1#' \
-        >> /tmp/$$.$file.bak
+    sed -e 1,7d \
+        -e 's#_("-:--:--")#"-:--:--"#' \
+        -e 's#_("---")#"---"#' \
+        -e 's#_("--")#"--"#' \
+        -e 's#_("/dev/dvd")#"/dev/dvd"#' \
+        -e 's#_(\("./."\))#\1#' \
+       < modules/gui/gtk/$file >> /tmp/$$.$file.bak
     mv -f /tmp/$$.$file.bak modules/gui/gtk/$file
 fi
-echo -n "$file "
 done
 
 file=gtk_support.h
 if grep "DO NOT EDIT THIS FILE" modules/gui/gtk/$file 2>&1 > /dev/null
 then
     rm -f /tmp/$$.$file.bak
-    sed 's/DO NOT EDIT THIS FILE.*/This file was created automatically by glade and fixed by bootstrap.sh/ ; s/#if.*ENABLE_NLS.*/#if defined( ENABLE_NLS ) \&\& defined ( HAVE_GETTEXT )/' < modules/gui/gtk/$file > /tmp/$$.$file.bak
+    sed -e 's/DO NOT EDIT THIS FILE.*/This file was created automatically by glade and fixed by bootstrap.sh/ ; s/#if.*ENABLE_NLS.*/#if defined( ENABLE_NLS ) \&\& defined ( HAVE_GETTEXT )/' < modules/gui/gtk/$file > /tmp/$$.$file.bak
     mv -f /tmp/$$.$file.bak modules/gui/gtk/$file
 fi
-echo "$file."
 
+##
+##  Shut up
+##
+set +x
 
 ##
 ##  Update the potfiles because no one ever does it
@@ -112,10 +170,29 @@ if test "$do_po" = "no"
 then
   echo "not updating potfiles. use --update-po to force doing it."
 else
-  echo -n " + updating potfiles: "
   cd po
   make update-po 2>&1 | grep '^[^:]*:$' | cut -f1 -d: | tr '\n' ' ' | sed 's/ $//'
   cd ..
-  echo "."
 fi
 
+##
+##  Tell the user about gettext
+##
+case "$GETTEXT" in
+  yes)
+  ;;
+  no)
+    echo ""
+    echo "==========================================================="
+    echo "IMPORTANT NOTE: you do not have gettext installed on your"
+    echo "system. The vlc build will work, but you will not have"
+    echo "internationalization support. We suggest installing gettext."
+  ;;
+  old)
+    echo ""
+    echo "=========================================================="
+    echo "NOTE: you have an old version of gettext installed on your"
+    echo "system. We suggest upgrading to gettext 0.11.3 or later."
+  ;;
+esac
+