mirror of
https://github.com/microsoft/vscode.git
synced 2026-04-26 03:29:00 +01:00
proposed API and its wiring
This commit is contained in:
@@ -442,7 +442,10 @@ export function createApiFactory(
|
||||
}),
|
||||
registerTaskProvider: (type: string, provider: vscode.TaskProvider) => {
|
||||
return extHostTask.registerTaskProvider(extension, provider);
|
||||
}
|
||||
},
|
||||
registerFileSystemProvider: proposedApiFunction(extension, (authority, provider) => {
|
||||
return extHostWorkspace.registerFileSystemProvider(authority, provider);
|
||||
})
|
||||
};
|
||||
|
||||
// namespace: scm
|
||||
|
||||
@@ -295,6 +295,8 @@ export abstract class MainThreadWorkspaceShape {
|
||||
$cancelSearch(requestId: number): Thenable<boolean> { throw ni(); }
|
||||
$saveAll(includeUntitled?: boolean): Thenable<boolean> { throw ni(); }
|
||||
$applyWorkspaceEdit(edits: IResourceEdit[]): TPromise<boolean> { throw ni(); }
|
||||
$registerFileSystemProvider(handle: number, authority: string): void { throw ni(); }
|
||||
$onFileSystemChange(handle: number, resource: URI): void { throw ni(); }
|
||||
}
|
||||
|
||||
export abstract class MainThreadTaskShape {
|
||||
@@ -420,6 +422,8 @@ export abstract class ExtHostTreeViewsShape {
|
||||
|
||||
export abstract class ExtHostWorkspaceShape {
|
||||
$acceptWorkspaceData(workspace: IWorkspaceData): void { throw ni(); }
|
||||
$resolveFile(handle: number, resource: URI): TPromise<string> { throw ni(); }
|
||||
$storeFile(handle: number, resource: URI, content: string): TPromise<any> { throw ni(); }
|
||||
}
|
||||
|
||||
export abstract class ExtHostExtensionServiceShape {
|
||||
|
||||
@@ -17,6 +17,8 @@ import { fromRange, EndOfLine } from 'vs/workbench/api/node/extHostTypeConverter
|
||||
import { IWorkspaceData, ExtHostWorkspaceShape, MainContext, MainThreadWorkspaceShape } from './extHost.protocol';
|
||||
import * as vscode from 'vscode';
|
||||
import { compare } from "vs/base/common/strings";
|
||||
import { asWinJsPromise } from 'vs/base/common/async';
|
||||
import { Disposable } from 'vs/workbench/api/node/extHostTypes';
|
||||
|
||||
export class ExtHostWorkspace extends ExtHostWorkspaceShape {
|
||||
|
||||
@@ -151,4 +153,30 @@ export class ExtHostWorkspace extends ExtHostWorkspaceShape {
|
||||
|
||||
return this._proxy.$applyWorkspaceEdit(resourceEdits);
|
||||
}
|
||||
|
||||
// --- EXPERIMENT: workspace resolver
|
||||
|
||||
private readonly _provider = new Map<number, vscode.FileSystemProvider>();
|
||||
|
||||
public registerFileSystemProvider(authority: string, provider: vscode.FileSystemProvider): vscode.Disposable {
|
||||
|
||||
const handle = this._provider.size;
|
||||
this._provider.set(handle, provider);
|
||||
const reg = provider.onDidChange(e => this._proxy.$onFileSystemChange(handle, <URI>e));
|
||||
this._proxy.$registerFileSystemProvider(handle, authority);
|
||||
return new Disposable(() => {
|
||||
this._provider.delete(handle);
|
||||
reg.dispose();
|
||||
});
|
||||
}
|
||||
|
||||
$resolveFile(handle: number, resource: URI): TPromise<string> {
|
||||
const provider = this._provider.get(handle);
|
||||
return asWinJsPromise(token => provider.resolveContents(resource));
|
||||
}
|
||||
|
||||
$storeFile(handle: number, resource: URI, content: string): TPromise<any> {
|
||||
const provider = this._provider.get(handle);
|
||||
return asWinJsPromise(token => provider.writeContents(resource, content));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user