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

隨筆-341  評論-2670  文章-0  trackbacks-0
    這個分析器包含了四個文件:
    VL_Data_Basic.h(使用了其中的智能指針VL_AutoPtr和一些類型重命名)
    VL_CpData.h(數(shù)據(jù)結(jié)構(gòu))
    VL_CpKernel.h/cpp(詞法分析器和語法分析器)

    昨天剛寫好的,可能有Bug,這個東西供給熟悉編譯原理(至少熟悉BNF notation)的人互相學(xué)習(xí)交流,并不打算作為一個成品出現(xiàn)。以下是將一個四則運算式子的字符串進行詞法分析,分割成記號之后求值的代碼:
  1 #include "..\..\..\..\VL++\Library\Platform\VL_Console.h"
  2 #include "..\..\..\..\VL++\Library\Data\Grammar2\VL_CpKernel.h"
  3 
  4 using namespace vl;
  5 using namespace vl::platform;
  6 using namespace vl::grammar;
  7 
  8 enum Operator
  9 {
 10     opAdd,
 11     opSub,
 12     opMul,
 13     opDiv
 14 };
 15 
 16 enum TokenID
 17 {
 18     tiNumber,
 19     tiLeft,
 20     tiRight,
 21     tiAdd,
 22     tiSub,
 23     tiMul,
 24     tiDiv
 25 };
 26 
 27 VDouble Number(const VL_CpToken& Input)
 28 {
 29     return VUnicodeString(Input.Start,Input.Length).ToDouble();
 30 }
 31 
 32 Operator Op(const VL_CpToken& Input)
 33 {
 34     switch(Input.ID)
 35     {
 36     case tiAdd:return opAdd;
 37     case tiSub:return opSub;
 38     case tiMul:return opMul;
 39     case tiDiv:return opDiv;
 40     default:return (Operator)-1;
 41     }
 42 }
 43 
 44 VDouble RemoveBracket(const VL_CpPair<VL_CpPair<VL_CpToken , VDouble> , VL_CpToken>& Input)
 45 {
 46     return Input.First.Second;
 47 }
 48 
 49 VDouble Calculate(const VL_CpPair<VDouble,VL_CpList<VL_CpPair<Operator,VDouble>>>& Numbers)
 50 {
 51     VDouble Result=Numbers.First;
 52     VL_CpList<VL_CpPair<Operator,VDouble>>::Node::Ptr Current=Numbers.Second.Head;
 53     while(Current)
 54     {
 55         switch(Current->Data.First)
 56         {
 57         case opAdd:
 58             Result+=Current->Data.Second;
 59             break;
 60         case opSub:
 61             Result-=Current->Data.Second;
 62             break;
 63         case opMul:
 64             Result*=Current->Data.Second;
 65             break;
 66         case opDiv:
 67             Result/=Current->Data.Second;
 68             break;
 69         }
 70         Current=Current->Next;
 71     }
 72     return Result;
 73 }
 74 
 75 void Parse()
 76 {
 77     VL_CpLexer Lexer;
 78     Lexer
 79         <<Token(false,L"(",tiLeft)
 80         <<Token(false,L")",tiRight)
 81         <<Token(false,L"+",tiAdd)
 82         <<Token(false,L"-",tiSub)
 83         <<Token(false,L"*",tiMul)
 84         <<Token(false,L"/",tiDiv)
 85         <<Token(false,_Float,tiNumber)
 86         ;
 87 
 88     _Wrapper<VL_CpTokenNodePtr , VDouble> Factor,Term,Expr;
 89     Factor    = (Number<<=Token(tiNumber)) | (RemoveBracket <<= Token(tiLeft) + Expr + Token(tiRight));
 90     Term    = Calculate <<= Factor + *((Op<<=Token(tiMul)|Token(tiDiv)) + Factor);
 91     Expr    = Calculate <<= Term + *((Op<<=Token(tiAdd)|Token(tiSub)) + Term);
 92 
 93     VL_CpParser<VL_CpTokenNodePtr , VDouble> p=Expr;
 94     VL_CpParser<VL_CpTokenNodePtr , VDouble>::_FullResult Value=p.Parse(Lexer.Parse(L"(1+2)*(3+4)").First.Head);
 95     GetConsole()->Write(L"結(jié)果:\t"+VUnicodeString(Value.Head->Data.First)+L"\r\n");
 96 }
 97 
 98 void vlmain()
 99 {
100     GetConsole()->SetTitle(L"Vczh Combinator Parser");
101     GetConsole()->SetTestMemoryLeaks(true);
102     GetConsole()->SetPauseOnExit(true);
103 
104     Parse();
105 }


    點擊這里下載。
