summaryrefslogtreecommitdiff
path: root/src/GF/Canon
diff options
context:
space:
mode:
authoraarne <unknown>2005-02-08 15:35:58 +0000
committeraarne <unknown>2005-02-08 15:35:58 +0000
commit4fd0c636f8590bf800715f2598e54ccc22c99b90 (patch)
tree6415ac64c06f2cf27bce3b5b154eeb58f18d3776 /src/GF/Canon
parent6fe9cca0ff4f0730de4f254482cb68ce494f58d7 (diff)
unlexer concat
Diffstat (limited to 'src/GF/Canon')
-rw-r--r--src/GF/Canon/Share.hs33
1 files changed, 17 insertions, 16 deletions
diff --git a/src/GF/Canon/Share.hs b/src/GF/Canon/Share.hs
index ff9be59b2..a5a5f5349 100644
--- a/src/GF/Canon/Share.hs
+++ b/src/GF/Canon/Share.hs
@@ -18,6 +18,7 @@ import AbsGFC
import Ident
import GFC
import qualified CMacros as C
+import PrGrammar (prt)
import Operations
import List
import qualified Modules as M
@@ -39,15 +40,15 @@ shareModule opt (i,m) = case m of
(i,M.ModMod (M.Module mt st fs me ops (mapTree (shareInfo opt) js)))
_ -> (i,m)
-shareInfo opt (c, CncCat ty t m) = (c, CncCat ty (shareOptim opt t) m)
-shareInfo opt (c, CncFun k xs t m) = (c, CncFun k xs (shareOptim opt t) m)
+shareInfo opt (c, CncCat ty t m) = (c, CncCat ty (shareOptim opt c t) m)
+shareInfo opt (c, CncFun k xs t m) = (c, CncFun k xs (shareOptim opt c t) m)
shareInfo _ i = i
-- the function putting together optimizations
-shareOptim :: OptSpec -> Term -> Term
-shareOptim opt
- | doOptFactor opt && doOptValues opt = values . factor 0
- | doOptFactor opt = share . factor 0
+shareOptim :: OptSpec -> Ident -> Term -> Term
+shareOptim opt c
+ | doOptFactor opt && doOptValues opt = values . factor c 0
+ | doOptFactor opt = share . factor c 0
| doOptValues opt = values
| otherwise = share
@@ -80,22 +81,22 @@ share t = case t of
-- do even more: factor parametric branches
-factor :: Int -> Term -> Term
-factor i t = case t of
+factor :: Ident -> Int -> Term -> Term
+factor c i t = case t of
T _ [_] -> t
T _ [] -> t
- T ty cs -> T ty $ factors i [Cas [p] (factor (i+1) v) | Cas ps v <- cs, p <- ps]
- R lts -> R [Ass l (factor i t) | Ass l t <- lts]
- P t l -> P (factor i t) l
- S t a -> S (factor i t) (factor i a)
- C t a -> C (factor i t) (factor i a)
- FV ts -> FV (map (factor i) ts)
+ T ty cs -> T ty $ factors i [Cas [p] (factor c (i+1) v) | Cas ps v <- cs, p <- ps]
+ R lts -> R [Ass l (factor c i t) | Ass l t <- lts]
+ P t l -> P (factor c i t) l
+ S t a -> S (factor c i t) (factor c i a)
+ C t a -> C (factor c i t) (factor c i a)
+ FV ts -> FV (map (factor c i) ts)
_ -> t
where
factors i psvs = -- we know psvs has at least 2 elements
- let p = pIdent i
+ let p = pIdent c i
vs' = map (mkFun p) psvs
in if allEqs vs'
then mkCase p vs'
@@ -107,7 +108,7 @@ factor i t = case t of
mkCase p (v:_) = [Cas [PV p] v]
-pIdent i = identC ("p__" ++ show i)
+pIdent c i = identC ("p_" ++ prt c ++ "__" ++ show i)
-- we need to replace subterms