Commit 96ba7f76 authored by Michael Goderbauer's avatar Michael Goderbauer Committed by GitHub

Revert "Simplify path handling logic in dependency checker and devFS (#8414)" (#8467)

This reverts commit e7bde11c.

Reason: broke hot reload when using "package:" style imports for sources
within the same project.
parent 0533ffc0
0edcbb7db427e4fcaff23308ea95f9aec0ebb432 eaacbf5f6f8f7f0be4cec64babc777816c68dd44
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
import 'dart:convert'; import 'dart:convert';
import '../artifacts.dart'; import '../artifacts.dart';
import '../base/file_system.dart';
import '../base/process.dart'; import '../base/process.dart';
class DartDependencySetBuilder { class DartDependencySetBuilder {
...@@ -29,6 +30,16 @@ class DartDependencySetBuilder { ...@@ -29,6 +30,16 @@ class DartDependencySetBuilder {
String output = runSyncAndThrowStdErrOnError(args); String output = runSyncAndThrowStdErrOnError(args);
return new Set<String>.from(LineSplitter.split(output)); final List<String> lines = LineSplitter.split(output).toList();
final Set<String> minimalDependencies = new Set<String>();
for (String line in lines) {
if (!line.startsWith('package:')) {
// We convert the uris so that they are relative to the project
// root.
line = fs.path.relative(line, from: projectRootPath);
}
minimalDependencies.add(line);
}
return minimalDependencies;
} }
} }
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
import 'asset.dart'; import 'asset.dart';
import 'base/file_system.dart'; import 'base/file_system.dart';
import 'dart/dependencies.dart'; import 'dart/dependencies.dart';
import 'dart/package_map.dart';
import 'globals.dart'; import 'globals.dart';
class DependencyChecker { class DependencyChecker {
...@@ -17,7 +18,10 @@ class DependencyChecker { ...@@ -17,7 +18,10 @@ class DependencyChecker {
/// if it cannot be determined. /// if it cannot be determined.
bool check(DateTime threshold) { bool check(DateTime threshold) {
_dependencies.clear(); _dependencies.clear();
PackageMap packageMap;
// Parse the package map.
try { try {
packageMap = new PackageMap(builder.packagesFilePath)..load();
_dependencies.add(builder.packagesFilePath); _dependencies.add(builder.packagesFilePath);
} catch (e, st) { } catch (e, st) {
printTrace('DependencyChecker: could not parse .packages file:\n$e\n$st'); printTrace('DependencyChecker: could not parse .packages file:\n$e\n$st');
...@@ -25,7 +29,16 @@ class DependencyChecker { ...@@ -25,7 +29,16 @@ class DependencyChecker {
} }
// Build the set of Dart dependencies. // Build the set of Dart dependencies.
try { try {
_dependencies.addAll(builder.build()); Set<String> dependencies = builder.build();
for (String path in dependencies) {
// Ensure all paths are absolute.
if (path.startsWith('package:')) {
path = packageMap.pathForPackage(Uri.parse(path));
} else {
path = fs.path.join(builder.projectRootPath, path);
}
_dependencies.add(path);
}
} catch (e, st) { } catch (e, st) {
printTrace('DependencyChecker: error determining .dart dependencies:\n$e\n$st'); printTrace('DependencyChecker: error determining .dart dependencies:\n$e\n$st');
return true; return true;
......
...@@ -461,10 +461,10 @@ class DevFS { ...@@ -461,10 +461,10 @@ class DevFS {
} }
bool _shouldIgnore(String devicePath) { bool _shouldIgnore(String devicePath) {
List<String> ignoredPrefixes = <String>['android' + fs.path.separator, List<String> ignoredPrefixes = <String>['android/',
getBuildDirectory(), getBuildDirectory(),
'ios' + fs.path.separator, 'ios/',
'.pub' + fs.path.separator]; '.pub/'];
for (String ignoredPrefix in ignoredPrefixes) { for (String ignoredPrefix in ignoredPrefixes) {
if (devicePath.startsWith(ignoredPrefix)) if (devicePath.startsWith(ignoredPrefix))
return true; return true;
...@@ -473,14 +473,16 @@ class DevFS { ...@@ -473,14 +473,16 @@ class DevFS {
} }
Future<bool> _scanDirectory(Directory directory, Future<bool> _scanDirectory(Directory directory,
{String directoryNameOnDevice, {String directoryName,
bool recursive: false, bool recursive: false,
bool ignoreDotFiles: true, bool ignoreDotFiles: true,
String packagesDirectoryName,
Set<String> fileFilter}) async { Set<String> fileFilter}) async {
if (directoryNameOnDevice == null) { String prefix = directoryName;
directoryNameOnDevice = fs.path.relative(directory.path, from: rootDirectory.path); if (prefix == null) {
if (directoryNameOnDevice == '.') prefix = fs.path.relative(directory.path, from: rootDirectory.path);
directoryNameOnDevice = ''; if (prefix == '.')
prefix = '';
} }
try { try {
Stream<FileSystemEntity> files = Stream<FileSystemEntity> files =
...@@ -506,8 +508,24 @@ class DevFS { ...@@ -506,8 +508,24 @@ class DevFS {
} }
final String relativePath = final String relativePath =
fs.path.relative(file.path, from: directory.path); fs.path.relative(file.path, from: directory.path);
final String devicePath = fs.path.join(directoryNameOnDevice, relativePath); final String devicePath = fs.path.join(prefix, relativePath);
if ((fileFilter != null) && !fileFilter.contains(file.absolute.path)) { bool filtered = false;
if ((fileFilter != null) &&
!fileFilter.contains(devicePath)) {
if (packagesDirectoryName != null) {
// Double check the filter for packages/packagename/
final String packagesDevicePath =
fs.path.join(packagesDirectoryName, relativePath);
if (!fileFilter.contains(packagesDevicePath)) {
// File was not in the filter set.
filtered = true;
}
} else {
// File was not in the filter set.
filtered = true;
}
}
if (filtered) {
// Skip files that are not included in the filter. // Skip files that are not included in the filter.
continue; continue;
} }
...@@ -530,26 +548,27 @@ class DevFS { ...@@ -530,26 +548,27 @@ class DevFS {
PackageMap packageMap = new PackageMap(_packagesFilePath); PackageMap packageMap = new PackageMap(_packagesFilePath);
for (String packageName in packageMap.map.keys) { for (String packageName in packageMap.map.keys) {
Uri packageUri = packageMap.map[packageName]; Uri uri = packageMap.map[packageName];
String packagePath = fs.path.fromUri(packageUri); // This project's own package.
Directory packageDirectory = fs.directory(packageUri); final bool isProjectPackage = uri.toString() == 'lib/';
String directoryNameOnDevice = fs.path.join('packages', packageName); final String directoryName =
bool packageExists; isProjectPackage ? 'lib' : fs.path.join('packages', packageName);
// If this is the project's package, we need to pass both
if (fs.path.isWithin(rootDirectory.path, packagePath)) { // package:<package_name> and lib/ as paths to be checked against
// We already scanned everything under the root directory. // the filter because we must support both package: imports and relative
packageExists = packageDirectory.existsSync(); // path imports within the project's own code.
directoryNameOnDevice = fs.path.relative(packagePath, from: rootDirectory.path); final String packagesDirectoryName =
} else { isProjectPackage ? fs.path.join('packages', packageName) : null;
packageExists = Directory directory = fs.directory(uri);
await _scanDirectory(packageDirectory, bool packageExists =
directoryNameOnDevice: directoryNameOnDevice, await _scanDirectory(directory,
directoryName: directoryName,
recursive: true, recursive: true,
packagesDirectoryName: packagesDirectoryName,
fileFilter: fileFilter); fileFilter: fileFilter);
}
if (packageExists) { if (packageExists) {
sb ??= new StringBuffer(); sb ??= new StringBuffer();
sb.writeln('$packageName:$directoryNameOnDevice'); sb.writeln('$packageName:$directoryName');
} }
} }
if (sb != null) { if (sb != null) {
......
...@@ -98,7 +98,18 @@ class HotRunner extends ResidentRunner { ...@@ -98,7 +98,18 @@ class HotRunner extends ResidentRunner {
new DartDependencySetBuilder( new DartDependencySetBuilder(
mainPath, projectRootPath, packagesFilePath); mainPath, projectRootPath, packagesFilePath);
try { try {
_dartDependencies = new Set<String>.from(dartDependencySetBuilder.build()); Set<String> dependencies = dartDependencySetBuilder.build();
_dartDependencies = new Set<String>();
for (String path in dependencies) {
// We need to tweak package: uris so that they reflect their devFS
// location.
if (path.startsWith('package:')) {
// Swap out package: for packages/ because we place all package
// sources under packages/.
path = path.replaceFirst('package:', 'packages/');
}
_dartDependencies.add(path);
}
} catch (error) { } catch (error) {
printStatus('Error detected in application source code:', emphasis: true); printStatus('Error detected in application source code:', emphasis: true);
printError('$error'); printError('$error');
......
...@@ -21,8 +21,8 @@ void main() { ...@@ -21,8 +21,8 @@ void main() {
DartDependencySetBuilder builder = DartDependencySetBuilder builder =
new DartDependencySetBuilder(mainPath, testPath, packagesPath); new DartDependencySetBuilder(mainPath, testPath, packagesPath);
Set<String> dependencies = builder.build(); Set<String> dependencies = builder.build();
expect(dependencies.contains(mainPath), isTrue); expect(dependencies.contains('main.dart'), isTrue);
expect(dependencies.contains(fs.path.join(testPath, 'foo.dart')), isTrue); expect(dependencies.contains('foo.dart'), isTrue);
}); });
testUsingContext('syntax_error', () { testUsingContext('syntax_error', () {
final String testPath = fs.path.join(dataPath, 'syntax_error'); final String testPath = fs.path.join(dataPath, 'syntax_error');
......
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