home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 7 / 07.iso / c / c082_122 / 6.ddi / WEXAMPLE.ZIP / HELPEX.C < prev    next >
Encoding:
C/C++ Source or Header  |  1992-06-10  |  12.9 KB  |  420 lines

  1. /****************************************************************************
  2.  
  3.    PROGRAM:    HelpEx.c
  4.  
  5.    Copyright (c) 1991, 1992 Borland International, Inc.
  6.  
  7.    PURPOSE:    Illustrates calls to WinHelp and context-sensitive help.
  8.                HelpEx loads library MenuHook, which detects F1 keystrokes in
  9.                the HelpEx application menus.
  10.  
  11.    FUNCTIONS:
  12.  
  13.    WinMain() - Calls initialization function, processes message loop.
  14.    InitApplication() - Initializes window data and registers window class.
  15.    InitInstance() - Saves instance handle and creates main window.
  16.    MainWndProc() - Processes window messages.
  17.    About() - Processes messages for "About" dialog box.
  18.    MakeHelpPathName() - Derives path name of help file.
  19.  
  20. ****************************************************************************/
  21.  
  22. #define  STRICT
  23. #include <windows.h>
  24. #include "helpex.h"
  25. #include "helpids.h"
  26.  
  27. HWND       hWnd;               /* Handle to main window */
  28. HINSTANCE  hInst;              /* Handle to instance data*/
  29. BOOL       bHelp = FALSE;      /* Help mode flag; TRUE = "ON"*/
  30. HCURSOR    hHelpCursor;        /* Cursor displayed when in help mode*/
  31. char       szHelpFileName[EXE_NAME_MAX_SIZE+1];    /* Help file name*/
  32. HACCEL     hAccTable;                              /* handle to accelerator table */
  33.  
  34. void MakeHelpPathName(char*);  /* Function deriving help file path */
  35.  
  36.  
  37. /****************************************************************************
  38.  
  39.    FUNCTION:   WinMain(HINSTANCE, HINSTANCE, LPSTR, int)
  40.  
  41.    PURPOSE:    Calls initialization function, processes message loop.
  42.  
  43. ****************************************************************************/
  44. #pragma argsused
  45.  
  46. int PASCAL WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
  47.                    LPSTR lpCmdLine, int nCmdShow)
  48. {
  49.    MSG msg;
  50.  
  51.    if (!hPrevInstance)
  52.        if (!InitApplication(hInstance))
  53.        return (FALSE);
  54.  
  55.    if (!InitInstance(hInstance, nCmdShow))
  56.        return (FALSE);
  57.  
  58.    while (GetMessage(&msg, NULL, NULL, NULL)) {
  59.  
  60.       /* Only translate message if it is not an accelerator message */
  61.       if (!TranslateAccelerator(hWnd, hAccTable, &msg)) {
  62.  
  63.           TranslateMessage(&msg);
  64.           DispatchMessage(&msg);
  65.       }
  66.    }
  67.    return (msg.wParam);
  68. }
  69.  
  70.  
  71. /****************************************************************************
  72.  
  73.    FUNCTION:   InitApplication(HINSTANCE)
  74.  
  75.    PURPOSE:    Initializes window data and registers window class.
  76.  
  77.    RETURNS:    Status of RegisterClass() call.
  78.  
  79. ****************************************************************************/
  80.  
  81. BOOL InitApplication(HINSTANCE hInstance)
  82. {
  83.    WNDCLASS wc;
  84.  
  85.    wc.style = NULL;
  86.    wc.lpfnWndProc = MainWndProc;
  87.    wc.cbClsExtra = 0;
  88.    wc.cbWndExtra = 0;
  89.    wc.hInstance = hInstance;
  90.    wc.hIcon = LoadIcon(NULL, IDI_APPLICATION);
  91.    wc.hCursor = LoadCursor(NULL, IDC_ARROW);
  92.    wc.hbrBackground = GetStockObject(WHITE_BRUSH); 
  93.    wc.lpszMenuName ="HelpexMenu";
  94.    wc.lpszClassName = "HelpexWClass";
  95.  
  96.    return (RegisterClass(&wc));
  97. }
  98.  
  99.  
  100. /****************************************************************************
  101.  
  102.    FUNCTION:   InitInstance(HINSTANCE, int)
  103.  
  104.    PURPOSE:    Saves instance handle in global variable and creates main 
  105.                window.
  106.  
  107.    RETURNS:    Status of CreateWindow() call.
  108.  
  109. ****************************************************************************/
  110.  
  111. BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
  112. {
  113.  
  114.    hInst = hInstance;
  115.                                        
  116.    hAccTable = LoadAccelerators(hInst, "HelpexAcc");
  117.  
  118.    hWnd = CreateWindow(
  119.        "HelpexWClass",
  120.        "Help Example ",
  121.        WS_OVERLAPPEDWINDOW,
  122.        CW_USEDEFAULT,
  123.        CW_USEDEFAULT,
  124.        CW_USEDEFAULT,
  125.        CW_USEDEFAULT,
  126.        NULL,
  127.        NULL,
  128.        hInstance,
  129.        NULL
  130.        );
  131.  
  132.    if (!hWnd)
  133.        return (FALSE);
  134.  
  135.    ShowWindow(hWnd, nCmdShow);
  136.    UpdateWindow(hWnd);
  137.  
  138.    EnableMenuItem(GetSubMenu(GetMenu(hWnd), 1), IDM_CLEAR, MF_ENABLED);
  139.  
  140.    MakeHelpPathName(szHelpFileName);
  141.    hHelpCursor = LoadCursor(hInst,"HelpCursor");
  142.  
  143.    return (TRUE);
  144.  
  145. }
  146.  
  147. /****************************************************************************
  148.  
  149.    FUNCTION:   MainWndProc(HWND, UINT, WORD, LONG)
  150.  
  151.    PURPOSE:    Processes window messages.
  152.  
  153.    MESSAGES:
  154.  
  155.        WM_COMMAND- Application menu item 
  156.        WM_DESTROY- Destroy window
  157.  
  158. ****************************************************************************/
  159.  
  160. LRESULT CALLBACK MainWndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
  161. {
  162.    DLGPROC lpProcAbout;
  163.    DWORD   dwHelpContextId;
  164.    
  165.    switch (message) {
  166.  
  167.        case WM_COMMAND:
  168.            /* Was F1 just pressed in a menu, or are we in help mode */
  169.            /* (Shift-F1)? */
  170.  
  171.            if (bHelp) {
  172.                dwHelpContextId =
  173.                    (wParam == IDM_NEW)    ? (DWORD) HELPID_FILE_NEW     :
  174.                    (wParam == IDM_OPEN)   ? (DWORD) HELPID_FILE_OPEN    :
  175.                    (wParam == IDM_SAVE)   ? (DWORD) HELPID_FILE_SAVE    :
  176.                    (wParam == IDM_SAVEAS) ? (DWORD) HELPID_FILE_SAVE_AS :
  177.                    (wParam == IDM_PRINT)  ? (DWORD) HELPID_FILE_PRINT   :
  178.                    (wParam == IDM_EXIT)   ? (DWORD) HELPID_FILE_EXIT    :
  179.                    (wParam == IDM_UNDO)   ? (DWORD) HELPID_EDIT_UNDO    :
  180.                    (wParam == IDM_CUT)    ? (DWORD) HELPID_EDIT_CUT     :
  181.                    (wParam == IDM_CLEAR)  ? (DWORD) HELPID_EDIT_CLEAR   :
  182.                    (wParam == IDM_COPY)   ? (DWORD) HELPID_EDIT_COPY    :
  183.                    (wParam == IDM_PASTE)  ? (DWORD) HELPID_EDIT_PASTE   :
  184.                                             (DWORD) 0L;
  185.  
  186.                if (!dwHelpContextId)
  187.            {
  188.                    MessageBox( hWnd, "Help not available for Help Menu item",
  189.                    "Help Example", MB_OK                          );
  190.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  191.            }
  192.  
  193.                bHelp = FALSE;
  194.                WinHelp(hWnd,szHelpFileName,HELP_CONTEXT,dwHelpContextId);
  195.                break;
  196.            }
  197.  
  198.            switch (wParam) {
  199.                case IDM_NEW:
  200.                case IDM_OPEN:
  201.                case IDM_SAVE:
  202.                case IDM_SAVEAS:
  203.                case IDM_PRINT:
  204.                case IDM_UNDO:
  205.                case IDM_CUT:
  206.                case IDM_CLEAR:
  207.                case IDM_COPY:
  208.                case IDM_PASTE:
  209.                    MessageBox(hWnd,
  210.                    "Command not implemented",
  211.                    "Help Example",
  212.                    MB_OK);
  213.                    break;
  214.  
  215.                case IDM_EXIT:
  216.                     DestroyWindow(hWnd);
  217.                     break;
  218.  
  219.                case IDM_HELP_INDEX:
  220.                    WinHelp(hWnd,szHelpFileName,HELP_INDEX,0L);
  221.                    break;
  222.  
  223.                case IDM_HELP_KEYBOARD:
  224.            WinHelp(hWnd,szHelpFileName,HELP_KEY,(DWORD)(LPSTR)"keys");
  225.                    break;
  226.  
  227.                case IDM_HELP_HELP:
  228.            WinHelp(hWnd,"WINHELP.HLP",HELP_INDEX,0L);
  229.                    break;
  230.  
  231.                case IDM_ABOUT:
  232.                    lpProcAbout = (DLGPROC)MakeProcInstance((FARPROC)About, hInst);
  233.                    DialogBox(hInst, 
  234.                        "AboutBox", 
  235.                        hWnd, 
  236.                        lpProcAbout);
  237.                    FreeProcInstance((FARPROC)lpProcAbout);
  238.                    break;
  239.  
  240.                default:
  241.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  242.            }
  243.  
  244.            break;
  245.        
  246.        case WM_LBUTTONDOWN:
  247.        if (bHelp)
  248.        {
  249.            bHelp = FALSE;
  250.            WinHelp( hWnd, szHelpFileName, HELP_CONTEXT,
  251.             (DWORD) HELPID_EDIT_WINDOW          );
  252.            break;
  253.        }
  254.  
  255.            return (DefWindowProc(hWnd, message, wParam, lParam));
  256.  
  257.        case WM_NCLBUTTONDOWN:
  258.            /* If we are in help mode (Shift-F1) then display context- */
  259.            /* sensitive help for non-client area. */
  260.  
  261.            if (bHelp) {
  262.                dwHelpContextId =
  263.                    (wParam == HTCAPTION)     ? (DWORD) HELPID_TITLE_BAR     :
  264.                    (wParam == HTREDUCE)      ? (DWORD) HELPID_MINIMIZE_ICON :
  265.                    (wParam == HTZOOM)        ? (DWORD) HELPID_MAXIMIZE_ICON :
  266.                    (wParam == HTSYSMENU)     ? (DWORD) HELPID_SYSTEM_MENU   :
  267.                    (wParam == HTBOTTOM)      ? (DWORD) HELPID_SIZING_BORDER :
  268.                    (wParam == HTBOTTOMLEFT)  ? (DWORD) HELPID_SIZING_BORDER :
  269.                    (wParam == HTBOTTOMRIGHT) ? (DWORD) HELPID_SIZING_BORDER :
  270.                    (wParam == HTTOP)         ? (DWORD) HELPID_SIZING_BORDER :
  271.                    (wParam == HTLEFT)        ? (DWORD) HELPID_SIZING_BORDER :
  272.                    (wParam == HTRIGHT)       ? (DWORD) HELPID_SIZING_BORDER :
  273.                    (wParam == HTTOPLEFT)     ? (DWORD) HELPID_SIZING_BORDER :
  274.                    (wParam == HTTOPRIGHT)    ? (DWORD) HELPID_SIZING_BORDER :
  275.                                                (DWORD) 0L;
  276.  
  277.                if (!((BOOL)dwHelpContextId))
  278.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  279.  
  280.                bHelp = FALSE;
  281.                WinHelp(hWnd,szHelpFileName,HELP_CONTEXT,dwHelpContextId);
  282.                break;
  283.            }
  284.  
  285.            return (DefWindowProc(hWnd, message, wParam, lParam));
  286.  
  287.        case WM_KEYDOWN:
  288.            if (wParam == VK_F1) {
  289.  
  290.                /* If Shift-F1, turn help mode on and set help cursor */ 
  291.  
  292.                if (GetKeyState(VK_SHIFT)<0) {
  293.                    bHelp = TRUE;
  294.                    SetCursor(hHelpCursor);
  295.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  296.                }
  297.  
  298.                /* If F1 without shift, then call up help main index topic */ 
  299.                else {
  300.                    WinHelp(hWnd,szHelpFileName,HELP_INDEX,0L);
  301.                }
  302.            }
  303.  
  304.            else if (wParam == VK_ESCAPE && bHelp) {
  305.  
  306.                /* Escape during help mode: turn help mode off */
  307.                bHelp = FALSE;
  308.                SetCursor((HCURSOR)GetClassWord(hWnd,GCW_HCURSOR));
  309.            }
  310.  
  311.            break;
  312.  
  313.        case WM_SETCURSOR:
  314.            /* In help mode it is necessary to reset the cursor in response */
  315.            /* to every WM_SETCURSOR message.Otherwise, by default, Windows */
  316.            /* will reset the cursor to that of the window class. */
  317.  
  318.            if (bHelp) {
  319.                SetCursor(hHelpCursor);
  320.                break;
  321.            }
  322.            return (DefWindowProc(hWnd, message, wParam, lParam));
  323.  
  324.        case WM_INITMENU:
  325.            if (bHelp) {
  326.                SetCursor(hHelpCursor);
  327.            } 
  328.            return (TRUE);
  329.  
  330.        case WM_ENTERIDLE:
  331.            if ((wParam == MSGF_MENU) && (GetKeyState(VK_F1) & 0x8000)) {
  332.                bHelp = TRUE;
  333.                PostMessage(hWnd, WM_KEYDOWN, VK_RETURN, 0L);
  334.            }
  335.            break;
  336.  
  337.        case WM_DESTROY:
  338.            WinHelp(hWnd,szHelpFileName,HELP_QUIT,0L);
  339.            PostQuitMessage(0);
  340.            break;
  341.  
  342.        default:
  343.            return (DefWindowProc(hWnd, message, wParam, lParam));
  344.    }
  345.  
  346.    return (NULL);
  347. }
  348.  
  349.  
  350. /****************************************************************************
  351.  
  352.    FUNCTION:   About(HWND, UINT, WORD, LONG)
  353.  
  354.    PURPOSE:    Processes messages for "About" dialog box
  355.    
  356.    MESSAGES:
  357.  
  358.        WM_INITDIALOG - Initialize dialog box
  359.        WM_COMMAND- Input received
  360.  
  361. ****************************************************************************/
  362. #pragma argsused
  363.  
  364. BOOL FAR PASCAL About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
  365. {
  366.    switch (message) {
  367.        case WM_INITDIALOG:
  368.            return (TRUE);
  369.  
  370.        case WM_COMMAND:
  371.            if (wParam == IDOK) {
  372.                EndDialog(hDlg, TRUE);
  373.                return (TRUE);
  374.            }
  375.            break;
  376.    }
  377.  
  378.    return (FALSE);
  379. }
  380.  
  381.  
  382. /****************************************************************************
  383.  
  384.    FUNCTION:   MakeHelpPathName
  385.  
  386.    PURPOSE:    HelpEx assumes that the .HLP help file is in the same
  387.                directory as the HelpEx executable.This function derives
  388.                the full path name of the help file from the path of the
  389.                executable.
  390.  
  391. ****************************************************************************/
  392.  
  393. void MakeHelpPathName(char* szFileName)
  394. {
  395.    char *  pcFileName;
  396.    int     nFileNameLen;
  397.  
  398.    nFileNameLen = GetModuleFileName(hInst,szFileName,EXE_NAME_MAX_SIZE);
  399.    pcFileName = szFileName + nFileNameLen;
  400.  
  401.    while (pcFileName > szFileName) {
  402.        if (*pcFileName == '\\' || *pcFileName == ':') {
  403.            *(++pcFileName) = '\0';
  404.            break;
  405.        }
  406.    nFileNameLen--;
  407.    pcFileName--;
  408.    }
  409.  
  410.    if ((nFileNameLen+13) < EXE_NAME_MAX_SIZE) {
  411.        lstrcat(szFileName, "helpex.hlp");
  412.    }
  413.  
  414.    else {
  415.        lstrcat(szFileName, "?");
  416.    }
  417.  
  418.    return;
  419. }
  420.