Index: package_config/lib/src/util.dart |
diff --git a/package_config/lib/src/util.dart b/package_config/lib/src/util.dart |
deleted file mode 100644 |
index badf64086da8308f16d6aba0d169a42a2da7e7c4..0000000000000000000000000000000000000000 |
--- a/package_config/lib/src/util.dart |
+++ /dev/null |
@@ -1,97 +0,0 @@ |
-// 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. |
- |
-/// Utility methods used by more than one library in the package. |
-library package_config.util; |
- |
-import "package:charcode/ascii.dart"; |
- |
-// All ASCII characters that are valid in a package name, with space |
-// for all the invalid ones (including space). |
-const String _validPackageNameCharacters = |
- r" ! $ &'()*+,-. 0123456789 ; = " |
- r"@ABCDEFGHIJKLMNOPQRSTUVWXYZ _ abcdefghijklmnopqrstuvwxyz ~ "; |
- |
-/// Tests whether something is a valid Dart package name. |
-bool isValidPackageName(String string) { |
- return _findInvalidCharacter(string) < 0; |
-} |
- |
-/// Check if a string is a valid package name. |
-/// |
-/// Valid package names contain only characters in [_validPackageNameCharacters] |
-/// and must contain at least one non-'.' character. |
-/// |
-/// Returns `-1` if the string is valid. |
-/// Otherwise returns the index of the first invalid character, |
-/// or `string.length` if the string contains no non-'.' character. |
-int _findInvalidCharacter(String string) { |
- // Becomes non-zero if any non-'.' character is encountered. |
- int nonDot = 0; |
- for (int i = 0; i < string.length; i++) { |
- var c = string.codeUnitAt(i); |
- if (c > 0x7f || _validPackageNameCharacters.codeUnitAt(c) <= $space) { |
- return i; |
- } |
- nonDot += c ^ $dot; |
- } |
- if (nonDot == 0) return string.length; |
- return -1; |
-} |
- |
-/// Validate that a Uri is a valid package:URI. |
-String checkValidPackageUri(Uri packageUri) { |
- if (packageUri.scheme != "package") { |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Not a package: URI"); |
- } |
- if (packageUri.hasAuthority) { |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package URIs must not have a host part"); |
- } |
- if (packageUri.hasQuery) { |
- // A query makes no sense if resolved to a file: URI. |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package URIs must not have a query part"); |
- } |
- if (packageUri.hasFragment) { |
- // We could leave the fragment after the URL when resolving, |
- // but it would be odd if "package:foo/foo.dart#1" and |
- // "package:foo/foo.dart#2" were considered different libraries. |
- // Keep the syntax open in case we ever get multiple libraries in one file. |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package URIs must not have a fragment part"); |
- } |
- if (packageUri.path.startsWith('/')) { |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package URIs must not start with a '/'"); |
- } |
- int firstSlash = packageUri.path.indexOf('/'); |
- if (firstSlash == -1) { |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package URIs must start with the package name followed by a '/'"); |
- } |
- String packageName = packageUri.path.substring(0, firstSlash); |
- int badIndex = _findInvalidCharacter(packageName); |
- if (badIndex >= 0) { |
- if (packageName.isEmpty) { |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package names mus be non-empty"); |
- } |
- if (badIndex == packageName.length) { |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package names must contain at least one non-'.' character"); |
- } |
- assert(badIndex < packageName.length); |
- int badCharCode = packageName.codeUnitAt(badIndex); |
- var badChar = "U+" + badCharCode.toRadixString(16).padLeft(4, '0'); |
- if (badCharCode >= 0x20 && badCharCode <= 0x7e) { |
- // Printable character. |
- badChar = "'${packageName[badIndex]}' ($badChar)"; |
- } |
- throw new ArgumentError.value(packageUri, "packageUri", |
- "Package names must not contain $badChar"); |
- } |
- return packageName; |
-} |