Skip to content

Commit

Permalink
fixup
Browse files Browse the repository at this point in the history
  • Loading branch information
timotheecour committed Jul 29, 2019
1 parent 60b6502 commit e8b060f
Showing 1 changed file with 15 additions and 9 deletions.
24 changes: 15 additions & 9 deletions lib/pure/sugar.nim
Original file line number Diff line number Diff line change
Expand Up @@ -247,7 +247,7 @@ proc splitDefinition*(def: NimNode): tuple[lhs: NimNode, rhs: NimNode, exported:
let def2 = def[0]
case def2.kind
of nnkInfix:
doAssert $def2[0].ident == "*="
doAssert def2[0].strVal == "*="
result.lhs = def2[1]
result.rhs = def2[2]
result.exported = true
Expand All @@ -268,19 +268,25 @@ macro byRef*(def: untyped): untyped =
doAssert type(x1) is int and x == @[1,12,3]

let (name, exp, exported) = splitDefinition(def)
result = quote do:
let myAddr = addr `exp`
template `name`: untyped = myAddr[]
if exported:
result.add quote do: export `name`
result = quote do:
let myAddr = addr `exp`
template `name`*: untyped = myAddr[]
else:
result = quote do:
let myAddr = addr `exp`
template `name`: untyped = myAddr[]

macro byPtr*(def: untyped): untyped =
## Same as `byRef` but uses uses `unsafeAddr` instead of `addr`; `byRef` is
## safer and should be preferred when possible.
## This can for example be used on `let` variables.
let (name, exp, exported) = splitDefinition(def)
result = quote do:
let myAddr = unsafeAddr `exp`
template `name`: untyped = myAddr[]
if exported:
result.add quote do: export `name`
result = quote do:
let myAddr = unsafeAddr `exp`
template `name`*: untyped = myAddr[]
else:
result = quote do:
let myAddr = unsafeAddr `exp`
template `name`: untyped = myAddr[]

0 comments on commit e8b060f

Please sign in to comment.