|
|
//----------------------------------------------------------------------------
//
// Help support.
//
// Copyright (C) Microsoft Corporation, 2000-2002.
//
//----------------------------------------------------------------------------
#include "main.h"
#include <htmlhelp.h>
#include "cerhelp.h"
//#include "cmnutil.hpp"
//#include "dhhelp.h"
TCHAR g_HelpFileName[MAX_PATH];
void MakeHelpFileName() { TCHAR *Tmp = NULL;
//
// Get the file name for the base module.
//
if (GetModuleFileName(GetModuleHandle(NULL), g_HelpFileName, sizeof g_HelpFileName / sizeof g_HelpFileName[0])) { // Remove the executable name.
Tmp = g_HelpFileName + _tcslen(g_HelpFileName); if (Tmp != g_HelpFileName) { --Tmp; } while ( (*Tmp != NULL) && (*Tmp != _T('\\')) && Tmp != g_HelpFileName) { --Tmp; }
}
if ( (Tmp == NULL) || (Tmp == g_HelpFileName)) { // Error. Use the current directory.
Tmp = g_HelpFileName; *Tmp++ = _T('.'); }
*Tmp = 0;
if (StringCbCat(g_HelpFileName,sizeof g_HelpFileName, _T("\\")) != S_OK) { goto ERRORS; } //CatString(g_HelpFileName, "\\", DIMA(g_HelpFileName));
//CatString(g_HelpFileName, File, DIMA(g_HelpFileName));
if( StringCbCat(g_HelpFileName,sizeof g_HelpFileName, _T("CerHelp.chm")) != S_OK) { goto ERRORS; } ERRORS: ; }
/*** OpenHelpTopic - opens the .chm and selects the specified topic
* * Purpose: * This opens the Help File and displays the specified page. * (This help file's name is stored as g_HelpFileName, but * this string will presumably always be "debugger.chm".) * If the .chm has already been opened for context-sensitive * help, the already-existing .chm will be used. * * This function should be called when you know exactly what * page is needed -- for instance, if a "Help" button is pressed. * * Input: * PageConstant -- this is one of the topic constants defined * in the header file generated when the .chm * is built -- these constants will always * be of the form "help_topic_xxxxx" * * Returns: * 0 - debugger.chm opened and page displayed correctly * 1 - debugger.chm opened, but specified page not found * 2 - debugger.chm not opened (probably the file wasn't found) * * Exceptions: * None * *************************************************************************/
ULONG OpenHelpTopic(ULONG PageConstant) { HWND helpfileHwnd; HWND returnedHwnd;
// If we knew we were in WinDbg, we could use WinDbg's HWND,
// but we could be in a console debugger.
helpfileHwnd = GetDesktopWindow();
// Make "Contents" the active panel in debugger.chm
returnedHwnd = HtmlHelp(helpfileHwnd, g_HelpFileName, HH_DISPLAY_TOC, 0); if (returnedHwnd == NULL) { return HELP_FAILURE; }
// Select the proper page
/* returnedHwnd =
HtmlHelp(helpfileHwnd, g_HelpFileName, HH_HELP_CONTEXT, PageConstant); if (returnedHwnd == NULL) { return HELP_NO_SUCH_PAGE; } */ return HELP_SUCCESS; }
/*** OpenHelpIndex - opens the .chm and searches for the specified text
* * Purpose: * This opens the Help File and looks up the specified text in * the Index. (This help file's name is stored as g_HelpFileName, * but this string will presumably always be "debugger.chm".) * If the .chm has already been opened for context-sensitive * help, the already-existing .chm will be used. * * This function should be called when you don't know exactly * which page is needed -- for instance, if someone types * "help bp" or "help breakpoints" in the Command window. * * Input: * IndexText -- any text string (even ""); this string will * appear in the Index panel of the .chm * * Returns: * 0 - debugger.chm opened and index search displayed correctly * 2 - debugger.chm not opened (probably the file wasn't found) * * Exceptions: * None * *************************************************************************/
ULONG OpenHelpIndex(PCSTR IndexText) { HWND helpfileHwnd; HWND returnedHwnd;
// If we knew we were in WinDbg, we could use WinDbg's HWND,
// but we could be in a console debugger.
helpfileHwnd = GetDesktopWindow();
// Select the Index panel and clip IndexText into it.
returnedHwnd = HtmlHelp(helpfileHwnd, g_HelpFileName, HH_DISPLAY_INDEX, (DWORD_PTR)IndexText); if (returnedHwnd == NULL) { return HELP_FAILURE; } return HELP_SUCCESS; }
ULONG OpenHelpSearch(PCSTR SearchText) { HWND helpfileHwnd; HWND returnedHwnd; HH_FTS_QUERY Query;
// If we knew we were in WinDbg, we could use WinDbg's HWND,
// but we could be in a console debugger.
helpfileHwnd = GetDesktopWindow();
// Select the Search panel.
ZeroMemory(&Query, sizeof(Query)); Query.cbStruct = sizeof(Query); Query.pszSearchQuery = SearchText; returnedHwnd = HtmlHelp(helpfileHwnd, g_HelpFileName, HH_DISPLAY_SEARCH, (DWORD_PTR)&Query); if (returnedHwnd == NULL) { return HELP_FAILURE; } return HELP_SUCCESS; }
ULONG OpenHelpKeyword(PCSTR Keyword, BOOL ShowErrorPopup) { HWND helpfileHwnd; HWND returnedHwnd; HH_AKLINK helpfileLink;
helpfileLink.cbStruct = sizeof(helpfileLink); helpfileLink.fReserved = FALSE; helpfileLink.pszKeywords = Keyword; helpfileLink.pszUrl = NULL;
// If ShowErrorPopup is TRUE, then entering an invalid keyword will cause
// an error message to be displayed. If FALSE, it will cause the .chm to
// display the Index tab, and the keyword will be entered into the index
// box, just as with OpenHelpIndex.
if (ShowErrorPopup) { helpfileLink.pszMsgText = "The text you entered is not in the index of this help file."; helpfileLink.pszMsgTitle = "HTML Help Error"; helpfileLink.pszWindow = NULL; helpfileLink.fIndexOnFail = FALSE; } else { helpfileLink.pszMsgText = NULL; helpfileLink.pszMsgTitle = NULL; helpfileLink.pszWindow = NULL; helpfileLink.fIndexOnFail = TRUE; }
// If we knew we were in WinDbg, we could use WinDbg's HWND,
// but we could be in a console debugger.
helpfileHwnd = GetDesktopWindow();
// Select the Index panel and clip IndexText into it.
returnedHwnd = HtmlHelp(helpfileHwnd, g_HelpFileName, HH_KEYWORD_LOOKUP, (DWORD_PTR)&helpfileLink); if (returnedHwnd == NULL) { return HELP_NO_SUCH_PAGE; } return HELP_SUCCESS; }
BOOL SpawnHelp(ULONG Topic) { CHAR StartHelpCommand[MAX_PATH + 32]; PROCESS_INFORMATION ProcInfo = {0}; STARTUPINFO SI = {0};
// Start help with the given arguments.
if(StringCbPrintf(StartHelpCommand, sizeof StartHelpCommand,_T("hh.exe -mapid %d "), Topic) != S_OK) { goto ERRORS; } // CatString(StartHelpCommand, g_HelpFileName, DIMA(StartHelpCommand));
if(StringCbCat(StartHelpCommand, sizeof StartHelpCommand, g_HelpFileName) != S_OK) { goto ERRORS; } return CreateProcess(NULL, StartHelpCommand, NULL, NULL, FALSE, CREATE_BREAKAWAY_FROM_JOB, NULL, NULL, &SI, &ProcInfo); ERRORS: return FALSE; }
|