青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-341  評論-2670  文章-0  trackbacks-0

    大概一年前曾經用C++開發了一個可以在C++中直接寫上下文無關文法的上下文無關文法分析器。這玩意兒叫Syngram。Syngram曾經做了兩次,第一次做成了用一個類去讀文法文件,后來不爽就改成了直接在C++里面寫的。我弄了一個叫Term的類,重載了一些操作符,于是你可以搞分支、可選、錯誤處理等復雜的文法推導式。現在打算做一個周邊工具。

    這個周邊工具的由來是這樣的。后來我用Syngram開發了一個支持namespace、class和函數的動態語言Vczh Free Script 2.0 beta,這個動態語言支持面向對象、泛型以及函數式等若干范式,語言可以調用編譯器編譯一個字符串并操作。虛擬機被我做成了兩個dll,一個是給native c++調用的,另一個是給C# 3.0調用的。編譯器我用了Syngram,在上面那個鏈接所提供的代碼里就有一個文件,布滿了文法推導式以及每一個式子的語義函數。旁邊的一個文件寫了一個很大的語法樹數據結構,是一組C++類。

    這門腳本語言的第一個版本的編譯器開發長達三天,因為我要花一天時間做文法,一天時間做語法樹,一天時間生成指令。第一版只支持閉包和數組。這么小的語言寫一個編譯器花了三天實在是浪費的太多了,因為后來我發現語法樹是一個很有規律的東西。我就在想,能不能我就寫一點點東西,然后有一個工具就幫我把這些代碼寫出來呢?前幾天洗澡的時候想到了一個解決方案。

    我可以用一種很簡便的方法寫一個可以被轉換成C++的類、列表、字典和枚舉類型的語法樹模型,然后將一點點東西添加在推導式里面告訴推導式創建什么樣的對象、如何修改對象、列表和字典等。錯誤信息的產生以及錯誤恢復已經在Syngram里面實現了,很容易支持進去。于是現在又變成了類似讀文法文件產生代碼的東西了,不過跟Syngram第一版有很大區別。

    首先,Syngram作為一個C++的類庫,仍然可以支持在C++里直接寫文法、錯誤處理以及語義函數。
    第二,這個新的工具讀入文法文件之后,產生的并不是一個完整的語法分析器,而是一些基于Syngram類庫的代碼。
    第三,這個新的工具的最大好處在于可以在自己寫的語義函數(將分析結果轉換成自己想要的語法樹)中和自己寫語法樹的數據結構(特別是相應的一些虛函數族)這兩個沒有挑戰性而且很煩的工作中解放出來。工具將根據輸入的文件生成用于表達數據結構的一堆類(通常是幾十個),根據需求自動分成幾個繼承的組,為他們添加一兩個使用了Visitor模式的接口。于是虛函數的方便被轉移到了Visitor模式的產物中,自己的代碼跟生成的代碼完全隔離。
    最后,說不定這個工具有GUI。

    前幾天完成了Syngram所屬的Vczh Library ++ 2.0中的GUI Framework預覽版。這個東西的初衷是寫給我自己用的,因為我很不喜歡MFC等有BEGIN_MESSAGE_MAP或者需要我處理WPARAM和LPARAM的界面庫,于是自己弄了一個。不過GUI Framework實在是龐大,一個人做起來也是比較吃力的。如果我心情好GUI 1.0 beta比這個Syngram Helper早完成的話,那么Syngram Helper就會有GUI用了。今天寫了個簡單的語法文件的文法,貼出來先。里面的注釋用英語僅僅是因為我懶的來回切換輸入法,估計有一堆語法錯誤,不要計較。

KEYWORD  ->class
  ->bool
  ->int
  ->double
  ->string
  ->list
  ->map
  ->term
  ->infer
OPERATOR ->[
  ->]
  -><
  ->>
  ->,
  ->=
  ->|
  ->:
  ->#
  ->@

IDENT  ->[a-zA-Z_]\w*
REGEX  ->[^\r\n]+\r\n
COMMENT  ->'[^\r\n]*\r\n
STRING  ->"([^\\"]|\\\.)*"

CLASS   ->class IDENT [: IDENT] "{" MEMBERS "}"
ENUM  ->enum IDENT "{" IDENTS "}"
MEMBER  ->TYPE IDENT
  ->STRING IDENT //external member, treat STRING as type, can not be accessed in semantic rule
TYPE  ->bool
  ->int
  ->double
  ->string
  ->token  //store a token
  ->list<TYPE>
  ->map<TYPE,TYPE>
  ->multimap<TYPE,TYPE>

LEXICAL  ->term IDENT REGEX
SYNTAX  ->infer TYPE IDENT RULE_EXP
RULE_EXP ->[ RULE_EXP "|" ]RULE_SERIES
RULE_SERIES ->[ RULE_SERIES ]RULE_UNIT
RULE_UNIT ->RULE_TERM
  ->"[" RULE_EXP "]"
