summaryrefslogtreecommitdiff
path: root/mnv/runtime/plugin/openPlugin.mnv
diff options
context:
space:
mode:
Diffstat (limited to 'mnv/runtime/plugin/openPlugin.mnv')
-rw-r--r--mnv/runtime/plugin/openPlugin.mnv46
1 files changed, 46 insertions, 0 deletions
diff --git a/mnv/runtime/plugin/openPlugin.mnv b/mnv/runtime/plugin/openPlugin.mnv
new file mode 100644
index 0000000000..ee51cd1acd
--- /dev/null
+++ b/mnv/runtime/plugin/openPlugin.mnv
@@ -0,0 +1,46 @@
+mnv9script
+
+# MNV runtime support library
+#
+# Maintainer: The MNV Project <https://github.com/Project-Tick/Project-Tick>
+# Last Change: 2025 Jun 22
+
+if exists("g:loaded_openPlugin") || &cp
+ finish
+endif
+g:loaded_openPlugin = 1
+
+import autoload 'dist/mnv9.mnv'
+
+command -complete=shellcmd -nargs=1 Launch mnv9.Launch(trim(<f-args>))
+
+# technically, -nargs=1 is correct, but this throws E480: No match
+# when the argument contains a wildchar on Windows
+command -complete=file -nargs=* Open mnv9.Open(trim(<f-args>))
+# Use URLOpen when you don't want completion to happen
+# (or because you want to avoid cmdline-special)
+command -nargs=1 URLOpen mnv9.Open(trim(<f-args>))
+
+const no_gx = get(g:, "nogx", get(g:, "netrw_nogx", false))
+if !no_gx
+ def GetWordUnderCursor(): string
+ const url = matchstr(expand("<cWORD>"), '\%(\%(http\|ftp\|irc\)s\?\|file\)://\S\{-}\ze[^A-Za-z0-9/]*$')
+ if !empty(url)
+ return url
+ endif
+
+ const user_var = get(g:, 'gx_word', get(g:, 'netrw_gx', '<cfile>'))
+ return expand(user_var)
+ enddef
+
+ if maparg('gx', 'n') == ""
+ nnoremap <Plug>(open-word-under-cursor) <scriptcmd>mnv9.Open(GetWordUnderCursor())<CR>
+ nmap gx <Plug>(open-word-under-cursor)
+ endif
+ if maparg('gx', 'x') == ""
+ xnoremap <Plug>(open-word-under-cursor) <scriptcmd>mnv9.Open(getregion(getpos('v'), getpos('.'), { type: mode() })->join())<CR>
+ xmap gx <Plug>(open-word-under-cursor)
+ endif
+endif
+
+# mnv: ts=8 sts=2 sw=2 et