| Index: pkg/kernel/lib/application_root.dart
|
| diff --git a/pkg/kernel/lib/application_root.dart b/pkg/kernel/lib/application_root.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..a65d8dd0bf12c4ce1c58daa5f6242877be678f75
|
| --- /dev/null
|
| +++ b/pkg/kernel/lib/application_root.dart
|
| @@ -0,0 +1,45 @@
|
| +// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +library kernel.application_root;
|
| +
|
| +import 'package:path/path.dart' as pathlib;
|
| +
|
| +/// Resolves URIs with the `app` scheme.
|
| +///
|
| +/// These are used internally in kernel to represent file paths relative to
|
| +/// some application root. This is done to avoid storing irrelevant paths, such
|
| +/// as the path to the home directory of the user who compiled a given file.
|
| +class ApplicationRoot {
|
| + static const String scheme = 'app';
|
| +
|
| + final String path;
|
| +
|
| + ApplicationRoot(this.path) {
|
| + assert(path == null || pathlib.isAbsolute(path));
|
| + }
|
| +
|
| + ApplicationRoot.none() : path = null;
|
| +
|
| + /// Converts `app` URIs to absolute `file` URIs.
|
| + Uri absoluteUri(Uri uri) {
|
| + if (path == null) return uri;
|
| + if (uri.scheme == ApplicationRoot.scheme) {
|
| + return new Uri(scheme: 'file', path: pathlib.join(this.path, uri.path));
|
| + } else {
|
| + return uri;
|
| + }
|
| + }
|
| +
|
| + /// Converts `file` URIs to `app` URIs.
|
| + Uri relativeUri(Uri uri) {
|
| + if (path == null) return uri;
|
| + if (uri.scheme == 'file' && pathlib.isWithin(this.path, uri.path)) {
|
| + return new Uri(
|
| + scheme: ApplicationRoot.scheme,
|
| + path: pathlib.relative(uri.path, from: this.path));
|
| + } else {
|
| + return uri;
|
| + }
|
| + }
|
| +}
|
|
|