Skip to content

Commit

Permalink
Merge pull request #444 from desbo/fix-backslash-escaping
Browse files Browse the repository at this point in the history
Preserve backslashes in `expandMavenSettings`
  • Loading branch information
eed3si9n authored Jul 1, 2024
2 parents 8ab867d + 649b6df commit e63b6cc
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 7 deletions.
25 changes: 18 additions & 7 deletions core/src/main/scala/sbt/librarymanagement/ResolverExtra.scala
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,15 @@
*/
package sbt.librarymanagement

import java.io.{ IOException, File }
import java.io.{ File, IOException }
import java.net.{ URI, URL }
import scala.annotation.nowarn
import scala.xml.XML
import org.xml.sax.SAXParseException
import sbt.util.Logger

import java.net.URI
import scala.util.matching.Regex

final class RawRepository(val resolver: AnyRef, name: String) extends Resolver(name) {
override def toString = "Raw(" + resolver.toString + ")"
Expand Down Expand Up @@ -400,20 +402,29 @@ private[librarymanagement] abstract class ResolverFunctions {
def defaultRetrievePattern =
"[type]s/[organisation]/[module]/" + PluginPattern + "[artifact](-[revision])(-[classifier]).[ext]"
final val PluginPattern = "(scala_[scalaVersion]/)(sbt_[sbtVersion]/)"
private[librarymanagement] def expandMavenSettings(str: String): String = {

private[librarymanagement] def expandMavenSettings(
str: String,
envVars: Map[String, String] = sys.env,
props: Map[String, String] = sys.props.toMap
): String = {
// Aren't regular expressions beautifully clear and concise.
// This means "find all ${...}" blocks, with the first group of each being the text between curly brackets.
val findQuoted = "\\$\\{([^\\}]*)\\}".r
val findQuoted = "\\$\\{([^}]*)}".r
val env = "env\\.(.*)".r

findQuoted.replaceAllIn(
str,
_.group(1) match {
case env(variable) => sys.env.getOrElse(variable, "")
case property => sys.props.getOrElse(property, "")
}
regexMatch =>
Regex.quoteReplacement {
regexMatch.group(1) match {
case env(variable) => envVars.getOrElse(variable, "")
case property => props.getOrElse(property, "")
}
}
)
}

private[this] def mavenLocalDir: File = {
def loadHomeFromSettings(f: () => File): Option[File] =
try {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,13 @@ object ResolverExtraTest extends BasicTestSuite {
)
}

test("expandMavenSettings should preserve backslashes in environment variable values") {
val path = """C:\foo\bar\baz"""
val env = Map("SOME_PATH" -> path)

assert(Resolver.expandMavenSettings("${env.SOME_PATH}", env) == path)
}

// - Helper functions ----------------------------------------------------------------------------
// -----------------------------------------------------------------------------------------------
def assertExpansion(input: String, expected: String) =
Expand Down

0 comments on commit e63b6cc

Please sign in to comment.