|
|
@ -324,10 +324,6 @@ public class RedissonBoundedBlockingQueue<V> extends RedissonQueue<V> implements
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public int drainTo(Collection<? super V> c, int maxElements) {
|
|
|
|
public int drainTo(Collection<? super V> c, int maxElements) {
|
|
|
|
if (maxElements <= 0) {
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return get(drainToAsync(c, maxElements));
|
|
|
|
return get(drainToAsync(c, maxElements));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -336,7 +332,10 @@ public class RedissonBoundedBlockingQueue<V> extends RedissonQueue<V> implements
|
|
|
|
if (c == null) {
|
|
|
|
if (c == null) {
|
|
|
|
throw new NullPointerException();
|
|
|
|
throw new NullPointerException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (maxElements <= 0) {
|
|
|
|
|
|
|
|
return new CompletableFutureWrapper<>(0);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return commandExecutor.evalWriteAsync(getRawName(), codec, new RedisCommand<Object>("EVAL", new ListDrainToDecoder(c)),
|
|
|
|
return commandExecutor.evalWriteAsync(getRawName(), codec, new RedisCommand<Object>("EVAL", new ListDrainToDecoder(c)),
|
|
|
|
"local elemNum = math.min(ARGV[1], redis.call('llen', KEYS[1])) - 1;" +
|
|
|
|
"local elemNum = math.min(ARGV[1], redis.call('llen', KEYS[1])) - 1;" +
|
|
|
|
"local vals = redis.call('lrange', KEYS[1], 0, elemNum); " +
|
|
|
|
"local vals = redis.call('lrange', KEYS[1], 0, elemNum); " +
|
|
|
|