• <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>
            隨筆-341  評論-2670  文章-0  trackbacks-0
                今天先放圖哈。智能完成已經開始做試驗了不過距離能看還差很遠,所以今天先繼續談一下著色的事情。

                這就是我暫時實現的所有功能了。首先著色算法可以外掛,其次左邊那個邊欄(大小和繪制均可以訂制)操作他的時候會發生什么事情也是外掛的。著色器與“斷點變紅”是分離在兩個不同的插件接口里面的,原因上一篇文章說過了。你們可能還會注意到那個灰色的框框。那個框框的確是會被編輯器當成一個整體來對待,不過我絕對還沒有實現折疊。因為在我的設計里面,如何進行折疊應該是插件的事情,控件本身只要處理好怎么編輯和顯示就行了。還有一個比較難發現的就是,我這玩意兒也是支持輸入法的,輸入法的窗口會跟隨光標移動……

                在開發這個東西的時候我嘗試了兩種新方法。第一種是MVC。MVC開發高亮還真是容易啊,不僅文字緩存部分(C#也是可以精確控制內存的哈)可以獨立出來,連編輯操作(各種按鍵鼠標組合)其實也可以不做在控件里面。這樣有什么好處呢,當然是可以進行高強度的單元測試了哈。第二種就是GUI自動化,光對類進行單元測試還是不夠的,Visual Studio 2010為.net單元測試工程提供了一個Coded UI Test框架可以給我啟動一個獨立的外部程序(MFC寫的也行,WinForm寫的也行,WPF寫的也行,網頁都行)然后操作上面的各種控件最后拿到控件里面的信息。不過可惜的是我的文本框并沒有按照Windows的UI Automation標準來實現(從而讓盲人也能使用這個控件),因此只能進行鍵盤和鼠標的操作,至于我繪制的東西是什么則需要其他方法。C#跨進程怎么做最方便呢?當然是Windows Communication Foundation了哈。為了寫足夠的單元測試是要不惜一切D。不過顯然WCF的服務不可能做在控件里,因此我的solution下面暫時就有控件工程、測試工程和被測試的“獨立程序”工程了。

                有了GUI自動化測試,我在進行重構的時候,就可以放心的修改代碼,然后執行測試程序,去外面喝杯茶。過個幾分鐘測試工程就會跟我報告一共掛掉了多少個case,只要修好就行了。這種方法杜絕了絕大多數由粗心引起的bug。如果你在公司使用類似技術來對付你的代碼的話可以有效減少工作時間,從而讓公司可以榨取更多價值。

                操作的組合還是比較麻煩的。為了全套支持,我特地操作了一下Visual Studio 2010的文本框,然后對一些我看不順眼的行為經過修改之后,現在已經可以實現{LEFT, RIGHT, UP, DOWN, HOME, END, PAGEUP, PAGEDOWN, ENTER, BACKSPACE, DELETE}×{null, CONTROL, SHIFT, CONTROL+SHIFT}共44種操作方法。加上鼠標,突破半百。這么復雜的東西,如果沒有足夠的單元測試,也沒有足夠的GUI自動化測試的話,隨便改個什么都很有可能發生問題的。所以開發這類程序的時候要十分小心,一定要寫單元測試。

                至于著色應該怎么測試呢?只要有了WCF,就十分簡單了。測試程序發送兩個坐標,WCF服務返回坐標之間所有字符的顏色代號就行了。代號是可以在測試程序跟被測程序之間約定的,所以這種方法就讓測試變得十分簡單了。

                開發這一部分一共花掉我大約四天時間(假設不用上班每天能寫8個小時,累計出來的)。當然平時要上班所以實際花費是要多一倍不止的。其實當我在紙上畫出了上圖C#著色器的狀態機之后,也沒想到實現出來速度這么猛的。雖然著色器使用狀態機來實現已經是速度最快的方法了(經過大學4年寫編譯器的經驗……不過我后來用C++做出了一個能根據正則表達式在內存中產生詞法分析器的,比手寫的更快),不過還是要感嘆一下.net到了4.0還是比起當年的2.0要進步無窮多倍的哈。虛擬機可以在執行的時候才開始產生并優化x86代碼,可以讓程序越跑越快(非騙人,編譯原理小白請自行學習),這還是靜態編譯其所不能達到的。之前還看過channel9上面的視頻講微軟某個研究院在做一個全新的javascript引擎(看起來好像沒有加進IE9beta),就是用了動態的兩階段profile+optimize+codegen的方法,通過為瓶頸代碼使用激進優化方法,從而讓總體的運行和編譯時間的總和降到最低。生成X86什么的還是非常麻煩的,總之我已經被機器碼囧了半年,暫時不想碰JIT了……當然這是遲早要再碰一次的。

                寫到這里就先碎覺了,下一篇開始說之前在糾結的過程中產生的幾個智能完成的方案。遲早都要把它給做出來的。
            posted on 2010-09-16 10:32 陳梓瀚(vczh) 閱讀(10012) 評論(12)  編輯 收藏 引用 所屬分類: 開發自己的IDE

            評論:
            # re: 開發自己的IDE(二) 2010-09-16 16:34 | ccsdu2009
            幫你頂頂 太冷清了  回復  更多評論
              
            # re: 開發自己的IDE(二)[未登錄] 2010-09-16 17:45 | king
            同樓上,勇氣可嘉。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 17:59 | 溪流
            UI也可以單元測試啊,學習了  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 18:04 | Sunshine Alike
            看來C#越來越威武了~~  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 19:38 | pengwang
            加油,哪里像我整天陷在一坨一坨的business logic里,丫的根本不像Martin說的幫客戶解決問題也很有成就感,沮喪啊。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 19:48 | schindlerlee
            強烈支持  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 21:47 | megax
            折疊不應該由plugin來處理,否則會很痛苦的。編輯器本身應該提供那些行不顯示的功能,并對scrollbar和caret的更新提供支持,然后才讓plugin去處理折疊。輸入法光標跟隨,那是輸入法本身提供的功能,有的輸入法沒有光標跟隨,比如微軟的日語輸入法,而且如果用sogou的輸入法的話,它有一個bug,在多語言切換之后,就無法跟隨了。正確的處理方法還是自己處理IME消息,然后移動窗口。如果不處理的話,那么你輸入一個句子的話,會對每一個漢字產生一個OnChar,效率較低。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 23:10 | 陳梓瀚(vczh)
            @megax
            我的編輯器有listener,可以讓插件監聽和同步在編輯器上的發生的所有事情,所以可以放進插件,這個倒不用擔心,而且這么做還能讓你的單元測試更容易寫,單元測試運行得更快,所以不會有問題的哈。

            不過因為我的插件是可以做成同時插入多個的(combinator),因此可以把折疊的功能獨立出來做成一個“服務”供其他跟語言相關的插件享用。個人認為這種做法最利于解耦以及測試。只要測試跟上了,開發的痛苦就會大大減少了。因為痛苦來源于debug,而不是寫代碼本身。

            至于光標跟隨,我只響應了一個IME消息,在需要的時候更新那個輸入框的位置。不過我沒有處理把一個句子不分割成很多Char的事情,因為這個才會受到實現的影響,而且你也只會在輸入注釋的時候用輸入法,所以也就不需要做了。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-16 23:12 | 陳梓瀚(vczh)
            @pengwang
            因為你解決的不是客戶的問題,而是經理制造出來的問題哈。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-19 17:39 | 空明流轉
            師祖威武。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-19 19:16 | luna
            輸入法的窗口會跟隨光標移動……
            把輸入法的光標跟隨去掉不就行了。  回復  更多評論
              
            # re: 開發自己的IDE(二) 2010-09-19 23:06 | 陳梓瀚(vczh)
            @luna
            你可能理解錯我的意思了,我是自己寫代碼讓輸入法的窗口跟著光標移動了- -b  回復  更多評論
              
            99热成人精品热久久669| 久久伊人精品一区二区三区| 青青青青久久精品国产| 久久精品国产亚洲Aⅴ蜜臀色欲| 久久久久这里只有精品| 无码AV中文字幕久久专区| 好久久免费视频高清| 色偷偷88欧美精品久久久| 久久久噜噜噜久久熟女AA片| 亚洲午夜精品久久久久久人妖| 久久99热这里只频精品6| 国产成人综合久久综合| 国产成年无码久久久免费| 超级碰久久免费公开视频| 狠狠色婷婷久久一区二区 | 伊人久久综合无码成人网| 狠狠色丁香久久综合婷婷| 日产精品久久久久久久| 欧美激情精品久久久久| 99久久精品国产一区二区| 久久久久一本毛久久久| 日本三级久久网| 国产精品久久自在自线观看| 伊人久久大香线蕉av不变影院| 亚洲国产成人久久综合碰| 国产精品美女久久久久网| 久久久无码精品亚洲日韩按摩 | 亚洲国产成人久久综合一区77 | 精品国产乱码久久久久久人妻| 久久精品国产99久久丝袜| 婷婷久久综合九色综合98| 日韩久久久久久中文人妻| 久久精品国产亚洲av麻豆图片| 青青青青久久精品国产h久久精品五福影院1421 | 青青青青久久精品国产h| 国产精品对白刺激久久久| 久久人人妻人人爽人人爽| 久久精品无码专区免费青青| 国产精品美女久久久久 | 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 一本久久久久久久|