From 933a114887e66502ffbd47efbd60a7d99527eed4 Mon Sep 17 00:00:00 2001 From: bptato Date: Sun, 30 Jan 2022 11:05:56 +0100 Subject: Avoid stack overflow in renderBlockContext --- src/render/renderdocument.nim | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) (limited to 'src/render/renderdocument.nim') diff --git a/src/render/renderdocument.nim b/src/render/renderdocument.nim index e6020c6e..2d4dac82 100644 --- a/src/render/renderdocument.nim +++ b/src/render/renderdocument.nim @@ -145,14 +145,19 @@ proc renderInlineContext(grid: var FlexibleGrid, ctx: InlineContext, x, y: int, grid.setSpacing(spacing, x, y, term) proc renderBlockContext(grid: var FlexibleGrid, ctx: BlockContext, x, y: int, term: TermAttributes) = - let x = x + ctx.relx - let y = y + ctx.rely - if ctx.inline != nil: - assert ctx.nested.len == 0 - grid.renderInlineContext(ctx.inline, x, y, term) - else: - for ctx in ctx.nested: - grid.renderBlockContext(ctx, x, y, term) + var stack = newSeqOfCap[(BlockContext, int, int)](100) + stack.add((ctx, x, y)) + + while stack.len > 0: + var (ctx, x, y) = stack.pop() + x += ctx.relx + y += ctx.rely + if ctx.inline != nil: + assert ctx.nested.len == 0 + grid.renderInlineContext(ctx.inline, x, y, term) + else: + for i in countdown(ctx.nested.high, 0): + stack.add((ctx.nested[i], x, y)) const css = staticRead"res/ua.css" let uastyle = css.parseStylesheet() -- cgit 1.4.1-2-gfad0