X-Git-Url: https://feistymeow.org/gitweb/?a=blobdiff_plain;f=scripts%2Ftty%2Fterminal_titler.sh;h=0203b9ae7fd771bbacbc80b1c2d2319e34462e3f;hb=114c4d0b2dcaebe6bab3a24ad07483c5bacc7ece;hp=f32b10b5707ff2d2498492ad3f19a9bba75df827;hpb=8d62fc5172372ffab8b751235e499a65662750e2;p=feisty_meow.git diff --git a/scripts/tty/terminal_titler.sh b/scripts/tty/terminal_titler.sh index f32b10b5..0203b9ae 100644 --- a/scripts/tty/terminal_titler.sh +++ b/scripts/tty/terminal_titler.sh @@ -4,7 +4,7 @@ source "$FEISTY_MEOW_SCRIPTS/core/functions.sh" source "$FEISTY_MEOW_SCRIPTS/core/common.alias" # uncomment this to get extra noisy debugging. -export DEBUG_TERM_TITLE=true +#export DEBUG_TERM_TITLE=true # puts a specific textual label on the terminal title bar. # this doesn't consider any previous titles; it just labels the terminal. @@ -45,7 +45,8 @@ function set_terminal_title() # echoes back the current title on the terminal window, if we can acquire it. function get_terminal_title() { - local term_title_found + # this is an important value now; it is checked for in save_terminal_title. + local term_title_found="unknown" # save the former terminal title if we're running in X with xterm. which xprop &>/dev/null if [ $? -eq 0 ]; then @@ -54,19 +55,19 @@ function get_terminal_title() term_title_found="$(xprop -id $WINDOWID | perl -nle 'print $1 if /^WM_NAME.+= \"(.*)\"$/')" fi fi - echo "$term_title_found" + echo -n "$term_title_found" } # reads the current terminal title, if possible, and saves it to our record. function save_terminal_title() { local title="$(get_terminal_title)" - if [ ! -z "$title" ]; then + if [ "$title" != "unknown" ]; then # there was a title, so save it. if [ ! -z "$DEBUG_TERM_TITLE" ]; then - echo "saving prior terminal title as '$prior_title'" + echo "saving prior terminal title as '$title'" fi - export PRIOR_TERMINAL_TITLE="$prior_title" + export PRIOR_TERMINAL_TITLE="$title" else # the terminal had no title, or we couldn't access it, or there's no terminal. if [ ! -z "$DEBUG_TERM_TITLE" ]; then @@ -101,7 +102,7 @@ function label_terminal_with_info() fi pruned_host=$(echo $HOSTNAME | sed -e 's/^\([^\.]*\)\..*$/\1/') date_string=$(date +"%Y %b %e @ %T") - user=$USER + user=$(logname) if [ -z "$user" ]; then # try snagging the windoze name. user=$USERNAME