summaryrefslogtreecommitdiff
path: root/src-3.0/GF/OldParsing/ConvertGrammar.hs
diff options
context:
space:
mode:
authoraarne <aarne@cs.chalmers.se>2008-05-21 09:26:44 +0000
committeraarne <aarne@cs.chalmers.se>2008-05-21 09:26:44 +0000
commit055c0d0d5a5bb0dc75904fe53df7f2e4f5732a8f (patch)
tree0e63fb68c69c8f6ad0f78893c63420f0a3600e1c /src-3.0/GF/OldParsing/ConvertGrammar.hs
parent915a1de71783ab8446b1af9e72c7ba7dfbc12d3f (diff)
GF/src is now for 2.9, and the new sources are in src-3.0 - keep it this way until the release of GF 3
Diffstat (limited to 'src-3.0/GF/OldParsing/ConvertGrammar.hs')
-rw-r--r--src-3.0/GF/OldParsing/ConvertGrammar.hs44
1 files changed, 44 insertions, 0 deletions
diff --git a/src-3.0/GF/OldParsing/ConvertGrammar.hs b/src-3.0/GF/OldParsing/ConvertGrammar.hs
new file mode 100644
index 000000000..0dcd90770
--- /dev/null
+++ b/src-3.0/GF/OldParsing/ConvertGrammar.hs
@@ -0,0 +1,44 @@
+----------------------------------------------------------------------
+-- |
+-- Module : ConvertGrammar
+-- Maintainer : PL
+-- Stability : (stable)
+-- Portability : (portable)
+--
+-- > CVS $Date: 2005/04/21 16:22:45 $
+-- > CVS $Author: bringert $
+-- > CVS $Revision: 1.2 $
+--
+-- All (?) grammar conversions which are used in GF
+-----------------------------------------------------------------------------
+
+
+module GF.OldParsing.ConvertGrammar
+ (pInfo, emptyPInfo,
+ module GF.OldParsing.GrammarTypes
+ ) where
+
+import GF.Canon.GFC (CanonGrammar)
+import GF.Canon.MkGFC (grammar2canon)
+import GF.OldParsing.GrammarTypes
+import GF.Infra.Ident (Ident(..))
+import GF.Infra.Option
+import GF.System.Tracing
+
+-- import qualified GF.OldParsing.FiniteTypes.Calc as Fin
+import qualified GF.OldParsing.ConvertGFCtoMCFG as G2M
+import qualified GF.OldParsing.ConvertMCFGtoCFG as M2C
+import qualified GF.OldParsing.MCFGrammar as MCFG
+import qualified GF.OldParsing.CFGrammar as CFG
+
+pInfo :: Options -> CanonGrammar -> Ident -> PInfo
+pInfo opts canon lng = PInfo mcfg cfg mcfp cfp
+ where mcfg = G2M.convertGrammar cnv (canon, lng)
+ cnv = maybe "nondet" id $ getOptVal opts gfcConversion
+ cfg = M2C.convertGrammar mcfg
+ mcfp = MCFG.pInfo mcfg
+ cfp = CFG.pInfo cfg
+
+emptyPInfo :: PInfo
+emptyPInfo = PInfo [] [] (MCFG.pInfo []) (CFG.pInfo [])
+