summaryrefslogtreecommitdiff
path: root/src/runtime/haskell/PGF/Optimize.hs
diff options
context:
space:
mode:
Diffstat (limited to 'src/runtime/haskell/PGF/Optimize.hs')
-rw-r--r--src/runtime/haskell/PGF/Optimize.hs10
1 files changed, 7 insertions, 3 deletions
diff --git a/src/runtime/haskell/PGF/Optimize.hs b/src/runtime/haskell/PGF/Optimize.hs
index a339c9add..f04a8b04c 100644
--- a/src/runtime/haskell/PGF/Optimize.hs
+++ b/src/runtime/haskell/PGF/Optimize.hs
@@ -221,9 +221,13 @@ splitLexicalRules cnc p_prods =
wf ts = (ts,IntSet.singleton funid)
- seq2prefix [] = TrieMap.fromList [wf []]
- seq2prefix (SymKS ts :syms) = TrieMap.fromList [wf ts]
- seq2prefix (SymKP ts alts:syms) = TrieMap.fromList (wf ts : [wf ts | Alt ts ps <- alts])
+ seq2prefix [] = TrieMap.fromList [wf []]
+ seq2prefix (SymKS t :syms) = TrieMap.fromList [wf [t]]
+ seq2prefix (SymKP syms0 alts:syms) = TrieMap.unionsWith IntSet.union
+ (seq2prefix (syms0++syms) :
+ [seq2prefix (syms1 ++ syms) | (syms1,ps) <- alts])
+ seq2prefix (SymNE :syms) = TrieMap.empty
+ seq2prefix (SymBIND :syms) = TrieMap.fromList [wf ["&+"]]
updateConcrete abs cnc =
let p_prods0 = filterProductions IntMap.empty IntSet.empty (productions cnc)