diff options
author | dos-reis <gdr@axiomatics.org> | 2009-04-08 08:21:20 +0000 |
---|---|---|
committer | dos-reis <gdr@axiomatics.org> | 2009-04-08 08:21:20 +0000 |
commit | def4da7bfc1f143b6a7a13a87895143909dc50c6 (patch) | |
tree | 8a5c0a90ae674840f1e95a1d0ce95e6f0887a370 /src/interp | |
parent | 05e0fb0c631ec281c283ef6afb27ee3f228c2828 (diff) | |
download | open-axiom-def4da7bfc1f143b6a7a13a87895143909dc50c6.tar.gz |
* interp/scan.boot (scanCheckRadix): Take the radix in string form.
Croak on missing digit after radix.
(scanNumber): Don't ask for implicit 0 completion for explicit
radix integers.
* interp/int-top.boot (phInterpret): Don't bother evaluating
expressions if earlier phases saw errors.
* interp/msg.boot (getStFromMsg): Fix typo.
Diffstat (limited to 'src/interp')
-rw-r--r-- | src/interp/int-top.boot | 4 | ||||
-rw-r--r-- | src/interp/msg.boot | 5 | ||||
-rw-r--r-- | src/interp/scan.boot | 27 |
3 files changed, 20 insertions, 16 deletions
diff --git a/src/interp/int-top.boot b/src/interp/int-top.boot index 8c7df1e8..06366706 100644 --- a/src/interp/int-top.boot +++ b/src/interp/int-top.boot @@ -1,6 +1,6 @@ -- Copyright (c) 1991-2002, The Numerical Algorithms Group Ltd. -- All rights reserved. --- Copyright (C) 2007-2008, Gabriel Dos Reis. +-- Copyright (C) 2007-2009, Gabriel Dos Reis. -- All rights reserved. -- -- Redistribution and use in source and binary forms, with or without @@ -247,6 +247,8 @@ intloopSpadProcess(stepNo,lines,ptree,interactive?)== stepNo+1 phInterpret carrier == + -- Don't try evaluation if the data structure may have been corrupted. + not ncEltQ(carrier, "ok?") => "KO" ptree := ncEltQ(carrier, 'ptree) val := intInterpretPform(ptree) ncPutQ(carrier, 'value, val) diff --git a/src/interp/msg.boot b/src/interp/msg.boot index 4f658fd2..af1532f9 100644 --- a/src/interp/msg.boot +++ b/src/interp/msg.boot @@ -1,6 +1,6 @@ -- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. -- All rights reserved. --- Copyright (C) 2007-2008, Gabriel Dos Reis. +-- Copyright (C) 2007-2009, Gabriel Dos Reis. -- All rights reserved. -- -- Redistribution and use in source and binary forms, with or without @@ -349,8 +349,7 @@ getStFromMsg msg == setOptKeyBlanks() preStL := getPreStL getMsgPrefix? msg getMsgTag msg = 'line => - [$optKeyBlanks, '"%1" , :preStL,_ - getMsgText msg] + [$optKeyBlanks, :preStL, getMsgText msg] posStL := getPosStL msg optKey := $showKeyNum => diff --git a/src/interp/scan.boot b/src/interp/scan.boot index eff296bf..77f5bdc4 100644 --- a/src/interp/scan.boot +++ b/src/interp/scan.boot @@ -1,6 +1,6 @@ -- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. -- All rights reserved. --- Copyright (C) 2007-2008, Gabriel Dos Reis. +-- Copyright (C) 2007-2009, Gabriel Dos Reis. -- All rights reserved. -- -- Redistribution and use in source and binary forms, with or without @@ -585,14 +585,17 @@ spleI1(dig,zro) == bb:=spleI1(dig,zro)-- escape, anyno spaces are ignored CONCAT(str,bb) -scanCheckRadix(r,w)== - ns:=#w - done:=false - for i in 0..ns-1 repeat - a:=rdigit? w.i - if null a or a>=r - then ncSoftError(cons($linepos,lnExtraBlanks $linepos+$n-ns+i), - "S2CN0002", [w.i]) +scanCheckRadix(a,w)== + r := PARSE_-INTEGER a + ns:=#w + ns = 0 => + ncSoftError([$linepos,:lnExtraBlanks $linepos+$n],"S2CN0004",[a]) + done:=false + for i in 0..ns-1 repeat + a:=rdigit? w.i + if null a or a>=r + then ncSoftError(cons($linepos,lnExtraBlanks $linepos+$n-ns+i), + "S2CN0002", [w.i]) scanNumber() == a := spleI(function digit?) @@ -615,8 +618,8 @@ scanNumber() == else lfinteger a else $n:=$n+1 - w:=spleI1(function rdigit?,true) - scanCheckRadix(PARSE_-INTEGER a,w) + w:=spleI1(function rdigit?,false) + scanCheckRadix(a,w) if $n>=$sz then lfrinteger(a,w) @@ -631,7 +634,7 @@ scanNumber() == else --$n:=$n+1 v:=spleI1(function rdigit?,true) - scanCheckRadix(PARSE_-INTEGER a,v) + scanCheckRadix(a,v) scanExponent(CONCAT(a,'"r",w),v) else lfrinteger(a,w) |