Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
3763ab7b
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,发现更多精彩内容 >>
提交
3763ab7b
编写于
1月 11, 2019
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
async data tree: clear cached refresh promises on setinput
fixes #65500
上级
bb21186a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
24 addition
and
16 deletion
+24
-16
src/vs/base/browser/ui/tree/asyncDataTree.ts
src/vs/base/browser/ui/tree/asyncDataTree.ts
+24
-16
未找到文件。
src/vs/base/browser/ui/tree/asyncDataTree.ts
浏览文件 @
3763ab7b
...
...
@@ -9,12 +9,13 @@ import { IListVirtualDelegate, IIdentityProvider, IListDragAndDrop, IListDragOve
import
{
ITreeElement
,
ITreeNode
,
ITreeRenderer
,
ITreeEvent
,
ITreeMouseEvent
,
ITreeContextMenuEvent
,
ITreeSorter
,
ICollapseStateChangeEvent
,
IAsyncDataSource
,
ITreeDragAndDrop
}
from
'
vs/base/browser/ui/tree/tree
'
;
import
{
IDisposable
,
dispose
}
from
'
vs/base/common/lifecycle
'
;
import
{
Emitter
,
Event
}
from
'
vs/base/common/event
'
;
import
{
timeout
,
always
}
from
'
vs/base/common/async
'
;
import
{
timeout
,
always
,
CancelablePromise
,
createCancelablePromise
}
from
'
vs/base/common/async
'
;
import
{
IListStyles
}
from
'
vs/base/browser/ui/list/listWidget
'
;
import
{
toggleClass
}
from
'
vs/base/browser/dom
'
;
import
{
Iterator
}
from
'
vs/base/common/iterator
'
;
import
{
IDragAndDropData
}
from
'
vs/base/browser/dnd
'
;
import
{
ElementsDragAndDropData
}
from
'
vs/base/browser/ui/list/listView
'
;
import
{
isPromiseCanceledError
}
from
'
vs/base/common/errors
'
;
enum
AsyncDataTreeNodeState
{
Uninitialized
,
...
...
@@ -221,7 +222,7 @@ export class AsyncDataTree<TInput, T, TFilterData = void> implements IDisposable
private
readonly
tree
:
ObjectTree
<
IAsyncDataTreeNode
<
TInput
,
T
>
,
TFilterData
>
;
private
readonly
root
:
IAsyncDataTreeNode
<
TInput
,
T
>
;
private
readonly
nodes
=
new
Map
<
null
|
T
,
IAsyncDataTreeNode
<
TInput
,
T
>>
();
private
readonly
refreshPromises
=
new
Map
<
IAsyncDataTreeNode
<
TInput
,
T
>
,
Promise
<
void
>>
();
private
readonly
refreshPromises
=
new
Map
<
IAsyncDataTreeNode
<
TInput
,
T
>
,
CancelablePromise
<
T
[]
>>
();
private
readonly
identityProvider
?:
IIdentityProvider
<
T
>
;
private
readonly
_onDidChangeNodeState
=
new
Emitter
<
IAsyncDataTreeNode
<
TInput
,
T
>>
();
...
...
@@ -327,6 +328,9 @@ export class AsyncDataTree<TInput, T, TFilterData = void> implements IDisposable
}
setInput
(
input
:
TInput
):
Promise
<
void
>
{
this
.
refreshPromises
.
forEach
(
promise
=>
promise
.
cancel
());
this
.
refreshPromises
.
clear
();
this
.
root
.
element
=
input
!
;
return
this
.
refresh
(
input
);
}
...
...
@@ -486,25 +490,13 @@ export class AsyncDataTree<TInput, T, TFilterData = void> implements IDisposable
}
private
async
refreshNode
(
node
:
IAsyncDataTreeNode
<
TInput
,
T
>
,
recursive
:
boolean
,
reason
:
ChildrenResolutionReason
):
Promise
<
void
>
{
await
this
.
_refreshNode
(
node
,
recursive
,
reason
);
await
this
.
doRefresh
(
node
,
recursive
,
reason
);
if
(
recursive
&&
node
.
children
)
{
await
Promise
.
all
(
node
.
children
.
map
(
child
=>
this
.
refreshNode
(
child
,
recursive
,
reason
)));
}
}
private
_refreshNode
(
node
:
IAsyncDataTreeNode
<
TInput
,
T
>
,
recursive
:
boolean
,
reason
:
ChildrenResolutionReason
):
Promise
<
void
>
{
let
result
=
this
.
refreshPromises
.
get
(
node
);
if
(
result
)
{
return
result
;
}
result
=
this
.
doRefresh
(
node
,
recursive
,
reason
);
this
.
refreshPromises
.
set
(
node
,
result
);
return
always
(
result
,
()
=>
this
.
refreshPromises
.
delete
(
node
));
}
private
doRefresh
(
node
:
IAsyncDataTreeNode
<
TInput
,
T
>
,
recursive
:
boolean
,
reason
:
ChildrenResolutionReason
):
Promise
<
void
>
{
const
hasChildren
=
!!
this
.
dataSource
.
hasChildren
(
node
.
element
!
);
...
...
@@ -524,7 +516,7 @@ export class AsyncDataTree<TInput, T, TFilterData = void> implements IDisposable
this
.
_onDidChangeNodeState
.
fire
(
node
);
},
_
=>
null
);
return
Promise
.
resolve
(
this
.
d
ataSource
.
getChildren
(
node
.
element
!
))
return
Promise
.
resolve
(
this
.
d
oGetChildren
(
node
))
.
then
(
children
=>
{
slowTimeout
.
cancel
();
node
.
state
=
AsyncDataTreeNodeState
.
Loaded
;
...
...
@@ -533,6 +525,10 @@ export class AsyncDataTree<TInput, T, TFilterData = void> implements IDisposable
this
.
setChildren
(
node
,
children
,
recursive
);
this
.
_onDidResolveChildren
.
fire
({
element
:
node
.
element
as
T
,
reason
});
},
err
=>
{
if
(
isPromiseCanceledError
(
err
))
{
return
Promise
.
resolve
(
null
);
}
slowTimeout
.
cancel
();
node
.
state
=
AsyncDataTreeNodeState
.
Uninitialized
;
this
.
_onDidChangeNodeState
.
fire
(
node
);
...
...
@@ -546,6 +542,18 @@ export class AsyncDataTree<TInput, T, TFilterData = void> implements IDisposable
}
}
private
doGetChildren
(
node
:
IAsyncDataTreeNode
<
TInput
,
T
>
):
Promise
<
T
[]
>
{
let
result
=
this
.
refreshPromises
.
get
(
node
);
if
(
result
)
{
return
result
;
}
result
=
createCancelablePromise
(
_
=>
Promise
.
resolve
(
this
.
dataSource
.
getChildren
(
node
.
element
!
)));
this
.
refreshPromises
.
set
(
node
,
result
);
return
always
(
result
,
()
=>
this
.
refreshPromises
.
delete
(
node
));
}
private
_onDidChangeCollapseState
({
node
,
deep
}:
ICollapseStateChangeEvent
<
IAsyncDataTreeNode
<
TInput
,
T
>
,
any
>
):
void
{
if
(
!
node
.
collapsed
&&
node
.
element
.
state
===
AsyncDataTreeNodeState
.
Uninitialized
)
{
if
(
deep
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录