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 }