[svn-commits] tilghman: trunk r115813 - /trunk/contrib/scripts/install_prereq
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Mon May 12 15:34:39 CDT 2008
Author: tilghman
Date: Mon May 12 15:34:38 2008
New Revision: 115813
URL: http://svn.digium.com/view/asterisk?view=rev&rev=115813
Log:
Add a script which installs every package needed for a Debian install of
Asterisk, and includes possible support (to be contributed) for various other
distributions.
(closes issue #10523)
Reported by: tzafrir
Patches:
install_prereq_2 uploaded by tzafrir (license 46)
Added:
trunk/contrib/scripts/install_prereq (with props)
Added: trunk/contrib/scripts/install_prereq
URL: http://svn.digium.com/view/asterisk/trunk/contrib/scripts/install_prereq?view=auto&rev=115813
==============================================================================
--- trunk/contrib/scripts/install_prereq (added)
+++ trunk/contrib/scripts/install_prereq Mon May 12 15:34:38 2008
@@ -1,0 +1,126 @@
+#! /bin/sh
+#
+# $Id$
+#
+
+# install_prereq: a script to install distribution-specific
+# prerequirements
+
+set -e
+
+usage() {
+ echo "$0: a script to install distribution-specific prerequirement"
+ echo 'Revision: $Id$'
+ echo ""
+ echo "Usage: $0: Shows this message."
+ echo "Usage: $0 test Prints commands it is about to run."
+ echo "Usage: $0 install Really install."
+}
+
+# Basic build system:
+PACKAGES_DEBIAN="build-essential"
+# Asterisk: basic requirements:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libncurses-dev libz-dev libssl-dev"
+# Asterisk: very useful addons:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libcurl-dev libspeex-dev libogg-dev libvorbis-dev libasound2-dev"
+# Asterisk: nice-to-have addons:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libpq-dev unixodbc-dev libsqlite-dev"
+# Not so nice addon:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libopenh323-dev"
+# Extras for 1.4:
+PACKAGES_DEBIAN="$PACKAGES_DEBIAN libsnmp-dev libiksemel-dev "
+
+PACKAGES_RH="gcc gcc-c++ ncurses-devel openssl-devel"
+
+KVERS=`uname -r`
+
+case "$1" in
+test) testcmd=echo ;;
+install) testcmd='' ;;
+'') usage; exit 0 ;;
+*) usage; exit 1 ;;
+esac
+
+in_test_mode() {
+ test "$testcmd" != ''
+}
+
+# Fixme: should be done by apt and not by dpkg?
+check_installed_debs() {
+ dpkg-query -W --showformat '${Status} ${Package}\n' "$@" 2>/dev/null \
+ | awk '/ not-installed/{print $4}'
+}
+
+# parsing the output of yum is close to impossible.
+# We'll use rpm and hope for the best:
+check_installed_rpms() {
+ for pack in "$@"
+ do
+ if ! rpm -q $pack >/dev/null 2>/dev/null
+ then echo $pack
+ fi
+ done
+}
+
+handle_debian() {
+ # echo "# Distribution is Debian or compatible"
+ extra_packs=`check_installed_debs $PACKAGES_DEBIAN`
+ $testcmd apt-get install -y $extra_packs
+}
+
+handle_rh() {
+ # echo "# Distribution is RedHat-based or compatible"
+ extra_packs=`check_installed_rpms $PACKAGES_RH`
+ # FIXME: is there yum with RHEL 4?
+ $testcmd yum install -y $extra_packs
+}
+
+if in_test_mode; then
+ echo "#############################################"
+ echo "## $1: test mode."
+ echo "## Use the commands here to install your system."
+ echo "#############################################"
+fi
+
+OS=`uname -s`
+unsupported_distro=''
+
+# A number of distributions we don't (yet?) support.
+if [ "$OS" != 'Linux' ]; then
+ echo >&2 "$0: Your OS ($OS) is currently not supported. Aborting."
+ exit 1
+fi
+
+if [ -f /etc/gentoo-release ]; then
+ unsupported_distro='Gentoo'
+fi
+
+if [ -f /etc/mandrake-release ]; then
+ unsupported_distro='Mandriva'
+fi
+
+if [ -f /etc/SuSE-release ]; then
+ unsupported_distro='SUSE'
+fi
+
+if [ -f /etc/slackware-version ]; then
+ unsupported_distro='Slackware'
+fi
+
+if [ "$unsupported_distro" != '' ]; then
+ echo >&2 "$0: Your distribution ($unsupported_distro) is currently not supported. Aborting."
+ exit 1
+fi
+
+# The distributions we do support:
+if [ -r /etc/debian_version ]; then
+ handle_debian
+elif [ -r /etc/redhat-release ]; then
+ handle_rh
+fi
+
+if ! in_test_mode; then
+ echo "#############################################"
+ echo "## $1 completed successfully"
+ echo "#############################################"
+fi
Propchange: trunk/contrib/scripts/install_prereq
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: trunk/contrib/scripts/install_prereq
------------------------------------------------------------------------------
svn:executable = *
Propchange: trunk/contrib/scripts/install_prereq
------------------------------------------------------------------------------
svn:keywords = Id Author Date Revision
Propchange: trunk/contrib/scripts/install_prereq
------------------------------------------------------------------------------
svn:mime-type = text/plain
More information about the svn-commits
mailing list