X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FFrontendHistoryMetadataBuilder.java;h=beed765a690590bd8174210861a06c7a2b78f09c;hp=d8d7bdda217b9dd2c1144b4acfd901b2435acd79;hb=bfbc7893038987db21ed3ec5970a6de1c2a655de;hpb=edd61d79da614388134b0e0a618010c91e9c91bd diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendHistoryMetadataBuilder.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendHistoryMetadataBuilder.java index d8d7bdda21..beed765a69 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendHistoryMetadataBuilder.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/datastore/FrontendHistoryMetadataBuilder.java @@ -8,6 +8,13 @@ package org.opendaylight.controller.cluster.datastore; import com.google.common.base.Preconditions; +import com.google.common.collect.Range; +import com.google.common.collect.RangeSet; +import com.google.common.collect.TreeRangeSet; +import com.google.common.primitives.UnsignedLong; +import java.util.HashMap; +import java.util.Map; +import javax.annotation.Nonnull; import org.opendaylight.controller.cluster.access.concepts.ClientIdentifier; import org.opendaylight.controller.cluster.access.concepts.LocalHistoryIdentifier; import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier; @@ -15,19 +22,25 @@ import org.opendaylight.controller.cluster.datastore.persisted.FrontendHistoryMe import org.opendaylight.yangtools.concepts.Builder; import org.opendaylight.yangtools.concepts.Identifiable; -final class FrontendHistoryMetadataBuilder implements Builder, Identifiable { +final class FrontendHistoryMetadataBuilder implements Builder, + Identifiable { + + private final Map closedTransactions; + private final RangeSet purgedTransactions; private final LocalHistoryIdentifier identifier; - private long nextTransaction; private boolean closed; FrontendHistoryMetadataBuilder(final LocalHistoryIdentifier identifier) { this.identifier = Preconditions.checkNotNull(identifier); + this.purgedTransactions = TreeRangeSet.create(); + this.closedTransactions = new HashMap<>(2); } FrontendHistoryMetadataBuilder(final ClientIdentifier clientId, final FrontendHistoryMetadata meta) { identifier = new LocalHistoryIdentifier(clientId, meta.getHistoryId(), meta.getCookie()); - nextTransaction = meta.getNextTransaction(); + closedTransactions = new HashMap<>(meta.getClosedTransactions()); + purgedTransactions = TreeRangeSet.create(meta.getPurgedTransactions()); closed = meta.isClosed(); } @@ -38,14 +51,42 @@ final class FrontendHistoryMetadataBuilder implements Builder