Class RangeSet
This is useful if one is going to be doing work that will carve out pieces from another subspace and work on those separately. The methods in here will allow for a (more-or-less) append only set that can be used to keep track of the progress that that job is making.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intValue indicating that there should be no limit.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidclear(Transaction tr) Clears the subspace used by this RangeSet instance.Clears the subspace used by this RangeSet instance.contains(TransactionContext tc, byte[] key) Determines if a single key is contained within the range set.insertRange(TransactionContext tc, byte[] begin, byte[] end) Inserts a range into the set.insertRange(TransactionContext tc, byte[] begin, byte[] end, boolean requireEmpty) Inserts a range into the set.insertRange(TransactionContext tc, Range r) Inserts a range into the set.insertRange(TransactionContext tc, Range r, boolean requireEmpty) Inserts a range into the set.isEmpty(ReadTransaction rtr) Determine whether this range set is empty.Determine whether this range set is empty.static booleanisFinalKey(byte[] key) static booleanisFirstKey(byte[] key) Returns all of the ranges that are missing within this set.Returns all of the ranges that are missing within this set as list.missingRanges(ReadTransactionContext tc, byte[] begin, byte[] end) Returns all of the ranges that are missing within a given set of bounds as a list.missingRanges(ReadTransactionContext tc, byte[] begin, byte[] end, int limit) Returns all of the ranges that are missing within a given set of bounds as a list.missingRanges(ReadTransactionContext tc, Range superRange) Returns all of the ranges that are missing within a given range as a list.missingRanges(ReadTransaction tr, byte[] begin, byte[] end) Returns all of the ranges that are missing within a given set of bounds as a list.missingRanges(ReadTransaction tr, byte[] begin, byte[] end, int limit) Returns all of the ranges that are missing within a given set of bounds.missingRanges(ReadTransaction tr, Range superRange) Returns all of the ranges that are missing within a given range.
- 
Field Details- 
UNLIMITEDpublic static final int UNLIMITEDValue indicating that there should be no limit. This should be passed tomissingRangesto indicate that the read should not limit the number of results it returns.- See Also:
 
 
- 
- 
Constructor Details- 
RangeSetCreates a new RangeSet that will write its data to the given subspace provided. The contents of this subspace should either be empty or contain the data used by another RangeSet object.- Parameters:
- subspace- the subspace in which to write data
 
 
- 
- 
Method Details- 
isFirstKeypublic static boolean isFirstKey(@Nonnull byte[] key) 
- 
isFinalKeypublic static boolean isFinalKey(@Nonnull byte[] key) 
- 
contains@Nonnull public CompletableFuture<Boolean> contains(@Nonnull TransactionContext tc, @Nonnull byte[] key) Determines if a single key is contained within the range set. If it is, this will returntrue, and if it is not, it will returnfalse. In terms of isolation, this adds a read- conflict to the key corresponding to the key being checked but to nothing else even though it has to do a range read that might be larger. This means that updates to keys before this won't conflict unless they actually change whether this key is contained within the range set.- Parameters:
- tc- transaction or database in which to run operation
- key- the key to check presence in set
- Returns:
- a future that contains whether some range in the set contains the key
 
- 
insertRange@Nonnull public CompletableFuture<Boolean> insertRange(@Nonnull TransactionContext tc, @Nonnull Range r) Inserts a range into the set. This behaves the same way as the four-parameter version ofRangeSet.insertRange(including conflict settings), but it gets its begin and end from the givenRangeobject and assumes thatrequiresEmptyisfalse, i.e., it is okay for there already to be data within the given range.- Parameters:
- tc- the transaction or database in which to operate
- r- the range to add to the set
- Returns:
- a future that is trueif there were any modifications to the database andfalseotherwise
 
