forked from GitHub/gf-core
remove FCFG folder
This commit is contained in:
@@ -1,82 +0,0 @@
|
||||
module GF.FCFG.AbsFCFG where
|
||||
|
||||
-- Haskell module generated by the BNF converter
|
||||
|
||||
newtype Ident = Ident String deriving (Eq,Ord,Show)
|
||||
data FGrammar =
|
||||
FGr [FRule]
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data FRule =
|
||||
FR Abstract [[FSymbol]]
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Abstract =
|
||||
Abs FCat [FCat] Name
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data FSymbol =
|
||||
FSymCat FCat Integer Integer
|
||||
| FSymTok String
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data FCat =
|
||||
FC Integer Ident [[PathEl]] [PathTerm]
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data PathEl =
|
||||
PLabel Label
|
||||
| PTerm Term
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data PathTerm =
|
||||
PtT [PathEl] Term
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Name =
|
||||
Nm Ident [Profile]
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Profile =
|
||||
Unify [Integer]
|
||||
| Const Forest
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Forest =
|
||||
FMeta
|
||||
| FNode Ident [[Forest]]
|
||||
| FString String
|
||||
| FInt Integer
|
||||
| FFloat Double
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Term =
|
||||
Arg Integer Ident [PathEl]
|
||||
| Constr CIdent [Term]
|
||||
| Rec [Assoc]
|
||||
| Proj Term Label
|
||||
| Tbl [Case]
|
||||
| Select Term Term
|
||||
| Vars [Term]
|
||||
| Concat Term Term
|
||||
| Tok String
|
||||
| Empty
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Case =
|
||||
Cas Term Term
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Assoc =
|
||||
Ass Label Term
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data Label =
|
||||
L Ident
|
||||
| LV Integer
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
data CIdent =
|
||||
CIQ Ident Ident
|
||||
deriving (Eq,Ord,Show)
|
||||
|
||||
@@ -1,131 +0,0 @@
|
||||
-- a portable format for FCFG (Peter Ljunglöf's MCFG modified by Krasimir Anglelov)
|
||||
-- Aarne Ranta September 2006
|
||||
|
||||
FGr. FGrammar ::= [FRule] ;
|
||||
FR. FRule ::= Abstract ":=" [[FSymbol]] ;
|
||||
Abs. Abstract ::= FCat "->" [FCat] "." Name ;
|
||||
FSymCat. FSymbol ::= "(" FCat Integer Integer ")" ;
|
||||
FSymTok. FSymbol ::= String ;
|
||||
FC. FCat ::= "(" Integer Ident "[" [[PathEl]] "]" "[" [PathTerm] "]" ")" ;
|
||||
PLabel. PathEl ::= Label ;
|
||||
PTerm. PathEl ::= Term ;
|
||||
PtT. PathTerm ::= "(" [PathEl] "," Term ")" ;
|
||||
Nm. Name ::= Ident "[" [Profile] "]" ;
|
||||
Unify. Profile ::= "[" [Integer] "]" ;
|
||||
Const. Profile ::= Forest ;
|
||||
|
||||
FMeta. Forest ::= "?" ;
|
||||
FNode. Forest ::= "(" Ident [[Forest]] ")" ;
|
||||
FString. Forest ::= String ;
|
||||
FInt. Forest ::= Integer ;
|
||||
FFloat. Forest ::= Double ;
|
||||
|
||||
Arg. Term ::= "(" Integer Ident [PathEl] ")" ;
|
||||
Constr. Term ::= "(" CIdent "-" [Term] ")" ;
|
||||
Rec. Term ::= "[" [Assoc] "]" ;
|
||||
Proj. Term ::= "(" Term "." Label ")" ;
|
||||
Tbl. Term ::= "[-" [Case] "-]" ;
|
||||
Select. Term ::= "(" Term "!" Term ")" ;
|
||||
Vars. Term ::= "[|" [Term] "|]" ;
|
||||
Concat. Term ::= "(" Term "++" Term ")" ;
|
||||
Tok. Term ::= String ;
|
||||
Empty. Term ::= "(" ")" ;
|
||||
|
||||
Cas. Case ::= Term "=>" Term ;
|
||||
Ass. Assoc ::= Label "=" Term ;
|
||||
|
||||
L. Label ::= Ident ;
|
||||
LV. Label ::= "$" Integer ;
|
||||
CIQ. CIdent ::= Ident "." Ident ;
|
||||
|
||||
terminator FRule ";" ;
|
||||
terminator [FSymbol] "|" ;
|
||||
terminator FSymbol "" ;
|
||||
terminator FCat "" ;
|
||||
terminator [Forest] "," ;
|
||||
terminator Forest "" ;
|
||||
terminator PathTerm "" ;
|
||||
terminator Profile "" ;
|
||||
terminator Integer "" ;
|
||||
terminator Term "," ;
|
||||
terminator Assoc "," ;
|
||||
terminator Case "," ;
|
||||
terminator [PathEl] "," ;
|
||||
terminator PathEl "." ;
|
||||
|
||||
|
||||
-- type FGrammar = [FRule]
|
||||
-- data FRule = FRule Abstract (Array Int (Array Int FSymbol))
|
||||
-- data Abstract = Abs FCat [FCat] Name
|
||||
-- data FSymbol = FSymCat FCat Int Int
|
||||
-- | FSymTok String
|
||||
-- data FCat = FCat Int Ident [Path] [(Path,Term)]
|
||||
-- newtype Path = Path [Either Label Term]
|
||||
-- type Name = Name Ident [Profile]
|
||||
-- type Label = AbsGFC.Label
|
||||
-- data Profile = Unify [Int] | Constant SyntaxForest
|
||||
-- SyntaxForest = FMeta
|
||||
-- | FNode Ident [[SyntaxForest]]
|
||||
-- | FString String
|
||||
-- | FInt Integer
|
||||
-- | FFloat Double
|
||||
{-
|
||||
data Term
|
||||
= Arg Int Ident Path -- ^ argument variable, the 'Path' is a path
|
||||
-- pointing into the term
|
||||
| Constr :^ [Term] -- ^ constructor
|
||||
| Rec [(Label, Term)] -- ^ record
|
||||
| Term :. Label -- ^ record projection
|
||||
| Tbl [(Term, Term)] -- ^ table of patterns\/terms
|
||||
| Term :! Term -- ^ table selection
|
||||
| Variants [Term] -- ^ variants
|
||||
| Term :++ Term -- ^ concatenation
|
||||
| Token String -- ^ single token
|
||||
| Empty -- ^ empty string
|
||||
-}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- type FGrammar = FCFGrammar FCat Name Token
|
||||
-- type FRule = FCFRule FCat Name Token
|
||||
-- type FCFGrammar cat name tok = [FCFRule cat name tok]
|
||||
-- data FCFRule cat name tok =
|
||||
-- FRule (Abstract cat name) (Array FLabel (Array FPointPos (FSymbol cat tok)))
|
||||
-- data Abstract cat name = Abs cat [cat] name
|
||||
-- data FSymbol cat tok = FSymCat cat FLabel Int | FSymTok tok
|
||||
-- type FLabel = Int
|
||||
-- type FPointPos = Int
|
||||
-- data FCat = FCat Int SCat [SPath] [(SPath,STerm)]
|
||||
-- newtype Path c t = Path [Either Label (Term c t)]
|
||||
-- type SCat = Ident.Ident
|
||||
-- type Fun = Ident.Ident
|
||||
-- type SPath = Path SCat Token
|
||||
-- type STerm = Term SCat Token
|
||||
-- type Name = NameProfile Fun
|
||||
-- data NameProfile a = Name a [Profile (SyntaxForest a)]
|
||||
-- SyntaxForest n = FMeta
|
||||
-- | FNode n [[SyntaxForest n]]
|
||||
-- | FString String
|
||||
-- | FInt Integer
|
||||
-- | FFloat Double
|
||||
-- type Token = String
|
||||
-- type Label = AbsGFC.Label
|
||||
-- data Profile a = Unify [Int] | Constant a
|
||||
-- type Constr = AbsGFC.CIdent
|
||||
{-
|
||||
data Term c t
|
||||
= Arg Int c (Path c t) -- ^ argument variable, the 'Path' is a path
|
||||
-- pointing into the term
|
||||
| Constr :^ [Term c t] -- ^ constructor
|
||||
| Rec [(Label, Term c t)] -- ^ record
|
||||
| Term c t :. Label -- ^ record projection
|
||||
| Tbl [(Term c t, Term c t)] -- ^ table of patterns\/terms
|
||||
| Term c t :! Term c t -- ^ table selection
|
||||
| Variants [Term c t] -- ^ variants
|
||||
| Term c t :++ Term c t -- ^ concatenation
|
||||
| Token t -- ^ single token
|
||||
| Empty -- ^ empty string
|
||||
-}
|
||||
|
||||
@@ -1,105 +0,0 @@
|
||||
----------------------------------------------------------------------
|
||||
-- |
|
||||
-- Maintainer : Aarne Ranta
|
||||
-- Stability : (stable)
|
||||
-- Portability : (portable)
|
||||
--
|
||||
-- mapping to GF-internal FGrammar from bnfc-defined FCFG
|
||||
-----------------------------------------------------------------------------
|
||||
|
||||
module GF.FCFG.ToFCFG (getFGrammar) where
|
||||
|
||||
import GF.Formalism.FCFG
|
||||
import GF.Formalism.SimpleGFC
|
||||
import GF.Conversion.Types
|
||||
import GF.Infra.Ident
|
||||
import qualified GF.FCFG.AbsFCFG as F
|
||||
|
||||
import GF.FCFG.ParFCFG (pFGrammar, myLexer)
|
||||
|
||||
import qualified GF.Canon.AbsGFC as C
|
||||
|
||||
import Control.Monad (liftM)
|
||||
import Data.List (groupBy)
|
||||
import Data.Array
|
||||
|
||||
import GF.Formalism.Utilities
|
||||
import GF.Formalism.GCFG
|
||||
|
||||
import GF.Data.Operations
|
||||
import GF.Infra.Print
|
||||
|
||||
|
||||
-- this is the main function used
|
||||
getFGrammar :: FilePath -> IO (FCFGrammar FCat Name Token)
|
||||
getFGrammar f =
|
||||
readFile f >>= err error (return . fgrammar) . pFGrammar . myLexer
|
||||
|
||||
fgrammar :: F.FGrammar -> FCFGrammar FCat Name Token
|
||||
fgrammar (F.FGr rs) = map frule rs
|
||||
|
||||
frule :: F.FRule -> FCFRule FCat Name Token
|
||||
frule (F.FR ab rhs) =
|
||||
FRule (abstract ab)
|
||||
(arr [arr [fsymbol sym | sym <- syms] | syms <- rhs])
|
||||
|
||||
arr xs = listArray (0,length xs - 1) xs
|
||||
|
||||
abstract :: F.Abstract -> Abstract FCat Name
|
||||
abstract (F.Abs cat cats n) = Abs (fcat cat) (map fcat cats) (name n)
|
||||
|
||||
fsymbol :: F.FSymbol -> FSymbol FCat Token
|
||||
fsymbol fs = case fs of
|
||||
F.FSymCat fc i j -> FSymCat (fcat fc) (fromInteger i) (fromInteger j)
|
||||
F.FSymTok s -> FSymTok s
|
||||
|
||||
fcat :: F.FCat -> FCat
|
||||
fcat (F.FC i id ps pts) =
|
||||
FCat (fromInteger i) (ident id) (map path ps)
|
||||
[ (path p, term t) | F.PtT p t <- pts]
|
||||
|
||||
name :: F.Name -> Name
|
||||
name (F.Nm id profs) = Name (ident id) (map profile profs)
|
||||
|
||||
pathel :: F.PathEl -> Either C.Label (Term SCat Token)
|
||||
pathel lt = case lt of
|
||||
F.PLabel lab -> Left $ label lab
|
||||
F.PTerm trm -> Right $ term trm
|
||||
|
||||
path = Path . map pathel
|
||||
|
||||
profile :: F.Profile -> Profile (SyntaxForest Fun)
|
||||
profile p = case p of
|
||||
F.Unify is -> Unify (map fromInteger is)
|
||||
F.Const sf -> Constant (forest sf)
|
||||
|
||||
forest :: F.Forest -> SyntaxForest Fun
|
||||
forest f = case f of
|
||||
F.FMeta -> FMeta
|
||||
F.FNode id fss -> FNode (ident id) (map (map forest) fss)
|
||||
F.FString s -> FString s
|
||||
F.FInt i -> FInt i
|
||||
F.FFloat d -> FFloat d
|
||||
|
||||
term :: F.Term -> Term SCat Token
|
||||
term tr = case tr of
|
||||
F.Arg i id p -> Arg (fromInteger i) (ident id) (path p)
|
||||
F.Rec rs -> Rec [(label l, term t) | F.Ass l t <- rs]
|
||||
F.Tbl cs -> Tbl [(term p, term v) | F.Cas p v <- cs]
|
||||
F.Constr c ts -> (constr c) :^ (map term ts)
|
||||
F.Proj t l -> (term t) :. (label l)
|
||||
F.Concat t u -> (term t) :++ (term u)
|
||||
F.Select t u -> (term t) :! (term u)
|
||||
F.Vars ts -> Variants $ map term ts
|
||||
F.Tok s -> Token s
|
||||
F.Empty -> Empty
|
||||
|
||||
label :: F.Label -> C.Label
|
||||
label b = case b of
|
||||
F.L x -> C.L $ ident x
|
||||
F.LV i -> C.LV i
|
||||
|
||||
ident :: F.Ident -> Ident
|
||||
ident (F.Ident x) = identC x --- should other constructors be used?
|
||||
|
||||
constr (F.CIQ m c) = C.CIQ (ident m) (ident c)
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
@@ -1,210 +0,0 @@
|
||||
{-# OPTIONS -fno-warn-incomplete-patterns #-}
|
||||
module GF.FCFG.PrintFCFG where
|
||||
|
||||
-- pretty-printer generated by the BNF converter
|
||||
|
||||
import GF.FCFG.AbsFCFG
|
||||
import Data.Char
|
||||
|
||||
-- the top-level printing method
|
||||
printTree :: Print a => a -> String
|
||||
printTree = render . prt 0
|
||||
|
||||
type Doc = [ShowS] -> [ShowS]
|
||||
|
||||
doc :: ShowS -> Doc
|
||||
doc = (:)
|
||||
|
||||
render :: Doc -> String
|
||||
render d = rend 0 (map ($ "") $ d []) "" where
|
||||
rend i ss = case ss of
|
||||
"[" :ts -> showChar '[' . rend i ts
|
||||
"(" :ts -> showChar '(' . rend i ts
|
||||
"{" :ts -> showChar '{' . new (i+1) . rend (i+1) ts
|
||||
"}" : ";":ts -> new (i-1) . space "}" . showChar ';' . new (i-1) . rend (i-1) ts
|
||||
"}" :ts -> new (i-1) . showChar '}' . new (i-1) . rend (i-1) ts
|
||||
";" :ts -> showChar ';' . new i . rend i ts
|
||||
t : "," :ts -> showString t . space "," . rend i ts
|
||||
t : ")" :ts -> showString t . showChar ')' . rend i ts
|
||||
t : "]" :ts -> showString t . showChar ']' . rend i ts
|
||||
t :ts -> space t . rend i ts
|
||||
_ -> id
|
||||
new i = showChar '\n' . replicateS (2*i) (showChar ' ') . dropWhile isSpace
|
||||
space t = showString t . (\s -> if null s then "" else (' ':s))
|
||||
|
||||
parenth :: Doc -> Doc
|
||||
parenth ss = doc (showChar '(') . ss . doc (showChar ')')
|
||||
|
||||
concatS :: [ShowS] -> ShowS
|
||||
concatS = foldr (.) id
|
||||
|
||||
concatD :: [Doc] -> Doc
|
||||
concatD = foldr (.) id
|
||||
|
||||
replicateS :: Int -> ShowS -> ShowS
|
||||
replicateS n f = concatS (replicate n f)
|
||||
|
||||
-- the printer class does the job
|
||||
class Print a where
|
||||
prt :: Int -> a -> Doc
|
||||
prtList :: [a] -> Doc
|
||||
prtList = concatD . map (prt 0)
|
||||
|
||||
instance Print a => Print [a] where
|
||||
prt _ = prtList
|
||||
|
||||
instance Print Char where
|
||||
prt _ s = doc (showChar '\'' . mkEsc '\'' s . showChar '\'')
|
||||
prtList s = doc (showChar '"' . concatS (map (mkEsc '"') s) . showChar '"')
|
||||
|
||||
mkEsc :: Char -> Char -> ShowS
|
||||
mkEsc q s = case s of
|
||||
_ | s == q -> showChar '\\' . showChar s
|
||||
'\\'-> showString "\\\\"
|
||||
'\n' -> showString "\\n"
|
||||
'\t' -> showString "\\t"
|
||||
_ -> showChar s
|
||||
|
||||
prPrec :: Int -> Int -> Doc -> Doc
|
||||
prPrec i j = if j<i then parenth else id
|
||||
|
||||
|
||||
instance Print Integer where
|
||||
prt _ x = doc (shows x)
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , prt 0 xs])
|
||||
|
||||
|
||||
instance Print Double where
|
||||
prt _ x = doc (shows x)
|
||||
|
||||
|
||||
instance Print Ident where
|
||||
prt _ (Ident i) = doc (showString i)
|
||||
|
||||
|
||||
|
||||
instance Print FGrammar where
|
||||
prt i e = case e of
|
||||
FGr frules -> prPrec i 0 (concatD [prt 0 frules])
|
||||
|
||||
|
||||
instance Print FRule where
|
||||
prt i e = case e of
|
||||
FR abstract fsymbolss -> prPrec i 0 (concatD [prt 0 abstract , doc (showString ":=") , prt 0 fsymbolss])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , doc (showString ";") , prt 0 xs])
|
||||
|
||||
instance Print Abstract where
|
||||
prt i e = case e of
|
||||
Abs fcat fcats name -> prPrec i 0 (concatD [prt 0 fcat , doc (showString "->") , prt 0 fcats , doc (showString ".") , prt 0 name])
|
||||
|
||||
|
||||
instance Print FSymbol where
|
||||
prt i e = case e of
|
||||
FSymCat fcat n0 n -> prPrec i 0 (concatD [doc (showString "(") , prt 0 fcat , prt 0 n0 , prt 0 n , doc (showString ")")])
|
||||
FSymTok str -> prPrec i 0 (concatD [prt 0 str])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , prt 0 xs])
|
||||
|
||||
instance Print FCat where
|
||||
prt i e = case e of
|
||||
FC n id pathelss pathterms -> prPrec i 0 (concatD [doc (showString "(") , prt 0 n , prt 0 id , doc (showString "[") , prt 0 pathelss , doc (showString "]") , doc (showString "[") , prt 0 pathterms , doc (showString "]") , doc (showString ")")])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , prt 0 xs])
|
||||
|
||||
instance Print PathEl where
|
||||
prt i e = case e of
|
||||
PLabel label -> prPrec i 0 (concatD [prt 0 label])
|
||||
PTerm term -> prPrec i 0 (concatD [prt 0 term])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , doc (showString ".") , prt 0 xs])
|
||||
|
||||
instance Print PathTerm where
|
||||
prt i e = case e of
|
||||
PtT pathels term -> prPrec i 0 (concatD [doc (showString "(") , prt 0 pathels , doc (showString ",") , prt 0 term , doc (showString ")")])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , prt 0 xs])
|
||||
|
||||
instance Print Name where
|
||||
prt i e = case e of
|
||||
Nm id profiles -> prPrec i 0 (concatD [prt 0 id , doc (showString "[") , prt 0 profiles , doc (showString "]")])
|
||||
|
||||
|
||||
instance Print Profile where
|
||||
prt i e = case e of
|
||||
Unify ns -> prPrec i 0 (concatD [doc (showString "[") , prt 0 ns , doc (showString "]")])
|
||||
Const forest -> prPrec i 0 (concatD [prt 0 forest])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , prt 0 xs])
|
||||
|
||||
instance Print Forest where
|
||||
prt i e = case e of
|
||||
FMeta -> prPrec i 0 (concatD [doc (showString "?")])
|
||||
FNode id forestss -> prPrec i 0 (concatD [doc (showString "(") , prt 0 id , prt 0 forestss , doc (showString ")")])
|
||||
FString str -> prPrec i 0 (concatD [prt 0 str])
|
||||
FInt n -> prPrec i 0 (concatD [prt 0 n])
|
||||
FFloat d -> prPrec i 0 (concatD [prt 0 d])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , prt 0 xs])
|
||||
|
||||
instance Print Term where
|
||||
prt i e = case e of
|
||||
Arg n id pathels -> prPrec i 0 (concatD [doc (showString "(") , prt 0 n , prt 0 id , prt 0 pathels , doc (showString ")")])
|
||||
Constr cident terms -> prPrec i 0 (concatD [doc (showString "(") , prt 0 cident , doc (showString "-") , prt 0 terms , doc (showString ")")])
|
||||
Rec assocs -> prPrec i 0 (concatD [doc (showString "[") , prt 0 assocs , doc (showString "]")])
|
||||
Proj term label -> prPrec i 0 (concatD [doc (showString "(") , prt 0 term , doc (showString ".") , prt 0 label , doc (showString ")")])
|
||||
Tbl cases -> prPrec i 0 (concatD [doc (showString "[-") , prt 0 cases , doc (showString "-]")])
|
||||
Select term0 term -> prPrec i 0 (concatD [doc (showString "(") , prt 0 term0 , doc (showString "!") , prt 0 term , doc (showString ")")])
|
||||
Vars terms -> prPrec i 0 (concatD [doc (showString "[|") , prt 0 terms , doc (showString "|]")])
|
||||
Concat term0 term -> prPrec i 0 (concatD [doc (showString "(") , prt 0 term0 , doc (showString "++") , prt 0 term , doc (showString ")")])
|
||||
Tok str -> prPrec i 0 (concatD [prt 0 str])
|
||||
Empty -> prPrec i 0 (concatD [doc (showString "(") , doc (showString ")")])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , doc (showString ",") , prt 0 xs])
|
||||
|
||||
instance Print Case where
|
||||
prt i e = case e of
|
||||
Cas term0 term -> prPrec i 0 (concatD [prt 0 term0 , doc (showString "=>") , prt 0 term])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , doc (showString ",") , prt 0 xs])
|
||||
|
||||
instance Print Assoc where
|
||||
prt i e = case e of
|
||||
Ass label term -> prPrec i 0 (concatD [prt 0 label , doc (showString "=") , prt 0 term])
|
||||
|
||||
prtList es = case es of
|
||||
[] -> (concatD [])
|
||||
x:xs -> (concatD [prt 0 x , doc (showString ",") , prt 0 xs])
|
||||
|
||||
instance Print Label where
|
||||
prt i e = case e of
|
||||
L id -> prPrec i 0 (concatD [prt 0 id])
|
||||
LV n -> prPrec i 0 (concatD [doc (showString "$") , prt 0 n])
|
||||
|
||||
|
||||
instance Print CIdent where
|
||||
prt i e = case e of
|
||||
CIQ id0 id -> prPrec i 0 (concatD [prt 0 id0 , doc (showString ".") , prt 0 id])
|
||||
|
||||
|
||||
|
||||
@@ -1,101 +0,0 @@
|
||||
----------------------------------------------------------------------
|
||||
-- |
|
||||
-- Maintainer : Aarne Ranta
|
||||
-- Stability : (stable)
|
||||
-- Portability : (portable)
|
||||
--
|
||||
-- mapping from GF-internal FGrammar to bnfc-defined FCFG
|
||||
-----------------------------------------------------------------------------
|
||||
|
||||
module GF.FCFG.ToFCFG (printFGrammar) where
|
||||
|
||||
import GF.Formalism.FCFG
|
||||
import GF.Formalism.SimpleGFC
|
||||
import GF.Infra.Ident
|
||||
import qualified GF.FCFG.AbsFCFG as F
|
||||
|
||||
import GF.FCFG.PrintFCFG (printTree)
|
||||
|
||||
import qualified GF.Canon.AbsGFC as C
|
||||
|
||||
import Control.Monad (liftM)
|
||||
import Data.List (groupBy)
|
||||
import Data.Array
|
||||
|
||||
import GF.Formalism.Utilities
|
||||
import GF.Formalism.GCFG
|
||||
|
||||
import GF.Infra.Print
|
||||
|
||||
type FToken = String
|
||||
|
||||
-- this is the main function used
|
||||
printFGrammar :: FGrammar -> String
|
||||
printFGrammar = undefined {- printTree . fgrammar
|
||||
|
||||
fgrammar :: FCFGrammar FCat Name FToken -> F.FGrammar
|
||||
fgrammar = F.FGr . map frule
|
||||
|
||||
frule :: FCFRule FCat Name FToken -> F.FRule
|
||||
frule (FRule ab rhs) =
|
||||
F.FR (abstract ab) [[fsymbol sym | (_,sym) <- assocs syms] | (_,syms) <- assocs rhs]
|
||||
|
||||
abstract :: Abstract FCat Name -> F.Abstract
|
||||
abstract (Abs cat cats n) = F.Abs (fcat cat) (map fcat cats) (name n)
|
||||
|
||||
fsymbol :: FSymbol FCat FToken -> F.FSymbol
|
||||
fsymbol fs = case fs of
|
||||
FSymCat fc i j -> F.FSymCat (fcat fc) (toInteger i) (toInteger j)
|
||||
FSymTok s -> F.FSymTok s
|
||||
|
||||
fcat :: FCat -> F.FCat
|
||||
fcat (FCat i id ps pts) =
|
||||
F.FC (toInteger i) (ident id) [map pathel p | Path p <- ps]
|
||||
[F.PtT (map pathel p) (term t) | (Path p,t) <- pts]
|
||||
|
||||
name :: Name -> F.Name
|
||||
name (Name id profs) = F.Nm (ident id) (map profile profs)
|
||||
|
||||
pathel :: Either C.Label (Term SCat FToken) -> F.PathEl
|
||||
pathel lt = case lt of
|
||||
Left lab -> F.PLabel $ label lab
|
||||
Right trm -> F.PTerm $ term trm
|
||||
|
||||
path (Path p) = map pathel p
|
||||
|
||||
profile :: Profile (SyntaxForest Fun) -> F.Profile
|
||||
profile p = case p of
|
||||
Unify is -> F.Unify (map toInteger is)
|
||||
Constant sf -> F.Const (forest sf)
|
||||
|
||||
forest :: SyntaxForest Fun -> F.Forest
|
||||
forest f = case f of
|
||||
FMeta -> F.FMeta
|
||||
FNode id fss -> F.FNode (ident id) (map (map forest) fss)
|
||||
FString s -> F.FString s
|
||||
FInt i -> F.FInt i
|
||||
FFloat d -> F.FFloat d
|
||||
|
||||
term :: Term SCat FToken -> F.Term
|
||||
term tr = case tr of
|
||||
Arg i id p -> F.Arg (toInteger i) (ident id) (path p)
|
||||
Rec rs -> F.Rec [F.Ass (label l) (term t) | (l,t) <- rs]
|
||||
Tbl cs -> F.Tbl [F.Cas (term p) (term v) | (p,v) <- cs]
|
||||
c :^ ts -> F.Constr (constr c) (map term ts)
|
||||
t :. l -> F.Proj (term t) (label l)
|
||||
t :++ u -> F.Concat (term t) (term u)
|
||||
t :! u -> F.Select (term t) (term u)
|
||||
Variants ts -> F.Vars $ map term ts
|
||||
Token s -> F.Tok s
|
||||
Empty -> F.Empty
|
||||
|
||||
label :: C.Label -> F.Label
|
||||
label b = case b of
|
||||
C.L x -> F.L $ ident x
|
||||
C.LV i -> F.LV i
|
||||
|
||||
ident :: Ident -> F.Ident
|
||||
ident = F.Ident . prIdent --- is information lost?
|
||||
|
||||
constr (C.CIQ m c) = F.CIQ (ident m) (ident c)
|
||||
-}
|
||||
@@ -40,7 +40,6 @@ import qualified GF.Canon.GFCC.DataGFCC as DataGFCC
|
||||
import qualified GF.Canon.CanonToJS as JS (prCanon2js)
|
||||
import qualified GF.Source.AbsGF as GF
|
||||
import qualified GF.Grammar.MMacros as MM
|
||||
import GF.FCFG.ToFCFG
|
||||
import GF.Grammar.AbsCompute
|
||||
import GF.Grammar.TypeCheck
|
||||
import GF.UseGrammar.Generate
|
||||
@@ -301,7 +300,6 @@ customGrammarPrinter =
|
||||
-- grammar conversions:
|
||||
,(strCI "mcfg", \_ -> Prt.prt . stateMCFG)
|
||||
,(strCI "fcfg", \_ -> Prt.prt . stateFCFG)
|
||||
,(strCI "bfcfg", \_ -> printFGrammar . stateFCFG)
|
||||
,(strCI "cfg", \_ -> Prt.prt . stateCFG)
|
||||
,(strCI "pinfo", \_ -> Prt.prt . statePInfo)
|
||||
,(strCI "abstract", \_ -> Prt.prtAfter "\n" . Cnv.gfc2abstract . stateGrammarLang)
|
||||
|
||||
Reference in New Issue
Block a user