眼下新的GUI Framework的第一版也就只剩下3個(gè)控件了。雖然之前說過要開發(fā)一個(gè)理論上是P2P上的遠(yuǎn)程對(duì)象交互協(xié)議、要開發(fā)一個(gè)窗口設(shè)計(jì)器、還要開發(fā)一個(gè)LALR Parser GUI作為GUI Framework的demo。我想這也是一個(gè)大的工程,對(duì)于我一個(gè)人來說。但是今天的一個(gè)想法終于把這三個(gè)東西串了起來。
想必大家MFC用得很囧吧。Linux下面開發(fā)C++反正所有選擇相比起當(dāng)年的Borland C++Builder來說都是很爛的,那就不說了。Windows下面開發(fā)C++是哭笑不得。C++ Builder雖然想法是好的,其實(shí)我也不介意他用Delphi的VCL,只是編譯器的bug實(shí)在是太多了。新的C++Builder連試用版的安裝程序都有問題,于是徹底失去希望了。現(xiàn)在RAD也就剩下MFC一個(gè)了。說實(shí)話我以前做游戲、做軟件渲染器到現(xiàn)在做編譯器做什么什么的,實(shí)際上都是類似庫(kù)或者是中間件的,跟RAD一點(diǎn)關(guān)系都沒有。只不過我仍然非常喜歡RAD這樣的開發(fā)方式。但是MFC那個(gè)樣子實(shí)在是RAD不起來啊,所以我干脆揭竿而起,另做一個(gè)了。至于將來前途怎么樣我就不管了,至少得先讓自己爽起來再說。
為什么我那么強(qiáng)調(diào)窗口設(shè)計(jì)器呢?其實(shí)可以大家可以開個(gè)C#,嘗試做一下我以前那個(gè)
破IDE的界面。這樣的話窗口設(shè)計(jì)器會(huì)給你一份代碼,藏在XXForm.Designer.cs底下,然后寫幾行代碼把東西當(dāng)prototype跑起來。然后你再用MFC做一遍。現(xiàn)在VC++ 9.0對(duì)MFC的支持其實(shí)也是很漂亮的,只不過量變引起不了質(zhì)變而已。做完了之后比較一下哪個(gè)比較囧(指的僅僅是開發(fā)過程,不要拿效率說事兒,那點(diǎn)破界面慢一點(diǎn)無(wú)所謂)。
現(xiàn)在我揭竿而起重頭來了一次,就等于給你.NET的System.Windows.Forms一樣,有類庫(kù)沒有界面編輯器。如果你想做一個(gè)界面出來的話就要自己親手寫一個(gè)XXForm.Designer.cs出來。這個(gè)其實(shí)比MFC更囧,也令我自己更加不爽。要是我自己做的東西連我自己用著都不高興的話那就太沒意思了,所以得來一個(gè)那樣的設(shè)計(jì)器才行。
話說到這里,其實(shí)VL++這套類庫(kù)(除了GUI還有很多其他東西,用了的話連STL都免了)文件結(jié)構(gòu)復(fù)雜,每一次使用都要重新一個(gè)一個(gè)添加,也是很不爽的。因此至少窗口設(shè)計(jì)器也要自動(dòng)把這些該加進(jìn)去的文件添加到vcproj不是么。但是VL++并不僅僅是一個(gè)GUI Framework啊,至少還能寫編譯器是吧。自己做了一個(gè)Syngram,直接在C++里面寫左遞歸文法,用起來也挺爽的。當(dāng)然爽不是爽在能寫文法,而是爽在這樣做,編譯器遇到了大的變化也非常容易改,傳說中的解耦啊。Vczh Free Script 1.0只是一個(gè)支持閉包的東西,后來大刀闊斧修改了,就變成同時(shí)支持很多個(gè)編程范式的腳本語(yǔ)言了。多虧了Syngram啊,改語(yǔ)法真是不費(fèi)吹灰之力。既然我要弄一個(gè)GUI工具來寫編譯器,那么吧兩個(gè)工具整合在一起,就是一個(gè)很自然的想法了。再加上未來有空的話還要做一個(gè)遠(yuǎn)程對(duì)象交互協(xié)議,也是很需要GUI工具幫忙的。
于是呢,雖然工程量很大,但是我們來展望一下。現(xiàn)在,自己需要開發(fā)一個(gè)系統(tǒng)的客戶端,這個(gè)客戶端需要跟遠(yuǎn)程的數(shù)據(jù)庫(kù)打交道,同時(shí)還要支持大量的配置。那怎么辦呢?首先,打開這個(gè)工具,連接到一個(gè)剛剛建立好的vcproj上面,然后就拖控件了。拖完了之后就是一個(gè)prototype了,一跑覺得不錯(cuò)。現(xiàn)在,從遠(yuǎn)程的機(jī)器那邊拿到一個(gè)使用遠(yuǎn)程對(duì)象交互協(xié)議的接口說明,添加到這個(gè)工具里面,這個(gè)工具就自動(dòng)產(chǎn)生了客戶端的代碼,讓你可以像調(diào)用一個(gè)類一樣跟遠(yuǎn)程的機(jī)器打交道(像SOA?我覺得不像,我也不想像。像WCF?雖然概念類似,不過既然我不做SOA,那就不像了)。最后一步要配置。現(xiàn)在配置都寫DSL啊。所謂的DSL就是面向特定領(lǐng)域的特殊語(yǔ)言。編譯器不會(huì)寫?沒關(guān)系,還是那個(gè)工具,新建一個(gè)編譯器,拖幾個(gè)文法出來,搞一搞,呀,代碼出來啦。用這個(gè)生成以后的代碼寫寫后端,一個(gè)DSL就有啦。
嗯嗯,雖然很理想化,但至少這玩意兒作為一個(gè)原型存在,也是挺好玩的。不過呢,可能要花很長(zhǎng)時(shí)間,這個(gè)計(jì)劃也不是穩(wěn)定的,得看未來發(fā)生了些什么事情。不過最少那個(gè)做編譯器的玩意兒還是要的。ANTLR這個(gè)LL(k)都有了,我Syngram好歹也是LR(k),不做就不爽啦。
posted on 2008-08-19 09:51
陳梓瀚(vczh) 閱讀(1821)
評(píng)論(5) 編輯 收藏 引用 所屬分類:
其他