From b1402e8bd6a68a891b00a214d6cf184d66defe19 Mon Sep 17 00:00:00 2001 From: aarne Date: Mon, 22 Sep 2003 13:16:55 +0000 Subject: Founding the newly structured GF2.0 cvs archive. --- src/GF/Canon/GetGFC.hs | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 src/GF/Canon/GetGFC.hs (limited to 'src/GF/Canon/GetGFC.hs') diff --git a/src/GF/Canon/GetGFC.hs b/src/GF/Canon/GetGFC.hs new file mode 100644 index 000000000..225b0712a --- /dev/null +++ b/src/GF/Canon/GetGFC.hs @@ -0,0 +1,22 @@ +module GetGFC where + +import Operations +import ParGFC +import GFC +import MkGFC +import Modules +import GetGrammar (err2err) --- +import UseIO + +getCanonModule :: FilePath -> IOE CanonModule +getCanonModule file = do + gr <- getCanonGrammar file + case modules gr of + [m] -> return m + _ -> ioeErr $ Bad "expected exactly one module in a file" + +getCanonGrammar :: FilePath -> IOE CanonGrammar +getCanonGrammar file = do + s <- ioeIO $ readFileIf file + c <- ioeErr $ err2err $ pCanon $ myLexer s + return $ canon2grammar c -- cgit v1.2.3