5.1 KiB
v2.2.0 - yyyy-mm-dd
Changes affecting backward compatibility
-
-d:nimStrictDeletebecomes the default. An index error is produced when the index passed tosystem.deletewas out of bounds. Use-d:nimAuditDeleteto mimic the old behavior for backwards compatibility. -
The default user-agent in
std/httpclienthas been changed toNim-httpclient/<version>instead ofNim httpclient/<version>which was incorrect according to the HTTP spec. -
Methods now support implementations based on a VTable by using
--experimental:vtables. Methods are then confined to be in the same module where their type has been defined. -
With
-d:nimPreviewNonVarDestructor, non-var destructors become the default. -
A bug where tuple unpacking assignment with a longer tuple on the RHS than the LHS was allowed has been fixed, i.e. code like:
var a, b: int (a, b) = (1, 2, 3, 4)will no longer compile.
-
internalNewis removed from system, usenewinstead. -
bindMethodinstd/jsffiis deprecated, don't use it with closures. -
JS backend now supports lambda lifting for closures. Use
--legacy:jsNoLambdaLiftingto emulate old behavior. -
ownerinstd/macrosis deprecated.
Standard library additions and changes
- Changed
std/osfiles.copyFileto allow to specifybufferSizeinstead of a hardcoded one. - Changed
std/osfiles.copyFileto usePOSIX_FADV_SEQUENTIALhints for kernel-level aggressive sequential read-aheads. std/htmlparserhas been moved to a nimble package, usenimbleoratlasto install it.
- Added
newStringUninitto system, which creates a new string of lengthlenlikenewStringbut with uninitialized content. - Added
setLenUninitto system, which doesn't initialize slots when enlarging a sequence. - Added
hasDefaultValuetostd/typetraitsto check if a type has a valid default value. - Added Viewport API for the JavaScript targets in the
dommodule. - Added
toSinglyLinkedRingandtoDoublyLinkedRingtostd/liststo convert fromopenArrays. - ORC: To be enabled via
nimOrcStatsthere is a new API calledGC_orcStatsthat can be used to query how many objects the cyclic collector did free. If the number is zero that is a strong indicator that you can use--mm:arcinstead of--mm:orc. - A
$template is provided forPathinstd/paths. std/hashes.hash(x:string)changed to produce a 64-bit stringHash(based on Google's Farm Hash) which is also often faster than the present one. DefinenimStringHash2to get the old values back.--jsbigint=offmode always only produces the old values. This may impact your automated tests if they depend on hash order in some obvious or indirect way. UsingsortedorOrderedTableis often an easy workaround.
- Deprecates
system.newSeqUninitialized, which is replaced bynewSeqUninit.
Language changes
-
noInitcan be used in types and fields to disable member initializers in the C++ backend. -
C++ custom constructors initializers see https://nim-lang.org/docs/manual_experimental.htm#constructor-initializer
-
membercan be used to attach a procedure to a C++ type. -
C++
constructornow reusesresultinstead creatingthis. -
Tuple unpacking changes:
- Tuple unpacking assignment now supports using underscores to discard values.
var a, c: int (a, _, c) = (1, 2, 3) - Tuple unpacking variable declarations now support type annotations, but
only for the entire tuple.
let (a, b): (int, int) = (1, 2) let (a, (b, c)): (byte, (float, cstring)) = (1, (2, "abc"))
- Tuple unpacking assignment now supports using underscores to discard values.
-
An experimental option
genericsOpenSymhas been added to allow captured symbols in generic routine bodies to be replaced by symbols injected locally by templates/macros at instantiation time.bindmay be used to keep the captured symbols over the injected ones regardless of enabling the option.Since this change may affect runtime behavior, the experimental switch
genericsOpenSymneeds to be enabled, and a warning is given in the case where an injected symbol would replace a captured symbol not bound bybindand the experimental switch isn't enabled.const value = "captured" template foo(x: int, body: untyped) = let value {.inject.} = "injected" body proc old[T](): string = foo(123): return value # warning: a new `value` has been injected, use `bind` or turn on `experimental:genericsOpenSym` echo old[int]() # "captured" {.experimental: "genericsOpenSym".} proc bar[T](): string = foo(123): return value assert bar[int]() == "injected" # previously it would be "captured" proc baz[T](): string = bind value foo(123): return value assert baz[int]() == "captured"
Compiler changes
--nimcacheusing a relative path as the argument in a config file is now relative to the config file instead of the current directory.
Tool changes
- koch now allows bootstrapping with
-d:nimHasLibFFI, replacing the older option of building the compiler directly w/ thelibffinimble package in tow.