如何将可选空格包围的字符串与SBT Parsers匹配

时间:2016-10-06 15:12:52

标签: scala parsing sbt

我尝试使用SBT Parsers(http://www.scala-sbt.org/0.13/docs/Parsing-Input.html)解析sbt InputTask的命令行参数但是我没有编写解析器以匹配以下伪正则表达式:

\w+(-n|--dry-run)\w+

这是我能想到的最明智的表达方式。如果输入字符串匹配,则此处的结果应为Some(true)

import sbt.complete.Parser
import sbt.complete.DefaultParsers._

val dryRunOptions: Parser[String] = OptSpace ~> ("-n" | "--dry-run") <~ OptSpace
val dryRunParser: Parser[Boolean] = flag(dryRunOptions)

Parser(dryRunParser)("-n").result
Parser(dryRunParser)(" -n").result
Parser(dryRunParser)("-n ").result
Parser(dryRunParser)(" -n ").result

Parser(dryRunParser)("--dry-run").result
Parser(dryRunParser)(" --dry-run").result
Parser(dryRunParser)("--dry-run ").result
Parser(dryRunParser)(" --dry-run ").result

不幸的是,这与任何这些情况都不匹配!

res0: Option[Boolean] = None
res1: Option[Boolean] = None
res2: Option[Boolean] = None
res3: Option[Boolean] = None

res4: Option[Boolean] = None
res5: Option[Boolean] = None
res6: Option[Boolean] = None
res7: Option[Boolean] = None

我可以通过几种变体来匹配其中几种情况,但绝不会全部。任何帮助表示赞赏!

1 个答案:

答案 0 :(得分:0)

您正在以错误的方式检查解析器的正确性。看起来在这种情况下,您应该使用.resultEmpty.isValid代替.result,例如tests here。然后发生你的代码正常工作:

import sbt.complete.Parser
import sbt.complete.DefaultParsers._

val dryRunOptions: Parser[String] = OptSpace ~> ("-n" | "--dry-run") <~ OptSpace
val dryRunParser: Parser[Boolean] = flag(dryRunOptions)

val test = Seq("-n", " -n", "-n ", " -n   ",
  "--dry-run", " --dry-run", "--dry-run ", " --dry-run   ")

test.foldLeft(true)((b:Boolean, input:String) =>
  b && Parser(dryRunParser)(input).resultEmpty.isValid)

结果:

res0: Boolean = true