I have the following issue when trying to create a DLL in C++ and using it in Excel. When the argument reaches the C++ function, the value it holds changes (regardless of what it was in Excel). I am guessing somewhere it "drops", but I haven't been able to figure it out.
Here is the code:
Source.cpp
extern "C" double __stdcall my_double(double A)
{
return 2.0 * A;
}
Source.def
LIBRARY
EXPORTS
my_double
VBA Code
Declare PtrSafe Function my_double Lib "C:\MyDir\Example.dll" (ByVal A As Double) As Double
Then when I call my_double
from Excel, it always returns 0.0.
I attached a debug point to the function, and I can see that the value is indeed 0 when it reaches the cpp function. Any tips on how to debug this issue would be greatly appreciated!
Things I have tried so far without success:
ByVal
, ByRef
and using neither.int
instead of double
.DUMPBIN
in the DLL file I created, and it looks OKExcel will struggle to use a function declared directly from a dll entry point as it doesn't know the types of the parameters (and other things, eg how to manage the memory of the return value). The OP's method from the tutorial may have worked in the past, but not any more it seems.
Creating a VBA user-defined function (UDF) wrapper gets around this, as Excel knows how to handle and marshal parameters in this case:
Private Declare PtrSafe Function my_double Lib "somePath\DllForExcel.dll" (ByVal A As Double) As Double
Public Function MyDouble(d As Double) As Double
MyDouble = my_double(d)
End Function
Use the MyDouble()
function in the spreadsheet.
The other solution is to go down the route of creating a compiled Xll (often using the Excel SDK), which has entry points to register functions and their parameters, as well as managing memory allocations.