Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* 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.codegen;
import static com.querydsl.codegen.utils.Symbols.THIS_ESCAPE;
import com.querydsl.codegen.utils.CodeWriter;
import com.querydsl.codegen.utils.model.ClassType;
import com.querydsl.codegen.utils.model.Parameter;
import com.querydsl.codegen.utils.model.Type;
import com.querydsl.codegen.utils.model.TypeCategory;
import com.querydsl.codegen.utils.model.Types;
import com.querydsl.core.util.BeanUtils;
import jakarta.inject.Inject;
import jakarta.inject.Named;
import java.io.IOException;
import java.lang.annotation.Annotation;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.function.Function;
/**
* {@code BeanSerializer} is a {@link Serializer} implementation which serializes {@link EntityType}
* instances into JavaBean classes
*
* @author tiwe
*/
public class BeanSerializer implements Serializer {
public static final String DEFAULT_JAVADOC_SUFFIX = " is a Querydsl bean type";
public static final boolean DEFAULT_PROPERTY_ANNOTATIONS = true;
private static final Function propertyToParameter =
new Function<>() {
@Override
public Parameter apply(Property input) {
return new Parameter(input.getName(), input.getType());
}
};
private final Class extends Annotation> generatedAnnotationClass;
private final boolean propertyAnnotations;
private final List interfaces = new ArrayList<>();
private final String javadocSuffix;
private boolean addToString, addFullConstructor;
private boolean printSupertype = false;
/** Create a new BeanSerializer */
public BeanSerializer() {
this(
DEFAULT_PROPERTY_ANNOTATIONS,
DEFAULT_JAVADOC_SUFFIX,
GeneratedAnnotationResolver.resolveDefault());
}
/**
* Create a new BeanSerializer with the given javadoc suffix
*
* @param javadocSuffix suffix to be used after the simple name in class level javadoc
*/
public BeanSerializer(String javadocSuffix) {
this(DEFAULT_PROPERTY_ANNOTATIONS, javadocSuffix);
}
/**
* Create a new BeanSerializer with the given javadoc suffix and generatedAnnotationClass
*
* @param javadocSuffix suffix to be used after the simple name in class level javadoc
* @param generatedAnnotationClass the fully qualified class name of the Single-Element
* Annotation (with {@code String} element) to be used on the generated classes.
* @see Single-Element
* Annotation
*/
@Inject
public BeanSerializer(
@Named(CodegenModule.JAVADOC_SUFFIX) String javadocSuffix,
@Named(CodegenModule.GENERATED_ANNOTATION_CLASS)
Class extends Annotation> generatedAnnotationClass) {
this(DEFAULT_PROPERTY_ANNOTATIONS, javadocSuffix, generatedAnnotationClass);
}
/**
* Create a new BeanSerializer
*
* @param propertyAnnotations true, to serialize property annotations
*/
public BeanSerializer(boolean propertyAnnotations) {
this(propertyAnnotations, DEFAULT_JAVADOC_SUFFIX);
}
/**
* Create a new BeanSerializer
*
* @param propertyAnnotations true, to serialize property annotations
* @param javadocSuffix suffix to be used after the simple name in class level javadoc
*/
public BeanSerializer(boolean propertyAnnotations, String javadocSuffix) {
this(propertyAnnotations, javadocSuffix, GeneratedAnnotationResolver.resolveDefault());
}
/**
* Create a new BeanSerializer
*
* @param propertyAnnotations true, to serialize property annotations
* @param javadocSuffix suffix to be used after the simple name in class level javadoc
* @param generatedAnnotationClass the fully qualified class name of the Single-Element
* Annotation (with {@code String} element) to be used on the generated classes. * @see
* Single-Element
* Annotation
*/
public BeanSerializer(
boolean propertyAnnotations,
String javadocSuffix,
Class extends Annotation> generatedAnnotationClass) {
this.propertyAnnotations = propertyAnnotations;
this.javadocSuffix = javadocSuffix;
this.generatedAnnotationClass = generatedAnnotationClass;
}
@Override
public void serialize(EntityType model, SerializerConfig serializerConfig, CodeWriter writer)
throws IOException {
var simpleName = model.getSimpleName();
// package
if (!model.getPackageName().isEmpty()) {
writer.packageDecl(model.getPackageName());
}
// imports
var importedClasses = getAnnotationTypes(model);
for (Type iface : interfaces) {
importedClasses.add(iface.getFullName());
}
importedClasses.add(generatedAnnotationClass.getName());
if (model.hasLists()) {
importedClasses.add(List.class.getName());
}
if (model.hasCollections()) {
importedClasses.add(Collection.class.getName());
}
if (model.hasSets()) {
importedClasses.add(Set.class.getName());
}
if (model.hasMaps()) {
importedClasses.add(Map.class.getName());
}
if (addToString && model.hasArrays()) {
importedClasses.add(Arrays.class.getName());
}
writer.importClasses(importedClasses.toArray(new String[0]));
// javadoc
writer.javadoc(simpleName + javadocSuffix);
// header
for (Annotation annotation : model.getAnnotations()) {
writer.annotation(annotation);
}
writer.suppressWarnings(THIS_ESCAPE);
writer.line("@", generatedAnnotationClass.getSimpleName(), "(\"", getClass().getName(), "\")");
if (!interfaces.isEmpty()) {
Type superType = null;
if (printSupertype && model.getSuperType() != null) {
superType = model.getSuperType().getType();
}
var ifaces = interfaces.toArray(new Type[0]);
writer.beginClass(model, superType, ifaces);
} else if (printSupertype && model.getSuperType() != null) {
writer.beginClass(model, model.getSuperType().getType());
} else {
writer.beginClass(model);
}
bodyStart(model, writer);
if (addFullConstructor) {
addFullConstructor(model, writer);
}
// fields
for (Property property : model.getProperties()) {
if (propertyAnnotations) {
for (Annotation annotation : property.getAnnotations()) {
writer.annotation(annotation);
}
}
writer.privateField(property.getType(), property.getEscapedName());
}
// accessors
for (Property property : model.getProperties()) {
var propertyName = property.getEscapedName();
// getter
writer.beginPublicMethod(property.getType(), "get" + BeanUtils.capitalize(propertyName));
writer.line("return ", propertyName, ";");
writer.end();
// setter
var parameter = new Parameter(propertyName, property.getType());
writer.beginPublicMethod(Types.VOID, "set" + BeanUtils.capitalize(propertyName), parameter);
writer.line("this.", propertyName, " = ", propertyName, ";");
writer.end();
}
if (addToString) {
addToString(model, writer);
}
bodyEnd(model, writer);
writer.end();
}
protected void addFullConstructor(EntityType model, CodeWriter writer) throws IOException {
// public empty constructor
writer.beginConstructor();
writer.end();
// full constructor
writer.beginConstructor(model.getProperties(), propertyToParameter::apply);
for (Property property : model.getProperties()) {
writer.line("this.", property.getEscapedName(), " = ", property.getEscapedName(), ";");
}
writer.end();
}
protected void addToString(EntityType model, CodeWriter writer) throws IOException {
writer.line("@Override");
writer.beginPublicMethod(Types.STRING, "toString");
var builder = new StringBuilder();
for (Property property : model.getProperties()) {
var propertyName = property.getEscapedName();
if (builder.length() > 0) {
builder.append(" + \", ");
} else {
builder.append("\"");
}
builder.append(propertyName).append(" = \" + ");
if (property.getType().getCategory() == TypeCategory.ARRAY) {
builder.append("Arrays.toString(").append(propertyName).append(")");
} else {
builder.append(propertyName);
}
}
writer.line(" return ", builder.toString(), ";");
writer.end();
}
protected void bodyStart(EntityType model, CodeWriter writer) throws IOException {
// template method
}
protected void bodyEnd(EntityType model, CodeWriter writer) throws IOException {
// template method
}
private Set getAnnotationTypes(EntityType model) {
Set imports = new HashSet<>();
for (Annotation annotation : model.getAnnotations()) {
imports.add(annotation.annotationType().getName());
}
if (propertyAnnotations) {
for (Property property : model.getProperties()) {
for (Annotation annotation : property.getAnnotations()) {
imports.add(annotation.annotationType().getName());
}
}
}
return imports;
}
public void addInterface(Class> iface) {
interfaces.add(new ClassType(iface));
}
public void addInterface(Type type) {
interfaces.add(type);
}
public void setAddToString(boolean addToString) {
this.addToString = addToString;
}
public void setAddFullConstructor(boolean addFullConstructor) {
this.addFullConstructor = addFullConstructor;
}
public void setPrintSupertype(boolean printSupertype) {
this.printSupertype = printSupertype;
}
}