lisp是一種神奇的語(yǔ)言,scheme是lisp的一種方言。
tinyscheme是一個(gè)scheme語(yǔ)言的解釋器實(shí)現(xiàn),而這是我大幅修改并加了注釋后的tinyscheme(基于tinyscheme1.41)
代碼地址:http://flysnowxg.googlecode.com/svn/tinyscheme_note
原始代碼: http://tinyscheme.sourceforge.net/home.html
tinyscheme據(jù)說(shuō)是實(shí)現(xiàn)的r5rs標(biāo)準(zhǔn)(應(yīng)當(dāng)是實(shí)現(xiàn)了一部分,因?yàn)槟J狡ヅ浜驼Z(yǔ)法定義的那部分顯然沒(méi)實(shí)現(xiàn))
tinyscheme代碼很簡(jiǎn)短而且實(shí)現(xiàn)的語(yǔ)言功能還算比較完整,如果想研究一個(gè)lisp解釋器的實(shí)現(xiàn),tinyscheme是值得研究的
tinyscheme實(shí)現(xiàn)了lambda、宏、延續(xù)、異常、gc這些重要的語(yǔ)言機(jī)制,還實(shí)現(xiàn)了許多庫(kù)函數(shù),整個(gè)原版代碼大約有6500行左右,但是原版代碼有很多的宏定義和很多冗余的代碼,代碼分類(lèi)也很混亂,可讀性不算特別好,在閱讀過(guò)程中我對(duì)這個(gè)代碼進(jìn)行了大量的修改,清除了大量冗余代碼,重新組織了代碼結(jié)構(gòu),主要的實(shí)現(xiàn)文件scheme.c被我從5000行改到只有3400行。所有代碼加起來(lái)也只有4500行了,功能損失也不太多
修改一些bug,比如像‘延續(xù)’的實(shí)現(xiàn),原版像下面這樣的代碼中, “(r 1)”這一句是沒(méi)法運(yùn)行的
(define r 0)
(let ((x 1))
(set! x
(+ x
(call/cc (lambda (c) (set! r c) (+ 44 (c 1)))))
)
(display x))
(r 1)
有興趣的可以看一看!
tinyscheme是一個(gè)scheme語(yǔ)言的解釋器實(shí)現(xiàn),而這是我大幅修改并加了注釋后的tinyscheme(基于tinyscheme1.41)
代碼地址:http://flysnowxg.googlecode.com/svn/tinyscheme_note
原始代碼: http://tinyscheme.sourceforge.net/home.html
tinyscheme據(jù)說(shuō)是實(shí)現(xiàn)的r5rs標(biāo)準(zhǔn)(應(yīng)當(dāng)是實(shí)現(xiàn)了一部分,因?yàn)槟J狡ヅ浜驼Z(yǔ)法定義的那部分顯然沒(méi)實(shí)現(xiàn))
tinyscheme代碼很簡(jiǎn)短而且實(shí)現(xiàn)的語(yǔ)言功能還算比較完整,如果想研究一個(gè)lisp解釋器的實(shí)現(xiàn),tinyscheme是值得研究的
tinyscheme實(shí)現(xiàn)了lambda、宏、延續(xù)、異常、gc這些重要的語(yǔ)言機(jī)制,還實(shí)現(xiàn)了許多庫(kù)函數(shù),整個(gè)原版代碼大約有6500行左右,但是原版代碼有很多的宏定義和很多冗余的代碼,代碼分類(lèi)也很混亂,可讀性不算特別好,在閱讀過(guò)程中我對(duì)這個(gè)代碼進(jìn)行了大量的修改,清除了大量冗余代碼,重新組織了代碼結(jié)構(gòu),主要的實(shí)現(xiàn)文件scheme.c被我從5000行改到只有3400行。所有代碼加起來(lái)也只有4500行了,功能損失也不太多
修改一些bug,比如像‘延續(xù)’的實(shí)現(xiàn),原版像下面這樣的代碼中, “(r 1)”這一句是沒(méi)法運(yùn)行的
(define r 0)
(let ((x 1))
(set! x
(+ x
(call/cc (lambda (c) (set! r c) (+ 44 (c 1)))))
)
(display x))
(r 1)
有興趣的可以看一看!