1. 程式人生 > >.NET平臺開源專案速覽(4).NET文件生成工具ADB及使用

.NET平臺開源專案速覽(4).NET文件生成工具ADB及使用

    很久以前就使用ADB這個工具來生成專案的幫助文件。功能強大,在學習一些開源專案的過程中,官方沒有提供CHM幫助文件,所以為了快速的瞭解專案結構和註釋。就生成文件來自己看,非常好用。這也是一個學習方法吧。例如本文在:

  上述2篇文章中最後的資源中就手動製作了CHM幫助文件。有時候我們還可以對原始碼進行翻譯,再製作,效果還不錯。今天介紹的ADB工具,我使用的是基於X元件的一個改進版。改進的細節我也不太清楚,反正非常好用。下面來看看介紹和使用方法。

1.ADB介紹

    程式的註釋在程式的編寫和維護中扮演著相當重要的角色,在Visual C#中,可以為程式碼建立文件,方法是在XML標記所指的程式碼塊前面,直接在原始碼的特殊註釋欄位中包括XML 標記。編譯器編譯時將在原始碼中搜索所有的 XML 標記,並建立一個XML文件檔案。.NET文件生成工具(

下文簡稱為ADB)通過反射程式集及其程式碼中的XML註釋來建立MSDN形式的API文件。

    ADB文件生成工具是部落格園 盧春城 開發的一個開源工具,專案的介紹網址為:

    注意:使用該軟體需先安裝Microsoft HTML Help Workshop,主要作用有:

(1)根據程式集及其對應的XML文件檔案生成風格類似MSDN的文件,並打包為CHM檔案;

(2)將多個程式集對應的文件合併到一個文件中;

(3)自動搜尋程式集及其引用的程式集對應的XML文件(包括.Net自帶的程式集,如:System.xml);

(4)靈活控制在文件中顯示哪些成員(如:只生成公共方法);

(5)介面友好,操作簡便。

(6)使用者可以根據自己的需要擴充套件XML標誌

(7)使用者可以根據自己的需要編寫自定義的文件生成器。

    ADB官方提供的最新版是2.3,可以去上面的連結下載最新版,我這裡分享的是@大石頭使用X元件重新編譯後的版本。

2.ADB生成.NET文件過程

    使用過程分為3個步驟:

2.1 .NET專案程式碼註釋

    ADB程式碼生成主要是根據專案的註釋來進行生成的。例如C#中註釋的標記:

/// <summary>獲取指定陣列中,滿足範圍的比例</summary>
/// <param name="data">目標資料</param>
/// <param name="L">下限</param>
/// <param name="H">上限</param>
public static double FindPrecent(this IEnumerable<Int32> data, Int32 L, Int32 H)
{
	var t = (double)data.Where(n => n >= L && n <= H).Count();
	return t / (double)data.Count();	
}

    當然還有更多的標記符號,例如example,code,see等等。如果想做很完善的幫助文件,那這些細節處理得越好,那文件的作用就越強大。

2.2 專案設定與生成

    專案編譯之前,要確認是否生成xml檔案,開啟 專案屬性->生成->輸出 節點,如下圖:

blob.png

    確認勾選xml文件檔案選項。生成的時候就是根據這個xml的註釋來進行的。

2.3 ADB使用生成CHM文件

    開啟ADB軟體,我在第3節提供2個版本的下載,如果需要自己編譯其他版本,開啟ADB軟體,如下圖:

blob.png

    輸入標題後,新增你要生成的文件的dll檔案,可以新增多個,然後如果你生成了對應的xml檔案,會自動載入進來。否則會報錯。如下圖:

blob.png

    還可以只新增你想要的型別以及方法。一般非公共型別可以不加進去。最後點”建立文件”就OK了,它會生成到你xml檔案的目錄。

注意2個小問題:你的CHM的檔案標題要規範一點,什麼#號,:號等都不要加上去,否則會報錯,有時候很頭疼。。。經常會忘記這一個,有時候還不止咋搞,就錯誤。如下圖所示,標題就有問題:

blob.png

    好了,不說了,說多了都是淚。下面看看我生成的一些文件:

blob.png

    效果不錯哦。。。趕緊試試。

3.資源與程式碼

    我這裡發的是X元件修改版本的原始碼,感謝@盧春城 ,@大石頭,我只是打醬油的,把它分享出來而已。

大家主要,如果dll不是上面2個版本,可能要自己編譯一下。如果有問題,及時留言,我會給大家解決,可能有一些小問題。因為我安裝好後,基本生成都是好的。沒碰到過啥問題,不保證大家也麼有問題啊。非常感謝 發現一個問題:


大多數人安裝HTML Help Workshop 會預設安在C盤,
我將 HTML Help Workshop 安裝到D盤時,生成時會報"系統找不到指定的檔案"。

