mirror of
https://github.com/Ponce/slackbuilds
synced 2024-11-18 22:06:04 +01:00
desktop/i3: Added (an improved dynamic tiling window manager)
Signed-off-by: Robby Workman <rworkman@slackbuilds.org>
This commit is contained in:
parent
88501b2b4e
commit
dd30c9a90a
6 changed files with 165 additions and 0 deletions
12
desktop/i3/README
Normal file
12
desktop/i3/README
Normal file
|
@ -0,0 +1,12 @@
|
|||
i3 is a tiling window manager, completely written from scratch.
|
||||
|
||||
i3 was created because wmii, our favorite window manager at the time, didn't
|
||||
provide some features we wanted (multi-monitor done right, for example), had
|
||||
some bugs, didn't progress since quite some time and wasn't easy to hack at
|
||||
all (source code comments/documentation completely lacking). Still, we think
|
||||
the wmii developers and contributors did a great job. Thank you for inspiring
|
||||
us to create i3.
|
||||
|
||||
Please be aware that i3 is primarily targeted at advanced users and developers.
|
||||
|
||||
This requires libev and yajl.
|
15
desktop/i3/doinst.sh
Normal file
15
desktop/i3/doinst.sh
Normal file
|
@ -0,0 +1,15 @@
|
|||
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/i3/config.new
|
||||
|
89
desktop/i3/i3.SlackBuild
Normal file
89
desktop/i3/i3.SlackBuild
Normal file
|
@ -0,0 +1,89 @@
|
|||
#!/bin/sh
|
||||
|
||||
# Slackware build script for i3
|
||||
|
||||
# Written by Eugene Wissner <belka.ew@gmail.com>
|
||||
|
||||
PRGNAM=i3
|
||||
VERSION=3.e_bf1
|
||||
BUILD=${BUILD:-1}
|
||||
TAG=${TAG:-_SBo}
|
||||
|
||||
SRC_VERSION=$(printf $VERSION | tr _ -)
|
||||
|
||||
if [ -z "$ARCH" ]; then
|
||||
case "$( uname -m )" in
|
||||
i?86) ARCH=i486 ;;
|
||||
arm*) ARCH=arm ;;
|
||||
*) ARCH=$( uname -m ) ;;
|
||||
esac
|
||||
fi
|
||||
|
||||
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
|
||||
SLKCFLAGS="-O2"
|
||||
LIBDIRSUFFIX=""
|
||||
fi
|
||||
|
||||
set -e # Exit on most errors
|
||||
|
||||
rm -rf $PKG
|
||||
mkdir -p $TMP $PKG $OUTPUT
|
||||
cd $TMP
|
||||
rm -rf $PRGNAM-$SRC_VERSION
|
||||
tar xvf $CWD/$PRGNAM-$SRC_VERSION.tar.bz2
|
||||
cd $PRGNAM-$SRC_VERSION
|
||||
chown -R root:root .
|
||||
find . \
|
||||
\( -perm 777 -o -perm 775 -o -perm 711 -o -perm 555 -o -perm 511 \) \
|
||||
-exec chmod 755 {} \; -o \
|
||||
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
|
||||
-exec chmod 644 {} \;
|
||||
|
||||
# instead of ./configure
|
||||
sed -i "s/-O2/$SLKCFLAGS/" common.mk
|
||||
sed -i "s,local/lib,lib$LIBDIRSUFFIX," common.mk
|
||||
make
|
||||
make install DESTDIR=$PKG
|
||||
|
||||
find $PKG | xargs file | grep -e "executable" -e "shared object" | grep ELF \
|
||||
| cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
|
||||
|
||||
# Don't clobber the default config
|
||||
mv $PKG/etc/i3/config $PKG/etc/i3/config.new
|
||||
|
||||
# Install an xinitrc script
|
||||
mkdir -p $PKG/etc/X11/xinit
|
||||
cat $CWD/xinitrc.i3 > $PKG/etc/X11/xinit/xinitrc.i3
|
||||
chmod 0755 $PKG/etc/X11/xinit/xinitrc.i3
|
||||
|
||||
# Install man pages
|
||||
mkdir -p $PKG/usr/man/man1
|
||||
cp man/*.1 $PKG/usr/man/man1
|
||||
find $PKG/usr/man -type f -exec gzip -9 {} \;
|
||||
|
||||
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
|
||||
cp -a \
|
||||
DEPENDS LICENSE TODO GOALS docs/* \
|
||||
$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}
|
10
desktop/i3/i3.info
Normal file
10
desktop/i3/i3.info
Normal file
|
@ -0,0 +1,10 @@
|
|||
PRGNAM="i3"
|
||||
VERSION="3.e-bf1"
|
||||
HOMEPAGE="http://i3.zekjur.net/"
|
||||
DOWNLOAD="http://i3.zekjur.net/downloads/i3-3.e-bf1.tar.bz2"
|
||||
MD5SUM="e13be1a4c6f3ba5180c7264194f57e38"
|
||||
DOWNLOAD_x86_64=""
|
||||
MD5SUM_x86_64=""
|
||||
MAINTAINER="Eugene Wissner"
|
||||
EMAIL="belka.ew@gmail.com"
|
||||
APPROVED="rworkman"
|
19
desktop/i3/slack-desc
Normal file
19
desktop/i3/slack-desc
Normal file
|
@ -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------------------------------------------------------|
|
||||
i3: i3 (an improved dynamic tiling window manager)
|
||||
i3:
|
||||
i3: i3 is a tiling window manager, completely written from scratch.
|
||||
i3:
|
||||
i3: i3 was created because wmii, our favorite window manager at the time,
|
||||
i3: didn't provide some features we wanted (multi-monitor done right,
|
||||
i3: for example), had some bugs, didn't progress since quite some time
|
||||
i3: and wasn't easy to hack at all (source code comments/documentation
|
||||
i3: completely lacking). Still, we think the wmii developers and
|
||||
i3: contributors did a great job.
|
||||
i3:
|
20
desktop/i3/xinitrc.i3
Normal file
20
desktop/i3/xinitrc.i3
Normal file
|
@ -0,0 +1,20 @@
|
|||
#!/bin/sh
|
||||
|
||||
userresources=$HOME/.Xresources
|
||||
usermodmap=$HOME/.Xmodmap
|
||||
sysresources=/etc/X11/xinit/.Xresources
|
||||
sysmodmap=/etc/X11/xinit/.Xmodmap
|
||||
|
||||
# Merge in defaults and keymaps
|
||||
[ -f $sysresources ] && /usr/bin/xrdb -merge $sysresources
|
||||
[ -f $sysmodmap ] && /usr/bin/xmodmap $sysmodmap
|
||||
[ -f $userresources ] && /usr/bin/xrdb -merge $userresources
|
||||
[ -f $usermodmap ] && /usr/bin/xmodmap $usermodmap
|
||||
|
||||
# Start i3
|
||||
if [ -z $DESKTOP_SESSION ]; then
|
||||
exec ck-launch-session i3
|
||||
else
|
||||
exec i3
|
||||
fi
|
||||
|
Loading…
Reference in a new issue