From 2725be64bacb46997c0959560d833ff946c8cb3b Mon Sep 17 00:00:00 2001 From: diegomrsantos Date: Thu, 18 Jan 2024 16:25:56 +0100 Subject: [PATCH] fix: use a temp var in withValue (#1010) --- libp2p/utility.nim | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/libp2p/utility.nim b/libp2p/utility.nim index 3b0a71345..e58f59d43 100644 --- a/libp2p/utility.nim +++ b/libp2p/utility.nim @@ -89,8 +89,27 @@ template exceptionToAssert*(body: untyped): untyped = res template withValue*[T](self: Opt[T] | Option[T], value, body: untyped): untyped = - if self.isSome: - let value {.inject.} = self.get() + ## This template provides a convenient way to work with `Option` types in Nim. + ## It allows you to execute a block of code (`body`) only when the `Option` is not empty. + ## + ## `self` is the `Option` instance being checked. + ## `value` is the variable name to be used within the `body` for the unwrapped value. + ## `body` is a block of code that is executed only if `self` contains a value. + ## + ## The `value` within `body` is automatically unwrapped from the `Option`, making it + ## simpler to work with without needing explicit checks or unwrapping. + ## + ## Example: + ## ```nim + ## let myOpt = Opt.some(5) + ## myOpt.withValue(value): + ## echo value # Will print 5 + ## ``` + ## + ## Note: This is a template, and it will be inlined at the call site, offering good performance. + let temp = (self) + if temp.isSome: + let value {.inject.} = temp.get() body macro withValue*[T](self: Opt[T] | Option[T], value, body, body2: untyped): untyped =