在原始碼裡,將CreateCHM()方法中的
“_hhcProcess.StartInfo.FileName = _defaultHHCPath; ” ,_defaultHHCPath 改成 HHCPath 就可以正常生成了。

相關推薦

.NET平臺開源專案(4).NET生成工具ADB使用

    很久以前就使用ADB這個工具來生成專案的幫助文件。功能強大,在學習一些開源專案的過程中,官方沒有提供CHM幫助文件,所以為了快速的瞭解專案結構和註釋。就生成文件來自己看,非常好用。這也是一個學習方法吧。例如本文在:   上述2篇文章中最後的資源中就手動製作了CHM幫助文件。有時候我們還可

.NET平臺開源專案(9)軟體序列號生成元件SoftwareProtector介紹與使用

  在文章:這些.NET開源專案你知道嗎?讓.NET開源來得更加猛烈些吧!(第二輯)中,給大家初步介紹了一下Software Protector序列號生成元件。今天就通過一篇簡單的文章來預覽一下其強大的功能。雖然我人為其已經基本滿足了一個軟體序列號的所有要素,但至於大家用不用得上,還得看大家的需求。總的來

.NET平臺開源專案-最快的物件對映元件Tiny Mapper之專案實踐

心情小札:近期換了工作,苦逼於22:00後下班,房間一篇狼藉~ 小翠鄙視到:"你就適合生活在垃圾堆中!!!" 看評論也是挺有價值,同時也看到許多新手同學問道在實際專案中使用的情況。 下面就原作者的程式碼的基礎上略作調整,闡述一下在實際專案場景中的使用: 第一步:瞭解類庫方法:TinyMapper 主

.NET平臺開源專案(14)最快的物件對映元件Tiny Mapper

    好久沒有寫文章,工作甚忙,但每日還是關注.NET領域的開源專案。五一休息,放鬆了一下之後,今天就給大家介紹一個輕量級的物件對映工具Tiny Mapper:號稱是.NET平臺最快的物件對映元件。那就一起看看呢。 臨時更新:感謝@ 的意見,為了避免新手誤解,這裡說明一下,Tiny Mappe

.NET平臺開源專案(20)Newlife.Core中簡單靈活的配置檔案

如果用知乎,可以關注專欄: 記得5年前開始拼命翻讀X元件的原始碼,特別是XCode,但對Newlife.Core 的東西瞭解很少,最多隻是會用用,而且用到的只是九牛一毛。裡面好用的東西太多了。 最近一年時間,零零散散又學了很多,也瞭解了很多,不會寫那總要學會用吧,今天就給大家介紹裡面非常好用的自定義配置檔

.NET平臺開源專案(19)Power BI神器DAX Studio

  PowerBI更新頻繁,已經有點更不上的節奏,一直在關注和學習中,基本的一些操作大概是沒問題,更重要的是注重Power Query,M函式,以及DAX的使用,這才是核心。     上個月研究了DAX的一些語法和公式,發現這玩意看起來簡單,但其實功能非常強大,所以就想和寫程式碼一樣,弄個工具試一下。

.NET平臺開源專案(21)Cron任務排程CronNET

Quartznet大名鼎鼎應該很少有人不知道,相關的開源專案很多,不過那東東對新手來說,有點晦澀,加上哪個Cron表示式,可能一進去雲裡霧裡的。今天給大家介紹一個簡單的在.NET平臺上執行Cron計劃任務的元件CronNET。同時也給大家推介幾個Cron表示式的工具。 1.Cron介紹和工具

.NET平臺開源專案(7)關於NoSQL資料庫LiteDB的分頁查詢解決過程

  在文章:這些.NET開源專案你知道嗎?讓.NET開源來得更加猛烈些吧!(第二輯) 與 .NET平臺開源專案速覽(3)小巧輕量級NoSQL檔案資料庫LiteDB中,介紹了LiteDB的基本使用情況以及部分技術細節,我還沒有在實際系統中大量使用,但文章釋出後,有不少網友( )反應在實際專案中使用過,效果還

.NET平臺開源專案(11)KwCombinatorics排列組合使用案例(1)

    今年上半年,我在KwCombinatorics系列文章中,重點介紹了KwCombinatorics元件的使用情況,其實這個元件我5年前就開始用了,非常方便,麻雀雖小五臟俱全。所以一直非常喜歡,才寫了幾篇文章推薦給大家。最近在計算足球彩票結果組合過程中,使用的到了其功能,生成排列,非常具有代表性,而且也

.NET平臺開源專案(1)SharpConfig配置檔案讀寫元件

