X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=org.simantics.interop.update%2Fsrc%2Forg%2Fsimantics%2Finterop%2Fupdate%2Fmodel%2FUpdateList.java;h=2267ebec6f47e8ec101a39d1945e19d99aa1325a;hb=6653e4a7d79b9766b6037111681d92f914c161b0;hp=6f66ba399326f0eb4ffa480d3b9d3874c54841f4;hpb=99e240f9ca43aa78fbc6d71d7905c38c00bc679a;p=simantics%2Finterop.git diff --git a/org.simantics.interop.update/src/org/simantics/interop/update/model/UpdateList.java b/org.simantics.interop.update/src/org/simantics/interop/update/model/UpdateList.java index 6f66ba3..2267ebe 100644 --- a/org.simantics.interop.update/src/org/simantics/interop/update/model/UpdateList.java +++ b/org.simantics.interop.update/src/org/simantics/interop/update/model/UpdateList.java @@ -10,28 +10,29 @@ import org.simantics.db.Resource; import org.simantics.db.Statement; import org.simantics.db.exception.DatabaseException; import org.simantics.interop.test.GraphChanges; +import org.simantics.interop.test.GraphChanges.Modification; import org.simantics.utils.datastructures.Pair; public class UpdateList { - private HashSet changes; + private List changes; public UpdateList() { - changes = new HashSet<>(); + changes = new ArrayList<>(); } public UpdateList(Collection changes) { - this.changes = new HashSet<>(changes); + this.changes = new ArrayList<>(changes); } - public UpdateList(GraphChanges graphChanges, Collection> coll) { - this.changes = new HashSet<>(); - for (Pair p : coll) { - changes.add(create(graphChanges, p)); + public UpdateList(GraphChanges graphChanges, Collection coll) { + this.changes = new ArrayList<>(); + for (Modification p : coll) { + addChange(create(graphChanges, p.getLeftSub(),p.getRightSub(),new Pair(p.getLeftStm(), p.getRightStm()))); } } - protected PropertyChange create(GraphChanges changes, Pair change) { - return new PropertyChange(changes, change); + protected PropertyChange create(GraphChanges changes, Resource left, Resource right, Pair change) { + return new PropertyChange(changes, left,right, change); } public Collection getChanges() { @@ -39,7 +40,8 @@ public class UpdateList { } public void addChange(PropertyChange change) { - changes.add(change); + if (!changes.contains(change)) + changes.add(change); } public void removeChange(PropertyChange change) {