From 16ef3f9e47830072522b1e58fce9160fcece1c92 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C5=99emysl=20Eric=20Janouch?=
Date: Fri, 21 Nov 2025 12:52:56 +0100 Subject: [PATCH] sdn-open: improve macOS and WSL experiences --- sdn-open | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/sdn-open b/sdn-open index 7252488..5eb048f 100755 --- a/sdn-open +++ b/sdn-open @@ -35,15 +35,35 @@ output=$(sdn-mc-ext <"$config" "$(file -Lbz "$1")" \ kind=$(echo "$output" | sed -n 1p) command=$(echo "$output" | sed -n 2p) +# We're trying to retain any explicit user preferences while navigating through: +# - Debian-based systems have /etc/alternatives/open as /usr/bin/open, +# pointing to either /usr/bin/xdg-open or /usr/bin/run-mailcap; +# - macOS has /usr/bin/open, and typically no xdg-open; +# - Windows Subsystem for Linux has explorer.exe in PATH, +# where launched applications may have problems with UNC paths, +# and possibly also xdg-open that may not be capable of opening much. +# +# Both macOS open and Windows explorer.exe are capable of opening files, +# directories, as well as URLs through native associations. +if [ -n "$MC_XDG_OPEN" ] +then : +elif command -v explorer.exe >/dev/null +then export MC_XDG_OPEN=explorer.exe +elif command -v open >/dev/null +then export MC_XDG_OPEN=open +elif command -v xdg-open >/dev/null +then export MC_XDG_OPEN=xdg-open +fi + case "$kind" in cd) # These mostly enter virtual filesystems, which we do not understand. - xdg-open "$MC_EXT_FILENAME" + "$MC_XDG_OPEN" "$MC_EXT_FILENAME" ;; '') if [ -n "$command" ] then eval "$command" - else xdg-open "$MC_EXT_FILENAME" + else "$MC_XDG_OPEN" "$MC_EXT_FILENAME" fi ;; *)