/*******************************************************************************
* Copyright (c) 2012-2015 Codenvy, S.A.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Codenvy, S.A. - initial API and implementation
*******************************************************************************/
package org.eclipse.che.ide.ext.java.jdt.text.edits;
/**
* A source modifier can be used to modify the source of a move or copy edit before it gets inserted at the target position. This
* is useful if the text to be copied has to be modified before it is inserted without changing the original source.
*/
public interface SourceModifier {
/**
* Returns the modification to be done to the passed string in form of replace edits. The set of returned replace edits must
* modify disjoint text regions. Violating this requirement will result in a <code>
* BadLocationException</code> while executing the associated move or copy edit.
* <p/>
* The caller of this method is responsible to apply the returned edits to the passed source.
*
* @param source
* the source to be copied or moved
* @return an array of <code>ReplaceEdits</code> describing the modifications.
*/
public ReplaceEdit[] getModifications(String source);
/**
* Creates a copy of this source modifier object. The copy will be used in a different text edit object. So it should be
* created in a way that is doesn't conflict with other text edits referring to this source modifier.
*
* @return the copy of the source modifier
*/
public SourceModifier copy();
}