DOCUMENT:Q173093 26-AUG-1997 [vbwin] TITLE :BUG: Moving .VBP File Can Corrupt References with Long Paths PRODUCT :Microsoft Visual Basic for Windows PROD/VER:WINDOWS:5.0 OPER/SYS:WINDOWS KEYWORDS:vb5all ====================================================================== --------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual Basic Control Creation, Learning, Professional, and Enterprise Editions for Windows, version 5.0 --------------------------------------------------------------------- SYMPTOMS ======== When moving a Visual Basic 5.0 project from one folder to another, you may see corruption to references that include a path longer than approximately 40 characters (such as DAO 3.5) in the project's .vbp file. On the same drive, this problem can occur when one of the folders is at least one level lower in the directory tree structure than the other. This problem does not occur when saving the project to a different folder within the IDE. RESOLUTION ========== Avoid moving .vbp files, or save them through the IDE to their new location using File | Save As. Attempting to edit and correct the corrupt .vbp file in Notepad does not work because the file becomes corrupt again the next time it is saved. 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 ================ Corruption of the .vbp file may occur when the project is moved to a different directory. Steps to Reproduce Behavior --------------------------- 1. Create two new directories as follows: C:\aaaTestThisBug C:\aaaFirstLevel\SecondLevel One of the directories needs to be two or more levels down. 2. Start a new Visual Basic Standard EXE project, Project1. 3. Go to Project | References and add at least one reference whose path is longer than approximately 40 characters (The reference to Microsoft DAO 3.5 Object Library is a good one). 4. Save Project1 to C:\aaaTestThisBug and exit Visual Basic. Using Windows Explorer, move the .vbp, .vbw, and .frm files associated with this project to C:\aaaFirstLevel\SecondLevel. 5. Open the .vbp file in Notepad and note that the all of the paths for the references are still correct. 6. Close Notepad. 7. Open Project1 with Visual Basic. 8. Save and Close Project1. Answer "yes" when prompted to save changes. 9. Examine the .vbp file in Notepad. Note that any reference that includes a path longer than approximately 40 characters is likely to be corrupted. Examples of sections from good and bad .vbp files ------------------------------------------------- DAO 3.5 reference from a good file: Reference=*\G{00025E01-0000-0000-C000-000000000046}#4.0#0#..\Program Files\Common Files\Microsoft Shared\DAO\DAO350.DLL#Microsoft DAO 3.5 Object Library DAO 3.5 reference from a bad file: Reference=*\G{00025E01-0000-0000-C000-000000000046}#4.0#0#..\..\..\Program Files\Common Files\Microsoft Shared\DC:\Program Fi#Microsoft DAO 3.5 Object Library ====================================================================== Keywords : vb5all 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 1997.