DOCUMENT:Q244140 06-JUN-2002 [vbwin] TITLE :BUG: Visual Basic Application Using HtmlHelp API Crashes PRODUCT :Microsoft Visual Basic for Windows PROD/VER::5.0,6.0 OPER/SYS: KEYWORDS:kbHTMLHelp kbVBp kbVBp500bug kbVBp600bug kbIDEProject kbGrpDSVB kbDSupport ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual Basic Learning Edition for Windows, versions 5.0, 6.0 - Microsoft Visual Basic Professional Edition for Windows, versions 5.0, 6.0 - Microsoft Visual Basic Enterprise Edition for Windows, versions 5.0, 6.0 ------------------------------------------------------------------------------- SYMPTOMS ======== A Visual Basic application that is running in the IDE uses the HtmlHelp function to display a Help window. When the calling form is closed or the project is stopped, a fatal error occurs. Under Microsoft Windows 95 and Microsoft Windows 98, the Visual Basic design environment shuts down with no message. Under Microsoft Windows NT, an access violation occurs. Depending on the operating system, an IPF or access violation occurs in a compiled program. These problems do not occur on Windows 2000. STATUS ====== Microsoft has confirmed this to be a bug in the Microsoft products listed at the beginning of this article. MORE INFORMATION ================ Steps to Reproduce Behavior --------------------------- 1. Start a new Visual Basic Standard EXE project. Form1 is created by default. 2. Add a CommandButton to Form1. 3. Add the following code to the General Declarations section of Form1: Option Explicit Private Declare Function HtmlHelp Lib "hhctrl.ocx" _ Alias "HtmlHelpA" _ (ByVal hwndCaller As Long, _ ByVal pszFile As String, _ ByVal uCommand As Long, _ ByVal dwData As Long) _ As Long Private Const HH_DISPLAY_TOPIC = &H0 Private Const HH_CLOSE_ALL = &H12 Private Sub Command1_Click() Call HtmlHelp(Me.hWnd, "IEXPLORE.CHM", _ HH_DISPLAY_TOPIC, 0) End Sub Private Sub Form_Unload(Cancel As Integer) ' Call HtmlHelp(Me.hWnd, "", HH_CLOSE_ALL, 0) End Sub 4. Run the project, and click Command1. 5. On Windows 95 and 98, Visual Basic closes. On Windows NT, you should see an access violation. If you build an executable, the application crashes when you close the form. WORKAROUND ---------- Uncomment symbol the line of code in the Form_Unload event, and run the application again. The problem will no longer occur. NOTE: This problem does not occur on Windows 2000 or Windows XP. Additional query words: ====================================================================== Keywords : kbHTMLHelp kbVBp kbVBp500bug kbVBp600bug kbIDEProject kbGrpDSVB kbDSupport Technology : kbVBSearch kbAudDeveloper kbZNotKeyword6 kbZNotKeyword2 kbVB500Search kbVB600Search kbVB500 kbVB600 Version : :5.0,6.0 Issue type : kbbug Solution Type : kbpending ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2002.