summaryrefslogtreecommitdiff
path: root/src/GF/Parsing/CFG.hs
blob: f64ce55f1df711349d8715bcceeed94af43bd3bf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
----------------------------------------------------------------------
-- |
-- Maintainer  : PL
-- Stability   : (stable)
-- Portability : (portable)
--
-- > CVS $Date: 2005/05/11 10:28:16 $ 
-- > CVS $Author: peb $
-- > CVS $Revision: 1.5 $
--
-- CFG parsing
-----------------------------------------------------------------------------

module GF.Parsing.CFG
    (parseCF, module GF.Parsing.CFG.PInfo) where

import GF.Data.Operations (Err(..))

import GF.Formalism.Utilities
import GF.Formalism.CFG
import GF.Parsing.CFG.PInfo

import qualified GF.Parsing.CFG.Incremental as Inc
import qualified GF.Parsing.CFG.General as Gen

----------------------------------------------------------------------
-- parsing

parseCF :: (Ord n, Ord c, Ord t) => String -> Err (CFParser c n t) 

parseCF "bottomup" = Ok $ Gen.parse bottomup
parseCF "topdown"  = Ok $ Gen.parse topdown

parseCF "gb"    = Ok $ Gen.parse bottomup
parseCF "gt"    = Ok $ Gen.parse topdown
parseCF "ib"    = Ok $ Inc.parse (bottomup, noFilter)
parseCF "it"    = Ok $ Inc.parse (topdown, noFilter)
parseCF "ibFT"  = Ok $ Inc.parse (bottomup, topdown)
parseCF "ibFB"  = Ok $ Inc.parse (bottomup, bottomup)
parseCF "ibFTB" = Ok $ Inc.parse (bottomup, bothFilters)
parseCF "itF"   = Ok $ Inc.parse (topdown, bottomup)

-- error parser:
parseCF prs = Bad $ "CFG parsing strategy not defined: " ++ prs

bottomup = (True, False)
topdown = (False, True)
noFilter = (False, False)
bothFilters = (True, True)