- 
insertRange@Nonnull public CompletableFuture<Boolean> insertRange(@Nonnull TransactionContext tc, @Nonnull Range r, boolean requireEmpty) Inserts a range into the set. This behaves the same way as the four-parmater version ofRangeSet.insertRange(including conflict settings), but it gets its begin and end from the givenRangeobject.- Parameters:
- tc- the transaction or database in which to operate
- r- the range to add to the set
- requireEmpty- whether this should only be added if this range is initally empty
- Returns:
- a future that is trueif there were any modifications to the database andfalseotherwise
 
- 
insertRange@Nonnull public CompletableFuture<Boolean> insertRange(@Nonnull TransactionContext tc, @Nullable byte[] begin, @Nullable byte[] end) Inserts a range into the set. This behaves the same way as the four-parameter version ofRangeSet.insertRange(including conflict settings), but it assumes thatrequiresEmptyisfalse, i.e., it is okay for there already to be data within the given range.- Parameters:
- tc- the transaction or database in which to operate
- begin- the (inclusive) beginning of the range to add
- end- the (exclusive) end of the range to add
- Returns:
- a future that is trueif there were any modifications to the database andfalseotherwise
 
- 
insertRange@Nonnull public CompletableFuture<Boolean> insertRange(@Nonnull TransactionContext tc, @Nullable byte[] begin, @Nullable byte[] end, boolean requireEmpty) Inserts a range into the set. The range inserted will begin atbegin(inclusive) and end atend(exclusive). If therequireEmptyis set, then this will only actually change the database in the case that the range being added is not yet included in the set. If this flag is set tofalse, then this will "fill in the gaps" between ranges present so that the whole range is present following this transactions operation. The return value will (when ready) be equal totrueif and only if there are changes (i.e., writes) to the database that need to be made, i.e., the range was not already included in the set. If the initial end point is less than the begin point, then this will throw anIllegalArgumentExceptionindicating that one has passed an inverted range. Ifbeginandendare equal, then this will immediately return a future that is set tofalse(corresponding to adding an empty range). Ifnullis set for either endpoint, this will insert a range all the way to the end of the total range.In terms of isolation, this method will add both read- and write-conflict ranges. It adds a read-conflict range corresponding to the range being added, i.e., for the keys within the range from begintoend. This is so that if this range is modified concurrently by another writer, this transaction will fail (as the exact writes done depend on these keys not being modified.) It will also a write-conflict ranges corresponding to all of the individual ranges added to the database. That means that if the range is initially empty, a write-conflict range corresponding to the keys frombegintoend. This is done so that if another transaction checks to see if a key in the range we are writing is within the range set and finds that it is not, this write will then cause that transaction to fail if it is committed after this one. If the range is not empty initially, write conflict ranges are added for all of the "gaps" that have to be added. (So, if the range is already full, then no write conflict ranges are added at all.)- Parameters:
- tc- the transaction or database in which to operate
- begin- the (inclusive) beginning of the range to add
- end- the (exclusive) end of the range to add
- requireEmpty- whether this should only be added if this range is initially empty
- Returns:
- a future that is trueif there were any modifications to the database andfalseotherwise
 
