diff options
author | Araq <rumpf_a@web.de> | 2014-01-13 02:10:03 +0100 |
---|---|---|
committer | Araq <rumpf_a@web.de> | 2014-01-13 02:10:03 +0100 |
commit | 20b5f31c03fb556ec0aa2428a40adbac004d8987 (patch) | |
tree | 58086941e7d6bb8f480ca1173a95722ada9435b2 /tests/method/tmultim2.nim | |
parent | 51ee524109cf7e3e86c676bc1676063a01bfd979 (diff) | |
download | Nim-20b5f31c03fb556ec0aa2428a40adbac004d8987.tar.gz |
new tester; all tests categorized
Diffstat (limited to 'tests/method/tmultim2.nim')
-rw-r--r-- | tests/method/tmultim2.nim | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/tests/method/tmultim2.nim b/tests/method/tmultim2.nim new file mode 100644 index 000000000..75f652137 --- /dev/null +++ b/tests/method/tmultim2.nim @@ -0,0 +1,36 @@ +discard """ + file: "tmultim2.nim" + output: "collide: unit, thing collide: unit, thing collide: thing, unit" +""" +# Test multi methods + +type + TThing = object {.inheritable.} + TUnit = object of TThing + x: int + TParticle = object of TThing + a, b: int + +method collide(a, b: TThing) {.inline.} = + quit "to override!" + +method collide(a: TThing, b: TUnit) {.inline.} = + write stdout, "collide: thing, unit " + +method collide(a: TUnit, b: TThing) {.inline.} = + write stdout, "collide: unit, thing " + +proc test(a, b: TThing) {.inline.} = + collide(a, b) + +var + a: TThing + b, c: TUnit +collide(b, c) # ambiguous (unit, thing) or (thing, unit)? -> prefer unit, thing! +test(b, c) +collide(a, b) +#OUT collide: unit, thing collide: unit, thing collide: thing, unit + + + + |