/*
 * Copyright (c) 2017, 2018 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package org.glassfish.jersey.internal.inject;

import java.lang.reflect.Type;
import java.util.Objects;
import java.util.Set;

Implementation of the instance keeper which kept the instance of the class from InjectionManager and the other information about this instance.
Type parameters:
  • <T> – type of the kept instance.
/** * Implementation of the instance keeper which kept the instance of the class from * {@link InjectionManager} and the other information about this instance. * * @param <T> type of the kept instance. */
public class ServiceHolderImpl<T> implements ServiceHolder<T> { private final T service; private final Class<T> implementationClass; private final Set<Type> contractTypes; private final int rank;
Creates a new instance of the service holder which keeps the concrete instance and its additional information.
Params:
  • service – service instance kept by this holder.
  • contractTypes – types which represent the given instance.
/** * Creates a new instance of the service holder which keeps the concrete instance and its additional information. * * @param service service instance kept by this holder. * @param contractTypes types which represent the given instance. */
@SuppressWarnings("unchecked") public ServiceHolderImpl(T service, Set<Type> contractTypes) { this(service, (Class<T>) service.getClass(), contractTypes, 0); }
Creates a new instance of the service holder which keeps the concrete instance and its additional information.
Params:
  • service – service instance kept by this holder.
  • implementationClass – implementation class of the given instance.
  • contractTypes – types which represent the given instance.
  • rank – ranking of the given instance.
/** * Creates a new instance of the service holder which keeps the concrete instance and its additional information. * * @param service service instance kept by this holder. * @param implementationClass implementation class of the given instance. * @param contractTypes types which represent the given instance. * @param rank ranking of the given instance. */
public ServiceHolderImpl(T service, Class<T> implementationClass, Set<Type> contractTypes, int rank) { this.service = service; this.implementationClass = implementationClass; this.contractTypes = contractTypes; this.rank = rank; } @Override public T getInstance() { return service; } @Override public Class<T> getImplementationClass() { return implementationClass; } @Override public Set<Type> getContractTypes() { return contractTypes; } @Override public int getRank() { return rank; } @Override public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof ServiceHolderImpl)) { return false; } ServiceHolderImpl<?> that = (ServiceHolderImpl<?>) o; return rank == that.rank && Objects.equals(service, that.service) && Objects.equals(implementationClass, that.implementationClass) && Objects.equals(contractTypes, that.contractTypes); } @Override public int hashCode() { return Objects.hash(service, implementationClass, contractTypes, rank); } }