Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
adc3a33e
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,发现更多精彩内容 >>
提交
adc3a33e
编写于
2月 21, 2017
作者:
J
Johannes Rieken
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix #14107
上级
00104cc6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
4 addition
and
77 deletion
+4
-77
src/vs/editor/browser/view/viewLayer.ts
src/vs/editor/browser/view/viewLayer.ts
+4
-77
未找到文件。
src/vs/editor/browser/view/viewLayer.ts
浏览文件 @
adc3a33e
...
...
@@ -38,8 +38,6 @@ interface IRendererContext<T extends IVisibleLine> {
lines
:
T
[];
linesLength
:
number
;
readonly
viewportData
:
ViewportData
;
scrollDomNode
:
HTMLElement
;
scrollDomNodeIsAbove
:
boolean
;
}
export
interface
ILine
{
...
...
@@ -255,8 +253,6 @@ export abstract class ViewLayer<T extends IVisibleLine> extends ViewPart {
protected
domNode
:
FastDomNode
<
HTMLElement
>
;
protected
_linesCollection
:
RenderedLinesCollection
<
T
>
;
private
_renderer
:
ViewLayerRenderer
<
T
>
;
private
_scrollDomNode
:
HTMLElement
;
private
_scrollDomNodeIsAbove
:
boolean
;
constructor
(
context
:
ViewContext
)
{
super
(
context
);
...
...
@@ -265,9 +261,6 @@ export abstract class ViewLayer<T extends IVisibleLine> extends ViewPart {
this
.
_linesCollection
=
new
RenderedLinesCollection
<
T
>
(()
=>
this
.
_createLine
());
this
.
_scrollDomNode
=
null
;
this
.
_scrollDomNodeIsAbove
=
false
;
this
.
_renderer
=
new
ViewLayerRenderer
<
T
>
(
()
=>
this
.
_createLine
()
);
...
...
@@ -286,7 +279,6 @@ export abstract class ViewLayer<T extends IVisibleLine> extends ViewPart {
public
onFlushed
(
e
:
viewEvents
.
ViewFlushedEvent
):
boolean
{
this
.
_linesCollection
=
new
RenderedLinesCollection
<
T
>
(()
=>
this
.
_createLine
());
this
.
_scrollDomNode
=
null
;
// No need to clear the dom node because a full .innerHTML will occur in ViewLayerRenderer._render
return
true
;
}
...
...
@@ -348,17 +340,13 @@ export abstract class ViewLayer<T extends IVisibleLine> extends ViewPart {
rendLineNumberStart
:
inp
.
rendLineNumberStart
,
lines
:
inp
.
lines
,
linesLength
:
inp
.
lines
.
length
,
viewportData
:
viewportData
,
scrollDomNode
:
this
.
_scrollDomNode
,
scrollDomNodeIsAbove
:
this
.
_scrollDomNodeIsAbove
viewportData
:
viewportData
};
// Decide if this render will do a single update (single large .innerHTML) or many updates (inserting/removing dom nodes)
let
resCtx
=
this
.
_renderer
.
renderWithManyUpdates
(
ctx
,
viewportData
.
startLineNumber
,
viewportData
.
endLineNumber
,
viewportData
.
relativeVerticalOffset
);
this
.
_linesCollection
.
_set
(
resCtx
.
rendLineNumberStart
,
resCtx
.
lines
);
this
.
_scrollDomNode
=
resCtx
.
scrollDomNode
;
this
.
_scrollDomNodeIsAbove
=
resCtx
.
scrollDomNodeIsAbove
;
}
private
_createDomNode
():
FastDomNode
<
HTMLElement
>
{
...
...
@@ -393,19 +381,9 @@ class ViewLayerRenderer<T extends IVisibleLine> {
lines
:
inContext
.
lines
.
slice
(
0
),
linesLength
:
inContext
.
linesLength
,
viewportData
:
inContext
.
viewportData
,
scrollDomNode
:
inContext
.
scrollDomNode
,
scrollDomNodeIsAbove
:
inContext
.
scrollDomNodeIsAbove
};
let
canRemoveScrollDomNode
=
true
;
if
(
ctx
.
scrollDomNode
)
{
let
time
=
this
.
_getScrollDomNodeTime
(
ctx
.
scrollDomNode
);
if
((
new
Date
()).
getTime
()
-
time
<
1000
)
{
canRemoveScrollDomNode
=
false
;
}
}
if
(
canRemoveScrollDomNode
&&
((
ctx
.
rendLineNumberStart
+
ctx
.
linesLength
-
1
<
startLineNumber
)
||
(
stopLineNumber
<
ctx
.
rendLineNumberStart
)))
{
if
((
ctx
.
rendLineNumberStart
+
ctx
.
linesLength
-
1
<
startLineNumber
)
||
(
stopLineNumber
<
ctx
.
rendLineNumberStart
))
{
// There is no overlap whatsoever
ctx
.
rendLineNumberStart
=
startLineNumber
;
ctx
.
linesLength
=
stopLineNumber
-
startLineNumber
+
1
;
...
...
@@ -414,7 +392,6 @@ class ViewLayerRenderer<T extends IVisibleLine> {
ctx
.
lines
[
x
-
startLineNumber
]
=
this
.
_createLine
();
}
this
.
_finishRendering
(
ctx
,
true
,
deltaTop
);
ctx
.
scrollDomNode
=
null
;
return
ctx
;
}
...
...
@@ -434,14 +411,6 @@ class ViewLayerRenderer<T extends IVisibleLine> {
if
(
fromLineNumber
<=
toLineNumber
)
{
this
.
_insertLinesBefore
(
ctx
,
fromLineNumber
,
toLineNumber
,
deltaTop
,
startLineNumber
);
ctx
.
linesLength
+=
toLineNumber
-
fromLineNumber
+
1
;
// Clean garbage above
if
(
ctx
.
scrollDomNode
&&
ctx
.
scrollDomNodeIsAbove
)
{
if
(
ctx
.
scrollDomNode
.
parentNode
)
{
ctx
.
scrollDomNode
.
parentNode
.
removeChild
(
ctx
.
scrollDomNode
);
}
ctx
.
scrollDomNode
=
null
;
}
}
}
else
if
(
ctx
.
rendLineNumberStart
<
startLineNumber
)
{
// Remove lines before
...
...
@@ -462,14 +431,6 @@ class ViewLayerRenderer<T extends IVisibleLine> {
if
(
fromLineNumber
<=
toLineNumber
)
{
this
.
_insertLinesAfter
(
ctx
,
fromLineNumber
,
toLineNumber
,
deltaTop
,
startLineNumber
);
ctx
.
linesLength
+=
toLineNumber
-
fromLineNumber
+
1
;
// Clean garbage below
if
(
ctx
.
scrollDomNode
&&
!
ctx
.
scrollDomNodeIsAbove
)
{
if
(
ctx
.
scrollDomNode
.
parentNode
)
{
ctx
.
scrollDomNode
.
parentNode
.
removeChild
(
ctx
.
scrollDomNode
);
}
ctx
.
scrollDomNode
=
null
;
}
}
}
else
if
(
ctx
.
rendLineNumberStart
+
ctx
.
linesLength
-
1
>
stopLineNumber
)
{
...
...
@@ -508,45 +469,11 @@ class ViewLayerRenderer<T extends IVisibleLine> {
ctx
.
lines
=
newLines
.
concat
(
ctx
.
lines
);
}
private
_getScrollDomNodeTime
(
domNode
:
HTMLElement
):
number
{
let
lastScrollTime
=
domNode
.
getAttribute
(
'
last-scroll-time
'
);
if
(
lastScrollTime
)
{
return
parseInt
(
lastScrollTime
,
10
);
}
return
0
;
}
private
_removeIfNotScrollDomNode
(
ctx
:
IRendererContext
<
T
>
,
domNode
:
HTMLElement
,
isAbove
:
boolean
)
{
let
time
=
this
.
_getScrollDomNodeTime
(
domNode
);
if
(
!
time
)
{
ctx
.
domNode
.
removeChild
(
domNode
);
return
;
}
if
(
ctx
.
scrollDomNode
)
{
let
otherTime
=
this
.
_getScrollDomNodeTime
(
ctx
.
scrollDomNode
);
if
(
otherTime
>
time
)
{
// The other is the real scroll dom node
ctx
.
domNode
.
removeChild
(
domNode
);
return
;
}
if
(
ctx
.
scrollDomNode
.
parentNode
)
{
ctx
.
scrollDomNode
.
parentNode
.
removeChild
(
ctx
.
scrollDomNode
);
}
ctx
.
scrollDomNode
=
null
;
}
ctx
.
scrollDomNode
=
domNode
;
ctx
.
scrollDomNodeIsAbove
=
isAbove
;
}
private
_removeLinesBefore
(
ctx
:
IRendererContext
<
T
>
,
removeCount
:
number
):
void
{
for
(
let
i
=
0
;
i
<
removeCount
;
i
++
)
{
let
lineDomNode
=
ctx
.
lines
[
i
].
getDomNode
();
if
(
lineDomNode
)
{
this
.
_removeIfNotScrollDomNode
(
ctx
,
lineDomNode
,
tru
e
);
ctx
.
domNode
.
removeChild
(
lineDomNod
e
);
}
}
ctx
.
lines
.
splice
(
0
,
removeCount
);
...
...
@@ -567,7 +494,7 @@ class ViewLayerRenderer<T extends IVisibleLine> {
for
(
let
i
=
0
;
i
<
removeCount
;
i
++
)
{
let
lineDomNode
=
ctx
.
lines
[
removeIndex
+
i
].
getDomNode
();
if
(
lineDomNode
)
{
this
.
_removeIfNotScrollDomNode
(
ctx
,
lineDomNode
,
fals
e
);
ctx
.
domNode
.
removeChild
(
lineDomNod
e
);
}
}
ctx
.
lines
.
splice
(
removeIndex
,
removeCount
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录