在.NET平臺日常開發中,讀取配置檔案是一個很常見的需求。以前都是使用System.Configuration.ConfigurationSettings來操作,這個說實話,搞起來比較費勁。不知道大家有沒有同感。所以更多時候我還是喜歡使用開源的東西,更加方便簡潔,也穩定。省去自己的麻煩。今天就介紹一個非常精緻

.NET平臺開源專案(3)小巧輕量級NoSQL檔案資料庫LiteDB

    今天給大家介紹一個不錯的小巧輕量級的NoSQL檔案資料庫LiteDB。本部落格在2013年也介紹過2款.NET平臺的開源資料庫:     上面2個數據庫我的實際的專案中用過,還不錯。當然資料量很小,主要是客戶比較變態,必須要用xml檔案儲存,就想到了,另外NDatabase只是自己覺得好玩,

.NET平臺開源專案(10)FluentValidation驗證元件深入使用(二)

    在上一篇文章:.NET平臺開源專案速覽(6)FluentValidation驗證元件介紹與入門(一) 中,給大家初步介紹了一下FluentValidation驗證元件的使用情況。文章從構建間的驗證器開始,到最後的結果,以及複雜驗證等都做了比較深入的講解和使用。但其實一個完整的元件是麻雀雖小五臟俱全

.NET平臺開源專案(2)Compare .NET Objects物件比較元件

    .NET平臺開源專案速覽今天介紹一款小巧強大的物件比較元件。可以更詳細的獲取2個物件的差別,並記錄具體差別,比較過程和要求可以靈活配置。 1.Compare .NET Objects介紹     Compare .NET Objects元件是.NET平臺用於深入比較2個.NET物件的開源元

.NET平臺開源專案(13)機器學習元件Accord.NET框架功能介紹

    Accord.NET Framework是在AForge.NET專案的基礎上封裝和進一步開發而來。因為AForge.NET更注重與一些底層和廣度,而Accord.NET Framework更注重與機器學習演算法以及提供計算機視訊、音訊、訊號處理以及統計應用相關的解決方案。該專案使用C#語言編寫,專

.NET平臺開源專案(5)深入使用與擴充套件SharpConfig元件

  上個月在文章:這些.NET開源專案你知道嗎?讓.NET開源來得更加猛烈些吧  和 .NET平臺開源專案速覽(1)SharpConfig配置檔案讀寫元件 中都提到了SharpConfig元件,簡單輕量級,速度快,而且還有比較深入的使用介紹。在文章釋出後,也有網友提到一些問題,當時我也沒仔細去分析,在這次我親

.NET平臺開源專案(8)Expression Evaluator表示式計算元件使用

  在文章:這些.NET開源專案你知道嗎?讓.NET開源來得更加猛烈些吧!(第二輯)中,給大家初步介紹了一下Expression Evaluator驗證元件。那裡只是概述了一下,並沒有對其使用和強大功能做深入研究,所以今天就通過一篇簡單的文章來預覽一下其強大的功能。本文曾在【原創】.NET開源表示式計算元

.NET平臺開源專案(6)FluentValidation驗證元件介紹與入門(一)

    在文章:這些.NET開源專案你知道嗎?讓.NET開源來得更加猛烈些吧!(第二輯)中,給大家初步介紹了一下FluentValidation驗證元件。那裡只是概述了一下,並沒有對其使用和強大功能做深入研究,所以今天以及接下去的幾篇文章就專門介紹這個元件。不僅僅是它小,輕量級,優雅,而且一直在持續更新中

.NET平臺開源專案(12)雜湊演算法集合類庫HashLib

    .NET的System.Security.Cryptography名稱空間本身是提供加密服務,雜湊函式,對稱與非對稱加密演算法等功能。實際上,大部分情況下已經滿足了需求,而且.NET實現的都是目前國際上比較權威的,標準化的演算法,所以還是安全可靠的。但也有一些場合,需要自己實現一些安全雜湊演算法。

.NET平臺開源專案(18)C#平臺JSON實體類生成器JSON C# Class Generator

    去年,我在一篇文章用原始方法解析複雜字串,json一定要用JsonMapper麼?中介紹了簡單的JSON解析的問題,那種方法在當時的環境是非常方便的,因為不需要生成實體類,結構很容易解析。但隨著業務的變化,也會碰到超級變態的JSON,如果還按照以前的思路,會把人搞抽風掉,一旦結構變化,又要重來。所

.NET平臺開源專案(16)C#寫PDF檔案類庫PDF File Writer介紹

    1年前,我在文章:這些.NET開源專案你知道嗎?.NET平臺開源文件與報表處理元件集合(三)中(第9個專案),給大家推薦了一個開源免費的PDF讀寫元件 PDFSharp,PDFSharp我2年前就看過,用過簡單的例子,不過程式碼沒有寫成專門的文章。最近在查詢資料的時候,又發現一款小巧的寫PDF檔案