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

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

    昨天剛寫好的,可能有Bug,這個東西供給熟悉編譯原理(至少熟悉BNF notation)的人互相學習交流,并不打算作為一個成品出現。以下是將一個四則運算式子的字符串進行詞法分析,分割成記號之后求值的代碼:
  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"結果:\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) 閱讀(6343) 評論(9)  編輯 收藏 引用 所屬分類: 作品

評論:
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 03:20 | CPP09
Another lightweight parser combinator?  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源)[未登錄] 2009-04-03 04:00 | david
請教可配置的含義是什么?  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:19 | 1shou
問題是 你的頭文件里面包含了些什么東東?  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:30 | 1shou
走眼了。。呵呵,,原來沒用你以前的 頭文件了呵。  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:43 | 陳梓瀚(vczh)
@david
也就是說,被分析的字符串的格式可以讓你輕松表達,分析過程不用你管的意思。我下午用這個東西小庫寫了個四則運算到語法樹的代碼,只需5分鐘。  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-03 04:45 | 陳梓瀚(vczh)
@CPP09
這個是無聊弄著玩的,參考Graham Hutton寫的《Higher-Order Functions for Parsing》。純函數式語言跟C++的模板還真是像啊。  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2009-04-04 06:14 | 陳梓瀚(vczh)
還真是發現了些bug。  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2012-04-28 04:52 | anna
想問一下博主,這個代碼里讓用戶自己輸入regex,并通過regex制造出NFA,在到DFA的代碼主要集中在哪一塊呢? 如果某個字符串匹配了,是否能輸出是命中了哪條規則呢?  回復  更多評論
  
