io.vlingo.actors.RoundRobinRouter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vlingo-actors Show documentation
Show all versions of vlingo-actors Show documentation
Type safe Actor Model toolkit for reactive concurrency and resiliency using Java and other JVM languages.
// Copyright © 2012-2020 VLINGO LABS. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.
package io.vlingo.actors;
import java.util.List;
/**
* RoundRobinRouter
*/
public class RoundRobinRouter extends Router
{
protected int poolIndex;
public RoundRobinRouter(final RouterSpecification
specification) {
super(specification);
}
int poolIndex() {
return poolIndex;
}
/* @see io.vlingo.actors.Router#computeRouting() */
@Override
protected Routing
computeRouting() {
return Routing.with(nextRoutee());
}
protected Routee
nextRoutee() {
final List> routees = routees();
return routees.get(incrementAndGetPoolIndex() % routees.size());
}
private int incrementAndGetPoolIndex() {
poolIndex = (poolIndex == Integer.MAX_VALUE) ? 0 : poolIndex + 1;
return poolIndex;
}
}