Motivation: It's good to minimize potentially broken windows. Modifications: Fix most inspector warnings from our profile Update IntObjectHashMap Result: Cleaner code
87 lines
2.8 KiB
Java
87 lines
2.8 KiB
Java
/*
|
|
* Copyright 2013 The Netty Project
|
|
*
|
|
* The Netty Project licenses this file to you 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.netty.util.concurrent;
|
|
|
|
import java.util.Arrays;
|
|
|
|
final class DefaultFutureListeners {
|
|
|
|
private GenericFutureListener<? extends Future<?>>[] listeners;
|
|
private int size;
|
|
private int progressiveSize; // the number of progressive listeners
|
|
|
|
@SuppressWarnings("unchecked")
|
|
DefaultFutureListeners(
|
|
GenericFutureListener<? extends Future<?>> first, GenericFutureListener<? extends Future<?>> second) {
|
|
listeners = new GenericFutureListener[2];
|
|
listeners[0] = first;
|
|
listeners[1] = second;
|
|
size = 2;
|
|
if (first instanceof GenericProgressiveFutureListener) {
|
|
progressiveSize ++;
|
|
}
|
|
if (second instanceof GenericProgressiveFutureListener) {
|
|
progressiveSize ++;
|
|
}
|
|
}
|
|
|
|
public void add(GenericFutureListener<? extends Future<?>> l) {
|
|
GenericFutureListener<? extends Future<?>>[] listeners = this.listeners;
|
|
final int size = this.size;
|
|
if (size == listeners.length) {
|
|
this.listeners = listeners = Arrays.copyOf(listeners, size << 1);
|
|
}
|
|
listeners[size] = l;
|
|
this.size = size + 1;
|
|
|
|
if (l instanceof GenericProgressiveFutureListener) {
|
|
progressiveSize ++;
|
|
}
|
|
}
|
|
|
|
public void remove(GenericFutureListener<? extends Future<?>> l) {
|
|
final GenericFutureListener<? extends Future<?>>[] listeners = this.listeners;
|
|
int size = this.size;
|
|
for (int i = 0; i < size; i ++) {
|
|
if (listeners[i] == l) {
|
|
int listenersToMove = size - i - 1;
|
|
if (listenersToMove > 0) {
|
|
System.arraycopy(listeners, i + 1, listeners, i, listenersToMove);
|
|
}
|
|
listeners[-- size] = null;
|
|
this.size = size;
|
|
|
|
if (l instanceof GenericProgressiveFutureListener) {
|
|
progressiveSize --;
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
public GenericFutureListener<? extends Future<?>>[] listeners() {
|
|
return listeners;
|
|
}
|
|
|
|
public int size() {
|
|
return size;
|
|
}
|
|
|
|
public int progressiveSize() {
|
|
return progressiveSize;
|
|
}
|
|
}
|