Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
c16d7a3c
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,发现更多精彩内容 >>
提交
c16d7a3c
编写于
12月 18, 2017
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
#40196 Read the content since last read by passing position to file service
上级
78f1f553
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
16 addition
and
12 deletion
+16
-12
src/vs/workbench/parts/output/electron-browser/outputServices.ts
...workbench/parts/output/electron-browser/outputServices.ts
+16
-12
未找到文件。
src/vs/workbench/parts/output/electron-browser/outputServices.ts
浏览文件 @
c16d7a3c
...
...
@@ -142,7 +142,7 @@ class FileOutputChannel extends Disposable implements OutputChannel {
private
onModelAdded
(
model
:
IModel
):
void
{
if
(
model
.
uri
.
fsPath
===
this
.
id
)
{
this
.
endOffset
=
this
.
startOffset
+
model
.
getValueLength
()
;
this
.
endOffset
=
this
.
startOffset
+
new
Buffer
(
model
.
getValueLength
()).
byteLength
;
this
.
fileHandler
.
watch
();
}
}
...
...
@@ -164,17 +164,8 @@ class FileOutputChannel extends Disposable implements OutputChannel {
let
model
=
this
.
getModel
();
if
(
model
)
{
this
.
fileHandler
.
loadContent
(
this
.
endOffset
)
.
then
(
delta
=>
{
model
=
this
.
getModel
();
if
(
model
&&
delta
)
{
const
lastLine
=
model
.
getLineCount
();
const
lastLineMaxColumn
=
model
.
getLineMaxColumn
(
lastLine
);
model
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
lastLine
,
lastLineMaxColumn
),
delta
)]);
this
.
endOffset
=
this
.
endOffset
+
delta
.
length
;
if
(
!
this
.
scrollLock
)
{
(
<
OutputPanel
>
this
.
panelService
.
getActivePanel
()).
revealLastLine
();
}
}
.
then
(
content
=>
{
this
.
appendContent
(
content
);
this
.
updateInProgress
=
false
;
},
()
=>
this
.
updateInProgress
=
false
);
}
else
{
...
...
@@ -182,6 +173,19 @@ class FileOutputChannel extends Disposable implements OutputChannel {
}
}
private
appendContent
(
content
:
string
):
void
{
const
model
=
this
.
getModel
();
if
(
model
&&
content
)
{
const
lastLine
=
model
.
getLineCount
();
const
lastLineMaxColumn
=
model
.
getLineMaxColumn
(
lastLine
);
model
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
lastLine
,
lastLineMaxColumn
),
content
)]);
this
.
endOffset
=
this
.
endOffset
+
new
Buffer
(
content
).
byteLength
;
if
(
!
this
.
scrollLock
)
{
(
<
OutputPanel
>
this
.
panelService
.
getActivePanel
()).
revealLastLine
();
}
}
}
protected
getModel
():
IModel
{
const
model
=
this
.
modelService
.
getModel
(
URI
.
from
({
scheme
:
OUTPUT_SCHEME
,
path
:
this
.
id
}));
return
model
&&
!
model
.
isDisposed
()
?
model
:
null
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录