/******************************************************************************* * 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(); }