
org.apache.tapestry.ioc.ObjectLocator Maven / Gradle / Ivy
// Copyright 2006, 2007 The Apache Software Foundation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package org.apache.tapestry.ioc;
import org.apache.tapestry.services.MasterObjectProvider;
/**
* Defines an object which can provide access to services defined within a
* {@link org.apache.tapestry.ioc.Registry}, or to objects or object instances available by other
* means. Services are accessed via service id, or (when appropriate) by just service interface. The
* Registry itself implements this interface, as does
* {@link org.apache.tapestry.ioc.ServiceResources}.
*/
public interface ObjectLocator
{
/**
* Obtains a service via its unique service id. Returns the service's proxy. The service proxy
* implements the same interface as the actual service, and is used to instantiate the actual
* service only as needed (this is transparent to the application).
*
* @param
* @param serviceId unique Service id used to locate the service object (may contain symbols,
* which will be expanded), case is ignored
* @param serviceInterface the interface implemented by the service (or an interface extended by the service
* interface)
* @return the service instance
* @throws RuntimeException if the service is not defined, or if an error occurs instantiating it
*/
T getService(String serviceId, Class serviceInterface);
/**
* Locates a service given just a service interface. A single service must implement the service
* interface (which can be hard to guarantee). The search takes into account inheritance of the
* service interface (not the service implementation), which may result in a failure
* due to extra matches.
*
* @param
* @param serviceInterface the interface the service implements
* @return the service's proxy
* @throws RuntimeException if the service does not exist (this is considered programmer error), or multiple
* services directly implement, or extend from, the service interface
*/
T getService(Class serviceInterface);
/**
* Obtains an object indirectly, using an {@link ObjectProvider} identified by the prefix of the
* reference.
*
* @param objectType the type of object to be returned
* @param annotationProvider provides access to annotations on the field or parameter for which a value is to
* be obtained, which may be utilized in selecting an appropriate object, use
* null when annotations are not available (in which case,
* selection will be based only on the object type)
* @param
* @return the requested object
* @see ObjectProvider
*/
T getObject(Class objectType, AnnotationProvider annotationProvider);
/**
* Autobuilds a class by finding the public constructor with the most parameters. Services and
* resources will be injected into the parameters of the constructor.
*
* @param
* @param clazz the type of object to instantiate
* @return the instantiated instance
* @throws RuntimeException if the autobuild fails
* @see MasterObjectProvider
*/
T autobuild(Class clazz);
/**
* Creates a proxy. The proxy will defer invocation of {@link #autobuild(Class)} until
* just-in-time (that is, first method invocation). In a limited number of cases, it is
* necessary to use such a proxy to prevent service construction cycles, particularly when
* contributing (directly or indirectly) to the {@link MasterObjectProvider} (which is itself at
* the heart of autobuilding).
*
* @param
* @param interfaceClass the interface implemented by the proxy
* @param implementationClass a concrete class that implements the interface
* @return a proxy
*/
T proxy(Class interfaceClass, Class extends T> implementationClass);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy