aboutsummaryrefslogtreecommitdiff
path: root/stage1/resolver.scala
diff options
context:
space:
mode:
Diffstat (limited to 'stage1/resolver.scala')
-rw-r--r--stage1/resolver.scala15
1 files changed, 14 insertions, 1 deletions
diff --git a/stage1/resolver.scala b/stage1/resolver.scala
index 13d4070..0da8f6f 100644
--- a/stage1/resolver.scala
+++ b/stage1/resolver.scala
@@ -268,7 +268,10 @@ case class BoundMavenDependency(
classpath.strings.map(new File(_).lastModified).max
}
- private lazy val base = "/" + groupId.split("\\.").mkString("/") + "/" + artifactId + "/" + version + "/" + artifactId + "-" + version
+ private lazy val base = {
+ val v = BoundMavenDependency.extractVersion(version)
+ "/" + groupId.split("\\.").mkString("/") + "/" + artifactId + "/" + v + "/" + artifactId + "-" + v
+ }
protected[cbt] def basePath(useClassifier: Boolean) = // PERFORMANCE HOTSPOT
base + (if (useClassifier && classifier.name.nonEmpty) "-" + classifier.name.get else "")
@@ -421,6 +424,16 @@ case class BoundMavenDependency(
}
}
object BoundMavenDependency{
+ private lazy val versionRangeRegex = "^[\\[\\(]([^,\\]\\)]*)(,([^\\]\\)]*))?[\\]\\)]".r
+ def extractVersion( versionOrRange: String ) = {
+ versionOrRange match {
+ case versionRangeRegex(left,middle,right) if left != null || right != null => {
+ Option(left).filterNot(_ == "") getOrElse right
+ }
+ case version => version
+ }
+ }
+
val ValidIdentifier = "^([A-Za-z0-9_\\-.]+)$".r // according to maven's DefaultModelValidator.java
def semanticVersionLessThan(left: Array[Either[Int,String]], right: Array[Either[Int,String]]) = {
// FIXME: this ignores ends when different size