Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
a47886c5
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,发现更多精彩内容 >>
提交
a47886c5
编写于
9月 20, 2019
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix build
上级
e0cdfa58
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
33 addition
and
4 deletion
+33
-4
src/vs/base/browser/ui/tree/abstractTree.ts
src/vs/base/browser/ui/tree/abstractTree.ts
+2
-2
src/vs/base/common/arrays.ts
src/vs/base/common/arrays.ts
+6
-0
src/vs/base/common/collections.ts
src/vs/base/common/collections.ts
+6
-0
src/vs/base/common/iterator.ts
src/vs/base/common/iterator.ts
+17
-1
src/vs/base/common/resourceTree.ts
src/vs/base/common/resourceTree.ts
+2
-1
未找到文件。
src/vs/base/browser/ui/tree/abstractTree.ts
浏览文件 @
a47886c5
...
...
@@ -14,7 +14,7 @@ import { KeyCode } from 'vs/base/common/keyCodes';
import
{
ITreeModel
,
ITreeNode
,
ITreeRenderer
,
ITreeEvent
,
ITreeMouseEvent
,
ITreeContextMenuEvent
,
ITreeFilter
,
ITreeNavigator
,
ICollapseStateChangeEvent
,
ITreeDragAndDrop
,
TreeDragOverBubble
,
TreeVisibility
,
TreeFilterResult
,
ITreeModelSpliceEvent
,
TreeMouseEventTarget
}
from
'
vs/base/browser/ui/tree/tree
'
;
import
{
ISpliceable
}
from
'
vs/base/common/sequence
'
;
import
{
IDragAndDropData
,
StaticDND
,
DragAndDropData
}
from
'
vs/base/browser/dnd
'
;
import
{
range
,
equals
,
distinctES6
}
from
'
vs/base/common/arrays
'
;
import
{
range
,
equals
,
distinctES6
,
fromSet
}
from
'
vs/base/common/arrays
'
;
import
{
ElementsDragAndDropData
}
from
'
vs/base/browser/ui/list/listView
'
;
import
{
domEvent
}
from
'
vs/base/browser/event
'
;
import
{
fuzzyScore
,
FuzzyScore
}
from
'
vs/base/common/filters
'
;
...
...
@@ -1266,7 +1266,7 @@ export abstract class AbstractTree<T, TFilterData, TRef> implements IDisposable
set
.
add
(
node
);
}
onDidChangeActiveNodes
.
fire
(
Array
.
from
(
set
.
values
()
));
onDidChangeActiveNodes
.
fire
(
fromSet
(
set
));
},
null
,
this
.
disposables
);
if
(
_options
.
keyboardSupport
!==
false
)
{
...
...
src/vs/base/common/arrays.ts
浏览文件 @
a47886c5
...
...
@@ -372,6 +372,12 @@ export function distinctES6<T>(array: ReadonlyArray<T>): T[] {
});
}
export
function
fromSet
<
T
>
(
set
:
Set
<
T
>
):
T
[]
{
const
result
:
T
[]
=
[];
set
.
forEach
(
o
=>
result
.
push
(
o
));
return
result
;
}
export
function
uniqueFilter
<
T
>
(
keyFn
:
(
t
:
T
)
=>
string
):
(
t
:
T
)
=>
boolean
{
const
seen
:
{
[
key
:
string
]:
boolean
;
}
=
Object
.
create
(
null
);
...
...
src/vs/base/common/collections.ts
浏览文件 @
a47886c5
...
...
@@ -95,6 +95,12 @@ export function fromMap<T>(original: Map<string, T>): IStringDictionary<T> {
return
result
;
}
export
function
mapValues
<
V
>
(
map
:
Map
<
any
,
V
>
):
V
[]
{
const
result
:
V
[]
=
[];
map
.
forEach
((
_
,
v
)
=>
result
.
push
(
v
));
return
result
;
}
export
class
SetMap
<
K
,
V
>
{
private
map
=
new
Map
<
K
,
Set
<
V
>>
();
...
...
src/vs/base/common/iterator.ts
浏览文件 @
a47886c5
...
...
@@ -18,6 +18,22 @@ export interface Iterator<T> {
next
():
IteratorResult
<
T
>
;
}
interface
NativeIteratorYieldResult
<
TYield
>
{
done
?:
false
;
value
:
TYield
;
}
interface
NativeIteratorReturnResult
<
TReturn
>
{
done
:
true
;
value
:
TReturn
;
}
type
NativeIteratorResult
<
T
,
TReturn
=
any
>
=
NativeIteratorYieldResult
<
T
>
|
NativeIteratorReturnResult
<
TReturn
>
;
export
interface
NativeIterator
<
T
>
{
next
():
NativeIteratorResult
<
T
>
;
}
export
module
Iterator
{
const
_empty
:
Iterator
<
any
>
=
{
next
()
{
...
...
@@ -56,7 +72,7 @@ export module Iterator {
};
}
export
function
from
IterableIterator
<
T
>
(
it
:
Iterabl
eIterator
<
T
>
):
Iterator
<
T
>
{
export
function
from
NativeIterator
<
T
>
(
it
:
Nativ
eIterator
<
T
>
):
Iterator
<
T
>
{
return
{
next
():
IteratorResult
<
T
>
{
const
result
=
it
.
next
();
...
...
src/vs/base/common/resourceTree.ts
浏览文件 @
a47886c5
...
...
@@ -8,6 +8,7 @@ import * as paths from 'vs/base/common/path';
import
{
Iterator
}
from
'
vs/base/common/iterator
'
;
import
{
relativePath
,
joinPath
}
from
'
vs/base/common/resources
'
;
import
{
URI
}
from
'
vs/base/common/uri
'
;
import
{
mapValues
}
from
'
vs/base/common/collections
'
;
export
interface
ILeafNode
<
T
,
C
=
void
>
{
readonly
uri
:
URI
;
...
...
@@ -49,7 +50,7 @@ class BranchNode<T, C> extends Node<C> implements IBranchNode<T, C> {
}
get
children
():
Iterator
<
BranchNode
<
T
,
C
>
|
LeafNode
<
T
,
C
>>
{
return
Iterator
.
from
IterableIterator
(
this
.
_children
.
values
(
));
return
Iterator
.
from
Array
(
mapValues
(
this
.
_children
));
}
constructor
(
uri
:
URI
,
relativePath
:
string
,
context
:
C
,
readonly
parent
:
IBranchNode
<
T
,
C
>
|
undefined
=
undefined
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录