[tor-commits] [torbrowser/master] [Linux] Add a 'complain' shell function to RelativeLink.sh
erinn at torproject.org
erinn at torproject.org
Sun Aug 28 12:10:37 UTC 2011
commit e167e931c8e75d3915317ae3da5d3da747ef5065
Author: Robert Ransom <rransom.8774 at gmail.com>
Date: Wed Aug 24 00:46:50 2011 -0400
[Linux] Add a 'complain' shell function to RelativeLink.sh
If the user is running start-tor-browser from a GUI file manager,
he/she/it probably won't see any messages we output to stdout/stderr.
The 'complain' function tries to make sure the user will actually see
an error message.
---
src/RelativeLink/RelativeLink.sh | 51 ++++++++++++++++++++++++++++++++++++++
1 files changed, 51 insertions(+), 0 deletions(-)
diff --git a/src/RelativeLink/RelativeLink.sh b/src/RelativeLink/RelativeLink.sh
index fe00dcd..0435054 100755
--- a/src/RelativeLink/RelativeLink.sh
+++ b/src/RelativeLink/RelativeLink.sh
@@ -7,6 +7,57 @@
#
# Copyright 2010 The Tor Project. See LICENSE for licensing information.
+# Complain about an error, by any means necessary.
+# Usage: complain message
+# message must not begin with a dash.
+complain () {
+ # If we're being run in a terminal, complain there.
+ #
+ # FIXME Hopefully the user didn't run startx on the console and then
+ # double-click 'start-tor-browser' in a GUI file manager.
+ if [ -t 2 ]; then
+ echo "$1" >&2
+ return
+ fi
+
+ # Otherwise, hope that we're being run in a GUI of some sort,
+ # and try to pop up a message there in the nicest way
+ # possible.
+ #
+ # In mksh, non-existent commands return 127; I'll assume all
+ # other shells set the same exit code if they can't run a
+ # command. (xmessage returns 1 if the user clicks the WM
+ # close button, so we do need to look at the exact exit code,
+ # not just assume the command failed to display a message if
+ # it returns non-zero.)
+ #
+ # If DISPLAY isn't set, the first command on the list will
+ # fail with a non-127 exit code; that feels wrong somehow, but
+ # there's nothing better we can do in that case anyway.
+
+ # First, try zenity.
+ zenity --error --text="$1"
+ if [ "$?" -ne 127 ]; then
+ return
+ fi
+
+ # Try xmessage.
+ xmessage "$1"
+ if [ "$?" -ne 127 ]; then
+ return
+ fi
+
+ # Try gxmessage. This one isn't installed by default on
+ # Debian with the default GNOME installation, so it seems to
+ # be the least likely program to have available, but it might
+ # be used by one of the 'lightweight' Gtk-based desktop
+ # environments.
+ gxmessage "$1"
+ if [ "$?" -ne 127 ]; then
+ return
+ fi
+}
+
if [ "`id -u`" -eq 0 ]; then
echo "The Tor Browser Bundle should not be run as root. Exiting."
exit 1
More information about the tor-commits
mailing list