Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
6edcd367
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,发现更多精彩内容 >>
提交
6edcd367
编写于
10月 11, 2018
作者:
M
Manish Vasani
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Report AD0001 if an analyzer accidentally provides a null descriptor in its SupportedDiagnostics
Fixes #30453
上级
b1ab1b05
变更
18
隐藏空白更改
内联
并排
Showing
18 changed file
with
112 addition
and
0 deletion
+112
-0
src/Compilers/CSharp/Test/Semantic/Diagnostics/DiagnosticAnalyzerTests.cs
...harp/Test/Semantic/Diagnostics/DiagnosticAnalyzerTests.cs
+16
-0
src/Compilers/Core/Portable/CodeAnalysisResources.Designer.cs
...Compilers/Core/Portable/CodeAnalysisResources.Designer.cs
+9
-0
src/Compilers/Core/Portable/CodeAnalysisResources.resx
src/Compilers/Core/Portable/CodeAnalysisResources.resx
+3
-0
src/Compilers/Core/Portable/DiagnosticAnalyzer/AnalyzerManager.AnalyzerExecutionContext.cs
...osticAnalyzer/AnalyzerManager.AnalyzerExecutionContext.cs
+9
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.cs.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.cs.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.de.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.de.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.es.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.es.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.fr.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.fr.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.it.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.it.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ja.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ja.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ko.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ko.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.pl.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.pl.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.pt-BR.xlf
...mpilers/Core/Portable/xlf/CodeAnalysisResources.pt-BR.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ru.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ru.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.tr.xlf
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.tr.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.zh-Hans.xlf
...ilers/Core/Portable/xlf/CodeAnalysisResources.zh-Hans.xlf
+5
-0
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.zh-Hant.xlf
...ilers/Core/Portable/xlf/CodeAnalysisResources.zh-Hant.xlf
+5
-0
src/Test/Utilities/Portable/Diagnostics/CommonDiagnosticAnalyzers.cs
...ilities/Portable/Diagnostics/CommonDiagnosticAnalyzers.cs
+10
-0
未找到文件。
src/Compilers/CSharp/Test/Semantic/Diagnostics/DiagnosticAnalyzerTests.cs
浏览文件 @
6edcd367
...
...
@@ -889,6 +889,22 @@ public void TestReportingDiagnosticWithInvalidId()
.
WithLocation
(
1
,
1
));
}
[
Fact
,
WorkItem
(
30453
,
"https://github.com/dotnet/roslyn/issues/30453"
)]
public
void
TestAnalyzerWithNullDescriptor
()
{
string
source
=
@""
;
var
analyzers
=
new
DiagnosticAnalyzer
[]
{
new
AnalyzerWithNullDescriptor
()
};
var
analyzerFullName
=
"Microsoft.CodeAnalysis.CommonDiagnosticAnalyzers+AnalyzerWithNullDescriptor"
;
string
message
=
new
ArgumentException
(
string
.
Format
(
CodeAnalysisResources
.
SupportedDiagnosticsHasNullDescriptor
,
analyzerFullName
),
"SupportedDiagnostics"
).
Message
;
CreateCompilationWithMscorlib45
(
source
)
.
VerifyDiagnostics
()
.
VerifyAnalyzerDiagnostics
(
analyzers
,
null
,
null
,
logAnalyzerExceptionAsDiagnostics
:
true
,
expected
:
Diagnostic
(
"AD0001"
)
.
WithArguments
(
analyzerFullName
,
"System.ArgumentException"
,
message
)
.
WithLocation
(
1
,
1
));
}
[
Fact
,
WorkItem
(
25748
,
"https://github.com/dotnet/roslyn/issues/25748"
)]
public
void
TestReportingDiagnosticWithCSharpCompilerId
()
{
...
...
src/Compilers/Core/Portable/CodeAnalysisResources.Designer.cs
浏览文件 @
6edcd367
...
...
@@ -1387,6 +1387,15 @@ internal class CodeAnalysisResources {
}
}
/// <summary>
/// Looks up a localized string similar to Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'..
/// </summary>
internal
static
string
SupportedDiagnosticsHasNullDescriptor
{
get
{
return
ResourceManager
.
GetString
(
"SupportedDiagnosticsHasNullDescriptor"
,
resourceCulture
);
}
}
/// <summary>
/// Looks up a localized string similar to Windows PDB writer doesn't support SourceLink feature: '{0}'.
/// </summary>
...
...
src/Compilers/Core/Portable/CodeAnalysisResources.resx
浏览文件 @
6edcd367
...
...
@@ -449,6 +449,9 @@
<data
name=
"InvalidDiagnosticLocationReported"
xml:space=
"preserve"
>
<value>
Reported diagnostic '{0}' has a source location in file '{1}', which is not part of the compilation being analyzed.
</value>
</data>
<data
name=
"SupportedDiagnosticsHasNullDescriptor"
xml:space=
"preserve"
>
<value>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</value>
</data>
<data
name=
"The_type_0_is_not_understood_by_the_serialization_binder"
xml:space=
"preserve"
>
<value>
The type '{0}' is not understood by the serialization binder.
</value>
</data>
...
...
src/Compilers/Core/Portable/DiagnosticAnalyzer/AnalyzerManager.AnalyzerExecutionContext.cs
浏览文件 @
6edcd367
...
...
@@ -260,6 +260,15 @@ public ImmutableArray<DiagnosticDescriptor> GetOrComputeDescriptors(DiagnosticAn
var
supportedDiagnosticsLocal
=
analyzer
.
SupportedDiagnostics
;
if
(!
supportedDiagnosticsLocal
.
IsDefaultOrEmpty
)
{
foreach
(
var
descriptor
in
supportedDiagnosticsLocal
)
{
if
(
descriptor
==
null
)
{
// Disallow null descriptors.
throw
new
ArgumentException
(
string
.
Format
(
CodeAnalysisResources
.
SupportedDiagnosticsHasNullDescriptor
,
analyzer
.
ToString
()),
nameof
(
DiagnosticAnalyzer
.
SupportedDiagnostics
));
}
}
supportedDiagnostics
=
supportedDiagnosticsLocal
;
}
},
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.cs.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Kopie modulu se nedá použít k vytvoření metadat sestavení.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Nevyřešeno:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.de.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Modulkopie kann nicht zum Erstellen von Assembly-Metadaten verwendet werden.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Nicht aufgelöst:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.es.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
No se puede usar una copia de módulo para crear metadatos de ensamblado.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Sin resolver:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.fr.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Impossible d'utiliser le module de copie pour créer des métadonnées d'assembly.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Non résolu :
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.it.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Non è possibile usare la copia del modulo per creare i metadati di un assembly.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Non risolto:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ja.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
モジュールのコピーは、アセンブリ メタデータの作成には使用できません。
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
未解決:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ko.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
모듈 복사본은 어셈블리 메타데이터를 만드는 데 사용할 수 없습니다.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
확인되지 않음:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.pl.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Nie można użyć kopii modułu do utworzenia metadanych zestawu.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Nierozpoznane:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.pt-BR.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Cópia de módulo não pode ser usada para criar metadados do assembly.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Não resolvido:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.ru.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Копию модуля нельзя использовать для создания метаданных сборки.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Не разрешено:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.tr.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
Derleme meta verileri oluşturmak için modül kopyası kullanılamaz.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
Çözümlenmemiş:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.zh-Hans.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
模块复制不能用于创建程序集元数据。
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
未解析:
</target>
...
...
src/Compilers/Core/Portable/xlf/CodeAnalysisResources.zh-Hant.xlf
浏览文件 @
6edcd367
...
...
@@ -59,6 +59,11 @@
<target
state=
"translated"
>
不可使用模組複本建立組件中繼資料。
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"SupportedDiagnosticsHasNullDescriptor"
>
<source>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</source>
<target
state=
"new"
>
Analyzer '{0}' contains a null descriptor in its 'SupportedDiagnostics'.
</target>
<note
/>
</trans-unit>
<trans-unit
id=
"Unresolved"
>
<source>
Unresolved:
</source>
<target
state=
"translated"
>
未解析:
</target>
...
...
src/Test/Utilities/Portable/Diagnostics/CommonDiagnosticAnalyzers.cs
浏览文件 @
6edcd367
...
...
@@ -463,6 +463,16 @@ public override void Initialize(AnalysisContext context)
}
}
[
DiagnosticAnalyzer
(
LanguageNames
.
CSharp
,
LanguageNames
.
VisualBasic
)]
public
sealed
class
AnalyzerWithNullDescriptor
:
DiagnosticAnalyzer
{
public
override
ImmutableArray
<
DiagnosticDescriptor
>
SupportedDiagnostics
=>
ImmutableArray
.
Create
((
DiagnosticDescriptor
)
null
);
public
override
void
Initialize
(
AnalysisContext
context
)
{
context
.
RegisterCompilationAction
(
_
=>
{
});
}
}
[
DiagnosticAnalyzer
(
LanguageNames
.
CSharp
,
LanguageNames
.
VisualBasic
)]
public
sealed
class
AnalyzerWithCSharpCompilerDiagnosticId
:
DiagnosticAnalyzer
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录