mirror of
https://github.com/github/semantic.git
synced 2025-01-06 23:46:21 +03:00
Merge branch 'python-assignment' of github.com:github/semantic-diff into python-assignment
This commit is contained in:
commit
32a8b9d979
2
languages/ruby/vendor/tree-sitter-ruby
vendored
2
languages/ruby/vendor/tree-sitter-ruby
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 04fd77ba80a49c4db32e5063dcabb2de5dbce866
|
Subproject commit 7c0c68390ae6c7a456499cc1087773cd4d02185c
|
@ -1,9 +1,7 @@
|
|||||||
{-# LANGUAGE DataKinds #-}
|
{-# LANGUAGE DataKinds #-}
|
||||||
module TreeSitter
|
module TreeSitter
|
||||||
( treeSitterParser
|
( treeSitterParser
|
||||||
, parseRubyToAST
|
|
||||||
, parseRubyToTerm
|
, parseRubyToTerm
|
||||||
, parsePythonToAST
|
|
||||||
, parsePythonToTerm
|
, parsePythonToTerm
|
||||||
, defaultTermAssignment
|
, defaultTermAssignment
|
||||||
) where
|
) where
|
||||||
@ -51,11 +49,11 @@ treeSitterParser language grammar blob = do
|
|||||||
pure term
|
pure term
|
||||||
|
|
||||||
|
|
||||||
-- | Parse Ruby to AST. Intended for use in ghci, e.g.:
|
-- | Parse Ruby to a list of Terms, printing any assignment errors to stdout. Intended for use in ghci, e.g.:
|
||||||
--
|
--
|
||||||
-- > Command.Files.readFile "/Users/rob/Desktop/test.rb" >>= parseRubyToAST . source
|
-- > Command.Files.readFile "/Users/rob/Desktop/test.rb" >>= parseRubyToTerm . source
|
||||||
parseRubyToAST :: Source -> IO (A.AST Ruby.Grammar)
|
parseRubyToTerm :: Source -> IO (Maybe [Term Ruby.Syntax A.Location])
|
||||||
parseRubyToAST source = do
|
parseRubyToTerm source = do
|
||||||
document <- ts_document_new
|
document <- ts_document_new
|
||||||
ts_document_set_language document Ruby.tree_sitter_ruby
|
ts_document_set_language document Ruby.tree_sitter_ruby
|
||||||
root <- withCStringLen (toText source) $ \ (source, len) -> do
|
root <- withCStringLen (toText source) $ \ (source, len) -> do
|
||||||
@ -68,35 +66,17 @@ parseRubyToAST source = do
|
|||||||
ast <- anaM toAST root
|
ast <- anaM toAST root
|
||||||
|
|
||||||
ts_document_free document
|
ts_document_free document
|
||||||
pure ast
|
|
||||||
where toAST :: Node -> IO (A.RoseF (A.Node Ruby.Grammar) Node)
|
|
||||||
toAST node@Node{..} = do
|
|
||||||
let count = fromIntegral nodeChildCount
|
|
||||||
children <- allocaArray count $ \ childNodesPtr -> do
|
|
||||||
_ <- with nodeTSNode (\ nodePtr -> ts_node_copy_child_nodes nullPtr nodePtr childNodesPtr (fromIntegral count))
|
|
||||||
peekArray count childNodesPtr
|
|
||||||
pure $ A.RoseF (toEnum (fromIntegral nodeSymbol) :. nodeRange node :. nodeSpan node :. Nil) children
|
|
||||||
|
|
||||||
anaM :: (Corecursive t, Monad m, Traversable (Base t)) => (a -> m (Base t a)) -> a -> m t
|
|
||||||
anaM g = a where a = pure . embed <=< traverse a <=< g
|
|
||||||
|
|
||||||
|
|
||||||
-- | Parse Ruby to a list of Terms, printing any assignment errors to stdout. Intended for use in ghci, e.g.:
|
|
||||||
--
|
|
||||||
-- > Command.Files.readFile "/Users/rob/Desktop/test.rb" >>= parseRubyToTerm . source
|
|
||||||
parseRubyToTerm :: Source -> IO (Maybe [Term Ruby.Syntax A.Location])
|
|
||||||
parseRubyToTerm source = do
|
|
||||||
ast <- parseRubyToAST source
|
|
||||||
let A.Result errors value = A.assign Ruby.assignment source ast
|
let A.Result errors value = A.assign Ruby.assignment source ast
|
||||||
case value of
|
case value of
|
||||||
Just a -> pure (Just a)
|
Just a -> pure (Just a)
|
||||||
_ -> traverse_ (putStrLn . ($ "") . A.showError source) errors >> pure Nothing
|
_ -> traverse_ (putStrLn . ($ "") . A.showError source) errors >> pure Nothing
|
||||||
|
|
||||||
-- | Parse Python to AST. Intended for use in ghci, e.g.:
|
-- | Parse Python to a list of Terms, printing any assignment errors to stdout. Intended for use in ghci, e.g.:
|
||||||
--
|
--
|
||||||
-- > Command.Files.readFile "/Users/rob/Desktop/test.rb" >>= parsePythonToAST . source
|
-- > Command.Files.readFile "/Users/rob/Desktop/test.rb" >>= parsePythonToTerm . source
|
||||||
parsePythonToAST :: Source -> IO (A.AST Python.Grammar)
|
parsePythonToTerm :: Source -> IO (Maybe [Term Python.Syntax A.Location])
|
||||||
parsePythonToAST source = do
|
parsePythonToTerm source = do
|
||||||
document <- ts_document_new
|
document <- ts_document_new
|
||||||
ts_document_set_language document Python.tree_sitter_python
|
ts_document_set_language document Python.tree_sitter_python
|
||||||
root <- withCStringLen (toText source) $ \ (source, len) -> do
|
root <- withCStringLen (toText source) $ \ (source, len) -> do
|
||||||
@ -109,29 +89,23 @@ parsePythonToAST source = do
|
|||||||
ast <- anaM toAST root
|
ast <- anaM toAST root
|
||||||
|
|
||||||
ts_document_free document
|
ts_document_free document
|
||||||
pure ast
|
|
||||||
where toAST :: Node -> IO (A.RoseF (A.Node Python.Grammar) Node)
|
|
||||||
toAST node@Node{..} = do
|
|
||||||
let count = fromIntegral nodeChildCount
|
|
||||||
children <- allocaArray count $ \ childNodesPtr -> do
|
|
||||||
_ <- with nodeTSNode (\ nodePtr -> ts_node_copy_child_nodes nullPtr nodePtr childNodesPtr (fromIntegral count))
|
|
||||||
peekArray count childNodesPtr
|
|
||||||
pure $ A.RoseF (toEnum (fromIntegral nodeSymbol) :. nodeRange node :. nodeSpan node :. Nil) children
|
|
||||||
|
|
||||||
anaM :: (Corecursive t, Monad m, Traversable (Base t)) => (a -> m (Base t a)) -> a -> m t
|
|
||||||
anaM g = a where a = pure . embed <=< traverse a <=< g
|
|
||||||
|
|
||||||
-- | Parse Python to a list of Terms, printing any assignment errors to stdout. Intended for use in ghci, e.g.:
|
|
||||||
--
|
|
||||||
-- > Command.Files.readFile "/Users/rob/Desktop/test.rb" >>= parsePythonToTerm . source
|
|
||||||
parsePythonToTerm :: Source -> IO (Maybe [Term Python.Syntax A.Location])
|
|
||||||
parsePythonToTerm source = do
|
|
||||||
ast <- parsePythonToAST source
|
|
||||||
let A.Result errors value = A.assign Python.assignment source ast
|
let A.Result errors value = A.assign Python.assignment source ast
|
||||||
case value of
|
case value of
|
||||||
Just a -> pure (Just a)
|
Just a -> pure (Just a)
|
||||||
_ -> traverse_ (putStrLn . ($ "") . A.showError source) errors >> pure Nothing
|
_ -> traverse_ (putStrLn . ($ "") . A.showError source) errors >> pure Nothing
|
||||||
|
|
||||||
|
toAST :: Enum grammar => Node -> IO (A.RoseF (A.Node grammar) Node)
|
||||||
|
toAST node@Node{..} = do
|
||||||
|
let count = fromIntegral nodeChildCount
|
||||||
|
children <- allocaArray count $ \ childNodesPtr -> do
|
||||||
|
_ <- with nodeTSNode (\ nodePtr -> ts_node_copy_child_nodes nullPtr nodePtr childNodesPtr (fromIntegral count))
|
||||||
|
peekArray count childNodesPtr
|
||||||
|
pure $ A.RoseF (toEnum (fromIntegral nodeSymbol) :. nodeRange node :. nodeSpan node :. Nil) children
|
||||||
|
|
||||||
|
anaM :: (Corecursive t, Monad m, Traversable (Base t)) => (a -> m (Base t a)) -> a -> m t
|
||||||
|
anaM g = a where a = pure . embed <=< traverse a <=< g
|
||||||
|
|
||||||
-- | Return a parser for a tree sitter language & document.
|
-- | Return a parser for a tree sitter language & document.
|
||||||
documentToTerm :: Language -> Ptr Document -> Parser (Syntax.Syntax Text) (Record DefaultFields)
|
documentToTerm :: Language -> Ptr Document -> Parser (Syntax.Syntax Text) (Record DefaultFields)
|
||||||
documentToTerm language document SourceBlob{..} = do
|
documentToTerm language document SourceBlob{..} = do
|
||||||
|
Loading…
Reference in New Issue
Block a user