From 68903bb25155978b6da22b1f6bd7069621c7dc30 Mon Sep 17 00:00:00 2001 From: aarne Date: Sat, 24 May 2008 16:13:27 +0000 Subject: started source grammar API ; used it for a first implem. of cc command --- src-3.0/GF/Grammar/API.hs | 52 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 src-3.0/GF/Grammar/API.hs (limited to 'src-3.0/GF/Grammar/API.hs') diff --git a/src-3.0/GF/Grammar/API.hs b/src-3.0/GF/Grammar/API.hs new file mode 100644 index 000000000..be8094228 --- /dev/null +++ b/src-3.0/GF/Grammar/API.hs @@ -0,0 +1,52 @@ +module GF.Grammar.API ( + Grammar, + emptyGrammar, + pTerm, + prTerm, + checkTerm, + computeTerm + ) where + +import GF.Source.ParGF +import GF.Source.SourceToGrammar (transExp) +import GF.Grammar.Grammar +import GF.Infra.Ident +import GF.Infra.Modules (greatestResource) +import GF.Compile.GetGrammar +import GF.Grammar.Macros +import GF.Grammar.PrGrammar + +import GF.Compile.Rename (renameSourceTerm) +import GF.Compile.CheckGrammar (justCheckLTerm) +import GF.Compile.Compute (computeConcreteRec) + +import GF.Data.Operations +import qualified Data.ByteString.Char8 as BS + +type Grammar = SourceGrammar + +emptyGrammar :: Grammar +emptyGrammar = emptySourceGrammar + +pTerm :: String -> Err Term +pTerm s = do + e <- pExp $ myLexer (BS.pack s) + transExp e + +prTerm :: Term -> String +prTerm = prt + +checkTerm :: Grammar -> Term -> Err Term +checkTerm gr t = do + mo <- maybe (Bad "no source grammar in scope") return $ greatestResource gr + checkTermAny gr mo t + +checkTermAny :: Grammar -> Ident -> Term -> Err Term +checkTermAny gr m t = do + t1 <- renameSourceTerm gr m t + justCheckLTerm gr t1 + +computeTerm :: Grammar -> Term -> Err Term +computeTerm = computeConcreteRec + + -- cgit v1.2.3