summaryrefslogtreecommitdiff
path: root/src/jvm/clojure
diff options
context:
space:
mode:
authorRich Hickey <richhickey@gmail.com>2006-07-28 18:51:47 +0000
committerRich Hickey <richhickey@gmail.com>2006-07-28 18:51:47 +0000
commit709e897e44e353f2bda74d1f5b4bcaf413bf5a54 (patch)
treec948320ce2574b99495421c2f91ea50b50e0aa1d /src/jvm/clojure
parentf6beae41f544340607bddb4a217abd249d085fc6 (diff)
derived from Obj
Diffstat (limited to 'src/jvm/clojure')
-rw-r--r--src/jvm/clojure/lang/PersistentArrayIdentityMap.java15
-rw-r--r--src/jvm/clojure/lang/PersistentArrayMap.java22
-rw-r--r--src/jvm/clojure/lang/PersistentHashtableIdentityMap.java12
-rw-r--r--src/jvm/clojure/lang/PersistentHashtableMap.java20
4 files changed, 55 insertions, 14 deletions
diff --git a/src/jvm/clojure/lang/PersistentArrayIdentityMap.java b/src/jvm/clojure/lang/PersistentArrayIdentityMap.java
index d74cbeeb..a66c0482 100644
--- a/src/jvm/clojure/lang/PersistentArrayIdentityMap.java
+++ b/src/jvm/clojure/lang/PersistentArrayIdentityMap.java
@@ -22,14 +22,23 @@ private PersistentArrayIdentityMap() {
}
PersistentArrayMap create(Object... init){
- return new PersistentArrayIdentityMap(init);
+ PersistentArrayIdentityMap ret = new PersistentArrayIdentityMap(init);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap createHT(Object[] init){
- return new PersistentHashtableIdentityMap(init);
+ PersistentHashtableIdentityMap ret = new PersistentHashtableIdentityMap(init);
+ ret._meta = _meta;
+ return ret;
}
+
IPersistentMap empty() {
- return EMPTY;
+ if(_meta == null)
+ return EMPTY;
+ PersistentArrayIdentityMap ret = new PersistentArrayIdentityMap();
+ ret._meta = _meta;
+ return ret;
}
public PersistentArrayIdentityMap(Object... init) {
diff --git a/src/jvm/clojure/lang/PersistentArrayMap.java b/src/jvm/clojure/lang/PersistentArrayMap.java
index 4a17418e..19a1b255 100644
--- a/src/jvm/clojure/lang/PersistentArrayMap.java
+++ b/src/jvm/clojure/lang/PersistentArrayMap.java
@@ -23,7 +23,7 @@ import java.util.Iterator;
* null keys and values are ok, but you won't be able to distinguish a null value via get - use contains/find
*/
-public class PersistentArrayMap implements IPersistentMap, ISequential {
+public class PersistentArrayMap extends Obj implements IPersistentMap, ISequential, Cloneable {
final Object[] array;
static final int HASHTABLE_THRESHOLD = 42;
@@ -35,11 +35,21 @@ protected PersistentArrayMap(){
}
PersistentArrayMap create(Object... init){
- return new PersistentArrayMap(init);
+ PersistentArrayMap ret = new PersistentArrayMap(init);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap createHT(Object[] init){
- return new PersistentHashtableMap(init);
+ PersistentHashtableMap ret = new PersistentHashtableMap(init);
+ ret._meta = _meta;
+ return ret;
+}
+
+public Obj withMeta(IPersistentMap meta) throws Exception {
+ Obj ret = (Obj) clone();
+ ret._meta = meta;
+ return ret;
}
/**
@@ -132,7 +142,11 @@ public IPersistentMap remove(Object key) {
}
IPersistentMap empty() {
- return EMPTY;
+ if(_meta == null)
+ return EMPTY;
+ PersistentArrayMap ret = new PersistentArrayMap();
+ ret._meta = _meta;
+ return ret;
}
final public Object get(Object key) {
diff --git a/src/jvm/clojure/lang/PersistentHashtableIdentityMap.java b/src/jvm/clojure/lang/PersistentHashtableIdentityMap.java
index 281acc0c..1f1a50c0 100644
--- a/src/jvm/clojure/lang/PersistentHashtableIdentityMap.java
+++ b/src/jvm/clojure/lang/PersistentHashtableIdentityMap.java
@@ -78,15 +78,21 @@ static class Iter implements Iterator{
}
IPersistentMap create(int capacity) {
- return new PersistentHashtableIdentityMap(capacity);
+ PersistentHashtableIdentityMap ret = new PersistentHashtableIdentityMap(capacity);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap create(int count, PersistentArray array) {
- return new PersistentHashtableIdentityMap(count, array);
+ PersistentHashtableIdentityMap ret = new PersistentHashtableIdentityMap(count, array);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap create(int i, PersistentArray newArray, int growAtCount){
- return new PersistentHashtableIdentityMap(i, newArray, growAtCount);
+ PersistentHashtableIdentityMap ret = new PersistentHashtableIdentityMap(i, newArray, growAtCount);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap createListMap(Object key, Object val){
diff --git a/src/jvm/clojure/lang/PersistentHashtableMap.java b/src/jvm/clojure/lang/PersistentHashtableMap.java
index 290adb93..d60d15ba 100644
--- a/src/jvm/clojure/lang/PersistentHashtableMap.java
+++ b/src/jvm/clojure/lang/PersistentHashtableMap.java
@@ -13,7 +13,7 @@ package clojure.lang;
import java.util.Iterator;
import java.math.BigInteger;
-public class PersistentHashtableMap implements IPersistentMap {
+public class PersistentHashtableMap extends Obj implements IPersistentMap, Cloneable {
static final float FILL_FACTOR = 0.75f;
@@ -54,6 +54,12 @@ PersistentHashtableMap(int count,PersistentArray array,int growAt) {
this.growAtCount = growAt;
}
+public Obj withMeta(IPersistentMap meta) throws Exception {
+ Obj ret = (Obj) clone();
+ ret._meta = meta;
+ return ret;
+}
+
int calcPrimeCapacity(int capacity) {
return BigInteger.valueOf((long) (capacity/FILL_FACTOR)).nextProbablePrime().intValue();
}
@@ -253,15 +259,21 @@ static int bucketFor(Object key, PersistentArray array) {
}
IPersistentMap create(int capacity) {
- return new PersistentHashtableMap(capacity);
+ PersistentHashtableMap ret = new PersistentHashtableMap(capacity);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap create(int count,PersistentArray array) {
- return new PersistentHashtableMap(count, array);
+ PersistentHashtableMap ret = new PersistentHashtableMap(count, array);
+ ret._meta = _meta;
+ return ret;
}
IPersistentMap create(int i, PersistentArray newArray, int growAtCount){
- return new PersistentHashtableMap(i, newArray, growAtCount);
+ PersistentHashtableMap ret = new PersistentHashtableMap(i, newArray, growAtCount);
+ ret._meta = _meta;
+ return ret;
}