-
Notifications
You must be signed in to change notification settings - Fork 46
/
.editorconfig
506 lines (459 loc) · 32 KB
/
.editorconfig
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
###############################
# Core EditorConfig Options #
###############################
root = true
# All files
[*]
charset = utf-8
trim_trailing_whitespace = true
# MSBuild
[*.{csproj,proj,projitems,shproj,fsproj,targets,props}]
indent_style = space
indent_size = 2
# XML config files
[*.{xml,axml,xaml,config,nuspec,resx}]
indent_style = space
indent_size = 2
# RESX files
[*.resx]
trim_trailing_whitespace = false
# JSON files
[*.json]
indent_style = space
indent_size = 2
# F# files
[*.{fs, fsx, fsi}]
indent_style = space
indent_size = 4
# Code files
[*.{cs,csx,java,vb,vbx}]
insert_final_newline = true
indent_style = tab
tab_width = 8
indent_size = 8
max_line_length = 180
# CMake files
[CMakeLists.txt]
indent_style = space
indent_size = 2
insert_final_newline = true
###############################
# .NET Coding Conventions #
###############################
[*.{cs,vb}]
# Organize usings
dotnet_sort_system_directives_first = true
dotnet_separate_import_directive_groups = false
# Avoid "this." and "Me." if not necessary
dotnet_style_qualification_for_field = false:suggestion
dotnet_style_qualification_for_property = false:suggestion
dotnet_style_qualification_for_method = false:suggestion
dotnet_style_qualification_for_event = false:suggestion
# Use language keywords instead of framework type names for type references
dotnet_style_predefined_type_for_locals_parameters_members = true:suggestion
dotnet_style_predefined_type_for_member_access = true:suggestion
# Suggest more modern language features when available
dotnet_style_object_initializer = true:suggestion
dotnet_style_collection_initializer = true:suggestion
dotnet_style_coalesce_expression = true:suggestion
dotnet_style_null_propagation = true:suggestion
dotnet_style_explicit_tuple_names = true:suggestion
# Parentheses preferences
dotnet_style_parentheses_in_arithmetic_binary_operators = always_for_clarity:silent
dotnet_style_parentheses_in_relational_binary_operators = always_for_clarity:silent
dotnet_style_parentheses_in_other_binary_operators = always_for_clarity:silent
dotnet_style_parentheses_in_other_operators = never_if_unnecessary:silent
# Avoid redundant accessibility modifiers when they're default
dotnet_style_require_accessibility_modifiers = omit_if_default:suggestion
dotnet_style_readonly_field = true:suggestion
# Expression-level preferences
dotnet_style_prefer_is_null_check_over_reference_equality_method = true:suggestion
dotnet_style_prefer_inferred_tuple_names = true:suggestion
dotnet_style_prefer_inferred_anonymous_type_member_names = true:suggestion
dotnet_style_prefer_auto_properties = true:silent
dotnet_style_prefer_conditional_expression_over_assignment = true:silent
dotnet_style_prefer_conditional_expression_over_return = true:silent
###############################
# Naming Conventions #
###############################
# Style Definitions
dotnet_naming_style.pascal_case_style.capitalization = pascal_case
dotnet_naming_style.underline_separator.word_separator = _
dotnet_naming_style.underline_separator.capitalization = all_lower
# Symbol Definitions
dotnet_naming_symbols.parameters.applicable_kinds = parameter
dotnet_naming_symbols.parameters.applicable_accessibilities = *
dotnet_naming_symbols.fields.applicable_kinds = field
dotnet_naming_symbols.constant_fields.applicable_kinds = field
dotnet_naming_symbols.constant_fields.applicable_accessibilities = *
dotnet_naming_symbols.constant_fields.required_modifiers = const
# Use CamelCase for parameters
dotnet_naming_rule.method_parameters_should_be_camel_case.severity = suggestion
dotnet_naming_rule.method_parameters_should_be_camel_case.symbols = parameters
dotnet_naming_rule.method_parameters_should_be_camel_case.style = camel_case
# Use PascalCase for constant fields
dotnet_naming_rule.constant_fields_should_be_pascal_case.severity = suggestion
dotnet_naming_rule.constant_fields_should_be_pascal_case.symbols = constant_fields
dotnet_naming_rule.constant_fields_should_be_pascal_case.style = pascal_case_style
# Use underline separator for instance fields
dotnet_naming_rule.fields_should_be_underline_separator.severity = suggestion
dotnet_naming_rule.fields_should_be_underline_separator.symbols = fields
dotnet_naming_rule.fields_should_be_underline_separator.style = underline_separator
###############################
# C# Code Style Rules #
###############################
[*.cs]
# var preferences
csharp_style_var_for_built_in_types = true:silent
csharp_style_var_when_type_is_apparent = true:silent
csharp_style_var_elsewhere = true:silent
# Expression-bodied members
csharp_style_expression_bodied_methods = false:silent
csharp_style_expression_bodied_constructors = false:silent
csharp_style_expression_bodied_operators = false:silent
csharp_style_expression_bodied_properties = true:silent
csharp_style_expression_bodied_indexers = true:silent
csharp_style_expression_bodied_accessors = true:silent
# Pattern-matching preferences
csharp_style_pattern_matching_over_is_with_cast_check = true:suggestion
csharp_style_pattern_matching_over_as_with_null_check = true:suggestion
# Null-checking preferences
csharp_style_throw_expression = true:suggestion
csharp_style_conditional_delegate_call = true:suggestion
# Modifier preferences
csharp_preferred_modifier_order = public,private,protected,internal,static,extern,new,virtual,abstract,sealed,override,readonly,unsafe,volatile,async:suggestion
# Expression-level preferences
csharp_prefer_braces = true:silent
csharp_style_deconstructed_variable_declaration = true:suggestion
csharp_prefer_simple_default_expression = true:suggestion
csharp_style_pattern_local_over_anonymous_function = true:suggestion
csharp_style_inlined_variable_declaration = true:suggestion
###############################
# C# Formatting Rules #
###############################
# Newline settings
csharp_new_line_before_open_brace = methods,types
csharp_new_line_before_else = false
csharp_new_line_before_catch = false
csharp_new_line_before_finally = false
csharp_new_line_before_members_in_object_initializers = true
csharp_new_line_before_members_in_anonymous_types = true
# Indentation preferences
csharp_indent_switch_labels = false
csharp_indent_case_contents = true
csharp_indent_switch_labels = true
# Space preferences
csharp_space_after_cast = true
csharp_space_after_keywords_in_control_flow_statements = true
csharp_space_between_method_call_parameter_list_parentheses = false
csharp_space_between_method_declaration_parameter_list_parentheses = false
csharp_space_between_parentheses = false
csharp_space_before_colon_in_inheritance_clause = true
csharp_space_after_colon_in_inheritance_clause = true
csharp_space_around_binary_operators = before_and_after
csharp_space_between_method_declaration_empty_parameter_list_parentheses = false
csharp_space_between_method_call_name_and_opening_parenthesis = true
csharp_space_between_method_call_empty_parameter_list_parentheses = false
csharp_space_between_method_declaration_name_and_open_parenthesis = true
csharp_space_after_keywords_in_control_flow_statements = true
csharp_space_before_open_square_brackets = true
# Wrapping preferences
csharp_preserve_single_line_statements = true
csharp_preserve_single_line_blocks = true
##################################
# Visual Basic Code Style Rules #
##################################
[*.vb]
# Modifier preferences
visual_basic_preferred_modifier_order = Partial,Default,Private,Protected,Public,Friend,NotOverridable,Overridable,MustOverride,Overloads,Overrides,MustInherit,NotInheritable,Static,Shared,Shadows,ReadOnly,WriteOnly,Dim,Const,WithEvents,Widening,Narrowing,Custom,Async:suggestion
##################################
# DevDiv Recommended Analyzers #
##################################
# Code files
[*.{cs,vb}]
dotnet_diagnostic.CA2153.severity = error # Do Not Catch Corrupted State Exceptions
dotnet_diagnostic.CA2301.severity = error # Do not call BinaryFormatter.Deserialize without first setting BinaryFormatter.Binder
dotnet_diagnostic.CA2302.severity = error # Ensure BinaryFormatter.Binder is set before calling BinaryFormatter.Deserialize
dotnet_diagnostic.CA2305.severity = error # Do not use insecure deserializer LosFormatter
dotnet_diagnostic.CA2311.severity = error # Do not deserialize without first setting NetDataContractSerializer.Binder
dotnet_diagnostic.CA2312.severity = error # Ensure NetDataContractSerializer.Binder is set before deserializing
dotnet_diagnostic.CA2315.severity = error # Do not use insecure deserializer ObjectStateFormatter
dotnet_diagnostic.CA2321.severity = error # Do not deserialize with JavaScriptSerializer using a SimpleTypeResolver
dotnet_diagnostic.CA2327.severity = error # Do not use insecure JsonSerializerSettings
dotnet_diagnostic.CA2328.severity = error # Ensure that JsonSerializerSettings are secure
dotnet_diagnostic.CA2329.severity = error # Do not deserialize with JsonSerializer using an insecure configuration
dotnet_diagnostic.CA2330.severity = error # Ensure that JsonSerializer has a secure configuration when deserializing
dotnet_diagnostic.CA3061.severity = error # Do Not Add Schema By URL
dotnet_diagnostic.CA3075.severity = error # Insecure DTD processing in XML
dotnet_diagnostic.CA3076.severity = error # Insecure XSLT script processing.
dotnet_diagnostic.CA3077.severity = error # Insecure Processing in API Design, XmlDocument and XmlTextReader
dotnet_diagnostic.CA3147.severity = error # Mark Verb Handlers With Validate Antiforgery Token
dotnet_diagnostic.CA5350.severity = error # Do Not Use Weak Cryptographic Algorithms
dotnet_diagnostic.CA5351.severity = error # Do Not Use Broken Cryptographic Algorithms
dotnet_diagnostic.CA5358.severity = error # Review cipher mode usage with cryptography experts
dotnet_diagnostic.CA5361.severity = error # Do Not Disable SChannel Use of Strong Crypto
dotnet_diagnostic.CA5364.severity = error # Do Not Use Deprecated Security Protocols
dotnet_diagnostic.CA5378.severity = error # Do not disable ServicePointManagerSecurityProtocols
dotnet_diagnostic.CA5397.severity = error # Do not use deprecated SslProtocols values
dotnet_diagnostic.IA5350.severity = error # Do Not Use Weak Cryptographic Algorithms
dotnet_diagnostic.IA5351.severity = error # Do Not Use Broken Cryptographic Algorithms
dotnet_diagnostic.IA5352.severity = error # Do Not Misuse Cryptographic APIs
dotnet_diagnostic.CA2322.severity = suggestion # Ensure JavaScriptSerializer is not initialized with SimpleTypeResolver before deserializing
dotnet_diagnostic.CA2350.severity = suggestion # Do not use DataTable.ReadXml() with untrusted data
dotnet_diagnostic.CA2351.severity = suggestion # Do not use DataSet.ReadXml() with untrusted data
dotnet_diagnostic.CA2352.severity = suggestion # Unsafe DataSet or DataTable in serializable type can be vulnerable to remote code execution attacks
dotnet_diagnostic.CA2353.severity = suggestion # Unsafe DataSet or DataTable in serializable type
dotnet_diagnostic.CA2354.severity = suggestion # Unsafe DataSet or DataTable in deserialized object graph can be vulnerable to remote code execution attacks
dotnet_diagnostic.CA2355.severity = suggestion # Unsafe DataSet or DataTable type found in deserializable object graph
dotnet_diagnostic.CA2356.severity = suggestion # Unsafe DataSet or DataTable type in web deserializable object graph
dotnet_diagnostic.CA2361.severity = suggestion # Ensure autogenerated class containing DataSet.ReadXml() is not used with untrusted data
dotnet_diagnostic.CA2362.severity = suggestion # Unsafe DataSet or DataTable in autogenerated serializable type can be vulnerable to remote code execution attacks
dotnet_diagnostic.CA3001.severity = suggestion # Review code for SQL injection vulnerabilities
dotnet_diagnostic.CA3002.severity = suggestion # Review code for XSS vulnerabilities
dotnet_diagnostic.CA3003.severity = suggestion # Review code for file path injection vulnerabilities
dotnet_diagnostic.CA3004.severity = suggestion # Review code for information disclosure vulnerabilities
dotnet_diagnostic.CA3005.severity = suggestion # Review code for LDAP injection vulnerabilities
dotnet_diagnostic.CA3006.severity = suggestion # Review code for process command injection vulnerabilities
dotnet_diagnostic.CA3007.severity = suggestion # Review code for open redirect vulnerabilities
dotnet_diagnostic.CA3008.severity = suggestion # Review code for XPath injection vulnerabilities
dotnet_diagnostic.CA3009.severity = suggestion # Review code for XML injection vulnerabilities
dotnet_diagnostic.CA3010.severity = suggestion # Review code for XAML injection vulnerabilities
dotnet_diagnostic.CA3011.severity = suggestion # Review code for DLL injection vulnerabilities
dotnet_diagnostic.CA3012.severity = suggestion # Review code for regex injection vulnerabilities
dotnet_diagnostic.CA5359.severity = suggestion # Do Not Disable Certificate Validation
dotnet_diagnostic.CA5380.severity = suggestion # Do Not Add Certificates To Root Store
dotnet_diagnostic.CA5381.severity = suggestion # Ensure Certificates Are Not Added To Root Store
dotnet_diagnostic.CA5395.severity = suggestion # Miss HttpVerb attribute for action methods
dotnet_diagnostic.CA5396.severity = suggestion # Set HttpOnly to true for HttpCookie
dotnet_diagnostic.CA5398.severity = suggestion # Avoid hardcoded SslProtocols values
dotnet_diagnostic.CA5386.severity = suggestion # Avoid hardcoding SecurityProtocolType value
dotnet_diagnostic.CA5391.severity = suggestion # Use antiforgery tokens in ASP.NET Core MVC controllers
dotnet_diagnostic.IA6450.severity = suggestion # Custom web token handler was found
dotnet_diagnostic.IA6451.severity = suggestion # Implement required validations for app asserted actor token
# Adding the FxCopAnalyzers NuGet package automatically starts analyzing code at the default
# severity levels for each rule. We're not ready for that yet, so disable all other rules.
dotnet_diagnostic.CA2310.severity = none # Do not use insecure deserializer NetDataContractSerializer
dotnet_diagnostic.Async001.severity = none
dotnet_diagnostic.Async002.severity = none
dotnet_diagnostic.Async003.severity = none
dotnet_diagnostic.Async004.severity = none
dotnet_diagnostic.Async005.severity = none
dotnet_diagnostic.Async006.severity = none
dotnet_diagnostic.CA1000.severity = none # Do not declare static members on generic types
dotnet_diagnostic.CA1001.severity = none # Types that own disposable fields should be disposable
dotnet_diagnostic.CA1002.severity = none # Do not expose generic lists
dotnet_diagnostic.CA1003.severity = none # Use generic event handler instances
dotnet_diagnostic.CA1005.severity = none # Avoid excessive parameters on generic types
dotnet_diagnostic.CA1008.severity = none # Enums should have zero value
dotnet_diagnostic.CA1010.severity = none # Generic interface should also be implemented
dotnet_diagnostic.CA1012.severity = none # Abstract types should not have public constructors
dotnet_diagnostic.CA1014.severity = none # Mark assemblies with CLSCompliant
dotnet_diagnostic.CA1016.severity = none # Mark assemblies with assembly version
dotnet_diagnostic.CA1017.severity = none # Mark assemblies with ComVisible
dotnet_diagnostic.CA1018.severity = none # Mark attributes with AttributeUsageAttribute
dotnet_diagnostic.CA1019.severity = none # Define accessors for attribute arguments
dotnet_diagnostic.CA1021.severity = none # Avoid out parameters
dotnet_diagnostic.CA1024.severity = none # Use properties where appropriate
dotnet_diagnostic.CA1027.severity = none # Mark enums with FlagsAttribute
dotnet_diagnostic.CA1028.severity = none # Enum Storage should be Int32
dotnet_diagnostic.CA1030.severity = none # Use events where appropriate
dotnet_diagnostic.CA1031.severity = none # Do not catch general exception types
dotnet_diagnostic.CA1032.severity = none # Implement standard exception constructors
dotnet_diagnostic.CA1033.severity = none # Interface methods should be callable by child types
dotnet_diagnostic.CA1034.severity = none # Nested types should not be visible
dotnet_diagnostic.CA1036.severity = none # Override methods on comparable types
dotnet_diagnostic.CA1040.severity = none # Avoid empty interfaces
dotnet_diagnostic.CA1041.severity = none # Provide ObsoleteAttribute message
dotnet_diagnostic.CA1043.severity = none # Use Integral Or String Argument For Indexers
dotnet_diagnostic.CA1044.severity = none # Properties should not be write only
dotnet_diagnostic.CA1045.severity = none # Do not pass types by reference
dotnet_diagnostic.CA1046.severity = none # Do not overload equality operator on reference types
dotnet_diagnostic.CA1047.severity = none # Do not declare protected member in sealed type
dotnet_diagnostic.CA1050.severity = none # Declare types in namespaces
dotnet_diagnostic.CA1051.severity = none # Do not declare visible instance fields
dotnet_diagnostic.CA1052.severity = none # Static holder types should be Static or NotInheritable
dotnet_diagnostic.CA1054.severity = none # URI-like parameters should not be strings
dotnet_diagnostic.CA1055.severity = none # URI-like return values should not be strings
dotnet_diagnostic.CA1056.severity = none # URI-like properties should not be strings
dotnet_diagnostic.CA1058.severity = none # Types should not extend certain base types
dotnet_diagnostic.CA1060.severity = none # Move pinvokes to native methods class
dotnet_diagnostic.CA1061.severity = none # Do not hide base class methods
dotnet_diagnostic.CA1062.severity = none # Validate arguments of public methods
dotnet_diagnostic.CA1063.severity = none # Implement IDisposable Correctly
dotnet_diagnostic.CA1064.severity = none # Exceptions should be public
dotnet_diagnostic.CA1065.severity = none # Do not raise exceptions in unexpected locations
dotnet_diagnostic.CA1066.severity = none # Implement IEquatable when overriding Object.Equals
dotnet_diagnostic.CA1067.severity = none # Override Object.Equals(object) when implementing IEquatable<T>
dotnet_diagnostic.CA1068.severity = none # CancellationToken parameters must come last
dotnet_diagnostic.CA1069.severity = none # Enums values should not be duplicated
dotnet_diagnostic.CA1070.severity = none # Do not declare event fields as virtual
dotnet_diagnostic.CA1200.severity = none # Avoid using cref tags with a prefix
dotnet_diagnostic.CA1303.severity = none # Do not pass literals as localized parameters
dotnet_diagnostic.CA1304.severity = none # Specify CultureInfo
dotnet_diagnostic.CA1305.severity = none # Specify IFormatProvider
dotnet_diagnostic.CA1307.severity = none # Specify StringComparison
dotnet_diagnostic.CA1308.severity = none # Normalize strings to uppercase
dotnet_diagnostic.CA1309.severity = none # Use ordinal stringcomparison
dotnet_diagnostic.CA1401.severity = none # P/Invokes should not be visible
dotnet_diagnostic.CA1417.severity = none # Do not use 'OutAttribute' on string parameters for P/Invokes
dotnet_diagnostic.CA1501.severity = none # Avoid excessive inheritance
dotnet_diagnostic.CA1502.severity = none # Avoid excessive complexity
dotnet_diagnostic.CA1505.severity = none # Avoid unmaintainable code
dotnet_diagnostic.CA1506.severity = none # Avoid excessive class coupling
dotnet_diagnostic.CA1507.severity = none # Use nameof to express symbol names
dotnet_diagnostic.CA1508.severity = none # Avoid dead conditional code
dotnet_diagnostic.CA1509.severity = none # Invalid entry in code metrics rule specification file
dotnet_diagnostic.CA1700.severity = none # Do not name enum values 'Reserved'
dotnet_diagnostic.CA1707.severity = none # Identifiers should not contain underscores
dotnet_diagnostic.CA1708.severity = none # Identifiers should differ by more than case
dotnet_diagnostic.CA1710.severity = none # Identifiers should have correct suffix
dotnet_diagnostic.CA1711.severity = none # Identifiers should not have incorrect suffix
dotnet_diagnostic.CA1712.severity = none # Do not prefix enum values with type name
dotnet_diagnostic.CA1713.severity = none # Events should not have 'Before' or 'After' prefix
dotnet_diagnostic.CA1714.severity = none # Flags enums should have plural names
dotnet_diagnostic.CA1715.severity = none # Identifiers should have correct prefix
dotnet_diagnostic.CA1716.severity = none # Identifiers should not match keywords
dotnet_diagnostic.CA1717.severity = none # Only FlagsAttribute enums should have plural names
dotnet_diagnostic.CA1720.severity = none # Identifier contains type name
dotnet_diagnostic.CA1721.severity = none # Property names should not match get methods
dotnet_diagnostic.CA1724.severity = none # Type names should not match namespaces
dotnet_diagnostic.CA1725.severity = none # Parameter names should match base declaration
dotnet_diagnostic.CA1801.severity = none # Review unused parameters
dotnet_diagnostic.CA1802.severity = none # Use literals where appropriate
dotnet_diagnostic.CA1805.severity = none # Do not initialize unnecessarily
dotnet_diagnostic.CA1806.severity = none # Do not ignore method results
dotnet_diagnostic.CA1810.severity = none # Initialize reference type static fields inline
dotnet_diagnostic.CA1812.severity = none # Avoid uninstantiated internal classes
dotnet_diagnostic.CA1813.severity = none # Avoid unsealed attributes
dotnet_diagnostic.CA1814.severity = none # Prefer jagged arrays over multidimensional
dotnet_diagnostic.CA1815.severity = none # Override equals and operator equals on value types
dotnet_diagnostic.CA1816.severity = none # Dispose methods should call SuppressFinalize
dotnet_diagnostic.CA1819.severity = none # Properties should not return arrays
dotnet_diagnostic.CA1820.severity = none # Test for empty strings using string length
dotnet_diagnostic.CA1821.severity = none # Remove empty Finalizers
dotnet_diagnostic.CA1822.severity = none # Mark members as static
dotnet_diagnostic.CA1823.severity = none # Avoid unused private fields
dotnet_diagnostic.CA1824.severity = none # Mark assemblies with NeutralResourcesLanguageAttribute
dotnet_diagnostic.CA1825.severity = none # Avoid zero-length array allocations
dotnet_diagnostic.CA1826.severity = none # Do not use Enumerable methods on indexable collections
dotnet_diagnostic.CA1827.severity = none # Do not use Count() or LongCount() when Any() can be used
dotnet_diagnostic.CA1828.severity = none # Do not use CountAsync() or LongCountAsync() when AnyAsync() can be used
dotnet_diagnostic.CA1829.severity = none # Use Length/Count property instead of Count() when available
dotnet_diagnostic.CA1830.severity = none # Prefer strongly-typed Append and Insert method overloads on StringBuilder
dotnet_diagnostic.CA1831.severity = none # Use AsSpan or AsMemory instead of Range-based indexers when appropriate
dotnet_diagnostic.CA1832.severity = none # Use AsSpan or AsMemory instead of Range-based indexers when appropriate
dotnet_diagnostic.CA1833.severity = none # Use AsSpan or AsMemory instead of Range-based indexers when appropriate
dotnet_diagnostic.CA1834.severity = none # Consider using 'StringBuilder.Append(char)' when applicable
dotnet_diagnostic.CA1835.severity = none # Prefer the 'Memory'-based overloads for 'ReadAsync' and 'WriteAsync'
dotnet_diagnostic.CA1836.severity = none # Prefer IsEmpty over Count
dotnet_diagnostic.CA1837.severity = none # Use 'Environment.ProcessId'
dotnet_diagnostic.CA1838.severity = none # Avoid 'StringBuilder' parameters for P/Invokes
dotnet_diagnostic.CA2000.severity = none # Dispose objects before losing scope
dotnet_diagnostic.CA2002.severity = none # Do not lock on objects with weak identity
dotnet_diagnostic.CA2007.severity = none # Consider calling ConfigureAwait on the awaited task
dotnet_diagnostic.CA2008.severity = none # Do not create tasks without passing a TaskScheduler
dotnet_diagnostic.CA2009.severity = none # Do not call ToImmutableCollection on an ImmutableCollection value
dotnet_diagnostic.CA2010.severity = none
dotnet_diagnostic.CA2011.severity = none # Avoid infinite recursion
dotnet_diagnostic.CA2012.severity = none # Use ValueTasks correctly
dotnet_diagnostic.CA2013.severity = none # Do not use ReferenceEquals with value types
dotnet_diagnostic.CA2014.severity = none # Do not use stackalloc in loops
dotnet_diagnostic.CA2015.severity = none # Do not define finalizers for types derived from MemoryManager<T>
dotnet_diagnostic.CA2016.severity = none # Forward the 'CancellationToken' parameter to methods that take one
dotnet_diagnostic.CA2100.severity = none # Review SQL queries for security vulnerabilities
dotnet_diagnostic.CA2101.severity = none # Specify marshaling for P/Invoke string arguments
dotnet_diagnostic.CA2109.severity = none # Review visible event handlers
dotnet_diagnostic.CA2119.severity = none # Seal methods that satisfy private interfaces
dotnet_diagnostic.CA2200.severity = none # Rethrow to preserve stack details
dotnet_diagnostic.CA2201.severity = none # Do not raise reserved exception types
dotnet_diagnostic.CA2207.severity = none # Initialize value type static fields inline
dotnet_diagnostic.CA2208.severity = none # Instantiate argument exceptions correctly
dotnet_diagnostic.CA2211.severity = none # Non-constant fields should not be visible
dotnet_diagnostic.CA2213.severity = none # Disposable fields should be disposed
dotnet_diagnostic.CA2214.severity = none # Do not call overridable methods in constructors
dotnet_diagnostic.CA2215.severity = none # Dispose methods should call base class dispose
dotnet_diagnostic.CA2216.severity = none # Disposable types should declare finalizer
dotnet_diagnostic.CA2217.severity = none # Do not mark enums with FlagsAttribute
dotnet_diagnostic.CA2218.severity = none # Override GetHashCode on overriding Equals
dotnet_diagnostic.CA2219.severity = none # Do not raise exceptions in finally clauses
dotnet_diagnostic.CA2224.severity = none # Override Equals on overloading operator equals
dotnet_diagnostic.CA2225.severity = none # Operator overloads have named alternates
dotnet_diagnostic.CA2226.severity = none # Operators should have symmetrical overloads
dotnet_diagnostic.CA2227.severity = none # Collection properties should be read only
dotnet_diagnostic.CA2229.severity = none # Implement serialization constructors
dotnet_diagnostic.CA2231.severity = none # Overload operator equals on overriding value type Equals
dotnet_diagnostic.CA2234.severity = none # Pass system uri objects instead of strings
dotnet_diagnostic.CA2235.severity = none # Mark all non-serializable fields
dotnet_diagnostic.CA2237.severity = none # Mark ISerializable types with serializable
dotnet_diagnostic.CA2241.severity = none # Provide correct arguments to formatting methods
dotnet_diagnostic.CA2242.severity = none # Test for NaN correctly
dotnet_diagnostic.CA2243.severity = none # Attribute string literals should parse correctly
dotnet_diagnostic.CA2244.severity = none # Do not duplicate indexed element initializations
dotnet_diagnostic.CA2245.severity = none # Do not assign a property to itself
dotnet_diagnostic.CA2246.severity = none # Assigning symbol and its member in the same statement
dotnet_diagnostic.CA2247.severity = none # Argument passed to TaskCompletionSource constructor should be TaskCreationOptions enum instead of TaskContinuationOptions enum
dotnet_diagnostic.CA2248.severity = none # Provide correct 'enum' argument to 'Enum.HasFlag'
dotnet_diagnostic.CA2249.severity = none # Consider using 'string.Contains' instead of 'string.IndexOf'
dotnet_diagnostic.CA2300.severity = none # Do not use insecure deserializer BinaryFormatter
dotnet_diagnostic.CA2326.severity = none # Do not use TypeNameHandling values other than None
dotnet_diagnostic.CA5360.severity = none # Do Not Call Dangerous Methods In Deserialization
dotnet_diagnostic.CA5362.severity = none # Potential reference cycle in deserialized object graph
dotnet_diagnostic.CA5363.severity = none # Do Not Disable Request Validation
dotnet_diagnostic.CA5365.severity = none # Do Not Disable HTTP Header Checking
dotnet_diagnostic.CA5366.severity = none # Use XmlReader For DataSet Read Xml
dotnet_diagnostic.CA5367.severity = none # Do Not Serialize Types With Pointer Fields
dotnet_diagnostic.CA5368.severity = none # Set ViewStateUserKey For Classes Derived From Page
dotnet_diagnostic.CA5369.severity = none # Use XmlReader For Deserialize
dotnet_diagnostic.CA5370.severity = none # Use XmlReader For Validating Reader
dotnet_diagnostic.CA5371.severity = none # Use XmlReader For Schema Read
dotnet_diagnostic.CA5372.severity = none # Use XmlReader For XPathDocument
dotnet_diagnostic.CA5373.severity = none # Do not use obsolete key derivation function
dotnet_diagnostic.CA5374.severity = none # Do Not Use XslTransform
dotnet_diagnostic.CA5375.severity = none # Do Not Use Account Shared Access Signature
dotnet_diagnostic.CA5376.severity = none # Use SharedAccessProtocol HttpsOnly
dotnet_diagnostic.CA5377.severity = none # Use Container Level Access Policy
dotnet_diagnostic.CA5379.severity = none # Do Not Use Weak Key Derivation Function Algorithm
dotnet_diagnostic.CA5382.severity = none # Use Secure Cookies In ASP.Net Core
dotnet_diagnostic.CA5383.severity = none # Ensure Use Secure Cookies In ASP.Net Core
dotnet_diagnostic.CA5384.severity = none # Do Not Use Digital Signature Algorithm (DSA)
dotnet_diagnostic.CA5385.severity = none # Use Rivest–Shamir–Adleman (RSA) Algorithm With Sufficient Key Size
dotnet_diagnostic.CA5387.severity = none # Do Not Use Weak Key Derivation Function With Insufficient Iteration Count
dotnet_diagnostic.CA5388.severity = none # Ensure Sufficient Iteration Count When Using Weak Key Derivation Function
dotnet_diagnostic.CA5389.severity = none # Do Not Add Archive Item's Path To The Target File System Path
dotnet_diagnostic.CA5390.severity = none # Do not hard-code encryption key
dotnet_diagnostic.CA5392.severity = none # Use DefaultDllImportSearchPaths attribute for P/Invokes
dotnet_diagnostic.CA5393.severity = none # Do not use unsafe DllImportSearchPath value
dotnet_diagnostic.CA5394.severity = none # Do not use insecure randomness
dotnet_diagnostic.CA5399.severity = none # HttpClients should enable certificate revocation list checks
dotnet_diagnostic.CA5400.severity = none # Ensure HttpClient certificate revocation list check is not disabled
dotnet_diagnostic.CA5401.severity = none # Do not use CreateEncryptor with non-default IV
dotnet_diagnostic.CA5402.severity = none # Use CreateEncryptor with the default IV
dotnet_diagnostic.CA5403.severity = none # Do not hard-code certificate
dotnet_diagnostic.CA9999.severity = none # Analyzer version mismatch
dotnet_diagnostic.IA2989.severity = none # Do not use banned insecure deserialization APIs
dotnet_diagnostic.IA2992.severity = none # Do Not Use Banned APIs For Insecure Deserializers
dotnet_diagnostic.IA2993.severity = none # Do Not Use Banned Constructors For Insecure Deserializers
dotnet_diagnostic.IA2994.severity = none # Do Not Use ResourceSet Without ResourceReader
dotnet_diagnostic.IA2995.severity = none # Do Not Use ResourceReader
dotnet_diagnostic.IA2996.severity = none # Do Not Use ResXResourceReader Without ITypeResolutionService
dotnet_diagnostic.IA2997.severity = none # Do Not Use TypeNameHandling Other Than None
dotnet_diagnostic.IA2998.severity = none # Do Not Deserialize With BinaryFormatter Without Binder
dotnet_diagnostic.IA2999.severity = none # Do Not Set BinaryFormatter.Binder to null
dotnet_diagnostic.IA5359.severity = none # Use approved crypto libraries for the supported platform
dotnet_diagnostic.IL3000.severity = none # Avoid using accessing Assembly file path when publishing as a single-file
dotnet_diagnostic.IL3001.severity = none # Avoid using accessing Assembly file path when publishing as a single-file
dotnet_diagnostic.RS1000.severity = none
dotnet_diagnostic.RS1001.severity = none
dotnet_diagnostic.RS1002.severity = none
dotnet_diagnostic.RS1003.severity = none
dotnet_diagnostic.RS1004.severity = none
dotnet_diagnostic.RS1005.severity = none
dotnet_diagnostic.RS1006.severity = none
dotnet_diagnostic.RS1007.severity = none
dotnet_diagnostic.RS1008.severity = none
dotnet_diagnostic.RS1009.severity = none
dotnet_diagnostic.RS1010.severity = none
dotnet_diagnostic.RS1011.severity = none
dotnet_diagnostic.RS1012.severity = none
dotnet_diagnostic.RS1013.severity = none
dotnet_diagnostic.RS1014.severity = none