Commit 1062c44f authored by Phil Quitslund's avatar Phil Quitslund

Merge pull request #2094 from flutter/analyze_fixes

Enumerate lints for analysis in synthesized options file.
parents 8111fa79 44797565
...@@ -235,9 +235,32 @@ class AnalyzeCommand extends FlutterCommand { ...@@ -235,9 +235,32 @@ class AnalyzeCommand extends FlutterCommand {
for (String package in packages.keys) for (String package in packages.keys)
packagesBody.writeln('$package:${path.toUri(packages[package])}'); packagesBody.writeln('$package:${path.toUri(packages[package])}');
/// specify analysis options
/// note that until there is a default "all-in" lint rule-set we need
/// to opt-in to all desired lints (https://github.com/dart-lang/sdk/issues/25843)
String optionsBody = '''
linter:
rules:
- camel_case_types
# sometimes we have no choice (e.g. when matching other platforms)
# - constant_identifier_names
- empty_constructor_bodies
# disabled until regexp fix is pulled in (https://github.com/flutter/flutter/pull/1996)
# - library_names
- library_prefixes
- non_constant_identifier_names
# too many false-positives; code review should catch real instances
# - one_member_abstracts
- slash_for_doc_comments
- super_goes_last
- type_init_formals
- unnecessary_brace_in_string_interp
''';
// save the Dart file and the .packages file to disk // save the Dart file and the .packages file to disk
Directory host = Directory.systemTemp.createTempSync('flutter-analyze-'); Directory host = Directory.systemTemp.createTempSync('flutter-analyze-');
File mainFile = new File(path.join(host.path, 'main.dart'))..writeAsStringSync(mainBody.toString()); File mainFile = new File(path.join(host.path, 'main.dart'))..writeAsStringSync(mainBody.toString());
File optionsFile = new File(path.join(host.path, '_analysis.options'))..writeAsStringSync(optionsBody.toString());
File packagesFile = new File(path.join(host.path, '.packages'))..writeAsStringSync(packagesBody.toString()); File packagesFile = new File(path.join(host.path, '.packages'))..writeAsStringSync(packagesBody.toString());
List<String> cmd = <String>[ List<String> cmd = <String>[
...@@ -252,7 +275,8 @@ class AnalyzeCommand extends FlutterCommand { ...@@ -252,7 +275,8 @@ class AnalyzeCommand extends FlutterCommand {
'--fatal-warnings', '--fatal-warnings',
'--strong-hints', '--strong-hints',
'--fatal-hints', '--fatal-hints',
'--lints', // defines lints
'--options', optionsFile.path,
'--packages', packagesFile.path, '--packages', packagesFile.path,
mainFile.path mainFile.path
]; ];
...@@ -295,8 +319,6 @@ class AnalyzeCommand extends FlutterCommand { ...@@ -295,8 +319,6 @@ class AnalyzeCommand extends FlutterCommand {
new RegExp(r'^\[warning\] .+ will need runtime check to cast to type .+'), // https://github.com/dart-lang/sdk/issues/24542 new RegExp(r'^\[warning\] .+ will need runtime check to cast to type .+'), // https://github.com/dart-lang/sdk/issues/24542
new RegExp(r'^\[error\] Type check failed: .*\(dynamic\) is not of type'), // allow unchecked casts from dynamic new RegExp(r'^\[error\] Type check failed: .*\(dynamic\) is not of type'), // allow unchecked casts from dynamic
new RegExp('^\\[error\\] Target of URI does not exist: \'dart:ui_internals\''), // https://github.com/flutter/flutter/issues/83 new RegExp('^\\[error\\] Target of URI does not exist: \'dart:ui_internals\''), // https://github.com/flutter/flutter/issues/83
new RegExp(r'\[lint\] Prefer using lowerCamelCase for constant names.'), // sometimes we have no choice (e.g. when matching other platforms)
new RegExp(r'\[lint\] Avoid defining a one-member abstract class when a simple function will do.'), // too many false-positives; code review should catch real instances
new RegExp(r'\[info\] TODO.+'), new RegExp(r'\[info\] TODO.+'),
new RegExp('\\[warning\\] Missing concrete implementation of \'RenderObject\\.applyPaintTransform\''), // https://github.com/dart-lang/sdk/issues/25232 new RegExp('\\[warning\\] Missing concrete implementation of \'RenderObject\\.applyPaintTransform\''), // https://github.com/dart-lang/sdk/issues/25232
new RegExp(r'[0-9]+ (error|warning|hint|lint).+found\.'), new RegExp(r'[0-9]+ (error|warning|hint|lint).+found\.'),
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment