From 544cb107c75523196ceee9408f9b1d5d89c82e48 Mon Sep 17 00:00:00 2001 From: flywind <43030857+xflywind@users.noreply.github.com> Date: Mon, 2 Nov 2020 17:41:44 +0800 Subject: [PATCH] fix #8821 (#15809) --- compiler/jsgen.nim | 5 +++++ tests/js/t8821.nim | 12 ++++++++++++ 2 files changed, 17 insertions(+) create mode 100644 tests/js/t8821.nim diff --git a/compiler/jsgen.nim b/compiler/jsgen.nim index cd14f1cf9d0f..10c0722534a4 100644 --- a/compiler/jsgen.nim +++ b/compiler/jsgen.nim @@ -865,6 +865,7 @@ proc genRaiseStmt(p: PProc, n: PNode) = proc genCaseJS(p: PProc, n: PNode, r: var TCompRes) = var cond, stmt: TCompRes + totalRange = 0 genLineDir(p, n) gen(p, n[0], cond) let stringSwitch = skipTypes(n[0].typ, abstractVar).kind == tyString @@ -884,6 +885,10 @@ proc genCaseJS(p: PProc, n: PNode, r: var TCompRes) = let e = it[j] if e.kind == nkRange: var v = copyNode(e[0]) + inc(totalRange, int(e[1].intVal - v.intVal)) + if totalRange > 65535: + localError(p.config, n.info, + "Your case statement contains too many branches, consider using if/else instead!") while v.intVal <= e[1].intVal: gen(p, v, cond) lineF(p, "case $1:$n", [cond.rdLoc]) diff --git a/tests/js/t8821.nim b/tests/js/t8821.nim new file mode 100644 index 000000000000..43cf3f6f2a68 --- /dev/null +++ b/tests/js/t8821.nim @@ -0,0 +1,12 @@ +discard """ + errormsg: "Your case statement contains too many branches, consider using if/else instead!" +""" + +proc isInt32(i: int): bool = + case i + of 1 .. 70000: + return true + else: + return false + +discard isInt32(1) \ No newline at end of file