| OLD | NEW |
| 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 library file_system; | 5 library file_system; |
| 6 | 6 |
| 7 import 'dart:async'; | 7 import 'dart:async'; |
| 8 | 8 |
| 9 import 'package:analyzer/src/generated/source.dart'; | 9 import 'package:analyzer/src/generated/source.dart'; |
| 10 import 'package:analyzer/src/util/absolute_path.dart'; | 10 import 'package:analyzer/src/util/absolute_path.dart'; |
| 11 import 'package:path/path.dart'; | 11 import 'package:path/path.dart'; |
| 12 import 'package:watcher/watcher.dart'; | 12 import 'package:watcher/watcher.dart'; |
| 13 | 13 |
| 14 /** | 14 /** |
| 15 * [File]s are leaf [Resource]s which contain data. | 15 * [File]s are leaf [Resource]s which contain data. |
| 16 */ | 16 */ |
| 17 abstract class File extends Resource { | 17 abstract class File implements Resource { |
| 18 /** | 18 /** |
| 19 * Watch for changes to this file | 19 * Watch for changes to this file |
| 20 */ | 20 */ |
| 21 Stream<WatchEvent> get changes; | 21 Stream<WatchEvent> get changes; |
| 22 | 22 |
| 23 /** | 23 /** |
| 24 * Return the last-modified stamp of the file. | 24 * Return the last-modified stamp of the file. |
| 25 * Throws [FileSystemException] if the file does not exist. | 25 * Throws [FileSystemException] if the file does not exist. |
| 26 */ | 26 */ |
| 27 int get modificationStamp; | 27 int get modificationStamp; |
| (...skipping 18 matching lines...) Expand all Loading... |
| 46 final String message; | 46 final String message; |
| 47 | 47 |
| 48 FileSystemException(this.path, this.message); | 48 FileSystemException(this.path, this.message); |
| 49 | 49 |
| 50 String toString() => 'FileSystemException(path=$path; message=$message)'; | 50 String toString() => 'FileSystemException(path=$path; message=$message)'; |
| 51 } | 51 } |
| 52 | 52 |
| 53 /** | 53 /** |
| 54 * [Folder]s are [Resource]s which may contain files and/or other folders. | 54 * [Folder]s are [Resource]s which may contain files and/or other folders. |
| 55 */ | 55 */ |
| 56 abstract class Folder extends Resource { | 56 abstract class Folder implements Resource { |
| 57 /** | 57 /** |
| 58 * Watch for changes to the files inside this folder (and in any nested | 58 * Watch for changes to the files inside this folder (and in any nested |
| 59 * folders, including folders reachable via links). | 59 * folders, including folders reachable via links). |
| 60 */ | 60 */ |
| 61 Stream<WatchEvent> get changes; | 61 Stream<WatchEvent> get changes; |
| 62 | 62 |
| 63 /** | 63 /** |
| 64 * If the path [path] is a relative path, convert it to an absolute path | 64 * If the path [path] is a relative path, convert it to an absolute path |
| 65 * by interpreting it relative to this folder. If it is already an aboslute | 65 * by interpreting it relative to this folder. If it is already an aboslute |
| 66 * path, then don't change it. | 66 * path, then don't change it. |
| (...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 201 | 201 |
| 202 @override | 202 @override |
| 203 Uri restoreAbsolute(Source source) => | 203 Uri restoreAbsolute(Source source) => |
| 204 _provider.pathContext.toUri(source.fullName); | 204 _provider.pathContext.toUri(source.fullName); |
| 205 | 205 |
| 206 /** | 206 /** |
| 207 * Return `true` if the given [uri] is a `file` URI. | 207 * Return `true` if the given [uri] is a `file` URI. |
| 208 */ | 208 */ |
| 209 static bool _isFileUri(Uri uri) => uri.scheme == _FILE_SCHEME; | 209 static bool _isFileUri(Uri uri) => uri.scheme == _FILE_SCHEME; |
| 210 } | 210 } |
| OLD | NEW |