用javascript實現一門程式語言-字元輸入流

Alongite發表於2018-08-03

目錄

  1. 用javascript實現一門程式語言-前言
  2. 用javascript實現一門程式語言-語言構想
  3. 用javascript實現一門程式語言-寫一個解析器
  4. 用javascript實現一門程式語言-字元輸入流

字元輸入流

原文中是the character input stream,不知道怎麼翻譯好,就翻譯成字元輸入流

我們在這部分將會建立一個stream object,用來提供從字串讀取字元的方法。stream object包含四個方法:

  • peek() -- 讀取下一個值
  • next() -- 讀取下一個值,並且將這個值從輸入流移除
  • eof() -- 當輸入流中沒用值時,返回true
  • croak(msg) -- 用來丟擲錯誤

為什麼將丟擲錯誤的方法croak放到這裡,是因為在這裡能更簡單的來獲錯誤發生的位置,這對於提示錯誤資訊很重要。

你可以根據自己的需要在這裡新增任何函式。這四個函式對於我們這個教程已經夠用了。

字元輸入流是面向字元的,所以next()peek()函式的返回值是一個字元(char型別,因為javascript中沒有char型別,所以返回的是長度唯一的string)。

以下是stream object的程式碼:

function InputStream(input) {
    var pos = 0, line = 1, col = 0;
    return {
        next  : next,
        peek  : peek,
        eof   : eof,
        croak : croak,
    };
    function next() {
        var ch = input.charAt(pos++);
        if (ch == "\n") line++, col = 0; else col++;
        return ch;
    }
    function peek() {
        return input.charAt(pos);
    }
    function eof() {
        return peek() == "";
    }
    function croak(msg) {
        throw new Error(msg + " (" + line + ":" + col + ")");
    }
}
複製程式碼

原文連結: lisperator.net/pltut/parse…

相關文章