Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
41414146
R
roslyn
项目概览
lwm1986
/
roslyn
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
roslyn
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
41414146
编写于
6月 23, 2017
作者:
S
Sam Harwell
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Remove unnecessary gen-0 allocations from the RecordReplaceOldWithNew fast path
上级
5cf22e55
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
51 addition
and
7 deletion
+51
-7
src/Compilers/Core/Portable/Syntax/SyntaxDiffer.cs
src/Compilers/Core/Portable/Syntax/SyntaxDiffer.cs
+51
-7
未找到文件。
src/Compilers/Core/Portable/Syntax/SyntaxDiffer.cs
浏览文件 @
41414146
...
...
@@ -529,13 +529,26 @@ private void RecordDeleteOld(int oldNodeCount)
private
void
RecordReplaceOldWithNew
(
int
oldNodeCount
,
int
newNodeCount
)
{
var
oldSpan
=
GetSpan
(
_oldNodes
,
0
,
oldNodeCount
);
var
removedNodes
=
CopyFirst
(
_oldNodes
,
oldNodeCount
);
RemoveFirst
(
_oldNodes
,
oldNodeCount
);
var
newSpan
=
GetSpan
(
_newNodes
,
0
,
newNodeCount
);
var
insertedNodes
=
CopyFirst
(
_newNodes
,
newNodeCount
);
RemoveFirst
(
_newNodes
,
newNodeCount
);
RecordChange
(
new
ChangeRecord
(
new
TextChangeRange
(
oldSpan
,
newSpan
.
Length
),
removedNodes
,
insertedNodes
));
if
(
oldNodeCount
==
1
&&
newNodeCount
==
1
)
{
var
removedNode
=
_oldNodes
.
Pop
();
var
oldSpan
=
removedNode
.
FullSpan
;
var
insertedNode
=
_newNodes
.
Pop
();
var
newSpan
=
insertedNode
.
FullSpan
;
RecordChange
(
new
TextChangeRange
(
oldSpan
,
newSpan
.
Length
),
removedNode
,
insertedNode
);
}
else
{
var
oldSpan
=
GetSpan
(
_oldNodes
,
0
,
oldNodeCount
);
var
removedNodes
=
CopyFirst
(
_oldNodes
,
oldNodeCount
);
RemoveFirst
(
_oldNodes
,
oldNodeCount
);
var
newSpan
=
GetSpan
(
_newNodes
,
0
,
newNodeCount
);
var
insertedNodes
=
CopyFirst
(
_newNodes
,
newNodeCount
);
RemoveFirst
(
_newNodes
,
newNodeCount
);
RecordChange
(
new
ChangeRecord
(
new
TextChangeRange
(
oldSpan
,
newSpan
.
Length
),
removedNodes
,
insertedNodes
));
}
}
private
void
RecordInsertNew
(
int
newNodeCount
)
...
...
@@ -568,6 +581,37 @@ private void RecordChange(ChangeRecord change)
_changes
.
Add
(
change
);
}
private
void
RecordChange
(
TextChangeRange
textChangeRange
,
SyntaxNodeOrToken
removedNode
,
SyntaxNodeOrToken
insertedNode
)
{
if
(
_changes
.
Count
>
0
)
{
var
last
=
_changes
[
_changes
.
Count
-
1
];
if
(
last
.
Range
.
Span
.
End
==
textChangeRange
.
Span
.
Start
)
{
// merge changes...
last
.
OldNodes
?.
Enqueue
(
removedNode
);
last
.
NewNodes
?.
Enqueue
(
insertedNode
);
_changes
[
_changes
.
Count
-
1
]
=
new
ChangeRecord
(
new
TextChangeRange
(
new
TextSpan
(
last
.
Range
.
Span
.
Start
,
last
.
Range
.
Span
.
Length
+
textChangeRange
.
Span
.
Length
),
last
.
Range
.
NewLength
+
textChangeRange
.
NewLength
),
last
.
OldNodes
??
CreateQueue
(
removedNode
),
last
.
NewNodes
??
CreateQueue
(
insertedNode
));
return
;
}
Debug
.
Assert
(
textChangeRange
.
Span
.
Start
>=
last
.
Range
.
Span
.
End
);
}
_changes
.
Add
(
new
ChangeRecord
(
textChangeRange
,
CreateQueue
(
removedNode
),
CreateQueue
(
insertedNode
)));
// Local Functions
Queue
<
SyntaxNodeOrToken
>
CreateQueue
(
SyntaxNodeOrToken
nodeOrToken
)
{
var
queue
=
new
Queue
<
SyntaxNodeOrToken
>();
queue
.
Enqueue
(
nodeOrToken
);
return
queue
;
}
}
private
static
TextSpan
GetSpan
(
Stack
<
SyntaxNodeOrToken
>
stack
,
int
first
,
int
length
)
{
int
start
=
-
1
,
end
=
-
1
,
i
=
0
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录