diff -r 1e6eca42d90b -r 8778d23fef92 cw5_marking/c2.sc --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/cw5_marking/c2.sc Mon Feb 03 12:34:38 2025 +0000 @@ -0,0 +1,24 @@ +// for testing tokenisation + +import scala.util.{Try, Success, Failure} +import $file.cw05_add +import cw05_add._ + +// programs to test (and number of toplevel definitions) +val uprogs = List(("fact.fun", 5), + ("hanoi.fun", 2), + ("mand.fun", 11), + ("sqr.fun", 4)) + +for ((file, no) <- uprogs) { + + print(s"Testing Parsing of $file ") + val str = os.read(os.pwd / file) + + + Try(test_string(str).length) match { + case Success(v) if v == no => println(s"--> Success. Parsed $no top-level definitions.") + case Success(v) => println(s"--> Success? Parsed $v top-level definitions (should be $no).")// ; throw new Exception("Different") + case Failure(e) => println(s"--> FAIL. Exception raised.") ; throw(e) + } +}