From 0e21dcbf543f9a0367e69abd7f5f19b7852911e3 Mon Sep 17 00:00:00 2001 From: aarne Date: Sun, 19 Sep 2004 20:27:38 +0000 Subject: [PATCH] Imper --- grammars/prelude/Prelude.gf | 2 ++ src/GF/CF/PrLBNF.hs | 12 +++++++++++- src/GF/UseGrammar/Custom.hs | 1 + 3 files changed, 14 insertions(+), 1 deletion(-) diff --git a/grammars/prelude/Prelude.gf b/grammars/prelude/Prelude.gf index 385a734ec..d124d7df6 100644 --- a/grammars/prelude/Prelude.gf +++ b/grammars/prelude/Prelude.gf @@ -29,6 +29,8 @@ oper postfixSS : Str -> SS -> SS = \f,x -> ss (x.s ++ f) ; embedSS : Str -> Str -> SS -> SS = \f,g,x -> ss (f ++ x.s ++ g) ; + id : (A : Type) -> A -> A ; + -- discontinuous SD2 = {s1,s2 : Str} ; sd2 : (_,_ : Str) -> SD2 = \x,y -> {s1 = x ; s2 = y} ; diff --git a/src/GF/CF/PrLBNF.hs b/src/GF/CF/PrLBNF.hs index 345863456..59067c39b 100644 --- a/src/GF/CF/PrLBNF.hs +++ b/src/GF/CF/PrLBNF.hs @@ -1,4 +1,4 @@ -module PrLBNF (prLBNF) where +module PrLBNF (prLBNF,prBNF) where import CF import CFIdent @@ -16,6 +16,16 @@ import Char prLBNF :: CF -> String prLBNF = unlines . (map prCFRule) . rulesOfCF -- hiding the literal recogn function +-- a hack to hide the LBNF details +prBNF :: CF -> String +prBNF = unlines . (map (unwords . unLBNF . drop 1 . words . prCFRule)) . rulesOfCF + where + unLBNF r = case r of + "---":ts -> ts + ";":"---":ts -> ts + c:ts -> c : unLBNF ts + _ -> r + prCFRule :: CFRule -> String prCFRule (fun,(cat,its)) = prCFFun fun ++ "." +++ prCFCat True cat +++ "::=" +++ --- err in cat -> in syntax diff --git a/src/GF/UseGrammar/Custom.hs b/src/GF/UseGrammar/Custom.hs index 229b94fc7..9587038be 100644 --- a/src/GF/UseGrammar/Custom.hs +++ b/src/GF/UseGrammar/Custom.hs @@ -195,6 +195,7 @@ customGrammarPrinter = name = cncId s in gslPrinter name opts $ Cnv.cfg $ statePInfo s) ,(strCI "lbnf", prLBNF . stateCF) + ,(strCI "bnf", prBNF . stateCF) ,(strCI "haskell", grammar2haskell . stateGrammarST) ,(strCI "morpho", prMorpho . stateMorpho) ,(strCI "fullform",prFullForm . stateMorpho)