Copyright (c) 2000, 2019 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 John Kaplan, johnkaplantech@gmail.com - 108071 [code templates] template for body of newly created class
/******************************************************************************* * Copyright (c) 2000, 2019 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 * John Kaplan, johnkaplantech@gmail.com - 108071 [code templates] template for body of newly created class *******************************************************************************/
package org.eclipse.jdt.core.manipulation; import org.eclipse.core.runtime.CoreException; import org.eclipse.jdt.core.ICompilationUnit; import org.eclipse.jdt.core.IMethod; import org.eclipse.jdt.core.IModuleDescription; import org.eclipse.jdt.core.dom.IMethodBinding; import org.eclipse.jdt.core.dom.MethodDeclaration; import org.eclipse.jdt.internal.core.manipulation.CodeTemplateContextType; import org.eclipse.jdt.internal.core.manipulation.StubUtility;
Class that offers access to the templates contained in the 'code templates' preference page.

This class is not intended to be subclassed or instantiated by clients.

Since:1.11
@noinstantiateThis class is not intended to be instantiated by clients.
@noextendThis class is not intended to be subclassed by clients.
/** * Class that offers access to the templates contained in the 'code templates' preference page. * * <p> * This class is not intended to be subclassed or instantiated by clients. * </p> * * @since 1.11 * * @noinstantiate This class is not intended to be instantiated by clients. * @noextend This class is not intended to be subclassed by clients. */
public class CodeGeneration {
Constant ID for the type kind to be used in getTypeBody(String, ICompilationUnit, String, String) to get the code template used for a new class type body.
Since:3.2
/** * Constant ID for the type kind to be used in {@link #getTypeBody(String, ICompilationUnit, String, String)} to get the code template used * for a new class type body. * @since 3.2 */
public static final String CLASS_BODY_TEMPLATE_ID= CodeTemplateContextType.CLASSBODY_ID;
Constant ID for the type kind to be used in getTypeBody(String, ICompilationUnit, String, String) to get the code template used for a new interface type body.
Since:3.2
/** * Constant ID for the type kind to be used in {@link #getTypeBody(String, ICompilationUnit, String, String)} to get the code template used * for a new interface type body. * @since 3.2 */
public static final String INTERFACE_BODY_TEMPLATE_ID= CodeTemplateContextType.INTERFACEBODY_ID;
Constant ID for the type kind to be used in getTypeBody(String, ICompilationUnit, String, String) to get the code template used for a new enum type body.
Since:3.2
/** * Constant ID for the type kind to be used in {@link #getTypeBody(String, ICompilationUnit, String, String)} to get the code template used * for a new enum type body. * @since 3.2 */
public static final String ENUM_BODY_TEMPLATE_ID= CodeTemplateContextType.ENUMBODY_ID;
Constant ID for the type kind to be used in getTypeBody(String, ICompilationUnit, String, String) to get the code template used for a new annotation type body.
Since:3.2
/** * Constant ID for the type kind to be used in {@link #getTypeBody(String, ICompilationUnit, String, String)} to get the code template used * for a new annotation type body. * @since 3.2 */
public static final String ANNOTATION_BODY_TEMPLATE_ID= CodeTemplateContextType.ANNOTATIONBODY_ID; private static final String[] EMPTY= new String[0]; private CodeGeneration() { }
Returns the content for a new compilation unit using the 'new Java file' code template.
Params:
  • cu – The compilation unit to create the source for. The compilation unit does not need to exist.
  • typeComment – The comment for the type to be created. Used when the code template contains a ${typecomment} variable. Can be null if no comment should be added.
  • typeContent – The code of the type, including type declaration and body.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the template is undefined or empty.
/** * Returns the content for a new compilation unit using the 'new Java file' code template. * @param cu The compilation unit to create the source for. The compilation unit does not need to exist. * @param typeComment The comment for the type to be created. Used when the code template contains a <i>${typecomment}</i> variable. Can be <code>null</code> if * no comment should be added. * @param typeContent The code of the type, including type declaration and body. * @param lineDelimiter The line delimiter to be used. * @return Returns the new content or <code>null</code> if the template is undefined or empty. * @throws CoreException Thrown when the evaluation of the code template fails. */
public static String getCompilationUnitContent(ICompilationUnit cu, String typeComment, String typeContent, String lineDelimiter) throws CoreException { return getCompilationUnitContent(cu, getFileComment(cu, lineDelimiter), typeComment, typeContent, lineDelimiter); }
Returns the content for a new compilation unit using the 'new Java file' code template.
Params:
  • cu – The compilation unit to create the source for. The compilation unit does not need to exist. @param fileComment The file comment to be used when the code template contains a ${filecomment} variable. Can be null if no comment should be added.
  • typeComment – The comment for the type to be created. Used when the code template contains a ${typecomment} variable. Can be null if no comment should be added.
  • typeContent – The code of the type, including type declaration and body.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the template is undefined or empty.
Since:3.1
/** * Returns the content for a new compilation unit using the 'new Java file' code template. * @param cu The compilation unit to create the source for. The compilation unit does not need to exist. * @param fileComment The file comment to be used when the code template contains a <i>${filecomment}</i> variable. Can be <code>null</code> if * no comment should be added. * @param typeComment The comment for the type to be created. Used when the code template contains a <i>${typecomment}</i> variable. Can be <code>null</code> if * no comment should be added. * @param typeContent The code of the type, including type declaration and body. * @param lineDelimiter The line delimiter to be used. * @return Returns the new content or <code>null</code> if the template is undefined or empty. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.1 */
public static String getCompilationUnitContent(ICompilationUnit cu, String fileComment, String typeComment, String typeContent, String lineDelimiter) throws CoreException { return StubUtility.getCompilationUnitContent(cu, fileComment, typeComment, typeContent, lineDelimiter); }
Returns the content for a new file comment using the 'file comment' code template. The returned content is unformatted and is not indented.
Params:
  • cu – The compilation unit to add the comment to. The compilation unit does not need to exist.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the code template is undefined or empty. The returned content is unformatted and is not indented.
Since:3.1
/** * Returns the content for a new file comment using the 'file comment' code template. The returned content is unformatted and is not indented. * @param cu The compilation unit to add the comment to. The compilation unit does not need to exist. * @param lineDelimiter The line delimiter to be used. * @return Returns the new content or <code>null</code> if the code template is undefined or empty. The returned content is unformatted and is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.1 */
public static String getFileComment(ICompilationUnit cu, String lineDelimiter) throws CoreException { return StubUtility.getFileComment(cu, lineDelimiter); }
Returns the content for a new type comment using the 'type comment' code template. The returned content is unformatted and is not indented.
Params:
  • cu – The compilation unit where the type is contained. The compilation unit does not need to exist.
  • typeQualifiedName – The name of the type to which the comment is added. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the code template is undefined or empty. The returned content is unformatted and is not indented.
/** * Returns the content for a new type comment using the 'type comment' code template. The returned content is unformatted and is not indented. * @param cu The compilation unit where the type is contained. The compilation unit does not need to exist. * @param typeQualifiedName The name of the type to which the comment is added. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param lineDelimiter The line delimiter to be used. * @return Returns the new content or <code>null</code> if the code template is undefined or empty. The returned content is unformatted and is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. */
public static String getTypeComment(ICompilationUnit cu, String typeQualifiedName, String lineDelimiter) throws CoreException { return StubUtility.getTypeComment(cu, typeQualifiedName, EMPTY, lineDelimiter); }
Returns the content for a new type comment using the 'type comment' code template. The returned content is unformatted and is not indented.
Params:
  • cu – The compilation unit where the type is contained. The compilation unit does not need to exist.
  • typeQualifiedName – The name of the type to which the comment is added. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • typeParameterNames – The type parameter names
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the code template is undefined or empty. The returned content is unformatted and is not indented.
Since:3.1
/** * Returns the content for a new type comment using the 'type comment' code template. The returned content is unformatted and is not indented. * @param cu The compilation unit where the type is contained. The compilation unit does not need to exist. * @param typeQualifiedName The name of the type to which the comment is added. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param typeParameterNames The type parameter names * @param lineDelimiter The line delimiter to be used. * @return Returns the new content or <code>null</code> if the code template is undefined or empty. The returned content is unformatted and is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.1 */
public static String getTypeComment(ICompilationUnit cu, String typeQualifiedName, String[] typeParameterNames, String lineDelimiter) throws CoreException { return StubUtility.getTypeComment(cu, typeQualifiedName, typeParameterNames, lineDelimiter); }
Returns the content of a new new type body using the 'type body' code templates. The returned content is unformatted and is not indented.
Params:
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the code template is undefined or empty. The returned content is unformatted and is not indented.
Since:3.2
/** * Returns the content of a new new type body using the 'type body' code templates. The returned content is unformatted and is not indented. * @param typeKind The type kind ID of the body template. Valid values are {@link #CLASS_BODY_TEMPLATE_ID}, {@link #INTERFACE_BODY_TEMPLATE_ID}, * {@link #ENUM_BODY_TEMPLATE_ID} and {@link #ANNOTATION_BODY_TEMPLATE_ID}. * @param cu The compilation unit where the type is contained. The compilation unit does not need to exist. * @param typeName The name of the type(for embedding in the template as a user variable). * @param lineDelim The line delimiter to be used. * @return Returns the new content or <code>null</code> if the code template is undefined or empty. The returned content is unformatted and is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.2 */
public static String getTypeBody(String typeKind, ICompilationUnit cu, String typeName, String lineDelim) throws CoreException { return StubUtility.getTypeBody(typeKind, cu, typeName, lineDelim); }
Returns the content for a new field comment using the 'field comment' code template. The returned content is unformatted and is not indented.
Params:
  • cu – The compilation unit where the field is contained. The compilation unit does not need to exist.
  • typeName – The name of the field declared type.
  • fieldName – The name of the field to which the comment is added.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the new content or null if the code template is undefined or empty. The returned content is unformatted and is not indented.
Since:3.0
/** * Returns the content for a new field comment using the 'field comment' code template. The returned content is unformatted and is not indented. * @param cu The compilation unit where the field is contained. The compilation unit does not need to exist. * @param typeName The name of the field declared type. * @param fieldName The name of the field to which the comment is added. * @param lineDelimiter The line delimiter to be used. * @return Returns the new content or <code>null</code> if the code template is undefined or empty. The returned content is unformatted and is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.0 */
public static String getFieldComment(ICompilationUnit cu, String typeName, String fieldName, String lineDelimiter) throws CoreException { return StubUtility.getFieldComment(cu, typeName, fieldName, lineDelimiter); }
Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). null is returned if the template is empty.
Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • decl – The MethodDeclaration AST node that will be added as new method. The node does not need to exist in an AST (no parent needed) and does not need to resolve. See AST.newMethodDeclaration() for how to create such a node.
  • overridden – The binding of the method to which to add an "@see" link or null if no link should be created.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the generated method comment or null if the code template is empty. The returned content is unformatted and not indented (formatting required).
/** * Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). * <code>null</code> is returned if the template is empty. * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param decl The MethodDeclaration AST node that will be added as new * method. The node does not need to exist in an AST (no parent needed) and does not need to resolve. * See {@link org.eclipse.jdt.core.dom.AST#newMethodDeclaration()} for how to create such a node. * @param overridden The binding of the method to which to add an "@see" link or * <code>null</code> if no link should be created. * @param lineDelimiter The line delimiter to be used. * @return Returns the generated method comment or <code>null</code> if the * code template is empty. The returned content is unformatted and not indented (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. */
public static String getMethodComment(ICompilationUnit cu, String declaringTypeName, MethodDeclaration decl, IMethodBinding overridden, String lineDelimiter) throws CoreException { if (overridden != null) { overridden= overridden.getMethodDeclaration(); String declaringClassQualifiedName= overridden.getDeclaringClass().getQualifiedName(); String linkToMethodName= overridden.getName(); String[] parameterTypesQualifiedNames= StubUtility.getParameterTypeNamesForSeeTag(overridden); return StubUtility.getMethodComment(cu, declaringTypeName, decl, overridden.isDeprecated(), linkToMethodName, declaringClassQualifiedName, parameterTypesQualifiedNames, false, lineDelimiter); } else { return StubUtility.getMethodComment(cu, declaringTypeName, decl, false, null, null, null, false, lineDelimiter); } }
Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). null is returned if the template is empty.

