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

com.querydsl.sql.codegen.NamingStrategy Maven / Gradle / Ivy

/*
 * Copyright 2015, The Querydsl Team (http://www.querydsl.com/team)
 *
 * 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 com.querydsl.sql.codegen;

import com.querydsl.codegen.EntityType;
import com.querydsl.sql.SchemaAndTable;
import com.querydsl.sql.codegen.support.ForeignKeyData;

/**
 * {@code NamingStrategy} defines a conversion strategy from table to class and column to property
 * names
 *
 * @author tiwe
 */
public interface NamingStrategy {

  /**
   * Normalizes and appends the given schema name to the package name
   *
   * @deprecated Use {@link #getPackage(String, SchemaAndTable)} instead.
   * @param packageName
   * @param schema
   * @return
   */
  @Deprecated
  String appendSchema(String packageName, String schema);

  /**
   * Convert the given tableName to a simple class name
   *
   * @deprecated Use {@link #getClassName(SchemaAndTable)} instead.
   * @return
   */
  @Deprecated
  String getClassName(String tableName);

  /** Convert the given schema and table name to a simple class name. */
  String getClassName(SchemaAndTable schemaAndTable);

  /**
   * Get the default alias for the given EntityType
   *
   * @param entityType
   * @return
   */
  String getDefaultAlias(EntityType entityType);

  /**
   * Get the default variable name for the given EntityType
   *
   * @param entityType
   * @return
   */
  String getDefaultVariableName(EntityType entityType);

  /**
   * Get the class name for the foreign keys inner class
   *
   * @return
   */
  String getForeignKeysClassName();

  /**
   * Get the field name for the foreign keys class instance
   *
   * @return
   */
  String getForeignKeysVariable(EntityType entityType);

  /**
   * Get the class name for the primary keys inner class
   *
   * @return
   */
  String getPrimaryKeysClassName();

  /**
   * Get the field name for the primary keys class instance
   *
   * @return
   */
  String getPrimaryKeysVariable(EntityType entityType);

  /**
   * Convert the given column name to a property name
   *
   * @param columnName
   * @param entityType
   * @return
   */
  String getPropertyName(String columnName, EntityType entityType);

  /**
   * Convert the given foreign key name to a foreign key property name
   *
   * @param foreignKeyName
   * @param entityType
   * @return
   */
  String getPropertyNameForForeignKey(String foreignKeyName, EntityType entityType);

  /**
   * Convert the given foreign key name to a foreign key property name
   *
   * @param name
   * @param model
   * @return
   */
  String getPropertyNameForInverseForeignKey(String name, EntityType model);

  /**
   * Convert the given primary key name to a primary key property name
   *
   * @param name
   * @param model
   * @return
   */
  String getPropertyNameForPrimaryKey(String name, EntityType model);

  /**
   * Convert the given column name and provide the opportunity to add quoted identifiers
   *
   * @param columnName
   * @return
   */
  String normalizeColumnName(String columnName);

  /**
   * Convert the given table name and provide the opportunity to add quoted identifiers
   *
   * @param tableName
   * @return
   */
  String normalizeTableName(String tableName);

  /**
   * Convert the given schema name and provide the opportunity to add quoted identifiers
   *
   * @param schemaName
   * @return
   */
  String normalizeSchemaName(String schemaName);

  /**
   * Returns true if the class generation of the table is required, otherwise 
   * false.
   *
   * @param schemaAndTable the schema and table
   * @return
   */
  boolean shouldGenerateClass(SchemaAndTable schemaAndTable);

  /**
   * Returns true if the foreign key reference should be generated in the table,
   * otherwise false.
   *
   * @param schemaAndTable the schema and table
   * @param foreignKeyData the foreign key in the table
   * @return
   */
  boolean shouldGenerateForeignKey(SchemaAndTable schemaAndTable, ForeignKeyData foreignKeyData);

  /**
   * Returns the package where the class of the table will be generated.
   *
   * @param basePackage the base package of the class generation
   * @param schemaAndTable the schema and table
   * @return
   */
  String getPackage(String basePackage, SchemaAndTable schemaAndTable);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy