Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
9eb01697
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
9eb01697
编写于
12月 01, 2017
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix #34789
上级
59b091af
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
197 addition
and
111 deletion
+197
-111
src/vs/workbench/api/electron-browser/mainThreadTreeViews.ts
src/vs/workbench/api/electron-browser/mainThreadTreeViews.ts
+39
-39
src/vs/workbench/api/node/extHost.protocol.ts
src/vs/workbench/api/node/extHost.protocol.ts
+1
-2
src/vs/workbench/api/node/extHostTreeViews.ts
src/vs/workbench/api/node/extHostTreeViews.ts
+60
-37
src/vs/workbench/browser/parts/views/treeView.ts
src/vs/workbench/browser/parts/views/treeView.ts
+9
-4
src/vs/workbench/common/views.ts
src/vs/workbench/common/views.ts
+2
-0
src/vs/workbench/test/electron-browser/api/extHostTreeViews.test.ts
...kbench/test/electron-browser/api/extHostTreeViews.test.ts
+86
-29
未找到文件。
src/vs/workbench/api/electron-browser/mainThreadTreeViews.ts
浏览文件 @
9eb01697
...
...
@@ -31,10 +31,10 @@ export class MainThreadTreeViews extends Disposable implements MainThreadTreeVie
ViewsRegistry
.
registerTreeViewDataProvider
(
treeViewId
,
this
.
_register
(
new
TreeViewDataProvider
(
treeViewId
,
this
.
_proxy
,
this
.
messageService
)));
}
$refresh
(
treeViewId
:
string
,
treeItemHandles
:
string
[]
):
void
{
$refresh
(
treeViewId
:
string
,
itemsToRefresh
:
{
[
treeItemHandle
:
string
]:
ITreeItem
}
):
void
{
const
treeViewDataProvider
:
TreeViewDataProvider
=
<
TreeViewDataProvider
>
ViewsRegistry
.
getTreeViewDataProvider
(
treeViewId
);
if
(
treeViewDataProvider
)
{
treeViewDataProvider
.
refresh
(
treeItemHandles
);
treeViewDataProvider
.
refresh
(
itemsToRefresh
);
}
}
...
...
@@ -54,7 +54,6 @@ class TreeViewDataProvider implements ITreeViewDataProvider {
private
_onDispose
:
Emitter
<
void
>
=
new
Emitter
<
void
>
();
readonly
onDispose
:
Event
<
void
>
=
this
.
_onDispose
.
event
;
private
childrenMap
:
Map
<
TreeItemHandle
,
TreeItemHandle
[]
>
=
new
Map
<
TreeItemHandle
,
TreeItemHandle
[]
>
();
private
itemsMap
:
Map
<
TreeItemHandle
,
ITreeItem
>
=
new
Map
<
TreeItemHandle
,
ITreeItem
>
();
constructor
(
private
treeViewId
:
string
,
...
...
@@ -66,8 +65,7 @@ class TreeViewDataProvider implements ITreeViewDataProvider {
getElements
():
TPromise
<
ITreeItem
[]
>
{
return
this
.
_proxy
.
$getElements
(
this
.
treeViewId
)
.
then
(
elements
=>
{
this
.
postGetElements
(
null
,
elements
);
return
elements
;
return
this
.
postGetElements
(
elements
);
},
err
=>
{
this
.
messageService
.
show
(
Severity
.
Error
,
err
);
return
null
;
...
...
@@ -80,28 +78,35 @@ class TreeViewDataProvider implements ITreeViewDataProvider {
}
return
this
.
_proxy
.
$getChildren
(
this
.
treeViewId
,
treeItem
.
handle
)
.
then
(
children
=>
{
this
.
postGetElements
(
treeItem
.
handle
,
children
);
return
children
;
return
this
.
postGetElements
(
children
);
},
err
=>
{
this
.
messageService
.
show
(
Severity
.
Error
,
err
);
return
null
;
});
}
refresh
(
treeItemHandles
:
string
[])
{
if
(
treeItemHandles
&&
treeItemHandles
.
length
)
{
let
treeItems
=
treeItemHandles
.
map
(
treeItemHandle
=>
this
.
itemsMap
.
get
(
treeItemHandle
))
.
filter
(
treeItem
=>
!!
treeItem
);
if
(
treeItems
.
length
)
{
this
.
_onDidChange
.
fire
(
treeItems
);
refresh
(
itemsToRefreshByHandle
:
{
[
treeItemHandle
:
string
]:
ITreeItem
})
{
if
(
itemsToRefreshByHandle
)
{
const
itemsToRefresh
:
ITreeItem
[]
=
[];
for
(
const
treeItemHandle
of
Object
.
keys
(
itemsToRefreshByHandle
))
{
const
currentTreeItem
=
this
.
itemsMap
.
get
(
treeItemHandle
);
if
(
currentTreeItem
)
{
// Refresh only if the item exists
const
treeItem
=
itemsToRefreshByHandle
[
treeItemHandle
];
// Update the current item with refreshed item
this
.
updateTreeItem
(
currentTreeItem
,
treeItem
);
if
(
treeItemHandle
===
treeItem
.
handle
)
{
itemsToRefresh
.
push
(
currentTreeItem
);
}
else
{
// Update maps when handle is changed and refresh parent
this
.
itemsMap
.
delete
(
treeItemHandle
);
this
.
itemsMap
.
set
(
currentTreeItem
.
handle
,
currentTreeItem
);
itemsToRefresh
.
push
(
this
.
itemsMap
.
get
(
treeItem
.
parentHandle
));
}
}
if
(
itemsToRefresh
.
length
)
{
this
.
_onDidChange
.
fire
(
itemsToRefresh
);
}
/*this._proxy.$resolveHandles(this.treeViewId, treeItemHandles)
.then(treeItems => {
treeItems = coalesce(treeItems.map(treeItem => this.updateTreeItem(treeItem)));
if (treeItems.length) {
this._onDidChange.fire(treeItems);
}
}); */
}
else
{
this
.
_onDidChange
.
fire
();
}
...
...
@@ -111,33 +116,28 @@ class TreeViewDataProvider implements ITreeViewDataProvider {
this
.
_onDispose
.
fire
();
}
private
postGetElements
(
parent
:
TreeItemHandle
,
children
:
ITreeItem
[])
{
this
.
setElements
(
parent
,
children
);
}
private
setElements
(
parent
:
TreeItemHandle
,
children
:
ITreeItem
[])
{
if
(
children
&&
children
.
length
)
{
for
(
const
child
of
children
)
{
if
(
!
this
.
updateTreeItem
(
child
))
{
this
.
itemsMap
.
set
(
child
.
handle
,
child
);
}
if
(
child
.
children
&&
child
.
children
.
length
)
{
this
.
setElements
(
child
.
handle
,
child
.
children
);
}
private
postGetElements
(
elements
:
ITreeItem
[]):
ITreeItem
[]
{
const
result
=
[];
if
(
elements
)
{
for
(
const
element
of
elements
)
{
const
currentTreeItem
=
this
.
itemsMap
.
get
(
element
.
handle
);
if
(
currentTreeItem
)
{
// Update the current item with new item
this
.
updateTreeItem
(
currentTreeItem
,
element
);
}
else
{
this
.
itemsMap
.
set
(
element
.
handle
,
element
);
}
if
(
parent
)
{
this
.
childrenMap
.
set
(
parent
,
children
.
map
(
child
=>
child
.
handle
));
// Always use the existing items
result
.
push
(
this
.
itemsMap
.
get
(
element
.
handle
));
}
}
return
result
;
}
private
updateTreeItem
(
treeItem
:
ITreeItem
):
ITreeItem
{
const
current
=
this
.
itemsMap
.
get
(
treeItem
.
handle
);
private
updateTreeItem
(
current
:
ITreeItem
,
treeItem
:
ITreeItem
):
void
{
treeItem
.
children
=
treeItem
.
children
?
treeItem
.
children
:
null
;
if
(
current
)
{
assign
(
current
,
treeItem
);
return
current
;
}
return
null
;
}
}
\ No newline at end of file
src/vs/workbench/api/node/extHost.protocol.ts
浏览文件 @
9eb01697
...
...
@@ -238,7 +238,7 @@ export interface MainThreadEditorsShape extends IDisposable {
export
interface
MainThreadTreeViewsShape
extends
IDisposable
{
$registerView
(
treeViewId
:
string
):
void
;
$refresh
(
treeViewId
:
string
,
treeItemHandles
:
string
[]
):
void
;
$refresh
(
treeViewId
:
string
,
itemsToRefresh
?:
{
[
treeItemHandle
:
string
]:
ITreeItem
}
):
void
;
}
export
interface
MainThreadErrorsShape
extends
IDisposable
{
...
...
@@ -495,7 +495,6 @@ export interface ExtHostDocumentsAndEditorsShape {
export
interface
ExtHostTreeViewsShape
{
$getElements
(
treeViewId
:
string
):
TPromise
<
ITreeItem
[]
>
;
$getChildren
(
treeViewId
:
string
,
treeItemHandle
:
string
):
TPromise
<
ITreeItem
[]
>
;
// $resolveHandles(treeViewId: string, treeItemHandles: string[]): TPromise<ITreeItem[]>;
}
export
interface
ExtHostWorkspaceShape
{
...
...
src/vs/workbench/api/node/extHostTreeViews.ts
浏览文件 @
9eb01697
...
...
@@ -62,14 +62,6 @@ export class ExtHostTreeViews implements ExtHostTreeViewsShape {
return
treeView
.
getChildren
(
treeItemHandle
);
}
/* $resolveHandles(treeViewId: string, treeItemHandles: string[]): TPromise<ITreeItem[]> {
const treeView = this.treeViews.get(treeViewId);
if (!treeView) {
return TPromise.wrapError<ITreeItem[]>(new Error(localize('treeView.notRegistered', 'No tree view with id \'{0}\' registered.', treeViewId)));
}
return treeView.resolveHandles(treeItemHandles);
} */
private
convertArgument
(
arg
:
TreeViewItemHandleArg
):
any
{
const
treeView
=
this
.
treeViews
.
get
(
arg
.
$treeViewId
);
return
treeView
?
treeView
.
getExtensionElement
(
arg
.
$treeItemHandle
)
:
null
;
...
...
@@ -77,6 +69,7 @@ export class ExtHostTreeViews implements ExtHostTreeViewsShape {
}
interface
TreeNode
{
index
:
number
;
handle
:
TreeItemHandle
;
parent
:
TreeItemHandle
;
children
:
TreeItemHandle
[];
...
...
@@ -84,7 +77,8 @@ interface TreeNode {
class
ExtHostTreeView
<
T
>
extends
Disposable
{
private
extElementsMap
:
Map
<
TreeItemHandle
,
T
>
=
new
Map
<
TreeItemHandle
,
T
>
();
private
static
ROOT_HANDLE
=
'
0
'
;
private
elements
:
Map
<
TreeItemHandle
,
T
>
=
new
Map
<
TreeItemHandle
,
T
>
();
private
nodes
:
Map
<
T
,
TreeNode
>
=
new
Map
<
T
,
TreeNode
>
();
constructor
(
private
viewId
:
string
,
private
dataProvider
:
vscode
.
TreeDataProvider
<
T
>
,
private
proxy
:
MainThreadTreeViewsShape
,
private
commands
:
CommandsConverter
)
{
...
...
@@ -98,7 +92,7 @@ class ExtHostTreeView<T> extends Disposable {
getTreeItems
():
TPromise
<
ITreeItem
[]
>
{
this
.
clearAll
();
return
asWinJsPromise
(()
=>
this
.
dataProvider
.
getChildren
())
.
then
(
elements
=>
this
.
resolveElements
(
elements
,
'
0
'
));
.
then
(
elements
=>
this
.
resolveElements
(
elements
));
}
getChildren
(
treeItemHandle
:
TreeItemHandle
):
TPromise
<
ITreeItem
[]
>
{
...
...
@@ -117,34 +111,23 @@ class ExtHostTreeView<T> extends Disposable {
});
}
/* resolveHandles(treeItemHandles: TreeItemHandle[]): TPromise<ITreeItem[]> {
return TPromise.join(treeItemHandles.map(treeItemHandle => {
let extElement = this.getExtensionElement(treeItemHandle);
if (!extElement) {
return TPromise.wrapError<ITreeItem>(new Error(localize('treeItem.notFound', 'No tree item with id \'{0}\' found.', treeItemHandle)));
}
const node = this.nodes.get(extElement);
return this.resolveElement(extElement, node.handle);
})).then(treeItems => coalesce(treeItems));
} */
getExtensionElement
(
treeItemHandle
:
TreeItemHandle
):
T
{
return
this
.
e
xtElementsMap
.
get
(
treeItemHandle
);
return
this
.
e
lements
.
get
(
treeItemHandle
);
}
private
_refresh
(
elements
:
T
[]):
void
{
const
hasRoot
=
elements
.
some
(
element
=>
!
element
);
if
(
hasRoot
)
{
this
.
proxy
.
$refresh
(
this
.
viewId
,
[]
);
this
.
proxy
.
$refresh
(
this
.
viewId
);
}
else
{
const
handlesToUpdate
=
this
.
get
Element
sToUpdate
(
elements
);
const
handlesToUpdate
=
this
.
get
Handle
sToUpdate
(
elements
);
if
(
handlesToUpdate
.
length
)
{
this
.
proxy
.
$refresh
(
this
.
viewId
,
handlesToUpdate
);
this
.
_refreshHandles
(
handlesToUpdate
);
}
}
}
private
resolveElements
(
elements
:
T
[],
parentHandle
:
TreeItemHandle
):
TPromise
<
ITreeItem
[]
>
{
private
resolveElements
(
elements
:
T
[],
parentHandle
?
:
TreeItemHandle
):
TPromise
<
ITreeItem
[]
>
{
if
(
elements
&&
elements
.
length
)
{
return
TPromise
.
join
(
elements
.
filter
(
element
=>
!!
element
)
...
...
@@ -153,11 +136,12 @@ class ExtHostTreeView<T> extends Disposable {
.
then
(
treeItem
=>
{
if
(
treeItem
)
{
this
.
nodes
.
set
(
element
,
{
index
,
handle
:
treeItem
.
handle
,
parent
:
parentHandle
,
children
:
void
0
});
this
.
e
xtElementsMap
.
set
(
treeItem
.
handle
,
element
);
this
.
e
lements
.
set
(
treeItem
.
handle
,
element
);
}
return
treeItem
;
});
...
...
@@ -167,7 +151,7 @@ class ExtHostTreeView<T> extends Disposable {
return
TPromise
.
as
([]);
}
private
resolveElement
(
element
:
T
,
index
:
number
,
parentHandle
:
TreeItemHandle
):
TPromise
<
ITreeItem
>
{
private
resolveElement
(
element
:
T
,
index
:
number
,
parentHandle
?
:
TreeItemHandle
):
TPromise
<
ITreeItem
>
{
return
asWinJsPromise
(()
=>
this
.
dataProvider
.
getTreeItem
(
element
))
.
then
(
extTreeItem
=>
this
.
massageTreeItem
(
extTreeItem
,
index
,
parentHandle
));
}
...
...
@@ -178,7 +162,8 @@ class ExtHostTreeView<T> extends Disposable {
}
const
icon
=
this
.
getLightIconPath
(
extensionTreeItem
);
return
{
handle
:
`
${
parentHandle
}
/
${
index
}
:
${
extensionTreeItem
.
label
}
`
,
handle
:
`
${
parentHandle
?
parentHandle
:
ExtHostTreeView
.
ROOT_HANDLE
}
/
${
index
}
:
${
extensionTreeItem
.
label
}
`
,
parentHandle
,
label
:
extensionTreeItem
.
label
,
command
:
extensionTreeItem
.
command
?
this
.
commands
.
toInternal
(
extensionTreeItem
.
command
)
:
void
0
,
contextValue
:
extensionTreeItem
.
contextValue
,
...
...
@@ -212,7 +197,7 @@ class ExtHostTreeView<T> extends Disposable {
return
URI
.
file
(
iconPath
).
toString
();
}
private
get
Element
sToUpdate
(
elements
:
T
[]):
TreeItemHandle
[]
{
private
get
Handle
sToUpdate
(
elements
:
T
[]):
TreeItemHandle
[]
{
const
elementsToUpdate
=
new
Set
<
TreeItemHandle
>
();
for
(
const
element
of
elements
)
{
let
elementNode
=
this
.
nodes
.
get
(
element
);
...
...
@@ -220,10 +205,10 @@ class ExtHostTreeView<T> extends Disposable {
// check if an ancestor of extElement is already in the elements to update list
let
currentNode
=
elementNode
;
while
(
currentNode
&&
currentNode
.
parent
&&
!
elementsToUpdate
.
has
(
currentNode
.
parent
))
{
const
parentElement
=
this
.
e
xtElementsMap
.
get
(
currentNode
.
parent
);
const
parentElement
=
this
.
e
lements
.
get
(
currentNode
.
parent
);
currentNode
=
this
.
nodes
.
get
(
parentElement
);
}
if
(
!
currentNode
)
{
if
(
!
currentNode
.
parent
)
{
elementsToUpdate
.
add
(
elementNode
.
handle
);
}
}
...
...
@@ -232,7 +217,7 @@ class ExtHostTreeView<T> extends Disposable {
const
handlesToUpdate
:
TreeItemHandle
[]
=
[];
// Take only top level elements
elementsToUpdate
.
forEach
((
handle
)
=>
{
const
element
=
this
.
e
xtElementsMap
.
get
(
handle
);
const
element
=
this
.
e
lements
.
get
(
handle
);
let
node
=
this
.
nodes
.
get
(
element
);
if
(
node
&&
!
elementsToUpdate
.
has
(
node
.
parent
))
{
handlesToUpdate
.
push
(
handle
);
...
...
@@ -242,11 +227,49 @@ class ExtHostTreeView<T> extends Disposable {
return
handlesToUpdate
;
}
private
_refreshHandles
(
itemHandles
:
TreeItemHandle
[]):
TPromise
<
void
>
{
const
itemsToRefresh
:
{
[
handle
:
string
]:
ITreeItem
}
=
{};
const
promises
:
TPromise
<
void
>
[]
=
[];
itemHandles
.
forEach
(
treeItemHandle
=>
{
const
extElement
=
this
.
getExtensionElement
(
treeItemHandle
);
const
node
=
this
.
nodes
.
get
(
extElement
);
const
promise
=
this
.
resolveElement
(
extElement
,
node
.
index
,
node
.
parent
)
.
then
(
treeItem
=>
{
if
(
treeItemHandle
!==
treeItem
.
handle
)
{
// Update caches if handle changes
this
.
updateCaches
(
node
,
treeItem
,
extElement
);
}
itemsToRefresh
[
treeItemHandle
]
=
treeItem
;
});
promises
.
push
(
promise
);
});
return
TPromise
.
join
(
promises
)
.
then
(
treeItems
=>
{
this
.
proxy
.
$refresh
(
this
.
viewId
,
itemsToRefresh
);
});
}
private
updateCaches
(
node
:
TreeNode
,
treeItem
:
ITreeItem
,
element
:
T
):
void
{
if
(
node
.
parent
)
{
// Update parent's children handles
const
parentElement
=
this
.
getExtensionElement
(
node
.
parent
);
const
parentNode
=
this
.
nodes
.
get
(
parentElement
);
parentNode
.
children
[
node
.
index
]
=
treeItem
.
handle
;
}
// Update elements map
this
.
elements
.
delete
(
node
.
handle
);
this
.
elements
.
set
(
treeItem
.
handle
,
element
);
// Update node
node
.
handle
=
treeItem
.
handle
;
}
private
clearChildren
(
element
:
T
):
void
{
let
node
=
this
.
nodes
.
get
(
element
);
if
(
node
.
children
)
{
for
(
const
childHandle
of
node
.
children
)
{
const
childEleement
=
this
.
e
xtElementsMap
.
get
(
childHandle
);
const
childEleement
=
this
.
e
lements
.
get
(
childHandle
);
if
(
childEleement
)
{
this
.
clear
(
childEleement
);
}
...
...
@@ -259,18 +282,18 @@ class ExtHostTreeView<T> extends Disposable {
let
node
=
this
.
nodes
.
get
(
element
);
if
(
node
.
children
)
{
for
(
const
childHandle
of
node
.
children
)
{
const
childEleement
=
this
.
e
xtElementsMap
.
get
(
childHandle
);
const
childEleement
=
this
.
e
lements
.
get
(
childHandle
);
if
(
childEleement
)
{
this
.
clear
(
childEleement
);
}
}
}
this
.
nodes
.
delete
(
element
);
this
.
e
xtElementsMap
.
delete
(
node
.
handle
);
this
.
e
lements
.
delete
(
node
.
handle
);
}
private
clearAll
():
void
{
this
.
e
xtElementsMap
.
clear
();
this
.
e
lements
.
clear
();
this
.
nodes
.
clear
();
}
...
...
src/vs/workbench/browser/parts/views/treeView.ts
浏览文件 @
9eb01697
...
...
@@ -173,11 +173,15 @@ export class TreeView extends TreeViewsViewletPanel {
}
private
refresh
(
elements
:
ITreeItem
[]):
void
{
elements
=
elements
?
elements
:
[
this
.
tree
.
getInput
()];
if
(
elements
)
{
for
(
const
element
of
elements
)
{
element
.
children
=
null
;
this
.
tree
.
refresh
(
element
);
}
}
else
{
const
root
:
ITreeItem
=
this
.
tree
.
getInput
();
root
.
children
=
null
;
// reset children
this
.
tree
.
refresh
(
root
);
}
}
dispose
():
void
{
...
...
@@ -193,6 +197,7 @@ export class TreeView extends TreeViewsViewletPanel {
class
Root
implements
ITreeItem
{
label
=
'
root
'
;
handle
=
'
0
'
;
parentHandle
=
null
;
collapsibleState
=
TreeItemCollapsibleState
.
Expanded
;
}
...
...
src/vs/workbench/common/views.ts
浏览文件 @
9eb01697
...
...
@@ -22,6 +22,8 @@ export interface ITreeItem {
handle
:
string
;
parentHandle
:
string
;
label
:
string
;
icon
?:
string
;
...
...
src/vs/workbench/test/electron-browser/api/extHostTreeViews.test.ts
浏览文件 @
9eb01697
...
...
@@ -19,27 +19,31 @@ import { IInstantiationService } from 'vs/platform/instantiation/common/instanti
import
{
mock
}
from
'
vs/workbench/test/electron-browser/api/mock
'
;
import
{
NoopLogService
}
from
'
vs/platform/log/common/log
'
;
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
import
{
TreeItemCollapsibleState
}
from
'
vs/workbench/common/views
'
;
import
{
TreeItemCollapsibleState
,
ITreeItem
}
from
'
vs/workbench/common/views
'
;
suite
(
'
ExtHostTreeView
'
,
function
()
{
class
RecordingShape
extends
mock
<
MainThreadTreeViewsShape
>
()
{
onRefresh
=
new
Emitter
<
string
[]
>
();
onRefresh
=
new
Emitter
<
{
[
treeItemHandle
:
string
]:
ITreeItem
}
>
();
$registerView
(
treeViewId
:
string
):
void
{
}
$refresh
(
viewId
:
string
,
item
Handles
:
string
[]
):
void
{
this
.
onRefresh
.
fire
(
item
Handles
);
$refresh
(
viewId
:
string
,
item
sToRefresh
?:
{
[
treeItemHandle
:
string
]:
ITreeItem
}
):
void
{
this
.
onRefresh
.
fire
(
item
sToRefresh
);
}
}
let
testObject
:
ExtHostTreeViews
;
let
target
:
RecordingShape
;
let
onDidChangeTreeData
:
Emitter
<
string
>
;
let
tree
=
{
let
tree
;
let
labels
;
setup
(()
=>
{
tree
=
{
'
a
'
:
{
'
aa
'
:
{},
'
ab
'
:
{}
...
...
@@ -50,7 +54,8 @@ suite('ExtHostTreeView', function () {
}
};
setup
(()
=>
{
labels
=
{};
let
threadService
=
new
TestThreadService
();
// Use IInstantiationService to get typechecking when instantiating
let
inst
:
IInstantiationService
;
...
...
@@ -102,23 +107,34 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh root
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
equal
(
0
,
actuals
.
length
);
assert
.
equal
(
undefined
,
actuals
);
done
();
});
onDidChangeTreeData
.
fire
();
});
test
(
'
refresh a parent node
'
,
function
(
done
)
{
test
(
'
refresh a parent node
'
,
()
=>
{
return
new
TPromise
((
c
,
e
)
=>
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/1:b
'
],
actuals
);
done
();
assert
.
deepEqual
([
'
0/1:b
'
],
Object
.
keys
(
actuals
));
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/1:b
'
]),
{
handle
:
'
0/1:b
'
,
label
:
'
b
'
,
});
c
(
null
);
});
onDidChangeTreeData
.
fire
(
'
b
'
);
});
});
test
(
'
refresh a leaf node
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/1:b/1:bb
'
],
actuals
);
assert
.
deepEqual
([
'
0/1:b/1:bb
'
],
Object
.
keys
(
actuals
));
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/1:b/1:bb
'
]),
{
handle
:
'
0/1:b/1:bb
'
,
parentHandle
:
'
0/1:b
'
,
label
:
'
bb
'
});
done
();
});
onDidChangeTreeData
.
fire
(
'
bb
'
);
...
...
@@ -126,7 +142,16 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh parent and child node trigger refresh only on parent - scenario 1
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/1:b
'
,
'
0/0:a/0:aa
'
],
actuals
);
assert
.
deepEqual
([
'
0/1:b
'
,
'
0/0:a/0:aa
'
],
Object
.
keys
(
actuals
));
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/1:b
'
]),
{
handle
:
'
0/1:b
'
,
label
:
'
b
'
,
});
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/0:a/0:aa
'
]),
{
handle
:
'
0/0:a/0:aa
'
,
parentHandle
:
'
0/0:a
'
,
label
:
'
aa
'
,
});
done
();
});
onDidChangeTreeData
.
fire
(
'
b
'
);
...
...
@@ -136,7 +161,16 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh parent and child node trigger refresh only on parent - scenario 2
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/0:a/0:aa
'
,
'
0/1:b
'
],
actuals
);
assert
.
deepEqual
([
'
0/0:a/0:aa
'
,
'
0/1:b
'
],
Object
.
keys
(
actuals
));
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/1:b
'
]),
{
handle
:
'
0/1:b
'
,
label
:
'
b
'
,
});
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/0:a/0:aa
'
]),
{
handle
:
'
0/0:a/0:aa
'
,
parentHandle
:
'
0/0:a
'
,
label
:
'
aa
'
,
});
done
();
});
onDidChangeTreeData
.
fire
(
'
bb
'
);
...
...
@@ -144,9 +178,22 @@ suite('ExtHostTreeView', function () {
onDidChangeTreeData
.
fire
(
'
b
'
);
});
test
(
'
refresh an element for label change
'
,
function
(
done
)
{
labels
[
'
a
'
]
=
'
aa
'
;
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/0:a
'
],
Object
.
keys
(
actuals
));
assert
.
deepEqual
(
removeUnsetKeys
(
actuals
[
'
0/0:a
'
]),
{
handle
:
'
0/0:aa
'
,
label
:
'
aa
'
,
});
done
();
});
onDidChangeTreeData
.
fire
(
'
a
'
);
});
test
(
'
refresh calls are throttled on roots
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
equal
(
0
,
actuals
.
length
);
assert
.
equal
(
undefined
,
actuals
);
done
();
});
onDidChangeTreeData
.
fire
();
...
...
@@ -157,7 +204,7 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh calls are throttled on elements
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/0:a
'
,
'
0/1:b
'
],
actuals
);
assert
.
deepEqual
([
'
0/0:a
'
,
'
0/1:b
'
],
Object
.
keys
(
actuals
)
);
done
();
});
...
...
@@ -169,7 +216,7 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh calls are throttled on unknown elements
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
deepEqual
([
'
0/0:a
'
,
'
0/1:b
'
],
actuals
);
assert
.
deepEqual
([
'
0/0:a
'
,
'
0/1:b
'
],
Object
.
keys
(
actuals
)
);
done
();
});
...
...
@@ -181,7 +228,7 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh calls are throttled on unknown elements and root
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
equal
(
0
,
actuals
.
length
);
assert
.
equal
(
undefined
,
actuals
);
done
();
});
...
...
@@ -193,7 +240,7 @@ suite('ExtHostTreeView', function () {
test
(
'
refresh calls are throttled on elements and root
'
,
function
(
done
)
{
target
.
onRefresh
.
event
(
actuals
=>
{
assert
.
equal
(
0
,
actuals
.
length
);
assert
.
equal
(
undefined
,
actuals
);
done
();
});
...
...
@@ -203,6 +250,16 @@ suite('ExtHostTreeView', function () {
onDidChangeTreeData
.
fire
(
'
a
'
);
});
function
removeUnsetKeys
(
obj
:
any
):
any
{
const
result
=
{};
for
(
const
key
of
Object
.
keys
(
obj
))
{
if
(
obj
[
key
]
!==
void
0
)
{
result
[
key
]
=
obj
[
key
];
}
}
return
result
;
}
function
aTreeDataProvider
():
TreeDataProvider
<
string
>
{
const
getTreeElement
=
(
element
)
=>
{
let
parent
=
tree
;
...
...
@@ -233,7 +290,7 @@ suite('ExtHostTreeView', function () {
getTreeItem
:
(
element
:
string
):
TreeItem
=>
{
const
treeElement
=
getTreeElement
(
element
);
return
{
label
:
element
,
label
:
labels
[
element
]
||
element
,
collapsibleState
:
treeElement
?
treeElement
[
'
collapsibleState
'
]
:
TreeItemCollapsibleState
.
Collapsed
};
},
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录