1
1
mirror of https://github.com/github/semantic.git synced 2025-01-02 20:41:38 +03:00

WIP typescript import restructuring

This commit is contained in:
Timothy Clem 2018-01-12 17:22:04 -07:00
parent 34640ef7d2
commit 7359d16dd9

View File

@ -616,19 +616,22 @@ statementIdentifier :: Assignment
statementIdentifier = makeTerm <$> symbol StatementIdentifier <*> (Syntax.Identifier <$> source)
importStatement :: Assignment
importStatement = makeTerm <$> symbol Grammar.ImportStatement <*> children (Declaration.Import <$> (((\a b -> [a, b]) <$> term importClause <*> term fromClause) <|> (pure <$> term (importRequireClause <|> string))))
importClause :: Assignment
importClause = makeTerm <$> symbol Grammar.ImportClause <*> children (TypeScript.Syntax.ImportClause <$> (((\a b -> [a, b]) <$> term identifier <*> term (namespaceImport <|> namedImports)) <|> (pure <$> term (namespaceImport <|> namedImports <|> identifier))))
namedImports :: Assignment
importStatement = mkImport <$> symbol Grammar.ImportStatement <*> children ((,) <$> importClause <*> expression)
<|> mkImport' <$> symbol Grammar.ImportStatement <*> children ((,) <$> stringClause <*> emptyTerm)
<|> mkImport' <$> symbol Grammar.ImportStatement <*> children ((,) <$> importRequireClause <*> emptyTerm)
where
stringClause = (,) <$> emptyTerm <*> string
importClause = symbol Grammar.ImportClause *> children (namespace <|> named <|> plain)
importRequireClause = symbol Grammar.ImportRequireClause *> children require
plain = (,) <$> expressions <*> emptyTerm
namespace = (,) <$> emptyTerm <*> namespaceImport
named = (,) <$> namedImports <*> emptyTerm
namedImports = makeTerm <$> symbol Grammar.NamedImports <*> children (TypeScript.Syntax.NamedImports <$> manyTerm importExportSpecifier)
namespaceImport :: Assignment
namespaceImport = makeTerm <$> symbol Grammar.NamespaceImport <*> children (TypeScript.Syntax.NamespaceImport <$> term identifier)
mkImport loc ((symbols, alias), from) = makeTerm loc (Declaration.Import from alias symbols)
importRequireClause :: Assignment
importRequireClause = makeTerm <$> symbol Grammar.ImportRequireClause <*> children (TypeScript.Syntax.ImportRequireClause <$> term identifier <*> term string)
require = (,) <$> term identifier <*> term string
mkImport' loc ((alias, from), symbols) = makeTerm loc (Declaration.Import from alias symbols)
debuggerStatement :: Assignment
debuggerStatement = makeTerm <$> symbol Grammar.DebuggerStatement <*> (TypeScript.Syntax.Debugger <$ source)