RULE_TERM ->IDENT [ "[" SEMANTICS "]" ]

SEMANTIC ->SEMANTIC_TARGET [ "=" SEMANTIC_SOURCE ]
SEMANTIC_TARGET ->:IDENT // Field of result, new map item or new list item
SEMANTIC_TARGET ->#key  // add item in result map using this key
SEMANTIC_TARGET ->#value // add item in result map using this value
SEMANTIC_TARGET ->#item  // add item in result list using this value
SEMANTIC_TARGET ->#result // treat this value as the result, result map or result list
    // new item in a path is not required if there is at least a #result term in the same path
SEMANTIC_TARGET ->#alias // name this value as SEMANTIC_SOURCE
SEMANTIC_TARGET ->#error // treat SEMANTIC_SOURCE as error message
SEMANTIC_TARGET ->#keyerror // treat SEMANTIC_SOURCE as error message and raise an error if the specified key exists
SEMANTIC_TARGET ->#past  // past this term when error occurs
SEMANTIC_TARGET ->#read  // read a token when error occurs
SEMANTIC_TARGET ->#exit  // terminate parsing when error occurs
SEMANTIC_SOURCE ->IDENT  // value of alias or enumeration item
SEMANTIC_SOURCE ->STRING // value of error message
SEMANTIC_SOURCE ->@IDENT // value of external string
/*
#key, #value, #item, #result : can only appears once in a path
#alias    : can not be conflict in a path
#error, #past, #read, #exit : can only appears once in a term
#alias, #error   : must be used with SEMANTIC_SOURCE
#keyerror   : can only appears once in a term, must be used with #key
:IDENT    : can not be conflict in a path
*/

IDENTS  ->IDENT [IDENTS]
MEMBER  ->MEMBER [MEMBERS]
SEMANTICS ->SEMANTIC ["," SEMANTICS]
TYPES  ->( CLASS | ENUM )[TYPES]
LEXICALS ->LEXICAL[LEXICALS]
SYNTAXES ->SYNTAX[SYNTAXES]

PROGRAM  ->TYPES LEXICALS SYNTAXES

posted on 2008-08-27 05:11 陳梓瀚(vczh) 閱讀(1880) 評論(5)  編輯 收藏 引用 所屬分類: 腳本技術

評論:
# re: Syngram Helper開始設計:一個能用來寫編譯器的工具 2008-08-27 06:25 | Lnn
super!  回復  更多評論
  
# re: Syngram Helper開始設計:一個能用來寫編譯器的工具 2008-08-27 09:13 | Michel
是否可以公布一下你的學習曲線?
讀過哪些讀物能夠達到現在的程度?需要做哪些努力,關注哪些方面?
如果您的飲食對您的能力有所提高的話,也可以公布一下~  回復  更多評論
  
# re: Syngram Helper開始設計:一個能用來寫編譯器的工具 2008-08-27 09:25 | 陳梓瀚(vczh)
事實上我以前是做圖形的,后來中途改方向,反正現在看起來以前走的路還真是亂七八糟。罷了。  回復  更多評論
  
# re: Syngram Helper開始設計:一個能用來寫編譯器的工具 2008-08-27 17:01 | foxtail
誰都說不清自己學習的路 摸爬滾打過來的  回復  更多評論
  
