pegjs/lib/typings/generated-parser.d.ts
Futago-za Ryuu 21a6de06d5 Optional features
This commit enables optional features that are enabled by default in the generated parser.

For now, only some of the helpers and filename are generated based on this new option, but this will change in the future most likely.

Resolves #421
2018-03-17 04:08:05 +00:00

150 lines
2.7 KiB
TypeScript

export = generatedparser;
declare namespace generatedparser {
/**
* Provides information pointing to a location within a source.
*/
interface SourcePosition {
offset: number;
line: number;
column: number;
}
/**
* The `start` and `end` position's of an object within the source.
*/
interface SourceLocation {
start: SourcePosition;
end: SourcePosition;
}
/**
* An object that can be used to make a generated parser trace it's progress.
*/
interface ITracer {
trace( event: {
type: string;
rule: string;
result?: string;
location: SourceLocation;
} );
}
interface ISyntaxError<T> {
name: string;
message: string;
stack?: string | any;
expected?: T;
found?: string;
location: SourceLocation;
}
interface SyntaxError<T> {
new( message: string, expected: T, found: string | null, location: SourceLocation ): ISyntaxError<T>;
readonly prototype: ISyntaxError<T>;
buildMessage( expected: T, found?: string ): string;
}
interface SyntaxExpectation {
type: string;
description?: string;
text?: string;
parts?: string[];
inverted?: boolean;
ignoreCase?: boolean;
expected?: SyntaxExpectation;
}
interface LiteralExpectation {
type: "literal";
text: string;
ignoreCase: boolean;
}
interface ClassExpectation {
type: "class";
parts: string[];
inverted: boolean;
ignoreCase: boolean;
}
interface AnyExpectation {
type: "any";
}
interface EndExpectation {
type: "end";
}
interface OtherExpectation {
type: "other";
description: string;
}
interface NotExpectation {
type: "not";
expected: SyntaxExpectation;
}
type SyntaxErrorConstructor
= SyntaxError<LiteralExpectation>
| SyntaxError<ClassExpectation>
| SyntaxError<AnyExpectation>
| SyntaxError<EndExpectation>
| SyntaxError<OtherExpectation>
| SyntaxError<NotExpectation>
| SyntaxError<SyntaxExpectation>;
/**
* Default options that are shared by all generated parser's.
*/
interface IOptions {
[ key: string ]: any;
filename?: string;
startRule?: string;
tracer?: ITracer;
}
/**
* API for the parser generated by PEG.js
*/
interface API<T = any> {
SyntaxError: SyntaxErrorConstructor;
DefaultTracer?: ITracer;
parse( input: string, options?: IOptions ): T;
}
}