1998-05-20 10:01:55 -04:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: helpbase.h
|
|
|
|
// Purpose: Help system base classes
|
|
|
|
// Author: Julian Smart
|
|
|
|
// Modified by:
|
|
|
|
// Created: 04/01/98
|
|
|
|
// RCS-ID: $Id$
|
2003-03-17 05:34:04 -05:00
|
|
|
// Copyright: (c) Julian Smart
|
2004-09-15 09:20:18 -04:00
|
|
|
// Licence: wxWindows licence
|
1998-05-20 10:01:55 -04:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
1998-08-14 20:23:28 -04:00
|
|
|
#ifndef _WX_HELPBASEH__
|
|
|
|
#define _WX_HELPBASEH__
|
1998-05-20 10:01:55 -04:00
|
|
|
|
1999-07-25 08:59:58 -04:00
|
|
|
#include "wx/defs.h"
|
2001-07-03 15:38:19 -04:00
|
|
|
|
|
|
|
#if wxUSE_HELP
|
|
|
|
|
1999-07-25 08:59:58 -04:00
|
|
|
#include "wx/object.h"
|
|
|
|
#include "wx/string.h"
|
|
|
|
#include "wx/gdicmn.h"
|
1999-07-26 12:06:20 -04:00
|
|
|
#include "wx/frame.h"
|
1998-05-20 10:01:55 -04:00
|
|
|
|
1999-02-18 09:55:34 -05:00
|
|
|
// Flags for SetViewer
|
|
|
|
#define wxHELP_NETSCAPE 1
|
|
|
|
|
2003-09-09 13:29:11 -04:00
|
|
|
// Search modes:
|
|
|
|
enum wxHelpSearchMode
|
|
|
|
{
|
|
|
|
wxHELP_SEARCH_INDEX,
|
|
|
|
wxHELP_SEARCH_ALL
|
|
|
|
};
|
|
|
|
|
1998-05-20 10:01:55 -04:00
|
|
|
// Defines the API for help controllers
|
|
|
|
class WXDLLEXPORT wxHelpControllerBase: public wxObject
|
|
|
|
{
|
2000-07-15 15:51:35 -04:00
|
|
|
public:
|
2005-10-26 05:32:10 -04:00
|
|
|
inline wxHelpControllerBase(wxWindow* parentWindow = NULL) { m_parentWindow = parentWindow; }
|
2002-12-04 09:11:26 -05:00
|
|
|
inline ~wxHelpControllerBase() {}
|
2001-07-03 15:38:19 -04:00
|
|
|
|
2000-07-15 15:51:35 -04:00
|
|
|
// Must call this to set the filename and server name.
|
|
|
|
// server is only required when implementing TCP/IP-based
|
|
|
|
// help controllers.
|
2004-09-15 09:20:18 -04:00
|
|
|
virtual bool Initialize(const wxString& WXUNUSED(file), int WXUNUSED(server) ) { return false; }
|
|
|
|
virtual bool Initialize(const wxString& WXUNUSED(file)) { return false; }
|
2001-07-03 15:38:19 -04:00
|
|
|
|
2000-07-15 15:51:35 -04:00
|
|
|
// Set viewer: only relevant to some kinds of controller
|
|
|
|
virtual void SetViewer(const wxString& WXUNUSED(viewer), long WXUNUSED(flags) = 0) {}
|
2001-07-03 15:38:19 -04:00
|
|
|
|
2000-07-15 15:51:35 -04:00
|
|
|
// If file is "", reloads file given in Initialize
|
2003-07-10 04:36:14 -04:00
|
|
|
virtual bool LoadFile(const wxString& file = wxEmptyString) = 0;
|
2000-09-12 10:53:39 -04:00
|
|
|
|
|
|
|
// Displays the contents
|
2000-07-15 15:51:35 -04:00
|
|
|
virtual bool DisplayContents(void) = 0;
|
2000-09-12 10:53:39 -04:00
|
|
|
|
|
|
|
// Display the given section
|
2000-07-15 15:51:35 -04:00
|
|
|
virtual bool DisplaySection(int sectionNo) = 0;
|
1998-05-20 10:01:55 -04:00
|
|
|
|
2000-09-12 10:53:39 -04:00
|
|
|
// Display the section using a context id
|
2004-09-15 09:20:18 -04:00
|
|
|
virtual bool DisplayContextPopup(int WXUNUSED(contextId)) { return false; };
|
2000-09-12 10:53:39 -04:00
|
|
|
|
|
|
|
// Display the text in a popup, if possible
|
2004-09-15 09:20:18 -04:00
|
|
|
virtual bool DisplayTextPopup(const wxString& WXUNUSED(text), const wxPoint& WXUNUSED(pos)) { return false; }
|
2000-09-12 10:53:39 -04:00
|
|
|
|
2000-07-15 15:51:35 -04:00
|
|
|
// By default, uses KeywordSection to display a topic. Implementations
|
|
|
|
// may override this for more specific behaviour.
|
2002-12-04 09:11:26 -05:00
|
|
|
virtual bool DisplaySection(const wxString& section) { return KeywordSearch(section); }
|
2000-07-15 15:51:35 -04:00
|
|
|
virtual bool DisplayBlock(long blockNo) = 0;
|
2003-09-09 13:29:11 -04:00
|
|
|
virtual bool KeywordSearch(const wxString& k,
|
|
|
|
wxHelpSearchMode mode = wxHELP_SEARCH_ALL) = 0;
|
2000-07-15 15:51:35 -04:00
|
|
|
/// Allows one to override the default settings for the help frame.
|
|
|
|
virtual void SetFrameParameters(const wxString& WXUNUSED(title),
|
|
|
|
const wxSize& WXUNUSED(size),
|
|
|
|
const wxPoint& WXUNUSED(pos) = wxDefaultPosition,
|
2004-09-15 09:20:18 -04:00
|
|
|
bool WXUNUSED(newFrameEachTime) = false)
|
2000-07-15 15:51:35 -04:00
|
|
|
{
|
|
|
|
// does nothing by default
|
|
|
|
}
|
2001-07-03 15:38:19 -04:00
|
|
|
/// Obtains the latest settings used by the help frame and the help
|
2000-07-15 15:51:35 -04:00
|
|
|
/// frame.
|
|
|
|
virtual wxFrame *GetFrameParameters(wxSize *WXUNUSED(size) = NULL,
|
|
|
|
wxPoint *WXUNUSED(pos) = NULL,
|
|
|
|
bool *WXUNUSED(newFrameEachTime) = NULL)
|
|
|
|
{
|
2002-12-04 09:11:26 -05:00
|
|
|
return (wxFrame*) NULL; // does nothing by default
|
2000-07-15 15:51:35 -04:00
|
|
|
}
|
2001-07-03 15:38:19 -04:00
|
|
|
|
2002-12-04 09:11:26 -05:00
|
|
|
virtual bool Quit() = 0;
|
|
|
|
virtual void OnQuit() {}
|
2004-09-15 09:20:18 -04:00
|
|
|
|
2005-10-26 05:32:10 -04:00
|
|
|
/// Set the window that can optionally be used for the help window's parent.
|
|
|
|
virtual void SetParentWindow(wxWindow* win) { m_parentWindow = win; }
|
|
|
|
|
|
|
|
/// Get the window that can optionally be used for the help window's parent.
|
|
|
|
virtual wxWindow* GetParentWindow() const { return m_parentWindow; }
|
|
|
|
|
|
|
|
protected:
|
|
|
|
wxWindow* m_parentWindow;
|
2002-12-04 09:11:26 -05:00
|
|
|
private:
|
|
|
|
DECLARE_CLASS(wxHelpControllerBase)
|
1998-05-20 10:01:55 -04:00
|
|
|
};
|
|
|
|
|
1998-09-25 09:28:52 -04:00
|
|
|
#endif // wxUSE_HELP
|
2001-07-03 15:38:19 -04:00
|
|
|
|
1998-05-20 10:01:55 -04:00
|
|
|
#endif
|
2000-07-15 15:51:35 -04:00
|
|
|
// _WX_HELPBASEH__
|