diff options
author | Zahary Karadjov <zahary@gmail.com> | 2012-09-13 00:33:01 +0300 |
---|---|---|
committer | Zahary Karadjov <zahary@gmail.com> | 2012-09-13 00:33:01 +0300 |
commit | 9e4254e4de8cecff5c0a8026930ae79b68ca7c61 (patch) | |
tree | d5d2d1c4ef68fd0f2ff18d24067b6edfcd96295c | |
parent | d46ec1cc2246b45a5aa372a7cd57d7f176eb64aa (diff) | |
download | Nim-9e4254e4de8cecff5c0a8026930ae79b68ca7c61.tar.gz |
type trais used to work only on user-defined types. see #202
-rwxr-xr-x | compiler/evals.nim | 3 | ||||
-rw-r--r-- | tests/run/ttypetraits.nim | 16 |
2 files changed, 16 insertions, 3 deletions
diff --git a/compiler/evals.nim b/compiler/evals.nim index bb0e5936d..3f801e123 100755 --- a/compiler/evals.nim +++ b/compiler/evals.nim @@ -864,8 +864,7 @@ proc evalTypeTrait*(n: PNode, context: PSym): PNode = ## XXX: This should be pretty much guaranteed to be true # by the type traits procs' signatures, but until the # code is more mature it doesn't hurt to be extra safe - internalAssert n.sons.len >= 2 and n.sons[1].kind == nkSym and - n.sons[1].sym.typ.kind == tyTypeDesc + internalAssert n.sons.len >= 2 and n.sons[1].kind == nkSym let typ = n.sons[1].sym.typ.skipTypes({tyTypeDesc}) case n.sons[0].sym.name.s.normalize diff --git a/tests/run/ttypetraits.nim b/tests/run/ttypetraits.nim index 5b683bef0..cba610871 100644 --- a/tests/run/ttypetraits.nim +++ b/tests/run/ttypetraits.nim @@ -1,10 +1,11 @@ discard """ msg: "int\nstring\nTBar[int]" - output: "int\nstring\nTBar[int]" + output: "int\nstring\nTBar[int]\nint\nrange 0..2" """ import typetraits +# simple case of type trait usage inside/outside of static blocks proc foo(x) = static: var t = type(x) @@ -22,3 +23,16 @@ foo 10 foo "test" foo bar +# generic params on user types work too +proc foo2[T](x: TBar[T]) = + echo T.name + +foo2 bar + +# less usual generic params on built-in types +var arr: array[0..2, int] = [1, 2, 3] + +proc foo3[R, T](x: array[R, T]) = + echo name(R) + +foo3 arr |