View Javadoc

1   /*
2    * EL4J, the Extension Library for the J2EE, adds incremental enhancements to
3    * the spring framework, http://el4j.sf.net
4    * Copyright (C) 2006 by ELCA Informatique SA, Av. de la Harpe 22-24,
5    * 1000 Lausanne, Switzerland, http://www.elca.ch
6    *
7    * EL4J is published under the GNU Lesser General Public License (LGPL)
8    * Version 2.1. See http://www.gnu.org/licenses/
9    *
10   * This program is distributed in the hope that it will be useful,
11   * but WITHOUT ANY WARRANTY; without even the implied warranty of
12   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13   * GNU Lesser General Public License for more details.
14   *
15   * For alternative licensing, please contact info@elca.ch
16   */
17  package ch.elca.el4j.services.xmlmerge;
18  
19  import org.jdom.Element;
20  
21  /**
22   * Creates operation (action, mapper and matcher) instances corresponding to a
23   * pair of elements from the original and patch DOMs.
24   *
25   * @svnLink $Revision: 3881 $;$Date: 2009-08-04 15:22:05 +0200 (Di, 04. Aug 2009) $;$Author: swismer $;$URL: https://el4j.svn.sourceforge.net/svnroot/el4j/branches/el4j_3_1/el4j/framework/modules/xml_merge/common/src/main/java/ch/elca/el4j/services/xmlmerge/OperationFactory.java $
26   *
27   * @author Laurent Bovet (LBO)
28   * @author Alex Mathey (AMA)
29   */
30  public interface OperationFactory {
31  
32  	/**
33  	 * Creates operation (action, mapper and matcher) instances corresponding to
34  	 * a pair of elements from the original and patch DOMs.
35  	 *
36  	 * @param originalElement
37  	 *            Original element
38  	 * @param modifiedElement
39  	 *            Modified element
40  	 * @return The operation (action, mapper or matcher) for the given element
41  	 *         pair
42  	 * @throws AbstractXmlMergeException
43  	 *             If an error occurs during operation creation
44  	 */
45  	public Operation getOperation(Element originalElement,
46  		Element modifiedElement) throws AbstractXmlMergeException;
47  
48  }