Declare statements that include PtrSafe work correctly in the VBA7 development environment on both 32-bit and 64-bit platforms. The PtrSafe keyword asserts that a Declare statement is safe to run in 64-bit versions of Office.ĭeclare statements with the PtrSafe keyword is the recommended syntax. Implicit conversions of LongLong to smaller integrals are not allowed. Conversion functions must be used to explicitly assign LongLong (including LongPtr on 64-bit platforms) to smaller integral types. The LongLong data type is a signed 64-bit integer that is only available on 64-bit versions of Office. The actual data type that LongPtr resolves to depends on the version of Office that it is running in LongPtr resolves to Long in 32-bit versions of Office, and LongPtr resolves to LongLong in 64-bit versions of Office. VBA now includes the variable type alias LongPtr. Three important additions are the LongPtr type alias, the LongLong data type, and the PtrSafe keyword. The table at the bottom of this document summarizes the new VBA language features.
MICROSOFT VISUAL BASIC FOR APPLICATIONS WINDOW CODE
To address this problem and enable VBA code to work correctly in both 32-bit and 64-bit environments, several language features have been added to VBA. This can result in memory overruns, unexpected results in your code, and possible application failure. The problem with running legacy VBA code in 64-bit Office is that trying to load 64-bits into a 32-bit data type truncates the 64-bit quantity.
You only need to modify VBA code if it runs in the 64-bit version of Microsoft Office.