diff options
| author | Teddy Wing | 2019-06-23 18:45:47 +0200 | 
|---|---|---|
| committer | Teddy Wing | 2019-06-23 20:42:45 +0200 | 
| commit | 884bf54a000924670c0a0d86f4c10c2278ff2daf (patch) | |
| tree | dc6b3cdf195fb9274c79dfb8e7476c7cd5495e34 | |
| parent | 0a3d74bf9ce488f035cf5bc36f753a711bc74334 (diff) | |
| download | browser-884bf54a000924670c0a0d86f4c10c2278ff2daf.tar.bz2 | |
Add support for the BROWSER environment variablesupport-for-BROWSER-environment-variable
Allow user-defined URL-opening commands via the BROWSER environment
variable. This enables using a non-default browser, or changing the
browser for a single command.
For example, on Mac:
    $ export BROWSER='open -a Firefox'
Windows:
    > setx BROWSER "start iexplore"
In UNIX environments, the command is run through `$SHELL -c`, or
`/bin/sh` if `$SHELL` is not set. On Windows, it uses `cmd /c`.
Ensure that URLs are properly quoted between UNIX and Windows
environments in `fmtBrowserCmd()`.
| -rw-r--r-- | browser.go | 17 | ||||
| -rw-r--r-- | browser_unix.go | 22 | ||||
| -rw-r--r-- | browser_windows.go | 9 | 
3 files changed, 47 insertions, 1 deletions
| @@ -55,9 +55,24 @@ func OpenURL(url string) error {  }  func runCmd(prog string, args ...string) error { -	cmd := exec.Command(prog, args...) +	var cmd *exec.Cmd + +	browser := envBrowserCmd() +	if browser != "" { +		sh, flag := shell() +		url := args[len(args)-1] +		browserCmd := fmtBrowserCmd(browser, url) +		cmd = exec.Command(sh, flag, browserCmd) +	} else { +		cmd = exec.Command(prog, args...) +	} +  	cmd.Stdout = Stdout  	cmd.Stderr = Stderr  	setFlags(cmd)  	return cmd.Run()  } + +func envBrowserCmd() string { +	return os.Getenv("BROWSER") +} diff --git a/browser_unix.go b/browser_unix.go new file mode 100644 index 0000000..30d57db --- /dev/null +++ b/browser_unix.go @@ -0,0 +1,22 @@ +// +build !windows + +package browser + +import ( +	"fmt" +	"os" +) + +func shell() (shell, flag string) { +	shell = os.Getenv("SHELL") + +	if shell == "" { +		shell = "/bin/sh" +	} + +	return shell, "-c" +} + +func fmtBrowserCmd(browser, url string) string { +	return fmt.Sprintf("%s '%s'", browser, url) +} diff --git a/browser_windows.go b/browser_windows.go index a964c7b..0be67a2 100644 --- a/browser_windows.go +++ b/browser_windows.go @@ -1,6 +1,7 @@  package browser  import ( +	"fmt"  	"os/exec"  	"strings"  	"syscall" @@ -14,3 +15,11 @@ func openBrowser(url string) error {  func setFlags(cmd *exec.Cmd) {  	cmd.SysProcAttr = &syscall.SysProcAttr{HideWindow: true}  } + +func shell() (shell, flag string) { +	return "cmd", "/c" +} + +func fmtBrowserCmd(browser, url string) string { +	return fmt.Sprintf("%s %s", browser, url) +} | 
