aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ChangeLog8
-rw-r--r--src/algebra/array1.spad.pamphlet38
-rw-r--r--src/interp/g-opt.boot3
-rw-r--r--src/interp/g-util.boot5
4 files changed, 34 insertions, 20 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index 61418877..0a6758d4 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,5 +1,13 @@
2010-06-26 Gabriel Dos Reis <gdr@cs.tamu.edu>
+ * interp/g-opt.boot ($VMsideEffectFreeOperators): Include %vref
+ and %vlength.
+ * interp/g-util.boot: Expand them.
+ * algebra/array1.spad.pamphlet (PrimitiveArray): Use them.
+ (IndexedOneDimensionalArray): Likewise.
+
+2010-06-26 Gabriel Dos Reis <gdr@cs.tamu.edu>
+
* algebra/aggcat.spad.pamphlet (HomogeneousAggregate): Satisfy
BasicType if element type satisfies it.
diff --git a/src/algebra/array1.spad.pamphlet b/src/algebra/array1.spad.pamphlet
index 3f93b26f..0d4257e8 100644
--- a/src/algebra/array1.spad.pamphlet
+++ b/src/algebra/array1.spad.pamphlet
@@ -15,8 +15,10 @@
++ This provides a fast array type with no bound checking on elt's.
++ Minimum index is 0 in this type, cannot be changed
PrimitiveArray(S:Type): OneDimensionalArrayAggregate S == add
- #x ==
- sizeOfSimpleArray(x)$Lisp
+ import %vlength: % -> NonNegativeInteger from Foreign Builtin
+ import %vref: (%,Integer) -> S from Foreign Builtin
+
+ #x == %vlength x
minIndex x ==
0
@@ -30,11 +32,8 @@ PrimitiveArray(S:Type): OneDimensionalArrayAggregate S == add
new(n, x) ==
makeFilledSimpleArray(getVMType(S)$Lisp,n,x)$Lisp
- qelt(x, i) ==
- getSimpleArrayEntry(x,i)$Lisp
-
- elt(x:%, i:Integer) ==
- getSimpleArrayEntry(x,i)$Lisp
+ qelt(x, i) == %vref(x,i)
+ elt(x:%, i:Integer) == %vref(x,i)
qsetelt!(x, i, s) ==
setSimpleArrayEntry(x,i,s)$Lisp
@@ -371,9 +370,10 @@ FlexibleArray(S: Type) == Implementation where
IndexedOneDimensionalArray(S:Type, mn:Integer):
OneDimensionalArrayAggregate S == add
+ import %vlength: % -> NonNegativeInteger from Foreign Builtin
+ import %vref: (%,Integer) -> S from Foreign Builtin
+
macro Qmax == maxIndexOfSimpleArray$Foreign(Builtin)
- macro Qsize == sizeOfSimpleArray$Foreign(Builtin)
- macro Qelt == getSimpleArrayEntry$Foreign(Builtin)
macro Qsetelt == setSimpleArrayEntry$Foreign(Builtin)
macro I == Integer
Rep == PrimitiveArray S
@@ -393,14 +393,14 @@ IndexedOneDimensionalArray(S:Type, mn:Integer):
map!(f, s1) ==
n: Integer := Qmax(s1)
n < 0 => s1
- for i in 0..n repeat Qsetelt(s1, i, f(Qelt(s1,i)))
+ for i in 0..n repeat Qsetelt(s1, i, f(%vref(s1,i)))
s1
map(f, s1) ==
n:Integer := Qmax(s1)
n < 0 => s1
ss2:% := newArray(n+1)
- for i in 0..n repeat Qsetelt(ss2, i, f(Qelt(s1,i)))
+ for i in 0..n repeat Qsetelt(ss2, i, f(%vref(s1,i)))
ss2
map(f, a, b) ==
@@ -408,11 +408,11 @@ IndexedOneDimensionalArray(S:Type, mn:Integer):
maxind < 0 => empty()
c:% := newArray(maxind+1)
for i in 0..maxind repeat
- Qsetelt(c, i, f(Qelt(a,i),Qelt(b,i)))
+ Qsetelt(c, i, f(%vref(a,i),%vref(b,i)))
c
if zero? mn then
- qelt(x, i) == Qelt(x, i)
+ qelt(x, i) == %vref(x, i)
qsetelt!(x, i, s) == Qsetelt(x, i, s)
elt(x:%, i:I) ==
@@ -424,22 +424,22 @@ IndexedOneDimensionalArray(S:Type, mn:Integer):
qsetelt!(x, i, s)
else if one? mn then
- maxIndex x == Qsize x
- qelt(x, i) == Qelt(x, i-1)
+ maxIndex x == %vlength x
+ qelt(x, i) == %vref(x, i-1)
qsetelt!(x, i, s) == Qsetelt(x, i-1, s)
elt(x:%, i:I) ==
- QSLESSP(i,1$Lisp)$Lisp or QSLESSP(Qsize x,i)$Lisp =>
+ QSLESSP(i,1$Lisp)$Lisp or QSLESSP(%vlength x,i)$Lisp =>
error "index out of range"
- Qelt(x, i-1)
+ %vref(x, i-1)
setelt(x:%, i:I, s:S) ==
- QSLESSP(i,1$Lisp)$Lisp or QSLESSP(Qsize x,i)$Lisp =>
+ QSLESSP(i,1$Lisp)$Lisp or QSLESSP(%vlength x,i)$Lisp =>
error "index out of range"
Qsetelt(x, i-1, s)
else
- qelt(x, i) == Qelt(x, i - mn)
+ qelt(x, i) == %vref(x, i - mn)
qsetelt!(x, i, s) == Qsetelt(x, i - mn, s)
elt(x:%, i:I) ==
diff --git a/src/interp/g-opt.boot b/src/interp/g-opt.boot
index d526f439..8c7c4a10 100644
--- a/src/interp/g-opt.boot
+++ b/src/interp/g-opt.boot
@@ -478,7 +478,8 @@ $VMsideEffectFreeOperators ==
%fpow %fdiv %fneg %i2f %fminval %fmaxval %fbase %fprec %ftrunc
%nil %pair? %lconcat %llength %lfirst %lsecond %lthird
%lreverse %lempty? %hash %ismall? %string? %f2s
- %ceq %clt %cle %cgt %cge %c2i %i2c)
+ %ceq %clt %cle %cgt %cge %c2i %i2c
+ %vref %vlength)
++ List of simple VM operators
$simpleVMoperators ==
diff --git a/src/interp/g-util.boot b/src/interp/g-util.boot
index b718e253..97519045 100644
--- a/src/interp/g-util.boot
+++ b/src/interp/g-util.boot
@@ -372,6 +372,11 @@ for x in [
-- binary list operations
['%lconcat, :'APPEND],
+ -- simple vector operations
+ ['%vfill, :'FILL],
+ ['%vlength, :'sizeOfSimpleArray],
+ ['%vref, :'getSimpleArrayEntry],
+
-- symbol unary functions
['%gensym, :'GENSYM],