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

wtf.metio.yosql.codegen.blocks.Variables Maven / Gradle / Ivy

There is a newer version: 2023.5.3
Show newest version
/*
 * This file is part of yosql. It is subject to the license terms in the LICENSE file found in the top-level
 * directory of this distribution and at https://creativecommons.org/publicdomain/zero/1.0/. No part of yosql,
 * including this file, may be copied, modified, propagated, or distributed except according to the terms contained
 * in the LICENSE file.
 */

package wtf.metio.yosql.codegen.blocks;

import com.squareup.javapoet.CodeBlock;
import com.squareup.javapoet.TypeName;

/**
 * Controls the generation of variables. Handles the usage of keywords like 'final' or 'var'.
 */
public interface Variables {

    /**
     * Generates an inline variable without an initializer.
     *
     * @param variableClass The class of the variable.
     * @param name          The name of the variable.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock inline(Class variableClass, String name);

    /**
     * Generates an inline variable with an initializer.
     *
     * @param variableClass The class of the variable.
     * @param name          The name of the variable.
     * @param initializer   The initializer to use.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock inline(Class variableClass, String name, CodeBlock initializer);

    /**
     * Generates an inline variable with an initializer.
     *
     * @param variableType The type of the variable.
     * @param name         The name of the variable.
     * @param initializer  The initializer to use.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock inline(TypeName variableType, String name, CodeBlock initializer);

    /**
     * Generates an inline variable with an initializer.
     *
     * @param variableClass   The class of the variable.
     * @param name            The name of the variable.
     * @param initializer     The initializer to use.
     * @param initializerArgs The initializer arguments to use.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock inline(Class variableClass, String name, String initializer, Object... initializerArgs);

    /**
     * Generates an inline variable with an initializer.
     *
     * @param variableType    The type of the variable.
     * @param name            The name of the variable.
     * @param initializer     The initializer to use.
     * @param initializerArgs The initializer arguments to use.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock inline(TypeName variableType, String name, String initializer, Object... initializerArgs);

    /**
     * Generates a variable statement with an initializer.
     *
     * @param variableClass The class of the variable.
     * @param name          The name of the variable.
     * @param initializer   The initializer to use.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock statement(Class variableClass, String name, CodeBlock initializer);

    /**
     * Generates a variable statement with an initializer.
     *
     * @param variableType The type of the variable.
     * @param name         The name of the variable.
     * @param initializer  The initializer to use.
     * @return The corresponding code block for the new variable.
     */
    CodeBlock statement(TypeName variableType, String name, CodeBlock initializer);

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy