diff options
author | Rich Hickey <richhickey@gmail.com> | 2006-07-28 18:51:47 +0000 |
---|---|---|
committer | Rich Hickey <richhickey@gmail.com> | 2006-07-28 18:51:47 +0000 |
commit | 709e897e44e353f2bda74d1f5b4bcaf413bf5a54 (patch) | |
tree | c948320ce2574b99495421c2f91ea50b50e0aa1d /src/jvm/clojure | |
parent | f6beae41f544340607bddb4a217abd249d085fc6 (diff) |
derived from Obj
Diffstat (limited to 'src/jvm/clojure')
-rw-r--r-- | src/jvm/clojure/lang/PersistentArrayIdentityMap.java | 15 | ||||
-rw-r--r-- | src/jvm/clojure/lang/PersistentArrayMap.java | 22 | ||||
-rw-r--r-- | src/jvm/clojure/lang/PersistentHashtableIdentityMap.java | 12 | ||||
-rw-r--r-- | src/jvm/clojure/lang/PersistentHashtableMap.java | 20 |
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;
}
|