How can I get this 8 year old VBA 64-bit compiler bug fixed?
data:image/s3,"s3://crabby-images/c6c0f/c6c0fc03e74fd850a30ac781fe5989c153a30d7b" alt="Matheus Mello"
data:image/s3,"s3://crabby-images/8a0d2/8a0d226f31241847efba915128534d47e94935ac" alt="Cover Image for How can I get this 8 year old VBA 64-bit compiler bug fixed?"
data:image/s3,"s3://crabby-images/c6c0f/c6c0fc03e74fd850a30ac781fe5989c153a30d7b" alt="Matheus Mello"
š Title: How to Fix the 8-Year-Old VBA 64-Bit Compiler Bug in Microsoft Office
š Hey there, fellow VBA enthusiasts! š Today, I want to address a long-standing issue that has been bugging many developers like us for years: the infamous 8-year-old VBA 64-bit compiler bug in Microsoft Office. š±š„ Don't worry, though! I've got some easy solutions that can help you fix this issue. So, let's dive right in and solve this bug together! šŖš§
Understanding the Bug š
The bug manifests itself when using a 64-bit VBA host, such as Access 365 or Excel 2016, and creating a class module with a Class_Terminate()
sub. The problem arises when evaluating conditions inside an IF
statement or a WHILE
loop. The incorrect evaluation causes unexpected behavior and incorrect results. š«
Reproducing the Bug š
To see the bug in action, follow these steps:
Create a class module named
SomeClass
with the following code:Private Sub Class_Terminate() End Sub
Create a module named
Test
with the following code:Function ReturnFalse(o As Object) As Boolean ReturnFalse = False End Function Sub Test() Debug.Print ReturnFalse(New SomeClass) If ReturnFalse(New SomeClass) Then Debug.Print True Else Debug.Print False End If End Sub
When running the Test
subroutine, you'll notice that in a 32-bit VBA host, the expected output is:
False
False
But in a 64-bit VBA host, it outputs:
False
True
The Call to Action šš¬
Now that you've experienced the bug firsthand, it's time to take action! Here are some steps you can follow to help get this bug fixed:
Report the Bug: Visit the Microsoft Office support forum or use the Smile button in Excel to report the bug directly to Microsoft. Here are some helpful links that can guide you:
Engage with the Community: Join discussions on platforms like Stack Overflow or uservoice.com. Upvote and contribute to existing posts that discuss the bug. Here are some active threads to get you started:
Spread the Word: Share this blog post on social media, forums, or with fellow VBA enthusiasts to raise awareness about the bug. The more attention it gets, the higher the chances of getting it fixed.
šØ Let's come together as a community and make a difference by ensuring that this long-standing bug gets the attention it deserves! Together, we can help Microsoft address and fix this issue, empowering developers worldwide. ššŖ
āØ Keep coding, stay curious, and never stop exploring new possibilities with VBA! šš©āš»šØāš»