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

br.com.objectos.way.sql.compiler.QuerySql Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2015 Objectos, Fábrica de Software LTDA.
 *
 * 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 br.com.objectos.way.sql.compiler;

import java.util.List;
import java.util.Set;

import br.com.objectos.way.code.AnnotationInfo;
import br.com.objectos.way.code.AnnotationInfoEnclosingTypeInfo;
import br.com.objectos.way.code.ClassInfo;
import br.com.objectos.way.code.ImportInfo;
import br.com.objectos.way.code.ImportInfoSet;
import br.com.objectos.way.code.MethodInfo;
import br.com.objectos.way.code.NameInfo;
import br.com.objectos.way.code.PackageInfo;
import br.com.objectos.way.code.SimpleTypeInfo;
import br.com.objectos.way.code.TypeInfo;
import br.com.objectos.way.core.tmpl.mustache.IsMustacheSerializable;
import br.com.objectos.way.core.tmpl.mustache.MustacheObject;
import br.com.objectos.way.core.tmpl.mustache.Mustaches;
import br.com.objectos.way.core.util.WayIterables;
import br.com.objectos.way.sql.Parameter;
import br.com.objectos.way.sql.SqlException;
import br.com.objectos.way.sql.Transaction;
import br.com.objectos.way.sql.WaySql;

import com.google.common.base.Function;
import com.google.common.base.Optional;

/**
 * @author [email protected] (Marcio Endo)
 */
abstract class QuerySql implements IsMustacheSerializable {

  private final ClassInfo classInfo;
  private final MethodInfo methodInfo;

  private final TypeInfo joinedTypeInfo;
  private final List columnList;
  private final Optional parameter;

  QuerySql(ClassInfo classInfo, MethodInfo methodInfo, TypeInfo joinedTypeInfo) {
    this.classInfo = classInfo;
    this.methodInfo = methodInfo;
    this.joinedTypeInfo = joinedTypeInfo;
    columnList = SqlColumn.columnListOf(joinedTypeInfo);
    parameter = QueryParameter.parameterOf(methodInfo);
  }

  public static QuerySql wrap(ClassInfo classInfo, MethodInfo methodInfo) {
    SimpleTypeInfo returnTypeInfo = methodInfo.returnTypeInfo();

    if (returnTypeInfo.isInfoOf(List.class)) {
      TypeInfo relatedTypeInfo = relatedTypeInfo(returnTypeInfo);
      return new QueryListSql(classInfo, methodInfo, relatedTypeInfo);
    }

    if (returnTypeInfo.isInfoOf(Optional.class)) {
      TypeInfo relatedTypeInfo = relatedTypeInfo(returnTypeInfo);
      return new QueryMaybeSql(classInfo, methodInfo, relatedTypeInfo);
    }

    throw new AssertionError();
  }

  private static TypeInfo relatedTypeInfo(SimpleTypeInfo returnTypeInfo) {
    return returnTypeInfo.getTypeParameterInfoIterable()
        .first()
        .get()
        .getTypeInfo()
        .get();
  }

  @Override
  public MustacheObject toMustache() {
    ImportInfoSet importInfoSet = importInfoSet();
    List imports = importInfoSet.toImportInfoList(classInfo);

    return Mustaches.toMustacheHelper()
        .add("imports", imports)
        .add("emptyImports", imports.isEmpty())

        .add("columns", columns())
        .add("joinedClass", joinedTypeInfo)
        .add("orderBy", orderBy())
        .add("processorClass", SqlPojoProcessor.class.getName())
        .add("queryParameter", parameter.orNull())
        .add("queryReturn", queryReturn(joinedTypeInfo))
        .add("selectClassName", selectClassName())
        .add("selectMethodName", selectMethodName())
        .add("sqlClassName", sqlClasName())
        .add("superClass", classInfo)
        .add("tables", tables())
        .toMustache();
  }

  ImportInfoSet importInfoSet() {
    ImportInfoSet importInfoSet = ImportInfoSet.setOf();

    importInfoSet.add(Parameter.class);
    importInfoSet.add(SqlException.class);
    importInfoSet.add(Transaction.class);
    importInfoSet.add(WaySql.class);

    importInfoSet.addAll(joinedTypeInfo.toImportInfo());
    addAll(importInfoSet);

    if (parameter.isPresent()) {
      QueryParameter _parameter = parameter.get();
      _parameter.addTo(importInfoSet);
    }

    return importInfoSet;
  }

  abstract String queryReturn(TypeInfo joinedTypeInfo);

  abstract String selectClassName();

  abstract String selectMethodName();

  private void addAll(ImportInfoSet importInfoSet) {
    PackageInfo joinedPackageInfo = joinedTypeInfo.packageInfo();
    String joinedLoaderName = joinedTypeInfo.getSimpleName() + "Loader";
    NameInfo joinedLoaderNamedInfo = NameInfo.of(joinedLoaderName);
    ImportInfo joinedLoaderImportInfo = joinedPackageInfo.toImportInfo(joinedLoaderNamedInfo);
    importInfoSet.add(joinedLoaderImportInfo);
  }

  private List columns() {
    return WayIterables.from(columnList)
        .transform(new Function() {
          @Override
          public QueryColumn apply(SqlColumn input) {
            return input.toQueryColumn(classInfo);
          }
        })
        .toImmutableList();
  }

  private QueryOrderBy orderBy() {
    return QueryOrderBy.wrap(methodInfo);
  }

  private String sqlClasName() {
    return classInfo.getSimpleName() + methodInfo.getClassName() + "Sql";
  }

  private Set tables() {
    return WayIterables.from(columnList)
        .transform(new Function() {
          @Override
          public AnnotationInfo apply(SqlColumn input) {
            return input.getAnnotationInfo();
          }
        })
        .transform(AnnotationInfoEnclosingTypeInfo.get())
        .presentInstancesOf(SimpleTypeInfo.class)
        .toImmutableSet();
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy