X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-remoterpc-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fremote%2Frpc%2Fregistry%2Fgossip%2FBucketImpl.java;h=daf945289c42b65b6adc1d0c8d31529749a378b5;hp=444faed6bd38a5882f28b2d55e5ef6f26c472a33;hb=5b66dd8f5e3467a07e77b20fe696b29993ce5565;hpb=9ddc65e1ddae50f691566cd9382707679436c055 diff --git a/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/registry/gossip/BucketImpl.java b/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/registry/gossip/BucketImpl.java index 444faed6bd..daf945289c 100644 --- a/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/registry/gossip/BucketImpl.java +++ b/opendaylight/md-sal/sal-remoterpc-connector/src/main/java/org/opendaylight/controller/remote/rpc/registry/gossip/BucketImpl.java @@ -7,34 +7,25 @@ */ package org.opendaylight.controller.remote.rpc.registry.gossip; +import com.google.common.base.Preconditions; +import com.google.common.base.Verify; import java.io.Serializable; -public class BucketImpl> implements Bucket, Serializable { - private static final long serialVersionUID = 294779770032719196L; +final class BucketImpl> implements Bucket, Serializable { + private static final long serialVersionUID = 1L; - private Long version = System.currentTimeMillis(); + private final long version; - private T data; + // Guaranteed to be non-null + private final T data; - public BucketImpl() { - } - - public BucketImpl(T data) { - this.data = data; - } - - public BucketImpl(Bucket other) { - this.version = other.getVersion(); - this.data = other.getData(); - } - - public void setData(T data) { - this.data = data; - this.version = System.currentTimeMillis() + 1; + BucketImpl(final long version, final T data) { + this.version = version; + this.data = Preconditions.checkNotNull(data); } @Override - public Long getVersion() { + public long getVersion() { return version; } @@ -47,4 +38,9 @@ public class BucketImpl> implements Bucket, Serializable public String toString() { return "BucketImpl{" + "version=" + version + ", data=" + data + '}'; } + + private Object readResolve() { + Verify.verifyNotNull(data); + return this; + } }