aboutsummaryrefslogtreecommitdiff
path: root/src/interp/spad-parser.boot
diff options
context:
space:
mode:
Diffstat (limited to 'src/interp/spad-parser.boot')
-rw-r--r--src/interp/spad-parser.boot28
1 files changed, 13 insertions, 15 deletions
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 ==