blob: 7d3903738ca19f9ad1dce2aa2a2e3b5b8b8ea88f [file] [log] [blame]
// Copyright 2006, 2008 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.tapestry5.ioc.services;
import org.apache.tapestry5.ioc.annotations.UsesMappedConfiguration;
/**
* A provider of values for symbols, used by the {@link org.apache.tapestry5.ioc.services.SymbolSource} service.
* <p/>
* This is the service interface for the FactoryDefaults and ApplicationDefaults services; each of these takes a
* configuration mapping symbols to their values.
*/
@UsesMappedConfiguration(String.class)
public interface SymbolProvider
{
/**
* Returns the value for the symbol, or null if this provider can not provide a value. The value itself may contain
* symbols that will be recursively expanded.
*
* @param symbolName
* @return the value or null
*/
String valueForSymbol(String symbolName);
}