Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(524)

Side by Side Diff: lib/src/analyzer/multi_package_resolver.dart

Issue 1917863005: Qualify library names in packages (Closed) Base URL: https://github.com/dart-lang/dev_compiler.git@master
Patch Set: Use restoreAbsolute Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 import 'dart:io'; 5 import 'dart:io';
6 6
7 import 'package:analyzer/src/generated/java_io.dart'; 7 import 'package:analyzer/src/generated/java_io.dart';
8 import 'package:analyzer/src/generated/source.dart'; 8 import 'package:analyzer/src/generated/source.dart';
9 import 'package:analyzer/src/generated/source_io.dart'; 9 import 'package:analyzer/src/generated/source_io.dart';
10 import 'package:path/path.dart' show join; 10 import 'package:path/path.dart' as path;
11 11
12 /// A package resolver that supports a non-standard package layout, where 12 /// A package resolver that supports a non-standard package layout, where
13 /// packages with dotted names are expanded to a hierarchy of directories, and 13 /// packages with dotted names are expanded to a hierarchy of directories, and
14 /// packages can be found on one or more locations. 14 /// packages can be found on one or more locations.
15 class MultiPackageResolver extends UriResolver { 15 class MultiPackageResolver extends UriResolver {
16 final List<String> searchPaths; 16 final List<String> searchPaths;
17 MultiPackageResolver(this.searchPaths); 17 MultiPackageResolver(this.searchPaths);
18 18
19 @override 19 @override
20 Source resolveAbsolute(Uri uri, [Uri actualUri]) { 20 Source resolveAbsolute(Uri uri, [Uri actualUri]) {
21 var candidates = _expandPath(uri); 21 var candidates = _expandPath(uri);
22 if (candidates == null) return null; 22 if (candidates == null) return null;
23 23
24 for (var path in candidates) { 24 for (var path in candidates) {
25 var resolvedPath = _resolve(path); 25 var resolvedPath = _resolve(path);
26 if (resolvedPath != null) { 26 if (resolvedPath != null) {
27 return new FileBasedSource( 27 return new FileBasedSource(
28 new JavaFile(resolvedPath), actualUri != null ? actualUri : uri); 28 new JavaFile(resolvedPath), actualUri != null ? actualUri : uri);
29 } 29 }
30 } 30 }
31 return null; 31 return null;
32 } 32 }
33 33
34 /// Resolve [path] by looking at each prefix in [searchPaths] and returning 34 @override
35 /// the first location where `prefix + path` exists. 35 Uri restoreAbsolute(Source source) {
Paul Berry 2016/04/27 19:19:57 FYI, technically this breaks the interface contrac
36 String _resolve(String path) { 36 var uri = source.uri;
37 if (uri.scheme == 'package' || uri.scheme == 'dart') {
38 return uri;
39 }
40 if (uri.scheme == '' || uri.scheme == 'file') {
41 var filePath = path.absolute(uri.path);
Paul Berry 2016/04/27 19:19:57 This won't work on Windows, since uri.path uses '/
42 for (var searchPath in searchPaths) {
43 if (path.isWithin(searchPath, filePath)) {
44 var relativePath = path.relative(filePath, from: searchPath);
45 var segments = path.split(relativePath);
46 var libIndex = segments.lastIndexOf('lib');
vsm 2016/04/27 18:24:35 This is not yet tested and seems brittle...
47 var packageName = segments.sublist(0, libIndex).join('.');
48 var packageRelativePath = segments.sublist(libIndex + 1).join('/');
49 return Uri.parse('package:$packageName/$packageRelativePath');
50 }
51 }
52 }
53 return null;
54 }
55
56 /// Resolve [packagePath] by looking at each prefix in [searchPaths] and retur ning
Jennifer Messerly 2016/04/27 18:30:05 long line
57 /// the first location where `prefix + packagePath` exists.
58 String _resolve(String packagePath) {
37 for (var prefix in searchPaths) { 59 for (var prefix in searchPaths) {
38 var resolvedPath = join(prefix, path); 60 var resolvedPath = path.join(prefix, packagePath);
39 if (new File(resolvedPath).existsSync()) return resolvedPath; 61 if (new File(resolvedPath).existsSync()) return resolvedPath;
40 } 62 }
41 return null; 63 return null;
42 } 64 }
43 65
44 /// Expand `uri.path`, replacing dots in the package name with slashes. 66 /// Expand `uri.path`, replacing dots in the package name with slashes.
45 List<String> _expandPath(Uri uri) { 67 List<String> _expandPath(Uri uri) {
46 if (uri.scheme != 'package') return null; 68 if (uri.scheme != 'package') return null;
47 var path = uri.path; 69 var path = uri.path;
48 var slashPos = path.indexOf('/'); 70 var slashPos = path.indexOf('/');
49 var packagePath = path.substring(0, slashPos).replaceAll(".", "/"); 71 var packagePath = path.substring(0, slashPos).replaceAll(".", "/");
50 var filePath = path.substring(slashPos + 1); 72 var filePath = path.substring(slashPos + 1);
51 return ['$packagePath/lib/$filePath', '$packagePath/$filePath']; 73 return ['$packagePath/lib/$filePath', '$packagePath/$filePath'];
52 } 74 }
53 } 75 }
OLDNEW
« no previous file with comments | « no previous file | lib/src/compiler/code_generator.dart » ('j') | lib/src/compiler/code_generator.dart » ('J')

Powered by Google App Engine
This is Rietveld 408576698