The returned string is unformatted and not indented.

Exception types and return type are in signature notation. e.g. a source method declared as public void foo(String text, int length) would return the array {"QString;","I"} as parameter types. See Signature.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – Name of the method.
  • paramNames – Names of the parameters for the method.
  • excTypeSig – Thrown exceptions (Signature notation).
  • retTypeSig – Return type (Signature notation) or null for constructors.
  • overridden – The method that will be overridden by the created method or null for non-overriding methods. If not null, the method must exist.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed comment or null if the comment code template is empty. The returned content is unformatted and not indented (formatting required).
/** * Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * <p>Exception types and return type are in signature notation. e.g. a source method declared as <code>public void foo(String text, int length)</code> * would return the array <code>{"QString;","I"}</code> as parameter types. See {@link org.eclipse.jdt.core.Signature}. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName Name of the method. * @param paramNames Names of the parameters for the method. * @param excTypeSig Thrown exceptions (Signature notation). * @param retTypeSig Return type (Signature notation) or <code>null</code> * for constructors. * @param overridden The method that will be overridden by the created method or * <code>null</code> for non-overriding methods. If not <code>null</code>, the method must exist. * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed comment or <code>null</code> if * the comment code template is empty. The returned content is unformatted and not indented (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. */
public static String getMethodComment(ICompilationUnit cu, String declaringTypeName, String methodName, String[] paramNames, String[] excTypeSig, String retTypeSig, IMethod overridden, String lineDelimiter) throws CoreException { return StubUtility.getMethodComment(cu, declaringTypeName, methodName, paramNames, excTypeSig, retTypeSig, EMPTY, overridden, false, lineDelimiter); }
Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). null is returned if the template is empty.

