mirror of
https://github.com/github/semantic.git
synced 2025-01-02 20:41:38 +03:00
Move the Taggable instances for Data.Syntax out.
This commit is contained in:
parent
de9b171d55
commit
a30be6b59c
@ -16,12 +16,13 @@ import GHC.TypeLits
|
||||
import Diffing.Algorithm
|
||||
import Prelude
|
||||
import Prologue
|
||||
import Reprinting.Tokenize hiding (Element)
|
||||
import Reprinting.Tokenize hiding (Element, In)
|
||||
import qualified Assigning.Assignment as Assignment
|
||||
import qualified Data.Error as Error
|
||||
import Control.Abstract.ScopeGraph (reference, Reference(..), Declaration(..))
|
||||
import Control.Abstract.Heap (deref, lookupSlot)
|
||||
import qualified Data.Abstract.ScopeGraph as ScopeGraph
|
||||
import Tags.Taggable (Taggable(..), subtractLocation)
|
||||
|
||||
-- Combinators
|
||||
|
||||
@ -118,7 +119,7 @@ instance (Element f all, c f, Generate c all fs) => Generate c all (f ': fs) whe
|
||||
newtype Identifier a = Identifier { name :: Name }
|
||||
deriving newtype (Eq, Ord, Show)
|
||||
deriving stock (Foldable, Functor, Generic1, Traversable)
|
||||
deriving anyclass (Diffable, Hashable1, ToJSONFields1, NFData1)
|
||||
deriving anyclass (Diffable, Hashable1, Taggable, ToJSONFields1, NFData1)
|
||||
deriving (Eq1, Show1, Ord1) via Generically Identifier
|
||||
|
||||
|
||||
@ -146,7 +147,7 @@ instance Declarations1 Identifier where
|
||||
newtype AccessibilityModifier a = AccessibilityModifier { contents :: Text }
|
||||
deriving newtype (Eq, Ord, Show)
|
||||
deriving stock (Foldable, Functor, Generic1, Traversable)
|
||||
deriving anyclass (Declarations1, Diffable, FreeVariables1, Hashable1, ToJSONFields1, NFData1)
|
||||
deriving anyclass (Declarations1, Diffable, FreeVariables1, Hashable1, Taggable, ToJSONFields1, NFData1)
|
||||
deriving (Eq1, Show1, Ord1) via Generically AccessibilityModifier
|
||||
|
||||
-- TODO: Implement Eval instance for AccessibilityModifier
|
||||
@ -156,7 +157,7 @@ instance Evaluatable AccessibilityModifier
|
||||
--
|
||||
-- This can be used to represent an implicit no-op, e.g. the alternative in an 'if' statement without an 'else'.
|
||||
data Empty a = Empty
|
||||
deriving (Eq, Ord, Show, Foldable, Traversable, Functor, Generic1, Hashable1, Diffable, FreeVariables1, Declarations1, ToJSONFields1, NFData1)
|
||||
deriving (Eq, Ord, Show, Foldable, Traversable, Functor, Generic1, Hashable1, Diffable, FreeVariables1, Declarations1, Taggable, ToJSONFields1, NFData1)
|
||||
deriving (Eq1, Show1, Ord1) via Generically Empty
|
||||
|
||||
instance Evaluatable Empty where
|
||||
@ -167,7 +168,7 @@ instance Tokenize Empty where
|
||||
|
||||
-- | Syntax representing a parsing or assignment error.
|
||||
data Error a = Error { errorCallStack :: ErrorStack, errorExpected :: [String], errorActual :: Maybe String, errorChildren :: [a] }
|
||||
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Ord, Show, ToJSONFields1, Traversable, NFData1)
|
||||
deriving (Declarations1, Diffable, Eq, Foldable, FreeVariables1, Functor, Generic1, Hashable1, Ord, Show, Taggable, ToJSONFields1, Traversable, NFData1)
|
||||
deriving (Eq1, Show1, Ord1) via Generically Error
|
||||
|
||||
instance Evaluatable Error
|
||||
@ -243,3 +244,6 @@ instance Tokenize Context where
|
||||
|
||||
instance Declarations1 Context where
|
||||
liftDeclaredName declaredName = declaredName . contextSubject
|
||||
|
||||
instance Taggable Context where
|
||||
snippet ann (Context _ (Term (In subj _))) = Just (subtractLocation ann subj)
|
||||
|
@ -38,7 +38,6 @@ import Data.Text hiding (empty)
|
||||
import Streaming hiding (Sum)
|
||||
import Streaming.Prelude (yield)
|
||||
|
||||
import qualified Data.Syntax as Syntax
|
||||
import qualified Data.Syntax.Comment as Comment
|
||||
import qualified Data.Syntax.Declaration as Declaration
|
||||
import qualified Data.Syntax.Directive as Directive
|
||||
@ -139,9 +138,6 @@ instance (Taggable a) => Taggable (TermF a Location) where
|
||||
snippet ann t = snippet ann (termFOut t)
|
||||
symbolName t = symbolName (termFOut t)
|
||||
|
||||
instance Taggable Syntax.Context where
|
||||
snippet ann (Syntax.Context _ (Term (In subj _))) = Just (subtractLocation ann subj)
|
||||
|
||||
instance Taggable Declaration.Function where
|
||||
docsLiteral Python (Declaration.Function _ _ _ (Term (In _ bodyF)))
|
||||
| (Term (In exprAnn exprF):_) <- toList bodyF
|
||||
@ -288,11 +284,6 @@ instance Taggable Statement.Try
|
||||
instance Taggable Statement.While
|
||||
instance Taggable Statement.Yield
|
||||
|
||||
instance Taggable Syntax.Empty
|
||||
instance Taggable Syntax.Error
|
||||
instance Taggable Syntax.Identifier
|
||||
instance Taggable Syntax.AccessibilityModifier
|
||||
|
||||
instance Taggable Type.Annotation
|
||||
instance Taggable Type.Array
|
||||
instance Taggable Type.Bool
|
||||
|
Loading…
Reference in New Issue
Block a user