/******************************************************************************* * Copyright (c) 2000, 2010 IBM Corporation and others. * 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: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.jdt.core.formatter; import org.eclipse.jdt.internal.compiler.util.Util; import org.eclipse.jface.text.IRegion; import org.eclipse.text.edits.TextEdit; /** * Specification for a generic source code formatter. * * @since 3.0 * @noextend This class is not intended to be subclassed by clients. */ public abstract class CodeFormatter { /** * Unknown kind *<p> * <b>Since 3.6</b>, if the corresponding comment options are set to * <code>true</code> then it is also possible to format the comments on the fly * by adding the {@link #F_INCLUDE_COMMENTS} flag to this kind of format. * </p> */ public static final int K_UNKNOWN = 0x00; /** * Kind used to format an expression * <p> * Note that using this constant, the comments encountered while formatting * the expression may be shifted to match the correct indentation but are not * formatted. * </p><p> * <b>Since 3.6</b>, if the corresponding comment options are set to * <code>true</code> then it is also possible to format the comments on the fly * by adding the {@link #F_INCLUDE_COMMENTS} flag to this kind of format. * </p> */ public static final int K_EXPRESSION = 0x01; /** * Kind used to format a set of statements * <p> * Note that using this constant, the comments encountered while formatting * the statements may be shifted to match the correct indentation but are not * formatted. * </p><p> * <b>Since 3.6</b>, if the corresponding comment options are set to * <code>true</code> then it is also possible to format the comments on the fly * by adding the {@link #F_INCLUDE_COMMENTS} flag to this kind of format. * </p> */ public static final int K_STATEMENTS = 0x02; /** * Kind used to format a set of class body declarations * <p> * Note that using this constant, the comments encountered while formatting * the body declarations may be shifted to match the correct indentation but * are not formatted. * </p><p> * <b>Since 3.6</b>, if the corresponding comment options are set to * <code>true</code> then it is also possible to format the comments on the fly * by adding the {@link #F_INCLUDE_COMMENTS} flag to this kind of format. * </p> */ public static final int K_CLASS_BODY_DECLARATIONS = 0x04; /** * Kind used to format a compilation unit * <p> * Note that using this constant, the comments are only indented while * formatting the compilation unit. * </p><p> * <b>Since 3.4</b>, if the corresponding comment option is set to * <code>true</code> then it is also possible to format the comments on the fly * by adding the {@link #F_INCLUDE_COMMENTS} flag to this kind of format. * </p> */ public static final int K_COMPILATION_UNIT = 0x08; /** * Kind used to format a single-line comment * @since 3.1 */ public static final int K_SINGLE_LINE_COMMENT = 0x10; /** * Kind used to format a multi-line comment * @since 3.1 */ public static final int K_MULTI_LINE_COMMENT = 0x20; /** * Kind used to format a Javadoc comment * * @since 3.1 */ public static final int K_JAVA_DOC = 0x40; /** * Flag used to include the comments during the formatting of the code * snippet. * <p> * This flag can be combined with the following kinds: * <ul> * <li>{@link #K_COMPILATION_UNIT}</li> * <li>{@link #K_UNKNOWN}</li> * <li>{@link #K_CLASS_BODY_DECLARATIONS} <i>(since 3.6)</i></li> * <li>{@link #K_EXPRESSION} <i>(since 3.6)</i></li> * <li>{@link #K_STATEMENTS} <i>(since 3.6)</i></li> * </ul> * </p><p> * Note also that it has an effect only when one or several format comments * options for * {@link DefaultCodeFormatterConstants#FORMATTER_COMMENT_FORMAT_JAVADOC_COMMENT javadoc} * , * {@link DefaultCodeFormatterConstants#FORMATTER_COMMENT_FORMAT_BLOCK_COMMENT block} * or * {@link DefaultCodeFormatterConstants#FORMATTER_COMMENT_FORMAT_LINE_COMMENT line} * are set to {@link DefaultCodeFormatterConstants#TRUE true} while calling * {@link #format(int, String, int, int, int, String)} or * {@link #format(int, String, IRegion[], int, String)} methods * </p><p> * For example, with the Eclipse default formatter options, the formatting * of the following code snippet using {@link #K_COMPILATION_UNIT}: * <pre> * public class X { * /** * * This is just a simple example to show that comments will be formatted while processing a compilation unit only if the constant flag <code>F_INCLUDE_COMMENT</code> flag is set. * * @param str The input string * */ * void foo(String str){}} * </pre> * will produce the following output: * <pre> * public class X { * /** * * This is just a simple example to show that comments will be formatted while processing a compilation unit only if the constant flag <code>F_INCLUDE_COMMENT</code> flag is set. * * * * @param str The input string * */ * void foo(String str){ * } * } * </pre> * Adding this flavor to the kind given while formatting the same source * (e.g. {@link #K_COMPILATION_UNIT} | {@link #F_INCLUDE_COMMENTS}) * will produce the following output instead: * <pre> * public class X { * /** * * This is just a simple example to show that comments will be formatted * * while processing a compilation unit only if the constant flag * * <code>F_INCLUDE_COMMENT</code> flag is set. * * * * @param str * * The input string * */ * void foo(String str){ * } * } * </pre> * </p><p> * <i><u>Note</u>: Although we're convinced that the formatter should * always include the comments while processing a * {@link #K_COMPILATION_UNIT kind of compilation unit}, we * have decided to add a specific flag to fix this formatter incorrect behavior. * This will prevent all existing clients (e.g. 3.3 and previous versions) using * the {@link #K_COMPILATION_UNIT} kind to be broken while formatting.</i> * </p> * @since 3.4 */ public static final int F_INCLUDE_COMMENTS = 0x1000; /** * Format <code>source</code>, * and returns a text edit that correspond to the difference between the given * string and the formatted string. * <p> * It returns null if the given string cannot be formatted. * </p><p> * If the offset position is matching a whitespace, the result can include * whitespaces. It would be up to the caller to get rid of preceding * whitespaces. * </p> * * @param kind Use to specify the kind of the code snippet to format. It can * be any of these: * <ul> * <li>{@link #K_EXPRESSION}</li> * <li>{@link #K_STATEMENTS}</li> * <li>{@link #K_CLASS_BODY_DECLARATIONS}</li> * <li>{@link #K_COMPILATION_UNIT}<br> * <b>Since 3.4</b>, the comments can be formatted on the fly while * using this kind of code snippet<br> * (see {@link #F_INCLUDE_COMMENTS} for more detailed explanation on * this flag) * </li> * <li>{@link #K_UNKNOWN}</li> * <li>{@link #K_SINGLE_LINE_COMMENT}</li> * <li>{@link #K_MULTI_LINE_COMMENT}</li> * <li>{@link #K_JAVA_DOC}</li> * </ul> * @param source the source to format * @param offset the given offset to start recording the edits (inclusive). * @param length the given length to stop recording the edits (exclusive). * @param indentationLevel the initial indentation level, used * to shift left/right the entire source fragment. An initial indentation * level of zero or below has no effect. * @param lineSeparator the line separator to use in formatted source, * if set to <code>null</code>, then the platform default one will be used. * @return the text edit * @throws IllegalArgumentException if offset is lower than 0, length is lower than 0 or * length is greater than source length. */ public abstract TextEdit format(int kind, String source, int offset, int length, int indentationLevel, String lineSeparator); /** * Format <code>source</code>, * and returns a text edit that correspond to the difference between the given string and the formatted string. * <p>It returns null if the given string cannot be formatted.</p> * * <p>If an offset position is matching a whitespace, the result can include whitespaces. It would be up to the * caller to get rid of preceding whitespaces.</p> * * <p>No region in <code>regions</code> must overlap with any other region in <code>regions</code>. * Each region must be within source. There must be at least one region. Regions must be sorted * by their offsets, smaller offset first.</p> * * @param kind Use to specify the kind of the code snippet to format. It can * be any of these: * <ul> * <li>{@link #K_EXPRESSION}</li> * <li>{@link #K_STATEMENTS}</li> * <li>{@link #K_CLASS_BODY_DECLARATIONS}</li> * <li>{@link #K_COMPILATION_UNIT}<br> * <b>Since 3.4</b>, the comments can be formatted on the fly while * using this kind of code snippet<br> * (see {@link #F_INCLUDE_COMMENTS} for more detailed explanation on * this flag) * </li> * <li>{@link #K_UNKNOWN}</li> * <li>{@link #K_SINGLE_LINE_COMMENT}</li> * <li>{@link #K_MULTI_LINE_COMMENT}</li> * <li>{@link #K_JAVA_DOC}</li> * </ul> * @param source the source to format * @param regions a set of regions in source to format * @param indentationLevel the initial indentation level, used * to shift left/right the entire source fragment. An initial indentation * level of zero or below has no effect. * @param lineSeparator the line separator to use in formatted source, * if set to <code>null</code>, then the platform default one will be used. * @return the text edit * @throws IllegalArgumentException if there is no region, a region overlaps with another region, or the regions are not * sorted in the ascending order. * @since 3.4 */ public abstract TextEdit format(int kind, String source, IRegion[] regions, int indentationLevel, String lineSeparator); /** * Answers the string that corresponds to the indentation to the given indentation level or an empty string * if the indentation cannot be computed. * <p>This method needs to be overridden in a subclass.</p> * * <p>The default implementation returns an empty string.</p> * * @param indentationLevel the given indentation level * @return the string corresponding to the right indentation level * @exception IllegalArgumentException if the given indentation level is lower than zero * @since 3.2 */ public String createIndentationString(int indentationLevel) { return Util.EMPTY_STRING; } }