Update tsd to include latest changes

These changes are mainly from from @Minigun and @futagoza
This commit is contained in:
Futago-za Ryuu 2018-01-26 10:32:55 +00:00
parent 4b6ceb2b46
commit f41ef82ce9
2 changed files with 68 additions and 65 deletions

97
lib/typings/api.d.ts vendored
View file

@ -5,7 +5,7 @@ export as namespace peg;
declare namespace peg { declare namespace peg {
type Grammar = parser.ast.Grammar; type AST = parser.Grammar;
type GeneratedParser<T = any> = gp.API<T>; type GeneratedParser<T = any> = gp.API<T>;
type SyntaxError = gp.SyntaxErrorConstructor; type SyntaxError = gp.SyntaxErrorConstructor;
type SourceLocation = gp.SourceLocation; type SourceLocation = gp.SourceLocation;
@ -33,49 +33,84 @@ declare namespace peg {
*/ */
namespace parser { namespace parser {
/**
* PEG.js node constructor, used internally by the PEG.js to create nodes.
*/
class Node {
type: string;
location: SourceLocation;
constructor( type: string, location: SourceLocation );
}
/**
* The main PEG.js AST class returned by the parser.
*/
class Grammar extends Node {
// Default properties and methods
private readonly _alwaysConsumesOnSuccess: any;
type: "grammar";
comments?: CommentMao;
initializer?: ast.Initializer;
rules: ast.Rule[];
constructor(
initializer: void | ast.Initializer,
rules: ast.Rule[],
comments: void | CommentMao,
location: SourceLocation,
);
findRule( name: string ): ast.Rule | void;
indexOfRule( name: string ): number;
alwaysConsumesOnSuccess( node: ast.Node ): boolean;
// Added by Bytecode generator
literals?: string[];
classes?: string[];
expectations?: string[];
functions?: string[];
// Added by JavaScript generator
code?: string;
}
interface CommentMao {
[ offset: number ]: {
text: string;
multiline: boolean;
location: SourceLocation;
};
}
/** /**
* Interface's that describe the abstact sytax tree used by PEG.js * Interface's that describe the abstact sytax tree used by PEG.js
*/ */
namespace ast { namespace ast {
interface INode extends parser.Node { }
/** /**
* Unlike `parser.ast.INode` this interface represent's all PEG.js node's. * Unlike `parser.Node` this interface represent's all PEG.js node's.
*/ */
type Node type Node
= Grammar = parser.Grammar
| Initializer | Initializer
| Rule | Rule
| Named | Named
| Expression; | Expression;
/**
* Basic representation of a PEG.js node.
*/
interface INode {
type: string;
location: SourceLocation;
}
interface Grammar extends INode {
// Default properties
type: "grammar";
initializer?: Initializer;
rules: Rule[];
// Added by Bytecode generator
consts?: string[];
// Added by JavaScript generator
code?: string;
}
interface Initializer extends INode { interface Initializer extends INode {
type: "initializer"; type: "initializer";

View file

@ -20,27 +20,8 @@ declare module "pegjs/lib/parser" {
declare module "pegjs/lib/parser/ast" { declare module "pegjs/lib/parser/ast" {
export class Node { export const Node: peg.parser.Node;
export const Grammar: peg.parser.Grammar;
type: string;
location: peg.SourceLocation;
constructor( type: string, location: peg.SourceLocation );
}
export class Grammar extends Node {
initializer?: peg.parser.ast.Initializer;
rules: peg.parser.ast.Rule[];
constructor(
initializer: void | peg.parser.ast.Initializer,
rules: peg.parser.ast.Rule[],
location: peg.SourceLocation,
);
}
} }
@ -62,19 +43,6 @@ declare module "pegjs/lib/compiler" {
} }
declare module "pegjs/lib/compiler/asts" {
namespace asts {
function findRule( ast: peg.Grammar, name: string ): peg.parser.ast.Rule | void;
function indexOfRule( ast: peg.Grammar, name: string ): number;
function alwaysConsumesOnSuccess( ast: peg.Grammar, node: peg.parser.ast.Node ): boolean;
}
export default asts;
}
declare module "pegjs/lib/compiler/index" { declare module "pegjs/lib/compiler/index" {
export default peg.compiler; export default peg.compiler;