refactor(Lexer): switch token types to an enum
This commit is contained in:
parent
9700e80698
commit
edd01615c3
|
@ -8,15 +8,16 @@ import {
|
||||||
isPresent
|
isPresent
|
||||||
} from "angular2/src/facade/lang";
|
} from "angular2/src/facade/lang";
|
||||||
|
|
||||||
const TOKEN_TYPE_CHARACTER = 1;
|
enum TokenType {
|
||||||
const TOKEN_TYPE_IDENTIFIER = 2;
|
CHARACTER,
|
||||||
const TOKEN_TYPE_KEYWORD = 3;
|
IDENTIFIER,
|
||||||
const TOKEN_TYPE_STRING = 4;
|
KEYWORD,
|
||||||
const TOKEN_TYPE_OPERATOR = 5;
|
STRING,
|
||||||
const TOKEN_TYPE_NUMBER = 6;
|
OPERATOR,
|
||||||
|
NUMBER
|
||||||
|
}
|
||||||
|
|
||||||
@Injectable()
|
@Injectable() export class Lexer {
|
||||||
export class Lexer {
|
|
||||||
tokenize(text: string): List<any> {
|
tokenize(text: string): List<any> {
|
||||||
var scanner = new _Scanner(text);
|
var scanner = new _Scanner(text);
|
||||||
var tokens = [];
|
var tokens = [];
|
||||||
|
@ -30,86 +31,87 @@ export class Lexer {
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Token {
|
export class Token {
|
||||||
constructor(public index: number, public type: number, public numValue: number,
|
constructor(public index: number, public type: TokenType, public numValue: number,
|
||||||
public strValue: string) {}
|
public strValue: string) {}
|
||||||
|
|
||||||
isCharacter(code: number): boolean {
|
isCharacter(code: number): boolean {
|
||||||
return (this.type == TOKEN_TYPE_CHARACTER && this.numValue == code);
|
return (this.type == TokenType.CHARACTER && this.numValue == code);
|
||||||
}
|
}
|
||||||
|
|
||||||
isNumber(): boolean { return (this.type == TOKEN_TYPE_NUMBER); }
|
isNumber(): boolean { return (this.type == TokenType.NUMBER); }
|
||||||
|
|
||||||
isString(): boolean { return (this.type == TOKEN_TYPE_STRING); }
|
isString(): boolean { return (this.type == TokenType.STRING); }
|
||||||
|
|
||||||
isOperator(operater: string): boolean {
|
isOperator(operater: string): boolean {
|
||||||
return (this.type == TOKEN_TYPE_OPERATOR && this.strValue == operater);
|
return (this.type == TokenType.OPERATOR && this.strValue == operater);
|
||||||
}
|
}
|
||||||
|
|
||||||
isIdentifier(): boolean { return (this.type == TOKEN_TYPE_IDENTIFIER); }
|
isIdentifier(): boolean { return (this.type == TokenType.IDENTIFIER); }
|
||||||
|
|
||||||
isKeyword(): boolean { return (this.type == TOKEN_TYPE_KEYWORD); }
|
isKeyword(): boolean { return (this.type == TokenType.KEYWORD); }
|
||||||
|
|
||||||
isKeywordVar(): boolean { return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "var"); }
|
isKeywordVar(): boolean { return (this.type == TokenType.KEYWORD && this.strValue == "var"); }
|
||||||
|
|
||||||
isKeywordNull(): boolean { return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "null"); }
|
isKeywordNull(): boolean { return (this.type == TokenType.KEYWORD && this.strValue == "null"); }
|
||||||
|
|
||||||
isKeywordUndefined(): boolean {
|
isKeywordUndefined(): boolean {
|
||||||
return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "undefined");
|
return (this.type == TokenType.KEYWORD && this.strValue == "undefined");
|
||||||
}
|
}
|
||||||
|
|
||||||
isKeywordTrue(): boolean { return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "true"); }
|
isKeywordTrue(): boolean { return (this.type == TokenType.KEYWORD && this.strValue == "true"); }
|
||||||
|
|
||||||
isKeywordIf(): boolean { return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "if"); }
|
isKeywordIf(): boolean { return (this.type == TokenType.KEYWORD && this.strValue == "if"); }
|
||||||
|
|
||||||
isKeywordElse(): boolean { return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "else"); }
|
isKeywordElse(): boolean { return (this.type == TokenType.KEYWORD && this.strValue == "else"); }
|
||||||
|
|
||||||
isKeywordFalse(): boolean {
|
isKeywordFalse(): boolean { return (this.type == TokenType.KEYWORD && this.strValue == "false"); }
|
||||||
return (this.type == TOKEN_TYPE_KEYWORD && this.strValue == "false");
|
|
||||||
}
|
|
||||||
|
|
||||||
toNumber(): number {
|
toNumber(): number {
|
||||||
// -1 instead of NULL ok?
|
// -1 instead of NULL ok?
|
||||||
return (this.type == TOKEN_TYPE_NUMBER) ? this.numValue : -1;
|
return (this.type == TokenType.NUMBER) ? this.numValue : -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
toString(): string {
|
toString(): string {
|
||||||
var t: number = this.type;
|
switch (this.type) {
|
||||||
if (t >= TOKEN_TYPE_CHARACTER && t <= TOKEN_TYPE_STRING) {
|
case TokenType.CHARACTER:
|
||||||
return this.strValue;
|
case TokenType.STRING:
|
||||||
} else if (t == TOKEN_TYPE_NUMBER) {
|
case TokenType.IDENTIFIER:
|
||||||
return this.numValue.toString();
|
case TokenType.KEYWORD:
|
||||||
} else {
|
return this.strValue;
|
||||||
return null;
|
case TokenType.NUMBER:
|
||||||
|
return this.numValue.toString();
|
||||||
|
default:
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function newCharacterToken(index: number, code: number): Token {
|
function newCharacterToken(index: number, code: number): Token {
|
||||||
return new Token(index, TOKEN_TYPE_CHARACTER, code, StringWrapper.fromCharCode(code));
|
return new Token(index, TokenType.CHARACTER, code, StringWrapper.fromCharCode(code));
|
||||||
}
|
}
|
||||||
|
|
||||||
function newIdentifierToken(index: number, text: string): Token {
|
function newIdentifierToken(index: number, text: string): Token {
|
||||||
return new Token(index, TOKEN_TYPE_IDENTIFIER, 0, text);
|
return new Token(index, TokenType.IDENTIFIER, 0, text);
|
||||||
}
|
}
|
||||||
|
|
||||||
function newKeywordToken(index: number, text: string): Token {
|
function newKeywordToken(index: number, text: string): Token {
|
||||||
return new Token(index, TOKEN_TYPE_KEYWORD, 0, text);
|
return new Token(index, TokenType.KEYWORD, 0, text);
|
||||||
}
|
}
|
||||||
|
|
||||||
function newOperatorToken(index: number, text: string): Token {
|
function newOperatorToken(index: number, text: string): Token {
|
||||||
return new Token(index, TOKEN_TYPE_OPERATOR, 0, text);
|
return new Token(index, TokenType.OPERATOR, 0, text);
|
||||||
}
|
}
|
||||||
|
|
||||||
function newStringToken(index: number, text: string): Token {
|
function newStringToken(index: number, text: string): Token {
|
||||||
return new Token(index, TOKEN_TYPE_STRING, 0, text);
|
return new Token(index, TokenType.STRING, 0, text);
|
||||||
}
|
}
|
||||||
|
|
||||||
function newNumberToken(index: number, n: number): Token {
|
function newNumberToken(index: number, n: number): Token {
|
||||||
return new Token(index, TOKEN_TYPE_NUMBER, n, "");
|
return new Token(index, TokenType.NUMBER, n, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export var EOF: Token = new Token(-1, 0, 0, "");
|
export var EOF: Token = new Token(-1, TokenType.CHARACTER, 0, "");
|
||||||
|
|
||||||
export const $EOF = 0;
|
export const $EOF = 0;
|
||||||
export const $TAB = 9;
|
export const $TAB = 9;
|
||||||
|
|
Loading…
Reference in New Issue