git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@36466 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
248 lines
6.5 KiB
C++
248 lines
6.5 KiB
C++
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: src/msw/helpchm.cpp
|
|
// Purpose: Help system: MS HTML Help implementation
|
|
// Author: Julian Smart
|
|
// Modified by:
|
|
// Created: 16/04/2000
|
|
// RCS-ID: $Id$
|
|
// Copyright: (c) Julian Smart
|
|
// Licence: wxWindows licence
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// For compilers that support precompilation, includes "wx.h".
|
|
#include "wx/wxprec.h"
|
|
|
|
#ifdef __BORLANDC__
|
|
#pragma hdrstop
|
|
#endif
|
|
|
|
#if wxUSE_HELP && wxUSE_MS_HTML_HELP
|
|
|
|
#include "wx/filefn.h"
|
|
#include "wx/msw/helpchm.h"
|
|
|
|
#include "wx/dynload.h"
|
|
|
|
#ifndef WX_PRECOMP
|
|
#include "wx/intl.h"
|
|
#include "wx/app.h"
|
|
#endif
|
|
|
|
#include "wx/msw/private.h"
|
|
#include "wx/msw/htmlhelp.h"
|
|
|
|
// ----------------------------------------------------------------------------
|
|
// utility functions to manage the loading/unloading
|
|
// of hhctrl.ocx
|
|
// ----------------------------------------------------------------------------
|
|
|
|
#ifndef UNICODE
|
|
typedef HWND ( WINAPI * HTMLHELP )( HWND, LPCSTR, UINT, DWORD );
|
|
#define HTMLHELP_NAME wxT("HtmlHelpA")
|
|
#else // ANSI
|
|
typedef HWND ( WINAPI * HTMLHELP )( HWND, LPCWSTR, UINT, DWORD );
|
|
#define HTMLHELP_NAME wxT("HtmlHelpW")
|
|
#endif
|
|
|
|
// dll symbol handle
|
|
static HTMLHELP gs_htmlHelp = 0;
|
|
|
|
static bool LoadHtmlHelpLibrary()
|
|
{
|
|
wxPluginLibrary *lib = wxPluginManager::LoadLibrary( _T("HHCTRL.OCX"), wxDL_DEFAULT | wxDL_VERBATIM );
|
|
|
|
if( !lib )
|
|
{
|
|
wxLogError(_("MS HTML Help functions are unavailable because the MS HTML Help library is not installed on this machine. Please install it."));
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
gs_htmlHelp = (HTMLHELP)lib->GetSymbol( HTMLHELP_NAME );
|
|
|
|
if( !gs_htmlHelp )
|
|
{
|
|
wxLogError(_("Failed to initialize MS HTML Help."));
|
|
|
|
lib->UnrefLib();
|
|
return false ;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
static void UnloadHtmlHelpLibrary()
|
|
{
|
|
if ( gs_htmlHelp )
|
|
{
|
|
if (wxPluginManager::UnloadLibrary( _T("HHCTRL.OCX") ))
|
|
gs_htmlHelp = 0;
|
|
}
|
|
}
|
|
|
|
static HWND GetSuitableHWND(wxCHMHelpController* controller)
|
|
{
|
|
if (controller->GetParentWindow())
|
|
return (HWND) controller->GetParentWindow()->GetHWND();
|
|
else if (wxTheApp->GetTopWindow())
|
|
return (HWND) wxTheApp->GetTopWindow()->GetHWND();
|
|
else
|
|
return GetDesktopWindow();
|
|
}
|
|
|
|
IMPLEMENT_DYNAMIC_CLASS(wxCHMHelpController, wxHelpControllerBase)
|
|
|
|
bool wxCHMHelpController::Initialize(const wxString& filename)
|
|
{
|
|
// warn on failure
|
|
if( !LoadHtmlHelpLibrary() )
|
|
return false;
|
|
|
|
m_helpFile = filename;
|
|
return true;
|
|
}
|
|
|
|
bool wxCHMHelpController::LoadFile(const wxString& file)
|
|
{
|
|
if (!file.IsEmpty())
|
|
m_helpFile = file;
|
|
return true;
|
|
}
|
|
|
|
bool wxCHMHelpController::DisplayContents()
|
|
{
|
|
if (m_helpFile.IsEmpty()) return false;
|
|
|
|
wxString str = GetValidFilename(m_helpFile);
|
|
|
|
gs_htmlHelp(GetSuitableHWND(this), (const wxChar*) str, HH_DISPLAY_TOPIC, 0L);
|
|
return true;
|
|
}
|
|
|
|
// Use topic or HTML filename
|
|
bool wxCHMHelpController::DisplaySection(const wxString& section)
|
|
{
|
|
if (m_helpFile.IsEmpty()) return false;
|
|
|
|
wxString str = GetValidFilename(m_helpFile);
|
|
|
|
// Is this an HTML file or a keyword?
|
|
bool isFilename = (section.Find(wxT(".htm")) != wxNOT_FOUND);
|
|
|
|
if (isFilename)
|
|
gs_htmlHelp(GetSuitableHWND(this), (const wxChar*) str, HH_DISPLAY_TOPIC, (DWORD) (const wxChar*) section);
|
|
else
|
|
KeywordSearch(section);
|
|
return true;
|
|
}
|
|
|
|
// Use context number
|
|
bool wxCHMHelpController::DisplaySection(int section)
|
|
{
|
|
if (m_helpFile.IsEmpty()) return false;
|
|
|
|
wxString str = GetValidFilename(m_helpFile);
|
|
|
|
gs_htmlHelp(GetSuitableHWND(this), (const wxChar*) str, HH_HELP_CONTEXT, (DWORD)section);
|
|
return true;
|
|
}
|
|
|
|
bool wxCHMHelpController::DisplayContextPopup(int contextId)
|
|
{
|
|
if (m_helpFile.IsEmpty()) return false;
|
|
|
|
wxString str = GetValidFilename(m_helpFile);
|
|
|
|
// We also have to specify the popups file (default is cshelp.txt).
|
|
// str += wxT("::/cshelp.txt");
|
|
|
|
HH_POPUP popup;
|
|
popup.cbStruct = sizeof(popup);
|
|
popup.hinst = (HINSTANCE) wxGetInstance();
|
|
popup.idString = contextId ;
|
|
|
|
GetCursorPos(& popup.pt);
|
|
popup.clrForeground = (COLORREF)-1;
|
|
popup.clrBackground = (COLORREF)-1;
|
|
popup.rcMargins.top = popup.rcMargins.left = popup.rcMargins.right = popup.rcMargins.bottom = -1;
|
|
popup.pszFont = NULL;
|
|
popup.pszText = NULL;
|
|
|
|
gs_htmlHelp(GetSuitableHWND(this), (const wxChar*) str, HH_DISPLAY_TEXT_POPUP, (DWORD) & popup);
|
|
return true;
|
|
}
|
|
|
|
bool wxCHMHelpController::DisplayTextPopup(const wxString& text, const wxPoint& pos)
|
|
{
|
|
HH_POPUP popup;
|
|
popup.cbStruct = sizeof(popup);
|
|
popup.hinst = (HINSTANCE) wxGetInstance();
|
|
popup.idString = 0 ;
|
|
popup.pt.x = pos.x; popup.pt.y = pos.y;
|
|
popup.clrForeground = (COLORREF)-1;
|
|
popup.clrBackground = (COLORREF)-1;
|
|
popup.rcMargins.top = popup.rcMargins.left = popup.rcMargins.right = popup.rcMargins.bottom = -1;
|
|
popup.pszFont = NULL;
|
|
popup.pszText = (const wxChar*) text;
|
|
|
|
gs_htmlHelp(GetSuitableHWND(this), NULL, HH_DISPLAY_TEXT_POPUP, (DWORD) & popup);
|
|
return true;
|
|
}
|
|
|
|
bool wxCHMHelpController::DisplayBlock(long block)
|
|
{
|
|
return DisplaySection(block);
|
|
}
|
|
|
|
bool wxCHMHelpController::KeywordSearch(const wxString& k,
|
|
wxHelpSearchMode WXUNUSED(mode))
|
|
{
|
|
if (m_helpFile.IsEmpty()) return false;
|
|
|
|
wxString str = GetValidFilename(m_helpFile);
|
|
|
|
HH_AKLINK link;
|
|
link.cbStruct = sizeof(HH_AKLINK) ;
|
|
link.fReserved = FALSE ;
|
|
link.pszKeywords = k.c_str() ;
|
|
link.pszUrl = NULL ;
|
|
link.pszMsgText = NULL ;
|
|
link.pszMsgTitle = NULL ;
|
|
link.pszWindow = NULL ;
|
|
link.fIndexOnFail = TRUE ;
|
|
|
|
gs_htmlHelp(GetSuitableHWND(this), (const wxChar*) str, HH_KEYWORD_LOOKUP, (DWORD)& link);
|
|
return true;
|
|
}
|
|
|
|
bool wxCHMHelpController::Quit()
|
|
{
|
|
gs_htmlHelp(GetSuitableHWND(this), 0, HH_CLOSE_ALL, 0L);
|
|
|
|
return true;
|
|
}
|
|
|
|
// Append extension if necessary.
|
|
wxString wxCHMHelpController::GetValidFilename(const wxString& file) const
|
|
{
|
|
wxString path, name, ext;
|
|
wxSplitPath(file, & path, & name, & ext);
|
|
|
|
wxString fullName;
|
|
if (path.IsEmpty())
|
|
fullName = name + wxT(".chm");
|
|
else if (path.Last() == wxT('\\'))
|
|
fullName = path + name + wxT(".chm");
|
|
else
|
|
fullName = path + wxT("\\") + name + wxT(".chm");
|
|
return fullName;
|
|
}
|
|
|
|
wxCHMHelpController::~wxCHMHelpController()
|
|
{
|
|
UnloadHtmlHelpLibrary();
|
|
}
|
|
|
|
#endif // wxUSE_HELP
|