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

Side by Side Diff: pkg/scheduled_test/lib/src/descriptor/utils.dart

Issue 12330062: Add a filesystem descriptor library to scheduled_test. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 10 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
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.
4
5 library descriptor.utils;
6
7 import 'dart:io';
8
9 import 'package:path/path.dart' as path;
10
11 /// Returns a single filesystem entry within [parent] whose name matches
12 /// [pattern]. If [pattern] is a string, looks for an exact match; otherwise,
13 /// looks for an entry that contains [pattern].
14 ///
15 /// If there are no entries in [parent] matching [pattern], or more than one,
16 /// this will throw an exception.
17 String entryMatchingPattern(String parent, Pattern pattern) {
18 if (pattern is String) {
19 var path = path.join(parent, pattern);
20 if (new File(path).existsSync() || new Directory(path).existsSync()) {
21 return path;
22 }
23 throw "Entry not found: '$path'.";
24 }
25
26 var matchingEntries = new Directory(parent).listSync()
Bob Nystrom 2013/02/22 17:58:21 Yay listSync()!
27 .map((entry) => entry is File ? entry.fullPathSync() : entry.path)
28 .where((entry) => entry.contains(pattern))
29 .toList();
30
31 if (matchingEntries.length == 0) {
32 throw "No entry found in '$parent' matching ${describePattern(pattern)}.";
33 } else if (matchingEntries.length > 1) {
34 throw "Multiple entries found in '$parent' matching "
35 "${describePattern(pattern)}:\n"
36 "${matchingEntries.map((entry) => '* $entry').join('\n')}";
37 } else {
38 return matchingEntries.first;
39 }
40 }
41
42 /// Returns a human-readable description of [pattern].
43 String describePattern(Pattern pattern) {
44 if (pattern is String) return "'$pattern'";
Bob Nystrom 2013/02/22 17:58:21 Do you care about escaping quotes here?
nweiz 2013/02/22 20:57:20 I'd *like* to escape enough stuff that it's a vali
45 if (pattern is! RegExp) return '$pattern';
46
47 var flags = new StringBuffer();
48 if (!pattern.isCaseSensitive) flags.add('i');
49 if (pattern.isMultiLine) flags.add('m');
50 return '/${pattern.pattern}/$flags';
51 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698