123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- #[
- xxx macros tests need to be reorganized to makes sure each API is tested once
- See also:
- tests/macros/tdumpast.nim for treeRepr + friends
- ]#
- import std/macros
- import std/assertions
- block: # hasArgOfName
- macro m(u: untyped): untyped =
- for name in ["s","i","j","k","b","xs","ys"]:
- doAssert hasArgOfName(params u,name)
- doAssert not hasArgOfName(params u,"nonexistent")
- proc p(s: string; i,j,k: int; b: bool; xs,ys: seq[int] = @[]) {.m.} = discard
- block: # bug #17454
- proc f(v: NimNode): string {.raises: [].} = $v
- block: # unpackVarargs
- block:
- proc bar1(a: varargs[int]): string =
- for ai in a: result.add " " & $ai
- proc bar2(a: varargs[int]) =
- let s1 = bar1(a)
- let s2 = unpackVarargs(bar1, a) # `unpackVarargs` makes no difference here
- doAssert s1 == s2
- bar2(1, 2, 3)
- bar2(1)
- bar2()
- block:
- template call1(fun: typed; args: varargs[untyped]): untyped =
- unpackVarargs(fun, args)
- template call2(fun: typed; args: varargs[untyped]): untyped =
- # fun(args) # works except for last case with empty `args`, pending bug #9996
- when varargsLen(args) > 0: fun(args)
- else: fun()
- proc fn1(a = 0, b = 1) = discard (a, b)
- call1(fn1)
- call1(fn1, 10)
- call1(fn1, 10, 11)
- call2(fn1)
- call2(fn1, 10)
- call2(fn1, 10, 11)
- block:
- template call1(fun: typed; args: varargs[typed]): untyped =
- unpackVarargs(fun, args)
- template call2(fun: typed; args: varargs[typed]): untyped =
- # xxx this would give a confusing error message:
- # required type for a: varargs[typed] [varargs] but expression '[10]' is of type: varargs[typed] [varargs]
- when varargsLen(args) > 0: fun(args)
- else: fun()
- macro toString(a: varargs[typed, `$`]): string =
- var msg = genSym(nskVar, "msg")
- result = newStmtList()
- result.add quote do:
- var `msg` = ""
- for ai in a:
- result.add quote do: `msg`.add $`ai`
- result.add quote do: `msg`
- doAssert call1(toString) == ""
- doAssert call1(toString, 10) == "10"
- doAssert call1(toString, 10, 11) == "1011"
- block: # SameType
- type
- A = int
- B = distinct int
- C = object
- Generic[T, Y] = object
- macro isSameType(a, b: typed): untyped =
- newLit(sameType(a, b))
- static:
- assert Generic[int, int].isSameType(Generic[int, int])
- assert Generic[A, string].isSameType(Generic[int, string])
- assert not Generic[A, string].isSameType(Generic[B, string])
- assert not Generic[int, string].isSameType(Generic[int, int])
- assert isSameType(int, A)
- assert isSameType(10, 20)
- assert isSameType("Hello", "world")
- assert not isSameType("Hello", cstring"world")
- assert not isSameType(int, B)
- assert not isSameType(int, Generic[int, int])
- assert not isSameType(C, string)
- assert not isSameType(C, int)
- #[
- # compiler sameType fails for the following, read more in `types.nim`'s `sameTypeAux`.
- type
- D[T] = C
- G[T] = T
- static:
- assert isSameType(D[int], C)
- assert isSameType(D[int], D[float])
- assert isSameType(G[float](1.0), float(1.0))
- assert isSameType(float(1.0), G[float](1.0))
- ]#
- type Tensor[T] = object
- data: T
- macro testTensorInt(x: typed): untyped =
- let
- tensorIntType = getTypeInst(Tensor[int])[1]
- xTyp = x.getTypeInst
-
- newLit(xTyp.sameType(tensorIntType))
- var
- x: Tensor[int]
- x1 = Tensor[float]()
- x2 = Tensor[A]()
- x3 = Tensor[B]()
- static:
- assert testTensorInt(x)
- assert not testTensorInt(x1)
- assert testTensorInt(x2)
- assert not testTensorInt(x3)
- block: # extractDocCommentsAndRunnables
- macro checkRunnables(prc: untyped) =
- let runnables = prc.body.extractDocCommentsAndRunnables()
- doAssert runnables[0][0].eqIdent("runnableExamples")
- macro checkComments(comment: static[string], prc: untyped) =
- let comments = prc.body.extractDocCommentsAndRunnables()
- doAssert comments[0].strVal == comment
-
- proc a() {.checkRunnables.} =
- runnableExamples: discard
- discard
- proc b() {.checkRunnables.} =
- runnableExamples "-d:ssl": discard
- discard
-
- proc c() {.checkComments("Hello world").} =
- ## Hello world
- block: # bug #19020
- type
- foo = object
- template typ(T:typedesc) {.pragma.}
- proc bar() {.typ: foo.} = discard
- static:
- doAssert $bar.getCustomPragmaVal(typ) == "foo"
- doAssert $bar.getCustomPragmaVal(typ) == "foo"
|