1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: Help system base classes
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_HELPBASEH__
13 #define _WX_HELPBASEH__
15 #if defined(__GNUG__) && !defined(__APPLE__)
16 #pragma interface "helpbase.h"
23 #include "wx/object.h"
24 #include "wx/string.h"
25 #include "wx/gdicmn.h"
28 // Flags for SetViewer
29 #define wxHELP_NETSCAPE 1
31 // Defines the API for help controllers
32 class WXDLLEXPORT wxHelpControllerBase
: public wxObject
34 DECLARE_CLASS(wxHelpControllerBase
)
37 inline wxHelpControllerBase() {}
38 inline ~wxHelpControllerBase() {};
40 // Must call this to set the filename and server name.
41 // server is only required when implementing TCP/IP-based
43 virtual bool Initialize(const wxString
& WXUNUSED(file
), int WXUNUSED(server
) ) { return FALSE
; }
44 virtual bool Initialize(const wxString
& WXUNUSED(file
)) { return FALSE
; }
46 // Set viewer: only relevant to some kinds of controller
47 virtual void SetViewer(const wxString
& WXUNUSED(viewer
), long WXUNUSED(flags
) = 0) {}
49 // If file is "", reloads file given in Initialize
50 virtual bool LoadFile(const wxString
& file
= "") = 0;
52 // Displays the contents
53 virtual bool DisplayContents(void) = 0;
55 // Display the given section
56 virtual bool DisplaySection(int sectionNo
) = 0;
58 // Display the section using a context id
59 virtual bool DisplayContextPopup(int WXUNUSED(contextId
)) { return FALSE
; };
61 // Display the text in a popup, if possible
62 virtual bool DisplayTextPopup(const wxString
& WXUNUSED(text
), const wxPoint
& WXUNUSED(pos
)) { return FALSE
; };
64 // By default, uses KeywordSection to display a topic. Implementations
65 // may override this for more specific behaviour.
66 virtual bool DisplaySection(const wxString
& section
) { return KeywordSearch(section
); };
67 virtual bool DisplayBlock(long blockNo
) = 0;
68 virtual bool KeywordSearch(const wxString
& k
) = 0;
69 /// Allows one to override the default settings for the help frame.
70 virtual void SetFrameParameters(const wxString
& WXUNUSED(title
),
71 const wxSize
& WXUNUSED(size
),
72 const wxPoint
& WXUNUSED(pos
) = wxDefaultPosition
,
73 bool WXUNUSED(newFrameEachTime
) = FALSE
)
75 // does nothing by default
77 /// Obtains the latest settings used by the help frame and the help
79 virtual wxFrame
*GetFrameParameters(wxSize
*WXUNUSED(size
) = NULL
,
80 wxPoint
*WXUNUSED(pos
) = NULL
,
81 bool *WXUNUSED(newFrameEachTime
) = NULL
)
83 return (wxFrame
*) NULL
;// does nothing by default
86 virtual bool Quit(void) = 0;
87 virtual void OnQuit(void) {};