]> git.pld-linux.org Git - packages/firefox.git/blobdiff - mozilla-firefox.sh
- cleanup (no system libs installed now)
[packages/firefox.git] / mozilla-firefox.sh
index 96b867f2fc84a098b5c69c7e7318cf5e8646b069..ac9e4b0b75f8377e4ce87b63ec560c6e78b391e6 100644 (file)
@@ -1,24 +1,69 @@
 #!/bin/sh
 # based on script by (c) vip at linux.pl, wolf at pld-linux.org
 
-MOZILLA_FIVE_HOME=/usr/lib/mozilla-firefox
+LIBDIR="@LIBDIR@/mozilla-firefox"
+
+MOZILLA_FIVE_HOME=$LIBDIR
+
+MOZARGS=
+MOZLOCALE="$(/usr/bin/locale | grep "^LC_MESSAGES=" | \
+               sed -e "s|LC_MESSAGES=||g" -e "s|\"||g" )"
+for MOZLANG in $(echo $LANGUAGE | tr ":" " ") $MOZLOCALE; do
+       eval MOZLANG="$(echo $MOZLANG | sed -e "s|_\([^.]*\).*|-\1|g")"
+
+       if [ -f $MOZILLA_FIVE_HOME/chrome/$MOZLANG.jar ]; then
+               MOZARGS="-UILocale $MOZLANG"
+               break
+       fi
+done
+
+if [ -z "$MOZARGS" ]; then
+       # try harder
+       for MOZLANG in $(echo $LANGUAGE | tr ":" " ") $MOZLOCALE; do
+               eval MOZLANG="$(echo $MOZLANG | sed -e "s|_.*||g")"
+
+               LANGFILE=$(echo ${MOZILLA_FIVE_HOME}/chrome/${MOZLANG}*.jar \
+                               | sed 's/\s.*//g' )
+               if [ -f "$LANGFILE" ]; then
+                       MOZLANG=$(basename "$LANGFILE" | sed 's/\.jar//')
+                       MOZARGS="-UILocale $MOZLANG"
+                       break
+               fi
+       done
+fi
+
+# compreg.dat and/or chrome.rdf will screw things up if it's from an
+# older version.  http://bugs.gentoo.org/show_bug.cgi?id=63999
+for f in ~/{.,.mozilla/}firefox/*/{compreg.dat,chrome.rdf,XUL.mfasl}; do
+       if [[ -f ${f} && ${f} -ot /usr/bin/mozilla-firefox ]]; then
+               echo "Removing ${f} leftover from older firefox"
+               rm -f "${f}"
+       fi
+done
+
+if [ -n "$MOZARGS" ]; then
+       FIREFOX="$LIBDIR/firefox $MOZARGS"
+else
+       FIREFOX="$LIBDIR/firefox"
+fi
+
 if [ "$1" == "-remote" ]; then
-       /usr/lib/mozilla-firefox/firefox "$@"
+       exec $FIREFOX "$@"
 else
-       PING=`/usr/lib/mozilla-firefox/firefox -remote 'ping()' 2>&1 >/dev/null`
+       PING=`$FIREFOX -remote 'ping()' 2>&1 >/dev/null`
        if [ -n "$PING" ]; then
                if [ -f "`pwd`/$1" ]; then
-                       /usr/lib/mozilla-firefox/firefox "file://`pwd`/$1"
+                       exec $FIREFOX "file://`pwd`/$1"
                else
-                       /usr/lib/mozilla-firefox/firefox "$@"
+                       exec $FIREFOX "$@"
                fi
        else
                if [ -z "$1" ]; then
-                       /usr/lib/mozilla-firefox/firefox -remote 'xfeDoCommand (openBrowser)'
+                       exec $FIREFOX -remote 'xfeDoCommand(openBrowser)'
                elif [ "$1" == "-mail" ]; then
-                       /usr/lib/mozilla-firefox/firefox -remote 'xfeDoCommand (openInbox)'
+                       exec $FIREFOX -remote 'xfeDoCommand(openInbox)'
                elif [ "$1" == "-compose" ]; then
-                       /usr/lib/mozilla-firefox/firefox -remote 'xfeDoCommand (composeMessage)'
+                       exec $FIREFOX -remote 'xfeDoCommand(composeMessage)'
                else
                        if [ -f "`pwd`/$1" ]; then
                                URL="file://`pwd`/$1"
@@ -27,9 +72,9 @@ else
                        fi
                        grep browser.tabs.opentabfor.middleclick ~/.mozilla/firefox/*/prefs.js | grep true > /dev/null
                        if [ 0 -eq 0 ]; then
-                               /usr/lib/mozilla-firefox/firefox -remote "OpenUrl($URL,new-tab)"
+                               exec $FIREFOX -remote "OpenUrl($URL,new-tab)"
                        else
-                               /usr/lib/mozilla-firefox/firefox -remote "OpenUrl($URL,new-window)"
+                               exec $FIREFOX -remote "OpenUrl($URL,new-window)"
                        fi
                fi
        fi
This page took 0.096936 seconds and 4 git commands to generate.