diff options
Diffstat (limited to 'source/l/hal/hal.SlackBuild')
-rwxr-xr-x | source/l/hal/hal.SlackBuild | 105 |
1 files changed, 59 insertions, 46 deletions
diff --git a/source/l/hal/hal.SlackBuild b/source/l/hal/hal.SlackBuild index a797b252..96713686 100755 --- a/source/l/hal/hal.SlackBuild +++ b/source/l/hal/hal.SlackBuild @@ -1,7 +1,7 @@ #!/bin/sh # Copyright 2007 Ole Andre Rodlie <olear@slackforge.net> -# Copyright 2008, 2009 Patrick J. Volkerding, Sebeka, MN +# Copyright 2008, 2009, 2010 Patrick J. Volkerding, Sebeka, MN # All rights reserved. # # Redistribution and use of this script, with or without modification, is @@ -21,34 +21,46 @@ # OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -PRGNAM=hal -VERSION=0.5.11 -ARCH=${ARCH:-x86_64} -BUILD=${BUILD:-6} +PKGNAM=hal +VERSION=${VERSION:-$(echo $PKGNAM-*.tar.?z* | rev | cut -f 3- -d . | cut -f 1 -d - | rev)} +BUILD=${BUILD:-2} NUMJOBS=${NUMJOBS:--j7} +# Automatically determine the architecture we're building on: +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) export ARCH=i486 ;; + arm*) export ARCH=arm ;; + # Unless $ARCH is already set, use uname -m for all other archs: + *) export ARCH=$( uname -m ) ;; + esac +fi + CWD=$(pwd) TMP=${TMP:-/tmp} -PKG=$TMP/package-$PRGNAM +PKG=$TMP/package-$PKGNAM if [ "$ARCH" = "i486" ]; then SLKCFLAGS="-O2 -march=i486 -mtune=i686" LIBDIRSUFFIX="" -elif [ "$ARCH" = "i686" ]; then - SLKCFLAGS="-O2 -march=i686 -mtune=i686" +elif [ "$ARCH" = "s390" ]; then + SLKCFLAGS="-O2" LIBDIRSUFFIX="" elif [ "$ARCH" = "x86_64" ]; then SLKCFLAGS="-O2 -fPIC" LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" fi rm -rf $PKG mkdir -p $TMP $PKG cd $TMP || exit 1 -rm -rf $PRGNAM-$VERSION -tar xvf $CWD/$PRGNAM-$VERSION.tar.?z* || exit 1 -cd $PRGNAM-$VERSION || exit 1 +rm -rf $PKGNAM-$VERSION +tar xvf $CWD/$PKGNAM-$VERSION.tar.?z* || exit 1 +cd $PKGNAM-$VERSION || exit 1 chown -R root:root . find . \ \( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \ @@ -56,43 +68,42 @@ find . \ \( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \ -exec chmod 644 {} \; -# Restore Xorg's Zap'ing behavior by default and make it -# clearer to the user how to edit and/or get back old behavior -zcat $CWD/patches/10-keymap.fdi-restore_zap.diff.gz | patch -p1 || exit 1 -# Hide some invalid partition types -zcat $CWD/patches/hide_more_invalid_partitions.diff.gz | patch -p1 || exit 1 -# Allow uid/gid options with ntfs-3g filesystems -zcat $CWD/patches/allow_uid_gid_ntfs.diff.gz | patch -p1 || exit 1 -# Check UDI's properly so that we don't cause dbus errors -zcat $CWD/patches/check_udi_properly.diff.gz | patch -p1 || exit 1 -# Prevent crash on newer kernels during resume operations -zcat $CWD/patches/fix_led_crash.diff.gz | patch -p1 || exit 1 -# Fix a crash when assembling md devices -zcat $CWD/patches/fix_md_crash.diff.gz | patch -p1 || exit 1 -# Fix another segfault in mdraid handling -zcat $CWD/patches/fix_segfault_in_mdraid.diff.gz | patch -p1 || exit 1 -# Strip trailing "/" characters from UDI strings to prevent dbus errors -zcat $CWD/patches/fixup_udi_strings.diff.gz | patch -p1 || exit 1 -# Ignore duplicate events (e.g. run udevadm trigger on a running system) -zcat $CWD/patches/ignore_dupe_add_events.diff.gz | patch -p1 || exit 1 -# Use direct hal connection to set the X keymap -zcat $CWD/patches/set_X_keymap_properly.diff.gz | patch -p1 || exit 1 -# Instead of dying, regenerate the fdi cache if it's zero-byte -zcat $CWD/patches/regen_fdi_cache_if_zero_size.diff.gz | patch -p1 || exit 1 -# We need to use "udevadm info" now instead of "udevinfo" -zcat $CWD/patches/use_udevadm_not_udevinfo.patch.gz | patch -p1 || exit 1 +# Restore the DontZap defaults from lore +zcat $CWD/patches/10-keymap.fdi-restore_zap.diff.gz | patch -p1 --verbose || exit 1 + +# Oops, a freebsd-specific commit wasn't :-) +zcat $CWD/patches/fix_libusb_detection.diff.gz | patch -p1 --verbose || exit 1 + +# Fix a segfault -- http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=562068 +zcat $CWD/patches/fix_segfault_in_LIBHAL_FREE_DBUS_ERROR.diff.gz | patch -p1 --verbose || exit 1 +# Increase PATH_HAL_MAX to 4096 to avoid crashes +# https://bugs.freedesktop.org/show_bug.cgi?id=25888 +zcat $CWD/patches/increase_HAL_PATH_MAX_to_4096.diff.gz | patch -p1 --verbose || exit 1 + +# Handle input.touchpad explicitly (needed due to kernel changes) +zcat $CWD/patches/handle_input.touchpad_explicitly.diff.gz | patch -p1 --verbose || exit 1 + +# Fix incorrect arguments to ioperm() +zcat $CWD/patches/fix_ioperm_arguments.patch.gz | patch -p1 --verbose || exit 1 + +# Fix segfaults from not calling dbus_error_init() early enough +zcat $CWD/patches/fix_segfault-dbus_error_init.patch.gz | patch -p1 --verbose || exit 1 + +autoconf CFLAGS="$SLKCFLAGS" \ CXXFLAGS="$SLKCFLAGS" \ ./configure \ --prefix=/usr \ --libdir=/usr/lib${LIBDIRSUFFIX} \ + --libexecdir=/usr/libexec \ --sysconfdir=/etc \ --localstatedir=/var \ --mandir=/usr/man \ + --with-udev-prefix=/lib \ --disable-static \ --enable-docbook-docs \ - --docdir=/usr/doc/$PRGNAM-$VERSION \ + --docdir=/usr/doc/$PKGNAM-$VERSION \ --with-pid-file=/var/run/hald/pid \ --enable-parted \ --disable-policy-kit \ @@ -104,6 +115,10 @@ CXXFLAGS="$SLKCFLAGS" \ || exit 1 # These were merged into the 2.6.22 kernels # --enable-acpi-ibm --enable-acpi-toshiba +# Use these instead of the corresponding --disable lines for PolicyKit support +# --enable-policy-kit \ +# --enable-console-kit \ +# --enable-acl-management \ make $NUMJOBS || make || exit 1 make install DESTDIR=$PKG || exit 1 @@ -116,30 +131,28 @@ find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \ for i in $(find . -type l) ; do ln -s $(readlink $i).gz $i.gz ; rm $i ; done ) -# Let's put the udev rules in the right place -mkdir -p $PKG/lib -mv $PKG/etc/udev $PKG/lib - # Install init script for hal mkdir -p $PKG/etc/rc.d zcat $CWD/rc.hald.gz > $PKG/etc/rc.d/rc.hald.new # Make HAL run by default: chmod 0755 $PKG/etc/rc.d/rc.hald.new +# /* remove everything between the C-style comments if using PK # Make the HAL access controls suitable for us # Big thanks to Richard Hughes for feedback on this :-) # First, move the one installed by the system to the docs directory -mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +mkdir -p $PKG/usr/doc/$PKGNAM-$VERSION mv $PKG/etc/dbus-1/system.d/hal.conf \ - $PKG/usr/doc/$PRGNAM-$VERSION/hal.conf.orig + $PKG/usr/doc/$PKGNAM-$VERSION/hal.conf.orig +# end removal */ # Don't clobber an existing config file in case custom changes have been made zcat $CWD/hal.conf.gz > $PKG/etc/dbus-1/system.d/hal.conf.new # Install docs (directory was created above) cp -a \ AUTHORS COPYING* HACKING INSTALL NEWS README* \ - $PKG/usr/doc/$PRGNAM-$VERSION -( cd $PKG/usr/doc/$PRGNAM-$VERSION + $PKG/usr/doc/$PKGNAM-$VERSION +( cd $PKG/usr/doc/$PKGNAM-$VERSION ln -s ../../share/gtk-doc/html/libhal libhal ln -s ../../share/gtk-doc/html/libhal-storage libhal-storage ) @@ -149,5 +162,5 @@ cat $CWD/slack-desc > $PKG/install/slack-desc zcat $CWD/doinst.sh.gz > $PKG/install/doinst.sh cd $PKG -/sbin/makepkg -l y -c n $TMP/$PRGNAM-$VERSION-$ARCH-$BUILD.txz +/sbin/makepkg -l y -c n $TMP/$PKGNAM-$VERSION-$ARCH-$BUILD.txz |