| Index: pkg/scheduled_test/lib/src/descriptor/utils.dart
 | 
| diff --git a/pkg/scheduled_test/lib/src/descriptor/utils.dart b/pkg/scheduled_test/lib/src/descriptor/utils.dart
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..f0d594cc429e5a6787bca9f68c81ce67c4c8cd33
 | 
| --- /dev/null
 | 
| +++ b/pkg/scheduled_test/lib/src/descriptor/utils.dart
 | 
| @@ -0,0 +1,53 @@
 | 
| +// Copyright (c) 2013, 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 descriptor.utils;
 | 
| +
 | 
| +import 'dart:io';
 | 
| +
 | 
| +import 'package:pathos/path.dart' as path;
 | 
| +
 | 
| +/// Returns a single filesystem entry within [parent] whose name matches
 | 
| +/// [pattern]. If [pattern] is a string, looks for an exact match; otherwise,
 | 
| +/// looks for an entry that contains [pattern].
 | 
| +///
 | 
| +/// If there are no entries in [parent] matching [pattern], or more than one,
 | 
| +/// this will throw an exception.
 | 
| +///
 | 
| +/// [type] is used for error reporting. It should be capitalized.
 | 
| +String entryMatchingPattern(String type, String parent, Pattern pattern) {
 | 
| +  if (pattern is String) {
 | 
| +    var path = path.join(parent, pattern);
 | 
| +    if (new File(path).existsSync() || new Directory(path).existsSync()) {
 | 
| +      return path;
 | 
| +    }
 | 
| +    throw "$type not found: '$path'.";
 | 
| +  }
 | 
| +
 | 
| +  var matchingEntries = new Directory(parent).listSync()
 | 
| +      .map((entry) => entry is File ? entry.fullPathSync() : entry.path)
 | 
| +      .where((entry) => entry.contains(pattern))
 | 
| +      .toList();
 | 
| +
 | 
| +  if (matchingEntries.length == 0) {
 | 
| +    throw "No entry found in '$parent' matching ${describePattern(pattern)}.";
 | 
| +  } else if (matchingEntries.length > 1) {
 | 
| +    throw "Multiple entries found in '$parent' matching "
 | 
| +          "${describePattern(pattern)}:\n"
 | 
| +      "${matchingEntries.map((entry) => '* $entry').join('\n')}";
 | 
| +  } else {
 | 
| +    return matchingEntries.first;
 | 
| +  }
 | 
| +}
 | 
| +
 | 
| +/// Returns a human-readable description of [pattern].
 | 
| +String describePattern(Pattern pattern) {
 | 
| +  if (pattern is String) return "'$pattern'";
 | 
| +  if (pattern is! RegExp) return '$pattern';
 | 
| +
 | 
| +  var flags = new StringBuffer();
 | 
| +  if (!pattern.isCaseSensitive) flags.add('i');
 | 
| +  if (pattern.isMultiLine) flags.add('m');
 | 
| +  return '/${pattern.pattern}/$flags';
 | 
| +}
 | 
| 
 |