Merge pull request #301 from greyhoof/browser-option
Browser option URL handling improvements
This commit is contained in:
commit
c4c6d9c83d
|
@ -188,14 +188,15 @@ function openURLExternally(linkUrl: string): void {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fileIsExecutable) {
|
if (fileIsExecutable) {
|
||||||
// check if URL is already encoded
|
// regular expression that looks for an encoded % symbol followed by two hexadecimal characters
|
||||||
// (this should work almost all the time, but there might be edge-cases with very unusual URLs)
|
// using this expression, we can find parts of the URL that were encoded twice
|
||||||
let isEncoded = (linkUrl !== decodeURI(linkUrl));
|
const re = new RegExp('%25([0-9a-f]{2})', 'ig');
|
||||||
// only encode URL if it isn't encoded yet
|
|
||||||
if (!isEncoded) {
|
// encode the URL no matter what
|
||||||
// encode URL so if it contains spaces, it remains a single argument for the browser
|
|
||||||
linkUrl = encodeURI(linkUrl);
|
linkUrl = encodeURI(linkUrl);
|
||||||
}
|
|
||||||
|
// eliminate double-encoding using expression above
|
||||||
|
linkUrl = linkUrl.replace(re, '%$1');
|
||||||
|
|
||||||
if (!settings.browserArgs.includes('%s')) {
|
if (!settings.browserArgs.includes('%s')) {
|
||||||
// append %s to params if it is not already there
|
// append %s to params if it is not already there
|
||||||
|
|
Loading…
Reference in New Issue