From 5e294dbd586034b23484adb3c0c4de0f6acd901c Mon Sep 17 00:00:00 2001 From: Andrew Branson Date: Tue, 16 Sep 2014 08:49:21 +0200 Subject: Abstract properties. Activities cannot be instantiated unless the slot overrides them. Fixes #190 --- .../com/c2kernel/lifecycle/ActivitySlotDef.java | 19 +++++++++++-- .../java/com/c2kernel/lifecycle/WfVertexDef.java | 2 +- .../java/com/c2kernel/utils/CastorHashMap.java | 33 ++++++++++++++++++++-- src/main/java/com/c2kernel/utils/KeyValuePair.java | 16 +++++++++-- 4 files changed, 61 insertions(+), 9 deletions(-) (limited to 'src/main/java') diff --git a/src/main/java/com/c2kernel/lifecycle/ActivitySlotDef.java b/src/main/java/com/c2kernel/lifecycle/ActivitySlotDef.java index 85c942f..004d4c1 100644 --- a/src/main/java/com/c2kernel/lifecycle/ActivitySlotDef.java +++ b/src/main/java/com/c2kernel/lifecycle/ActivitySlotDef.java @@ -97,6 +97,18 @@ public class ActivitySlotDef extends WfVertexDef } } } + + KeyValuePair[] props; + try { + props = getTheActivityDef().getProperties().getKeyValuePairs(); + for (KeyValuePair prop : props) { + if (prop.isAbstract() && !getProperties().containsKey(prop.getKey())) { + mErrors.add("Abstract property '"+prop.getKey()+"' not defined in slot"); + err = false; + } + } + } catch (Exception ex) { } + // Loop check Vertex[] outV = getOutGraphables(); @@ -138,11 +150,11 @@ public class ActivitySlotDef extends WfVertexDef * * @return CastorHashMap */ - public void configureInstance(Activity act) + private void configureInstance(Activity act) { KeyValuePair[] k = getProperties().getKeyValuePairs(); for (KeyValuePair element : k) - act.getProperties().put(element.getKey(), element.getValue()); + act.getProperties().put(element.getKey(), element.getValue(), element.isAbstract()); act.setCentrePoint(getCentrePoint()); act.setOutlinePoints(getOutlinePoints()); act.setInEdgeIds(getInEdgeIds()); @@ -160,6 +172,9 @@ public class ActivitySlotDef extends WfVertexDef public WfVertex instantiate() throws ObjectNotFoundException, InvalidDataException { Activity newActivity = (Activity)getTheActivityDef().instantiate(); configureInstance(newActivity); + if (newActivity.getProperties().getAbstract().size() > 0) { + throw new InvalidDataException("Abstract properties not overridden: "+newActivity.getProperties().getAbstract().toString(), ""); + } return newActivity; } } diff --git a/src/main/java/com/c2kernel/lifecycle/WfVertexDef.java b/src/main/java/com/c2kernel/lifecycle/WfVertexDef.java index b2bd306..b0a6938 100644 --- a/src/main/java/com/c2kernel/lifecycle/WfVertexDef.java +++ b/src/main/java/com/c2kernel/lifecycle/WfVertexDef.java @@ -33,7 +33,7 @@ public abstract class WfVertexDef extends GraphableVertex public void configureInstance(WfVertex newVertex) { KeyValuePair[] k = getProperties().getKeyValuePairs(); for (KeyValuePair element : k) - newVertex.getProperties().put(element.getKey(), element.getValue()); + newVertex.getProperties().put(element.getKey(), element.getValue(), element.isAbstract()); newVertex.setID(getID()); if (getIsLayoutable()) { newVertex.setInEdgeIds(getInEdgeIds()); diff --git a/src/main/java/com/c2kernel/utils/CastorHashMap.java b/src/main/java/com/c2kernel/utils/CastorHashMap.java index 25e5ab4..2ec64fe 100644 --- a/src/main/java/com/c2kernel/utils/CastorHashMap.java +++ b/src/main/java/com/c2kernel/utils/CastorHashMap.java @@ -1,5 +1,6 @@ package com.c2kernel.utils; +import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; @@ -12,6 +13,8 @@ public class CastorHashMap extends HashMap { clear(); } + + ArrayList abstractPropNames = new ArrayList(); public KeyValuePair[] getKeyValuePairs() { @@ -24,8 +27,8 @@ public class CastorHashMap extends HashMap for(i=0; i } } - public void setKeyValuePair(KeyValuePair keyValuePair) + @Override + public void clear() { + super.clear(); + abstractPropNames = new ArrayList(); + } + + + public void setKeyValuePair(KeyValuePair keyValuePair) { put(keyValuePair.getKey(), keyValuePair.getValue()); + if (keyValuePair.isAbstract()) + abstractPropNames.add(keyValuePair.getKey()); + else + abstractPropNames.remove(keyValuePair.getKey()); } + public ArrayList getAbstract() { + return abstractPropNames; + } + + + public void put(String key, Object value, boolean isAbstract) { + super.put(key, value); + if (isAbstract) + abstractPropNames.add(key); + else + abstractPropNames.remove(key); + + } } diff --git a/src/main/java/com/c2kernel/utils/KeyValuePair.java b/src/main/java/com/c2kernel/utils/KeyValuePair.java index 5e5a147..92777f6 100644 --- a/src/main/java/com/c2kernel/utils/KeyValuePair.java +++ b/src/main/java/com/c2kernel/utils/KeyValuePair.java @@ -5,13 +5,15 @@ public class KeyValuePair { private String mKey = null; private Object mValue = null; + private boolean mAbstract = false; - public KeyValuePair() {} + public KeyValuePair() {} - public KeyValuePair(String key, Object value) + public KeyValuePair(String key, Object value, boolean isAbstract) { mKey = key; mValue = value; + mAbstract = isAbstract; } public String getKey() { @@ -30,7 +32,15 @@ public class KeyValuePair mValue = value; } - public String getStringValue() { + public void setAbstract(boolean isAbstract) { + mAbstract = isAbstract; + } + + public boolean isAbstract() { + return mAbstract; + } + + public String getStringValue() { if (mValue instanceof String) return (String)mValue; else -- cgit v1.2.3