@Override public <T> T getInstance(Class<T> type) throws InjectionException { T obj = tryGetInstance(Qualifiers.matchDefault(), type); if (obj == null) { throw new ResolutionException("no resolution available for " + type); } else { return obj; } }
/** * Get the component of a particular type, if one is already instantiated. This is useful to extract pre-built * models from serialized recommender engines, for example. * @param type The required component type. * @param <T> The required component type. * @return The component instance, or {@code null} if no instance can be retreived (either because no such * component is configured, or it is not yet instantiated). */ @Nullable public <T> T getComponent(Class<T> type) { DAGNode<Component, Dependency> node = GraphtUtils.findSatisfyingNode(graph, Qualifiers.matchDefault(), type); if (node == null) { return null; } Satisfaction sat = node.getLabel().getSatisfaction(); if (sat instanceof InstanceSatisfaction) { return type.cast(((InstanceSatisfaction) sat).getInstance()); } else { return null; } }
@Nullable public <T> T tryGetInstance(Class<T> type) throws InjectionException { Desire d = Desires.create(null, type, true); DAGEdge<Component, Dependency> e = graph.getOutgoingEdgeWithLabel(l -> l.hasInitialDesire(d)); if (e != null) { return type.cast(instantiator.instantiate(e.getTail())); } else { DAGNode<Component, Dependency> node = GraphtUtils.findSatisfyingNode(graph, Qualifiers.matchDefault(), type); if (node != null) { return type.cast(instantiator.instantiate(node)); } else { return null; } } }
/** * Create an unanchored ReflectionContextElementMatcher that matches the given type * with the default qualifier matcher. * * @param type The type to match * @throws NullPointerException if type is null */ public TypeElementMatcher(Class<?> type) { this(type, Qualifiers.matchDefault()); }
@Override public Context within(Class<?> type) { return in(Qualifiers.matchDefault(), type, false); }
@Override public Context at(Class<?> type) { return in(Qualifiers.matchDefault(), type, true); }
@Override public <T> T getInstance(Class<T> type) throws InjectionException { T obj = tryGetInstance(Qualifiers.matchDefault(), type); if (obj == null) { throw new ResolutionException("no resolution available for " + type); } else { return obj; } }
public BindingImpl(ContextImpl context, Class<T> type) { this(context, type, context.getBuilder().getDefaultExclusions(), Qualifiers.matchDefault(), CachePolicy.NO_PREFERENCE, false); }
/** * Get the component of a particular type, if one is already instantiated. This is useful to extract pre-built * models from serialized recommender engines, for example. * @param type The required component type. * @param <T> The required component type. * @return The component instance, or {@code null} if no instance can be retreived (either because no such * component is configured, or it is not yet instantiated). */ @Nullable public <T> T getComponent(Class<T> type) { DAGNode<Component, Dependency> node = GraphtUtils.findSatisfyingNode(graph, Qualifiers.matchDefault(), type); if (node == null) { return null; } Satisfaction sat = node.getLabel().getSatisfaction(); if (sat instanceof InstanceSatisfaction) { return type.cast(((InstanceSatisfaction) sat).getInstance()); } else { return null; } }
@Nullable public <T> T tryGetInstance(Class<T> type) throws InjectionException { Desire d = Desires.create(null, type, true); DAGEdge<Component, Dependency> e = graph.getOutgoingEdgeWithLabel(l -> l.hasInitialDesire(d)); if (e != null) { return type.cast(instantiator.instantiate(e.getTail())); } else { DAGNode<Component, Dependency> node = GraphtUtils.findSatisfyingNode(graph, Qualifiers.matchDefault(), type); if (node != null) { return type.cast(instantiator.instantiate(node)); } else { return null; } } }