基于Linux的源代碼開(kāi)放瀏覽器
Linux在嵌入式系統(tǒng)中的應(yīng)用正在迅速擴(kuò)大,這意味著軟件開(kāi)發(fā)工程師必須弄懂如何將為資源豐富的臺(tái)式PC和服務(wù)器開(kāi)發(fā)的源代碼開(kāi)放軟件,應(yīng)用于資源有限的嵌入式系統(tǒng)。
現(xiàn)在PC機(jī)上具備上百兆字節(jié)RAM和幾十GB的硬盤(pán)資源已很普遍,但對(duì)嵌入式系統(tǒng)的開(kāi)發(fā)者來(lái)說(shuō)通常是不可能的。而且,運(yùn)行在可隨意重啟動(dòng)系統(tǒng)中的桌面和企業(yè)級(jí)軟件很容易經(jīng)常升級(jí),但是安裝在工業(yè)現(xiàn)場(chǎng)的嵌入式應(yīng)用系統(tǒng)就不太容易,而且理想狀態(tài)下這種系統(tǒng)會(huì)一直運(yùn)行下去,根本不存在重新啟動(dòng)的問(wèn)題。因此,開(kāi)發(fā)工程師們應(yīng)當(dāng)研究如何在一個(gè)只有數(shù)兆存儲(chǔ)器資源的嵌入式設(shè)計(jì)中,充分利用過(guò)去十年來(lái)開(kāi)發(fā)的桌面軟件資源?
現(xiàn)有的基于Linux操作系統(tǒng)的桌面瀏覽器家族已經(jīng)發(fā)展到了相當(dāng)?shù)囊?guī)模,目前市面上可供用戶選擇的桌面瀏覽器超過(guò)20種,那么為什么還要引入另外一種呢?在做了哪一種現(xiàn)有的桌面瀏覽器適合用于開(kāi)發(fā)嵌入式瀏覽器的調(diào)查之后,我們發(fā)現(xiàn)沒(méi)有一個(gè)網(wǎng)絡(luò)客戶端的桌面瀏覽器滿足嵌入式系統(tǒng)的要求。這些瀏覽器不是象Netscape的Mozilla那樣太大而導(dǎo)致沒(méi)法在大多數(shù)嵌入式系統(tǒng)上運(yùn)行,就是太小,其HTML功能很不完整,因此我們決定自己設(shè)計(jì)一種新型瀏覽器,一種專門(mén)適用于嵌入式Linux設(shè)備的瀏覽器。
我們有五個(gè)最初的設(shè)計(jì)目標(biāo)。首先,希望創(chuàng)建盡可能小的瀏覽器,不過(guò)這種瀏覽器要保持與HTML 100%的標(biāo)準(zhǔn)兼容性。這種瀏覽器可以應(yīng)用于很多應(yīng)用設(shè)備,從嵌入式設(shè)備文檔顯示到因特網(wǎng)電器設(shè)備和機(jī)頂盒,而且我們必須確信這種瀏覽器總能正確地顯示網(wǎng)頁(yè)。其次,同樣重要的是,希望采用現(xiàn)有的用于HTML語(yǔ)法分析和顯示引擎的開(kāi)放式源代碼,我們不想再?gòu)牧汩_(kāi)始編寫(xiě)HTML引擎代碼,這是實(shí)現(xiàn)大多數(shù)小型瀏覽器時(shí)最常見(jiàn)的一個(gè)毛病,因?yàn)檎_地顯示所有的HTML文件需要大量的知識(shí)和經(jīng)驗(yàn),尤其是現(xiàn)在很多的HTML文件仍然是手寫(xiě)的。
第三,希望采用已選定的HTML窗口部件代碼,我們不想改變?nèi)魏魏诵腍TML顯示引擎代碼,盡管它的源代碼是開(kāi)放的。這樣做將帶來(lái)兩大主要好處:一是不用操心HTML顯示引擎功能的升級(jí),因?yàn)镠TML專家已經(jīng)優(yōu)化了HTML分析引擎的代碼設(shè)計(jì);二是不會(huì)有設(shè)計(jì)缺陷被直接引入到核心顯示子程序中,從而可保證很高的代碼質(zhì)量。
小型窗口部件
第四,我們想要使用一套適用于小環(huán)境的用戶界面窗口部件,為此,決定利用Fast Light工具套件(FLTK)應(yīng)用框架。FLTK可從www.fltk.org獲得,它能提供一套理想的適用于小型應(yīng)用環(huán)境的用戶界面窗口部件。
最后,我們認(rèn)為為了使這種瀏覽器被市場(chǎng)廣泛接受,應(yīng)使它具有足夠的靈活性,即既可以運(yùn)行在新型嵌入式Microwindows圖形窗口環(huán)境中(www.microwindows.org),也可以運(yùn)行在標(biāo)準(zhǔn)的X Windows系統(tǒng)中。此外,我們希望確保這兩種視窗操作系統(tǒng)都可以與該軟件設(shè)計(jì)進(jìn)行無(wú)縫集成,而且不會(huì)對(duì)該瀏覽器的體系結(jié)構(gòu)產(chǎn)生任何影響。
第一個(gè)主要的決定是選擇源代碼開(kāi)放的HTML語(yǔ)法分析和顯示引擎。我們從KDE桌面的kmf文件管理器中選擇了KDE 1.0 HTML窗口部件(KDE可在www.kde.org獲得),這一選擇引出了至少三個(gè)問(wèn)題:為什么不使用KDE更新的v2.0 Konqueror窗口部件?Mozilla 和 Gecko 搜索引擎怎樣?為什么不使用QT(它是挪威Trolltech AS公司的C++跨平臺(tái)GUI開(kāi)發(fā)系統(tǒng))?
對(duì)于第一個(gè)問(wèn)題,我們是這樣考慮的:KDE 1.0 HTML窗口部件在大多數(shù)網(wǎng)站上都能正確顯示,這一點(diǎn)我們已經(jīng)通過(guò)運(yùn)行桌面kfm文件管理器得到驗(yàn)證。KDE窗口部件工作穩(wěn)定,支持全部HTML 3.2功能,相對(duì)較小,而且其代碼可讀性好,易于再利用。那么為什么不使用可支持HTML 4.0和JavaScript 1.4的KDE 2.0窗口部件呢?這里至少有兩個(gè)問(wèn)題:首先,KDE 2.0在我們?cè)O(shè)計(jì)工作開(kāi)始的時(shí)候還不成熟,缺少很多功能,而且在實(shí)際運(yùn)作工程中的表現(xiàn)還不夠穩(wěn)定?,F(xiàn)在它已經(jīng)改進(jìn)了很多,但仍缺乏實(shí)際驗(yàn)證。與此相反,KDE 1.0窗口部件已經(jīng)推出了一年多,實(shí)踐證明是比較成熟的;第二,KDE 2.0窗口部件幾乎比它的1.0版本大四倍。我們認(rèn)為對(duì)第一版來(lái)說(shuō),其功能與大小的折衷是可以接受的,尤其是由于該設(shè)計(jì)的可擴(kuò)展性好,即便在其設(shè)計(jì)定型以后仍允許添加新的功能。
有段時(shí)間,我們還曾考慮過(guò)Mozilla, 它是繼網(wǎng)景瀏覽器之后推出的一種源代碼開(kāi)放瀏覽器,但最終因反對(duì)聲過(guò)多而放棄了它,只因?yàn)镸ozilla過(guò)于龐大了。Mozilla 版本的GTK+窗口部件(不包括郵件、新聞等)在不裝入任何網(wǎng)頁(yè)的情況下需要多達(dá)12M字節(jié),這比目前的ViewML瀏覽器要大6倍。GTK+窗口部件集合也很大,與FLTK的100k相比,它至少有2M字節(jié)。
易置換的類集
到目前為止,在考慮使用那一種窗口部件時(shí),爭(zhēng)論最多的是KDE 1.0窗口部件使用的QT窗口部件集合(QT可從www.trolltech.com 獲得)。如果我們可以對(duì)最初的設(shè)計(jì)目標(biāo)做一些妥協(xié),那么QT窗口部件將由于好幾種理由而成為這一方案的一個(gè)合乎邏輯的選擇。其中之一是,尚沒(méi)有Microwindows版本的QT采用了一種獨(dú)特的編碼風(fēng)格,它允許用運(yùn)行在另一工具套件上的改進(jìn)版類方便地置換原有的類,這一工具套件具有Microwindows和X版本。
這一事實(shí)降低了QT API的總體大小,因?yàn)槲覀儾辉傩枰械念?。你可得到一個(gè)免費(fèi)的QT版本作為編碼參考。
我們最終選擇的是可同時(shí)在Microwindows和X上運(yùn)行的唯一窗口部件集合FLTK,這一工具套件也采用C++編寫(xiě)。選擇它的另外一個(gè)好處是這一工具套件在對(duì)QT API和后端FLTK進(jìn)行集成時(shí)相對(duì)較簡(jiǎn)單。
在選擇了核心顯示引擎之后,我們創(chuàng)建了一個(gè)分層軟件體系結(jié)構(gòu),這一結(jié)構(gòu)嚴(yán)格地定義了每一個(gè)瀏覽器模塊以及每一模塊應(yīng)該完成的功能。為了滿足不改變顯示引擎編碼的設(shè)計(jì)目標(biāo),該體系結(jié)構(gòu)是必需的。我們也必須定義一些新模塊,一旦開(kāi)發(fā)出更小的模塊,或因采用圖形化視窗系統(tǒng)而需要對(duì)某些模塊進(jìn)行更改,就可以置換舊模塊。我們集成的模塊包括:瀏覽器應(yīng)用層、萬(wàn)維網(wǎng)的WWWLib庫(kù)、KHTML View和窗口部件模塊、QT兼容層、IMLIB 圖形庫(kù)和FLTK應(yīng)用框架。
ViewML瀏覽器應(yīng)用層很小,并完全用C++ FLTK應(yīng)用框架編寫(xiě),它提供了基本的圖形用戶界面布局。我們盡量將這一層做得很小,以便應(yīng)用工程師能夠很容易地為某個(gè)特定嵌入式應(yīng)用環(huán)境修改ViewML瀏覽器,而無(wú)需深入了解整個(gè)瀏覽器。在一些嵌入式應(yīng)用環(huán)境中,可能根本沒(méi)有用戶界面,只顯示一個(gè)全屏幕的瀏覽器頁(yè)面。這一層也可以處理網(wǎng)絡(luò)和本地文件存取需求。
我們選用了萬(wàn)維網(wǎng)協(xié)會(huì)的WWWLib庫(kù)來(lái)執(zhí)行所有的異步網(wǎng)絡(luò)輸入/輸出和HTTP獲得(HTTP get)功能,因?yàn)樗容^容易使用。我們發(fā)現(xiàn)WWWLib庫(kù)基本上要比實(shí)際所需要的大,因此它可能將被改寫(xiě)。不過(guò),就目前而言,它使我們不必在這一專門(mén)領(lǐng)域花費(fèi)太多精力就可迅速獲取初始版瀏覽器的功能。
KHTML View和窗口部件模塊由原始的未經(jīng)修改的KDE 1.0 HTML窗口部件代碼構(gòu)成,這一未經(jīng)修改的源代碼被上層的用戶界面應(yīng)用層調(diào)用,仍認(rèn)為是在和下層的QT應(yīng)用框架通信。KHTML窗口部件處理所有的HTML語(yǔ)法分析、作圖和基本的布局操作,它并不直接處理屏幕滾動(dòng)或顯示框架的操作,而是把這些任務(wù)授權(quán)給KHTML View去做。KHTML View是ViewML中功能最全面的一種窗口部件,它管理一個(gè)或多個(gè)KHTML窗口部件,并執(zhí)行屏幕滾動(dòng)和HTML框架顯示操作。
QT兼容性層提供未經(jīng)修改的HTML窗口部件和FLTK應(yīng)用框架(而不是QT框架)之間的接口。C++ QT類在這一層被改寫(xiě),以保持相同的公共接口,這些類包括圖形窗口部件(編輯控制、按鈕等)、類集及字符串類、以及實(shí)現(xiàn)一些特定QT功能的通用功能類。所有的圖形類采用FLTK提供的功能實(shí)現(xiàn),這使得所有標(biāo)準(zhǔn)控制和大多數(shù)作圖功能相對(duì)比較容易實(shí)現(xiàn),不過(guò),用于窗口部件內(nèi)部通信的非標(biāo)準(zhǔn)QT信號(hào)機(jī)制不得不從零開(kāi)始進(jìn)行編碼。所有的類集和字符串類在標(biāo)準(zhǔn)C++庫(kù)中實(shí)現(xiàn),這些庫(kù)包括:堆棧、列表、字典(哈希表)和常見(jiàn)字符串類,除了QT在其類集合中使用的新型自動(dòng)刪除機(jī)制以外,這些類完全是標(biāo)準(zhǔn)的。
對(duì)圖象而言,Gnome項(xiàng)目中的IMLIB曾用于X視窗系統(tǒng),IMLIB庫(kù)允許實(shí)現(xiàn)QT類型圖象的顯示功能,包括自動(dòng)檢測(cè)圖象類型、自動(dòng)縮放圖象、以及將圖象顯示在屏幕上。盡管IMLIB庫(kù)也有一些不足之處,例如大小,但最主要的缺點(diǎn)是它不適用于Microwindows。因此,對(duì)于該環(huán)境,我們直接將圖形圖象支持功能增加到Microwindows中,這樣就較好地解決了這一問(wèn)題,同時(shí)使該模塊仍保持較小的尺寸,并且允許增加新的圖像解碼器。
根據(jù)視窗系統(tǒng)的不同,可以采用兩個(gè)不同版本的FLTK應(yīng)用框架。標(biāo)準(zhǔn)版本的FLTK包括對(duì)Win32和X的支持。我們和Microwindows項(xiàng)目開(kāi)發(fā)人員一起將FLTK移植到Microwindows已有的Nano-X API中,這一技術(shù)支持允許與Microwindows服務(wù)器進(jìn)行客戶-服務(wù)器交互,就如同采用Xlib模型一樣。由于FLTK和Microwindows都能支持X Window系統(tǒng),因此它是一個(gè)很不錯(cuò)的選擇。
通過(guò)直接采用帶FLTK的X Windows系統(tǒng),或在X Windows系統(tǒng)上運(yùn)行Microwindows服務(wù)器,ViewML瀏覽器就可在Linux平臺(tái)上進(jìn)行調(diào)試和改進(jìn)。用這種方法,不管運(yùn)行的Microwindows還是X Windows系統(tǒng),目標(biāo)環(huán)境的確切特性都可以被仿真出來(lái)。Microwindows系統(tǒng)允許在臺(tái)式機(jī)上仿真目標(biāo)設(shè)備的準(zhǔn)確顯示特性,我們也希望能夠在臺(tái)式機(jī)上運(yùn)行與目標(biāo)設(shè)備基本相同的代碼路徑,這可極大地改善質(zhì)量控制。
ViewML項(xiàng)目已經(jīng)在短時(shí)間內(nèi)開(kāi)發(fā)出了一種高品質(zhì)的網(wǎng)絡(luò)瀏覽器,它直接針對(duì)嵌入式Linux環(huán)境。通過(guò)包含源代碼開(kāi)放的核心部件,我們已經(jīng)能夠在不占用多少RAM和ROM資源的情況下使用一個(gè)高品質(zhì)的顯示引擎。
ViewML瀏覽器的運(yùn)行大概需要2M字節(jié)的RAM,代碼文件的大小大約是800k。在Microwindows系統(tǒng)環(huán)境下運(yùn)行時(shí),對(duì)RAM的需求不超過(guò)2.5M字節(jié),這使它可用在大多數(shù)帶圖象顯示功能的32位嵌入式Linux系統(tǒng)上。由于整個(gè)ViewML項(xiàng)目的源代碼是開(kāi)放的,因此其他開(kāi)發(fā)者可以迅速理解ViewML并進(jìn)一步將它加以完善。
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評(píng)論