Skip to content

Commit

Permalink
fixes #8568
Browse files Browse the repository at this point in the history
  • Loading branch information
Araq committed May 22, 2019
1 parent 57bc8d7 commit 8f9f600
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 4 deletions.
1 change: 1 addition & 0 deletions compiler/semexprs.nim
Original file line number Diff line number Diff line change
Expand Up @@ -1473,6 +1473,7 @@ proc semSubscript(c: PContext, n: PNode, flags: TExprFlags): PNode =
# type parameters: partial generic specialization
n.sons[0] = semSymGenericInstantiation(c, n.sons[0], s)
result = explicitGenericInstantiation(c, n, s)
n.sons[0] = result
of skMacro, skTemplate:
if efInCall in flags:
# We are processing macroOrTmpl[] in macroOrTmpl[](...) call.
Expand Down
11 changes: 7 additions & 4 deletions compiler/sigmatch.nim
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,9 @@ proc copyCandidate(a: var TCandidate, b: TCandidate) =
copyIdTable(a.bindings, b.bindings)

proc sumGeneric(t: PType): int =
# count the "genericness" so that Foo[Foo[T]] has the value 3
# and Foo[T] has the value 2 so that we know Foo[Foo[T]] is more
# specific than Foo[T].
var t = t
var isvar = 1
while true:
Expand All @@ -202,9 +205,9 @@ proc sumGeneric(t: PType): int =
of tyOr:
var maxBranch = 0
for branch in t.sons:
let branchSum = branch.sumGeneric
let branchSum = sumGeneric(branch)
if branchSum > maxBranch: maxBranch = branchSum
inc result, maxBranch + 1
inc result, maxBranch
break
of tyVar:
t = t.sons[0]
Expand All @@ -218,10 +221,10 @@ proc sumGeneric(t: PType): int =
result += ord(t.kind in {tyGenericInvocation, tyAnd})
for i in 0 ..< t.len:
if t.sons[i] != nil:
result += t.sons[i].sumGeneric
result += sumGeneric(t.sons[i])
break
of tyStatic:
return t.sons[0].sumGeneric + 1
return sumGeneric(t.sons[0]) + 1
of tyGenericParam, tyUntyped, tyTyped: break
of tyAlias, tySink: t = t.lastSon
of tyBool, tyChar, tyEnum, tyObject, tyPointer,
Expand Down
18 changes: 18 additions & 0 deletions tests/overload/tor_isnt_better.nim
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
discard """
errormsg: "ambiguous call;"
line: 16
"""

# bug #8568

type
D[T] = object
E[T] = object

proc g(a: D|E): string = "foo D|E"
proc g(a: D): string = "foo D"

proc test() =
let x = g D[int]()

test()
23 changes: 23 additions & 0 deletions tests/overload/toverload_various.nim
Original file line number Diff line number Diff line change
Expand Up @@ -174,3 +174,26 @@ block tstaticoverload:
foo("literal")
foo("constant" & " " & "folding")
foo(staticString("static string"))

# bug #8568 (2)

proc goo(a: int): string = "int"
proc goo(a: static[int]): string = "static int"
proc goo(a: var int): string = "var int"
proc goo[T: int](a: T): string = "T: int"
#proc goo[T](a: T): string = "nur T"

const tmp1 = 1
let tmp2 = 1
var tmp3 = 1

doAssert goo(1) == "static int"
doAssert goo(tmp1) == "static int"
doAssert goo(tmp2) == "int"
doAssert goo(tmp3) == "var int"

doAssert goo[int](1) == "T: int"

doAssert goo[int](tmp1) == "T: int"
doAssert goo[int](tmp2) == "T: int"
doAssert goo[int](tmp3) == "T: int"

0 comments on commit 8f9f600

Please sign in to comment.