# re: C++輕量級可配置語法分析器(開源) 2012-04-28 05:21 | 陳梓瀚(vczh)
@anna
能,因為一個我每一個DFA終結狀態都保存了他是屬于哪條regex的。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            麻豆freexxxx性91精品| 久久噜噜噜精品国产亚洲综合| 国产色产综合产在线视频| 欧美大片国产精品| 国产精品一区二区欧美| 亚洲人成网在线播放| 国产喷白浆一区二区三区| 日韩视频免费观看高清在线视频 | 午夜精品福利电影| 一区二区三区产品免费精品久久75| 欧美一区二视频| 亚洲欧美电影院| 欧美日韩成人在线播放| 亚洲高清视频中文字幕| 伊人成人开心激情综合网| 亚洲综合视频网| 亚洲在线播放电影| 欧美天堂亚洲电影院在线播放 | 一个人看的www久久| 亚洲激情午夜| 看片网站欧美日韩| 噜噜噜久久亚洲精品国产品小说| 国产老女人精品毛片久久| 亚洲图中文字幕| 亚洲免费在线观看| 国产精品户外野外| 亚洲午夜一二三区视频| 亚洲欧美另类国产| 国产精品欧美一区喷水| 亚洲一区二区在| 欧美专区在线观看一区| 国产欧美大片| 欧美在线观看一区二区| 久久亚洲免费| 1769国产精品| 欧美黄色片免费观看| 亚洲精选视频在线| 亚洲制服av| 国产日韩在线不卡| 久久福利资源站| 欧美国产精品一区| 亚洲东热激情| 欧美人成在线| 亚洲免费在线播放| 久久午夜av| 亚洲欧洲日韩在线| 欧美日一区二区三区在线观看国产免| 中文av一区特黄| 久久精彩免费视频| 亚洲国产婷婷综合在线精品| 欧美激情欧美激情在线五月| 一个人看的www久久| 欧美在线观看www| 亚洲高清激情| 欧美日韩一区三区四区| 香蕉成人伊视频在线观看| 玖玖国产精品视频| 一区二区三区精品在线| 国产视频一区免费看| 美女国内精品自产拍在线播放| 亚洲精品无人区| 久久精品日韩一区二区三区| 亚洲青色在线| 国产日产精品一区二区三区四区的观看方式 | 亚洲视频精选| 免费日韩av电影| 亚洲午夜在线| 在线欧美三区| 国产精品毛片a∨一区二区三区|国| 欧美一区午夜精品| 亚洲精品一级| 美国十次成人| 亚洲欧美综合一区| 91久久久国产精品| 国产欧美日本在线| 欧美日韩成人一区二区| 久久久久久免费| 亚洲在线观看视频网站| 亚洲国产精品第一区二区三区| 欧美亚洲一区| 亚洲网在线观看| 亚洲国产精品成人一区二区 | 国产区精品在线观看| 欧美国产日韩二区| 久久九九全国免费精品观看| 亚洲视频大全| 日韩亚洲欧美中文三级| 欧美福利电影在线观看| 久久人人爽人人爽爽久久| 亚洲欧美在线另类| 一区二区三区|亚洲午夜| 在线日韩欧美| 伊人色综合久久天天五月婷| 国产欧美一区二区三区国产幕精品| 欧美另类极品videosbest最新版本| 久久精品人人爽| 午夜精品久久久久久久99樱桃| aa级大片欧美| 日韩天堂在线观看| 亚洲国产一区二区精品专区| 欧美大尺度在线观看| 久久一区二区三区av| 久久精品一区二区三区四区| 亚洲欧美清纯在线制服| 亚洲免费中文| 亚洲免费人成在线视频观看| 一区二区三区欧美| 99国产精品久久久久久久成人热| 最新亚洲视频| 日韩视频在线一区二区| 亚洲三级视频| 一本色道久久88亚洲综合88 | 亚洲精品国产无天堂网2021| 亚洲电影自拍| 亚洲欧洲在线看| 亚洲久久一区二区| 9i看片成人免费高清| 亚洲视频二区| 亚洲欧美清纯在线制服| 欧美亚洲一区二区三区| 久久久久久穴| 欧美国产日韩xxxxx| 亚洲国产精品一区二区第四页av | 亚洲欧洲精品一区二区| 亚洲精品乱码视频| 一区二区三区四区五区视频 | 欧美日韩在线大尺度| 欧美日韩中文字幕综合视频| 国产精品vvv| 国产日韩欧美精品| 在线看一区二区| 99视频一区二区| 亚洲欧美日韩爽爽影院| 久久久久久久久久久久久女国产乱 | 欧美一区=区| 免费在线一区二区| 亚洲大胆美女视频| 99在线精品免费视频九九视| 午夜精品国产更新| 老鸭窝91久久精品色噜噜导演| 欧美电影资源| 国产毛片一区二区| 亚洲国产精品久久精品怡红院| 一区二区欧美视频| 欧美在线综合| 亚洲欧洲在线一区| 香蕉av777xxx色综合一区| 欧美aaa级| 国产精品中文字幕欧美| 亚洲激情成人在线| 欧美一区2区三区4区公司二百| 蜜臀久久99精品久久久久久9 | 一区二区三区www| 久久av最新网址| 欧美精品九九| 韩国精品在线观看| 亚洲一区二区三区在线播放| 久久亚洲捆绑美女| 一区二区三区四区蜜桃| 久久影院午夜论| 国产精品少妇自拍| 亚洲美女网站| 久久综合亚洲社区| 亚洲免费在线播放| 欧美人与性动交cc0o| 国内久久精品视频| 亚洲自拍偷拍色片视频| 亚洲第一区在线| 久久精品国产亚洲一区二区| 国产精品免费区二区三区观看| 亚洲电影欧美电影有声小说| 久久爱另类一区二区小说| 亚洲美女在线观看| 欧美电影在线| 亚洲国产精品视频一区| 久久精品国产欧美激情| 在线综合亚洲| 欧美三级在线播放| 91久久精品日日躁夜夜躁国产| 久久久久久日产精品| 亚洲一区欧美二区| 欧美视频在线观看一区二区| 亚洲三级视频| 亚洲激情不卡| 欧美激情按摩在线| 亚洲国产精品悠悠久久琪琪 | 欧美不卡福利| 久久精品视频免费观看| 国产日本欧美视频| 久久99在线观看| 亚洲欧美日韩区| 国产欧美日韩精品专区| 亚洲欧美综合精品久久成人| 99精品国产热久久91蜜凸| 欧美金8天国| 一本色道久久综合亚洲精品婷婷 | 欧美成人免费视频| 久久精品五月| 亚洲第一级黄色片| 欧美国产亚洲精品久久久8v|