Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
883f9e4b
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,发现更多精彩内容 >>
提交
883f9e4b
编写于
5月 04, 2017
作者:
C
CyrusNajmabadi
提交者:
GitHub
5月 04, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #19246 from CyrusNajmabadi/tupleTypeInference
Add type inference support for tuples.
上级
a2de1326
1c8f1af7
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
168 addition
and
4 deletion
+168
-4
src/EditorFeatures/CSharpTest/Diagnostics/GenerateMethod/GenerateMethodTests.cs
...arpTest/Diagnostics/GenerateMethod/GenerateMethodTests.cs
+63
-1
src/EditorFeatures/VisualBasicTest/Diagnostics/GenerateMethod/GenerateMethodTests.vb
...sicTest/Diagnostics/GenerateMethod/GenerateMethodTests.vb
+56
-0
src/Workspaces/CSharp/Portable/LanguageServices/CSharpTypeInferenceService.TypeInferrer.cs
...nguageServices/CSharpTypeInferenceService.TypeInferrer.cs
+17
-0
src/Workspaces/VisualBasic/Portable/LanguageServices/VisualBasicTypeInferenceService.TypeInferrer.vb
...eServices/VisualBasicTypeInferenceService.TypeInferrer.vb
+32
-3
未找到文件。
src/EditorFeatures/CSharpTest/Diagnostics/GenerateMethod/GenerateMethodTests.cs
浏览文件 @
883f9e4b
...
...
@@ -7262,7 +7262,7 @@ private object Method()
parseOptions
:
TestOptions
.
Regular
);
}
[
Fact
/*(Skip = "https://github.com/dotnet/roslyn/issues/15508")*/
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)]
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)]
[
WorkItem
(
14136
,
"https://github.com/dotnet/roslyn/issues/14136"
)]
public
async
Task
TestDeconstruction4
()
{
...
...
@@ -7379,5 +7379,67 @@ public void Foo()
}
}"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)]
[
WorkItem
(
18969
,
"https://github.com/dotnet/roslyn/issues/18969"
)]
public
async
Task
TestTupleElement1
()
{
await
TestAsync
(
@"using System;
class C
{
public void M1()
{
(int x, string y) t = ([|Method|](), null);
}
}"
,
@"using System;
class C
{
public void M1()
{
(int x, string y) t = (Method(), null);
}
private int Method()
{
throw new NotImplementedException();
}
}"
,
parseOptions
:
TestOptions
.
Regular
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)]
[
WorkItem
(
18969
,
"https://github.com/dotnet/roslyn/issues/18969"
)]
public
async
Task
TestTupleElement2
()
{
await
TestAsync
(
@"using System;
class C
{
public void M1()
{
(int x, string y) t = (0, [|Method|]());
}
}"
,
@"using System;
class C
{
public void M1()
{
(int x, string y) t = (0, Method());
}
private string Method()
{
throw new NotImplementedException();
}
}"
,
parseOptions
:
TestOptions
.
Regular
);
}
}
}
\ No newline at end of file
src/EditorFeatures/VisualBasicTest/Diagnostics/GenerateMethod/GenerateMethodTests.vb
浏览文件 @
883f9e4b
...
...
@@ -3926,6 +3926,62 @@ Class Program
End Class"
)
End
Function
<
WorkItem
(
18969
,
"https://github.com/dotnet/roslyn/issues/18969"
)
>
<
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)
>
Public
Async
Function
TupleElement1
()
As
Task
Await
TestInRegularAndScriptAsync
(
"
Imports System
Public Class Q
Sub Main()
Dim x As (Integer, String) = ([|Foo|](),
""""
)
End Sub
End Class
"
,
"
Imports System
Public Class Q
Sub Main()
Dim x As (Integer, String) = (Foo(),
""""
)
End Sub
Private Function Foo() As Integer
Throw New NotImplementedException()
End Function
End Class
"
)
End
Function
<
WorkItem
(
18969
,
"https://github.com/dotnet/roslyn/issues/18969"
)
>
<
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)
>
Public
Async
Function
TupleElement2
()
As
Task
Await
TestInRegularAndScriptAsync
(
"
Imports System
Public Class Q
Sub Main()
Dim x As (Integer, String) = (0, [|Foo|]())
End Sub
End Class
"
,
"
Imports System
Public Class Q
Sub Main()
Dim x As (Integer, String) = (0, Foo())
End Sub
Private Function Foo() As String
Throw New NotImplementedException()
End Function
End Class
"
)
End
Function
<
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsGenerateMethod
)
>
Public
Async
Function
MethodWithTupleWithNames
()
As
Task
Await
TestInRegularAndScriptAsync
(
...
...
src/Workspaces/CSharp/Portable/LanguageServices/CSharpTypeInferenceService.TypeInferrer.cs
浏览文件 @
883f9e4b
...
...
@@ -310,6 +310,11 @@ private IEnumerable<TypeInferenceInfo> InferTypeInAnonymousObjectCreation(Anonym
return
InferTypeInElementAccessExpression
(
elementAccess
,
index
,
argument
);
}
if
(
argument
.
IsParentKind
(
SyntaxKind
.
TupleExpression
))
{
return
InferTypeInTupleExpression
((
TupleExpressionSyntax
)
argument
.
Parent
,
argument
);
}
}
if
(
argument
.
Parent
.
IsParentKind
(
SyntaxKind
.
ImplicitElementAccess
)
&&
...
...
@@ -331,6 +336,18 @@ private IEnumerable<TypeInferenceInfo> InferTypeInAnonymousObjectCreation(Anonym
return
SpecializedCollections
.
EmptyEnumerable
<
TypeInferenceInfo
>();
}
private
IEnumerable
<
TypeInferenceInfo
>
InferTypeInTupleExpression
(
TupleExpressionSyntax
tupleExpression
,
ArgumentSyntax
argument
)
{
var
index
=
tupleExpression
.
Arguments
.
IndexOf
(
argument
);
var
parentTypes
=
InferTypes
(
tupleExpression
);
return
parentTypes
.
Select
(
typeInfo
=>
typeInfo
.
InferredType
)
.
OfType
<
INamedTypeSymbol
>()
.
Where
(
namedType
=>
namedType
.
IsTupleType
&&
index
<
namedType
.
TupleElements
.
Length
)
.
Select
(
tupleType
=>
new
TypeInferenceInfo
(
tupleType
.
TupleElements
[
index
].
Type
));
}
private
IEnumerable
<
TypeInferenceInfo
>
InferTypeInAttributeArgument
(
AttributeArgumentSyntax
argument
,
SyntaxToken
?
previousToken
=
null
,
ArgumentSyntax
argumentOpt
=
null
)
{
if
(
previousToken
.
HasValue
)
...
...
src/Workspaces/VisualBasic/Portable/LanguageServices/VisualBasicTypeInferenceService.TypeInferrer.vb
浏览文件 @
883f9e4b
...
...
@@ -53,7 +53,7 @@ Namespace Microsoft.CodeAnalysis.VisualBasic
Return
parent
.
TypeSwitch
(
Function
(
addRemoveHandlerStatement
As
AddRemoveHandlerStatementSyntax
)
InferTypeInAddRemoveHandlerStatementSyntax
(
addRemoveHandlerStatement
,
expression
),
Function
(
argument
As
ArgumentSyntax
)
InferTypeInArgument
List
(
TryCast
(
argument
.
Parent
,
ArgumentListSyntax
),
argument
),
Function
(
argument
As
ArgumentSyntax
)
InferTypeInArgument
(
argument
),
Function
(
arrayCreationExpression
As
ArrayCreationExpressionSyntax
)
InferTypeInArrayCreationExpression
(
arrayCreationExpression
),
Function
(
arrayRank
As
ArrayRankSpecifierSyntax
)
InferTypeInArrayRankSpecifier
(),
Function
(
arrayType
As
ArrayTypeSyntax
)
InferTypeInArrayType
(
arrayType
),
...
...
@@ -124,7 +124,7 @@ Namespace Microsoft.CodeAnalysis.VisualBasic
Dim
parent
=
token
.
Parent
Return
parent
.
TypeSwitch
(
Function
(
argument
As
ArgumentSyntax
)
InferTypeInArgument
List
(
TryCast
(
argument
.
Parent
,
ArgumentListSyntax
)
,
previousToken
:
=
token
),
Function
(
argument
As
ArgumentSyntax
)
InferTypeInArgument
(
argument
,
previousToken
:
=
token
),
Function
(
argumentList
As
ArgumentListSyntax
)
InferTypeInArgumentList
(
argumentList
,
previousToken
:
=
token
),
Function
(
arrayCreationExpression
As
ArrayCreationExpressionSyntax
)
InferTypeInArrayCreationExpression
(
arrayCreationExpression
),
Function
(
arrayRank
As
ArrayRankSpecifierSyntax
)
InferTypeInArrayRankSpecifier
(),
...
...
@@ -171,13 +171,42 @@ Namespace Microsoft.CodeAnalysis.VisualBasic
SpecializedCollections
.
EmptyEnumerable
(
Of
TypeInferenceInfo
)())
End
Function
Private
Function
InferTypeInArgument
(
argument
As
ArgumentSyntax
,
Optional
previousToken
As
SyntaxToken
=
Nothing
)
As
IEnumerable
(
Of
TypeInferenceInfo
)
If
TypeOf
argument
.
Parent
Is
ArgumentListSyntax
Then
Return
InferTypeInArgumentList
(
DirectCast
(
argument
.
Parent
,
ArgumentListSyntax
),
argument
,
previousToken
)
End
If
If
TypeOf
argument
.
Parent
Is
TupleExpressionSyntax
Then
Return
InferTypeInTupleExpression
(
DirectCast
(
argument
.
Parent
,
TupleExpressionSyntax
),
DirectCast
(
argument
,
SimpleArgumentSyntax
))
End
If
Return
SpecializedCollections
.
EmptyEnumerable
(
Of
TypeInferenceInfo
)
End
Function
Private
Function
InferTypeInTupleExpression
(
tupleExpression
As
TupleExpressionSyntax
,
argument
As
SimpleArgumentSyntax
)
As
IEnumerable
(
Of
TypeInferenceInfo
)
Dim
index
=
tupleExpression
.
Arguments
.
IndexOf
(
argument
)
Dim
parentTypes
=
InferTypes
(
tupleExpression
)
Return
parentTypes
.
Select
(
Function
(
TypeInfo
)
TypeInfo
.
InferredType
).
OfType
(
Of
INamedTypeSymbol
)().
Where
(
Function
(
namedType
)
namedType
.
IsTupleType
AndAlso
index
<
namedType
.
TupleElements
.
Length
).
Select
(
Function
(
tupleType
)
New
TypeInferenceInfo
(
tupleType
.
TupleElements
(
index
).
Type
))
End
Function
Private
Function
InferTypeInArgumentList
(
argumentList
As
ArgumentListSyntax
,
Optional
argumentOpt
As
ArgumentSyntax
=
Nothing
,
Optional
previousToken
As
SyntaxToken
=
Nothing
)
As
IEnumerable
(
Of
TypeInferenceInfo
)
Optional
argumentOpt
As
ArgumentSyntax
=
Nothing
,
Optional
previousToken
As
SyntaxToken
=
Nothing
)
As
IEnumerable
(
Of
TypeInferenceInfo
)
If
argumentList
Is
Nothing
Then
Return
SpecializedCollections
.
EmptyEnumerable
(
Of
TypeInferenceInfo
)()
End
If
If
argumentList
.
Parent
IsNot
Nothing
Then
If
argumentList
.
IsParentKind
(
SyntaxKind
.
ArrayCreationExpression
)
Then
Return
SpecializedCollections
.
SingletonEnumerable
(
New
TypeInferenceInfo
(
Compilation
.
GetSpecialType
(
SpecialType
.
System_Int32
)))
ElseIf
argumentList
.
IsParentKind
(
SyntaxKind
.
InvocationExpression
)
Then
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录