/**
*
* Copyright (c) 2006-2017, 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<JavadocTag> tags;
/**
* Initializes this javadoc block.
* <p>
* <b>Warning!</b> 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.
* <p>
* <b>Warning!</b> 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());
}
@Override
public String getText() {
return text;
}
@Override
public Javadoc setText(String text) {
this.text = text;
return this;
}
@Override
public List<JavadocTag> getTags() {
return tags;
}
@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);
}
}