1
1
mirror of https://github.com/github/semantic.git synced 2025-01-05 05:58:34 +03:00

Merge branch 'python-assignment' of github.com:github/semantic-diff into python-assignment

This commit is contained in:
Rick Winfrey 2017-05-16 10:49:54 -07:00
commit 32a8b9d979
2 changed files with 20 additions and 46 deletions

@ -1 +1 @@
Subproject commit 04fd77ba80a49c4db32e5063dcabb2de5dbce866 Subproject commit 7c0c68390ae6c7a456499cc1087773cd4d02185c

View File

@ -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