Merge branch 'canary' of https://github.com/hearmeneigh/fchat-rising into canary
This commit is contained in:
commit
489659ebed
|
@ -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