Open Source Repository

Home /spring/spring-beans-3.0.5 | Repository Home



org/springframework/beans/factory/parsing/SourceExtractor.java
/*
 * Copyright 2002-2006 the original author or authors.
 *
 * 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.springframework.beans.factory.parsing;

import org.springframework.core.io.Resource;

/**
 * Simple strategy allowing tools to control how source metadata is attached
 * to the bean definition metadata.
 *
 <p>Configuration parsers <strong>may</strong> provide the ability to attach
 * source metadata during the parse phase. They will offer this metadata in a
 * generic format which can be further modified by a {@link SourceExtractor}
 * before being attached to the bean definition metadata.
 *
 @author Rob Harrop
 @author Juergen Hoeller
 @since 2.0
 @see org.springframework.beans.BeanMetadataElement#getSource()
 @see org.springframework.beans.factory.config.BeanDefinition
 */
public interface SourceExtractor {

  /**
   * Extract the source metadata from the candidate object supplied
   * by the configuration parser.
   @param sourceCandidate the original source metadata (never <code>null</code>)
   @param definingResource the resource that defines the given source object
   * (may be <code>null</code>)
   @return the source metadata object to store (may be <code>null</code>)
   */
  Object extractSource(Object sourceCandidate, Resource definingResource);

}