# re: Syngram Helper開始設計:一個能用來寫編譯器的工具 2008-08-27 19:19 | 空明流轉
這個 Demo 倒是挺簡潔的。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            免费黄网站欧美| 欧美韩日高清| 亚洲黄色成人| 亚洲国产老妈| 最新亚洲激情| 亚洲图片欧美午夜| 欧美一激情一区二区三区| 久久福利精品| 欧美成人国产| 亚洲午夜电影在线观看| 午夜一区二区三区不卡视频| 亚洲自拍三区| 久久久国产午夜精品| 欧美黄色一级视频| 国产精品视频久久久| 亚洲国产日韩精品| 亚洲免费视频在线观看| 久久先锋影音| av不卡免费看| 久久午夜影视| 国产精品v欧美精品v日本精品动漫| 国产日韩欧美精品一区| 91久久中文字幕| 久久高清一区| 一区二区三区四区五区精品| 久久久综合网| 国产精品看片资源| 亚洲剧情一区二区| 久久蜜桃精品| 亚洲永久精品国产| 国产精品久久综合| 亚洲——在线| 久久久久久久久久看片| 欧美成人黑人xx视频免费观看| 国产精品videosex极品| 亚洲国产精品尤物yw在线观看| 午夜国产欧美理论在线播放| 欧美激情一区在线观看| 欧美一区二区三区四区在线 | 久久一区中文字幕| 欧美色图天堂网| 亚洲人成亚洲人成在线观看| 久久九九久精品国产免费直播| 亚洲久久一区| 欧美高清视频一区二区三区在线观看| 激情一区二区三区| 久久一区二区三区四区| 欧美一区二区三区日韩| 国产精品一卡| 性久久久久久| 亚洲永久免费| 国产日韩欧美中文| 欧美有码在线观看视频| 亚洲视频中文字幕| 国产精品草草| 欧美一区二区啪啪| 欧美一区二区播放| 国产丝袜一区二区| 乱人伦精品视频在线观看| 欧美亚洲免费| 狠狠爱www人成狠狠爱综合网| 久久疯狂做爰流白浆xx| 欧美一区成人| 激情校园亚洲| 欧美激情国产高清| 欧美激情国产日韩| 一区二区欧美视频| 亚洲视频一二| 国产亚洲精品久久久久动| 久久aⅴ乱码一区二区三区| 欧美一区深夜视频| 亚洲国产精品久久| 亚洲精品免费看| 欧美精品在线看| 亚洲免费一在线| 亚洲欧美网站| 在线看无码的免费网站| 亚洲国产mv| 国产精品久久久久一区| 久久精品99国产精品| 老鸭窝毛片一区二区三区| 亚洲精品社区| 午夜国产欧美理论在线播放 | 亚洲电影在线| 亚洲欧洲综合另类| 欧美一区二区三区在线观看| 亚洲精品综合精品自拍| 亚洲国产精品成人| 国产精品九九久久久久久久| 久久超碰97中文字幕| 久久综合久色欧美综合狠狠| 中文在线一区| 久久综合激情| 午夜性色一区二区三区免费视频| 久久久一二三| 午夜在线精品| 欧美精品亚洲| 免费一级欧美片在线观看| 欧美视频亚洲视频| 欧美二区在线| 韩国欧美一区| 亚洲综合二区| 亚洲视频免费| 免费观看成人www动漫视频| 欧美一区二区免费| 欧美日韩精品是欧美日韩精品| 久久精精品视频| 国产精品yjizz| 最新亚洲电影| 伊人久久大香线蕉综合热线| 一卡二卡3卡四卡高清精品视频 | 国产在线乱码一区二区三区| 最新国产成人av网站网址麻豆| 国产麻豆一精品一av一免费| 91久久在线视频| 亚洲国产99精品国自产| 亚洲欧美久久久| 亚洲视频欧洲视频| 免费在线成人av| 久久免费国产精品| 国产日产欧产精品推荐色| 一区二区三区高清在线| 亚洲靠逼com| 免费欧美日韩国产三级电影| 久久久欧美一区二区| 国产区精品视频| 午夜视频久久久久久| 亚洲欧美日韩另类精品一区二区三区| 欧美顶级大胆免费视频| 欧美国内亚洲| 亚洲日本欧美天堂| 欧美成人免费在线| 欧美搞黄网站| 亚洲人www| 欧美韩国一区| 亚洲国产精品精华液网站| 亚洲人成精品久久久久| 欧美激情成人在线| 亚洲日韩欧美一区二区在线| 一本色道久久综合亚洲精品不| 欧美精品18| 一本一本久久| 欧美专区亚洲专区| 一区二区三区在线视频免费观看| 久久婷婷国产综合国色天香| 欧美黑人在线观看| 一区二区三区波多野结衣在线观看| 欧美视频在线观看一区二区| 亚洲资源av| 六月丁香综合| 99视频一区| 国产日韩精品视频一区二区三区| 国产视频在线观看一区二区| 亚洲欧洲日本国产| 日韩视频精品在线观看| 欧美午夜精品伦理| 新67194成人永久网站| 久久午夜国产精品| 亚洲精品女av网站| 欧美日韩一区二区在线 | 久久夜色精品| 亚洲精品免费电影| 国产精品乱码一区二三区小蝌蚪 | 亚洲午夜国产成人av电影男同| 欧美一区二区三区男人的天堂| 红桃av永久久久| 欧美精品福利在线| 欧美一级淫片播放口| 欧美激情一级片一区二区| 一区二区毛片| 精品成人一区二区三区| 欧美日韩色综合| 久久久99免费视频| 在线中文字幕不卡| 欧美成人dvd在线视频| 亚洲无毛电影| 亚洲电影在线播放| 国产精品欧美风情| 欧美激情91| 欧美亚洲视频一区二区| 91久久国产自产拍夜夜嗨| 久久久91精品| 亚洲一区在线直播| 亚洲国产高清一区二区三区| 国产精品欧美一区喷水| 欧美国产专区| 六月丁香综合| 久久精品亚洲一区| 亚洲一区三区在线观看| 亚洲日本欧美| 欧美第一黄网免费网站| 久久精品国产免费| 亚洲欧美国产制服动漫| 日韩视频中文字幕| 亚洲国产精品久久91精品| 国产一区日韩欧美| 国产日韩欧美一区二区| 国产精品乱码一区二三区小蝌蚪| 欧美日韩一区二区在线观看| 欧美精品大片|