123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- discard """
- disabled: "openbsd"
- disabled: "netbsd"
- output: '''
- fastcall_proc implementation #1 10
- 11
- fastcall_proc implementation #2 20
- 22
- fastcall_proc implementation #2 20
- 22
- fastcall_proc implementation #3 30
- 33
- fastcall_proc implementation #3 30
- 33
- fastcall_proc implementation #3 30
- 33
- fastcall_proc implementation #3 40
- 43
- cdecl_proc implementation #1 10
- 11
- cdecl_proc implementation #2 20
- 22
- cdecl_proc implementation #2 20
- 22
- cdecl_proc implementation #3 30
- 33
- cdecl_proc implementation #3 30
- 33
- cdecl_proc implementation #3 30
- 33
- cdecl_proc implementation #3 40
- 43
- stdcall_proc implementation #1 10
- 11
- stdcall_proc implementation #2 20
- 22
- stdcall_proc implementation #2 20
- 22
- stdcall_proc implementation #3 30
- 33
- stdcall_proc implementation #3 30
- 33
- stdcall_proc implementation #3 30
- 33
- stdcall_proc implementation #3 40
- 43
- noconv_proc implementation #1 10
- 11
- noconv_proc implementation #2 20
- 22
- noconv_proc implementation #2 20
- 22
- noconv_proc implementation #3 30
- 33
- noconv_proc implementation #3 30
- 33
- noconv_proc implementation #3 30
- 33
- noconv_proc implementation #3 40
- 43
- inline_proc implementation #1 10
- 11
- inline_proc implementation #2 20
- 22
- inline_proc implementation #2 20
- 22
- inline_proc implementation #3 30
- 33
- inline_proc implementation #3 30
- 33
- inline_proc implementation #3 30
- 33
- inline_proc implementation #3 40
- 43
- '''
- """
- import macros
- macro carryOutTests(callingConv: untyped): untyped =
- let
- procName = $callingConv & "_proc"
- globalName = $callingConv & "_global"
- callingConv = callingConv
- p1 = ident(procName & "1")
- p2 = ident(procName & "2")
- p3 = ident(procName & "3")
- g1 = ident(globalName & "1")
- g2 = ident(globalName & "2")
- result = quote do:
- var `g1`: pointer = nil
- if hcrRegisterGlobal("dummy_module", `globalName`, sizeof(int), nil, addr `g1`):
- cast[ptr int](`g1`)[] = 10
- var `g2`: pointer = nil
- if hcrRegisterGlobal("dummy_module", `globalName`, sizeof(int), nil, addr `g2`):
- cast[ptr int](`g2`)[] = 20
- doAssert `g1` == `g2` and cast[ptr int](`g1`)[] == 10
- type
- F = proc (x: int): int {.placeholder.}
- proc `p1`(x: int): int {.placeholder.}=
- echo `procName`, " implementation #1 ", x
- return x + 1
- let fp1 = cast[F](hcrRegisterProc("dummy_module", `procName`, cast[pointer](`p1`)))
- echo fp1(10)
- proc `p2`(x: int): int {.placeholder.} =
- echo `procName`, " implementation #2 ", x
- return x + 2
- let fp2 = cast[F](hcrRegisterProc("dummy_module", `procName`, cast[pointer](`p2`)))
- echo fp1(20)
- echo fp2(20)
- proc `p3`(x: int): int {.placeholder.} =
- echo `procName`, " implementation #3 ", x
- return x + 3
- let fp3 = cast[F](hcrRegisterProc("dummy_module", `procName`, cast[pointer](`p3`)))
- echo fp1(30)
- echo fp2(30)
- echo fp3(30)
- let fp4 = cast[F](hcrGetProc("dummy_module", `procName`))
- echo fp4(40)
- proc replacePlaceholderPragmas(n: NimNode) =
- if n.kind == nnkPragma:
- n[0] = callingConv
- else:
- for i in 0 ..< n.len:
- replacePlaceholderPragmas n[i]
- replacePlaceholderPragmas result
- # echo result.treeRepr
- hcrAddModule("dummy_module")
- carryOutTests fastcall
- carryOutTests cdecl
- carryOutTests stdcall
- carryOutTests noconv
- carryOutTests inline
|