The returned string is unformatted and not indented.

Exception types and return type are in signature notation. e.g. a source method declared as public void foo(String text, int length) would return the array {"QString;","I"} as parameter types. See Signature.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – Name of the method.
  • paramNames – Names of the parameters for the method.
  • excTypeSig – Thrown exceptions (Signature notation).
  • retTypeSig – Return type (Signature notation) or null for constructors.
  • typeParameterNames – Names of the type parameters for the method.
  • overridden – The method that will be overridden by the created method or null for non-overriding methods. If not null, the method must exist.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed comment or null if the comment code template is empty. The returned content is unformatted and not indented (formatting required).
Since:3.1
/** * Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * <p>Exception types and return type are in signature notation. e.g. a source method declared as <code>public void foo(String text, int length)</code> * would return the array <code>{"QString;","I"}</code> as parameter types. See {@link org.eclipse.jdt.core.Signature}. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName Name of the method. * @param paramNames Names of the parameters for the method. * @param excTypeSig Thrown exceptions (Signature notation). * @param retTypeSig Return type (Signature notation) or <code>null</code> * for constructors. * @param typeParameterNames Names of the type parameters for the method. * @param overridden The method that will be overridden by the created method or * <code>null</code> for non-overriding methods. If not <code>null</code>, the method must exist. * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed comment or <code>null</code> if * the comment code template is empty. The returned content is unformatted and not indented (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.1 */
public static String getMethodComment(ICompilationUnit cu, String declaringTypeName, String methodName, String[] paramNames, String[] excTypeSig, String retTypeSig, String[] typeParameterNames, IMethod overridden, String lineDelimiter) throws CoreException { return StubUtility.getMethodComment(cu, declaringTypeName, methodName, paramNames, excTypeSig, retTypeSig, typeParameterNames, overridden, false, lineDelimiter); }
Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • method – The method to be documented. The method must exist.
  • overridden – The method that will be overridden by the created method or null for non-overriding methods. If not null, the method must exist.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed comment or null if the comment code template is empty. The returned string is unformatted and and has no indent (formatting required).
/** * Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param method The method to be documented. The method must exist. * @param overridden The method that will be overridden by the created method or * <code>null</code> for non-overriding methods. If not <code>null</code>, the method must exist. * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed comment or <code>null</code> if * the comment code template is empty. The returned string is unformatted and and has no indent (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. */
public static String getMethodComment(IMethod method, IMethod overridden, String lineDelimiter) throws CoreException { String retType= method.isConstructor() ? null : method.getReturnType(); String[] paramNames= method.getParameterNames(); String[] typeParameterNames= StubUtility.getTypeParameterNames(method.getTypeParameters()); return StubUtility.getMethodComment(method.getCompilationUnit(), method.getDeclaringType().getElementName(), method.getElementName(), paramNames, method.getExceptionTypes(), retType, typeParameterNames, overridden, false, lineDelimiter); }
Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • decl – The MethodDeclaration AST node that will be added as new method. The node does not need to exist in an AST (no parent needed) and does not need to resolve. See AST.newMethodDeclaration() for how to create such a node.
  • isDeprecated – If set, the method is deprecated
  • overriddenMethodName – If a method is overridden, the simple name of the overridden method, or null if no method is overridden.
  • overriddenMethodDeclaringTypeName – If a method is overridden, the fully qualified type name of the overridden method's declaring type, or null if no method is overridden.
  • overriddenMethodParameterTypeNames – If a method is overridden, the fully qualified parameter type names of the overridden method, or null if no method is overridden.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed comment or null if the comment code template is empty. The returned string is unformatted and and has no indent (formatting required).
Since:3.2
/** * Returns the comment for a method or constructor using the comment code templates (constructor / method / overriding method). * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param decl The MethodDeclaration AST node that will be added as new * method. The node does not need to exist in an AST (no parent needed) and does not need to resolve. * See {@link org.eclipse.jdt.core.dom.AST#newMethodDeclaration()} for how to create such a node. * @param isDeprecated If set, the method is deprecated * @param overriddenMethodName If a method is overridden, the simple name of the overridden method, or <code>null</code> if no method is overridden. * @param overriddenMethodDeclaringTypeName If a method is overridden, the fully qualified type name of the overridden method's declaring type, * or <code>null</code> if no method is overridden. * @param overriddenMethodParameterTypeNames If a method is overridden, the fully qualified parameter type names of the overridden method, * or <code>null</code> if no method is overridden. * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed comment or <code>null</code> if * the comment code template is empty. The returned string is unformatted and and has no indent (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.2 */
public static String getMethodComment(ICompilationUnit cu, String declaringTypeName, MethodDeclaration decl, boolean isDeprecated, String overriddenMethodName, String overriddenMethodDeclaringTypeName, String[] overriddenMethodParameterTypeNames, String lineDelimiter) throws CoreException { return StubUtility.getMethodComment(cu, declaringTypeName, decl, isDeprecated, overriddenMethodName, overriddenMethodDeclaringTypeName, overriddenMethodParameterTypeNames, false, lineDelimiter); }
Returns the comment for a module based on code templates
Params:
  • cu – The compilation unit for the module
  • moduleName – The name of the module
  • providesNames – Names of provided services
  • usesNames – Names of used modules
  • lineDelimiter – The line delimiter to use
