diff options
Diffstat (limited to 'cli/source/main/scala/com/rockymadden/stringmetric/cli/similarity/jaccardmetric.scala')
-rwxr-xr-x | cli/source/main/scala/com/rockymadden/stringmetric/cli/similarity/jaccardmetric.scala | 57 |
1 files changed, 17 insertions, 40 deletions
diff --git a/cli/source/main/scala/com/rockymadden/stringmetric/cli/similarity/jaccardmetric.scala b/cli/source/main/scala/com/rockymadden/stringmetric/cli/similarity/jaccardmetric.scala index 5dee606..8301158 100755 --- a/cli/source/main/scala/com/rockymadden/stringmetric/cli/similarity/jaccardmetric.scala +++ b/cli/source/main/scala/com/rockymadden/stringmetric/cli/similarity/jaccardmetric.scala @@ -3,47 +3,24 @@ package com.rockymadden.stringmetric.cli.similarity import com.rockymadden.stringmetric.cli._ import com.rockymadden.stringmetric.similarity.JaccardMetric -/** - * The jaccardmetric [[com.rockymadden.stringmetric.cli.Command]]. Compares the similarity of two strings using the - * Jaccard coefficient. - */ -object jaccardmetric extends Command { - override def main(args: Array[String]): Unit = { - val opts: OptionMap = args - - try - if (opts.contains('h) || opts.contains('help)) { - help() - exit(opts) - } else if (opts.contains('dashless) && (opts('dashless): Array[String]).length == 2 - && opts.contains('n) && (opts('n): Int) >= 1) { - - execute(opts) - exit(opts) - } else throw new IllegalArgumentException("Expected valid syntax. See --help.") - catch { case e: Throwable => error(e, opts) } - } - - override def help(): Unit = { - val ls = sys.props("line.separator") - val tab = " " - - println( - "Compares the similarity of two strings using the Jaccard coefficient." + ls + ls + - "Syntax:" + ls + - tab + "jaccardmetric [Options] string1 string2..." + ls + ls + - "Options:" + ls + - tab + "-h, --help" + ls + - tab + tab + "Outputs description, syntax, and opts." + - tab + "--n" + ls + - tab + tab + "The n-gram size." - ) - } - - override def execute(opts: OptionMap): Unit = { +case object jaccardmetric extends Command( + (opts) => + "Compares the similarity of two strings using the Jaccard coefficient." + Ls + Ls + + "Syntax:" + Ls + + Tab + "jaccardmetric [Options] string1 string2..." + Ls + Ls + + "Options:" + Ls + + Tab + "-h, --help" + Ls + + Tab + Tab + "Outputs description, syntax, and opts." + + Tab + "--n" + Ls + + Tab + Tab + "The n-gram size.", + (opts) => opts.contains('dashless) && (opts('dashless): Array[String]).length == 2 + && opts.contains('n) && (opts('n): Int) >= 1, + (opts) => { val strings: Array[String] = opts('dashless) val n: Int = opts('n) - println(JaccardMetric(n).compare(strings(0), strings(1)).getOrElse("not comparable")) + JaccardMetric(n).compare(strings(0), strings(1)) + .map(_.toString) + .getOrElse("not comparable") } -} +) |