diff options
-rw-r--r-- | system/pommed-light/README | 9 | ||||
-rw-r--r-- | system/pommed-light/doinst.sh | 14 | ||||
-rw-r--r-- | system/pommed-light/pommed-light.SlackBuild | 98 | ||||
-rw-r--r-- | system/pommed-light/pommed-light.info | 10 | ||||
-rw-r--r-- | system/pommed-light/pommed.patch | 154 | ||||
-rw-r--r-- | system/pommed-light/slack-desc | 19 |
6 files changed, 304 insertions, 0 deletions
diff --git a/system/pommed-light/README b/system/pommed-light/README new file mode 100644 index 0000000000..524b03a8e7 --- /dev/null +++ b/system/pommed-light/README @@ -0,0 +1,9 @@ +pommed-light (Apple laptops hotkeys events handler) + +This is a stripped-down version of pommed with client, dbus, +and ambient light sensor support removed, optimized for use +with dwm and the like. + +pommed-light handles the hotkeys found on the Apple MacBook Pro and +MacBook laptops and adjusts the LCD backlight, sound volume, +keyboard backlight or ejects the CD-ROM drive accordingly. diff --git a/system/pommed-light/doinst.sh b/system/pommed-light/doinst.sh new file mode 100644 index 0000000000..1e8713903f --- /dev/null +++ b/system/pommed-light/doinst.sh @@ -0,0 +1,14 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +config etc/pommed.conf.new diff --git a/system/pommed-light/pommed-light.SlackBuild b/system/pommed-light/pommed-light.SlackBuild new file mode 100644 index 0000000000..a565937a3a --- /dev/null +++ b/system/pommed-light/pommed-light.SlackBuild @@ -0,0 +1,98 @@ +#!/bin/sh + +# Slackware build script for pommed-light + +# Copyright 2014 Zhu Qun-Ying +# All rights reserved. +# +# Redistribution and use of this script, with or without modification, is +# permitted provided that the following conditions are met: +# +# 1. Redistributions of this script must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED +# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO +# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; +# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR +# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF +# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +PRGNAM=pommed-light +VERSION=${VERSION:-1.47lw} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i486 ;; + arm*) echo "No ARM platform is supported"; exit ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +set -e + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +if [ "$ARCH" = "i486" ]; then + SLKCFLAGS="-O2 -march=i486 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + echo "Unsupported platform $ARCH" +fi + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PRGNAM-$VERSION +tar xvf $CWD/$PRGNAM-$VERSION.tar.gz || tar xvf $CWD/v$VERSION.tar.gz +cd $PRGNAM-$VERSION +chown -R root:root . +find -L . \ + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + +# patch the source +patch -p1 < $CWD/pommed.patch + +make EXTRA_CFLAGS="$SLKCFLAGS" + +mkdir -p $PKG/usr/sbin +install -m755 pommed/pommed $PKG/usr/sbin +mkdir -p $PKG/usr/man/man1 +gzip -c pommed.1 > $PKG/usr/man/man1/pommed.1.gz + +mkdir -p $PKG/usr/share/pommed +cp -a pommed/data/* $PKG/usr/share/pommed + +mkdir -p $PKG/etc/rc.d/ +cp pommed.conf.mactel $PKG/etc/pommed.conf.new + +install -m644 pommed.init $PKG/etc/rc.d/rc.pommed + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp README.md INSTALL COPYING AUTHORS ChangeLog $PKG/usr/doc/$PRGNAM-$VERSION +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc +cat $CWD/doinst.sh > $PKG/install/doinst.sh + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz} diff --git a/system/pommed-light/pommed-light.info b/system/pommed-light/pommed-light.info new file mode 100644 index 0000000000..9c2defbde1 --- /dev/null +++ b/system/pommed-light/pommed-light.info @@ -0,0 +1,10 @@ +PRGNAM="pommed-light" +VERSION="1.74lw" +HOMEPAGE="https://github.com/qunying/pommed-light" +DOWNLOAD="https://github.com/qunying/pommed-light/archive/v1.47lw.tar.gz" +MD5SUM="36b21b215b17577c561439bc76fd00ef" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="confuse" +MAINTAINER="Zhu Qun-Ying" +EMAIL="zhu.qunying@gmail.com" diff --git a/system/pommed-light/pommed.patch b/system/pommed-light/pommed.patch new file mode 100644 index 0000000000..62ed28016f --- /dev/null +++ b/system/pommed-light/pommed.patch @@ -0,0 +1,154 @@ +diff --git a/pommed/Makefile b/pommed/Makefile +index 2a74e78..dd34146 100644 +--- a/pommed/Makefile ++++ b/pommed/Makefile +@@ -11,13 +11,9 @@ AUDIOFILE_LIBS = $(shell pkg-config audiofile --libs) + CONFUSE_CFLAGS = $(shell pkg-config libconfuse --cflags) + CONFUSE_LIBS = $(shell pkg-config libconfuse --libs) + +-INOTIFY_CFLAGS = $(shell test -e /usr/include/sys/inotify.h || echo -DNO_SYS_INOTIFY_H) ++CFLAGS = -g -O2 -Wall $(ALSA_CFLAGS) $(AUDIOFILE_CFLAGS) $(CONFUSE_CFLAGS) $(EXTRA_CFLAGS) + +-TIMERFD_CFLAGS = $(shell test -e /usr/include/sys/timerfd.h || echo -DNO_SYS_TIMERFD_H) +- +-CFLAGS = -g -O2 -Wall $(DBUS_CFLAGS) $(ALSA_CFLAGS) $(AUDIOFILE_CFLAGS) $(CONFUSE_CFLAGS) $(INOTIFY_CFLAGS) $(TIMERFD_CFLAGS) +- +-LDLIBS = -pthread -lrt $(DBUS_LIBS) $(ALSA_LIBS) $(AUDIOFILE_LIBS) $(CONFUSE_LIBS) ++LDLIBS = -pthread -lrt $(ALSA_LIBS) $(AUDIOFILE_LIBS) $(CONFUSE_LIBS) + + LIB_OBJS = + +@@ -53,9 +49,10 @@ ifeq ($(LIBPCI_SHARED), true) + LDLIBS += $(LIBPCI_LIBS) + else + LIB_OBJS += /usr/lib/libpci.a +- LDLIBS += -lz + endif + ++LDLIBS += -lz ++ + LDLIBS += $(LIB_OBJS) + + SOURCES = pommed.c cd_eject.c evdev.c conffile.c audio.c \ +diff --git a/pommed/evdev.c b/pommed/evdev.c +index abd8590..3564da1 100644 +--- a/pommed/evdev.c ++++ b/pommed/evdev.c +@@ -31,12 +31,7 @@ + + #include <sys/epoll.h> + +-#ifndef NO_SYS_INOTIFY_H +-# include <sys/inotify.h> +-#else +-# include <linux/inotify.h> +-# include "inotify-syscalls.h" +-#endif ++#include <sys/inotify.h> + + #include <linux/input.h> + +diff --git a/pommed/inotify-syscalls.h b/pommed/inotify-syscalls.h +deleted file mode 100644 +index a1d5408..0000000 +--- a/pommed/inotify-syscalls.h ++++ /dev/null +@@ -1,98 +0,0 @@ +-/* +- * Inotify syscall numbers +- * Taken from the Linux kernel source tree +- * +- * Licensed under the terms of the GNU General Public License Version 2. +- * +- * Copyright (c) 2006 Tobias Klauser <tklauser@distanz.ch> +- */ +- +-#ifndef _LINUX_INOTIFY_SYSCALLS_H +-#define _LINUX_INOTIFY_SYSCALLS_H +- +-#include <sys/syscall.h> +- +-#if defined(__i386__) +-# define __NR_inotify_init 291 +-# define __NR_inotify_add_watch 292 +-# define __NR_inotify_rm_watch 293 +-#elif defined(__x86_64__) +-# define __NR_inotify_init 253 +-# define __NR_inotify_add_watch 254 +-# define __NR_inotify_rm_watch 255 +-#elif defined(__powerpc__) || defined(__powerpc64__) +-# define __NR_inotify_init 275 +-# define __NR_inotify_add_watch 276 +-# define __NR_inotify_rm_watch 277 +-#elif defined (__ia64__) +-# define __NR_inotify_init 1277 +-# define __NR_inotify_add_watch 1278 +-# define __NR_inotify_rm_watch 1279 +-#elif defined (__s390__) +-# define __NR_inotify_init 284 +-# define __NR_inotify_add_watch 285 +-# define __NR_inotify_rm_watch 286 +-#elif defined (__alpha__) +-# define __NR_inotify_init 444 +-# define __NR_inotify_add_watch 445 +-# define __NR_inotify_rm_watch 446 +-#elif defined (__sparc__) || defined (__sparc64__) +-# define __NR_inotify_init 151 +-# define __NR_inotify_add_watch 152 +-# define __NR_inotify_rm_watch 156 +-#elif defined (__arm__) +-# define __NR_OABI_SYSCALL_BASE 0x900000 +-# if defined(__thumb__) || defined(__ARM_EABI__) +-# define __NR_SYSCALL_BASE 0 +-# else +-# define __NR_SYSCALL_BASE __NR_OABI_SYSCALL_BASE +-# endif +-# define __NR_inotify_init (__NR_SYSCALL_BASE + 316) +-# define __NR_inotify_add_watch (__NR_SYSCALL_BASE + 317) +-# define __NR_inotify_rm_watch (__NR_SYSCALL_BASE + 318) +-#elif defined (__sh__) +-# define __NR_inotify_init 290 +-# define __NR_inotify_add_watch 291 +-# define __NR_inotify_rm_watch 292 +-#elif defined (__hppa__) +-# define __NR_inotify_init 269 +-# define __NR_inotify_add_watch 270 +-# define __NR_inotify_rm_watch 271 +-#elif defined (__mips__) +-# include <sgidefs.h> +-# if _MIPS_SIM == _MIPS_SIM_ABI32 +-# define __NR_Linux 4000 +-# define __NR_inotify_init (__NR_Linux + 284) +-# define __NR_inotify_add_watch (__NR_Linux + 285) +-# define __NR_inotify_rm_watch (__NR_Linux + 286) +-# elif _MIPS_SIM == _MIPS_SIM_ABI64 +-# define __NR_Linux 5000 +-# define __NR_inotify_init (__NR_Linux + 243) +-# define __NR_inotify_add_watch (__NR_Linux + 244) +-# define __NR_inotify_rm_watch (__NR_Linux + 245) +-# elif _MIPS_SIM == _MIPS_SIM_NABI32 +-# define __NR_Linux 6000 +-# define __NR_inotify_init (__NR_Linux + 247) +-# define __NR_inotify_add_watch (__NR_Linux + 248) +-# define __NR_inotify_rm_watch (__NR_Linux + 249) +-# endif +-#else +-# error "inotify not supported on this architecture!" +-#endif +- +-static inline int inotify_init (void) +-{ +- return syscall (__NR_inotify_init); +-} +- +-static inline int inotify_add_watch (int fd, const char *name, __u32 mask) +-{ +- return syscall (__NR_inotify_add_watch, fd, name, mask); +-} +- +-static inline int inotify_rm_watch (int fd, __u32 wd) +-{ +- return syscall (__NR_inotify_rm_watch, fd, wd); +-} +- +-#endif /* _LINUX_INOTIFY_SYSCALLS_H */ diff --git a/system/pommed-light/slack-desc b/system/pommed-light/slack-desc new file mode 100644 index 0000000000..ea62e9da6a --- /dev/null +++ b/system/pommed-light/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. +# Line up the first '|' above the ':' following the base package name, and +# the '|' on the right side marks the last column you can put a character in. +# You must make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler-------------------------------------------------| +pommed-light: pommed-light (Apple laptops hotkeys events handler) +pommed-light: +pommed-light: pommed handles the hotkeys found on the Apple MacBook Pro and +pommed-light: MacBook laptops and adjusts the LCD backlight, sound volume, +pommed-light: keyboard backlight or ejects the CD-ROM drive accordingly. +pommed-light: +pommed-light: +pommed-light: +pommed-light: +pommed-light: Homepage: https://github.com/bytbox/pommed-light +pommed-light: |