summary refs log tree commit diff stats
path: root/lib/std
diff options
context:
space:
mode:
authorflywind <xzsflywind@gmail.com>2021-03-11 21:04:08 +0800
committerGitHub <noreply@github.com>2021-03-11 14:04:08 +0100
commitd8b5879c7df989aa258c2884eeed6e1e03856b35 (patch)
tree29338921cce78a0340ac75c9660f165ef1ecc169 /lib/std
parent3cbc80045dfe84e47e28abc4d19f2bbeba82748d (diff)
downloadNim-d8b5879c7df989aa258c2884eeed6e1e03856b35.tar.gz
clarify the docs of isolation (#17335)
* improve test coverage for isolation

* a bit better

* clarify the docs of isolation
Diffstat (limited to 'lib/std')
-rw-r--r--lib/std/isolation.nim8
1 files changed, 7 insertions, 1 deletions
diff --git a/lib/std/isolation.nim b/lib/std/isolation.nim
index 94abef807..8daca233b 100644
--- a/lib/std/isolation.nim
+++ b/lib/std/isolation.nim
@@ -29,15 +29,21 @@ proc `=destroy`*[T](dest: var Isolated[T]) {.inline.} =
   `=destroy`(dest.value)
 
 func isolate*[T](value: sink T): Isolated[T] {.magic: "Isolate".} =
-  ## Create an isolated subgraph from the expression `value`.
+  ## Creates an isolated subgraph from the expression `value`.
+  ## Isolation is checked at compile time.
+  ##
   ## Please read https://github.com/nim-lang/RFCs/issues/244
   ## for more details.
   Isolated[T](value: value)
 
 func unsafeIsolate*[T](value: sink T): Isolated[T] =
   ## Creates an isolated subgraph from the expression `value`.
+  ## 
+  ## .. warning:: The proc doesn't check whether `value` is isolated.
+  ## 
   Isolated[T](value: value)
 
 func extract*[T](src: var Isolated[T]): T =
   ## Returns the internal value of `src`.
+  ## The value is moved from `src`.
   result = move(src.value)