aboutsummaryrefslogtreecommitdiff
path: root/src/interp
diff options
context:
space:
mode:
Diffstat (limited to 'src/interp')
-rw-r--r--src/interp/astr.boot33
-rw-r--r--src/interp/posit.boot54
2 files changed, 55 insertions, 32 deletions
diff --git a/src/interp/astr.boot b/src/interp/astr.boot
index ecf8768a..b506c23a 100644
--- a/src/interp/astr.boot
+++ b/src/interp/astr.boot
@@ -33,6 +33,11 @@
import vmlisp
namespace BOOT
+module astr where
+ ncTag: %Thing -> %Symbol
+ ncAlist: %Thing -> %List
+ ncEltQ: %List -> %Thing
+ ncPutQ: (%List,%Thing,%Thing) -> %Thing
--% Attributed Structures (astr)
-- For objects which are pairs where the CAR field is either just a tag
@@ -40,25 +45,25 @@ namespace BOOT
-- Pick off the tag
ncTag x ==
- not PAIRP x => ncBug('S2CB0031,[])
- x := QCAR x
+ atom x => ncBug('S2CB0031,[])
+ x := first x
IDENTP x => x
- not PAIRP x => ncBug('S2CB0031,[])
- QCAR x
+ atom x => ncBug('S2CB0031,[])
+ first x
-- Pick off the property list
ncAlist x ==
- not PAIRP x => ncBug('S2CB0031,[])
- x := QCAR x
- IDENTP x => NIL
- not PAIRP x => ncBug('S2CB0031,[])
- QCDR x
+ atom x => ncBug('S2CB0031,[])
+ x := first x
+ IDENTP x => nil
+ atom x => ncBug('S2CB0031,[])
+ rest x
--- Get the entry for key k on x's association list
ncEltQ(x,k) ==
r := QASSQ(k,ncAlist x)
- NULL r => ncBug ('S2CB0007,[k])
- CDR r
+ null r => ncBug ('S2CB0007,[k])
+ rest r
-- Put (k . v) on the association list of x and return v
-- case1: ncPutQ(x,k,v) where k is a key (an identifier), v a value
@@ -70,9 +75,9 @@ ncPutQ(x,k,v) ==
for key in k for val in v repeat ncPutQ(x,key,val)
v
r := QASSQ(k,ncAlist x)
- if NULL r then
- r := CONS( CONS(k,v), ncAlist x)
- RPLACA(x,CONS(ncTag x,r))
+ if null r then
+ r := [[k,:v], :ncAlist x]
+ RPLACA(x,[ncTag x,:r])
else
RPLACD(r,v)
v
diff --git a/src/interp/posit.boot b/src/interp/posit.boot
index 0e12dbfc..77911e8b 100644
--- a/src/interp/posit.boot
+++ b/src/interp/posit.boot
@@ -1,6 +1,6 @@
-- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd.
-- All rights reserved.
--- Copyright (C) 2007, Gabriel Dos Reis.
+-- Copyright (C) 2007-2008, Gabriel Dos Reis.
-- All rights reserved.
--
-- Redistribution and use in source and binary forms, with or without
@@ -34,6 +34,11 @@
import sys_-macros
import astr
namespace BOOT
+module posit where
+ %Position <=> %List
+ tokType: %List -> %Symbol
+ tokPart: %List -> %Thing
+ tokPosn: %List -> %Position
$nopos ==
['noposition]
@@ -52,7 +57,7 @@ pfPosOrNopos pf ==
poNoPosition()
poIsPos? pos ==
- PAIRP pos and PAIRP CAR pos and LENGTH CAR pos = 5
+ PAIRP pos and PAIRP first pos and #first pos = 5
lnCreate(extBl, st, gNo, :optFileStuff) ==
lNo :=
@@ -81,7 +86,7 @@ lnFileName lineObject ==
ncBug('"there is no file name in %1", [lineObject] )
lnFileName? lineObject ==
- NOT PAIRP (fN := lineObject.4) => NIL
+ atom (fN := lineObject.4) => nil
fN
lnPlaceOfOrigin lineObject ==
@@ -91,7 +96,8 @@ lnImmediate? lineObject ==
not lnFileName? lineObject
poGetLineObject posn ==
- CAR posn
+ first posn
+
pfGetLineObject posn == poGetLineObject posn
pfSourceStok x==
@@ -113,23 +119,25 @@ pfSourceToken form ==
tokConstruct(hd,tok,:pos)==
a:=cons(hd,tok)
IFCAR pos =>
- pfNoPosition? CAR pos=> a
- ncPutQ(a,"posn",CAR pos)
+ pfNoPosition? first pos=> a
+ ncPutQ(a,"posn",first pos)
a
a
tokType x== ncTag x
-tokPart x== CDR x
+
+tokPart x== rest x
+
tokPosn x==
a:= QASSQ("posn",ncAlist x)
- if a then CDR a else pfNoPosition()
+ if a then rest a else pfNoPosition()
pfAbSynOp form ==
- hd := CAR form
+ hd := first form
IFCAR hd or hd
pfAbSynOp?(form, op) ==
- hd := CAR form
+ hd := first form
EQ(hd, op) or EQCAR(hd, op)
pfLeaf? form ==
@@ -141,10 +149,10 @@ pfLeaf(x,y,:z) == tokConstruct(x,y, IFCAR z or pfNoPosition())
pfLeafToken form == tokPart form
pfLeafPosition form == tokPosn form
-pfTree(x,y) == CONS(x,y) -- was ==>
-pfParts form == CDR form -- was ==>
-pfFirst form == CADR form -- was ==>
-pfSecond form == CADDR form -- was ==>
+pfTree(x,y) == [x,:y]
+pfParts form == rest form
+pfFirst form == second form
+pfSecond form == third form
pfPosn pf == pfSourcePosition pf
@@ -172,44 +180,54 @@ pfSourcePositionlist x==
else APPEND(pfSourcePositions first x,pfSourcePositionlist rest x)
-poCharPosn posn == CDR posn
+poCharPosn posn == rest posn
+
pfCharPosn posn == poCharPosn posn
poLinePosn posn ==
posn => lnLocalNum poGetLineObject posn --VECP posn =>
CDAR posn
+
pfLinePosn posn == poLinePosn posn
poGlobalLinePosn posn ==
posn => lnGlobalNum poGetLineObject posn
ncBug('"old style pos objects have no global positions",[])
+
pfGlobalLinePosn posn == poGlobalLinePosn posn
poFileName posn ==
posn => lnFileName poGetLineObject posn
CAAR posn
+
pfFileName posn == poFileName posn
poFileName? posn ==
- posn = ['noposition] => NIL
+ posn = ['noposition] => nil
posn => lnFileName? poGetLineObject posn
CAAR posn
+
pfFileName? posn == poFileName? posn
poPlaceOfOrigin posn ==
lnPlaceOfOrigin poGetLineObject posn
+
pfPlaceOfOrigin posn == poPlaceOfOrigin posn
poNopos? posn ==
posn = ['noposition]
+
pfNopos? posn == poNopos? posn
+
poPosImmediate? txp==
- poNopos? txp => NIL
+ poNopos? txp => nil
lnImmediate? poGetLineObject txp
+
pfPosImmediate? txp == poPosImmediate? txp
poImmediate? txp==
lnImmediate? poGetLineObject txp
+
pfImmediate? txp == poImmediate? txp
@@ -222,7 +240,7 @@ pfPrintSrcLines(pf) ==
lines := pfSourcePositions pf
lno := 0
for l in lines repeat
- line := car l
+ line := first l
if lno < lnGlobalNum(line) then
FORMAT(true, '" ~A~%", lnString line)
lno := lnGlobalNum(line)