使用 Nim 生成用于 C#/VB6 的 DLL
Using Nim to generate a DLL for use in C#/VB6
经过数小时的尝试解决这个问题后,我想知道是否有办法解决这个问题。
我需要能够导出从 VB6 调用的函数(是的,您没看错,不是 VB.NET),但我不知所措。我已经生成了一个应该可以工作的 DLL;它至少在从 C 调用时有效,但仅此而已。
也许一些 Nim 兽医可以引导我朝着正确的方向前进。我将不胜感激。
我绝对不是 Nim 兽医,但这里有一些有用的东西。
从 VB6 应用程序调用 Nim proc。
Nim DLL(使用 nim c 编译 --cpu:i386 --app:lib --nomain):
{.passc:"-m32"}
{.passl:"-m32"}
import winim,os
proc TestFunc(a: cint):cint {.exportc, stdcall, dynlib.} =
echo "function called!"
a + 5
when defined(vcc):
{.emit: "N_LIB_EXPORT N_CDECL(void, NimMain)(void);".}
else:
proc NimMain() {.cdecl, importc.}
proc DllMain(hModule: HINSTANCE, reasonForCall: DWORD, lpReserved: LPVOID): WINBOOL {.exportc, dynlib, stdcall.} =
case reasonForCall:
of DLL_PROCESS_ATTACH:
when defined(vcc):
{.emit: "NimMain();".}
else:
NimMain()
AllocConsole()
discard stdout.reopen("CONOUT$", fmWrite)
discard execShellCmd("chcp 65001")
echo "Hello from Nim Code!"
else:
discard
return TRUE
VB6:
Private Declare Function TestFunc Lib "nim.dll" Alias "TestFunc@4" (ByVal a As Long) As Long
Private Sub Form_Load()
Caption = CStr(TestFunc(5))
End Sub
经过数小时的尝试解决这个问题后,我想知道是否有办法解决这个问题。
我需要能够导出从 VB6 调用的函数(是的,您没看错,不是 VB.NET),但我不知所措。我已经生成了一个应该可以工作的 DLL;它至少在从 C 调用时有效,但仅此而已。
也许一些 Nim 兽医可以引导我朝着正确的方向前进。我将不胜感激。
我绝对不是 Nim 兽医,但这里有一些有用的东西。
从 VB6 应用程序调用 Nim proc。
Nim DLL(使用 nim c 编译 --cpu:i386 --app:lib --nomain):
{.passc:"-m32"}
{.passl:"-m32"}
import winim,os
proc TestFunc(a: cint):cint {.exportc, stdcall, dynlib.} =
echo "function called!"
a + 5
when defined(vcc):
{.emit: "N_LIB_EXPORT N_CDECL(void, NimMain)(void);".}
else:
proc NimMain() {.cdecl, importc.}
proc DllMain(hModule: HINSTANCE, reasonForCall: DWORD, lpReserved: LPVOID): WINBOOL {.exportc, dynlib, stdcall.} =
case reasonForCall:
of DLL_PROCESS_ATTACH:
when defined(vcc):
{.emit: "NimMain();".}
else:
NimMain()
AllocConsole()
discard stdout.reopen("CONOUT$", fmWrite)
discard execShellCmd("chcp 65001")
echo "Hello from Nim Code!"
else:
discard
return TRUE
VB6:
Private Declare Function TestFunc Lib "nim.dll" Alias "TestFunc@4" (ByVal a As Long) As Long
Private Sub Form_Load()
Caption = CStr(TestFunc(5))
End Sub