1
1
mirror of https://github.com/github/semantic.git synced 2024-11-24 08:54:07 +03:00

Make declare actually do something… in theory.

This commit is contained in:
Patrick Thomson 2020-01-14 14:19:57 -05:00
parent 2389535736
commit e9247ab8a8
4 changed files with 36 additions and 16 deletions

View File

@ -11,6 +11,7 @@ import Control.Carrier.Sketch.Fresh
import Control.Monad import Control.Monad
import Convert.ToScopeGraph import Convert.ToScopeGraph
import qualified Data.ByteString as ByteString import qualified Data.ByteString as ByteString
import Data.Name (Name)
import qualified Data.ScopeGraph as ScopeGraph import qualified Data.ScopeGraph as ScopeGraph
import qualified Language.Python () import qualified Language.Python ()
import Source.Loc import Source.Loc
@ -42,13 +43,13 @@ The graph should be
-} -}
runScopeGraph :: ToScopeGraph t => Path.AbsRelFile -> Source.Source -> t Loc -> (ScopeGraph.ScopeGraph Addr, Result) runScopeGraph :: ToScopeGraph t => Path.AbsRelFile -> Source.Source -> t Loc -> (ScopeGraph.ScopeGraph Name, Result)
runScopeGraph p _src item = run . runSketch @Addr (Just p) $ scopeGraph item runScopeGraph p _src item = run . runSketch @Name (Just p) $ scopeGraph item
sampleGraphThing :: (Has (Sketch Addr) sig m) => m Result sampleGraphThing :: (Has (Sketch Name) sig m) => m Result
sampleGraphThing = do sampleGraphThing = do
declare @Addr "hello" DeclProperties declare @Name "hello" DeclProperties
declare @Addr "goodbye" DeclProperties declare @Name "goodbye" DeclProperties
pure Complete pure Complete
@ -61,7 +62,7 @@ main = do
file <- ByteString.readFile path file <- ByteString.readFile path
tree <- TS.parseByteString @Py.Module @Loc TSP.tree_sitter_python file tree <- TS.parseByteString @Py.Module @Loc TSP.tree_sitter_python file
pyModule <- either die pure tree pyModule <- either die pure tree
let (expecto, Complete) = run $ runSketch @Addr Nothing sampleGraphThing let (expecto, Complete) = run $ runSketch @Name Nothing sampleGraphThing
let (result, Complete) = runScopeGraph (Path.absRel path) (Source.fromUTF8 file) pyModule let (result, Complete) = runScopeGraph (Path.absRel path) (Source.fromUTF8 file) pyModule
print result print result
assertEqual expecto result assertEqual expecto result

View File

@ -21,6 +21,7 @@ import Control.Effect.Sketch
import Convert.ToScopeGraph import Convert.ToScopeGraph
import Data.Foldable import Data.Foldable
import qualified Data.List.NonEmpty as NonEmpty import qualified Data.List.NonEmpty as NonEmpty
import Data.Name (Name)
import Language.Python.Core (pattern SingleIdentifier) import Language.Python.Core (pattern SingleIdentifier)
import qualified Language.Python.Tags as PyTags import qualified Language.Python.Tags as PyTags
import qualified Tags.Tagging.Precise as Tags import qualified Tags.Tagging.Precise as Tags
@ -48,7 +49,7 @@ instance ToScopeGraph Term where
instance ToScopeGraph Py.AssertStatement where scopeGraph = onChildren instance ToScopeGraph Py.AssertStatement where scopeGraph = onChildren
instance ToScopeGraph Py.Assignment where instance ToScopeGraph Py.Assignment where
scopeGraph (Py.Assignment _ (SingleIdentifier t) _val _typ) = complete <* declare @Addr t DeclProperties scopeGraph (Py.Assignment _ (SingleIdentifier t) _val _typ) = complete <* declare @Name t DeclProperties
scopeGraph x = todo x scopeGraph x = todo x
instance ToScopeGraph Py.Await where instance ToScopeGraph Py.Await where

View File

