mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-04-22 19:22:50 -06:00
change the PGF.Data.Exp type
This commit is contained in:
@@ -149,10 +149,9 @@ allCommands mgr = Map.fromAscList [
|
||||
gr = gfcc mgr
|
||||
|
||||
fromTrees ts = (ts,unlines (map showTree ts))
|
||||
fromStrings ss = (map tStr ss, unlines ss)
|
||||
fromString s = ([tStr s], s)
|
||||
toStrings ts = [s | DTr [] (AS s) [] <- ts]
|
||||
tStr s = DTr [] (AS s) []
|
||||
fromStrings ss = (map EStr ss, unlines ss)
|
||||
fromString s = ([EStr s], s)
|
||||
toStrings ts = [s | EStr s <- ts]
|
||||
|
||||
prGrammar opts = case valIdOpts "printer" "" opts of
|
||||
"cats" -> unwords $ categories mgr
|
||||
|
||||
@@ -1,39 +1,26 @@
|
||||
module GF.Command.PPrTree (pTree, prExp, tree2exp) where
|
||||
module GF.Command.PPrTree (tree2exp, exp2tree) where
|
||||
|
||||
import PGF.CId
|
||||
import PGF.Data
|
||||
import PGF.Macros
|
||||
import qualified GF.Command.ParGFShell as P
|
||||
import GF.Command.PrintGFShell
|
||||
import GF.Command.AbsGFShell
|
||||
import GF.Data.ErrM
|
||||
|
||||
pTree :: String -> Exp
|
||||
pTree s = case P.pTree (P.myLexer s) of
|
||||
Ok t -> tree2exp t
|
||||
Bad s -> error s
|
||||
|
||||
tree2exp t = case t of
|
||||
TApp f ts -> tree (AC (i2i f)) (map tree2exp ts)
|
||||
TAbs xs t -> DTr (map i2i xs ++ ys) f ts where DTr ys f ts = tree2exp t
|
||||
TId c -> tree (AC (i2i c)) []
|
||||
TInt i -> tree (AI i) []
|
||||
TStr s -> tree (AS s) []
|
||||
TFloat d -> tree (AF d) []
|
||||
TApp f ts -> EApp (i2i f) (map tree2exp ts)
|
||||
TAbs xs t -> EAbs (map i2i xs) (tree2exp t)
|
||||
TId c -> EApp (i2i c) []
|
||||
TInt i -> EInt i
|
||||
TStr s -> EStr s
|
||||
TFloat d -> EFloat d
|
||||
where
|
||||
i2i (Ident s) = mkCId s
|
||||
|
||||
prExp :: Exp -> String
|
||||
prExp = printTree . exp2tree
|
||||
|
||||
exp2tree (DTr xs at ts) = tabs (map i4i xs) (tapp at (map exp2tree ts))
|
||||
exp2tree t = case t of
|
||||
(EAbs xs e) -> TAbs (map i4i xs) (exp2tree e)
|
||||
(EApp f []) -> TId (i4i f)
|
||||
(EApp f es) -> TApp (i4i f) (map exp2tree es)
|
||||
(EInt i) -> TInt i
|
||||
(EStr i) -> TStr i
|
||||
(EFloat i) -> TFloat i
|
||||
(EMeta i) -> TId (Ident "?") ----
|
||||
where
|
||||
tabs [] t = t
|
||||
tabs ys t = TAbs ys t
|
||||
tapp (AC f) [] = TId (i4i f)
|
||||
tapp (AC f) vs = TApp (i4i f) vs
|
||||
tapp (AI i) [] = TInt i
|
||||
tapp (AS i) [] = TStr i
|
||||
tapp (AF i) [] = TFloat i
|
||||
tapp (AM i) [] = TId (Ident "?") ----
|
||||
i4i s = Ident (prCId s)
|
||||
|
||||
Reference in New Issue
Block a user