001 // Copyright 2004, 2005 The Apache Software Foundation 002 // 003 // Licensed under the Apache License, Version 2.0 (the "License"); 004 // you may not use this file except in compliance with the License. 005 // You may obtain a copy of the License at 006 // 007 // http://www.apache.org/licenses/LICENSE-2.0 008 // 009 // Unless required by applicable law or agreed to in writing, software 010 // distributed under the License is distributed on an "AS IS" BASIS, 011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 012 // See the License for the specific language governing permissions and 013 // limitations under the License. 014 015 package org.apache.tapestry; 016 017 import java.util.Collection; 018 019 import org.apache.hivemind.ApplicationRuntimeException; 020 import org.apache.hivemind.ClassResolver; 021 022 /** 023 * An object that provides a component with access to helper beans. Helper beans 024 * are JavaBeans associated with a page or component that are used to extend the 025 * functionality of the component via aggregation. 026 * 027 * @author Howard Lewis Ship 028 * @since 1.0.4 029 */ 030 031 public interface IBeanProvider 032 { 033 034 /** 035 * Returns the JavaBean with the specified name. The bean is created as 036 * needed. 037 * 038 * @throws ApplicationRuntimeException 039 * if no such bean is available. 040 */ 041 042 Object getBean(String name); 043 044 /** 045 * Returns the {@link IComponent} (which may be a 046 * {@link org.apache.tapestry.IPage}) for which this bean provider is 047 * providing beans. 048 * 049 * @since 1.0.5 050 */ 051 052 IComponent getComponent(); 053 054 /** 055 * Returns a collection of the names of any beans which may be provided. 056 * 057 * @since 1.0.6 058 * @see org.apache.tapestry.spec.IComponentSpecification#getBeanNames() 059 */ 060 061 Collection getBeanNames(); 062 063 /** 064 * Returns true if the provider can provide the named bean. 065 * 066 * @since 2.2 067 */ 068 069 boolean canProvideBean(String name); 070 071 /** 072 * Returns a resource resolver. 073 * 074 * @since 1.0.8 075 */ 076 077 ClassResolver getClassResolver(); 078 079 }