Commit c04b4c75 authored by Ian Hickson's avatar Ian Hickson

Merge pull request #2206 from Hixie/analyzer-messages

Handle conflicting 'library' identifiers
parents 9a3baa44 a33e256a
...@@ -16,6 +16,66 @@ import '../build_configuration.dart'; ...@@ -16,6 +16,66 @@ import '../build_configuration.dart';
import '../globals.dart'; import '../globals.dart';
import '../runner/flutter_command.dart'; import '../runner/flutter_command.dart';
bool isDartFile(FileSystemEntity entry) => entry is File && entry.path.endsWith('.dart');
bool isDartTestFile(FileSystemEntity entry) => entry is File && entry.path.endsWith('_test.dart');
bool isDartBenchmarkFile(FileSystemEntity entry) => entry is File && entry.path.endsWith('_bench.dart');
bool _addPackage(String directoryPath, List<String> dartFiles, Set<String> pubSpecDirectories) {
final int originalDartFilesCount = dartFiles.length;
// .../directoryPath/*/bin/*.dart
// .../directoryPath/*/lib/main.dart
// .../directoryPath/*/test/*_test.dart
// .../directoryPath/*/test/*/*_test.dart
// .../directoryPath/*/benchmark/*/*_bench.dart
Directory binDirectory = new Directory(path.join(directoryPath, 'bin'));
if (binDirectory.existsSync()) {
for (FileSystemEntity subentry in binDirectory.listSync()) {
if (isDartFile(subentry))
dartFiles.add(subentry.path);
}
}
String mainPath = path.join(directoryPath, 'lib', 'main.dart');
if (FileSystemEntity.isFileSync(mainPath))
dartFiles.add(mainPath);
Directory testDirectory = new Directory(path.join(directoryPath, 'test'));
if (testDirectory.existsSync()) {
for (FileSystemEntity entry in testDirectory.listSync()) {
if (entry is Directory) {
for (FileSystemEntity subentry in entry.listSync()) {
if (isDartTestFile(subentry))
dartFiles.add(subentry.path);
}
} else if (isDartTestFile(entry)) {
dartFiles.add(entry.path);
}
}
}
Directory benchmarkDirectory = new Directory(path.join(directoryPath, 'benchmark'));
if (benchmarkDirectory.existsSync()) {
for (FileSystemEntity entry in benchmarkDirectory.listSync()) {
if (entry is Directory) {
for (FileSystemEntity subentry in entry.listSync()) {
if (isDartBenchmarkFile(subentry))
dartFiles.add(subentry.path);
}
} else if (isDartBenchmarkFile(entry)) {
dartFiles.add(entry.path);
}
}
}
if (originalDartFilesCount != dartFiles.length) {
pubSpecDirectories.add(directoryPath);
return true;
}
return false;
}
class AnalyzeCommand extends FlutterCommand { class AnalyzeCommand extends FlutterCommand {
String get name => 'analyze'; String get name => 'analyze';
String get description => 'Analyze the project\'s Dart code.'; String get description => 'Analyze the project\'s Dart code.';
...@@ -56,126 +116,93 @@ class AnalyzeCommand extends FlutterCommand { ...@@ -56,126 +116,93 @@ class AnalyzeCommand extends FlutterCommand {
} }
} }
if (argResults['flutter-repo']) { if (argResults['current-directory']) {
// .../examples/*/*.dart // ./*.dart
// .../examples/*/lib/main.dart Directory currentDirectory = new Directory('.');
Directory examples = new Directory(path.join(ArtifactStore.flutterRoot, 'examples'));
for (FileSystemEntity entry in examples.listSync()) {
if (entry is Directory) {
bool foundOne = false; bool foundOne = false;
for (FileSystemEntity subentry in entry.listSync()) { for (FileSystemEntity entry in currentDirectory.listSync()) {
if (subentry is File && subentry.path.endsWith('.dart')) { if (isDartFile(entry)) {
dartFiles.add(subentry.path); dartFiles.add(entry.path);
foundOne = true;
} else if (subentry is Directory && path.basename(subentry.path) == 'lib') {
String mainPath = path.join(subentry.path, 'main.dart');
if (FileSystemEntity.isFileSync(mainPath)) {
dartFiles.add(mainPath);
foundOne = true; foundOne = true;
} }
} }
if (foundOne) {
pubSpecDirectories.add('.');
foundAnyInCurrentDirectory = true;
} }
if (foundOne)
pubSpecDirectories.add(entry.path);
} }
if (argResults['current-package']) {
if (_addPackage('.', dartFiles, pubSpecDirectories))
foundAnyInCurrentDirectory = true;
} }
// .../packages/*/bin/*.dart if (argResults['flutter-repo']) {
// .../packages/*/lib/main.dart
// .../packages/*/test/*_test.dart
// .../packages/*/test/*/*_test.dart
// .../packages/*/benchmark/*/*_bench.dart
Directory packages = new Directory(path.join(ArtifactStore.flutterRoot, 'packages'));
for (FileSystemEntity entry in packages.listSync()) {
if (entry is Directory) {
bool foundOne = false;
Directory binDirectory = new Directory(path.join(entry.path, 'bin')); //examples/*/ as package
if (binDirectory.existsSync()) { //examples/layers/*/ as files
for (FileSystemEntity subentry in binDirectory.listSync()) { //dev/manual_tests/*/ as package
if (subentry is File && subentry.path.endsWith('.dart')) { //dev/manual_tests/*/ as files
dartFiles.add(subentry.path);
foundOne = true;
}
}
}
String mainPath = path.join(entry.path, 'lib', 'main.dart'); Directory subdirectory;
if (FileSystemEntity.isFileSync(mainPath)) {
dartFiles.add(mainPath);
foundOne = true;
}
Directory testDirectory = new Directory(path.join(entry.path, 'test')); subdirectory = new Directory(path.join(ArtifactStore.flutterRoot, 'packages'));
if (testDirectory.existsSync()) { if (subdirectory.existsSync()) {
for (FileSystemEntity entry in testDirectory.listSync()) { for (FileSystemEntity entry in subdirectory.listSync()) {
if (entry is Directory) { if (entry is Directory)
for (FileSystemEntity subentry in entry.listSync()) { _addPackage(entry.path, dartFiles, pubSpecDirectories);
if (subentry is File && subentry.path.endsWith('_test.dart')) {
dartFiles.add(subentry.path);
foundOne = true;
} }
} }
} else if (entry is File && entry.path.endsWith('_test.dart')) {
dartFiles.add(entry.path); subdirectory = new Directory(path.join(ArtifactStore.flutterRoot, 'examples'));
foundOne = true; if (subdirectory.existsSync()) {
} for (FileSystemEntity entry in subdirectory.listSync()) {
if (entry is Directory)
_addPackage(entry.path, dartFiles, pubSpecDirectories);
} }
} }
Directory benchmarkDirectory = new Directory(path.join(entry.path, 'benchmark')); subdirectory = new Directory(path.join(ArtifactStore.flutterRoot, 'examples', 'layers'));
if (benchmarkDirectory.existsSync()) { if (subdirectory.existsSync()) {
for (FileSystemEntity entry in benchmarkDirectory.listSync()) { bool foundOne = false;
for (FileSystemEntity entry in subdirectory.listSync()) {
if (entry is Directory) { if (entry is Directory) {
for (FileSystemEntity subentry in entry.listSync()) { for (FileSystemEntity subentry in entry.listSync()) {
if (subentry is File && subentry.path.endsWith('_bench.dart')) { if (isDartFile(subentry)) {
dartFiles.add(subentry.path); dartFiles.add(subentry.path);
foundOne = true; foundOne = true;
} }
} }
} else if (entry is File && entry.path.endsWith('_bench.dart')) {
dartFiles.add(entry.path);
foundOne = true;
}
} }
} }
if (foundOne) if (foundOne)
pubSpecDirectories.add(entry.path); pubSpecDirectories.add(subdirectory.path);
}
}
} }
if (argResults['current-directory']) { subdirectory = new Directory(path.join(ArtifactStore.flutterRoot, 'dev', 'manual_tests'));
// ./*.dart if (subdirectory.existsSync()) {
Directory currentDirectory = new Directory('.');
bool foundOne = false; bool foundOne = false;
for (FileSystemEntity entry in currentDirectory.listSync()) { for (FileSystemEntity entry in subdirectory.listSync()) {
if (entry is File && entry.path.endsWith('.dart')) { if (entry is Directory) {
_addPackage(entry.path, dartFiles, pubSpecDirectories);
} else if (isDartFile(entry)) {
dartFiles.add(entry.path); dartFiles.add(entry.path);
foundOne = true; foundOne = true;
} }
} }
if (foundOne) { if (foundOne)
pubSpecDirectories.add('.'); pubSpecDirectories.add(subdirectory.path);
foundAnyInCurrentDirectory = true;
}
} }
if (argResults['current-package']) {
// ./lib/main.dart
String mainPath = 'lib/main.dart';
if (FileSystemEntity.isFileSync(mainPath)) {
dartFiles.add(mainPath);
pubSpecDirectories.add('.');
foundAnyInCurrentDirectory = true;
}
} }
dartFiles = dartFiles.map((String directory) => path.normalize(path.absolute(directory))).toSet().toList();
dartFiles.sort();
// prepare a Dart file that references all the above Dart files // prepare a Dart file that references all the above Dart files
StringBuffer mainBody = new StringBuffer(); StringBuffer mainBody = new StringBuffer();
for (int index = 0; index < dartFiles.length; index += 1) for (int index = 0; index < dartFiles.length; index += 1)
mainBody.writeln('import \'${path.normalize(path.absolute(dartFiles[index]))}\' as file$index;'); mainBody.writeln('import \'${dartFiles[index]}\' as file$index;');
mainBody.writeln('void main() { }'); mainBody.writeln('void main() { }');
// prepare a union of all the .packages files // prepare a union of all the .packages files
...@@ -220,7 +247,7 @@ class AnalyzeCommand extends FlutterCommand { ...@@ -220,7 +247,7 @@ class AnalyzeCommand extends FlutterCommand {
} }
if (hadInconsistentRequirements) { if (hadInconsistentRequirements) {
if (foundAnyInFlutterRepo) if (foundAnyInFlutterRepo)
printError('You may need to run "dart ${path.normalize(path.relative(path.join(ArtifactStore.flutterRoot, 'dev/update_packages.dart')))} --upgrade".'); printError('You may need to run "flutter update-packages --upgrade".');
if (foundAnyInCurrentDirectory) if (foundAnyInCurrentDirectory)
printError('You may need to run "pub upgrade".'); printError('You may need to run "pub upgrade".');
} }
...@@ -294,6 +321,8 @@ linter: ...@@ -294,6 +321,8 @@ linter:
} else { } else {
printStatus('Analyzing ${dartFiles.length} files...'); printStatus('Analyzing ${dartFiles.length} files...');
} }
for (String file in dartFiles)
printTrace(file);
} }
Process process = await Process.start( Process process = await Process.start(
...@@ -314,8 +343,6 @@ linter: ...@@ -314,8 +343,6 @@ linter:
int exitCode = await process.exitCode; int exitCode = await process.exitCode;
host.deleteSync(recursive: true);
List<Pattern> patternsToSkip = <Pattern>[ List<Pattern> patternsToSkip = <Pattern>[
'Analyzing [${mainFile.path}]...', 'Analyzing [${mainFile.path}]...',
new RegExp('^\\[(hint|error)\\] Unused import \\(${mainFile.path},'), new RegExp('^\\[(hint|error)\\] Unused import \\(${mainFile.path},'),
...@@ -331,6 +358,7 @@ linter: ...@@ -331,6 +358,7 @@ linter:
RegExp allowedIdentifiersPattern = new RegExp(r'_?([A-Z]|_+)\b'); RegExp allowedIdentifiersPattern = new RegExp(r'_?([A-Z]|_+)\b');
RegExp constructorTearOffsPattern = new RegExp('.+#.+// analyzer doesn\'t like constructor tear-offs'); RegExp constructorTearOffsPattern = new RegExp('.+#.+// analyzer doesn\'t like constructor tear-offs');
RegExp ignorePattern = new RegExp(r'// analyzer says "([^"]+)"'); RegExp ignorePattern = new RegExp(r'// analyzer says "([^"]+)"');
RegExp conflictingNamesPattern = new RegExp('^The imported libraries \'([^\']+)\' and \'([^\']+)\' cannot have the same name \'([^\']+)\'\$');
List<String> errorLines = output.toString().split('\n'); List<String> errorLines = output.toString().split('\n');
for (String errorLine in errorLines) { for (String errorLine in errorLines) {
...@@ -346,7 +374,14 @@ linter: ...@@ -346,7 +374,14 @@ linter:
List<String> sourceLines = source.readAsLinesSync(); List<String> sourceLines = source.readAsLinesSync();
String sourceLine = (lineNumber < sourceLines.length) ? sourceLines[lineNumber-1] : ''; String sourceLine = (lineNumber < sourceLines.length) ? sourceLines[lineNumber-1] : '';
bool shouldIgnore = false; bool shouldIgnore = false;
if (filename.endsWith('.mojom.dart')) { if (filename == mainFile.path) {
Match libs = conflictingNamesPattern.firstMatch(errorMessage);
if (libs != null) {
errorLine = '[$level] $errorMessage (${dartFiles[lineNumber-1]})'; // strip the reference to the generated main.dart
} else {
errorLine += ' (Please file a bug on the "flutter analyze" command saying that you saw this message.)';
}
} else if (filename.endsWith('.mojom.dart')) {
// autogenerated code - TODO(ianh): Fix the Dart mojom compiler // autogenerated code - TODO(ianh): Fix the Dart mojom compiler
shouldIgnore = true; shouldIgnore = true;
} else if ((sourceLines[0] == '/**') && (' * DO NOT EDIT. This is code generated'.matchAsPrefix(sourceLines[1]) != null)) { } else if ((sourceLines[0] == '/**') && (' * DO NOT EDIT. This is code generated'.matchAsPrefix(sourceLines[1]) != null)) {
...@@ -376,6 +411,8 @@ linter: ...@@ -376,6 +411,8 @@ linter:
stopwatch.stop(); stopwatch.stop();
String elapsed = (stopwatch.elapsedMilliseconds / 1000.0).toStringAsFixed(1); String elapsed = (stopwatch.elapsedMilliseconds / 1000.0).toStringAsFixed(1);
host.deleteSync(recursive: true);
if (exitCode < 0 || exitCode > 3) // 0 = nothing, 1 = hints, 2 = warnings, 3 = errors if (exitCode < 0 || exitCode > 3) // 0 = nothing, 1 = hints, 2 = warnings, 3 = errors
return exitCode; return exitCode;
......
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