From 327b68f0e2086eef9fc755b9ffba76343839e4ee Mon Sep 17 00:00:00 2001 From: dos-reis Date: Mon, 21 May 2012 06:52:01 +0000 Subject: * interp/spad-parser.boot (addParensAndSemisToLine): Drop 'drop', avoiding awakening GCL bug and quadratic traversal of lines. (parsePiles): Simplify. --- src/interp/spad-parser.boot | 28 +++++++++++++--------------- 1 file changed, 13 insertions(+), 15 deletions(-) (limited to 'src/interp') diff --git a/src/interp/spad-parser.boot b/src/interp/spad-parser.boot index 2799d88f..e934e2b9 100644 --- a/src/interp/spad-parser.boot +++ b/src/interp/spad-parser.boot @@ -177,28 +177,26 @@ addParensAndSemisToLine(lines,locs) == sc := first locs -- first line column number sc = nil or sc <= 0 => nil count := 0 -- number of semicolons added - i := 0 -- running local line number + z := lines for x in tails rest lines for y in tails rest locs repeat - i := i + 1 - nc := first y - nc = nil => nil - nc := abs nc - nc < sc => leave nil - nc = sc and (y.first := -nc) and not infixToken? first x => - z := drop(i - 1,lines) - z.first := addClose(first z,char ";") - count := count + 1 + do + nc := first y + nc = nil => nil + nc := abs nc + nc < sc => leave nil + nc = sc and (y.first := -nc) and not infixToken? first x => + z.first := addClose(first z,char ";") + count := count + 1 + z := rest z count > 0 => first(lines).(firstNonblankCharPosition first lines - 1) := char "(" - lines := drop(i - 1,lines) - lines.first := addClose(first lines,char ")") + z.first := addClose(first z,char ")") nil ++ Add parens and semis to lines to aid parsing. parsePiles(locs,lines) == - for x in tails append!(lines,['" "]) - for y in tails append!(locs,[nil]) repeat - addParensAndSemisToLine(x,y) + for x in tails lines for y in tails locs repeat + addParensAndSemisToLine(x,y) lines parsePrint l == -- cgit v1.2.3