Compare commits

...

2 Commits

Author SHA1 Message Date
Guilherme Soares e392528213
Merge 9fd9d87880 into b1134ab82e 2024-11-04 10:07:33 -08:00
Guilherme Soares 9fd9d87880 feat(util): add more handlers to util.open 2024-10-21 18:58:11 +01:00
1 changed files with 17 additions and 9 deletions

View File

@ -29,18 +29,26 @@ function M.open(uri, opts)
local cmd local cmd
if not opts.system and Config.options.ui.browser then if not opts.system and Config.options.ui.browser then
cmd = { Config.options.ui.browser, uri } cmd = { Config.options.ui.browser, uri }
elseif vim.fn.has("win32") == 1 then elseif vim.fn.has("mac") == 1 then
cmd = { "explorer", uri }
elseif vim.fn.has("macunix") == 1 then
cmd = { "open", uri } cmd = { "open", uri }
else elseif vim.fn.has("win32") == 1 then
if vim.fn.executable("xdg-open") == 1 then if vim.fn.executable("rundll32") == 1 then
cmd = { "xdg-open", uri } cmd = { "rundll32", "url.dll,FileProtocolHandler", uri }
elseif vim.fn.executable("wslview") == 1 then
cmd = { "wslview", uri }
else else
cmd = { "open", uri } vim.notify("rundll32 not found", vim.log.levels.ERROR)
return
end end
elseif vim.fn.executable("xdg-open") == 1 then
cmd = { "xdg-open", uri }
elseif vim.fn.executable("wslview") == 1 then
cmd = { "wslview", uri }
elseif vim.fn.executable("explorer.exe") == 1 then
cmd = { "explorer.exe", uri }
elseif vim.fn.executable("lemonade") == 1 then
cmd = { "lemonade", "open", uri }
else
vim.notify("no handler found (tried: wslview, explorer.exe, xdg-open, lemonade)", vim.log.levels.ERROR)
return
end end
local ret = vim.fn.jobstart(cmd, { detach = true }) local ret = vim.fn.jobstart(cmd, { detach = true })