Copyright (c) 2000, 2005 IBM Corporation and others. This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0 which accompanies this distribution, and is available at https://www.eclipse.org/legal/epl-2.0/ SPDX-License-Identifier: EPL-2.0 Contributors: IBM Corporation - initial API and implementation
/******************************************************************************* * Copyright (c) 2000, 2005 IBM Corporation and others. * * This program and the accompanying materials * are made available under the terms of the Eclipse Public License 2.0 * which accompanies this distribution, and is available at * https://www.eclipse.org/legal/epl-2.0/ * * SPDX-License-Identifier: EPL-2.0 * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/
package org.eclipse.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.
Since:3.0
/** * 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. * * @since 3.0 */
public interface ISourceModifier {
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 BadLocationException while executing the associated move or copy edit.

The caller of this method is responsible to apply the returned edits to the passed source.

Params:
  • source – the source to be copied or moved
Returns:an array of ReplaceEdits describing the modifications.
/** * 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.
Returns:the copy of the source modifier
/** * 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 ISourceModifier copy(); }