mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
os: implement support for VOPEN_URI_CMD env override for os.open_uri
This commit is contained in:
@@ -1,32 +1,30 @@
|
||||
module os
|
||||
|
||||
pub fn open_uri(uri string) ? {
|
||||
$if macos {
|
||||
result := execute('open "$uri"')
|
||||
if result.exit_code != 0 {
|
||||
return error('unable to open url: $result.output')
|
||||
}
|
||||
} $else $if freebsd || openbsd {
|
||||
result := execute('xdg-open "$uri"')
|
||||
if result.exit_code != 0 {
|
||||
return error('unable to open url: $result.output')
|
||||
}
|
||||
} $else $if linux {
|
||||
providers := ['xdg-open', 'x-www-browser', 'www-browser', 'wslview']
|
||||
|
||||
// There are multiple possible providers to open a browser on linux
|
||||
// One of them is xdg-open, another is x-www-browser, then there's www-browser, etc.
|
||||
// Look for one that exists and run it
|
||||
for provider in providers {
|
||||
if exists_in_system_path(provider) {
|
||||
result := execute('$provider "$uri"')
|
||||
if result.exit_code != 0 {
|
||||
return error('unable to open url: $result.output')
|
||||
mut vopen_uri_cmd := getenv('VOPEN_URI_CMD')
|
||||
if vopen_uri_cmd == '' {
|
||||
$if macos {
|
||||
vopen_uri_cmd = 'open'
|
||||
} $else $if freebsd || openbsd {
|
||||
vopen_uri_cmd = 'xdg-open'
|
||||
} $else $if linux {
|
||||
providers := ['xdg-open', 'x-www-browser', 'www-browser', 'wslview']
|
||||
// There are multiple possible providers to open a browser on linux
|
||||
// One of them is xdg-open, another is x-www-browser, then there's www-browser, etc.
|
||||
// Look for one that exists and run it
|
||||
for provider in providers {
|
||||
if exists_in_system_path(provider) {
|
||||
vopen_uri_cmd = provider
|
||||
break
|
||||
}
|
||||
break
|
||||
}
|
||||
}
|
||||
} $else {
|
||||
}
|
||||
if vopen_uri_cmd == '' {
|
||||
return error('unsupported platform')
|
||||
}
|
||||
result := execute('$vopen_uri_cmd "$uri"')
|
||||
if result.exit_code != 0 {
|
||||
return error('unable to open url: $result.output')
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user