diff options
| author | aarne <unknown> | 2004-09-19 20:27:38 +0000 |
|---|---|---|
| committer | aarne <unknown> | 2004-09-19 20:27:38 +0000 |
| commit | 0e21dcbf543f9a0367e69abd7f5f19b7852911e3 (patch) | |
| tree | 17f439f9732ea405f1325b81d51c65d8ec37b433 /src/GF/CF | |
| parent | df4cbb482f0546b884eb210d825c794d14f82712 (diff) | |
Imper
Diffstat (limited to 'src/GF/CF')
| -rw-r--r-- | src/GF/CF/PrLBNF.hs | 12 |
1 files changed, 11 insertions, 1 deletions
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 |
