+ public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
+ super.readExternal(in);
+ canCommit = in.readBoolean();
+ }
+
+ @Override
+ public void writeExternal(ObjectOutput out) throws IOException {
+ super.writeExternal(out);
+ out.writeBoolean(canCommit);
+ }
+
+ @Override
+ protected Object newLegacySerializedInstance() {
+ return canCommit ? YES_SERIALIZED : NO_SERIALIZED;
+ }
+
+ @Override
+ public String toString() {
+ return "CanCommitTransactionReply [canCommit=" + canCommit + ", version=" + getVersion() + "]";
+ }
+
+ public static CanCommitTransactionReply yes(short version) {
+ return version == DataStoreVersions.CURRENT_VERSION ? YES : new CanCommitTransactionReply(true, version);
+ }
+
+ public static CanCommitTransactionReply no(short version) {
+ return version == DataStoreVersions.CURRENT_VERSION ? NO : new CanCommitTransactionReply(false, version);
+ }
+
+ public static CanCommitTransactionReply fromSerializable(final Object serializable) {
+ if(serializable instanceof CanCommitTransactionReply) {
+ return (CanCommitTransactionReply)serializable;
+ } else {
+ ThreePhaseCommitCohortMessages.CanCommitTransactionReply serialized =
+ (ThreePhaseCommitCohortMessages.CanCommitTransactionReply) serializable;
+ return serialized.getCanCommit() ? YES : NO;
+ }