]> Git — Sourcephile - haskell/symantic-parser.git/blob - src/Symantic/Parser/Grammar.hs
TemplateHaskell: why is PprSplice much faster than DumpSplice?
[haskell/symantic-parser.git] / src / Symantic / Parser / Grammar.hs
1 {-# LANGUAGE AllowAmbiguousTypes #-} -- For grammar
2 {-# LANGUAGE ConstraintKinds #-} -- For Grammarable
3 module Symantic.Parser.Grammar
4 ( module Symantic.Parser.Grammar
5 , module Symantic.Parser.Grammar.Combinators
6 , module Symantic.Parser.Grammar.Fixity
7 , module Symantic.Parser.Grammar.Optimize
8 , module Symantic.Parser.Grammar.ObserveSharing
9 , module Symantic.Parser.Grammar.Write
10 , module Symantic.Parser.Grammar.View
11 , Letable(..)
12 , Letsable(..)
13 ) where
14 import Symantic.Parser.Grammar.Combinators
15 import Symantic.Parser.Grammar.View
16 import Symantic.Parser.Grammar.Fixity
17 import Symantic.Parser.Grammar.ObserveSharing
18 import Symantic.Parser.Grammar.Optimize
19 import Symantic.Parser.Grammar.Write
20
21 import Control.DeepSeq (NFData)
22 import Data.Eq (Eq(..))
23 import Data.Function ((.))
24 import Data.String (String)
25 import Data.Typeable (Typeable)
26 import Text.Show (Show(..))
27 import qualified Language.Haskell.TH.Syntax as TH
28
29 -- * Class 'Grammarable'
30 type Grammarable tok repr =
31 ( CombAlternable repr
32 , CombApplicable repr
33 , CombFoldable repr
34 , Letable TH.Name repr
35 , Letsable TH.Name repr
36 , CombLookable repr
37 , CombMatchable repr
38 , CombSatisfiable tok repr
39 , CombSelectable repr
40 , Eq tok
41 , TH.Lift tok
42 , NFData tok
43 , Show tok
44 , Typeable tok
45 )
46
47 -- | A usual pipeline to interpret 'Comb'inators:
48 -- 'observeSharing' then 'optimizeGrammar' then a polymorphic @(repr)@.
49 grammar ::
50 Grammarable tok repr =>
51 ObserveSharing TH.Name
52 (OptimizeGrammar repr) a ->
53 repr a
54 grammar = optimizeGrammar . observeSharing
55
56 -- | An usual pipeline to show 'Comb'inators:
57 -- 'observeSharing' then 'optimizeGrammar' then 'viewGrammar' then 'show'.
58 showGrammar :: forall showName a tok repr.
59 repr ~ ObserveSharing TH.Name (OptimizeGrammar (ViewGrammar showName)) =>
60 ShowLetName showName TH.Name =>
61 Grammarable tok repr =>
62 repr a -> String
63 showGrammar = show . viewGrammar . grammar @tok