mirror of
https://github.com/microsoft/vscode.git
synced 2026-04-25 02:58:56 +01:00
Keep a local tree at extHostExplorer side
This commit is contained in:
@@ -4,7 +4,7 @@
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
'use strict';
|
||||
|
||||
import * as vscode from 'vscode';
|
||||
import { ITreeNode, TreeContentProvider } from 'vscode';
|
||||
import {TPromise} from 'vs/base/common/winjs.base';
|
||||
import {Disposable} from 'vs/workbench/api/node/extHostTypes';
|
||||
import {IThreadService} from 'vs/workbench/services/thread/common/threadService';
|
||||
@@ -13,7 +13,9 @@ import {MainContext, ExtHostExplorersShape, MainThreadExplorersShape} from './ex
|
||||
export class ExtHostExplorers extends ExtHostExplorersShape {
|
||||
private _proxy: MainThreadExplorersShape;
|
||||
|
||||
private _treeContentProviders: { [treeContentProviderId: string]: vscode.TreeContentProvider };
|
||||
private _treeContentProviders: { [treeContentProviderId: string]: TreeContentProvider };
|
||||
private _treeContents: { [treeContentProviderId: string]: ExtHostTreeNode };
|
||||
private _treeNodeMaps: { [treeContentProviderId: string]: { [id: number]: ExtHostTreeNode }};
|
||||
|
||||
constructor(
|
||||
threadService: IThreadService
|
||||
@@ -23,9 +25,11 @@ export class ExtHostExplorers extends ExtHostExplorersShape {
|
||||
this._proxy = threadService.get(MainContext.MainThreadExplorers);
|
||||
|
||||
this._treeContentProviders = Object.create(null);
|
||||
this._treeContents = Object.create(null);
|
||||
this._treeNodeMaps = Object.create(null);
|
||||
}
|
||||
|
||||
registerTreeContentProvider(providerId: string, provider: vscode.TreeContentProvider): vscode.Disposable {
|
||||
registerTreeContentProvider(providerId: string, provider: TreeContentProvider): Disposable {
|
||||
this._proxy.$registerTreeContentProvider(providerId);
|
||||
this._treeContentProviders[providerId] = provider;
|
||||
|
||||
@@ -36,25 +40,56 @@ export class ExtHostExplorers extends ExtHostExplorersShape {
|
||||
});
|
||||
}
|
||||
|
||||
$provideTreeContent(treeContentProviderId: string): TPromise<vscode.ITreeNode> {
|
||||
$provideTreeContent(treeContentProviderId: string): TPromise<ExtHostTreeNode> {
|
||||
const provider = this._treeContentProviders[treeContentProviderId];
|
||||
if (!provider) {
|
||||
throw new Error(`no TreeContentProvider registered with id '${treeContentProviderId}'`);
|
||||
}
|
||||
|
||||
return TPromise.wrap(provider.provideTreeContent().then(treeContent => {
|
||||
return treeContent;
|
||||
const treeNodeMap = Object.create(null);
|
||||
this._treeNodeMaps[treeContentProviderId] = treeNodeMap;
|
||||
this._treeContents[treeContentProviderId] = new ExtHostTreeNode(treeContent, null, treeNodeMap);
|
||||
return this._treeContents[treeContentProviderId];
|
||||
}));
|
||||
}
|
||||
|
||||
$resolveChildren(treeContentProviderId: string, node: vscode.ITreeNode): TPromise<vscode.ITreeNode[]> {
|
||||
$resolveChildren(treeContentProviderId: string, mainThreadNode: ExtHostTreeNode): TPromise<ExtHostTreeNode[]> {
|
||||
const provider = this._treeContentProviders[treeContentProviderId];
|
||||
if (!provider) {
|
||||
throw new Error(`no TreeContentProvider registered with id '${treeContentProviderId}'`);
|
||||
}
|
||||
|
||||
return TPromise.wrap(provider.resolveChildren(node).then(children => {
|
||||
return children;
|
||||
const treeNodeMap = this._treeNodeMaps[treeContentProviderId];
|
||||
const extHostNode = treeNodeMap[mainThreadNode.id];
|
||||
|
||||
return TPromise.wrap(provider.resolveChildren(extHostNode).then(children => {
|
||||
extHostNode.children = children.map(child => {
|
||||
return new ExtHostTreeNode(child, extHostNode, treeNodeMap);
|
||||
});
|
||||
return extHostNode.children;
|
||||
}));
|
||||
}
|
||||
}
|
||||
|
||||
export class ExtHostTreeNode implements ITreeNode {
|
||||
static idCounter = 1;
|
||||
|
||||
id: number;
|
||||
|
||||
label: string;
|
||||
isExpanded: boolean;
|
||||
children: ExtHostTreeNode[];
|
||||
|
||||
constructor(node: ITreeNode, parent: ExtHostTreeNode, treeNodeMap: { [id: number]: ExtHostTreeNode}) {
|
||||
this.id = ExtHostTreeNode.idCounter++;
|
||||
|
||||
this.label = node.label;
|
||||
this.isExpanded = node.isExpanded;
|
||||
this.children = node.children.map(child => {
|
||||
return new ExtHostTreeNode(child, this, treeNodeMap);
|
||||
})
|
||||
|
||||
treeNodeMap[this.id] = this;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user