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

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

There is a newer version: 3.19.16
Show newest version

package org.jooq.conf;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.regex.Pattern;
import jakarta.xml.bind.annotation.XmlAccessType;
import jakarta.xml.bind.annotation.XmlAccessorType;
import jakarta.xml.bind.annotation.XmlElement;
import jakarta.xml.bind.annotation.XmlElementWrapper;
import jakarta.xml.bind.annotation.XmlType;
import jakarta.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import org.jooq.util.jaxb.tools.XMLAppendable;
import org.jooq.util.jaxb.tools.XMLBuilder;


/**
 * A schema mapping configuration.
 * 
 * 
 * 
 */
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "MappedSchema", propOrder = {

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

    private final static long serialVersionUID = 31700L;
    protected String input;
    @XmlElement(type = String.class)
    @XmlJavaTypeAdapter(RegexAdapter.class)
    protected Pattern inputExpression;
    protected String output;
    @XmlElementWrapper(name = "tables")
    @XmlElement(name = "table")
    protected List tables;

    /**
     * The input schema name as defined in {@link org.jooq.Schema#getName()}
     * 

* Either <input/> or <inputExpression/> must be provided * */ public String getInput() { return input; } /** * The input schema name as defined in {@link org.jooq.Schema#getName()} *

* Either <input/> or <inputExpression/> must be provided * */ public void setInput(String value) { this.input = value; } /** * A regular expression matching the input schema name as defined in {@link org.jooq.Schema#getName()} *

* Either <input/> or <inputExpression/> must be provided * */ public Pattern getInputExpression() { return inputExpression; } /** * A regular expression matching the input schema name as defined in {@link org.jooq.Schema#getName()} *

* Either <input/> or <inputExpression/> must be provided * */ public void setInputExpression(Pattern value) { this.inputExpression = value; } /** * The output schema as it will be rendered in SQL. *

    *
  • When this is omitted, you can still apply table mapping.
  • *
  • When <input/> is provided, <output/> is a constant value.
  • *
  • When <inputExpression/> is provided, <output/> is a replacement expression
  • *
* */ public String getOutput() { return output; } /** * The output schema as it will be rendered in SQL. *
    *
  • When this is omitted, you can still apply table mapping.
  • *
  • When <input/> is provided, <output/> is a constant value.
  • *
  • When <inputExpression/> is provided, <output/> is a replacement expression
  • *
* */ public void setOutput(String value) { this.output = value; } public List getTables() { if (tables == null) { tables = new ArrayList(); } return tables; } public void setTables(List tables) { this.tables = tables; } /** * The input schema name as defined in {@link org.jooq.Schema#getName()} *

* Either <input/> or <inputExpression/> must be provided * */ public MappedSchema withInput(String value) { setInput(value); return this; } /** * A regular expression matching the input schema name as defined in {@link org.jooq.Schema#getName()} *

* Either <input/> or <inputExpression/> must be provided * */ public MappedSchema withInputExpression(Pattern value) { setInputExpression(value); return this; } /** * The output schema as it will be rendered in SQL. *

    *
  • When this is omitted, you can still apply table mapping.
  • *
  • When <input/> is provided, <output/> is a constant value.
  • *
  • When <inputExpression/> is provided, <output/> is a replacement expression
  • *
* */ public MappedSchema withOutput(String value) { setOutput(value); return this; } public MappedSchema withTables(MappedTable... values) { if (values!= null) { for (MappedTable value: values) { getTables().add(value); } } return this; } public MappedSchema withTables(Collection values) { if (values!= null) { getTables().addAll(values); } return this; } public MappedSchema withTables(List tables) { setTables(tables); return this; } @Override public final void appendTo(XMLBuilder builder) { builder.append("input", input); builder.append("inputExpression", inputExpression); builder.append("output", output); builder.append("tables", "table", tables); } @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; } MappedSchema other = ((MappedSchema) that); if (input == null) { if (other.input!= null) { return false; } } else { if (!input.equals(other.input)) { return false; } } if (inputExpression == null) { if (other.inputExpression!= null) { return false; } } else { if (!inputExpression.pattern().equals(other.inputExpression.pattern())) { return false; } } if (output == null) { if (other.output!= null) { return false; } } else { if (!output.equals(other.output)) { return false; } } if (tables == null) { if (other.tables!= null) { return false; } } else { if (!tables.equals(other.tables)) { return false; } } return true; } @Override public int hashCode() { final int prime = 31; int result = 1; result = ((prime*result)+((input == null)? 0 :input.hashCode())); result = ((prime*result)+((inputExpression == null)? 0 :inputExpression.pattern().hashCode())); result = ((prime*result)+((output == null)? 0 :output.hashCode())); result = ((prime*result)+((tables == null)? 0 :tables.hashCode())); return result; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy