提交 e80c62bd 编写于 作者: J Johannes Rieken

allow $openUri to accept URI and string

上级 e51ef85b
...@@ -42,9 +42,17 @@ export class MainThreadWindow implements MainThreadWindowShape { ...@@ -42,9 +42,17 @@ export class MainThreadWindow implements MainThreadWindowShape {
return Promise.resolve(this.hostService.hasFocus); return Promise.resolve(this.hostService.hasFocus);
} }
async $openUri(uriComponents: UriComponents, options: IOpenUriOptions): Promise<boolean> { async $openUri(uriComponents: UriComponents, uriString: string | undefined, options: IOpenUriOptions): Promise<boolean> {
const uri = URI.from(uriComponents); const uri = URI.from(uriComponents);
return this.openerService.open(uri, { openExternal: true, allowTunneling: options.allowTunneling }); let target: URI | string;
if (uriString && URI.parse(uriString).toString() === uri.toString()) {
// called with string and no transformation happened -> keep string
target = uriString;
} else {
// called with URI or transformed -> use uri
target = uri;
}
return this.openerService.open(target, { openExternal: true, allowTunneling: options.allowTunneling });
} }
async $asExternalUri(uriComponents: UriComponents, options: IOpenUriOptions): Promise<UriComponents> { async $asExternalUri(uriComponents: UriComponents, options: IOpenUriOptions): Promise<UriComponents> {
......
...@@ -759,7 +759,7 @@ export interface IOpenUriOptions { ...@@ -759,7 +759,7 @@ export interface IOpenUriOptions {
export interface MainThreadWindowShape extends IDisposable { export interface MainThreadWindowShape extends IDisposable {
$getWindowVisibility(): Promise<boolean>; $getWindowVisibility(): Promise<boolean>;
$openUri(uri: UriComponents, options: IOpenUriOptions): Promise<boolean>; $openUri(uri: UriComponents, uriString: string | undefined, options: IOpenUriOptions): Promise<boolean>;
$asExternalUri(uri: UriComponents, options: IOpenUriOptions): Promise<UriComponents>; $asExternalUri(uri: UriComponents, options: IOpenUriOptions): Promise<UriComponents>;
} }
......
...@@ -245,9 +245,9 @@ class OpenNodeModuleFactory implements INodeModuleFactory { ...@@ -245,9 +245,9 @@ class OpenNodeModuleFactory implements INodeModuleFactory {
return this.callOriginal(target, options); return this.callOriginal(target, options);
} }
if (uri.scheme === 'http' || uri.scheme === 'https') { if (uri.scheme === 'http' || uri.scheme === 'https') {
return mainThreadWindow.$openUri(uri, { allowTunneling: true }); return mainThreadWindow.$openUri(uri, target, { allowTunneling: true });
} else if (uri.scheme === 'mailto' || uri.scheme === this._appUriScheme) { } else if (uri.scheme === 'mailto' || uri.scheme === this._appUriScheme) {
return mainThreadWindow.$openUri(uri, {}); return mainThreadWindow.$openUri(uri, target, {});
} }
return this.callOriginal(target, options); return this.callOriginal(target, options);
}; };
......
...@@ -39,7 +39,9 @@ export class ExtHostWindow implements ExtHostWindowShape { ...@@ -39,7 +39,9 @@ export class ExtHostWindow implements ExtHostWindowShape {
} }
openUri(stringOrUri: string | URI, options: IOpenUriOptions): Promise<boolean> { openUri(stringOrUri: string | URI, options: IOpenUriOptions): Promise<boolean> {
let uriAsString: string | undefined;
if (typeof stringOrUri === 'string') { if (typeof stringOrUri === 'string') {
uriAsString = stringOrUri;
try { try {
stringOrUri = URI.parse(stringOrUri); stringOrUri = URI.parse(stringOrUri);
} catch (e) { } catch (e) {
...@@ -51,7 +53,7 @@ export class ExtHostWindow implements ExtHostWindowShape { ...@@ -51,7 +53,7 @@ export class ExtHostWindow implements ExtHostWindowShape {
} else if (stringOrUri.scheme === Schemas.command) { } else if (stringOrUri.scheme === Schemas.command) {
return Promise.reject(`Invalid scheme '${stringOrUri.scheme}'`); return Promise.reject(`Invalid scheme '${stringOrUri.scheme}'`);
} }
return this._proxy.$openUri(stringOrUri, options); return this._proxy.$openUri(stringOrUri, uriAsString, options);
} }
async asExternalUri(uri: URI, options: IOpenUriOptions): Promise<URI> { async asExternalUri(uri: URI, options: IOpenUriOptions): Promise<URI> {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册