Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
a3f7b53d
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,发现更多精彩内容 >>
提交
a3f7b53d
编写于
1月 31, 2018
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix #42594
上级
93681eb4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
55 addition
and
57 deletion
+55
-57
src/vs/workbench/parts/output/electron-browser/outputServices.ts
...workbench/parts/output/electron-browser/outputServices.ts
+55
-57
未找到文件。
src/vs/workbench/parts/output/electron-browser/outputServices.ts
浏览文件 @
a3f7b53d
...
...
@@ -130,7 +130,7 @@ abstract class AbstractFileOutputChannel extends Disposable {
protected
model
:
ITextModel
;
readonly
file
:
URI
;
pr
ivate
startOffset
:
number
=
0
;
pr
otected
startOffset
:
number
=
0
;
protected
endOffset
:
number
=
0
;
constructor
(
...
...
@@ -164,38 +164,20 @@ abstract class AbstractFileOutputChannel extends Disposable {
this
.
startOffset
=
this
.
endOffset
;
}
loadModel
():
TPromise
<
ITextModel
>
{
return
this
.
fileService
.
resolveContent
(
this
.
file
,
{
position
:
this
.
startOffset
})
.
then
(
content
=>
{
if
(
this
.
model
)
{
this
.
model
.
setValue
(
content
.
value
);
}
else
{
this
.
model
=
this
.
createModel
(
content
.
value
);
}
this
.
endOffset
=
this
.
startOffset
+
new
Buffer
(
this
.
model
.
getValueLength
()).
byteLength
;
return
this
.
model
;
});
}
resetModel
():
TPromise
<
void
>
{
this
.
startOffset
=
0
;
this
.
endOffset
=
0
;
protected
createModel
(
content
:
string
):
ITextModel
{
if
(
this
.
model
)
{
return
this
.
loadModel
()
as
TPromise
;
this
.
model
.
setValue
(
content
);
}
else
{
this
.
model
=
this
.
modelService
.
createModel
(
content
,
this
.
modeService
.
getOrCreateMode
(
OUTPUT_MIME
),
this
.
modelUri
);
this
.
onModelCreated
(
this
.
model
);
const
disposables
:
IDisposable
[]
=
[];
disposables
.
push
(
this
.
model
.
onWillDispose
(()
=>
{
this
.
onModelWillDispose
(
this
.
model
);
this
.
model
=
null
;
dispose
(
disposables
);
}));
}
return
TPromise
.
as
(
null
);
}
private
createModel
(
content
:
string
):
ITextModel
{
const
model
=
this
.
modelService
.
createModel
(
content
,
this
.
modeService
.
getOrCreateMode
(
OUTPUT_MIME
),
this
.
modelUri
);
this
.
onModelCreated
(
model
);
const
disposables
:
IDisposable
[]
=
[];
disposables
.
push
(
model
.
onWillDispose
(()
=>
{
this
.
onModelWillDispose
(
model
);
this
.
model
=
null
;
dispose
(
disposables
);
}));
return
model
;
return
this
.
model
;
}
appendToModel
(
content
:
string
):
void
{
...
...
@@ -227,7 +209,6 @@ class OutputChannelBackedByFile extends AbstractFileOutputChannel implements Out
private
loadingFromFileInProgress
:
boolean
=
false
;
private
resettingDelayer
:
ThrottledDelayer
<
void
>
;
private
readonly
rotatingFilePath
:
string
;
private
hasContentsToFlush
:
boolean
=
false
;
constructor
(
outputChannelIdentifier
:
IOutputChannelIdentifier
,
...
...
@@ -273,37 +254,50 @@ class OutputChannelBackedByFile extends AbstractFileOutputChannel implements Out
}
loadModel
():
TPromise
<
ITextModel
>
{
this
.
startLoadingFromFile
();
return
super
.
loadModel
()
.
then
(
model
=>
{
this
.
finishedLoadingFromFile
();
return
model
;
this
.
loadingFromFileInProgress
=
true
;
if
(
this
.
modelUpdater
.
isScheduled
())
{
this
.
modelUpdater
.
cancel
();
}
this
.
appendedMessage
=
''
;
return
this
.
loadFile
()
.
then
(
content
=>
{
if
(
this
.
endOffset
!==
this
.
startOffset
+
new
Buffer
(
content
).
byteLength
)
{
// Queue content is not written into the file
// Flush it and load file again
this
.
flush
();
return
this
.
loadFile
();
}
return
content
;
})
.
then
(
content
=>
{
if
(
this
.
appendedMessage
)
{
this
.
write
(
this
.
appendedMessage
);
this
.
appendedMessage
=
''
;
}
this
.
loadingFromFileInProgress
=
false
;
return
this
.
createModel
(
content
);
});
}
protected
updateModel
():
void
{
if
(
this
.
model
&&
this
.
appendedMessage
)
{
this
.
appendToModel
(
this
.
appendedMessage
);
this
.
appendedMessage
=
''
;
private
resetModel
():
TPromise
<
void
>
{
this
.
startOffset
=
0
;
this
.
endOffset
=
0
;
if
(
this
.
model
)
{
return
this
.
loadModel
()
as
TPromise
;
}
return
TPromise
.
as
(
null
);
}
private
startLoadingFromFile
():
void
{
this
.
loadingFromFileInProgress
=
true
;
this
.
flush
();
if
(
this
.
modelUpdater
.
isScheduled
())
{
this
.
modelUpdater
.
cancel
();
}
this
.
appendedMessage
=
''
;
private
loadFile
():
TPromise
<
string
>
{
return
this
.
fileService
.
resolveContent
(
this
.
file
,
{
position
:
this
.
startOffset
})
.
then
(
content
=>
this
.
appendedMessage
?
content
.
value
+
this
.
appendedMessage
:
content
.
value
);
}
private
finishedLoadingFromFile
():
void
{
if
(
this
.
appendedMessage
)
{
this
.
write
(
this
.
appendedMessage
);
protected
updateModel
():
void
{
if
(
this
.
model
&&
this
.
appendedMessage
)
{
this
.
appendToModel
(
this
.
appendedMessage
);
this
.
appendedMessage
=
''
;
}
this
.
loadingFromFileInProgress
=
false
;
}
private
onFileChangedInOutputDirector
(
eventType
:
string
,
fileName
:
string
):
void
{
...
...
@@ -315,14 +309,10 @@ class OutputChannelBackedByFile extends AbstractFileOutputChannel implements Out
private
write
(
content
:
string
):
void
{
this
.
outputWriter
.
critical
(
content
);
this
.
hasContentsToFlush
=
true
;
}
private
flush
():
void
{
if
(
this
.
hasContentsToFlush
)
{
this
.
outputWriter
.
flush
();
this
.
hasContentsToFlush
=
false
;
}
this
.
outputWriter
.
flush
();
}
}
...
...
@@ -384,6 +374,14 @@ class FileOutputChannel extends AbstractFileOutputChannel implements OutputChann
this
.
_register
(
toDisposable
(()
=>
this
.
fileHandler
.
unwatch
()));
}
loadModel
():
TPromise
<
ITextModel
>
{
return
this
.
fileService
.
resolveContent
(
this
.
file
,
{
position
:
this
.
startOffset
})
.
then
(
content
=>
{
this
.
endOffset
=
this
.
startOffset
+
new
Buffer
(
content
.
value
).
byteLength
;
return
this
.
createModel
(
content
.
value
);
});
}
append
(
message
:
string
):
void
{
throw
new
Error
(
'
Not supported
'
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录