1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     Help system base classes 
   4 // Author:      Julian Smart 
   8 // Copyright:   (c) Julian Smart 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 #ifndef _WX_HELPBASEH__ 
  13 #define _WX_HELPBASEH__ 
  19 #include "wx/object.h" 
  20 #include "wx/string.h" 
  21 #include "wx/gdicmn.h" 
  24 // Flags for SetViewer 
  25 #define wxHELP_NETSCAPE     1 
  34 // Defines the API for help controllers 
  35 class WXDLLIMPEXP_CORE wxHelpControllerBase
: public wxObject
 
  38     inline wxHelpControllerBase(wxWindow
* parentWindow 
= NULL
) { m_parentWindow 
= parentWindow
; } 
  39     inline ~wxHelpControllerBase() {} 
  41     // Must call this to set the filename and server name. 
  42     // server is only required when implementing TCP/IP-based 
  44     virtual bool Initialize(const wxString
& WXUNUSED(file
), int WXUNUSED(server
) ) { return false; } 
  45     virtual bool Initialize(const wxString
& WXUNUSED(file
)) { return false; } 
  47     // Set viewer: only relevant to some kinds of controller 
  48     virtual void SetViewer(const wxString
& WXUNUSED(viewer
), long WXUNUSED(flags
) = 0) {} 
  50     // If file is "", reloads file given  in Initialize 
  51     virtual bool LoadFile(const wxString
& file 
= wxEmptyString
) = 0; 
  53     // Displays the contents 
  54     virtual bool DisplayContents(void) = 0; 
  56     // Display the given section 
  57     virtual bool DisplaySection(int sectionNo
) = 0; 
  59     // Display the section using a context id 
  60     virtual bool DisplayContextPopup(int WXUNUSED(contextId
)) { return false; } 
  62     // Display the text in a popup, if possible 
  63     virtual bool DisplayTextPopup(const wxString
& WXUNUSED(text
), const wxPoint
& WXUNUSED(pos
)) { return false; } 
  65     // By default, uses KeywordSection to display a topic. Implementations 
  66     // may override this for more specific behaviour. 
  67     virtual bool DisplaySection(const wxString
& section
) { return KeywordSearch(section
); } 
  68     virtual bool DisplayBlock(long blockNo
) = 0; 
  69     virtual bool KeywordSearch(const wxString
& k
, 
  70                                wxHelpSearchMode mode 
= wxHELP_SEARCH_ALL
) = 0; 
  71     /// Allows one to override the default settings for the help frame. 
  72     virtual void SetFrameParameters(const wxString
& WXUNUSED(title
), 
  73         const wxSize
& WXUNUSED(size
), 
  74         const wxPoint
& WXUNUSED(pos
) = wxDefaultPosition
, 
  75         bool WXUNUSED(newFrameEachTime
) = false) 
  77         // does nothing by default 
  79     /// Obtains the latest settings used by the help frame and the help 
  81     virtual wxFrame 
*GetFrameParameters(wxSize 
*WXUNUSED(size
) = NULL
, 
  82         wxPoint 
*WXUNUSED(pos
) = NULL
, 
  83         bool *WXUNUSED(newFrameEachTime
) = NULL
) 
  85         return (wxFrame
*) NULL
; // does nothing by default 
  88     virtual bool Quit() = 0; 
  89     virtual void OnQuit() {} 
  91     /// Set the window that can optionally be used for the help window's parent. 
  92     virtual void SetParentWindow(wxWindow
* win
) { m_parentWindow 
= win
; } 
  94     /// Get the window that can optionally be used for the help window's parent. 
  95     virtual wxWindow
* GetParentWindow() const { return m_parentWindow
; } 
  98     wxWindow
* m_parentWindow
; 
 100     DECLARE_CLASS(wxHelpControllerBase
)