blob: 5ad5b75027c4edf9e4765c10dd6e10a62cef22a8 [file] [log] [blame]
/*=============================================================================#
# Copyright (c) 2016, 2021 Stephan Wahlbrink and others.
#
# This program and the accompanying materials are made available under the
# terms of the Eclipse Public License 2.0 which is available at
# https://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
# which is available at https://www.apache.org/licenses/LICENSE-2.0.
#
# SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
#
# Contributors:
# Stephan Wahlbrink <sw@wahlbrink.eu> - initial API and implementation
#=============================================================================*/
package org.eclipse.statet.rj.servi.pool;
import org.eclipse.statet.jcommons.lang.NonNullByDefault;
import org.eclipse.statet.jcommons.lang.Nullable;
import org.eclipse.statet.internal.rj.servi.NodeHandler;
@NonNullByDefault
public interface PoolNodeObject {
@Nullable NodeHandler getNodeHandler();
/**
* Returns the time of the creation of the node.
*
* @return the time in milliseconds (as specified by {@link System#currentTimeMillis()})
*/
long getCreationTime();
/**
* Returns the count of allocation of this node.
*
* If the node is currently allocated, the current allocation is included in the returned
* number.
*
* @return the count
*/
long getAllocationCount();
/**
* Returns the duration of the latest allocation, if available.
*
* If the node is currently allocated, it is the duration of the current allocation at this
* time.
*
* @return the duration in milliseconds, or {@code -1} if not available
*/
long getLastestAllocationDuration();
/**
* Returns the current state.
*
* @return the current state
*/
PoolNodeState getState();
long getStateTime();
@Nullable String getClientLabel();
void evict(long timeoutMillis);
}