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

com.speedment.common.codegen.internal.model.JavadocImpl Maven / Gradle / Ivy

/**
 *
 * 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.internal.model;

import com.speedment.common.codegen.internal.util.Copier;
import com.speedment.common.codegen.model.Javadoc;
import com.speedment.common.codegen.model.JavadocTag;

import java.util.ArrayList;
import java.util.List;
import java.util.Objects;

import static java.util.Objects.requireNonNull;

/**
 * This is the default implementation of the {@link Javadoc} interface.
 * This class should not be instantiated directly. Instead you should call the
 * {@link Javadoc#of()} method to get an instance. In that way, you can layer 
 * change the implementing class without modifying the using code.
 * 
 * @author Emil Forslund
 * @see    Javadoc
 */
public final class JavadocImpl implements Javadoc {

    private String text;
    private final List tags;

    /**
     * Initializes this javadoc block.
     * 

* Warning! This class should not be instantiated directly but using * the {@link Javadoc#of()} method! */ public JavadocImpl() { text = ""; tags = new ArrayList<>(); } /** * Initializes this javadoc block using a text. The text may have multiple * lines separated by new-line characters. *

* Warning! This class should not be instantiated directly but using * the {@link Javadoc#of(java.lang.String)} method! * * @param text the text */ public JavadocImpl(final String text) { this.text = requireNonNull(text); this.tags = new ArrayList<>(); } /** * Copy constructor. * * @param prototype the prototype */ protected JavadocImpl(final Javadoc prototype) { text = requireNonNull(prototype).getText(); tags = Copier.copy(prototype.getTags()); } /** * {@inheritDoc} */ @Override public String getText() { return text; } /** * {@inheritDoc} */ @Override public Javadoc setText(String text) { this.text = text; return this; } /** * {@inheritDoc} */ @Override public List getTags() { return tags; } /** * {@inheritDoc} */ @Override public JavadocImpl copy() { return new JavadocImpl(this); } @Override public int hashCode() { int hash = 7; hash = 29 * hash + Objects.hashCode(this.text); hash = 29 * hash + Objects.hashCode(this.tags); return hash; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (getClass() != obj.getClass()) { return false; } final JavadocImpl other = (JavadocImpl) obj; if (!Objects.equals(this.text, other.text)) { return false; } return Objects.equals(this.tags, other.tags); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy