Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
e09143e8
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,发现更多精彩内容 >>
提交
e09143e8
编写于
5月 05, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more test and bugfix
上级
461a529b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
40 addition
and
9 deletion
+40
-9
src/vs/workbench/common/editor/editorStacksModel.ts
src/vs/workbench/common/editor/editorStacksModel.ts
+7
-5
src/vs/workbench/test/common/editor/editorStacksModel.test.ts
...vs/workbench/test/common/editor/editorStacksModel.test.ts
+33
-4
未找到文件。
src/vs/workbench/common/editor/editorStacksModel.ts
浏览文件 @
e09143e8
...
...
@@ -65,7 +65,6 @@ export interface IEditorOpenOptions {
// Open
// To the left / to the right (setting)
// Close
// Reveals from the left / from the right (setting)
// Close Others
// Close Editors to the Right
// Close All
...
...
@@ -160,13 +159,13 @@ export class EditorGroup implements IEditorGroup {
public
openEditor
(
editor
:
EditorInput
,
options
?:
IEditorOpenOptions
):
void
{
const
index
=
this
.
indexOf
(
editor
);
const
makeActive
=
(
options
&&
options
.
active
)
||
!
this
.
activeEditor
||
this
.
matches
(
this
.
preview
,
this
.
activeEditor
);
const
makePinned
=
options
&&
options
.
pinned
;
const
makeActive
=
(
options
&&
options
.
active
)
||
!
this
.
activeEditor
||
(
!
makePinned
&&
this
.
matches
(
this
.
preview
,
this
.
activeEditor
));
// New editor
if
(
index
===
-
1
)
{
// Insert into our list of editors if pinned or we
are first
// Insert into our list of editors if pinned or we
have no preview editor
if
(
makePinned
||
!
this
.
preview
)
{
const
indexOfActive
=
this
.
indexOf
(
this
.
active
);
...
...
@@ -187,9 +186,11 @@ export class EditorGroup implements IEditorGroup {
// Handle preview
if
(
!
makePinned
)
{
// Replace existing preview with this editor if we have a preview
if
(
this
.
preview
)
{
const
indexOfPreview
=
this
.
indexOf
(
this
.
preview
);
this
.
closeEditor
(
this
.
preview
);
this
.
closeEditor
(
this
.
preview
);
// TODO this can cause the next in MRU list to become active which may be unwanted
this
.
splice
(
indexOfPreview
,
false
,
editor
);
}
...
...
@@ -264,6 +265,7 @@ export class EditorGroup implements IEditorGroup {
this
.
active
=
editor
;
// Bring to front in MRU list
this
.
setMostRecentlyUsed
(
editor
);
// Event
...
...
@@ -379,7 +381,7 @@ export class EditorGroup implements IEditorGroup {
export
class
EditorStacksModel
implements
IEditorStacksModel
{
private
_groups
:
EditorGroup
[];
private
active
:
EditorGroup
;
// index of group with currently active editor
private
active
:
EditorGroup
;
private
_onGroupOpened
:
Emitter
<
EditorGroup
>
;
private
_onGroupClosed
:
Emitter
<
EditorGroup
>
;
...
...
src/vs/workbench/test/common/editor/editorStacksModel.test.ts
浏览文件 @
e09143e8
...
...
@@ -74,7 +74,7 @@ function input(id = String(index++)): EditorInput {
suite
(
'
Editor Stacks Model
'
,
()
=>
{
teardown
(()
=>
{
teardown
(()
=>
{
index
=
1
;
setOpenEditorDirection
(
Direction
.
RIGHT
);
});
...
...
@@ -490,6 +490,38 @@ suite('Editor Stacks Model', () => {
assert
.
equal
(
group
.
count
,
0
);
});
test
(
'
Stack - Multiple Editors - Pinned & Non Active
'
,
function
()
{
const
model
=
create
();
const
group
=
model
.
openGroup
(
'
group
'
);
const
input1
=
input
();
group
.
openEditor
(
input1
);
assert
.
equal
(
group
.
activeEditor
,
input1
);
assert
.
equal
(
group
.
previewEditor
,
input1
);
assert
.
equal
(
group
.
getEditors
()[
0
],
input1
);
assert
.
equal
(
group
.
count
,
1
);
const
input2
=
input
();
group
.
openEditor
(
input2
,
{
pinned
:
true
,
active
:
false
});
assert
.
equal
(
group
.
activeEditor
,
input1
);
assert
.
equal
(
group
.
previewEditor
,
input1
);
assert
.
equal
(
group
.
getEditors
()[
0
],
input1
);
assert
.
equal
(
group
.
getEditors
()[
1
],
input2
);
assert
.
equal
(
group
.
count
,
2
);
const
input3
=
input
();
group
.
openEditor
(
input3
,
{
pinned
:
true
,
active
:
false
});
assert
.
equal
(
group
.
activeEditor
,
input1
);
assert
.
equal
(
group
.
previewEditor
,
input1
);
assert
.
equal
(
group
.
getEditors
()[
0
],
input1
);
assert
.
equal
(
group
.
getEditors
()[
1
],
input3
);
assert
.
equal
(
group
.
getEditors
()[
2
],
input2
);
assert
.
equal
(
group
.
isPinned
(
input1
),
false
);
assert
.
equal
(
group
.
isPinned
(
input2
),
true
);
assert
.
equal
(
group
.
isPinned
(
input3
),
true
);
assert
.
equal
(
group
.
count
,
3
);
});
test
(
'
Stack - Multiple Editors - real user example
'
,
function
()
{
const
model
=
create
();
...
...
@@ -599,7 +631,4 @@ suite('Editor Stacks Model', () => {
assert
.
equal
(
group
.
activeEditor
,
null
);
assert
.
equal
(
group
.
previewEditor
,
null
);
});
});
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录