- public Object toSerializable() {
- return ThreePhaseCommitCohortMessages.CanCommitTransactionReply.newBuilder().setCanCommit(canCommit).build();
+ 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
+ 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) {
+ Preconditions.checkArgument(serializable instanceof CanCommitTransactionReply);
+ return (CanCommitTransactionReply)serializable;