首先声明一下,我们的IDoom3Tokenizer词法解析器仅支持ASCII编码字符串的解析,不支持UNICODE编码字符串的解析(换句话说,我们的词法解析器不支持中文解析),实际上Doom3引擎文本格式文件也仅支持ASCII编码的字符串。   然后再想强调一点,像Java的JDK,C#的.NET Framework或C语言的crt(C语言运行库)都内置了强大的ASCII字符处理函数,但是在TypeScript或JavaScript中处理ASCII字符的一些操作需要自己来实现,那么我们就先来实现两个简单但是必须的ASCII字符处理函数,具体代码如下:

// 接口实现使用implements关键字
class Doom3Tokenizer implements IDoom3Tokenizer {
    // 使用了初始化表达式方式初始化字符串数组
    private _digits : string [ ] = [ "0" , "1" , "2" , "3" , "4" , "5" , "6" , "7" , "8" , "9" ] ;
    private _whiteSpaces : string [ ] = [ " " , "\t" , "\v" , "\n" ] ;

    //判断某个字符是不是数字
    private _isDigit ( c : string ) : boolean {
        for ( let i : number = 0 ; i < this . _digits . length ; i++ ) {
            if ( c === this. _digits [ i ] ) {
                return true ;
            }
        }
        return false ;
    }
   //判断某个字符是不是空白符
   //一般我们将空格符(" "),水平制表符(\t),垂直制表符(\v)以及换行符(\n)统称为空白符
    private _isWhitespace ( c : string ) : boolean {
        for ( let i : number = 0 ; i < this . _whiteSpaces . length ; i++ ) {
            if ( c === this . _whiteSpaces [ i ] ) {
                return true ;
            }
        }
        return false;
    }
}
随风而行之青衫磊落险峰行(www.buleifeng.top) all right reserved,powered by Gitbook本文件修订时间: 2019-10-10 16:26:47

results matching ""

    No results matching ""