自動代碼生成,數據驅動編程,這都是一些比較好的理念。
編程編到一定程度,對數據驅動編程都不會太陌生。如果有數據,并且可以直接編寫算法對這些數據進行操作,那是再好不過的了。
不過并非事事完美,你有數據,但是你沒法直接通過算法對數據進行操作,因為這些數據必須是代碼的一部分,嵌入到代碼中。幸好,這種代碼的格式多半有規律的,因此,自動代碼生成可以在此使用。
托微軟的福,也許windows下的開發人員對自動代碼生成稍有陌生,不過這習慣在unix社區卻長久而廣泛(看看lex和yacc)。不過我仍不得不簡要介紹一下,什么是自動代碼生成(例子引自《unix編程藝術》)。
你有這樣一份數據:
pitter,08977135,usa,male,...
lucy,97869652,canada,female,...
welliem,2087987,england,male...
...
...
你希望把這些數據用表格的形式顯示到網站的一個頁面上,你肯定不想逐條的寫<tr>這種東西。于是,也許你會寫一個程序,讀取這份數據,并解析其中每個字段,然后將它們放進<tr>的標記中輸出。這就是自動代碼生成的開始。
我前陣子也有這樣的自動代碼生成需求,于是我寫了一個比較通用的工具。之所以說通用,是所生成的代碼的樣子,不是寫死在程序中的,而是外部的一個樣式文件定義的。
首先是數據文件的格式,我采用了xml,而不是像之前提到的,用基于換行的記錄。使用xml絕非偶然或者突發奇想,而是因為我所面對的數據確實是不平坦的,有著父子結構。簡單的舉個該格式的例子可能如下:
<r>
<data name="pitter" tel="08977135"/>
<data name="lucy" tel="9786952"/>
<data name="welliem" tel="2087987">
<im>
<data name="qq"/>
<data name="msn"/>
</im>
</data>
</r>
也許這個xml例子,還是可以用基于換行的記錄格式所描述的,不過更復雜的例子確實是平坦的格式力所不及的。
樣式文件的格式則很簡單,其中包含一個極小的微型語言,用來指定和控制xml數據如何替換到樣式文件中。比如:
$NODE<r>
$FOR_EACH_NODE<data>
printf( "$ATTR<name>" );
$END
然后,我們使用一下工具
h_replace -x data.xml -t css > a.cpp
a.cpp中將會生成如下代碼:
printf( "pitter" );
printf( "lucy" );
printf( "welliem" );
很顯然,$是命令的起始符號,更多的命令,大家可以從init_parser函數中看到。
關于源碼,rapidxml組件是sf.net上的,對于簡單的xml開發,這個東西足夠輕便和高效。其他的幾個文件都是我寫的。代碼很少,即使可讀性很差,相信大家還是能夠看明白的。代碼中肯定有諸多漏洞,樣式文件(微型語言)也會不太完整,不過這已經可以滿足我的絕大多數需要,所以也就沒有再修繕和拓展。
當然,歡迎感興趣的人對其改進,并把代碼發給我~
點擊這里下載源碼
posted on 2008-03-29 15:23
LOGOS 閱讀(3074)
評論(6) 編輯 收藏 引用