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

隨筆-91  評論-137  文章-0  trackbacks-0
  1 #pragma once
  2 #include "..\String\NWString.h"
  3 #include "..\AutoPtr\AutoPtr.h"
  4 #include "..\Common\List.h"
  5 
  6 #define Type_Match_Content                                                0        // 匹配值
  7 #define Type_Match_Rule                                                    1        // 匹配一條表達式
  8 #define Type_Or                                                           -1
  9 #define Type_Choose                                                       -2
 10 #define Type_Loop_0                                                       -3
 11 #define Type_Loop_1                                                       -4
 12 #define Type_Opt                                                       -5
 13 #define Type_LQ                                                           -6
 14 #define Type_RQ                                                           -7
 15 
 16 class Precept
 17 {
 18 public:
 19     int Left;
 20     List<int> Right;
 21 
 22     Precept() : Left(0){}
 23     Precept(int L,List<int> R) : Left(L),Right(R){}
 24 
 25     // +Precept
 26     friend NAutoPtr<Precept> operator+(NAutoPtr<Precept> P)
 27     {
 28         NAutoPtr<Precept> p = new Precept;
 29         p->Right.Add(Type_Loop_1);
 30         p->Right.Add(Type_LQ);
 31         p->Right.Add(P->Right);
 32         p->Right.Add(Type_RQ);
 33         return p;
 34     }
 35 
 36     // Precept + Precept
 37     friend NAutoPtr<Precept> operator+(NAutoPtr<Precept> P1,NAutoPtr<Precept> P2)
 38     {
 39         NAutoPtr<Precept> p = new Precept;
 40         p->Right.Add(P1->Right);
 41         p->Right.Add(P2->Right);
 42         return p;
 43     }
 44 
 45     // *Precept
 46     friend NAutoPtr<Precept> operator*(NAutoPtr<Precept> P)
 47     {
 48         NAutoPtr<Precept> p = new Precept;
 49         p->Right.Add(Type_Loop_0);
 50         p->Right.Add(Type_LQ);
 51         p->Right.Add(P->Right);
 52         p->Right.Add(Type_RQ);
 53         return p;
 54     }
 55 
 56     // Precept | Precept
 57     friend NAutoPtr<Precept> operator|(NAutoPtr<Precept> P1,NAutoPtr<Precept> P2)
 58     {
 59         NAutoPtr<Precept> p = new Precept;
 60         p->Right.Add(Type_LQ);
 61         p->Right.Add(P1->Right);
 62         p->Right.Add(Type_RQ);
 63         p->Right.Add(Type_Or);
 64         p->Right.Add(Type_LQ);
 65         p->Right.Add(P2->Right);
 66         p->Right.Add(Type_RQ);
 67         return p;
 68     }
 69 };
 70 
 71 class NV
 72 {
 73 public:
 74     NWString Content;
 75     int Type;                // Content Or Rule
 76     int Index;                // Index Of this
 77 
 78     NV() : Index(0),Type(0){}
 79     NV(NWString C,NWString R,int T) : Content(C),Type(T){}
 80 
 81     BOOL operator==(NV V)
 82     {
 83         return Content == V.Content && Type == V.Type;
 84     }
 85 
 86     // Left->V
 87     NAutoPtr<Precept> SetRight(NAutoPtr<NV> V)
 88     {
 89         NAutoPtr<Precept> p = new Precept;
 90         p->Left = Index;
 91         p->Right.Add(V->Index);
 92         return p;
 93     }
 94 
 95     // Left->Precept
 96     NAutoPtr<Precept> SetRight(NAutoPtr<Precept> P)
 97     {
 98         NAutoPtr<Precept> p = new Precept;
 99         p->Left = Index;
100         p->Right.Add(P->Right);
101         return p;
102     }
103 
104     // this + NV
105     NAutoPtr<Precept> operator+(NAutoPtr<NV> V)
106     {
107         NAutoPtr<Precept> p = new Precept;
108         p->Right.Add(Index);
109         p->Right.Add(V->Index);
110         return p;
111     }
112 
113     // NV + NV
114     friend NAutoPtr<Precept> operator+(NAutoPtr<NV> V1,NAutoPtr<NV> V2)
115     {
116         NAutoPtr<Precept> p = new Precept;
117         p->Right.Add(V1->Index);
118         p->Right.Add(V2->Index);
119         return p;
120     }
121 
122     // Precept + NV
123     friend NAutoPtr<Precept> operator+(NAutoPtr<Precept> P,NAutoPtr<NV> V)
124     {
125         NAutoPtr<Precept> p = new Precept;
126         p->Right.Add(P->Right);
127         p->Right.Add(V->Index);
128         return p;
129     }
130 
131     // NV + Precept
132     friend NAutoPtr<Precept> operator+(NAutoPtr<NV> V,NAutoPtr<Precept> P)
133     {
134         NAutoPtr<Precept> p = new Precept;
135         p->Right.Add(V->Index);
136         p->Right.Add(P->Right);
137         return p;
138     }
139 
140     // this | NV
141     NAutoPtr<Precept> operator|(NAutoPtr<NV> V)
142     {
143         NAutoPtr<Precept> p = new Precept;
144         p->Right.Add(Index);
145         p->Right.Add(Type_Or);
146         p->Right.Add(V->Index);
147         return p;
148     }
149 
150     // NV | NV
151     friend NAutoPtr<Precept> operator|(NAutoPtr<NV> V1,NAutoPtr<NV> V2)
152     {
153         NAutoPtr<Precept> p = new Precept;
154         p->Right.Add(V1->Index);
155         p->Right.Add(Type_Or);
156         p->Right.Add(V2->Index);
157         return p;
158     }
159 
160     // Precept | NV
161     friend NAutoPtr<Precept> operator|(NAutoPtr<Precept> P,NAutoPtr<NV> V)
162     {
163         NAutoPtr<Precept> p = new Precept;
164         p->Right.Add(Type_LQ);
165         p->Right.Add(P->Right);
166         p->Right.Add(Type_RQ);
167         p->Right.Add(Type_Or);
168         p->Right.Add(V->Index);
169         return p;
170     }
171 
172     // NV | Precept
173     friend NAutoPtr<Precept> operator|(NAutoPtr<NV> V,NAutoPtr<Precept> P)
174     {
175         NAutoPtr<Precept> p = new Precept;
176         p->Right.Add(V->Index);
177         p->Right.Add(Type_Or);
178         p->Right.Add(Type_LQ);
179         p->Right.Add(P->Right);
180         p->Right.Add(Type_RQ);
181         return p;
182     }
183 
184     // +NV
185     friend NAutoPtr<Precept> operator+(NAutoPtr<NV> V)
186     {
187         NAutoPtr<Precept> p = new Precept;
188         p->Right.Add(Type_Loop_1);
189         p->Right.Add(V->Index);
190         return p;
191     }
192 
193     // *NV
194     friend NAutoPtr<Precept> operator*(NAutoPtr<NV> V)
195     {
196         NAutoPtr<Precept> p = new Precept;
197         p->Right.Add(Type_Loop_0);
198         p->Right.Add(V->Index);
199         return p;
200     }
201 
202     // Opt(NV)
203     friend NAutoPtr<Precept> Opt(NAutoPtr<NV> V)
204     {
205         NAutoPtr<Precept> p = new Precept;
206         p->Right.Add(Type_Opt);
207         p->Right.Add(V->Index);
208         return p;
209     }
210 
211     // Opt(Precept)
212     friend NAutoPtr<Precept> Opt(NAutoPtr<Precept> P)
213     {
214         NAutoPtr<Precept> p = new Precept;
215         p->Right.Add(Type_Opt);
216         p->Right.Add(Type_LQ);
217         p->Right.Add(P->Right);
218         p->Right.Add(Type_RQ);
219         return p;
220     }
221 };
222 

