From 66667dff930ce55ffde547fb9fbede0ae9ee5cd4 Mon Sep 17 00:00:00 2001 From: metagn Date: Sun, 14 Aug 2022 17:04:06 +0300 Subject: [PATCH 1/2] Remove string == nil/nil == string error This was to help migration for `nil` strings being removed, but `nil` strings have been gone for a while now. --- lib/system.nim | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/lib/system.nim b/lib/system.nim index 738666e8da32..2b79fd37e346 100644 --- a/lib/system.nim +++ b/lib/system.nim @@ -3019,17 +3019,6 @@ proc `==`*(x, y: cstring): bool {.magic: "EqCString", noSideEffect, elif x.isNil or y.isNil: result = false else: result = strcmp(x, y) == 0 -when true: # xxx PRTEMP remove - # bug #9149; ensure that 'typeof(nil)' does not match *too* well by using 'typeof(nil) | typeof(nil)', - # especially for converters, see tests/overload/tconverter_to_string.nim - # Eventually we will be able to remove this hack completely. - proc `==`*(x: string; y: typeof(nil) | typeof(nil)): bool {. - error: "'nil' is now invalid for 'string'".} = - discard - proc `==`*(x: typeof(nil) | typeof(nil); y: string): bool {. - error: "'nil' is now invalid for 'string'".} = - discard - template closureScope*(body: untyped): untyped = ## Useful when creating a closure in a loop to capture local loop variables by ## their current iteration values. From 507a675ee9dc58fb2580b3a0324137698bf7d543 Mon Sep 17 00:00:00 2001 From: metagn Date: Sat, 20 Aug 2022 18:38:39 +0300 Subject: [PATCH 2/2] remove isNil too --- lib/system.nim | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/lib/system.nim b/lib/system.nim index 2b79fd37e346..5307bec4f16e 100644 --- a/lib/system.nim +++ b/lib/system.nim @@ -1604,18 +1604,6 @@ proc len*[U: Ordinal; V: Ordinal](x: HSlice[U, V]): int {.noSideEffect, inline.} ## assert((5..2).len == 0) result = max(0, ord(x.b) - ord(x.a) + 1) -when true: # PRTEMP: remove? - proc isNil*[T](x: seq[T]): bool {.noSideEffect, magic: "IsNil", error.} - ## Seqs are no longer nil by default, but set and empty. - ## Check for zero length instead. - ## - ## See also: - ## * `isNil(string) <#isNil,string>`_ - - proc isNil*(x: string): bool {.noSideEffect, magic: "IsNil", error.} - ## See also: - ## * `isNil(seq[T]) <#isNil,seq[T]>`_ - proc isNil*[T](x: ref T): bool {.noSideEffect, magic: "IsNil".} proc isNil*[T](x: ptr T): bool {.noSideEffect, magic: "IsNil".}