Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
ee4a4dff
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,发现更多精彩内容 >>
提交
ee4a4dff
编写于
12月 20, 2017
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more tree model tests
上级
1454f1bb
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
83 addition
and
16 deletion
+83
-16
src/vs/base/browser/ui/list/treeModel.ts
src/vs/base/browser/ui/list/treeModel.ts
+14
-12
src/vs/base/test/browser/ui/list/treeModel.test.ts
src/vs/base/test/browser/ui/list/treeModel.test.ts
+69
-4
未找到文件。
src/vs/base/browser/ui/list/treeModel.ts
浏览文件 @
ee4a4dff
...
...
@@ -5,7 +5,7 @@
'
use strict
'
;
import
{
ISp
readSpliceable
}
from
'
./spli
ce
'
;
import
{
ISp
liceable
}
from
'
vs/base/common/sequen
ce
'
;
export
interface
ITreeElement
<
T
>
{
readonly
element
:
T
;
...
...
@@ -73,30 +73,32 @@ export class TreeModel<T> {
private
root
=
TreeNode
.
createRoot
<
T
>
();
constructor
(
private
spliceable
:
ISp
readSp
liceable
<
ITreeNode
<
T
>>
)
{
}
constructor
(
private
spliceable
:
ISpliceable
<
ITreeNode
<
T
>>
)
{
}
splice
(
start
:
number
[],
deleteCount
:
number
,
elements
:
ITreeElement
<
T
>
[]):
void
{
if
(
start
.
length
===
0
)
{
throw
new
Error
(
'
Invalid tree location
'
);
}
const
{
node
,
listIndex
}
=
this
.
findNode
(
start
,
this
.
root
,
0
);
const
{
listDeleteCount
,
listElements
}
=
node
.
splice
(
start
[
start
.
length
-
1
],
deleteCount
,
elements
);
const
{
parentNode
,
parentListIndex
}
=
this
.
findParentNode
(
start
,
this
.
root
,
0
);
const
lastIndex
=
start
[
start
.
length
-
1
];
const
{
listDeleteCount
,
listElements
}
=
parentNode
.
splice
(
lastIndex
,
deleteCount
,
elements
);
this
.
spliceable
.
splice
(
listIndex
,
listDeleteCount
,
...
listElements
);
this
.
spliceable
.
splice
(
parentListIndex
+
lastIndex
,
listDeleteCount
,
listElements
);
}
private
findNode
(
location
:
number
[],
node
:
TreeNode
<
T
>
,
listIndex
:
number
):
{
node
:
TreeNode
<
T
>
;
listIndex
:
number
}
{
const
[
i
,
...
rest
]
=
location
;
if
(
rest
.
length
===
0
)
{
return
{
node
,
listIndex
};
private
findParentNode
(
location
:
number
[],
node
:
TreeNode
<
T
>
,
listIndex
:
number
):
{
parentNode
:
TreeNode
<
T
>
;
parentListIndex
:
number
}
{
if
(
location
.
length
===
1
)
{
return
{
parentNode
:
node
,
parentListIndex
:
listIndex
};
}
for
(
let
j
=
0
;
j
<
i
;
j
++
)
{
const
[
i
,
...
rest
]
=
location
;
const
limit
=
Math
.
min
(
i
,
node
.
children
.
length
);
for
(
let
j
=
0
;
j
<
limit
;
j
++
)
{
listIndex
+=
node
.
children
[
j
].
count
;
}
return
this
.
find
Node
(
rest
,
node
.
children
[
i
],
listIndex
);
return
this
.
find
ParentNode
(
rest
,
node
.
children
[
i
],
listIndex
+
1
);
}
}
src/vs/base/test/browser/ui/list/treeModel.test.ts
浏览文件 @
ee4a4dff
...
...
@@ -5,19 +5,28 @@
import
*
as
assert
from
'
assert
'
;
import
{
TreeModel
,
ITreeNode
}
from
'
vs/base/browser/ui/list/treeModel
'
;
import
{
ISpliceable
}
from
'
vs/base/browser/ui/list/splice
'
;
function
toSpliceable
<
T
>
(
arr
:
T
[]):
ISpliceable
<
T
>
{
return
{
splice
(
start
:
number
,
deleteCount
:
number
,
elements
:
T
[]):
void
{
arr
.
splice
(
start
,
deleteCount
,
...
elements
);
}
};
}
suite
(
'
TreeModel2
'
,
()
=>
{
test
(
'
ctor
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
TreeModel
<
number
>
(
list
);
const
model
=
new
TreeModel
<
number
>
(
toSpliceable
(
list
)
);
assert
(
model
);
assert
.
equal
(
list
.
length
,
0
);
});
test
(
'
insert
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
TreeModel
<
number
>
(
list
);
const
model
=
new
TreeModel
<
number
>
(
toSpliceable
(
list
)
);
model
.
splice
([
0
],
0
,
[
{
element
:
0
,
children
:
[]
},
...
...
@@ -36,7 +45,7 @@ suite('TreeModel2', () => {
test
(
'
deep insert
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
TreeModel
<
number
>
(
list
);
const
model
=
new
TreeModel
<
number
>
(
toSpliceable
(
list
)
);
model
.
splice
([
0
],
0
,
[
{
...
...
@@ -67,7 +76,7 @@ suite('TreeModel2', () => {
test
(
'
delete
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
TreeModel
<
number
>
(
list
);
const
model
=
new
TreeModel
<
number
>
(
toSpliceable
(
list
)
);
model
.
splice
([
0
],
0
,
[
{
element
:
0
,
children
:
[]
},
...
...
@@ -79,4 +88,60 @@ suite('TreeModel2', () => {
assert
.
equal
(
list
.
length
,
0
);
});
test
(
'
nested delete
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
TreeModel
<
number
>
(
toSpliceable
(
list
));
model
.
splice
([
0
],
0
,
[
{
element
:
0
,
children
:
[
{
element
:
10
,
children
:
[]
},
{
element
:
11
,
children
:
[]
},
{
element
:
12
,
children
:
[]
},
]
},
{
element
:
1
,
children
:
[]
},
{
element
:
2
,
children
:
[]
}
]);
model
.
splice
([
0
,
1
],
1
,
[]);
assert
.
deepEqual
(
list
.
length
,
5
,
'
list has 5 elements
'
);
assert
.
deepEqual
(
list
[
0
].
element
,
0
);
assert
.
deepEqual
(
list
[
0
].
depth
,
1
);
assert
.
deepEqual
(
list
[
1
].
element
,
10
);
assert
.
deepEqual
(
list
[
1
].
depth
,
2
);
assert
.
deepEqual
(
list
[
2
].
element
,
12
);
assert
.
deepEqual
(
list
[
2
].
depth
,
2
);
assert
.
deepEqual
(
list
[
3
].
element
,
1
);
assert
.
deepEqual
(
list
[
3
].
depth
,
1
);
assert
.
deepEqual
(
list
[
4
].
element
,
2
);
assert
.
deepEqual
(
list
[
4
].
depth
,
1
);
});
test
(
'
deep delete
'
,
()
=>
{
const
list
=
[]
as
ITreeNode
<
number
>
[];
const
model
=
new
TreeModel
<
number
>
(
toSpliceable
(
list
));
model
.
splice
([
0
],
0
,
[
{
element
:
0
,
children
:
[
{
element
:
10
,
children
:
[]
},
{
element
:
11
,
children
:
[]
},
{
element
:
12
,
children
:
[]
},
]
},
{
element
:
1
,
children
:
[]
},
{
element
:
2
,
children
:
[]
}
]);
model
.
splice
([
0
],
1
,
[]);
assert
.
deepEqual
(
list
.
length
,
2
,
'
list has 2 elements only
'
);
assert
.
deepEqual
(
list
[
0
].
element
,
1
);
assert
.
deepEqual
(
list
[
0
].
depth
,
1
);
assert
.
deepEqual
(
list
[
1
].
element
,
2
);
assert
.
deepEqual
(
list
[
1
].
depth
,
1
);
});
});
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录