1
1
mirror of https://github.com/github/semantic.git synced 2025-01-05 14:11:33 +03:00

Skip all but regular nodes.

This commit is contained in:
Rob Rix 2017-04-13 10:34:37 -04:00
parent 86f5e21529
commit 309636dc2c

View File

@ -16,6 +16,7 @@ import Control.Monad.Free.Freer
import Data.Functor.Classes import Data.Functor.Classes
import Data.Functor.Foldable import Data.Functor.Foldable
import Prologue hiding (Alt) import Prologue hiding (Alt)
import Text.Parser.TreeSitter.Language
import Text.Show hiding (show) import Text.Show hiding (show)
-- | Assignment from an AST with some set of 'symbol's onto some other value. -- | Assignment from an AST with some set of 'symbol's onto some other value.
@ -63,15 +64,15 @@ data Result a = Result a | Error [Text]
-- | Run an assignment of nodes in a grammar onto terms in a syntax, discarding any unparsed nodes. -- | Run an assignment of nodes in a grammar onto terms in a syntax, discarding any unparsed nodes.
assignAll :: (Eq grammar, Show grammar) => Assignment grammar a -> [AST grammar] -> Result a assignAll :: (Symbol grammar, Eq grammar, Show grammar) => Assignment grammar a -> [AST grammar] -> Result a
assignAll assignment nodes = case runAssignment assignment nodes of assignAll assignment nodes = case runAssignment assignment nodes of
Result ([], a) -> Result a Result ([], a) -> Result a
Result (c:_, _) -> Error ["Expected end of input, but got: " <> show c] Result (c:_, _) -> Error ["Expected end of input, but got: " <> show c]
Error e -> Error e Error e -> Error e
-- | Run an assignment of nodes in a grammar onto terms in a syntax. -- | Run an assignment of nodes in a grammar onto terms in a syntax.
runAssignment :: (Eq grammar, Show grammar) => Assignment grammar a -> [AST grammar] -> Result ([AST grammar], a) runAssignment :: (Symbol grammar, Eq grammar, Show grammar) => Assignment grammar a -> [AST grammar] -> Result ([AST grammar], a)
runAssignment = iterFreer (\ assignment yield nodes -> case (assignment, nodes) of runAssignment = iterFreer (\ assignment yield nodes -> case (assignment, dropWhile ((/= Regular) . symbolType . nodeSymbol . roseValue) nodes) of
-- Nullability: some rules, e.g. 'pure a' and 'many a', should match at the end of input. Either side of an alternation may be nullable, ergo Alt can match at the end of input. -- Nullability: some rules, e.g. 'pure a' and 'many a', should match at the end of input. Either side of an alternation may be nullable, ergo Alt can match at the end of input.
(Alt a b, nodes) -> yield a nodes <|> yield b nodes -- FIXME: Rule `Alt` Rule `Alt` Rule is inefficient, should build and match against an IntMap instead. (Alt a b, nodes) -> yield a nodes <|> yield b nodes -- FIXME: Rule `Alt` Rule `Alt` Rule is inefficient, should build and match against an IntMap instead.
(assignment, node@(Rose Node{..} children) : rest) -> case assignment of (assignment, node@(Rose Node{..} children) : rest) -> case assignment of