Skip to content

Commit

Permalink
try some more memoize
Browse files Browse the repository at this point in the history
  • Loading branch information
winitzki committed Jul 20, 2024
1 parent 3ca1519 commit d0ea8b1
Show file tree
Hide file tree
Showing 2 changed files with 4 additions and 2 deletions.
1 change: 1 addition & 0 deletions how_to_deduplicate_strings.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
java -Xlog:stringdedup*=debug -XX:+UseG1GC -XX:+UseStringDeduplication -jar dhall.jar --file scall-cli/src/test/resources/yaml-perftest/create_yaml.dhall yaml
5 changes: 3 additions & 2 deletions scall-core/src/main/scala/io/chymyst/dhall/Grammar.scala
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,7 @@ object Grammar {
| (escaped_interpolation ~ single_quote_continue).map { case (a, b) => a ++ b }
| P("''").map(_ => TextLiteral.empty) // End of text literal.
| (single_quote_char ~ single_quote_continue).map { case (char, tail) => TextLiteral.ofString[Expression](char) ++ tail }
)// Do not memoize here: stack overflow!
) // Do not memoize here: stack overflow!

def escaped_quote_pair[$: P]: P[TextLiteral[Expression]] = P(
"'''".!.map(_ => TextLiteral.ofString(s"''"))
Expand Down Expand Up @@ -419,6 +419,7 @@ object Grammar {
//def keywordOrBuiltin[$: P]: P[String] = concatKeywords(simpleKeywords ++ builtinSymbolNames)

def keyword[$: P]: P[String] = concatKeywords(simpleKeywords)
.memoize

val builtinSymbolNames = SyntaxConstants.Builtin.namesToValuesMap.keys.toSeq
val builtinSymbolNamesSet = SyntaxConstants.Builtin.namesToValuesMap.keySet
Expand All @@ -434,7 +435,7 @@ object Grammar {
(concatKeywords(builtinSymbolNames).map(SyntaxConstants.Builtin.withName).map(ExprBuiltin)
| concatKeywords(constantSymbolNames).map(SyntaxConstants.Constant.withName).map(ExprConstant)
).map(Expression.apply)
}
}.memoize

def combine[$: P] = P(
"\u2227" | "/\\"
Expand Down

0 comments on commit d0ea8b1

Please sign in to comment.