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