5a7500ca5e
This is important for incremental parsing, as it is where we can attach parse errors at the end of the file to. Also, it helps with things like emitting comments at the end of the file.
91 lines
1.2 KiB
JavaScript
91 lines
1.2 KiB
JavaScript
//// [concatError.ts]
|
|
|
|
var n1: number[];
|
|
/*
|
|
interface Array<T> {
|
|
concat(...items: T[][]): T[]; // Note: This overload needs to be picked for arrays of arrays, even though both are applicable
|
|
concat(...items: T[]): T[];
|
|
}
|
|
*/
|
|
var fa: number[];
|
|
|
|
fa = fa.concat([0]);
|
|
fa = fa.concat(0);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
|
|
declare class C<T> {
|
|
public m(p1: C<C<T>>): C<T>;
|
|
//public p: T;
|
|
}
|
|
|
|
var c: C<number>;
|
|
var cc: C<C<number>>;
|
|
|
|
c = c.m(cc);
|
|
*/
|
|
|
|
//// [concatError.js]
|
|
var n1;
|
|
/*
|
|
interface Array<T> {
|
|
concat(...items: T[][]): T[]; // Note: This overload needs to be picked for arrays of arrays, even though both are applicable
|
|
concat(...items: T[]): T[];
|
|
}
|
|
*/
|
|
var fa;
|
|
fa = fa.concat([0]);
|
|
fa = fa.concat(0);
|
|
/*
|
|
|
|
|
|
|
|
|
|
declare class C<T> {
|
|
public m(p1: C<C<T>>): C<T>;
|
|
//public p: T;
|
|
}
|
|
|
|
var c: C<number>;
|
|
var cc: C<C<number>>;
|
|
|
|
c = c.m(cc);
|
|
var n1: number[];
|
|
/*
|
|
interface Array<T> {
|
|
concat(...items: T[][]): T[]; // Note: This overload needs to be picked for arrays of arrays, even though both are applicable
|
|
concat(...items: T[]): T[];
|
|
}
|
|
*/
|
|
var fa: number[];
|
|
|
|
fa = fa.concat([0]);
|
|
fa = fa.concat(0);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
|
|
declare class C<T> {
|
|
public m(p1: C<C<T>>): C<T>;
|
|
//public p: T;
|
|
}
|
|
|
|
var c: C<number>;
|
|
var cc: C<C<number>>;
|
|
|
|
c = c.m(cc);
|
|
|