super(changes);
}
+ public AddDeleteUpdateOp(boolean add, GraphChanges changes) {
+ super(changes);
+ this.add = add;
+ }
+
@Override
public boolean isAdd() {
return add;
@Override
public boolean requiresOp(UpdateOp op) {
if (add) {
- if (getParentOps().contains(op))
+ if (getParentOps().contains(op) && op.isAdd())
return true;
} else {
- if (getSubOps().contains(op))
+ if (getSubOps().contains(op) && op.isDelete())
return true;
}
return false;
}
}
- protected static void copyProperties(WriteGraph g, Resource source, Resource destination) throws DatabaseException {
+ public static void copyProperties(WriteGraph g, Resource source, Resource destination) throws DatabaseException {
Layer0 l0 = Layer0.getInstance(g);
for (Statement s : g.getStatements(source, l0.HasProperty)) {
if (s.isAsserted(source))
continue;
if (g.isInstanceOf(s.getObject(), l0.Literal)) {
Object value = g.getPossibleValue(s.getObject());
- System.out.println(NameUtils.getSafeName(g, s.getSubject()) + " " + NameUtils.getSafeName(g, s.getPredicate()) + " " + NameUtils.getSafeName(g, s.getObject()) + " " + value);
+ //System.out.println(NameUtils.getSafeName(g, s.getSubject()) + " " + NameUtils.getSafeName(g, s.getPredicate()) + " " + NameUtils.getSafeName(g, s.getObject()) + " " + value);
if (value != null) {
Statement valueStm = g.getPossibleStatement(destination, s.getPredicate());
Resource valueResource = null;
g.claim(destination, s.getPredicate(), valueResource);
copyProperties(g, s.getObject(), valueResource);
} else {
- throw new DatabaseException("Expected to copy property resource " + s.getObject());
+ Resource type = g.getPossibleType(s.getObject(), l0.Value);
+ if (type != null && g.hasStatement(type, l0.Enumeration, type)) {
+ g.deny(destination, s.getPredicate());
+ g.claim(destination, s.getPredicate(), s.getObject());
+ } else {
+ throw new DatabaseException("Expected to copy property resource " + s.getObject());
+ }
+ }
+ }
+ }
+
+ public static void copyTags(WriteGraph g, Resource source, Resource destination) throws DatabaseException {
+ Layer0 L0 = Layer0.getInstance(g);
+ for (Statement s : g.getStatements(source, L0.IsWeaklyRelatedTo)) {
+ if (s.getObject().equals(source)) {
+ g.claim(destination, s.getPredicate(), destination);
}
}
}
+ public static void copyTypes(WriteGraph g, Resource source, Resource destination) throws DatabaseException {
+ Layer0 L0 = Layer0.getInstance(g);
+ for (Resource r : g.getObjects(source, L0.InstanceOf))
+ g.claim(destination, L0.InstanceOf, r);
+ for (Resource r : g.getObjects(source, L0.Inherits))
+ g.claim(destination, L0.Inherits, r);
+ for (Resource r : g.getObjects(source, L0.SubrelationOf))
+ g.claim(destination, L0.SubrelationOf, r);
+ }
+
protected void copyIssues(WriteGraph g, Resource source, Resource destination) throws DatabaseException {
Layer0 l0 = Layer0.getInstance(g);
IssueResource ir = IssueResource.getInstance(g);