From fba5f5acd6ab1b0aaca79241f55f95b089fbad2c Mon Sep 17 00:00:00 2001 From: Araq Date: Tue, 21 Nov 2017 01:42:53 +0100 Subject: [PATCH] added a version of macros.expectLen that takes min/max values --- lib/core/macros.nim | 7 +++++++ tests/js/tarrayboundscheck.nim | 0 2 files changed, 7 insertions(+) mode change 100755 => 100644 tests/js/tarrayboundscheck.nim diff --git a/lib/core/macros.nim b/lib/core/macros.nim index fc5b5bfb75..dc56bb671d 100644 --- a/lib/core/macros.nim +++ b/lib/core/macros.nim @@ -435,6 +435,13 @@ proc expectLen*(n: NimNode, len: int) {.compileTime.} = ## macros that check its number of arguments. if n.len != len: error("macro expects a node with " & $len & " children", n) +proc expectLen*(n: NimNode, min, max: int) {.compileTime.} = + ## checks that `n` has a number of children in the range ``min..max``. + ## If this is not the case, compilation aborts with an error message. + ## This is useful for writing macros that check its number of arguments. + if n.len < min or n.len > max: + error("macro expects a node with " & $min & ".." & $max " children", n) + proc newTree*(kind: NimNodeKind, children: varargs[NimNode]): NimNode {.compileTime.} = ## produces a new node with children. diff --git a/tests/js/tarrayboundscheck.nim b/tests/js/tarrayboundscheck.nim old mode 100755 new mode 100644