/*
 * CREDIT SUISSE IS WILLING TO LICENSE THIS SPECIFICATION TO YOU ONLY UPON THE CONDITION THAT YOU
 * ACCEPT ALL OF THE TERMS CONTAINED IN THIS AGREEMENT. PLEASE READ THE TERMS AND CONDITIONS OF THIS
 * AGREEMENT CAREFULLY. BY DOWNLOADING THIS SPECIFICATION, YOU ACCEPT THE TERMS AND CONDITIONS OF
 * THE AGREEMENT. IF YOU ARE NOT WILLING TO BE BOUND BY IT, SELECT THE "DECLINE" BUTTON AT THE
 * BOTTOM OF THIS PAGE. Specification: JSR-354 Money and Currency API ("Specification") Copyright
 * (c) 2012-2013, Credit Suisse All rights reserved.
 */
package javax.money.spi;

import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.logging.Level;
import java.util.logging.Logger;

This class implements the (default) ServiceProvider interface and hereby uses the JDK ServiceLoader to load the services required.
Author:Anatole Tresch
/** * This class implements the (default) {@link ServiceProvider} interface and hereby uses the JDK * {@link ServiceLoader} to load the services required. * * @author Anatole Tresch */
class DefaultServiceProvider implements ServiceProvider {
List of services loaded, per class.
/** List of services loaded, per class. */
private final ConcurrentHashMap<Class<?>, List<Object>> servicesLoaded = new ConcurrentHashMap<>(); @Override public int getPriority() { return 0; }
Loads and registers services.
Params:
  • serviceType – The service type.
Type parameters:
  • <T> – the concrete type.
Returns:the items found, never null.
/** * Loads and registers services. * * @param serviceType * The service type. * @param <T> * the concrete type. * @return the items found, never {@code null}. */
@Override public <T> List<T> getServices(final Class<T> serviceType) { @SuppressWarnings("unchecked") List<T> found = (List<T>) servicesLoaded.get(serviceType); if (found != null) { return found; } return loadServices(serviceType); }
Loads and registers services.
Params:
  • serviceType – The service type.
Type parameters:
  • <T> – the concrete type.
Returns: the items found, never null.
/** * Loads and registers services. * * @param serviceType The service type. * @param <T> the concrete type. * * @return the items found, never {@code null}. */
private <T> List<T> loadServices(final Class<T> serviceType) { List<T> services = new ArrayList<>(); try { for (T t : ServiceLoader.load(serviceType)) { services.add(t); } services.sort(Comparator.comparing(o -> o.getClass().getSimpleName())); @SuppressWarnings("unchecked") final List<T> previousServices = (List<T>) servicesLoaded.putIfAbsent(serviceType, (List<Object>) services); return Collections.unmodifiableList(previousServices != null ? previousServices : services); } catch (Exception e) { Logger.getLogger(DefaultServiceProvider.class.getName()).log(Level.WARNING, "Error loading services of type " + serviceType, e); return services; } } }