- 
missingRangesReturns all of the ranges that are missing within this set as list. See the three-parameter version ofRangeSet.missingRangesfor more details, but this will look from the beginning of the valid keys within this set to the end and find any gaps between ranges that need to be filled.- Parameters:
- tc- transaction that will be used to access the database
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRangesReturns all of the ranges that are missing within this set. See the three-parameter version ofRangeSet.missingRangesfor more details, but this will look from the beginning of the valid keys within this set to the end and find any gaps between ranges that need to be filled.- Parameters:
- tr- transaction that will be used to access the database
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRanges@Nonnull public CompletableFuture<List<Range>> missingRanges(@Nonnull ReadTransactionContext tc, @Nonnull Range superRange) Returns all of the ranges that are missing within a given range as a list. See the four-parameter version ofRangeSet.missingRangesfor more details, but this will look for ranges that aren't already within the set.- Parameters:
- tc- transaction that will be used to access the database
- superRange- the range within to search for additional ranges
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRanges@Nonnull public AsyncIterable<Range> missingRanges(@Nonnull ReadTransaction tr, @Nonnull Range superRange) Returns all of the ranges that are missing within a given range. See the four-parameter version ofRangeSet.missingRangesfor more details, but this will look for ranges that aren't already within the set.- Parameters:
- tr- transaction that will be used to access the database
- superRange- the range within to search for additional ranges
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRanges@Nonnull public CompletableFuture<List<Range>> missingRanges(@Nonnull ReadTransactionContext tc, @Nullable byte[] begin, @Nullable byte[] end) Returns all of the ranges that are missing within a given set of bounds as a list. See the four-parameter version ofRangeSet.missingRangesfor more details, but this will look for ranges that aren't already within the set.- Parameters:
- tc- transaction that will be used to access the database
- begin- the beginning (inclusive) of the range to look for gaps
- end- the end (inclusive) of the range to look for gaps
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRanges@Nonnull public AsyncIterable<Range> missingRanges(@Nonnull ReadTransaction tr, @Nullable byte[] begin, @Nullable byte[] end) Returns all of the ranges that are missing within a given set of bounds as a list. See the four-parameter version ofRangeSet.missingRangesfor more details, but this will look for ranges that aren't already within the set. It will not limit the number of results that it will return.- Parameters:
- tr- transaction that will be used to access the database
- begin- the beginning (inclusive) of the range to look for gaps
- end- the end (inclusive) of the range to look for gaps
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRanges@Nonnull public CompletableFuture<List<Range>> missingRanges(@Nonnull ReadTransactionContext tc, @Nullable byte[] begin, @Nullable byte[] end, int limit) Returns all of the ranges that are missing within a given set of bounds as a list. See the four-parameter version ofRangeSet.missingRangesfor more details, but this will look for ranges that aren't already within the set. It will not limit the number of results that it will return.- Parameters:
- tc- transaction that will be used to access the database
- begin- the beginning (inclusive) of the range to look for gaps
- end- the end (inclusive) of the range to look for gaps
- limit- the maximum number of results to return
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
missingRanges@Nonnull public AsyncIterable<Range> missingRanges(@Nonnull ReadTransaction tr, @Nullable byte[] begin, @Nullable byte[] end, int limit) Returns all of the ranges that are missing within a given set of bounds. In particular, this will look for "gaps" in the key-value pairs between begin (inclusive) and end (exclusive) so that at the end, we know what is missing. This takes in a read transaction (which could, theoretically, be a snapshot read if we so desired). If this transaction is committed before the iterator is cancelled or completes, this can cause problems.- Parameters:
- tr- transaction that will be used to access the database
- begin- the beginning (inclusive) of the range to look for gaps
- end- the end (inclusive) of the range to look for gaps
- limit- the maximum number of results to return
- Returns:
- an iterable that will produce all of the missing ranges
 
- 
isEmptyDetermine whether this range set is empty. If given aDatabase, this will create a transaction and use it to read from the database. If given aReadTransaction, it will use the provided transaction. SeeisEmpty(ReadTransaction)for more details on the semantics of this function.- Parameters:
- rtc- transaction or database object that will be used to read from the database
- Returns:
- a future that will contain trueif there are no ranges in this set orfalseotherwise
- See Also:
 
- 
isEmptyDetermine whether this range set is empty. This will scan the given range set and returntrueif no ranges have been inserted into the data structure. Otherwise, it will returnfalse.- Parameters:
- rtr- transaction that will be used to read from the database
- Returns:
- a future that will contain trueif there are no ranges in this set orfalseotherwise
 
- 
clearClears the subspace used by this RangeSet instance. This will remove all ranges from this set.- Parameters:
- tr- transaction with which to run the operation
 
- 
clearClears the subspace used by this RangeSet instance. This will remove all ranges from this set.- Parameters:
- tc- transaction or database in which to run operation
- Returns:
- a future that is completed when the range has been cleared
 
- 
rep
 
-