mirror of
https://github.com/nim-lang/Nim.git
synced 2025-12-28 17:04:41 +00:00
Relax the restrictions on the index types (#9412)
This commit is contained in:
@@ -1357,28 +1357,23 @@ proc semSubscript(c: PContext, n: PNode, flags: TExprFlags): PNode =
|
||||
arr = arr.base
|
||||
|
||||
case arr.kind
|
||||
of tyArray, tyOpenArray, tyVarargs, tySequence, tyString,
|
||||
tyCString:
|
||||
of tyArray, tyOpenArray, tyVarargs, tySequence, tyString, tyCString,
|
||||
tyUncheckedArray:
|
||||
if n.len != 2: return nil
|
||||
n.sons[0] = makeDeref(n.sons[0])
|
||||
for i in countup(1, sonsLen(n) - 1):
|
||||
n.sons[i] = semExprWithType(c, n.sons[i],
|
||||
flags*{efInTypeof, efDetermineType})
|
||||
var indexType = if arr.kind == tyArray: arr.sons[0] else: getSysType(c.graph, n.info, tyInt)
|
||||
var arg = indexTypesMatch(c, indexType, n.sons[1].typ, n.sons[1])
|
||||
if arg != nil:
|
||||
n.sons[1] = arg
|
||||
result = n
|
||||
result.typ = elemType(arr)
|
||||
#GlobalError(n.info, errIndexTypesDoNotMatch)
|
||||
of tyUncheckedArray:
|
||||
if n.len != 2: return nil
|
||||
n.sons[0] = makeDeref(n.sons[0])
|
||||
for i in countup(1, sonsLen(n) - 1):
|
||||
n.sons[i] = semExprWithType(c, n.sons[i],
|
||||
flags*{efInTypeof, efDetermineType})
|
||||
# index into unchecked array must be some integer type:
|
||||
if n.sons[1].typ.skipTypes(abstractRange-{tyDistinct}).kind in
|
||||
# Arrays index type is dictated by the range's type
|
||||
if arr.kind == tyArray:
|
||||
var indexType = arr.sons[0]
|
||||
var arg = indexTypesMatch(c, indexType, n.sons[1].typ, n.sons[1])
|
||||
if arg != nil:
|
||||
n.sons[1] = arg
|
||||
result = n
|
||||
result.typ = elemType(arr)
|
||||
# Other types have a bit more of leeway
|
||||
elif n.sons[1].typ.skipTypes(abstractRange-{tyDistinct}).kind in
|
||||
{tyInt..tyInt64, tyUInt..tyUInt64}:
|
||||
result = n
|
||||
result.typ = elemType(arr)
|
||||
|
||||
@@ -533,6 +533,9 @@ block t7818:
|
||||
doAssert(testOpenArray(@[u.addr, v.addr, w.addr]) == "123")
|
||||
doAssert(testOpenArray(@[w.addr, u.addr, v.addr]) == "312")
|
||||
|
||||
# regression regarding unchecked array indexing:
|
||||
proc foo(x: ptr UncheckedArray[int]; idx: uint64) =
|
||||
echo x[idx]
|
||||
block trelaxedindextyp:
|
||||
# any integral type is allowed as index
|
||||
proc foo(x: ptr UncheckedArray[int]; idx: uint64) = echo x[idx]
|
||||
proc foo(x: seq[int]; idx: uint64) = echo x[idx]
|
||||
proc foo(x: string|cstring; idx: uint64) = echo x[idx]
|
||||
proc foo(x: openArray[int]; idx: uint64) = echo x[idx]
|
||||
|
||||
Reference in New Issue
Block a user