Skip to content

Commit

Permalink
[cleanup][ml] ManagedCursor clean up. (apache#22246)
Browse files Browse the repository at this point in the history
(cherry picked from commit 532b0d9)
(cherry picked from commit d9d67da)
  • Loading branch information
dao-jun authored and nikhil-ctds committed Jun 7, 2024
1 parent 9eda9af commit 493657b
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ protected EntryImpl newObject(Handle<EntryImpl> handle) {
private long timestamp;
private long ledgerId;
private long entryId;
private PositionImpl position;
ByteBuf data;

private Runnable onDeallocate;
Expand Down Expand Up @@ -152,7 +153,10 @@ public int getLength() {

@Override
public PositionImpl getPosition() {
return new PositionImpl(ledgerId, entryId);
if (position == null) {
position = PositionImpl.get(ledgerId, entryId);
}
return position;
}

@Override
Expand Down Expand Up @@ -198,6 +202,7 @@ protected void deallocate() {
timestamp = -1;
ledgerId = -1;
entryId = -1;
position = null;
recyclerHandle.recycle(this);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1506,10 +1506,7 @@ public Set<? extends Position> asyncReplayEntries(Set<? extends Position> positi
Set<Position> alreadyAcknowledgedPositions = new HashSet<>();
lock.readLock().lock();
try {
positions.stream()
.filter(position -> ((PositionImpl) position).compareTo(markDeletePosition) <= 0
|| individualDeletedMessages.contains(position.getLedgerId(), position.getEntryId()))
.forEach(alreadyAcknowledgedPositions::add);
positions.stream().filter(this::isMessageDeleted).forEach(alreadyAcknowledgedPositions::add);
} finally {
lock.readLock().unlock();
}
Expand Down Expand Up @@ -2281,8 +2278,7 @@ public void asyncDelete(Iterable<Position> positions, AsyncCallbacks.DeleteCallb
return;
}

if (position.compareTo(markDeletePosition) <= 0
|| individualDeletedMessages.contains(position.getLedgerId(), position.getEntryId())) {
if (isMessageDeleted(position)) {
if (config.isDeletionAtBatchIndexLevelEnabled()) {
BitSetRecyclable bitSetRecyclable = batchDeletedIndexes.remove(position);
if (bitSetRecyclable != null) {
Expand Down Expand Up @@ -3541,8 +3537,7 @@ public Range<PositionImpl> getLastIndividualDeletedRange() {
@Override
public void trimDeletedEntries(List<Entry> entries) {
entries.removeIf(entry -> {
boolean isDeleted = markDeletePosition.compareTo(entry.getLedgerId(), entry.getEntryId()) >= 0
|| individualDeletedMessages.contains(entry.getLedgerId(), entry.getEntryId());
boolean isDeleted = isMessageDeleted(entry.getPosition());
if (isDeleted) {
entry.release();
}
Expand Down

0 comments on commit 493657b

Please sign in to comment.