DOCUMENT:Q190197 07-AUG-1998 [vbwin] TITLE :BUG: User Defined Type Not Defined Using Binary Compatibility PRODUCT :Microsoft Visual Basic for Windows PROD/VER:WINDOWS:5.0 OPER/SYS:WINDOWS KEYWORDS: ====================================================================== --------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual Basic for Windows Learning, Professional, and Enterprise Editions, version 6.0 - Microsoft Visual Basic Professional and Enterprise Editions for Windows, version 5.0 --------------------------------------------------------------------- SYMPTOMS ======== When compiling an ActiveX DLL or ActiveX EXE with Binary Compatibility, the following error occurs: Compile Error : User defined type not defined RESOLUTION ========== Turn off Binary Compatibility and compile the project. Visual Basic will highlight the line of code that contains the User Defined Type that is not defined. After resolving the problem, Binary Compatibility can be turned back on. STATUS ====== Microsoft has confirmed this to be a bug in the Microsoft products listed at the beginning of this article. We are researching this bug and will post new information here in the Microsoft Knowledge Base as it becomes available. MORE INFORMATION ================ Steps to Reproduce ------------------ 1. Create a new ActiveX DLL project in Microsoft Visual Basic. Class1 is created by default. 2. Paste the following code into Class1: Option Explicit Public Enum Colors Red Green Blue End Enum Public Sub ChangeColor(NewColor As Colors) End Sub 3. On the File menu, click Make Project1.dll. 4. On the Project menu, click Project1 Properties, and then click the Component tab. 5. In the Version Compatibility area, click Binary Compatibility, and then click OK. 6. Comment out the Enum declaration in Class1. 7. On the File menu, click Make Project1.dll. Click OK when asked to replace the current file. 8. Visual Basic will display a dialog warning about breaking compatibility. For this demonstration, choose the option that will break compatibility. NOTE: When Visual Basic warns about breaking compatibility, the Enum definition that was undefined was shown. The User Defined Type that raises this error will not always be identified by Visual Basic. 9. Visual Basic will display the following error: User Defined Type Not Defined 10. On the Project menu, click Project1 Properties, then click the Component tab. 11. In the Version Compatibility area, click to No Compatibility. 12. On the File menu, click Make Project1.dll. Click OK when asked to replace the current file. Note that Visual Basic will highlight the User Defined Type that is causing the error. Additional query words: kbDSupport kbdss kbVBp500bug kbVBp600bug kbCompiler kbVBp ====================================================================== Version : WINDOWS:5.0 Platform : WINDOWS Issue type : kbbug ============================================================================= 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 1998.