mirror of
https://github.com/nim-lang/Nim.git
synced 2026-01-08 14:03:23 +00:00
fixes #16790; fixes #19075; put big arrays on the constant seqs; don't inline them in the VM; big performance boost (#21318)
* don't inline arrays in VM * add a test for #19075
This commit is contained in:
@@ -32,7 +32,7 @@ when defined(nimPreviewSlimSystem):
|
||||
import std/assertions
|
||||
|
||||
import
|
||||
strutils, ast, types, msgs, renderer, vmdef,
|
||||
strutils, ast, types, msgs, renderer, vmdef, trees,
|
||||
intsets, magicsys, options, lowerings, lineinfos, transf, astmsgs
|
||||
|
||||
from modulegraphs import getBody
|
||||
@@ -2054,7 +2054,10 @@ proc gen(c: PCtx; n: PNode; dest: var TDest; flags: TGenFlags = {}) =
|
||||
genLit(c, n, dest)
|
||||
of skConst:
|
||||
let constVal = if s.astdef != nil: s.astdef else: s.typ.n
|
||||
gen(c, constVal, dest)
|
||||
if dontInlineConstant(n, constVal):
|
||||
genLit(c, constVal, dest)
|
||||
else:
|
||||
gen(c, constVal, dest)
|
||||
of skEnumField:
|
||||
# we never reach this case - as of the time of this comment,
|
||||
# skEnumField is folded to an int in semfold.nim, but this code
|
||||
|
||||
19
tests/vm/t19075.nim
Normal file
19
tests/vm/t19075.nim
Normal file
@@ -0,0 +1,19 @@
|
||||
discard """
|
||||
timeout: 10
|
||||
joinable: false
|
||||
"""
|
||||
|
||||
# bug #19075
|
||||
const size = 50_000
|
||||
|
||||
const stuff = block:
|
||||
var a: array[size, int]
|
||||
a
|
||||
|
||||
const zeugs = block:
|
||||
var zeugs: array[size, int]
|
||||
for i in 0..<size:
|
||||
zeugs[i] = stuff[i]
|
||||
zeugs
|
||||
|
||||
doAssert zeugs[0] == 0
|
||||
Reference in New Issue
Block a user