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

com.speedment.common.codegen.constant.DefaultAnnotationUsage 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.

There is a newer version: 3.1.6
Show newest version
/**
 *
 * Copyright (c) 2006-2016, 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.constant;

import com.speedment.common.codegen.model.AnnotationUsage;
import com.speedment.common.codegen.model.Value;

import javax.annotation.Generated;
import java.lang.annotation.*;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Optional;

import static com.speedment.common.codegen.constant.DefaultValue.string;
import static java.util.Objects.requireNonNull;

/**
 * An enumeration with default constants for the {@link AnnotationUsage}
 * interface. If any of the setter methods are called, the model will be cloned
 * into a non-enum value before the value is changed in the clone. This makes
 * it possible to safely set values in the constants without changing their
 * actual state.
 * 
 * @author Emil Forslund
 */
public enum DefaultAnnotationUsage implements AnnotationUsage {
    
    OVERRIDE    (Override.class),
    DOCUMENTED  (Documented.class),
    INHERITED   (Inherited.class),
    NATIVE      (Native.class),
    REPEATABLE  (Repeatable.class),
    RETENTION   (Retention.class),
    TARGET      (Target.class),
    GENERATED   (Generated.class),
    DEPRECATED  (Deprecated.class),
    SUPPRESS_WARNINGS_UNCHECKED (
        SuppressWarnings.class, string("unchecked")
    );
    
    private final Type type;
	private final Value value;
	
    /**
     * Constructs the AnnotationUsage based on a {@link Type}.
     * 
     * @param type  the type
     */
	DefaultAnnotationUsage(Type type) {
		this (type, null);
	}
    
    /**
     * Constructs the AnnotationUsage based on a {@link Type} and a {@link Value}.
     * 
     * @param type  the type
     */
    DefaultAnnotationUsage(Type type, Value value) {
		this.type	= requireNonNull(type);
		this.value	= value;
	}
    
    /**
     * {@inheritDoc}
     * 

* Since this is a constant, the model will first be copied and the * operation will then be performed on the copy. */ @Override public AnnotationUsage set(Type type) { return copy().set(requireNonNull(type)); } /** * {@inheritDoc} *

* Since this is a constant, the model will first be copied and the * operation will then be performed on the copy. */ @Override public AnnotationUsage set(Value val) { return copy().set(val); } /** * {@inheritDoc} *

* Since this is a constant, the model will first be copied and the * operation will then be performed on the copy. */ @Override public AnnotationUsage put(String key, Value val) { return copy().put(requireNonNull(key), val); } /** * {@inheritDoc} */ @Override public Type getType() { return type; } /** * {@inheritDoc} */ @Override public Optional> getValue() { return Optional.ofNullable(value).map(Value::copy); } /** * {@inheritDoc} */ @Override public List>> getValues() { return new ArrayList<>(); } /** * {@inheritDoc} */ @Override public AnnotationUsage copy() { final AnnotationUsage copy = AnnotationUsage.of(getType()); getValue().ifPresent(copy::set); return copy; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy