* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
-
package org.opendaylight.controller.cluster.example.messages;
-import com.google.protobuf.GeneratedMessage;
-import java.io.Serializable;
-import java.util.Map;
-import org.opendaylight.controller.cluster.raft.protobuff.client.messages.Payload;
-import org.opendaylight.controller.protobuff.messages.cluster.raft.AppendEntriesMessages;
+import org.opendaylight.controller.cluster.raft.messages.Payload;
-public class KeyValue extends Payload implements Serializable {
+public final class KeyValue extends Payload {
private static final long serialVersionUID = 1L;
+
private String key;
private String value;
public KeyValue() {
}
- public KeyValue(String key, String value){
+ public KeyValue(final String key, final String value) {
this.key = key;
this.value = value;
}
return value;
}
- public void setKey(String key) {
- this.key = key;
- }
-
- public void setValue(String value) {
- this.value = value;
- }
-
- @Override public String toString() {
- return "KeyValue{" +
- "key='" + key + '\'' +
- ", value='" + value + '\'' +
- '}';
+ @Override
+ public int size() {
+ return value.length() + key.length();
}
- // override this method to return the protobuff related extension fields and their values
- @Override public Map<GeneratedMessage.GeneratedExtension<?, ?>, String> encode() {
- return null;
+ @Override
+ public int serializedSize() {
+ // Should be a better estimate
+ return size();
}
- // override this method to assign the values from protobuff
- @Override public Payload decode(AppendEntriesMessages.AppendEntries.ReplicatedLogEntry.Payload payloadProtoBuff) {
- return null;
+ @Override
+ public String toString() {
+ return "KeyValue{" + "key='" + key + '\'' + ", value='" + value + '\'' + '}';
}
@Override
- public int size() {
- return this.value.length() + this.key.length();
+ protected Object writeReplace() {
+ return new KVv1(value, key);
}
-
}