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

Unified Diff: packages/analyzer/lib/source/path_filter.dart

Issue 1400473008: Roll Observatory packages and add a roll script (Closed) Base URL: git@github.com:dart-lang/observatory_pub_packages.git@master
Patch Set: Created 5 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: packages/analyzer/lib/source/path_filter.dart
diff --git a/packages/analyzer/lib/source/path_filter.dart b/packages/analyzer/lib/source/path_filter.dart
new file mode 100644
index 0000000000000000000000000000000000000000..40e81a63427386a08c82af332d72ce753678e0b9
--- /dev/null
+++ b/packages/analyzer/lib/source/path_filter.dart
@@ -0,0 +1,76 @@
+// Copyright (c) 2015, 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 source.path_filter;
+
+import 'package:glob/glob.dart' as glob;
+import 'package:path/path.dart' as path;
+
+/// Filter paths against a set of [ignorePatterns] relative to a [root]
+/// directory. Paths outside of [root] are also ignored.
+class PathFilter {
+ /// The path context to use when manipulating paths.
+ final path.Context pathContext;
+
+ /// Path that all ignore patterns are relative to.
+ final String root;
+
+ /// List of ignore patterns that paths are tested against.
+ final List<glob.Glob> _ignorePatterns = new List<glob.Glob>();
+
+ /// Construct a new path filter rooted at [root] with [ignorePatterns].
+ /// If [pathContext] is not specified, then the system path context is used.
+ PathFilter(this.root, List<String> ignorePatterns, [path.Context pathContext])
+ : this.pathContext = pathContext != null ? pathContext : path.context {
+ setIgnorePatterns(ignorePatterns);
+ }
+
+ /// Returns true if [path] should be ignored. A path is ignored if it is not
+ /// contained in [root] or matches one of the ignore patterns.
+ /// [path] is absolute or relative to [root].
+ bool ignored(String path) {
+ path = _canonicalize(path);
+ return !_contained(path) || _match(path);
+ }
+
+ /// Set the ignore patterns.
+ void setIgnorePatterns(List<String> ignorePatterns) {
+ _ignorePatterns.clear();
+ if (ignorePatterns != null) {
+ for (var ignorePattern in ignorePatterns) {
+ _ignorePatterns.add(new glob.Glob(ignorePattern));
+ }
+ }
+ }
+
+ /// Returns the absolute path of [path], relative to [root].
+ String _canonicalize(String path) =>
+ pathContext.normalize(pathContext.join(root, path));
+
+ /// Returns true when [path] is contained inside [root].
+ bool _contained(String path) => path.startsWith(root);
+
+ /// Returns true if [path] matches any ignore patterns.
+ bool _match(String path) {
+ path = _relative(path);
+ for (var glob in _ignorePatterns) {
+ if (glob.matches(path)) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ /// Returns the relative portion of [path] from [root].
+ String _relative(String path) => pathContext.relative(path, from: root);
+
+ String toString() {
+ StringBuffer sb = new StringBuffer();
+ for (var pattern in _ignorePatterns) {
+ sb.write('$pattern ');
+ }
+ sb.writeln('');
+ return sb.toString();
+ }
+}
« no previous file with comments | « packages/analyzer/lib/source/package_map_resolver.dart ('k') | packages/analyzer/lib/source/pub_package_map_provider.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698