posted on 2009-04-03 01:21 陳梓瀚(vczh) 閱讀(6335) 評論(9)  編輯 收藏 引用 所屬分類: 作品

評論:
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 03:20 | CPP09
Another lightweight parser combinator?  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源)[未登錄] 2009-04-03 04:00 | david
請教可配置的含義是什么?  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:19 | 1shou
問題是 你的頭文件里面包含了些什么東東?  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:30 | 1shou
走眼了。。呵呵,,原來沒用你以前的 頭文件了呵。  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:43 | 陳梓瀚(vczh)
@david
也就是說,被分析的字符串的格式可以讓你輕松表達,分析過程不用你管的意思。我下午用這個東西小庫寫了個四則運算到語法樹的代碼,只需5分鐘。  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:45 | 陳梓瀚(vczh)
@CPP09
這個是無聊弄著玩的,參考Graham Hutton寫的《Higher-Order Functions for Parsing》。純函數(shù)式語言跟C++的模板還真是像啊。  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-04 06:14 | 陳梓瀚(vczh)
還真是發(fā)現(xiàn)了些bug。  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2012-04-28 04:52 | anna
想問一下博主,這個代碼里讓用戶自己輸入regex,并通過regex制造出NFA,在到DFA的代碼主要集中在哪一塊呢? 如果某個字符串匹配了,是否能輸出是命中了哪條規(guī)則呢?  回復(fù)  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2012-04-28 05:21 | 陳梓瀚(vczh)
@anna
能,因為一個我每一個DFA終結(jié)狀態(tài)都保存了他是屬于哪條regex的。  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜视频久久久| 蜜臀91精品一区二区三区| 亚洲欧美国产制服动漫| 亚洲欧美日韩在线播放| 99国产精品自拍| 欧美成人免费在线视频| 久久综合伊人| 欧美国产日韩免费| 91久久国产综合久久| 久久裸体视频| 亚洲国产精品女人久久久| 欧美国产精品v| 日韩视频中午一区| 亚洲欧美综合| 欧美成人有码| 国产精品av一区二区| 国产精品久久久久影院色老大| 国产精品分类| 一色屋精品亚洲香蕉网站| 国产欧美日韩视频一区二区三区 | 亚洲欧洲日本在线| 日韩午夜精品| 欧美一区二区三区的| 欧美激情第六页| 国产精品99久久久久久人| 欧美在线观看网址综合| 免费观看亚洲视频大全| 亚洲毛片播放| 欧美激情第1页| 激情丁香综合| 久久99在线观看| 中日韩高清电影网| 欧美精品二区| 亚洲电影欧美电影有声小说| 欧美日韩麻豆| 亚洲欧洲日产国产综合网| 久久精品夜色噜噜亚洲a∨| 亚洲麻豆av| 欧美三级电影精品| 一级日韩一区在线观看| 亚洲高清色综合| 亚洲精品久久久久久下一站| 久久久不卡网国产精品一区| 99re66热这里只有精品3直播| 嫩草影视亚洲| 日韩视频免费| 免费在线成人| 欧美日韩亚洲一区二区三区在线观看 | 欧美成人精品在线观看| 在线观看欧美| 欧美国产视频在线| 亚洲欧美一区二区激情| 国产精品视频区| 欧美伊人久久| 久久综合给合久久狠狠狠97色69| 在线成人欧美| 99综合精品| 国模精品一区二区三区| 亚洲大胆av| 欧美日韩mv| 久久中文在线| 美女福利精品视频| 日韩一区二区高清| 亚洲欧美激情一区二区| 最新日韩在线| 性欧美xxxx视频在线观看| 一色屋精品视频免费看| 9久草视频在线视频精品| 国产精品mm| 亚洲人成人99网站| 国产欧美日韩一区二区三区在线观看 | 一本色道综合亚洲| 国产精品色婷婷| 99国产麻豆精品| 日韩视频免费看| 久久久久一区二区| 亚洲午夜视频在线观看| 久久亚洲电影| 欧美影视一区| 国产日韩av高清| 亚洲一品av免费观看| 洋洋av久久久久久久一区| 亚洲女人天堂成人av在线| 国产精品99久久久久久宅男| 欧美成人国产一区二区| 欧美黄色视屏| 一区二区欧美在线| 欧美午夜精品久久久久免费视| 亚洲国产精品t66y| 国产一区二区三区av电影| 国产精品日韩精品欧美精品| 欧美激情一区二区三区在线视频观看| 欧美日韩麻豆| 亚洲欧美中文另类| 免费看成人av| 亚洲一区二区高清| 狠狠综合久久| 欧美日韩精品三区| 销魂美女一区二区三区视频在线| 久久精品2019中文字幕| 亚洲国产精品一区| 国产精品v欧美精品v日韩| 欧美一区国产在线| 亚洲国产一区二区视频| 欧美在线免费| 宅男噜噜噜66一区二区| 精品电影一区| 国产一区二区三区免费在线观看| 麻豆亚洲精品| 久久精品国产欧美亚洲人人爽| 亚洲人午夜精品免费| 免费黄网站欧美| 欧美在线影院| 久久xxxx| 久久精品视频在线免费观看| 亚洲综合大片69999| 日韩视频在线永久播放| 伊人成人在线视频| 狠狠色2019综合网| 国产一区二区三区久久 | 亚洲大片一区二区三区| 久久精品国产第一区二区三区最新章节| 99精品99| 亚洲欧美国产一区二区三区| 亚洲色图在线视频| 国一区二区在线观看| 国产亚洲欧美另类一区二区三区| 国产精品女主播| 国内精品久久久久久久影视麻豆| 国产精品久久7| 在线观看日韩国产| 一本色道久久综合亚洲精品小说| 9色国产精品| 久久青草久久| 亚洲人体1000| 久久国产一区| 欧美黄色小视频| 欧美jizz19性欧美| 国产精品久久久久久影院8一贰佰 国产精品久久久久久影视 | 一本色道久久综合亚洲二区三区 | 欧美激情一区二区三区全黄| 亚洲国产成人av好男人在线观看| 国产精品色午夜在线观看| 国产精品一区二区视频| 国产欧美日韩在线观看| 在线免费观看日韩欧美| 亚洲欧美中日韩| 亚洲国产一区视频| 久久精品女人天堂| 国产欧美日韩视频一区二区| 亚洲开发第一视频在线播放| 久久精品中文字幕一区二区三区| 亚洲三级电影全部在线观看高清| 性欧美videos另类喷潮| 欧美精品一区二区三区蜜臀| 国产精品福利久久久| 亚洲日本中文字幕| 欧美激情影院| 欧美成人第一页| 黄色另类av| 美女国内精品自产拍在线播放| 亚洲一区二区三区精品视频| 国产精品国产三级国产aⅴ无密码| 日韩午夜av在线| 夜夜嗨av一区二区三区免费区| 久久亚洲综合色一区二区三区| 韩国在线视频一区| 亚洲高清资源| 国产精品欧美精品| 免费看的黄色欧美网站| 欧美aa在线视频| 亚洲综合色丁香婷婷六月图片| 一区二区三区成人精品| 国产自产女人91一区在线观看| 欧美高清影院| 国产一区再线| 夜色激情一区二区| 激情成人综合| 亚洲欧美www| 中文网丁香综合网| 久久久久国产一区二区三区| 一区二区三区黄色| 久久影院午夜论| 亚洲欧美日本视频在线观看| 久久夜色精品国产欧美乱| 亚洲男女自偷自拍图片另类| 久久久久国产精品午夜一区| 亚洲主播在线| 欧美精品一区二区三区视频| 美女精品一区| 亚洲福利视频一区二区| 欧美在线视频免费观看| 欧美一区二区观看视频| 欧美午夜宅男影院在线观看| 亚洲人成网站影音先锋播放| 国产乱肥老妇国产一区二| 亚洲全部视频| 一本色道久久综合亚洲精品婷婷| 欧美成人精品在线播放| 亚洲丰满在线|