Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(20)

Unified Diff: third_party/xdg-utils/scripts/xdg-open.in

Issue 3273010: Update our copy of xdg-utils to 2010-08-30, and include a patched xdg-mime. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/deps/
Patch Set: Created 10 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/xdg-utils/scripts/xdg-open ('k') | third_party/xdg-utils/scripts/xdg-screensaver » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/xdg-utils/scripts/xdg-open.in
===================================================================
--- third_party/xdg-utils/scripts/xdg-open.in (revision 57942)
+++ third_party/xdg-utils/scripts/xdg-open.in (working copy)
@@ -1,4 +1,4 @@
-#!/bin/bash
+#!/bin/sh
#---------------------------------------------
# xdg-open
#
@@ -27,10 +27,25 @@
#@xdg-utils-common@
+# This handles backslashes but not quote marks.
+first_word()
+{
+ read first rest
+ echo "$first"
+}
+
open_kde()
{
- kfmclient exec "$1"
- kfmclient_fix_exit_code $?
+ if kde-open -v 2>/dev/null 1>&2; then
+ kde-open "$1"
+ else
+ if [ x"$KDE_SESSION_VERSION" = x"4" ]; then
+ kfmclient openURL "$1"
+ else
+ kfmclient exec "$1"
+ kfmclient_fix_exit_code $?
+ fi
+ fi
if [ $? -eq 0 ]; then
exit_success
@@ -41,7 +56,11 @@
open_gnome()
{
- gnome-open "$1"
+ if gvfs-open --help 2>/dev/null 1>&2; then
+ gvfs-open "$1"
+ else
+ gnome-open "$1"
+ fi
if [ $? -eq 0 ]; then
exit_success
@@ -61,38 +80,80 @@
fi
}
-open_generic()
+open_generic_xdg_mime()
{
- if mimeopen -v 2>/dev/null 1>&2; then
- mimeopen -n "$1"
- if [ $? -eq 0 ]; then
- exit_success
- fi
+ filetype=`xdg-mime query filetype "$1" | sed "s/;.*//"`
+ default=`xdg-mime query default "$filetype"`
+ if [ -n "$default" ] ; then
+ xdg_user_dir="$XDG_DATA_HOME"
+ [ -n "$xdg_user_dir" ] || xdg_user_dir="$HOME/.local/share"
+
+ xdg_system_dirs="$XDG_DATA_DIRS"
+ [ -n "$xdg_system_dirs" ] || xdg_system_dirs=/usr/local/share/:/usr/share/
+
+ for x in `echo "$xdg_user_dir:$xdg_system_dirs" | sed 's/:/ /g'`; do
+ file="$x/applications/$default"
+ if [ -r "$file" ] ; then
+ command="`grep -E "^Exec(\[[^]=]*])?=" "$file" | cut -d= -f 2- | first_word`"
+ command_exec=`which $command 2>/dev/null`
+ if [ -x "$command_exec" ] ; then
+ $command_exec "$1"
+ if [ $? -eq 0 ]; then
+ exit_success
+ fi
+ fi
+ fi
+ done
fi
+}
- if which run-mailcap 2>/dev/null 1>&2 &&
- (echo "$1" | grep -q '^file://' ||
+open_generic()
+{
+ # Paths or file:// URLs
+ if (echo "$1" | grep -q '^file://' ||
! echo "$1" | egrep -q '^[a-zA-Z+\.\-]+:'); then
local file=$(echo "$1" | sed 's%^file://%%')
- run-mailcap --action=view "$file"
- if [ $? -eq 0 ]; then
- exit_success
+
+ # Decode URLs
+ # TODO
+
+ check_input_file "$file"
+
+ open_generic_xdg_mime "$file"
+
+ if [ -f /etc/debian_version ] &&
+ which run-mailcap 2>/dev/null 1>&2; then
+ run-mailcap --action=view "$file"
+ if [ $? -eq 0 ]; then
+ exit_success
+ fi
fi
+
+ if mimeopen -v 2>/dev/null 1>&2; then
+ mimeopen -L -n "$file"
+ if [ $? -eq 0 ]; then
+ exit_success
+ fi
+ fi
fi
IFS=":"
for browser in $BROWSER; do
if [ x"$browser" != x"" ]; then
- IFS=' '
- browser_with_arg=${browser//'%s'/"$1"}
+ browser_with_arg=`printf "$browser" "$1" 2>/dev/null`
+ if [ $? -ne 0 ]; then
+ browser_with_arg=$browser;
+ fi
- if [ x"$browser_with_arg" = x"$browser" ]; then "$browser" "$1";
- else $browser_with_arg;
+ if [ x"$browser_with_arg" = x"$browser" ]; then
+ "$browser" "$1";
+ else eval '$browser_with_arg'$xdg_redirect_output;
fi
- if [ $? -eq 0 ]; then exit_success;
+ if [ $? -eq 0 ]; then
+ exit_success;
fi
fi
done
@@ -128,13 +189,17 @@
detectDE
if [ x"$DE" = x"" ]; then
- # if BROWSER variable is not set, check some well known browsers instead
- if [ x"$BROWSER" = x"" ]; then
- BROWSER=firefox:mozilla:netscape
- fi
DE=generic
fi
+# if BROWSER variable is not set, check some well known browsers instead
+if [ x"$BROWSER" = x"" ]; then
+ BROWSER=links2:links:lynx:w3m
+ if [ -n "$DISPLAY" ]; then
+ BROWSER=firefox:mozilla:epiphany:konqueror:chromium-browser:google-chrome:$BROWSER
+ fi
+fi
+
case "$DE" in
kde)
open_kde "$url"
« no previous file with comments | « third_party/xdg-utils/scripts/xdg-open ('k') | third_party/xdg-utils/scripts/xdg-screensaver » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698