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

com.speedment.common.codegen.internal.java.view.ClassOrInterfaceView Maven / Gradle / Ivy

Go to download

A Speedment bundle that shades all dependencies into one jar. This is useful when deploying an application on a server.

The newest version!
/*
 *
 * Copyright (c) 2006-2019, Speedment, Inc. All Rights Reserved.
 *
 * 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.speedment.common.codegen.internal.java.view;

import com.speedment.common.codegen.Generator;
import com.speedment.common.codegen.Transform;
import com.speedment.common.codegen.internal.java.view.trait.*;
import com.speedment.common.codegen.model.ClassOrInterface;

import java.util.Optional;
import java.util.regex.Pattern;
import java.util.stream.Stream;

import static com.speedment.common.codegen.internal.util.NullUtil.requireNonNullElements;
import static com.speedment.common.codegen.internal.util.NullUtil.requireNonNulls;
import static com.speedment.common.codegen.util.Formatting.*;
import static java.util.stream.Collectors.joining;


/**
 * An abstract base class used to share functionality between different view
 * components such as {@link ClassView}, {@link EnumView} and 
 * {@link InterfaceView}.
 * 
 * @param   the extending model type
 * @author     Emil Forslund
 */
abstract class ClassOrInterfaceView> implements Transform, 
        HasNameView, 
        HasModifiersView, 
        HasJavadocView, 
        HasGenericsView,
        HasImplementsView, 
        HasInitializersView, 
        HasMethodsView,
        HasClassesView, 
        HasAnnotationUsageView, 
        HasFieldsView {

	private static final Pattern EMPTY_BLOCK =
		Pattern.compile("^\\s*\\{\\s*}\\s*$");

	protected static final String
		CLASS_STRING      = "class ",
		INTERFACE_STRING  = "interface ",
		ENUM_STRING       = "enum ",
		IMPLEMENTS_STRING = "implements ",
		EXTENDS_STRING    = "extends ";

    /**
     * A hook that is executed just before the 'fields' part of the class code.
     * 
     * @param gen    the generator being used
     * @param model  the model that is generated
     * @return       code to be inserted before the fields
     */
	protected String onBeforeFields(Generator gen, M model) {
		return "";
	}

    @Override
    public String fieldSeparator(M model) {
        return nl();
    }

    @Override
    public String fieldSuffix() {
        return ";";
    }
	
    /**
     * Returns the declaration type of this model. This can be either 'class',
     * 'interface' or 'enum'.
     * 
     * @return  the declaration type
     */
    protected abstract String renderDeclarationType();
    
    /**
     * Returns the supertype of this model. The supertype should include any
     * declaration like 'implements' or 'extends'.
     * 

* Example:

"implements List"
* * @param gen the generator to use * @param model the model of the component * @return the supertype part */ protected abstract String renderSupertype(Generator gen, M model); /** * Should render the constructors part of the code and return it. * * @param gen the generator to use * @param model the model of the component * @return generated constructors or an empty string if there shouldn't * be any */ protected abstract String renderConstructors(Generator gen, M model); @Override public Optional transform(Generator gen, M model) { requireNonNulls(gen, model); String code = block(nl() + separate( onBeforeFields(gen, model), // Enums have constants here.´ renderFields(gen, model), renderConstructors(gen, model), renderInitalizers(gen, model), renderMethods(gen, model), renderClasses(gen, model) )); if (EMPTY_BLOCK.matcher(code).find()) { code = "{}"; } return Optional.of(renderJavadoc(gen, model) + renderAnnotations(gen, model) + renderModifiers(gen, model) + renderDeclarationType() + renderName(gen, model) + renderGenerics(gen, model) + (model.getGenerics().isEmpty() ? " " : "") + renderSupertype(gen, model) + renderInterfaces(gen, model) + // Code code ); } /** * Converts the specified elements into strings using their * toString-method and combines them with two new-line-characters. * Empty strings will be discarded. * * @param strings the strings to combine * @return the combined string */ private String separate(Object... strings) { requireNonNullElements(strings); return Stream.of(strings) .map(Object::toString) .filter(s -> s.length() > 0) .collect(joining(dnl())); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy