001/*
002 * JPPF.
003 * Copyright (C) 2005-2018 JPPF Team.
004 * http://www.jppf.org
005 *
006 * Licensed under the Apache License, Version 2.0 (the "License");
007 * you may not use this file except in compliance with the License.
008 * You may obtain a copy of the License at
009 *
010 *   http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software
013 * distributed under the License is distributed on an "AS IS" BASIS,
014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015 * See the License for the specific language governing permissions and
016 * limitations under the License.
017 */
018package org.jppf.load.balancer.spi;
019
020import org.jppf.load.balancer.Bundler;
021import org.jppf.load.balancer.impl.*;
022import org.jppf.utils.TypedProperties;
023
024/**
025 * Provider implementation for the "nodethreads" algorithm.
026 * @author Laurent Cohen
027 */
028public class NodeThreadsBundlerProvider implements JPPFBundlerProvider<NodeThreadsProfile> {
029  /**
030   * Create a bundler instance using the specified parameters profile.
031   * @param profile encapsulates the parameters of this algorithm.
032   * @return an instance of {@link NodeThreadsBundler}.
033   */
034  @Override
035  public Bundler<NodeThreadsProfile> createBundler(final NodeThreadsProfile profile) {
036    return new NodeThreadsBundler(profile);
037  }
038
039  /**
040   * Create a bundler profile containing the parameters of the algorithm.
041   * @param configuration a set of properties defining the algorithm parameters.
042   * @return an instance of {@link NodeThreadsProfile}.
043   */
044  @Override
045  public NodeThreadsProfile createProfile(final TypedProperties configuration) {
046    return new NodeThreadsProfile(configuration);
047  }
048
049  /**
050   * Get the name of the algorithm defined by this provider.
051   * @return the algorithm name as a string.
052   */
053  @Override
054  public String getAlgorithmName() {
055    return "nodethreads";
056  }
057}