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

org.jooq.conf.RenderFormatting Maven / Gradle / Ivy

There is a newer version: 3.19.15
Show newest version

package org.jooq.conf;

import java.io.Serializable;
import jakarta.xml.bind.annotation.XmlAccessType;
import jakarta.xml.bind.annotation.XmlAccessorType;
import jakarta.xml.bind.annotation.XmlElement;
import jakarta.xml.bind.annotation.XmlType;
import org.jooq.util.jaxb.tools.XMLAppendable;
import org.jooq.util.jaxb.tools.XMLBuilder;


/**
 * All sorts of formatting flags / settings.
 * 
 * 
 * 
 */
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "RenderFormatting", propOrder = {

})
@SuppressWarnings({
    "all"
})
public class RenderFormatting
    extends SettingsBase
    implements Serializable, Cloneable, XMLAppendable
{

    private final static long serialVersionUID = 31700L;
    @XmlElement(defaultValue = "\n")
    protected String newline = "\n";
    @XmlElement(defaultValue = "  ")
    protected String indentation = "  ";
    @XmlElement(defaultValue = "80")
    protected Integer printMargin = 80;

    /**
     * The character to be used for line breaks.
     * 
     */
    public String getNewline() {
        return newline;
    }

    /**
     * The character to be used for line breaks.
     * 
     */
    public void setNewline(String value) {
        this.newline = value;
    }

    /**
     * The characters to be used for indentation.
     * 
     */
    public String getIndentation() {
        return indentation;
    }

    /**
     * The characters to be used for indentation.
     * 
     */
    public void setIndentation(String value) {
        this.indentation = value;
    }

    /**
     * The print margin after which (some) formatted elements will break lines.
     * 
     */
    public Integer getPrintMargin() {
        return printMargin;
    }

    /**
     * The print margin after which (some) formatted elements will break lines.
     * 
     */
    public void setPrintMargin(Integer value) {
        this.printMargin = value;
    }

    /**
     * The character to be used for line breaks.
     * 
     */
    public RenderFormatting withNewline(String value) {
        setNewline(value);
        return this;
    }

    /**
     * The characters to be used for indentation.
     * 
     */
    public RenderFormatting withIndentation(String value) {
        setIndentation(value);
        return this;
    }

    /**
     * The print margin after which (some) formatted elements will break lines.
     * 
     */
    public RenderFormatting withPrintMargin(Integer value) {
        setPrintMargin(value);
        return this;
    }

    @Override
    public final void appendTo(XMLBuilder builder) {
        builder.append("newline", newline);
        builder.append("indentation", indentation);
        builder.append("printMargin", printMargin);
    }

    @Override
    public String toString() {
        XMLBuilder builder = XMLBuilder.nonFormatting();
        appendTo(builder);
        return builder.toString();
    }

    @Override
    public boolean equals(Object that) {
        if (this == that) {
            return true;
        }
        if (that == null) {
            return false;
        }
        if (getClass()!= that.getClass()) {
            return false;
        }
        RenderFormatting other = ((RenderFormatting) that);
        if (newline == null) {
            if (other.newline!= null) {
                return false;
            }
        } else {
            if (!newline.equals(other.newline)) {
                return false;
            }
        }
        if (indentation == null) {
            if (other.indentation!= null) {
                return false;
            }
        } else {
            if (!indentation.equals(other.indentation)) {
                return false;
            }
        }
        if (printMargin == null) {
            if (other.printMargin!= null) {
                return false;
            }
        } else {
            if (!printMargin.equals(other.printMargin)) {
                return false;
            }
        }
        return true;
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = ((prime*result)+((newline == null)? 0 :newline.hashCode()));
        result = ((prime*result)+((indentation == null)? 0 :indentation.hashCode()));
        result = ((prime*result)+((printMargin == null)? 0 :printMargin.hashCode()));
        return result;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy