X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.api%2Fsrc%2Forg%2Fargeo%2Fapi%2Fgcr%2Fspi%2FAbstractContent.java;fp=org.argeo.api%2Fsrc%2Forg%2Fargeo%2Fapi%2Fgcr%2Fspi%2FAbstractContent.java;h=79c59f2f66ad06c0b1cf2ca74b0b6917f1610b9a;hb=51efb630db7314b67654a03d1bd983b45aa2f1ed;hp=2da186ef2538eb6d2d1f2da67be1d9dae6675d6a;hpb=62f4b67f846f67cdfd96340684e9fcf73bbd14ef;p=lgpl%2Fargeo-commons.git diff --git a/org.argeo.api/src/org/argeo/api/gcr/spi/AbstractContent.java b/org.argeo.api/src/org/argeo/api/gcr/spi/AbstractContent.java index 2da186ef2..79c59f2f6 100644 --- a/org.argeo.api/src/org/argeo/api/gcr/spi/AbstractContent.java +++ b/org.argeo.api/src/org/argeo/api/gcr/spi/AbstractContent.java @@ -1,7 +1,11 @@ package org.argeo.api.gcr.spi; import java.util.AbstractMap; -import java.util.HashSet; +import java.util.AbstractSet; +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; +import java.util.Map; import java.util.Set; import org.argeo.api.gcr.Content; @@ -10,39 +14,117 @@ public abstract class AbstractContent extends AbstractMap implem @Override public Set> entrySet() { - Set> result = new HashSet<>(); - for (String key : keys()) { - Entry entry = new Entry() { +// Set> result = new HashSet<>(); +// for (String key : keys()) { +// Entry entry = new Entry() { +// +// @Override +// public String getKey() { +// return key; +// } +// +// @Override +// public Object getValue() { +// return get(key, Object.class); +// } +// +// @Override +// public Object setValue(Object value) { +// throw new UnsupportedOperationException(); +// } +// +// }; +// result.add(entry); +// } + Set> result = new AttrSet(); + return result; + } + + protected abstract Iterable keys(); + + protected abstract void removeAttr(String key); + + @Override + public String getPath() { + List ancestors = new ArrayList<>(); + collectAncestors(ancestors, this); + StringBuilder path = new StringBuilder(); + for (Content c : ancestors) { + String name = c.getName(); + if (!"".equals(name)) + path.append('/').append(name); + } + return path.toString(); + } + + private void collectAncestors(List ancestors, Content content) { + if (content == null) + return; + ancestors.add(0, content); + collectAncestors(ancestors, content.getParent()); + } + + /* + * UTILITIES + */ + protected boolean isDefaultAttrTypeRequested(Class clss) { + // check whether clss is Object.class + return clss.isAssignableFrom(Object.class); + } + + @Override + public String toString() { + return "content "+getPath(); + } + + /* + * SUB CLASSES + */ + + class AttrSet extends AbstractSet> { + + @Override + public Iterator> iterator() { + final Iterator keys = keys().iterator(); + Iterator> it = new Iterator>() { + + String key = null; @Override - public String getKey() { - return key; + public boolean hasNext() { + return keys.hasNext(); } @Override - public Object getValue() { + public Entry next() { + key = keys.next(); // TODO check type - return get(key, Object.class); + Object value = get(key, Object.class); + AbstractMap.SimpleEntry entry = new SimpleEntry<>(key, value); + return entry; } @Override - public Object setValue(Object value) { - throw new UnsupportedOperationException(); + public void remove() { + if (key != null) { + AbstractContent.this.removeAttr(key); + } else { + throw new IllegalStateException("Iteration has not started"); + } } }; - result.add(entry); + return it; + } + + @Override + public int size() { + int count = 0; + for (String key : keys()) { + count++; + } + return count; } - return result; - } - protected abstract Iterable keys(); - - /* - * UTILITIES - */ - protected boolean isDefaultAttrTypeRequested(Class clss) { - // check whether clss is Object.class - return clss.isAssignableFrom(Object.class); } }