From 923b0503c91aa4a9c0bc94489caddf9ac94c5ad8 Mon Sep 17 00:00:00 2001 From: Paul Buetow Date: Mon, 26 May 2008 22:14:52 +0000 Subject: Two phase commit protocol works. --- sources/protocols/implementations/OnePhaseCommitProtocol.java | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'sources/protocols/implementations/OnePhaseCommitProtocol.java') diff --git a/sources/protocols/implementations/OnePhaseCommitProtocol.java b/sources/protocols/implementations/OnePhaseCommitProtocol.java index a8d8d75..bc42c38 100644 --- a/sources/protocols/implementations/OnePhaseCommitProtocol.java +++ b/sources/protocols/implementations/OnePhaseCommitProtocol.java @@ -47,8 +47,10 @@ public class OnePhaseCommitProtocol extends VSAbstractProtocol { * @see protocols.VSAbstractProtocol#onClientReset() */ protected void onClientReset() { - pids.clear(); - pids.addAll(getVector("pids")); + if (pids != null) { + pids.clear(); + pids.addAll(getVector("pids")); + } } /* (non-Javadoc) @@ -58,7 +60,6 @@ public class OnePhaseCommitProtocol extends VSAbstractProtocol { if (pids == null) { pids = new ArrayList(); pids.addAll(getVector("pids")); - } if (pids.size() != 0) { @@ -82,6 +83,8 @@ public class OnePhaseCommitProtocol extends VSAbstractProtocol { Integer pid = recvMessage.getIntegerObj("pid"); if (pids.contains(pid)) pids.remove(pid); + else + return; logg("ACK von Prozess " + pid + " erhalten!"); -- cgit v1.2.3