Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
c709c770
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,发现更多精彩内容 >>
提交
c709c770
编写于
4月 20, 2015
作者:
M
Matt Warren
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix recursion problem in SyntaxNormalizer
上级
6cc107cc
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
86 addition
and
64 deletion
+86
-64
src/Compilers/CSharp/Portable/Syntax/SyntaxNormalizer.cs
src/Compilers/CSharp/Portable/Syntax/SyntaxNormalizer.cs
+66
-62
src/Compilers/CSharp/Test/Syntax/Syntax/SyntaxFactoryTests.cs
...Compilers/CSharp/Test/Syntax/Syntax/SyntaxFactoryTests.cs
+1
-1
src/Compilers/CSharp/Test/Syntax/Syntax/SyntaxNormalizerTests.cs
...pilers/CSharp/Test/Syntax/Syntax/SyntaxNormalizerTests.cs
+19
-1
未找到文件。
src/Compilers/CSharp/Portable/Syntax/SyntaxNormalizer.cs
浏览文件 @
c709c770
...
...
@@ -62,7 +62,7 @@ internal static SyntaxTriviaList Normalize(SyntaxTriviaList trivia, string inden
trivia
,
GetDeclarationDepth
((
SyntaxToken
)
trivia
.
ElementAt
(
0
).
Token
),
isTrailing
:
false
,
mustBeIndented
:
false
,
indentAfterLineBreak
:
false
,
mustHaveSeparator
:
false
,
lineBreaksAfter
:
0
);
normalizer
.
Free
();
...
...
@@ -89,42 +89,35 @@ public override SyntaxToken VisitToken(SyntaxToken token)
var
tk
=
token
;
var
depth
=
GetDeclarationDepth
(
token
);
var
needsIndentation
=
_indentNext
||
(
LineBreaksAfter
(
_previousToken
,
token
)
>
0
);
var
lineBreaksAfter
=
LineBreaksAfter
(
token
);
_indentNext
=
false
;
tk
=
tk
.
WithLeadingTrivia
(
RewriteTrivia
(
token
.
LeadingTrivia
,
depth
,
isTrailing
:
false
,
mustBeIndented
:
needsIndentation
,
indentAfterLineBreak
:
NeedsIndentAfterLineBreak
(
token
)
,
mustHaveSeparator
:
false
,
lineBreaksAfter
:
lineBreaksAfter
));
lineBreaksAfter
:
0
));
var
nextToken
=
this
.
GetNextRelevantToken
(
token
);
_afterLineBreak
=
EndsIn
LineBreak
(
token
);
_afterLineBreak
=
Is
LineBreak
(
token
);
_afterIndentation
=
false
;
lineBreaksAfter
=
LineBreaksAfter
(
token
,
nextToken
);
var
lineBreaksAfter
=
LineBreaksAfter
(
token
,
nextToken
);
var
needsSeparatorAfter
=
NeedsSeparator
(
token
,
nextToken
);
tk
=
tk
.
WithTrailingTrivia
(
RewriteTrivia
(
token
.
TrailingTrivia
,
depth
,
isTrailing
:
true
,
mustBeIndented
:
false
,
indentAfterLineBreak
:
false
,
mustHaveSeparator
:
needsSeparatorAfter
,
lineBreaksAfter
:
lineBreaksAfter
));
if
(
lineBreaksAfter
>
0
)
{
_indentNext
=
true
;
}
return
tk
;
}
finally
{
// to help debugging
_previousToken
=
token
;
}
}
...
...
@@ -171,13 +164,18 @@ private SyntaxTrivia GetIndentation(int count)
return
_indentations
[
count
];
}
private
static
int
LineBreaksAfter
(
SyntaxToken
token
)
private
static
bool
NeedsIndentAfterLineBreak
(
SyntaxToken
token
)
{
return
token
.
Kind
()
==
SyntaxKind
.
EndOfDirectiveToken
?
1
:
0
;
return
!
token
.
IsKind
(
SyntaxKind
.
EndOfFileToken
)
;
}
private
int
LineBreaksAfter
(
SyntaxToken
currentToken
,
SyntaxToken
nextToken
)
{
if
(
currentToken
.
IsKind
(
SyntaxKind
.
EndOfDirectiveToken
))
{
return
1
;
}
if
(
nextToken
.
Kind
()
==
SyntaxKind
.
None
)
{
return
0
;
...
...
@@ -207,7 +205,6 @@ private int LineBreaksAfter(SyntaxToken currentToken, SyntaxToken nextToken)
{
return
1
;
}
break
;
case
SyntaxKind
.
SemicolonToken
:
return
LineBreaksAfterSemicolon
(
currentToken
,
nextToken
);
...
...
@@ -254,26 +251,25 @@ private int LineBreaksAfter(SyntaxToken currentToken, SyntaxToken nextToken)
private
static
int
LineBreaksAfterCloseBrace
(
SyntaxToken
nextToken
)
{
if
(
nextToken
.
Kind
()
==
SyntaxKind
.
CloseBraceToken
)
{
return
1
;
}
else
if
(
nextToken
.
Kind
()
==
SyntaxKind
.
CatchKeyword
||
nextToken
.
Kind
()
==
SyntaxKind
.
FinallyKeyword
||
nextToken
.
Kind
()
==
SyntaxKind
.
ElseKeyword
)
{
return
1
;
}
else
if
(
nextToken
.
Kind
()
==
SyntaxKind
.
WhileKeyword
&&
nextToken
.
Parent
.
Kind
()
==
SyntaxKind
.
DoStatement
)
{
return
1
;
}
else
var
kind
=
nextToken
.
Kind
();
switch
(
kind
)
{
return
2
;
case
SyntaxKind
.
EndOfFileToken
:
case
SyntaxKind
.
CloseBraceToken
:
case
SyntaxKind
.
CatchKeyword
:
case
SyntaxKind
.
FinallyKeyword
:
case
SyntaxKind
.
ElseKeyword
:
return
1
;
default
:
if
(
kind
==
SyntaxKind
.
WhileKeyword
&&
nextToken
.
Parent
.
IsKind
(
SyntaxKind
.
DoStatement
))
{
return
1
;
}
else
{
return
2
;
}
}
}
...
...
@@ -462,7 +458,7 @@ private static bool AssignmentTokenNeedsSeparator(SyntaxKind kind)
SyntaxTriviaList
triviaList
,
int
depth
,
bool
isTrailing
,
bool
mustBeIndented
,
bool
indentAfterLineBreak
,
bool
mustHaveSeparator
,
int
lineBreaksAfter
)
{
...
...
@@ -481,7 +477,9 @@ private static bool AssignmentTokenNeedsSeparator(SyntaxKind kind)
var
needsSeparator
=
(
currentTriviaList
.
Count
>
0
&&
NeedsSeparatorBetween
(
currentTriviaList
.
Last
()))
||
(
currentTriviaList
.
Count
==
0
&&
isTrailing
);
var
needsLineBreak
=
NeedsLineBreakBefore
(
trivia
)
||
(
currentTriviaList
.
Count
>
0
&&
NeedsLineBreakBetween
(
currentTriviaList
.
Last
(),
trivia
,
isTrailing
));
var
needsLineBreak
=
NeedsLineBreakBefore
(
trivia
,
isTrailing
)
||
(
currentTriviaList
.
Count
>
0
&&
NeedsLineBreakBetween
(
currentTriviaList
.
Last
(),
trivia
,
isTrailing
));
if
(
needsLineBreak
&&
!
_afterLineBreak
)
{
...
...
@@ -520,7 +518,8 @@ private static bool AssignmentTokenNeedsSeparator(SyntaxKind kind)
currentTriviaList
.
Add
(
trivia
);
}
if
(
NeedsLineBreakAfter
(
trivia
,
isTrailing
))
if
(
NeedsLineBreakAfter
(
trivia
,
isTrailing
)
&&
(
currentTriviaList
.
Count
==
0
||
!
EndsInLineBreak
(
currentTriviaList
.
Last
())))
{
currentTriviaList
.
Add
(
GetCarriageReturnLineFeed
());
_afterLineBreak
=
true
;
...
...
@@ -530,7 +529,8 @@ private static bool AssignmentTokenNeedsSeparator(SyntaxKind kind)
if
(
lineBreaksAfter
>
0
)
{
if
(
currentTriviaList
.
Count
>
0
&&
EndsInLineBreak
(
currentTriviaList
.
Last
()))
if
(
currentTriviaList
.
Count
>
0
&&
EndsInLineBreak
(
currentTriviaList
.
Last
()))
{
lineBreaksAfter
--;
}
...
...
@@ -542,7 +542,7 @@ private static bool AssignmentTokenNeedsSeparator(SyntaxKind kind)
_afterIndentation
=
false
;
}
}
else
if
(
mustBeIndented
)
else
if
(
indentAfterLineBreak
&&
_afterLineBreak
&&
!
_afterIndentation
)
{
currentTriviaList
.
Add
(
this
.
GetIndentation
(
depth
));
_afterIndentation
=
true
;
...
...
@@ -616,43 +616,33 @@ private static bool NeedsSeparatorBetween(SyntaxTrivia trivia)
private
static
bool
NeedsLineBreakBetween
(
SyntaxTrivia
trivia
,
SyntaxTrivia
next
,
bool
isTrailingTrivia
)
{
if
(
EndsInLineBreak
(
trivia
))
{
return
false
;
}
switch
(
next
.
Kind
())
{
case
SyntaxKind
.
SingleLineCommentTrivia
:
case
SyntaxKind
.
MultiLineCommentTrivia
:
case
SyntaxKind
.
DocumentationCommentExteriorTrivia
:
return
!
isTrailingTrivia
;
default
:
return
false
;
}
return
NeedsLineBreakAfter
(
trivia
,
isTrailingTrivia
)
||
NeedsLineBreakBefore
(
next
,
isTrailingTrivia
);
}
private
static
bool
NeedsLineBreakBefore
(
SyntaxTrivia
trivia
)
private
static
bool
NeedsLineBreakBefore
(
SyntaxTrivia
trivia
,
bool
isTrailingTrivia
)
{
switch
(
trivia
.
Kind
())
var
kind
=
trivia
.
Kind
();
switch
(
kind
)
{
case
SyntaxKind
.
DocumentationCommentExteriorTrivia
:
return
true
;
return
!
isTrailingTrivia
;
default
:
return
false
;
return
SyntaxFacts
.
IsPreprocessorDirective
(
kind
)
;
}
}
private
static
bool
NeedsLineBreakAfter
(
SyntaxTrivia
trivia
,
bool
isTrailingTrivia
)
{
switch
(
trivia
.
Kind
())
var
kind
=
trivia
.
Kind
();
switch
(
kind
)
{
case
SyntaxKind
.
SingleLineCommentTrivia
:
return
true
;
case
SyntaxKind
.
MultiLineCommentTrivia
:
return
!
isTrailingTrivia
;
default
:
return
false
;
return
SyntaxFacts
.
IsPreprocessorDirective
(
kind
)
;
}
}
...
...
@@ -671,7 +661,7 @@ private static bool NeedsIndentAfterLineBreak(SyntaxTrivia trivia)
}
}
private
static
bool
EndsIn
LineBreak
(
SyntaxToken
token
)
private
static
bool
Is
LineBreak
(
SyntaxToken
token
)
{
return
token
.
Kind
()
==
SyntaxKind
.
XmlTextLiteralNewLineToken
;
}
...
...
@@ -689,6 +679,20 @@ private static bool EndsInLineBreak(SyntaxTrivia trivia)
return
text
.
Length
>
0
&&
SyntaxFacts
.
IsNewLine
(
text
.
Last
());
}
if
(
trivia
.
HasStructure
)
{
var
node
=
trivia
.
GetStructure
();
var
trailing
=
node
.
GetTrailingTrivia
();
if
(
trailing
.
Count
>
0
)
{
return
EndsInLineBreak
(
trailing
.
Last
());
}
else
{
return
IsLineBreak
(
node
.
GetLastToken
());
}
}
return
false
;
}
...
...
src/Compilers/CSharp/Test/Syntax/Syntax/SyntaxFactoryTests.cs
浏览文件 @
c709c770
...
...
@@ -87,7 +87,7 @@ public void TestConstructPragmaChecksumDirective()
var
t
=
SyntaxFactory
.
PragmaChecksumDirectiveTrivia
(
makeStringLiteral
(
"file"
),
makeStringLiteral
(
"guid"
),
makeStringLiteral
(
"bytes"
),
true
);
Assert
.
Equal
(
SyntaxKind
.
PragmaChecksumDirectiveTrivia
,
t
.
Kind
());
Assert
.
Equal
(
"#pragmachecksum\"file\"\"guid\"\"bytes\""
,
t
.
ToString
());
Assert
.
Equal
(
"#pragma checksum \"file\" \"guid\" \"bytes\"\r\n"
,
t
.
NormalizeWhitespace
().
ToString
());
Assert
.
Equal
(
"#pragma checksum \"file\" \"guid\" \"bytes\"\r\n"
,
t
.
NormalizeWhitespace
().
To
Full
String
());
}
[
Fact
]
...
...
src/Compilers/CSharp/Test/Syntax/Syntax/SyntaxNormalizerTests.cs
浏览文件 @
c709c770
...
...
@@ -308,9 +308,13 @@ private void TestNormalizeToken(string text, string expected)
}
[
Fact
]
[
WorkItem
(
1066
,
"github"
)]
public
void
TestNormalizePreprocessorDirectives
()
{
// directive as node
TestNormalize
(
SyntaxFactory
.
DefineDirectiveTrivia
(
SyntaxFactory
.
Identifier
(
"a"
),
false
),
"#define a\r\n"
);
// directive as trivia
TestNormalizeTrivia
(
" # define a"
,
"#define a\r\n"
);
TestNormalizeTrivia
(
"#if(a||b)"
,
"#if (a || b)\r\n"
);
TestNormalizeTrivia
(
"#if(a&&b)"
,
"#if (a && b)\r\n"
);
...
...
@@ -324,7 +328,21 @@ public void TestNormalizePreprocessorDirectives()
SyntaxFactory
.
EndIfDirectiveTrivia
(
false
))),
"#if a\r\n#endif\r\n"
);
// red factories for structured trivia needs to return SyntaxTrivia, not structured node types?
TestNormalizeTrivia
(
"#endregion foo"
,
"#endregion foo\r\n"
);
TestNormalizeDeclaration
(
@"#pragma warning disable 123
namespace foo {
}
#pragma warning restore 123"
,
@"#pragma warning disable 123
namespace foo
{
}
#pragma warning restore 123
"
);
}
[
Fact
]
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录