From 7224c1253228e5c29c78cb3f0f26ce34770f2356 Mon Sep 17 00:00:00 2001 From: BlackNoxis Date: Sat, 15 Feb 2014 23:24:26 +0200 Subject: Added ebuilds for kogaion desktop --- .../sabayon-mce/files/1.1/bin/sabayon-mce-session | 3 + .../sabayon-mce/files/1.1/bin/sabayon-mce-start | 18 +++ .../sabayon-mce/files/1.1/bin/sabayon-mce-startx | 171 +++++++++++++++++++++ app-misc/sabayon-mce/files/1.1/init.d/sabayon-mce | 41 +++++ .../files/1.1/xsession/sabayon-mce.desktop | 8 + 5 files changed, 241 insertions(+) create mode 100644 app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-session create mode 100644 app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-start create mode 100644 app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-startx create mode 100644 app-misc/sabayon-mce/files/1.1/init.d/sabayon-mce create mode 100644 app-misc/sabayon-mce/files/1.1/xsession/sabayon-mce.desktop (limited to 'app-misc/sabayon-mce/files') diff --git a/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-session b/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-session new file mode 100644 index 00000000..66d0ed03 --- /dev/null +++ b/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-session @@ -0,0 +1,3 @@ +#!/bin/sh +# Start Xbox Media Center +exec /usr/bin/xbmc --standalone \ No newline at end of file diff --git a/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-start b/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-start new file mode 100644 index 00000000..ff2f9ee2 --- /dev/null +++ b/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-start @@ -0,0 +1,18 @@ +#!/bin/sh + +# setup +myxinitrc="/usr/bin/sabayon-mce-session" +myuser="sabayonmce" +mcepid="/var/sabayonmce/.mcepid" + +# make sure samba is started +[[ -f "/etc/init.d/samba" ]] && /etc/init.d/samba start &> /dev/null + +# Kill previous instance running since +# /etc/init.d/xdm does not support PIDFILE for +# custom DISPLAYMANAGER +[[ -f "$mcepid" ]] && kill $(cat $mcepid) &> /dev/null + +# spawn! +echo $$ > /var/run/sabayon-mce-start.pid +su - ${myuser} -c "source /etc/profile && /usr/bin/sabayon-mce-startx ${myxinitrc} &> /dev/null" & diff --git a/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-startx b/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-startx new file mode 100644 index 00000000..21ca87e8 --- /dev/null +++ b/app-misc/sabayon-mce/files/1.1/bin/sabayon-mce-startx @@ -0,0 +1,171 @@ +#!/bin/sh + +# $Xorg: startx.cpp,v 1.3 2000/08/17 19:54:29 cpqbld Exp $ +# +# This is just a sample implementation of a slightly less primitive +# interface than xinit. It looks for user .xinitrc and .xserverrc +# files, then system xinitrc and xserverrc files, else lets xinit choose +# its default. The system xinitrc should probably do things like check +# for .Xresources files and merge them in, startup up a window manager, +# and pop a clock and serveral xterms. +# +# Site administrators are STRONGLY urged to write nicer versions. +# +# $XFree86: xc/programs/xinit/startx.cpp,v 3.16tsi Exp $ + + +userclientrc="$1" +sysclientrc="$1" + +pidfilepath="$HOME/.mcepid" +userserverrc="$HOME/.xserverrc" +sysserverrc=/etc/X11/xinit/xserverrc +defaultclientargs="" +defaultserverargs="-nolisten tcp -br vt07" +clientargs="" +serverargs="" + +enable_xauth=1 + +if [ -f $userclientrc ]; then + defaultclientargs=$userclientrc +elif [ -f $sysclientrc ]; then + defaultclientargs=$sysclientrc +fi + +if [ x"$display" != x ]; then + export DISPLAY=$display +else + export DISPLAY=:0 +fi + + +if [ -f $userserverrc ]; then + defaultserverargs=$userserverrc +elif [ -f $sysserverrc ]; then + defaultserverargs=$sysserverrc +fi + +whoseargs="client" +while [ x"$1" != x ]; do + case "$1" in + /''*|\.*) if [ "$whoseargs" = "client" ]; then + if [ "x$clientargs" = x ]; then + clientargs="$1" + else + clientargs="$clientargs $1" + fi + else + if [ "x$serverargs" = x ]; then + serverargs="$1" + else + serverargs="$serverargs $1" + fi + fi ;; + --) whoseargs="server" ;; + *) if [ "$whoseargs" = "client" ]; then + if [ "x$clientargs" = x ]; then + clientargs="$defaultclientargs $1" + else + clientargs="$clientargs $1" + fi + else + case "$1" in + :[0-9]*) display="$1"; serverargs="$serverargs $1";; + *) serverargs="$serverargs $1" ;; + esac + fi ;; + esac + shift +done + +if [ x"$clientargs" = x ]; then + clientargs="$defaultclientargs" +fi +if [ x"$serverargs" = x ]; then + serverargs="$defaultserverargs" +fi + +if [ x"$enable_xauth" = x1 ] ; then + if [ x"$XAUTHORITY" = x ]; then + XAUTHORITY=$HOME/.Xauthority + export XAUTHORITY + fi + + removelist= + + # set up default Xauth info for this machine + case `uname` in + Linux*) + if [ -z "`hostname --version 2>&1 | grep GNU`" ]; then + hostname=`hostname -f` + else + hostname=`hostname` + fi + ;; + *) + hostname=`hostname` + ;; + esac + + authdisplay=${display:-:0} + + mcookie=`/usr/bin/mcookie` + + dummy=0 + + # create a file with auth information for the server. ':0' is a dummy. + xserverauthfile=$HOME/.serverauth.$$ + trap "rm -f $xserverauthfile" HUP INT QUIT ILL TRAP KILL BUS TERM + xauth -q -f $xserverauthfile << EOF +add :$dummy . $mcookie +EOF + serverargs=${serverargs}" -auth "${xserverauthfile} + + # now add the same credentials to the client authority file + # if '$displayname' already exists do not overwrite it as another + # server man need it. Add them to the '$xserverauthfile' instead. + for displayname in $authdisplay $hostname$authdisplay; do + authcookie=`xauth list "$displayname" \ + | sed -n "s/.*$displayname[[:space:]*].*[[:space:]*]//p"` 2>/dev/null; + if [ "z${authcookie}" = "z" ] ; then + xauth -q << EOF +add $displayname . $mcookie +EOF + removelist="$displayname $removelist" + else + dummy=$(($dummy+1)); + xauth -q -f $xserverauthfile << EOF +add :$dummy . $authcookie +EOF + fi + done +fi + +cleanup() { + + [ -n "$PID" ] && kill $PID > /dev/null 2>&1 + if [ x"$enable_xauth" = x1 ] ; then + if [ x"$removelist" != x ]; then + xauth remove $removelist + fi + if [ x"$xserverauthfile" != x ]; then + rm -f $xserverauthfile + fi + fi + +} + + +trap cleanup 0 + +xinit $clientargs -- $serverargs -deferglyphs 16 & + +PID=$! + +# Write pid to pid file +echo $PID > $pidfilepath + +wait $PID + +unset PID diff --git a/app-misc/sabayon-mce/files/1.1/init.d/sabayon-mce b/app-misc/sabayon-mce/files/1.1/init.d/sabayon-mce new file mode 100644 index 00000000..0dba609b --- /dev/null +++ b/app-misc/sabayon-mce/files/1.1/init.d/sabayon-mce @@ -0,0 +1,41 @@ +#!/sbin/runscript +# Copyright 2012 Sabayon + +depend() { + # In this way autologin settings are overwritten + after mtab sabayonlive + before xdm + need net +} + +start() { + + SABAYON_USER="sabayonmce" + source /sbin/rogentos-functions.sh + + if sabayon_is_mce; then + + ebegin "Sabayon Media Center mode enabled" + + # setup default .dmrc + echo "[Desktop]" > /var/sabayonmce/.dmrc + echo "Session=sabayon-mce" >> /var/sabayonmce/.dmrc + chown sabayonmce /var/sabayonmce/.dmrc + if [ -x "/usr/libexec/gdm-set-default-session" ]; then + # oh my fucking glorious god, this + # is AccountsService bullshit + # cross fingers + /usr/libexec/gdm-set-default-session sabayon-mce + fi + + sabayon_setup_autologin + + elif ! sabayon_is_live && ! sabayon_is_mce; then + ebegin "Sabayon Media Center mode disabled" + sabayon_disable_autologin + fi + + eend 0 + +} + diff --git a/app-misc/sabayon-mce/files/1.1/xsession/sabayon-mce.desktop b/app-misc/sabayon-mce/files/1.1/xsession/sabayon-mce.desktop new file mode 100644 index 00000000..46d11f10 --- /dev/null +++ b/app-misc/sabayon-mce/files/1.1/xsession/sabayon-mce.desktop @@ -0,0 +1,8 @@ +[Desktop Entry] +Encoding=UTF-8 +Name=Sabayon Media Center +Comment=This session loads Sabayon in Media Center mode +Exec=/usr/bin/sabayon-mce-session +Icon= +Type=Application + -- cgit v1.2.3