| Index: utils/pub/repo_source.dart | 
| diff --git a/utils/pub/repo_source.dart b/utils/pub/repo_source.dart | 
| deleted file mode 100644 | 
| index 241ea348b3a2b79922aaedd1b0fcbff3281f37d4..0000000000000000000000000000000000000000 | 
| --- a/utils/pub/repo_source.dart | 
| +++ /dev/null | 
| @@ -1,140 +0,0 @@ | 
| -// Copyright (c) 2012, 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('dartlang_source'); | 
| - | 
| -#import('dart:io'); | 
| -#import('dart:json'); | 
| -#import('dart:uri'); | 
| -#import('io.dart'); | 
| -#import('package.dart'); | 
| -#import('pubspec.dart'); | 
| -#import('source.dart'); | 
| -#import('source_registry.dart'); | 
| -#import('utils.dart'); | 
| -#import('version.dart'); | 
| - | 
| -/** | 
| - * A package source that installs packages from a package repository that uses | 
| - * the same API as pub.dartlang.org. | 
| - */ | 
| -class RepoSource extends Source { | 
| -  final String name = "repo"; | 
| - | 
| -  final bool shouldCache = true; | 
| - | 
| -  // TODO(nweiz): update this comment once pub.dartlang.org is online | 
| -  /** | 
| -   * The URL of the default package repository. | 
| -   * | 
| -   * At time of writing, pub.dartlang.org is not yet online, but it should be | 
| -   * soon. | 
| -   */ | 
| -  static final String defaultUrl = "http://pub.dartlang.org"; | 
| - | 
| -  RepoSource(); | 
| - | 
| -  /** | 
| -   * Downloads a list of all versions of a package that have been uploaded to | 
| -   * pub.dartlang.org. | 
| -   */ | 
| -  Future<List<Version>> getVersions(description) { | 
| -    var parsed = _parseDescription(description); | 
| -    var fullUrl = "${parsed.last}/packages/${parsed.first}.json"; | 
| -    return consumeInputStream(httpGet(fullUrl)).transform((data) { | 
| -      var doc = JSON.parse(new String.fromCharCodes(data)); | 
| -      return doc['versions'].map((version) => new Version.parse(version)); | 
| -    }); | 
| -  } | 
| - | 
| -  /** | 
| -   * Downloads and parses the pubspec for a specific version of a package that | 
| -   * has been uploaded to pub.dartlang.org. | 
| -   */ | 
| -  Future<Pubspec> describe(PackageId id) { | 
| -    var parsed = _parseDescription(id.description); | 
| -    var fullUrl = "${parsed.last}/packages/${parsed.first}/versions/" | 
| -      "${id.version}.yaml"; | 
| -    return consumeInputStream(httpGet(fullUrl)).transform((data) { | 
| -      return new Pubspec.parse( | 
| -          new String.fromCharCodes(data), systemCache.sources); | 
| -    }); | 
| -  } | 
| - | 
| -  /** | 
| -   * Downloads a package from a package repository and unpacks it. | 
| -   */ | 
| -  Future<bool> install(PackageId id, String destPath) { | 
| -    var parsedDescription = _parseDescription(id.description); | 
| -    var name = parsedDescription.first; | 
| -    var url = parsedDescription.last; | 
| - | 
| -    return ensureDir(destPath).chain((destDir) { | 
| -      var fullUrl = "$url/packages/$name/versions/${id.version}.tar.gz"; | 
| -      return extractTarGz(httpGet(fullUrl), destDir); | 
| -    }); | 
| -  } | 
| - | 
| -  /** | 
| -   * The system cache directory for the repo source contains subdirectories for | 
| -   * each separate repository URL that's used on the system. Each of these | 
| -   * subdirectories then contains a subdirectory for each package installed from | 
| -   * that repository. | 
| -   */ | 
| -  String systemCacheDirectory(PackageId id) { | 
| -    var parsed = _parseDescription(id.description); | 
| -    var url = parsed.last.replaceAll(new RegExp(@"^https?://"), ""); | 
| -    var urlDir = replace(url, new RegExp(@'[<>:"\\/|?*%]'), (match) { | 
| -      return '%${match[0].charCodeAt(0)}'; | 
| -    }); | 
| -    return join(systemCacheRoot, urlDir, "${parsed.first}-${id.version}"); | 
| -  } | 
| - | 
| -  String packageName(description) => _parseDescription(description).first; | 
| - | 
| -  bool descriptionsEqual(description1, description2) => | 
| -    _parseDescription(description1) == _parseDescription(description2); | 
| - | 
| -  /** | 
| -   * Ensures that [description] is a valid repo description. | 
| -   * | 
| -   * There are two valid formats. A plain string refers to a package with the | 
| -   * given name from the default repository, while a map with keys "name" and | 
| -   * "url" refers to a package with the given name from the repo at the given | 
| -   * URL. | 
| -   */ | 
| -  void validateDescription(description, [bool fromLockFile=false]) { | 
| -    _parseDescription(description); | 
| -  } | 
| - | 
| -  /** | 
| -   * Parses the description blob for a package. | 
| -   * | 
| -   * If the package parses correctly, this returns a (name, url) pair. If not, | 
| -   * this throws a descriptive FormatException. | 
| -   */ | 
| -  Pair<String, String> _parseDescription(description) { | 
| -    if (description is String) { | 
| -      return new Pair<String, String>(description, defaultUrl); | 
| -    } | 
| - | 
| -    if (description is! Map) { | 
| -      throw new FormatException( | 
| -          "The description must be a package name or map."); | 
| -    } | 
| - | 
| -    if (!description.containsKey("name")) { | 
| -      throw new FormatException( | 
| -          "The description map must contain a 'name' key."); | 
| -    } | 
| - | 
| -    var name = description["name"]; | 
| -    if (name is! String) { | 
| -      throw new FormatException("The 'name' key must have a string value."); | 
| -    } | 
| - | 
| -    var url = description.containsKey("url") ? description["url"] : defaultUrl; | 
| -    return new Pair<String, String>(name, url); | 
| -  } | 
| -} | 
|  |