Throws:
  • CoreException – Thrown when the evaluation of the code template fails
Returns:Module comment
Since:1.12
/** * Returns the comment for a module based on code templates * * @param cu The compilation unit for the module * @param moduleName The name of the module * @param providesNames Names of provided services * @param usesNames Names of used modules * @param lineDelimiter The line delimiter to use * @return Module comment * @throws CoreException Thrown when the evaluation of the code template fails * @since 1.12 */
public static String getModuleComment(ICompilationUnit cu, String moduleName, String[] providesNames, String[] usesNames, String lineDelimiter) throws CoreException { return StubUtility.getModuleComment(cu, moduleName, providesNames, usesNames, lineDelimiter); }
Returns the comment for a module based on code templates
Params:
  • cu – The compilation unit for the module
  • desc – The module description
  • lineDelimiter – The line delimiter to use
Throws:
  • CoreException – Thrown when the evaluation of the code template fails
Returns:Module comment
Since:1.12
/** * Returns the comment for a module based on code templates * * @param cu The compilation unit for the module * @param desc The module description * @param lineDelimiter The line delimiter to use * @return Module comment * @throws CoreException Thrown when the evaluation of the code template fails * @since 1.12 */
public static String getModuleComment(ICompilationUnit cu, IModuleDescription desc, String lineDelimiter) throws CoreException { return StubUtility.getModuleComment(cu, desc.getElementName(), desc.getProvidedServiceNames(), desc.getUsedServiceNames(), lineDelimiter); }
Returns the content of the body for a method or constructor using the method body templates. null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – Name of the method.
  • isConstructor – Defines if the created body is for a constructor.
  • bodyStatement – The code to be entered at the place of the variable ${body_statement}.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed body content or null if the comment code template is empty. The returned string is unformatted and and has no indent (formatting required).
/** * Returns the content of the body for a method or constructor using the method body templates. * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName Name of the method. * @param isConstructor Defines if the created body is for a constructor. * @param bodyStatement The code to be entered at the place of the variable ${body_statement}. * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed body content or <code>null</code> if * the comment code template is empty. The returned string is unformatted and and has no indent (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. */
public static String getMethodBodyContent(ICompilationUnit cu, String declaringTypeName, String methodName, boolean isConstructor, String bodyStatement, String lineDelimiter) throws CoreException { return StubUtility.getMethodBodyContent(isConstructor, cu.getJavaProject(), declaringTypeName, methodName, bodyStatement, lineDelimiter); }
Returns the content of body for a getter method using the getter method body template. null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – The name of the getter method.
  • fieldName – The name of the field to get in the getter method, corresponding to the template variable for ${field}.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed body content or null if the comment code template is empty. The returned string is unformatted and and has no indent (formatting required).