說明:
Precept類主要用于保存一條產生式
NV類則用來保存一個終結符或非終結符
對于以上操作符重載后你就可以像書寫文法那樣來寫你的代碼了.
比如你要寫一條產生式:Program->aaa [bbb+ + ccc*] | bbb+ | [ccc]
那么你可以書寫以下代碼來生成這條產生式:
 1     NParserDFA DFA;
 2     NAutoPtr<NV> Program = new NV(L"program",L"",Type_Match_Content);
 3     NAutoPtr<NV> aaa = new NV(L"aaa",L"",Type_Match_Content);
 4     NAutoPtr<NV> bbb = new NV(L"bbb",L"",Type_Match_Content);
 5     NAutoPtr<NV> ccc = new NV(L"ccc",L"",Type_Match_Content);
 6     // 以上生成終結符和非終結符
 7     DFA.AddVn(Program);
 8     DFA.AddVt(aaa);
 9     DFA.AddVt(bbb);
10     DFA.AddVt(ccc);
11     // 將終結符和非終結符添加到表中
12     DFA.SetStart(Program);
13     // 設置起始非終結符
14     List<NAutoPtr<Precept>> PreceptList;
15     NAutoPtr<Precept> p;
16     // Program->aaa [bbb+ + ccc*] | bbb+ | [ccc]
17     p = Program->SetRight(aaa + Opt(+bbb + *ccc) | +bbb | Opt(ccc));
18     // 添加產生式
19     PreceptList.Add(p);

編譯你的分析器的同時編譯器就為你檢查了文法有無書寫錯誤,并且再復雜的表達式都能成功被編譯.
posted on 2010-07-22 23:23 lwch 閱讀(1256) 評論(0)  編輯 收藏 引用 所屬分類: NScript
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品一二三| 玖玖综合伊人| 亚洲人体一区| 欧美中文字幕| 小辣椒精品导航| 欧美精品电影在线| 欧美大片免费观看在线观看网站推荐 | 午夜影视日本亚洲欧洲精品| 裸体歌舞表演一区二区| 欧美一区二区视频在线观看| 欧美日韩一区二区三区在线| 最新69国产成人精品视频免费| 黄色成人精品网站| 欧美在线不卡| 午夜精品久久久久久久久久久久| 欧美日韩和欧美的一区二区| 亚洲第一二三四五区| 伊人成人在线视频| 欧美在线视频导航| 久久精品亚洲国产奇米99| 国产精品电影观看| 一本色道久久| 亚洲伊人色欲综合网| 欧美日韩国产高清视频| 亚洲国产经典视频| 亚洲乱码国产乱码精品精98午夜| 免费成人在线视频网站| 欧美电影免费| 亚洲人人精品| 欧美日韩1区2区| 亚洲另类在线视频| 亚洲私人影院在线观看| 欧美三区在线| 亚洲一区二区三区影院| 欧美自拍偷拍午夜视频| 国产一区二区在线免费观看| 欧美一区国产在线| 久久综合色播五月| 在线精品在线| 欧美国产三区| 亚洲精品在线三区| 午夜一区不卡| 红杏aⅴ成人免费视频| 久久永久免费| 亚洲精品在线免费| 亚洲欧美电影院| 国模一区二区三区| 免费影视亚洲| 亚洲精品影院| 久久激情五月激情| 亚洲国产裸拍裸体视频在线观看乱了中文 | 性做久久久久久久免费看| 国产欧美大片| 久久精品国产欧美亚洲人人爽| 久久久久国产一区二区| 最新国产成人av网站网址麻豆| 欧美日本中文字幕| 亚洲欧美日韩天堂| 欧美高清视频| 亚洲欧美三级在线| 黄色成人在线网址| 欧美精品999| 欧美一级片久久久久久久| 亚洲电影专区| 欧美一区二区网站| 亚洲日本精品国产第一区| 欧美午夜国产| 久久先锋影音| 亚洲视频观看| 欧美黄色一区| 欧美制服丝袜第一页| 亚洲激情自拍| 国产欧美另类| 欧美日本乱大交xxxxx| 欧美亚洲视频在线看网址| 亚洲国产日韩欧美在线动漫| 久久国产精品99国产| 99精品99| 亚洲国产成人精品视频| 国产精品女人网站| 欧美日本一区| 久久综合影视| 亚洲欧美国产精品va在线观看| 亚洲黄色高清| 可以免费看不卡的av网站| 亚洲小说春色综合另类电影| 亚洲承认在线| 国产一区二区日韩精品| 国产精品v一区二区三区| 欧美sm重口味系列视频在线观看| 性欧美激情精品| 亚洲一区二区久久| 日韩亚洲成人av在线| 欧美激情性爽国产精品17p| 欧美一区二区视频在线观看2020| 亚洲性线免费观看视频成熟| 亚洲国产精品一区在线观看不卡 | 午夜精品久久久久久久久| 日韩视频免费观看| 亚洲国产三级网| 伊人精品成人久久综合软件| 国产午夜亚洲精品理论片色戒 | 欧美日韩国产一区二区| 麻豆精品视频| 嫩草国产精品入口| 久久亚洲一区二区三区四区| 久久国产乱子精品免费女 | 国产丝袜美腿一区二区三区| 欧美三级小说| 欧美日韩在线视频首页| 欧美激情中文字幕在线| 欧美精品1区| 欧美另类videos死尸| 欧美成人首页| 欧美精品啪啪| 欧美日韩91| 欧美午夜www高清视频| 国产精品区一区| 国产农村妇女精品| 国产一区二区中文字幕免费看| 国内免费精品永久在线视频| 在线播放不卡| 亚洲人成网站在线观看播放| 99精品视频免费观看视频| 亚洲中无吗在线| 欧美一区二区在线| 久久阴道视频| 亚洲区免费影片| 亚洲一级高清| 久久久久久亚洲综合影院红桃 | 亚洲国产另类久久精品| 夜夜嗨av一区二区三区免费区| 亚洲视频在线观看视频| 欧美一区二区黄色| 欧美99在线视频观看| 亚洲经典视频在线观看| 艳妇臀荡乳欲伦亚洲一区| 亚洲欧美日韩视频二区| 久久亚洲精品欧美| 欧美日韩在线视频一区| 国产一区99| 99re热精品| 久久久久久久综合| 亚洲国产精品成人| 亚洲视频国产视频| 久久女同互慰一区二区三区| 欧美手机在线视频| 在线观看亚洲视频啊啊啊啊| 中文日韩在线视频| 久久久久国产精品人| 亚洲伦理在线| 久久se精品一区精品二区| 欧美二区不卡| 国产偷久久久精品专区| 一本色道久久综合亚洲精品小说| 久久aⅴ乱码一区二区三区| 亚洲欧洲精品一区| 欧美尤物巨大精品爽| 欧美日韩色综合| 亚洲第一网站| 欧美在线二区| a91a精品视频在线观看| 免费永久网站黄欧美| 国产亚洲精品久久久久婷婷瑜伽| 一本色道久久加勒比精品| 麻豆精品视频| 午夜视频一区在线观看| 欧美日韩视频在线第一区| 亚洲电影下载| 久久久精品一区二区三区| 亚洲视频网站在线观看| 欧美激情一区二区三区在线| 精品96久久久久久中文字幕无| 午夜精品久久久久久久99水蜜桃| 亚洲精品系列| 欧美成人有码| 亚洲高清不卡在线观看| 久久九九电影| 欧美一区二区三区免费在线看| 国产精品黄视频| 亚洲午夜av在线| 亚洲精品免费在线观看| 暖暖成人免费视频| 在线观看日韩av先锋影音电影院| 久久av一区二区| 亚洲色图在线视频| 欧美三级电影精品| 一区二区91| 99v久久综合狠狠综合久久| 欧美国产综合视频| 亚洲精品欧美极品| 亚洲黄一区二区三区| 欧美第一黄色网| 日韩视频精品在线观看| 亚洲欧洲精品天堂一级| 欧美精品一级| 亚洲小视频在线观看| 一区二区三区蜜桃网| 国产精品视频内| 欧美在线亚洲在线|