Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
958ae3f264 | |||
d8b9b5dc01 | |||
7696ea5ce8 | |||
214ab03647 | |||
97b1be6732 | |||
545447c9b0 | |||
93ec32f793 | |||
02c7e5cb1a | |||
b32491ea9c |
@@ -1,7 +1,7 @@
|
|||||||
sx-open
|
sx-open
|
||||||
=======
|
=======
|
||||||
|
|
||||||
sx-open is an attemt to implement a saner alternative to xdg-open.
|
sx-open is an attempt to implement a saner alternative to xdg-open.
|
||||||
|
|
||||||
Installation
|
Installation
|
||||||
------------
|
------------
|
||||||
|
37
sx-open
37
sx-open
@@ -3,16 +3,19 @@
|
|||||||
|
|
||||||
# Source the config file.
|
# Source the config file.
|
||||||
cfg_file="$HOME/.config/sx-open.cfg"
|
cfg_file="$HOME/.config/sx-open.cfg"
|
||||||
|
cfg_uri_regex='^[A-Za-z]([A-Za-z0-9+.-]+)?://.+'
|
||||||
[[ -f "$cfg_file" ]] && { source "$cfg_file"; }
|
[[ -f "$cfg_file" ]] && { source "$cfg_file"; }
|
||||||
|
|
||||||
usage() { echo "usage function not implemented yet."; }
|
usage() { echo "${0##*/} <uri/file>"; }
|
||||||
|
|
||||||
handle_uri() {
|
handle_uri() {
|
||||||
local target="$1"
|
local target="$1"
|
||||||
|
|
||||||
for h in "${!uri_handlers[@]}"; do
|
for h in "${uri_handlers[@]}"; do
|
||||||
grep -oE "${uri_handlers[${h}]}" &>/dev/null <<< "$target" && {
|
IFS='=' read cmd regex <<< "$h"
|
||||||
${h} "$target" &
|
|
||||||
|
[[ "$target" =~ ${regex} ]] && {
|
||||||
|
${cmd} "$target" &
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
done
|
done
|
||||||
@@ -20,14 +23,14 @@ handle_uri() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
handle_fs_target() {
|
handle_mime() {
|
||||||
local target="${1##*file://}"
|
|
||||||
|
|
||||||
target_mimetype=$(file -ib "$target")
|
target_mimetype=$(file -ib "$target")
|
||||||
|
|
||||||
for m in "${!mime_handlers[@]}"; do
|
for m in "${mime_handlers[@]}"; do
|
||||||
grep -oE "${mime_handlers[${m}]}" &>/dev/null <<< "$target_mimetype" && {
|
IFS='=' read cmd regex <<< "$m"
|
||||||
${m} "$target" &
|
|
||||||
|
[[ "$target_mimetype" =~ ${regex} ]] && {
|
||||||
|
${cmd} "$target" &
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
done
|
done
|
||||||
@@ -39,11 +42,15 @@ main() {
|
|||||||
target="$1"
|
target="$1"
|
||||||
[[ "$target" ]] || { usage; exit; }
|
[[ "$target" ]] || { usage; exit; }
|
||||||
|
|
||||||
if [[ -e "$target" || "$target" == 'file://'* ]]; then
|
handle_uri "$target" || {
|
||||||
handle_fs_target "$target"
|
[[ "$target" =~ file://.+ ]] && { target="${target##*file://}"; }
|
||||||
else
|
|
||||||
handle_uri "$target"
|
[[ -e "$target" ]] && {
|
||||||
fi
|
[[ "$target" =~ ^/.* ]] || { target="${PWD}/${target}"; }
|
||||||
|
|
||||||
|
handle_mime "$target"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
[[ "$?" -gt 0 ]] && { echo "No handlers found for $target"; }
|
[[ "$?" -gt 0 ]] && { echo "No handlers found for $target"; }
|
||||||
|
|
||||||
|
10
sx-open.cfg
10
sx-open.cfg
@@ -1,16 +1,14 @@
|
|||||||
# Configuration file for sx-open
|
# Configuration file for sx-open
|
||||||
# Note that as sx-open checks the regexes in order, they should be placed in order from specific to less so.
|
# Note that as sx-open checks the regexes in order, they should be placed in order from specific to less so.
|
||||||
|
|
||||||
declare -A uri_handlers
|
|
||||||
declare -A mime_handlers
|
|
||||||
|
|
||||||
uri_handlers=(
|
uri_handlers=(
|
||||||
["steam"]='^steam://.+'
|
'steam=^steam://.+'
|
||||||
["browser"]='.+'
|
'javaws=.+kvm.+?\.cgi$'
|
||||||
|
'browser=^http(s)://.+'
|
||||||
)
|
)
|
||||||
|
|
||||||
mime_handlers=(
|
mime_handlers=(
|
||||||
["sxiv"]='image/.+'
|
'sxiv=image/.+'
|
||||||
)
|
)
|
||||||
|
|
||||||
# vim: syntax=sh
|
# vim: syntax=sh
|
||||||
|
Reference in New Issue
Block a user