summaryrefslogtreecommitdiffstats
path: root/starttde
diff options
context:
space:
mode:
Diffstat (limited to 'starttde')
-rw-r--r--starttde770
1 files changed, 770 insertions, 0 deletions
diff --git a/starttde b/starttde
new file mode 100644
index 000000000..269d4ffa5
--- /dev/null
+++ b/starttde
@@ -0,0 +1,770 @@
+#!/bin/sh
+#
+# DEFAULT TRINITY STARTUP SCRIPT
+#
+
+# This block might not be appropriate for all systems.
+# It should work for command line logins but graphical
+# login managers might already source these files.
+# Multiple sourcing is not a problem when the files are only
+# containers for environment variables and such.
+if [ -r /etc/xprofile ]; then
+ source /etc/xprofile
+fi
+if [ -r $HOME/.xprofile ]; then
+ source $HOME/.xprofile
+fi
+
+# Some functions to parse and check path correctly ...
+# Usage: is_in_path PATH /usr/bin
+is_in_path() {
+ var="$1"; search="$2";
+ if eval test -z \$$1; then return 1; fi
+ ifs="$IFS"; IFS=":"; eval set \$$var; IFS="$ifs"
+ for i in $*; do
+ [ "${i}" = "${search}" ] && return 0
+ done
+ return 1
+}
+
+# Usage: place_before_in_path PATH /opt/trinity/games /usr/games
+place_before_in_path() {
+ var="$1"; insert="$2";
+ if eval test -z \$$1; then
+ eval export $var=${insert}
+ else
+ before="$3"; ifs="$IFS"; IFS=":"; eval set \$$var; IFS="$ifs"
+ NPATH=""
+ for i in $*; do
+ [ "${i}" = "${before}" ] && NPATH="${NPATH}:${insert}"
+ NPATH="${NPATH}:${i}"
+ done
+ eval export $var=${NPATH#:}
+ fi
+}
+
+# Usage: remove_from_path PATH /opt/trinity/games
+remove_from_path() {
+ var="$1"; remove="$2";
+ if eval test -z \$$1; then return 1; fi
+ ifs="$IFS"; IFS=":"; eval set \$$var; IFS="$ifs"
+ NPATH=""
+ for i in $*; do
+ [ "${i}" != "${remove}" ] && NPATH="${NPATH}:${i}"
+ done
+ eval export $var=${NPATH#:}
+}
+
+echo "[starttde] Starting starttde." 1>&2
+echo "[starttde] This script is $0" 1>&2
+
+# Avoid any possible conflict with KDE4. Therefore within this script
+# use full path names to all binaries used.
+
+# The binaries for TDE are located in the same place as this script.
+# To determine that location use the following method rather than presuming
+# the existence of $TDEDIR. That environment variable might not be
+# defined or defined to point to KDE4 binaries.
+BIN_DIR="`dirname \`readlink -f $0\``"
+if [ -x $BIN_DIR/tde-config ]; then
+ TDE_VERSION=$($BIN_DIR/tde-config --version | while IFS=: read a b; do [ "${a#TDE}" != "$a" ] && echo $b; done)
+ echo "[starttde] TDE version is $TDE_VERSION" 1>&2
+ export TDEDIR=${BIN_DIR%/bin}
+ echo "[starttde] TDE base directory is $TDEDIR" 1>&2
+else
+ echo "[starttde] Unable to determine the TDE bin directory, where this script should be installed."
+ echo "[starttde] This script should be installed in the same directory."
+ echo "[starttde] Exiting."
+ exit 1
+fi
+unset BIN_DIR
+
+# When the X server dies we get a HUP signal from xinit. We must ignore it
+# because we still need to do some cleanup.
+trap '[starttde] echo GOT SIGHUP' HUP
+
+# Check if a TDE session is already running.
+if kcheckrunning >/dev/null 2>&1; then
+ echo "[starttde] TDE seems to be already running on this display."
+ xmessage -center -geometry 500x100 "TDE seems to be already running on this display." > /dev/null 2>/dev/null
+ exit 1
+fi
+
+# Set the background color.
+# The standard X background is nasty, causing moire effects and exploding
+# people's heads. We use colours from the standard TDE palette for those with
+# palettised displays.
+if test -z "$XDM_MANAGED" || echo "$XDM_MANAGED" | grep ",auto" > /dev/null; then
+ xsetroot -solid "#618DCC" # sky blue
+fi
+
+# Unset this for Darwin since it will screw up TDE's dynamic-loading.
+unset DYLD_FORCE_FLAT_NAMESPACE
+
+# Check whether prelinking is enabled. If yes, then exporting TDE_IS_PRELINKED improves
+# loading TDE. The $TDE_IS_PRELINKED variable might already be set on some systems
+# through /etc/profile.d. Therefore first check whether the variable exists.
+if [ "$TDE_IS_PRELINKED" = "" ]; then
+ if [ -r /etc/default/prelink ]; then
+ . /etc/default/prelink
+ elif [ -r /etc/sysconfig/prelink ]; then
+ . /etc/sysconfig/prelink
+ fi
+ if [ "$PRELINKING" = "yes" ]; then
+ export TDE_IS_PRELINKED=1
+ fi
+fi
+
+# Boot sequence:
+#
+# tdeinit is used to fork off processes which improves memory usage
+# and startup time.
+#
+# * tdeinit starts the dcopserver and tdelauncher first.
+# * Then kded is started. kded is responsible for keeping the sycoca
+# database up to date. When an up to date database is present it goes
+# into the background and the startup continues.
+# * Then tdeinit starts kcminit. kcminit performs initialisation of
+# certain devices according to the user's settings
+#
+# * Then ksmserver is started which takes control of the rest of the startup sequence.
+
+# The user's personal TDE directory usually is $HOME/.trinity.
+# This setting may be overridden by setting $TDEHOME. When migrating profiles
+# must be careful here because $HOME/.kde was used commonly in the pre-KDE4
+# days for the user's TDE profile, but now with KDE4 common on systems,
+# $HOME/.kde might point to KDE4 profile settings. The existence of KDE4
+# does not mean all people are using KDE4.
+
+if [ "$TDEHOME" != "" ]; then
+ echo "[starttde] TDEHOME is preset to $TDEHOME." 1>&2
+ export TDEHOME=$TDEHOME
+else
+ # $TDEHOME is NOT already preset in the environment. Try to help.
+ # This might be overkill but does provide flexibility.
+ # This script and kstandardirs.h and kstandardirs.cpp must match.
+ # The latter two must be edited/patched before compiling.
+ echo "[starttde] TDEHOME is not set." 1>&2
+ # Default value: $HOME/.trinity. Most users will use this.
+ export TDEHOME=$HOME/.trinity
+
+ if [ ! -d $HOME/.trinity ] && [ ! -f /usr/bin/kde4-config ] && [ "$TDEDIR"="/usr" ] && [ -d $HOME/.kde ]; then
+ # Looks like Trinity is installed and not playing second fiddle to KDE4.
+ export TDEHOME=$HOME/.kde
+ fi
+ echo "[starttde] Set TDEHOME to $TDEHOME." 1>&2
+fi
+
+# tdesu needs something to find root's TDE profile. Set the TDEROOTHOME variable
+# here as last resort. /root/.trinity is a safe presumption. If an admin wants
+# a different location then set the TDEROOTHOME variable elsewhere.
+if [ "$TDEROOTHOME" = "" ]; then
+ export TDEROOTHOME=/root/.trinity
+ echo "[starttde] Setting TDEROOTHOME to $TDEROOTHOME."
+fi
+
+# Modify the following environment variables only as necessary.
+if [ -d $TDEDIR/games ]; then
+ if ! is_in_path PATH "$TDEDIR/games" ; then
+ # Respect the traditional path order. Don't blindly place $TDEDIR/games
+ # first in the path. Only place $TDEDIR/games before /usr/games. If packagers
+ # are adding $TDEDIR/games elsewhere, then they need to ensure the traditional
+ # search patch is respected.
+ # Is there a way we can check that $TDEDIR/games is always placed only just before
+ # /usr/games in the search path?
+ if is_in_path PATH "/usr/games"; then
+ place_before_in_path PATH "$TDEDIR/games" "/usr/games"
+ else
+ export PATH=$TDEDIR/games:$PATH
+ fi
+ fi
+fi
+if [ -d $TDEDIR/bin ]; then
+ if ! is_in_path PATH "$TDEDIR/bin" ]; then
+ # Respect the traditional path order. Don't blindly place $TDEDIR/bin
+ # first in the path. Only place $TDEDIR/bin before /usr/bin. This order is
+ # consistent with tdelibs/tdesu/stub.cpp. If packagers are adding $TDEDIR/bin
+ # elsewhere, then they need to ensure the traditional search patch is respected.
+ # Is there a way we can check that $TDEDIR/bin is always placed only just before
+ # /usr/bin in the search path?
+ if is_in_path PATH "/usr/bin"; then
+ place_before_in_path PATH "$TDEDIR/bin" "/usr/bin"
+ else
+ export PATH=$TDEDIR/bin:$PATH
+ fi
+ fi
+fi
+if [ -d $TDEDIR/share/man ]; then
+ if [ -x /usr/bin/manpath ]; then
+ if [ "`manpath 2>/dev/null | grep \"$TDEDIR/share/man\"`" = "" ]; then
+ export MANPATH=$TDEDIR/share/man:$MANPATH
+ fi
+ else
+ if [ "`echo $MANPATH | grep \"$TDEDIR/share/man\"`" = "" ]; then
+ export MANPATH=$TDEDIR/share/man:$MANPATH
+ fi
+ fi
+fi
+
+if [ "$XDG_CONFIG_DIRS" = "" ]; then
+ if [ -d /etc/xdg ]; then
+ XDG_CONFIG_DIRS=/etc/xdg
+ fi
+fi
+if [ -d /etc/trinity/xdg ]; then
+ TDE_XDG_DIR="/etc/trinity/xdg"
+elif [ -d /etc/tde/xdg ]; then
+ TDE_XDG_DIR="/etc/tde/xdg"
+elif [ -d $TDEDIR/xdg ]; then
+ TDE_XDG_DIR="$TDEDIR/xdg"
+elif [ -d $TDEDIR/etc/xdg ]; then
+ TDE_XDG_DIR="$TDEDIR/etc/xdg"
+elif [ -d $TDEDIR/etc/trinity/xdg ]; then
+ TDE_XDG_DIR="$TDEDIR/etc/trinity/xdg"
+elif [ -d $TDEDIR/etc/tde/xdg ]; then
+ TDE_XDG_DIR="$TDEDIR/etc/tde/xdg"
+elif [ -d $TDEDIR/trinity/xdg ]; then
+ TDE_XDG_DIR="$TDEDIR/trinity/xdg"
+elif [ -d $TDEDIR/tde/xdg ]; then
+ TDE_XDG_DIR="$TDEDIR/tde/xdg"
+fi
+if [ -d $TDE_XDG_DIR ]; then
+ if [ "`echo $XDG_CONFIG_DIRS | grep \"$TDE_XDG_DIR\"`" = "" ]; then
+ if [ "$XDG_CONFIG_DIRS" = "" ]; then
+ XDG_CONFIG_DIRS=$TDE_XDG_DIR
+ else
+ XDG_CONFIG_DIRS=$TDE_XDG_DIR:$XDG_CONFIG_DIRS
+ fi
+ fi
+fi
+if [ "$XDG_CONFIG_DIRS" != "" ]; then
+ export XDG_CONFIG_DIRS
+fi
+
+# Explicitly set $XDG_DATA_DIRS only when Trinity is not installed in /usr.
+# Explicitly declaring $XDG_DATA_DIRS will override the default search path of /usr/share.
+# Explicitly declaring $XDG_DATA_DIRS will override $TDEDIRS, which must then be
+# explicitly identified in the $XDG_DATA_DIRS string to remain useful.
+# The $TDEDIR variable is intended to be singular and $TDEDIRS plural. When $TDEDIRS
+# exists in the environment then parse that variable into separate directories.
+# $TDEDIRS should contain whatever is set in $TDEDIR. Therefore any additional directories
+# set in $TDEDIRS are intended to override data files found in $TDEDIR. Those additional
+# directories should be placed before $TDEDIR and before /usr/share.
+if [ "$TDEDIR" != "/usr" ] && [ -d $TDEDIR/share ]; then
+ # If '/usr/share' is not already here, we include it at the last position.
+ if ! is_in_path XDG_DATA_DIRS "/usr/share"; then
+ XDG_DATA_DIRS=$XDG_DATA_DIRS:/usr/share
+ fi
+
+ # Ensure that $TDEDIR/share is always before '/usr/share'.
+ remove_from_path XDG_DATA_DIRS $TDEDIR/share
+ place_before_in_path XDG_DATA_DIRS "$TDEDIR/share" "/usr/share"
+
+ # Adds supplementary directories from TDEDIRS, if any, before TDEDIR.
+ if [ "$TDEDIRS" != "" ]; then
+ ifs="$IFS"; IFS=":"; set $TDEDIRS; IFS="$ifs"
+ for dir in $*; do
+ if ! is_in_path XDG_DATA_DIRS "$dir/share" && [ -d "$dir/share" ]; then
+ XDG_DATA_DIRS=$dir/share:$XDG_DATA_DIRS
+ fi
+ done
+ fi
+ export XDG_DATA_DIRS
+fi
+
+echo "[starttde] XDG_DATA_DIRS: $XDG_DATA_DIRS" 1>&2
+
+test -n "$TDEHOME" && tdehome=`echo "$TDEHOME" | sed "s,^~/,$HOME/,"`
+
+# Allow interested applications, such as the Plasma control wrapper,
+# to know that this is a Trinity desktop and not a KDE one.
+export DESKTOP_SESSION=trinity
+
+# Create profile directory.
+if [ ! -d "$tdehome" ]; then
+ echo "[starttde] Creating $tdehome" 1>&2
+ mkdir -m 700 -p "$tdehome"
+fi
+if [ -d "$tdehome" ]; then
+ # Run some R14 updates.
+ R14_UPDATED="`$TDEDIR/bin/kreadconfig --file kdeglobals --group "R14 XDG Updates" --key Updated --default false`"
+ R14_VERSION="`$TDEDIR/bin/kreadconfig --file kdeglobals --group "R14 XDG Updates" --key Version --default 0`"
+ if [ -e $TDEDIR/bin/r14-xdg-update ]; then
+ # Script version index is used to allow automatic rerun
+ R14_SCRIPT="`sed -n "s/SCRIPT_VERSION=\([0-9]*\)/\1/p" $TDEDIR/bin/r14-xdg-update`"
+ else
+ R14_SCRIPT=0
+ fi
+ if [ "$R14_UPDATED" != "true" ] || [ "$R14_VERSION" -lt "$R14_SCRIPT" ]; then
+ if [ -e $TDEDIR/bin/r14-xdg-update ]; then
+ sh $TDEDIR/bin/r14-xdg-update
+ EXIT_CODE="$?"
+ else
+ echo "[starttde] $TDEDIR/bin/r14-xdg-update does not exist." 1>&2
+ echo " Unable to perform a profile update for Trinity release R14."
+ fi
+ if [ "$EXIT_CODE" != "0" ]; then
+ exit 1
+ fi
+ fi
+fi
+
+# Please see tdestartupconfig source for usage.
+mkdir -m 700 -p "$tdehome/share"
+mkdir -m 700 -p "$tdehome/share/config"
+cat >"$tdehome/share/config/startupconfigkeys" <<EOF
+kcminputrc Mouse cursorTheme ''
+kcminputrc Mouse cursorSize ''
+kpersonalizerrc General FirstLogin true
+ksplashrc KSplash Theme Default
+kcmrandrrc Display ApplyOnStartup false
+kcmrandrrc [Screen0]
+kcmrandrrc [Screen1]
+kcmrandrrc [Screen2]
+kcmrandrrc [Screen3]
+kcmfonts General forceFontDPI 0
+EOF
+$TDEDIR/bin/tdestartupconfig
+if test $? -ne 0; then
+ xmessage -center -geometry 500x100 "Could not start tdestartupconfig. Check your installation."
+fi
+# $tdehome/share/config/startupconfig should exist but avoid script failure if not.
+if [ -r "$tdehome/share/config/startupconfig" ]; then
+ . "$tdehome/share/config/startupconfig"
+fi
+
+# Make sure a default wallpaper is set.
+if [ ! -e "$tdehome/share/config/kdesktoprc" ]; then
+ # With Trinity this file should exist, but test first.
+ if [ -r /usr/share/wallpapers/isadora.png.desktop ]; then
+cat >"$tdehome/share/config/kdesktoprc" <<EOF
+[Desktop0]
+Wallpaper=isadora.png
+WallpaperMode=Scaled
+EOF
+ fi
+fi
+
+# XCursor mouse theme needs to be applied here to work even for kded or ksmserver.
+if test -n "$kcminputrc_mouse_cursortheme" -o -n "$kcminputrc_mouse_cursorsize" ; then
+ kapplymousetheme "$kcminputrc_mouse_cursortheme" "$kcminputrc_mouse_cursorsize"
+ if test $? -eq 10; then
+ export XCURSOR_THEME=default
+ elif test -n "$kcminputrc_mouse_cursortheme"; then
+ export XCURSOR_THEME="$kcminputrc_mouse_cursortheme"
+ fi
+ if test -n "$kcminputrc_mouse_cursorsize"; then
+ export XCURSOR_SIZE="$kcminputrc_mouse_cursorsize"
+ fi
+fi
+
+if test "$kcmrandrrc_display_applyonstartup" = "true"; then
+ # 4 screens is hopefully enough.
+ for scrn in 0 1 2 3; do
+ args=
+ width="\$kcmrandrrc_screen${scrn}_width" ; eval "width=$width"
+ height="\$kcmrandrrc_screen${scrn}_height" ; eval "height=$height"
+ if test -n "${width}" -a -n "${height}"; then
+ args="$args -s ${width}x${height}"
+ fi
+ refresh="\$kcmrandrrc_screen${scrn}_refresh" ; eval "refresh=$refresh"
+ if test -n "${refresh}"; then
+ args="$args -r ${refresh}"
+ fi
+ rotation="\$kcmrandrrc_screen${scrn}_rotation" ; eval "rotation=$rotation"
+ if test -n "${rotation}"; then
+ case "${rotation}" in
+ 0)
+ args="$args -o 0"
+ ;;
+ 90)
+ args="$args -o 1"
+ ;;
+ 180)
+ args="$args -o 2"
+ ;;
+ 270)
+ args="$args -o 3"
+ ;;
+ esac
+ fi
+ reflectx="\$kcmrandrrc_screen${scrn}_reflectx" ; eval "reflectx=$reflectx"
+ if test "${refrectx}" = "true"; then
+ args="$args -x"
+ fi
+ reflecty="\$kcmrandrrc_screen${scrn}_reflecty" ; eval "reflecty=$reflecty"
+ if test "${refrecty}" = "true"; then
+ args="$args -y"
+ fi
+ if test -n "$args"; then
+ xrandr $args
+ fi
+ done
+fi
+
+dl=$DESKTOP_LOCKED
+unset DESKTOP_LOCKED # Don't want it in the environment
+
+# Launch splash that doesn't need any TDE libraries here, before
+# TDE libraries are loaded into memory (which may take some time
+# with cold caches). Makes the splash appear sooner.
+# If kpersonalizer needs to be run splash will be started only later.
+if test -z "$dl" && test "$kpersonalizerrc_general_firstlogin" != "true"; then
+ case "$ksplashrc_ksplash_theme" in
+ Simple)
+ ksplashsimple
+ ;;
+ *)
+ ;;
+ esac
+fi
+
+if test "$kcmfonts_general_forcefontdpi" -eq 120; then
+ xrdb -quiet -merge -nocpp <<EOF
+Xft.dpi: 120
+EOF
+elif test "$kcmfonts_general_forcefontdpi" -eq 96; then
+ xrdb -quiet -merge -nocpp <<EOF
+Xft.dpi: 96
+EOF
+fi
+
+# Configuration of the gtk_qt_engine if not already set.
+
+if test -n "$TDEDIRS"; then
+ tdedirs_first=${TDEDIRS%%:*}
+ TGTK_RC_ENGINE=$tdedirs_first/share/kgtk/gtk-qt-engine.rc.sh
+ TGTK_RC_TDE1=$tdedirs_first/share/kgtk/.gtkrc-2.0-kde4
+ TGTK_RC_TDE2=$tdedirs_first/share/kgtk/.gtkrc-2.0-kde-kde4
+else
+ TGTK_RC_ENGINE=$TDEDIR/share/kgtk/gtk-qt-engine.rc.sh
+ TGTK_RC_TDE1=$TDEDIR/share/kgtk/.gtkrc-2.0-kde4
+ TGTK_RC_TDE2=$TDEDIR/share/kgtk/.gtkrc-2.0-kde-kde4
+fi
+
+if [ ! -e "$tdehome/env/gtk-qt-engine.rc.sh" ] && [ -e $TGTK_RC_ENGINE ]; then
+ mkdir -p "$tdehome/env"
+ cp -f $TGTK_RC_ENGINE "$tdehome/env"
+ chmod 755 "$tdehome/env/gtk-qt-engine.rc.sh"
+fi
+
+if [ ! -e $HOME/.gtkrc-2.0-kde4 ] && [ -e $TGTK_RC_TDE1 ]
+then
+ cp -f $TGTK_RC_TDE1 $HOME
+fi
+
+if [ ! -e $HOME/.gtkrc-2.0-kde-kde4 ] && [ -e $TGTK_RC_TDE2 ]
+then
+ cp -f $TGTK_RC_TDE2 $HOME
+fi
+
+# Source scripts found in <localprefix>/env/*.sh and <prefixes>/env/*.sh
+# (where <localprefix> is $TDEHOME or ~/.trinity, and <prefixes> is where TDE is installed)
+#
+# This is where you can define environment variables that will be available to
+# all TDE programs. That is where to run agents using for example, eval `ssh-agent`
+# or eval `gpg-agent --daemon`.
+# Note: if you do that, you should also put "ssh-agent -k" as a shutdown script.
+# (Read the end of this script for running shutdown scripts).
+# For anything else (that doesn't set env vars, or that needs a window manager),
+# better use the Autostart folder.
+
+exepath=`tde-config --path exe | tr : '\n'`
+
+for prefix in `echo "$exepath" | sed -n -e 's,/bin[^/]*/,/env/,p'`; do
+ for file in "$prefix"*.sh; do
+ test -r "$file" && . "$file"
+ done
+done
+
+# Activate the TDE font directories.
+#
+# There are 4 directories that may be used for supplying fonts for TDE.
+#
+# There are two system directories. These belong to the administrator.
+# There are two user directories, where the user may add her own fonts.
+#
+# The 'override' versions are for fonts that should come first in the list,
+# i.e. if you have a font in your 'override' directory, it will be used in
+# preference to any other.
+#
+# The preference order looks like this:
+# user override, system override, X, user, system.
+#
+# Where X is the original font database that was set up before this
+# script runs.
+
+usr_odir=$HOME/.fonts/kde-override
+usr_fdir=$HOME/.fonts
+
+# Add any user-installed font directories to the X font path.
+tde_fontpaths=$usr_fdir/fontpaths
+do_usr_fdir=1
+do_usr_odir=1
+if test -r "$tde_fontpaths" ; then
+ savifs=$IFS
+ IFS="
+"
+ for fpath in `grep -v '^[ ]*#' < "$tde_fontpaths"` ; do
+ rfpath=`echo $fpath | sed "s:^~:$HOME:g"`
+ if test -s "$rfpath"/fonts.dir; then
+ xset fp+ "$rfpath"
+ if test "$rfpath" = "$usr_fdir"; then
+ do_usr_fdir=0
+ fi
+ if test "$rfpath" = "$usr_odir"; then
+ do_usr_odir=0
+ fi
+ fi
+ done
+ IFS=$savifs
+fi
+
+echo "[starttde] TDEDIR: $TDEDIR" 1>&2
+echo "[starttde] TDEDIRS: $TDEDIRS" 1>&2
+
+if test -n "$TDEDIRS"; then
+ tdedirs_first=${TDEDIRS%%:*}
+ sys_odir=$tdedirs_first/share/fonts/override
+ sys_fdir=$tdedirs_first/share/fonts
+else
+ sys_odir=$TDEDIR/share/fonts/override
+ sys_fdir=$TDEDIR/share/fonts
+fi
+
+if test -n "$TDEDIRS"; then
+ tdedirs_first=${TDEDIRS%%:*}
+ echo "[starttde] tdedirs_first: $tdedirs_first"
+ if [ -r $tdedirs_first/share/kgtk/preload ]; then
+ echo "[starttde] Reading from $tdedirs_first/share/kgtk/preload"
+ read -r TGTK_PRELOAD < $tdedirs_first/share/kgtk/preload
+ fi
+else
+ if [ -r $TDEDIR/share/kgtk/preload ]; then
+ read -r TGTK_PRELOAD < $TDEDIR/share/kgtk/preload
+ fi
+fi
+
+if [ "$TGTK_PRELOAD" != "" ]; then
+ if [ -e /usr/lib64/libnspr4.so ]; then
+ TGTK_NSPR_PRELOAD="/usr/lib64/libnspr4.so:"
+ elif [ -e /usr/lib/libnspr4.so ]; then
+ TGTK_NSPR_PRELOAD="/usr/lib/libnspr4.so:"
+ fi
+ export LD_PRELOAD=$TGTK_PRELOAD:$KGTK_NSPR_PRELOAD$LD_PRELOAD
+fi
+
+# We run mkfontdir on the user's font dirs (if we have permission) to pick
+# up any new fonts they may have installed. If mkfontdir fails, we still
+# add the user's dirs to the font path, as they might simply have been made
+# read-only by the administrator, for whatever reason.
+
+# Only do usr_fdir and usr_odir if they are *not* listed in fontpaths.
+if [ -e $sys_odir/fonts.dir ]
+then
+ xset +fp "$sys_odir"
+fi
+test $do_usr_odir -eq 1 && test -d "$usr_odir" && (mkfontdir "$usr_odir" ; xset +fp "$usr_odir")
+test $do_usr_fdir -eq 1 && test -d "$usr_fdir" && (mkfontdir "$usr_fdir" ; xset fp+ "$usr_fdir")
+test -d "$sys_fdir" && xset fp+ "$sys_fdir"
+
+# Ask X11 to rebuild its font list.
+xset fp rehash
+
+# Set a left cursor instead of the standard X11 "X" cursor, since I've heard
+# from some users that they're confused and don't know what to do. This is
+# especially necessary on slow machines, where starting TDE takes one or two
+# minutes until anything appears on the screen.
+#
+# If the user has overwritten fonts, the cursor font may be different now
+# so don't move this up.
+#
+xsetroot -cursor_name left_ptr
+
+# Get Ghostscript to look into user's TDE fonts dir for additional Fontmap.
+if test -n "$GS_LIB" ; then
+ GS_LIB=$usr_fdir:$GS_LIB
+ export GS_LIB
+else
+ GS_LIB=$usr_fdir
+ export GS_LIB
+fi
+
+# Link "tmp" "socket" and "cache" resources to directory in $TMP.
+# Creates:
+# - a directory $TMP/tde-$USER and is linked from $TDEHOME/tmp-$HOSTNAME to it.
+# - a directory $TMP/tdesocket-$USER and is linked from $TDEHOME/socket-$HOSTNAME to it.
+# - a directory /var/tmp/tdecache-$USER and is linked from $TDEHOME/cache-$HOSTNAME to it.
+# Note: temporary locations can be overridden through the TDETMP and TDEVARTMP
+# environment variables.
+for resource in tmp cache socket; do
+ if ! lnusertemp $resource >/dev/null; then
+ echo "[starttde] Call to lnusertemp failed (temporary directories full?). Check your installation." 1>&2
+ xmessage -center -geometry 600x100 "Call to lnusertemp failed (temporary directories full?). Check your installation."
+ exit 1
+ fi
+done
+
+# In case of dcop sockets left by a previous session, cleanup.
+$TDEDIR/bin/dcopserver_shutdown
+
+echo "[starttde] Starting Trinity..." 1>&2
+
+# Detect any running Xorg composition managers.
+$TDEDIR/bin/kdetcompmgr
+
+# Run KPersonalizer before the session if this is the first login.
+if test "$kpersonalizerrc_general_firstlogin" = "true"; then
+ if [ ! -x $TDEDIR/bin/kpersonalizer ]; then
+ echo "[starttde] kpersonalizer not found! Please install in order to properly configure your user profile." 1>&2
+ else
+ # Start only dcopserver, don't start whole tdeinit (takes too long).
+ echo "[starttde] Running kpersonalizer..." 1>&2
+ $TDEDIR/bin/dcopserver
+ $TDEDIR/bin/twin --lock &
+ $TDEDIR/bin/kpersonalizer --before-session
+ # Handle kpersonalizer restarts (language change).
+ while test $? -eq 1; do
+ $TDEDIR/bin/kpersonalizer --r --before-session
+ done
+ $TDEDIR/bin/dcopquit twin
+ $TDEDIR/bin/dcopserver_shutdown --wait
+ fi
+fi
+
+# Apply any user-specific display configuration settings
+$TDEDIR/bin/tdeinit_displayconfig
+EXIT_CODE="$?"
+
+# Remove moodin cache if we have a new wallpaper installed, jriddell. Distro-specific.
+if [ -d "$tdehome/share/apps/ksplash/cache/Moodin/kubuntu" ]; then
+ if [ /usr/share/wallpapers/kubuntu-wallpaper.png -nt "$tdehome/share/apps/ksplash/cache/Moodin/kubuntu/" ]; then
+ rm -rf "$tdehome/share/apps/ksplash/cache/Moodin/kubuntu/"
+ fi
+fi
+
+if test -z "$dl"; then
+ # The splashscreen and progress indicator.
+ case "$ksplashrc_ksplash_theme" in
+ None)
+ ;; # Nothing.
+ Simple)
+ if test "$kpersonalizerrc_general_firstlogin" = "true"; then
+ $TDEDIR/bin/ksplashsimple
+ fi # Otherwise started earlier.
+ ;;
+ *)
+ $TDEDIR/bin/ksplash --nodcop
+ ;;
+ esac
+fi
+
+# Mark that full TDE session is running (for example, Konqueror preloading works only
+# with full TDE running). The TDE_FULL_SESSION property can be detected by
+# any X client connected to the same X session, even if not launched
+# directly from the TDE session but for example, using "ssh -X", tdesu. $TDE_FULL_SESSION
+# however guarantees that the application is launched in the same environment
+# like the TDE session and that for example, TDE utilities/libraries are available.
+# The matching tests are:
+# For $TDE_FULL_SESSION:
+# if test -n "$TDE_FULL_SESSION"; then ... whatever
+# For TDE_FULL_SESSION property:
+# xprop -root | grep "^TDE_FULL_SESSION" >/dev/null 2>/dev/null
+# if test $? -eq 0; then ... whatever
+#
+# Additionally there is $TDE_SESSION_UID with the uid of the user
+# running the TDE session. It should be rarely needed (for example,
+# after sudo to prevent desktop-wide functionality in the new user's kded).
+#
+TDE_FULL_SESSION=true
+export TDE_FULL_SESSION
+xprop -root -f TDE_FULL_SESSION 8t -set TDE_FULL_SESSION true
+echo "[starttde] TDE_FULL_SESSION: $TDE_FULL_SESSION" 1>&2
+TDE_SESSION_UID=`id -u`
+export TDE_SESSION_UID
+echo "[starttde] TDE_SESSION_UID: $TDE_SESSION_UID" 1>&2
+
+# We set LD_BIND_NOW to increase the efficiency of tdeinit.
+# tdeinit unsets this variable before loading applications.
+LD_BIND_NOW=true $TDEDIR/bin/start_tdeinit_wrapper --new-startup +kcminit_startup
+if test $? -ne 0; then
+ # Startup error
+ echo "[starttde] Could not start tdeinit. Check your installation." 1>&2
+ xmessage -center -geometry 500x100 "Could not start tdeinit. Check your installation."
+fi
+echo "[starttde] tdeinit started successfully." 1>&2
+
+# If the session should be locked from the start (locked autologin),
+# lock now and do the rest of the TDE startup underneath the locker.
+# FIXME
+# kdesktop needs to be notified of this locker process somehow so that
+# it does not attempt to launch its own locker process on startup!
+if test -n "$dl"; then
+ $TDEDIR/bin/kwrapper kdesktop_lock --forcelock &
+ # Give it some time for starting up. This is somewhat unclean; some
+ # notification would be better.
+ sleep 1
+fi
+
+# Finally, give the session control to the session manager.
+# See tdebase/ksmserver for the description of the rest of the startup sequence.
+# When set, the TDEWM environment variable will be used as Trinity's
+# window manager instead of twin.
+# When TDEWM is not set, ksmserver will ensure twin is started.
+# kwrapper is used to reduce startup time and memory usage.
+# kwrapper does not return useful error codes such as the exit code of ksmserver.
+# We only check for 255, which means the ksmserver process could not be
+# started. Any problems thereafter, for example, ksmserver failing to initialize,
+# will remain undetected.
+# tdeinit_phase1 is still experimental.
+$TDEDIR/bin/tdeinit_phase1
+EXIT_CODE="$?"
+# If tdeinit_phase1 should cause problems, here is the old way:
+# test -n "$TDEWM" && TDEWM="--windowmanager $TDEWM"
+# $TDEDIR/bin/kwrapper $TDEDIR/bin/ksmserver $TDEWM
+# EXIT_CODE="$?"
+if test $EXIT_CODE -eq 255; then
+ # Startup error
+ echo "[starttde] An error was detected while attempting to load the session manager. Please check your installation for problems." 1>&2
+ xmessage -center -geometry 500x100 "An error was detected while attempting to load the session manager. Please check your installation for problems."
+fi
+
+# Wait if there's any crashhandler shown.
+while $TDEDIR/bin/dcop | grep -q ^drkonqi- ; do
+ sleep 5
+done
+
+echo "[starttde] Shutting down Trinity..." 1>&2
+
+# Clean up.
+$TDEDIR/bin/tdeinit_shutdown
+$TDEDIR/bin/dcopserver_shutdown --wait
+$TDEDIR/bin/artsshell -q terminate
+# KDE4 support.
+if [ -f /usr/bin/kdeinit4_shutdown ]; then
+ /usr/bin/kde4 kdeinit4_shutdown 2>/dev/null
+fi
+
+echo "[starttde] Running Trinity shutdown scripts..." 1>&2
+
+# Run scripts found in shutdown directories. Those locations are:
+# * $TDEHOME/shutdown
+# * $PREFIX/shutdown
+# * $TDEDIRS/shutdown ($TDEDIRS, not $TDEDIR)
+# Presumed is $TDEDIRS/bin exists. Create $TDEDIRS/bin even when
+# only using the shutdown directory or this snippet will fail to find
+# that shutdown directory.
+for prefix in `echo "$exepath" | sed -n -e 's,/bin[^/]*/,/shutdown/,p'`; do
+ for file in `ls "$prefix" 2> /dev/null | egrep -v '(~|\.bak)$'`; do
+ if [ -x "${prefix}${file}" ]; then
+ echo "[starttde] Running ${prefix}${file}." 1>&2
+ sh ${prefix}${file}
+ fi
+ done
+done
+
+unset TDE_FULL_SESSION
+xprop -root -remove TDE_FULL_SESSION
+unset TDE_SESSION_UID
+
+echo "[starttde] Trinity shutdown complete." 1>&2