All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.mybatis.generator.api.CommentGenerator Maven / Gradle / Ivy

The newest version!
/*
 *  Copyright 2008 The Apache Software Foundation
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
package org.mybatis.generator.api;

import org.mybatis.generator.api.dom.java.*;
import org.mybatis.generator.api.dom.xml.XmlElement;

import java.util.Properties;

/**
 * Implementations of this interface are used to generate comments for the
 * various artifacts.
 * 
 * @author Jeff Butler
 */
public interface CommentGenerator {

    /**
     * Adds properties for this instance from any properties configured in the
     * CommentGenerator configuration.
     * 
     * This method will be called before any of the other methods.
     * 
     * @param properties
     *            All properties from the configuration
     */
    void addConfigurationProperties(Properties properties);

    /**
     * This method should add a Javadoc comment to the specified field. The
     * field is related to the specified table and is used to hold the value of
     * the specified column.
     * 

* * Important: This method should add a the nonstandard JavaDoc tag * "@mbggenerated" to the comment. Without this tag, the Eclipse based Java * merge feature will fail. * * @param field field * @param introspectedTable introspectedTable * @param introspectedColumn introspectedColumn */ public void addFieldComment(Field field, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn); public void addFieldComment(Field field, IntrospectedTable introspectedTable); public void addClassComment(InnerClass innerClass, IntrospectedTable introspectedTable); public void addClassComment(InnerClass innerClass, IntrospectedTable introspectedTable, boolean markAsDoNotDelete); public void addEnumComment(InnerEnum innerEnum, IntrospectedTable introspectedTable); public void addGetterComment(Method method, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn); public void addSetterComment(Method method, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn); public void addGeneralMethodComment(Method method, IntrospectedTable introspectedTable); /** * This method is called to add a file level comment to a generated java * file. This method could be used to add a general file comment (such as a * copyright notice). However, note that the Java file merge function in * Eclipse does not deal with this comment. If you run the generator * repeatedly, you will only retain the comment from the initial run. *

* * The default implementation does nothing. * * @param compilationUnit compilationUnit */ public void addJavaFileComment(CompilationUnit compilationUnit); /** * This method should add a suitable comment as a child element of the * specified xmlElement to warn users that the element was generated and is * subject to regeneration. * * @param xmlElement xmlElement */ public void addComment(XmlElement xmlElement); /** * This method is called to add a comment as the first child of the root * element. This method could be used to add a general file comment (such as * a copyright notice). However, note that the XML file merge function does * not deal with this comment. If you run the generator repeatedly, you will * only retain the comment from the initial run. *

* * The default implementation does nothing. * * @param rootElement rootElement */ public void addRootComment(XmlElement rootElement); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy