Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
413dd919
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,体验更适合开发者的 AI 搜索 >>
提交
413dd919
编写于
2月 04, 2016
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
"Close All Files" action can leave the editor area stale and broken (fixes #2704)
上级
0ee59834
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
32 addition
and
12 deletion
+32
-12
src/vs/workbench/browser/parts/editor/editorPart.ts
src/vs/workbench/browser/parts/editor/editorPart.ts
+32
-12
未找到文件。
src/vs/workbench/browser/parts/editor/editorPart.ts
浏览文件 @
413dd919
...
...
@@ -79,6 +79,8 @@ export class EditorPart extends Part implements IEditorPart {
private
mapEditorCreationPromiseToEditor
:
{
[
editorId
:
string
]:
TPromise
<
BaseEditor
>
;
}[];
private
editorOpenToken
:
number
[];
private
editorSetInputErrorCounter
:
number
[];
private
pendingEditorInputsToClose
:
EditorInput
[];
private
pendingEditorInputCloseTimeout
:
number
;
constructor
(
private
messageService
:
IMessageService
,
...
...
@@ -111,6 +113,9 @@ export class EditorPart extends Part implements IEditorPart {
this
.
mapActionsToEditors
=
this
.
createPositionArray
(
false
);
this
.
mapEditorLoadingPromiseToEditor
=
this
.
createPositionArray
(
false
);
this
.
mapEditorCreationPromiseToEditor
=
this
.
createPositionArray
(
false
);
this
.
pendingEditorInputsToClose
=
[];
this
.
pendingEditorInputCloseTimeout
=
null
;
}
public
setInstantiationService
(
service
:
IInstantiationService
):
void
{
...
...
@@ -209,14 +214,13 @@ export class EditorPart extends Part implements IEditorPart {
if
(
input
)
{
this
.
visibleInputListeners
[
position
]
=
input
.
addListener
(
EventType
.
DISPOSE
,
()
=>
{
// To prevent race conditions, we call the close in a timeout because it can well be
// that an input is being disposed with the intent to replace it with some other input
// right after.
setTimeout
(()
=>
{
if
(
input
===
this
.
visibleInputs
[
position
])
{
this
.
closeEditors
(
false
,
input
).
done
(
null
,
errors
.
onUnexpectedError
);
}
},
0
);
// Keep the inputs to close. We use this to support multiple inputs closing
// right after each other and this helps avoid layout issues with the delayed
// timeout based closing below
if
(
input
===
this
.
visibleInputs
[
position
])
{
this
.
pendingEditorInputsToClose
.
push
(
input
);
this
.
startDelayedCloseEditorsFromInputDispose
();
}
});
}
...
...
@@ -432,17 +436,33 @@ export class EditorPart extends Part implements IEditorPart {
});
}
public
closeEditors
(
othersOnly
?:
boolean
,
input
?:
EditorInput
):
TPromise
<
void
>
{
private
startDelayedCloseEditorsFromInputDispose
():
void
{
// To prevent race conditions, we call the close in a timeout because it can well be
// that an input is being disposed with the intent to replace it with some other input
// right after.
if
(
this
.
pendingEditorInputCloseTimeout
===
null
)
{
this
.
pendingEditorInputCloseTimeout
=
setTimeout
(()
=>
{
this
.
closeEditors
(
false
,
this
.
pendingEditorInputsToClose
).
done
(
null
,
errors
.
onUnexpectedError
);
// Reset
this
.
pendingEditorInputCloseTimeout
=
null
;
this
.
pendingEditorInputsToClose
=
[];
},
0
);
}
}
public
closeEditors
(
othersOnly
?:
boolean
,
inputs
?:
EditorInput
[]):
TPromise
<
void
>
{
let
promises
:
Promise
[]
=
[];
let
editors
=
this
.
getVisibleEditors
().
reverse
();
// start from the end to prevent layout to happen through rochade
for
(
let
i
=
0
;
i
<
editors
.
length
;
i
++
)
{
let
editor
=
editors
[
i
];
for
(
var
i
=
0
;
i
<
editors
.
length
;
i
++
)
{
var
editor
=
editors
[
i
];
if
(
othersOnly
&&
this
.
getActiveEditor
()
===
editor
)
{
continue
;
}
if
(
!
input
||
input
===
editor
.
input
)
{
if
(
!
input
s
||
inputs
.
some
(
inp
=>
inp
===
editor
.
input
)
)
{
promises
.
push
(
this
.
openEditor
(
null
,
null
,
editor
.
position
));
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录