1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxHtmlHelpData 
   4 // Notes:       Based on htmlhelp.cpp, implementing a monolithic 
   5 //              HTML Help controller class,  by Vaclav Slavik 
   6 // Author:      Harm van der Heijden and Vaclav Slavik 
   8 // Copyright:   (c) Harm van der Heijden and Vaclav Slavik 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 #ifndef _WX_HELPDATA_H_ 
  13 #define _WX_HELPDATA_H_ 
  16 #pragma interface "helpdata.h" 
  23 #include "wx/object.h" 
  24 #include "wx/string.h" 
  25 #include "wx/filesys.h" 
  26 #include "wx/dynarray.h" 
  29 class WXDLLEXPORT wxHtmlHelpData
; 
  31 //-------------------------------------------------------------------------------- 
  32 // helper classes & structs 
  33 //-------------------------------------------------------------------------------- 
  35 class WXDLLEXPORT wxHtmlBookRecord 
: public wxObject
 
  38     wxHtmlBookRecord(const wxString
& basepath
, const wxString
& title
, 
  39                      const wxString
& start
) 
  41         m_BasePath 
= basepath
; 
  44         // for debugging, give the contents index obvious default values 
  45         m_ContentsStart 
= m_ContentsEnd 
= -1; 
  47     wxString 
GetTitle() const { return m_Title
; } 
  48     wxString 
GetStart() const { return m_Start
; } 
  49     wxString 
GetBasePath() const { return m_BasePath
; } 
  50     /* SetContentsRange: store in the bookrecord where in the index/contents lists the 
  51      * book's records are stored. This to facilitate searching in a specific book. 
  52      * This code will have to be revised when loading/removing books becomes dynamic. 
  53      * (as opposed to appending only) 
  54      * Note that storing index range is pointless, because the index is alphab. sorted. */ 
  55     void SetContentsRange(int start
, int end
) { m_ContentsStart 
= start
; m_ContentsEnd 
= end
; } 
  56     int GetContentsStart() const { return m_ContentsStart
; } 
  57     int GetContentsEnd() const { return m_ContentsEnd
; } 
  59     void SetTitle(const wxString
& title
) { m_Title 
= title
; } 
  60     void SetBasePath(const wxString
& path
) { m_BasePath 
= path
; } 
  61     void SetStart(const wxString
& start
) { m_Start 
= start
; } 
  63     // returns full filename of page (which is part of the book),  
  64     // i.e. with book's basePath prepended. If page is already absolute  
  65     // path, basePath is _not_ prepended. 
  66     wxString 
GetFullPath(const wxString 
&page
) const; 
  77 WX_DECLARE_EXPORTED_OBJARRAY(wxHtmlBookRecord
, wxHtmlBookRecArray
); 
  80 struct wxHtmlContentsItem
 
  86     wxHtmlBookRecord 
*m_Book
; 
  88     // returns full filename of m_Page, i.e. with book's basePath prepended 
  89     wxString 
GetFullPath() const { return m_Book
->GetFullPath(m_Page
); } 
  92 //------------------------------------------------------------------------------ 
  94 //                  This class takes input streams and scans them for occurence 
  96 //------------------------------------------------------------------------------ 
  98 class WXDLLEXPORT wxSearchEngine 
: public wxObject
 
 101     wxSearchEngine() : wxObject() {m_Keyword 
= NULL
; } 
 102     ~wxSearchEngine() {if (m_Keyword
) delete[] m_Keyword
; } 
 104     // Sets the keyword we will be searching for 
 105     virtual void LookFor(const wxString
& keyword
, bool case_sensitive
, bool whole_words_only
); 
 107     // Scans the stream for the keyword. 
 108     // Returns TRUE if the stream contains keyword, fALSE otherwise 
 109     virtual bool Scan(wxInputStream 
*stream
); 
 113     bool m_CaseSensitive