Since:3.0
/** * Returns the content of body for a getter method using the getter method body template. * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName The name of the getter method. * @param fieldName The name of the field to get in the getter method, corresponding to the template variable for ${field}. * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed body content or <code>null</code> if * the comment code template is empty. The returned string is unformatted and and has no indent (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.0 */
public static String getGetterMethodBodyContent(ICompilationUnit cu, String declaringTypeName, String methodName, String fieldName, String lineDelimiter) throws CoreException { return StubUtility.getGetterMethodBodyContent(cu.getJavaProject(), declaringTypeName, methodName, fieldName, lineDelimiter); }
Returns the content of body for a setter method using the setter method body template. null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – The name of the setter method.
  • fieldName – The name of the field to be set in the setter method, corresponding to the template variable for ${field}.
  • paramName – The name of the parameter passed to the setter method, corresponding to the template variable for $(param).
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the constructed body content or null if the comment code template is empty. The returned string is unformatted and and has no indent (formatting required).
Since:3.0
/** * Returns the content of body for a setter method using the setter method body template. * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName The name of the setter method. * @param fieldName The name of the field to be set in the setter method, corresponding to the template variable for ${field}. * @param paramName The name of the parameter passed to the setter method, corresponding to the template variable for $(param). * @param lineDelimiter The line delimiter to be used. * @return Returns the constructed body content or <code>null</code> if * the comment code template is empty. The returned string is unformatted and and has no indent (formatting required). * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.0 */
public static String getSetterMethodBodyContent(ICompilationUnit cu, String declaringTypeName, String methodName, String fieldName, String paramName, String lineDelimiter) throws CoreException { return StubUtility.getSetterMethodBodyContent(cu.getJavaProject(), declaringTypeName, methodName, fieldName, paramName, lineDelimiter); }
Returns the comment for a getter method using the getter comment template. null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – Name of the method.
  • fieldName – Name of the field to get.
  • fieldType – The type of the field to get.
  • bareFieldName – The field name without prefix or suffix.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the generated getter comment or null if the code template is empty. The returned content is not indented.
Since:3.0
/** * Returns the comment for a getter method using the getter comment template. * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName Name of the method. * @param fieldName Name of the field to get. * @param fieldType The type of the field to get. * @param bareFieldName The field name without prefix or suffix. * @param lineDelimiter The line delimiter to be used. * @return Returns the generated getter comment or <code>null</code> if the * code template is empty. The returned content is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.0 */
public static String getGetterComment(ICompilationUnit cu, String declaringTypeName, String methodName, String fieldName, String fieldType, String bareFieldName, String lineDelimiter) throws CoreException { return StubUtility.getGetterComment(cu, declaringTypeName, methodName, fieldName, fieldType, bareFieldName, lineDelimiter); }
Returns the comment for a setter method using the setter method body template. null is returned if the template is empty.

The returned string is unformatted and not indented.

Params:
  • cu – The compilation unit to which the method belongs. The compilation unit does not need to exist.
  • declaringTypeName – Name of the type to which the method belongs. For inner types the name must be qualified and include the outer types names (dot separated). See IType.getTypeQualifiedName(char).
  • methodName – Name of the method.
  • fieldName – Name of the field that is set.
  • fieldType – The type of the field that is to set.
  • paramName – The name of the parameter that used to set.
  • bareFieldName – The field name without prefix or suffix.
  • lineDelimiter – The line delimiter to be used.
Throws:
  • CoreException – Thrown when the evaluation of the code template fails.
Returns:Returns the generated setter comment or null if the code template is empty. The returned comment is not indented.
Since:3.0
/** * Returns the comment for a setter method using the setter method body template. * <code>null</code> is returned if the template is empty. * <p>The returned string is unformatted and not indented. * * @param cu The compilation unit to which the method belongs. The compilation unit does not need to exist. * @param declaringTypeName Name of the type to which the method belongs. For inner types the name must be qualified and include the outer * types names (dot separated). See {@link org.eclipse.jdt.core.IType#getTypeQualifiedName(char)}. * @param methodName Name of the method. * @param fieldName Name of the field that is set. * @param fieldType The type of the field that is to set. * @param paramName The name of the parameter that used to set. * @param bareFieldName The field name without prefix or suffix. * @param lineDelimiter The line delimiter to be used. * @return Returns the generated setter comment or <code>null</code> if the * code template is empty. The returned comment is not indented. * @throws CoreException Thrown when the evaluation of the code template fails. * @since 3.0 */
public static String getSetterComment(ICompilationUnit cu, String declaringTypeName, String methodName, String fieldName, String fieldType, String paramName, String bareFieldName, String lineDelimiter) throws CoreException { return StubUtility.getSetterComment(cu, declaringTypeName, methodName, fieldName, fieldType, paramName, bareFieldName, lineDelimiter); } }