上周寫了《ThinkPhp模板轉Flask、Django模板》
一時技癢,自然而然地想搞個大家伙,把整個PHP程序轉成Python。不比模板,可以用正則匹配偷懶,這次非寫一個Php編譯器不可。
上網(wǎng)搜了一下,發(fā)現(xiàn)大部分Python to xxx的transpile都是直接基于AST,省略了最重要的Tokenizer,Parser。直接寫個Visitor了事。要不然就是基于Antlr之類的生成器,搞一大堆代碼,看得令人心煩。
既然大家都不想做這個苦力,我就來試試,手工寫一個Php編譯器。分Tokenizer,Parser,Visitor三個部分來實現(xiàn)。
翻出《龍書》《虎書》做參考,仔細學了一回PHP,不學不知道,原來PHP有那么多特性,做個編譯器真心累人。
詞法部分很簡單,就是一個自動機。設計了一個結構存放自動機,然后簡單粗暴地在自動機上編程,也顧不上什么性能了,就是個一錘子買賣。
寫得還算快,調試不是很順,不過我是不會說的,哈
自動機不復雜,發(fā)上來大家看看,敬請指正。
self.statema