; 
 118 // State information of a search action. I'd have prefered to make this a nested 
 119 // class inside wxHtmlHelpData, but that's against coding standards :-( 
 120 // Never construct this class yourself, obtain a copy from 
 121 // wxHtmlHelpData::PrepareKeywordSearch(const wxString& key) 
 122 class WXDLLEXPORT wxHtmlSearchStatus
 
 125     // constructor; supply wxHtmlHelpData ptr, the keyword and (optionally) the 
 126     // title of the book to search. By default, all books are searched. 
 127     wxHtmlSearchStatus(wxHtmlHelpData
* base
, const wxString
& keyword
, 
 128                        bool case_sensitive
, bool whole_words_only
, 
 129                        const wxString
& book 
= wxEmptyString
); 
 130     bool Search();  // do the next iteration 
 131     bool IsActive() { return m_Active
; } 
 132     int GetCurIndex() { return m_CurIndex
; } 
 133     int GetMaxIndex() { return m_MaxIndex
; } 
 134     const wxString
& GetName() { return m_Name
; } 
 135     wxHtmlContentsItem
* GetContentsItem() { return m_ContentsItem
; } 
 138     wxHtmlHelpData
* m_Data
; 
 139     wxSearchEngine m_Engine
; 
 140     wxString m_Keyword
, m_Name
; 
 142     wxHtmlContentsItem
* m_ContentsItem
; 
 143     bool m_Active
;   // search is not finished 
 144     int m_CurIndex
;  // where we are now 
 145     int m_MaxIndex
;  // number of files we search 
 146     // For progress bar: 100*curindex/maxindex = % complete 
 149 class WXDLLEXPORT wxHtmlHelpData 
: public wxObject
 
 151     DECLARE_DYNAMIC_CLASS(wxHtmlHelpData
) 
 152     friend class wxHtmlSearchStatus
; 
 158     // Sets directory where temporary files are stored. 
 159     // These temp files are index & contents file in binary (much faster to read) 
 160     // form. These files are NOT deleted on program's exit. 
 161     void SetTempDir(const wxString
& path
); 
 163     // Adds new book. 'book' is location of .htb file (stands for "html book"). 
 164     // See documentation for details on its format. 
 166     bool AddBook(const wxString
& book
); 
 167     bool AddBookParam(const wxFSFile
& bookfile
, 
 168                       wxFontEncoding encoding
, 
 169                       const wxString
& title
, const wxString
& contfile
, 
 170                       const wxString
& indexfile 
= wxEmptyString
, 
 171                       const wxString
& deftopic 
= wxEmptyString
, 
 172                       const wxString
& path 
= wxEmptyString
); 
 174     // Some accessing stuff: 
 176     // returns URL of page on basis of (file)name 
 177     wxString 
FindPageByName(const wxString
& page
); 
 178     // returns URL of page on basis of MS id 
 179     wxString 
FindPageById(int id
); 
 181     const wxHtmlBookRecArray
& GetBookRecArray() { return m_BookRecords
; } 
 182     wxHtmlContentsItem
* GetContents() { return m_Contents
; } 
 183     int GetContentsCnt() { return m_ContentsCnt
; } 
 184     wxHtmlContentsItem
* GetIndex() { return m_Index
; } 
 185     int GetIndexCnt() { return m_IndexCnt
; } 
 190     wxHtmlBookRecArray m_BookRecords
; 
 191     // each book has one record in this array: 
 192     wxHtmlContentsItem
* m_Contents
; 
 194     wxHtmlContentsItem
* m_Index
; // list of all available books and pages. 
 195     int m_IndexCnt
;  // list of index items 
 198     // Imports .hhp files (MS HTML Help Workshop) 
 199     bool LoadMSProject(wxHtmlBookRecord 
*book
, wxFileSystem
& fsys
, 
 200                        const wxString
& indexfile
, const wxString
& contentsfile
); 
 202     bool LoadCachedBook(wxHtmlBookRecord 
*book
, wxInputStream 
*f
); 
 203     // Writes binary book 
 204     bool SaveCachedBook(wxHtmlBookRecord 
*book
, wxOutputStream 
*f
);