-
Added some enhancements to
std/jsonutils
module.- Added a possibility to deserialize JSON arrays directly to
HashSet
andOrderedSet
types and respectively to serialize those types to JSON arrays viajsonutils.fromJson
andjsonutils.toJson
procedures. - Added a possibility to deserialize JSON
null
objects to Nim option objects and respectively to serialize Nim option object to JSON object ifisSome
or to JSON null object ifisNone
viajsonutils.fromJson
andjsonutils.toJson
procedures. - Added
Joptions
parameter tojsonutils.fromJson
procedure currently containing two boolean optionsallowExtraKeys
andallowMissingKeys
.- If
allowExtraKeys
istrue
Nim's object to which the JSON is parsed is not required to have a field for every JSON key. - If
allowMissingKeys
istrue
Nim's object to which JSON is parsed is allowed to have fields without corresponding JSON keys.
- If
- Added a possibility to deserialize JSON arrays directly to
-
Added
bindParams
,bindParam
todb_sqlite
for binding parameters into aSqlPrepared
statement. -
Added
tryInsert
,insert
procs todb_*
libs accept primary key column name. -
Added
xmltree.newVerbatimText
support createstyle
's,script
's text. -
uri
adds Data URI Base64, implements RFC-2397. -
Added DOM Parser to the
dom
module for the JavaScript target. -
The default hash for
Ordinal
has changed to something more bit-scrambling.import hashes; proc hash(x: myInt): Hash = hashIdentity(x)
recovers the old one in an instantiation context while-d:nimIntHash1
recovers it globally. -
deques.peekFirst
anddeques.peekLast
now havevar Deque[T] -> var T
overloads. -
File handles created from high-level abstractions in the stdlib will no longer be inherited by child processes. In particular, these modules are affected:
asyncdispatch
,asyncnet
,system
,nativesockets
,net
andselectors
.For
asyncdispatch
,asyncnet
,net
andnativesockets
, aninheritable
flag has been added to allproc
s that create sockets, allowing the user to control whether the resulting socket is inheritable. This flag is provided to ease the writing of multi-process servers, where sockets inheritance is desired.For a transition period, define
nimInheritHandles
to enable file handle inheritance by default. This flag does not affect theselectors
module due to the differing semantics between operating systems.asyncdispatch.setInheritable
,system.setInheritable
andnativesockets.setInheritable
is also introduced for setting file handle or socket inheritance. Not all platform have theseproc
s defined. -
The file descriptors created for internal bookkeeping by
ioselector_kqueue
andioselector_epoll
will no longer be leaked to child processes. -
strutils.formatFloat
withprecision = 0
has been restored to the version 1 behaviour that produces a trailing dot, e.g.formatFloat(3.14159, precision = 0)
is now3.
, not3
. -
critbits
addscommonPrefixLen
. -
relativePath(rel, abs)
andrelativePath(abs, rel)
used to silently give wrong results (see #13222); instead they now usegetCurrentDir
to resolve those cases, and this can now throw in edge cases wheregetCurrentDir
throws.relativePath
also now works for js with-d:nodejs
. -
JavaScript and NimScript standard library changes:
streams.StringStream
is now supported in JavaScript, with the limitation that any bufferpointer
s used must be castable toptr string
, any incompatible pointer type will not work. Thelexbase
andstreams
modules used to fail to compile on NimScript due to a bug, but this has been fixed.The following modules now compile on both JS and NimScript:
parsecsv
,parsecfg
,parsesql
,xmlparser
,htmlparser
andropes
. Additionally supported for JS iscstrutils.startsWith
andcstrutils.endsWith
, for NimScript:json
,parsejson
,strtabs
andunidecode
. -
Added
streams.readStr
andstreams.peekStr
overloads to accept an existing string to modify, which avoids memory allocations, similar tostreams.readLine
(#13857). -
Added high-level
asyncnet.sendTo
andasyncnet.recvFrom
UDP functionality. -
dollars.$
now works for unsigned ints withnim js
-
Improvements to the
bitops
module, including bitslices, non-mutating versions of the original masking functions,mask
/masked
, and varargs support forbitand
,bitor
, andbitxor
. -
sugar.=>
andsugar.->
changes: Previously(x, y: int)
was transformed into(x: auto, y: int)
, it now becomes(x: int, y: int)
in consistency with regular proc definitions (although you cannot use semicolons).Pragmas and using a name are now allowed on the lefthand side of
=>
. Here is an aggregate example of these changes:import sugar foo(x, y: int) {.noSideEffect.} => x + y # is transformed into proc foo(x: int, y: int): auto {.noSideEffect.} = x + y
-
The fields of
times.DateTime
are now private, and are accessed with getters and deprecated setters. -
The
times
module now handles the default value forDateTime
more consistently. Most procs raise an assertion error when given an uninitializedDateTime
, the exceptions are==
and$
(which returns"Uninitialized DateTime"
). The proctimes.isInitialized
has been added which can be used to check if aDateTime
has been initialized. -
Fix a bug where calling
close
on io streams in osproc.startProcess was a noop and led to hangs if a process had both reads from stdin and writes (eg to stdout). -
The callback that is passed to
system.onThreadDestruction
must now be.raises: []
. -
The callback that is assigned to
system.onUnhandledException
must now be.gcsafe
. -
osproc.execCmdEx
now takes an optionalinput
for stdin,workingDir
andenv
parameters. -
Added a
ssl_config
module containing lists of secure ciphers as recommended by Mozilla OpSec -
net.newContext
now defaults to the list of ciphers targeting "Intermediate compatibility" per Mozilla's recommendation instead ofALL
. This change should protect users from the use of weak and insecure ciphers while still provides adequate compatibility with the majority of the Internet. -
A new module
std/jsonutils
with hookablejsonTo,toJson,fromJson
operations for json serialization/deserialization of custom types was added. -
A new proc
heapqueue.find[T](heap: HeapQueue[T], x: T): int
to get index of elementx
was added. -
Added
rstgen.rstToLatex
convenience proc forrenderRstToOut
andinitRstGenerator
withoutLatex
output. -
Added
os.normalizeExe
, e.g.:koch
=>./koch
. -
macros.newLit
now preserves named vs unnamed tuples; use-d:nimHasWorkaround14720
to keep old behavior. -
Added
random.gauss
, that uses the ratio of uniforms method of sampling from a Gaussian distribution. -
Added
typetraits.elementType
to get element type of an iterable. -
typetraits.$
changes:$(int,)
is now"(int,)"
instead of"(int)"
;$tuple[]
is now"tuple[]"
instead of"tuple"
;$((int, float), int)
is now"((int, float), int)"
instead of"(tuple of (int, float), int)"
-
Added
macros.extractDocCommentsAndRunnables
helper -
strformat.fmt
andstrformat.&
support= specifier
.fmt"{expr=}"
now expands tofmt"expr={expr}"
. -
deprecations:
os.existsDir
=>dirExists
,os.existsFile
=>fileExists
-
Added
jsre
module, Regular Expressions for the JavaScript target. -
Made
maxLines
argumentPositive
inlogging.newRollingFileLogger
, because negative values will result in a new file being created for each logged line which doesn't make sense. -
Changed
log
inlogging
to use proper log level on JavaScript target, e.g.debug
usesconsole.debug
,info
usesconsole.info
,warn
usesconsole.warn
, etc. -
Tables, HashSets, SharedTables and deques don't require anymore that the passed initial size must be a power of two - this is done internally. Proc
rightSize
for Tables and HashSets is deprecated, as it is not needed anymore.CountTable.inc
takesval: int
again notval: Positive
; I.e. it can "count down" again. -
Removed deprecated symbols from
macros
module, deprecated as far back as0.15
. -
Removed
sugar.distinctBase
, deprecated since0.19
. -
Export
asyncdispatch.PDispatcher.handles
so that an external library can register them. -
std/with
,sugar.dup
now support object field assignment expression:import std/with type Foo = object x, y: int var foo = Foo() with foo: x = 10 y = 20 echo foo
-
Proc
math.round
is no longer deprecated. The advice to usestrformat
instead cannot be applied to every use case. The limitations and the (lack of) reliability ofround
are well documented. -
Added
getprotobyname
towinlean
. AddedgetProtoByname
tonativesockets
which returns a protocol code from the database that matches the protocolname
. -
Added missing attributes and methods to
dom.Navigator
likedeviceMemory
,onLine
,vibrate()
, etc. -
Added
strutils.indentation
andstrutils.dedent
which enable indented string literals:import strutils echo dedent """ This is cool! """
-
Added
initUri(isIpv6: bool)
touri
module, nowuri
supports parsing ipv6 hostname. -
Added
readLines(p: Process)
toosproc
module forstartProcess
convenience. -
Added the below
to
procs for collections. The usage is similar to procs such assets.toHashSet
andtables.toTable
. Previously, it was necessary to create the respective empty collection and add items manually.critbits.toCritBitTree
, which creates aCritBitTree
from anopenArray
of items or anopenArray
of pairs.deques.toDeque
, which creates aDeque
from anopenArray
.heapqueue.toHeapQueue
, which creates aHeapQueue
from anopenArray
.intsets.toIntSet
, which creates anIntSet
from anopenArray
.
-
Added
progressInterval
argument toasyncftpclient.newAsyncFtpClient
to control the interval at which progress callbacks are called. -
Added
os.copyFileToDir
-
The
=destroy
hook no longer has to reset its target, as the compiler now automatically insertswasMoved
calls where needed. -
In the newruntime it is now allowed to assign to the discriminator field without restrictions as long as case object doesn't have custom destructor. The discriminator value doesn't have to be a constant either. If you have a custom destructor for a case object and you do want to freely assign discriminator fields, it is recommended to refactor object into 2 objects like this:
type MyObj = object case kind: bool of true: y: ptr UncheckedArray[float] of false: z: seq[int] proc `=destroy`(x: MyObj) = if x.kind and x.y != nil: deallocShared(x.y)
Refactor into:
type MySubObj = object val: ptr UncheckedArray[float] MyObj = object case kind: bool of true: y: MySubObj of false: z: seq[int] proc `=destroy`(x: MySubObj) = if x.val != nil: deallocShared(x.val)
-
getImpl
on enum type symbols now returns field syms instead of idents. This helps with writing typed macros. Old behavior for backwards compatibility can be restored with--useVersion:1.0
. -
The typed AST for proc headers will now have the arguments be syms instead of idents. This helps with writing typed macros. Old behaviour for backwards compatibility can be restored with
--useVersion:1.0
. -
let
statements can now be used without a value if declared withimportc
/importcpp
/importjs
/importobjc
. -
The keyword
from
is now usable as an operator. -
Exceptions inheriting from
system.Defect
are no longer tracked with the.raises: []
exception tracking mechanism. This is more consistent with the built-in operations. The following always used to compile (and still does):
proc mydiv(a, b): int {.raises: [].} =
a div b # can raise an DivByZeroDefect
Now also this compiles:
proc mydiv(a, b): int {.raises: [].} =
if b == 0: raise newException(DivByZeroDefect, "division by zero")
else: result = a div b
The reason for this is that DivByZeroDefect
inherits from Defect
and
with --panics:on
Defects
become unrecoverable errors.
-
Added the
thiscall
calling convention as specified by Microsoft, mostly for hooking purposes. -
Deprecated
{.unroll.}
pragma, was ignored by the compiler anyways, was a nop. -
Removed
strutils.isNilOrWhitespace
, was deprecated. -
Removed
sharedtables.initSharedTable
, was deprecated and produces undefined behavior. -
Removed
asyncdispatch.newAsyncNativeSocket
, was deprecated since0.18
. -
Removed
dom.releaseEvents
anddom.captureEvents
, was deprecated. -
Removed
sharedlists.initSharedList
, was deprecated and produces undefined behaviour. -
There is a new experimental feature called "strictFuncs" which makes the definition of
.noSideEffect
stricter. See for more information. -
"for-loop macros" (see the manual) are no longer an experimental feature. In other words, you don't have to write pragma
{.experimental: "forLoopMacros".}
if you want to use them. -
Added a
.noalias
pragma. It is mapped to C'srestrict
keyword for the increased performance this keyword can enable. -
items
no longer compiles with enum with holes as its behavior was error prone, see #14004 -
system.deepcopy
has to be enabled explicitly for--gc:arc
and--gc:orc
via--deepcopy:on
. -
Added a
std/effecttraits
module for introspection of the inferred effects. We hope this enablesasync
macros that are precise about the possible exceptions that can be raised. -
The pragma blocks
{.gcsafe.}: ...
and{.noSideEffect.}: ...
can now also be written as{.cast(gcsafe).}: ...
and{.cast(noSideEffect).}: ...
. This is the new preferred way of writing these, emphasizing their unsafe nature.
- Specific warnings can now be turned into errors via
--warningAsError[X]:on|off
. - The
define
andundef
pragmas have been de-deprecated. - New command:
nim r main.nim [args...]
which compiles and runs main.nim, and implies--usenimcache
so that output is saved to $nimcache/main$exeExt, using the same logic asnim c -r
to avoid recompiling when sources don't change. This is now the preferred way to run tests, avoiding the usual pain of clobbering your repo with binaries or using tricky gitignore rules on posix. Example:nim r compiler/nim.nim --help # only compiled the first time echo 'import os; echo getCurrentCompilerExe()' | nim r - # this works too nim r compiler/nim.nim --fullhelp # no recompilation nim r --nimcache:/tmp main # binary saved to /tmp/main
--hint:processing
is now supported and means--hint:processing:on
(likewise with other hints and warnings), which is consistent with all other bool flags. (since 1.3.3).nim doc -r main
andnim rst2html -r main
now callopenDefaultBrowser
.- new hint:
--hint:msgOrigin
will show where a compiler msg (hint|warning|error) was generated; this helps in particular when it's non obvious where it came from either because multiple locations generate the same message, or because the message involves runtime formatting. - new flag
--backend:js|c|cpp|objc
(or -b:js etc), to change backend; can be used with any command (eg nim r, doc, check etc); safe to re-assign. - new flag
--doccmd:cmd
to pass additional flags for runnableExamples, e.g.:--doccmd:-d:foo --threads
use--doccmd:skip
to skip runnableExamples and rst test snippets. - new flag
--usenimcache
to output to nimcache (whatever it resolves to after all commands are processed) and avoids polluting both $pwd and $projectdir. It can be used with any command. runnableExamples "-b:cpp -r:off": code
is now supported, allowing to override how an example is compiled and run, for example to change backend or compile only.nim doc
now outputs under$projectPath/htmldocs
when--outdir
is unspecified (with or without--project
); passing--project
now automatically generates an index and enables search. See docgen for details.- Removed the
--oldNewlines
switch. - Removed the
--laxStrings
switch for mutating the internal zero terminator on strings. - Removed the
--oldast
switch. - Removed the
--oldgensym
switch $getType(untyped)
is now "untyped" instead of "expr",$getType(typed)
is now "typed" instead of "stmt".- Sink inference is now disabled per default and has to enabled explicitly via
--sinkInference:on
. Note: For the standard library sink inference remains enabled. This change is most relevant for the--gc:arc
,--gc:orc
memory management modes.
nimsuggest
will now return both the forward declaration and the implementation location upon adef
query. Previously the behavior was just to return the forward declaration.