@ -9,6 +9,7 @@
{-# LANGUAGE TypeApplications #-} {-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeOperators #-} {-# LANGUAGE TypeOperators #-}
{-# LANGUAGE UndecidableInstances #-} {-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -Wno-redundant-constraints #-} {-# OPTIONS_GHC -Wno-redundant-constraints #-}
module Control.Carrier.Sketch.Fresh module Control.Carrier.Sketch.Fresh
@ -22,11 +23,15 @@ import Control.Carrier.Fresh.Strict
import Control.Carrier.State.Strict import Control.Carrier.State.Strict
import Control.Effect.Sketch import Control.Effect.Sketch
import Control.Monad.IO.Class import Control.Monad.IO.Class
import Data.Module
import Data.Name (Name)
import qualified Data.Name
import Data.Bifunctor import Data.Bifunctor
import Data.ScopeGraph (ScopeGraph) import Data.ScopeGraph (ScopeGraph)
import qualified Data.ScopeGraph as ScopeGraph import qualified Data.ScopeGraph as ScopeGraph
import Data.Semilattice.Lower import Data.Semilattice.Lower
import qualified System.Path as Path import qualified System.Path as Path
import Source.Span
newtype Sketchbook address = Sketchbook newtype Sketchbook address = Sketchbook
{ sGraph :: ScopeGraph address { sGraph :: ScopeGraph address
@ -35,8 +40,22 @@ newtype Sketchbook address = Sketchbook
newtype SketchC address m a = SketchC (StateC (Sketchbook address) (FreshC m) a) newtype SketchC address m a = SketchC (StateC (Sketchbook address) (FreshC m) a)
deriving (Applicative, Functor, Monad, MonadIO) deriving (Applicative, Functor, Monad, MonadIO)
instance forall address sig m . (Effect sig, Algebra sig m) => Algebra (Sketch address :+: sig) (SketchC address m) where instance forall address sig m . (address ~ Name, Effect sig, Algebra sig m) => Algebra (Sketch Name :+: sig) (SketchC Name m) where
alg (L (Declare _name _props k)) = do alg (L (Declare n _props k)) = do
old <- SketchC (gets @(Sketchbook address) sGraph)
addr <- SketchC Data.Name.gensym
let (new, _pos) =
ScopeGraph.declare
(ScopeGraph.Declaration (Data.Name.name n))
(lowerBound @ModuleInfo)
ScopeGraph.Default
ScopeGraph.Public
(lowerBound @Span)
ScopeGraph.Identifier
Nothing
addr
old
SketchC (put (Sketchbook new))
k () k ()
alg (R other) = SketchC (alg (R (R (handleCoercible other)))) alg (R other) = SketchC (alg (R (R (handleCoercible other))))

View File

@ -7,7 +7,6 @@
{-# LANGUAGE TypeOperators #-} {-# LANGUAGE TypeOperators #-}
module Convert.ToScopeGraph module Convert.ToScopeGraph
( ToScopeGraph (..) ( ToScopeGraph (..)
, Addr
, Result (..) , Result (..)
, onChildren , onChildren
, onField , onField
@ -15,15 +14,15 @@ module Convert.ToScopeGraph
import Control.Effect.Sketch import Control.Effect.Sketch
import Data.Foldable import Data.Foldable
import Data.Name (Name)
import Data.Typeable
import GHC.Generics import GHC.Generics
import GHC.Records import GHC.Records
import Source.Loc import Source.Loc
type Addr = Int class Typeable t => ToScopeGraph t where
class ToScopeGraph t where
scopeGraph :: scopeGraph ::
( Has (Sketch Addr) sig m ( Has (Sketch Name) sig m
) )
=> t Loc => t Loc
-> m Result -> m Result
@ -44,7 +43,7 @@ instance (ToScopeGraph l, ToScopeGraph r) => ToScopeGraph (l :+: r) where
onField :: onField ::
forall field syn sig m r . forall field syn sig m r .
( Has (Sketch Addr) sig m ( Has (Sketch Name) sig m
, HasField field (r Loc) (syn Loc) , HasField field (r Loc) (syn Loc)
, ToScopeGraph syn , ToScopeGraph syn
) )
@ -57,7 +56,7 @@ onField
onChildren :: onChildren ::
( Traversable t ( Traversable t
, ToScopeGraph syn , ToScopeGraph syn
, Has (Sketch Addr) sig m , Has (Sketch Name) sig m
, HasField "extraChildren" (r Loc) (t (syn Loc)) , HasField "extraChildren" (r Loc) (t (syn Loc))
) )
=> r Loc => r Loc