]> git.pld-linux.org Git - packages/firefox.git/blobdiff - mozilla-firefox.sh
- no branding
[packages/firefox.git] / mozilla-firefox.sh
index 05f25ba423f0eaf59a0ea6869a0332b32a3f4519..a8cc354d226f4fdc25228b6599c0bddb0106f49d 100644 (file)
@@ -1,30 +1,69 @@
 #!/bin/sh
 # based on script by (c) vip at linux.pl, wolf at pld-linux.org
 
-if [ `arch` == "x86_64" ]; then
-       LIBDIR="/usr/lib64/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
-       LIBDIR="/usr/lib/mozilla-firefox"
+       FIREFOX="$LIBDIR/firefox"
 fi
 
-MOZILLA_FIVE_HOME=$LIBDIR
 if [ "$1" == "-remote" ]; then
-       $LIBDIR/firefox "$@"
+       exec $FIREFOX "$@"
 else
-       PING=`$LIBDIR/firefox -remote 'ping()' 2>&1 >/dev/null`
+       PING=`$FIREFOX -remote 'ping()' 2>&1 >/dev/null`
        if [ -n "$PING" ]; then
                if [ -f "`pwd`/$1" ]; then
-                       $LIBDIR/firefox "file://`pwd`/$1"
+                       exec $FIREFOX "file://`pwd`/$1"
                else
-                       $LIBDIR/firefox "$@"
+                       exec $FIREFOX "$@"
                fi
        else
                if [ -z "$1" ]; then
-                       $LIBDIR/firefox -remote 'xfeDoCommand (openBrowser)'
+                       exec $FIREFOX -remote 'xfeDoCommand(openBrowser)'
                elif [ "$1" == "-mail" ]; then
-                       $LIBDIR/firefox -remote 'xfeDoCommand (openInbox)'
+                       exec $FIREFOX -remote 'xfeDoCommand(openInbox)'
                elif [ "$1" == "-compose" ]; then
-                       $LIBDIR/firefox -remote 'xfeDoCommand (composeMessage)'
+                       exec $FIREFOX -remote 'xfeDoCommand(composeMessage)'
                else
                        if [ -f "`pwd`/$1" ]; then
                                URL="file://`pwd`/$1"
@@ -32,10 +71,10 @@ else
                                URL="$1"
                        fi
                        grep browser.tabs.opentabfor.middleclick ~/.mozilla/firefox/*/prefs.js | grep true > /dev/null
-                       if [ 0 -eq 0 ]; then
-                               $LIBDIR/firefox -remote "OpenUrl($URL,new-tab)"
+                       if [ $? -eq 0 ]; then
+                               exec $FIREFOX -new-tab "$URL"
                        else
-                               $LIBDIR/firefox -remote "OpenUrl($URL,new-window)"
+                               exec $FIREFOX -new-window "$URL"
                        fi
                fi
        fi
This page took 0.078511 seconds and 4 git commands to generate.