1
1
mirror of https://github.com/github/semantic.git synced 2024-12-22 22:31:36 +03:00
semantic/src/Category.hs

42 lines
1.2 KiB
Haskell
Raw Normal View History

{-# LANGUAGE FlexibleInstances #-}
module Category where
2015-11-18 22:23:35 +03:00
2015-11-27 20:02:15 +03:00
import Term
import Control.Comonad.Cofree
2015-11-18 22:23:35 +03:00
import Data.Set
2016-02-05 00:35:42 +03:00
-- | A standardized category of AST node. Used to determine the semantics for
-- | semantic diffing and define comparability of nodes.
data Category =
2016-02-06 00:59:38 +03:00
-- | An operator with 2 operands.
BinaryOperator
2016-02-05 00:35:42 +03:00
-- | A literal key-value data structure.
2016-02-06 00:59:38 +03:00
| DictionaryLiteral
2016-02-14 05:01:52 +03:00
-- | A pair, e.g. of a key & value
| Pair
2016-02-06 00:54:08 +03:00
-- | A call to a function.
| FunctionCall
-- | A string literal.
| StringLiteral
-- | An integer literal.
| IntegerLiteral
-- | A symbol literal.
| SymbolLiteral
2016-02-05 00:35:42 +03:00
-- | A non-standard category, which can be used for comparability.
| Other String
2016-02-05 00:47:33 +03:00
deriving (Eq, Show, Ord)
2016-02-05 00:35:42 +03:00
-- | The class of types that have categories.
2015-11-18 22:23:35 +03:00
class Categorizable a where
2016-02-05 21:48:13 +03:00
categories :: a -> Set Category
2015-11-27 20:02:15 +03:00
instance Categorizable annotation => Categorizable (Term a annotation) where
categories (annotation :< _) = categories annotation
-- | Test whether the categories from the categorizables intersect.
comparable :: Categorizable a => a -> a -> Bool
comparable a b = catsA == catsB || (not . Data.Set.null $ intersection catsA catsB)
where
catsA = categories a
catsB = categories b