io.rsocket.internal.jctools.queues.MessagePassingQueueUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of rsocket-core Show documentation
Show all versions of rsocket-core Show documentation
Core functionality for the RSocket library
The newest version!
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.rsocket.internal.jctools.queues;
import io.rsocket.internal.jctools.queues.MessagePassingQueue.Consumer;
import io.rsocket.internal.jctools.queues.MessagePassingQueue.ExitCondition;
import io.rsocket.internal.jctools.queues.MessagePassingQueue.Supplier;
import io.rsocket.internal.jctools.queues.MessagePassingQueue.WaitStrategy;
final class MessagePassingQueueUtil {
public static int drain(MessagePassingQueue queue, Consumer c, int limit) {
if (null == c) throw new IllegalArgumentException("c is null");
if (limit < 0) throw new IllegalArgumentException("limit is negative: " + limit);
if (limit == 0) return 0;
E e;
int i = 0;
for (; i < limit && (e = queue.relaxedPoll()) != null; i++) {
c.accept(e);
}
return i;
}
public static int drain(MessagePassingQueue queue, Consumer c) {
if (null == c) throw new IllegalArgumentException("c is null");
E e;
int i = 0;
while ((e = queue.relaxedPoll()) != null) {
i++;
c.accept(e);
}
return i;
}
public static void drain(
MessagePassingQueue queue, Consumer c, WaitStrategy wait, ExitCondition exit) {
if (null == c) throw new IllegalArgumentException("c is null");
if (null == wait) throw new IllegalArgumentException("wait is null");
if (null == exit) throw new IllegalArgumentException("exit condition is null");
int idleCounter = 0;
while (exit.keepRunning()) {
final E e = queue.relaxedPoll();
if (e == null) {
idleCounter = wait.idle(idleCounter);
continue;
}
idleCounter = 0;
c.accept(e);
}
}
public static void fill(
MessagePassingQueue q, Supplier s, WaitStrategy wait, ExitCondition exit) {
if (null == wait) throw new IllegalArgumentException("waiter is null");
if (null == exit) throw new IllegalArgumentException("exit condition is null");
int idleCounter = 0;
while (exit.keepRunning()) {
if (q.fill(s, PortableJvmInfo.RECOMENDED_OFFER_BATCH) == 0) {
idleCounter = wait.idle(idleCounter);
continue;
}
idleCounter = 0;
}
}
public static int fillBounded(MessagePassingQueue q, Supplier s) {
return fillInBatchesToLimit(q, s, PortableJvmInfo.RECOMENDED_OFFER_BATCH, q.capacity());
}
public static int fillInBatchesToLimit(
MessagePassingQueue q, Supplier s, int batch, int limit) {
long result =
0; // result is a long because we want to have a safepoint check at regular intervals
do {
final int filled = q.fill(s, batch);
if (filled == 0) {
return (int) result;
}
result += filled;
} while (result <= limit);
return (int) result;
}
public static int fillUnbounded(MessagePassingQueue q, Supplier s) {
return fillInBatchesToLimit(q, s, PortableJvmInfo.RECOMENDED_OFFER_BATCH, 4096);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy