Introduce scope tracking in the parser (#9493)

* Introduce scope tracking

* Fix tests

* Add new tests

* Remove constructor-super check from transform as it is now in parser

* Correctly handle class properties and class scope

* Fix duplicate name check

* Convert scope identifier storage to array

* Enter a new scope in typescript module blocks

* Add test for duplicate declaration

* Rename error for duplicate exports

* Treat class declarations as lexical declaration

* Update whitelist

* Add tests

* Fix scope tracking for function declarations

* Migrate try-catch duplicate error

* Fix test

* More tests

* One more test

* Make scope a separate class and fix review comments

* Do not allow new.target in top scope arrow function

* Correctly enter new scope for declare module and treat type aliases as lexical declarations

* Tests for typescript scope tracking to not mark type aliases as duplicate

* Fix flow scope tracking

* Remove ident from test names as redundant

* Add test case for var and function

* Improve error messages

* Improve literal regex
This commit is contained in:
Daniel Tschinder
2019-02-25 11:04:52 -08:00
committed by GitHub
parent 918f149a63
commit a7391144b3
284 changed files with 5904 additions and 1842 deletions

View File

@@ -1,5 +1,5 @@
export type GraphQLFormattedError = number;
export type GraphQLFormattedError = {
export type GraphQLFormattedError2 = {
message: string,
locations?: Array<{
line: number,
@@ -7,4 +7,4 @@ export type GraphQLFormattedError = {
}>
};
export interface foo { p: number }
export interface foo<T> { p: T }
export interface foo2<T> { p: T }

View File

@@ -1,6 +1,6 @@
/*:: export type GraphQLFormattedError = number;*/
/*:: export type GraphQLFormattedError = {
/*:: export type GraphQLFormattedError2 = {
message: string,
locations?: Array<{
line: number,
@@ -10,4 +10,4 @@
/*:: export interface foo { p: number }*/
/*:: export interface foo<T> { p: T }*/
/*:: export interface foo2<T> { p: T }*/