mirror of
https://github.com/github/semantic.git
synced 2024-12-23 06:41:45 +03:00
Add & use a TermDecorator type synonym.
This commit is contained in:
parent
af88fad102
commit
120c77ba29
@ -84,12 +84,14 @@ readAndTranscodeFile path = do
|
|||||||
text <- B1.readFile path
|
text <- B1.readFile path
|
||||||
transcode text
|
transcode text
|
||||||
|
|
||||||
|
type TermDecorator f fields field = CofreeF f (Record fields) (Record (field ': fields)) -> field
|
||||||
|
|
||||||
-- | Decorate the 'Term's produced by a 'Parser' using a function to compute the annotation values at every node.
|
-- | Decorate the 'Term's produced by a 'Parser' using a function to compute the annotation values at every node.
|
||||||
decorateParser :: (Typeable field, Functor f) => (CofreeF f (Record fields) (Record (field ': fields)) -> field) -> Parser f (Record fields) -> Parser f (Record (field ': fields))
|
decorateParser :: (Typeable field, Functor f) => TermDecorator f fields field -> Parser f (Record fields) -> Parser f (Record (field ': fields))
|
||||||
decorateParser decorator = (fmap (decorateTerm decorator) .)
|
decorateParser decorator = (fmap (decorateTerm decorator) .)
|
||||||
|
|
||||||
-- | Decorate a 'Term' using a function to compute the annotation values at every node.
|
-- | Decorate a 'Term' using a function to compute the annotation values at every node.
|
||||||
decorateTerm :: (Typeable field, Functor f) => (CofreeF f (Record fields) (Record (field ': fields)) -> field) -> Cofree f (Record fields) -> Cofree f (Record (field ': fields))
|
decorateTerm :: (Typeable field, Functor f) => TermDecorator f fields field -> Cofree f (Record fields) -> Cofree f (Record (field ': fields))
|
||||||
decorateTerm decorator = cata $ \ c -> cofree ((decorator (extract <$> c) .: headF c) :< tailF c)
|
decorateTerm decorator = cata $ \ c -> cofree ((decorator (extract <$> c) .: headF c) :< tailF c)
|
||||||
|
|
||||||
-- | Given a parser and renderer, diff two sources and return the rendered
|
-- | Given a parser and renderer, diff two sources and return the rendered
|
||||||
@ -119,7 +121,7 @@ compareCategoryEq :: HasField fields Category => Term leaf (Record fields) -> Te
|
|||||||
compareCategoryEq = (==) `on` category . extract
|
compareCategoryEq = (==) `on` category . extract
|
||||||
|
|
||||||
-- | Term decorator computing the cost of an unpacked term.
|
-- | Term decorator computing the cost of an unpacked term.
|
||||||
termCost :: (Prologue.Foldable f, Functor f) => CofreeF f (Record a) (Record (Cost ': a)) -> Cost
|
termCost :: (Prologue.Foldable f, Functor f) => TermDecorator f a Cost
|
||||||
termCost c = 1 + sum (cost <$> tailF c)
|
termCost c = 1 + sum (cost <$> tailF c)
|
||||||
|
|
||||||
-- | The sum of the node count of the diff’s patches.
|
-- | The sum of the node count of the diff’s patches.
|
||||||
|
Loading…
Reference in New Issue
Block a user