X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=org.argeo.api%2Fsrc%2Forg%2Fargeo%2Fapi%2Fgcr%2Fspi%2FAbstractContent.java;h=2d3bcde93c9f23228e2f00c187f2802f903ee936;hb=865fc51900459b888938cc0d6943673ee6f20d09;hp=79c59f2f66ad06c0b1cf2ca74b0b6917f1610b9a;hpb=51efb630db7314b67654a03d1bd983b45aa2f1ed;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 79c59f2f6..2d3bcde93 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 @@ -3,46 +3,78 @@ package org.argeo.api.gcr.spi; import java.util.AbstractMap; import java.util.AbstractSet; import java.util.ArrayList; +import java.util.Collections; import java.util.Iterator; import java.util.List; import java.util.Map; +import java.util.Optional; import java.util.Set; +import javax.xml.namespace.QName; + import org.argeo.api.gcr.Content; +import org.argeo.api.gcr.CrName; + +public abstract class AbstractContent extends AbstractMap implements Content { + + /* + * ATTRIBUTES OPERATIONS + */ + protected abstract Iterable keys(); -public abstract class AbstractContent extends AbstractMap implements Content { + protected abstract void removeAttr(QName key); @Override - public Set> entrySet() { -// 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(); + public Set> entrySet() { + Set> result = new AttrSet(); return result; } - protected abstract Iterable keys(); + @Override + public Class getType(QName key) { + return String.class; + } + + @Override + public boolean isMultiple(QName key) { + return false; + } + + @Override + public Optional> getMultiple(QName key, Class clss) { + Object value = get(key); + if (value == null) + return null; + if (value instanceof List) { + try { + List res = (List) value; + return Optional.of(res); + } catch (ClassCastException e) { + List res = new ArrayList<>(); + List lst = (List) value; + try { + for (Object o : lst) { + A item = (A) o; + res.add(item); + } + return Optional.of(res); + } catch (ClassCastException e1) { + return Optional.empty(); + } + } + } else {// singleton + try { + A res = (A) value; + return Optional.of(Collections.singletonList(res)); + } catch (ClassCastException e) { + return Optional.empty(); + } + } + } - protected abstract void removeAttr(String key); + /* + * CONTENT OPERATIONS + */ @Override public String getPath() { @@ -50,8 +82,9 @@ public abstract class AbstractContent extends AbstractMap implem collectAncestors(ancestors, this); StringBuilder path = new StringBuilder(); for (Content c : ancestors) { - String name = c.getName(); - if (!"".equals(name)) + QName name = c.getName(); + // FIXME + if (!CrName.ROOT.get().equals(name)) path.append('/').append(name); } return path.toString(); @@ -74,21 +107,21 @@ public abstract class AbstractContent extends AbstractMap implem @Override public String toString() { - return "content "+getPath(); + return "content " + getPath(); } /* * SUB CLASSES */ - class AttrSet extends AbstractSet> { + class AttrSet extends AbstractSet> { @Override - public Iterator> iterator() { - final Iterator keys = keys().iterator(); - Iterator> it = new Iterator>() { + public Iterator> iterator() { + final Iterator keys = keys().iterator(); + Iterator> it = new Iterator>() { - String key = null; + QName key = null; @Override public boolean hasNext() { @@ -96,11 +129,12 @@ public abstract class AbstractContent extends AbstractMap implem } @Override - public Entry next() { + public Entry next() { key = keys.next(); // TODO check type - Object value = get(key, Object.class); - AbstractMap.SimpleEntry entry = new SimpleEntry<>(key, value); + Optional value = get(key, Object.class); + assert !value.isEmpty(); + AbstractMap.SimpleEntry entry = new SimpleEntry<>(key, value.get()); return entry; } @@ -120,7 +154,7 @@ public abstract class AbstractContent extends AbstractMap implem @Override public int size() { int count = 0; - for (String key : keys()) { + for (QName key : keys()) { count++; } return count;