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

hydra.langs.owl.syntax.DataRange Maven / Gradle / Ivy

package hydra.langs.owl.syntax;

import java.io.Serializable;

/**
 * See https://www.w3.org/TR/owl2-syntax/#Data_Ranges
 */
public abstract class DataRange implements Serializable {
  public static final hydra.core.Name NAME = new hydra.core.Name("hydra/langs/owl/syntax.DataRange");
  
  private DataRange () {
  
  }
  
  public abstract  R accept(Visitor visitor) ;
  
  public interface Visitor {
    R visit(DataComplementOf instance) ;
    
    R visit(DataIntersectionOf instance) ;
    
    R visit(DataOneOf instance) ;
    
    R visit(DataUnionOf instance) ;
    
    R visit(Datatype instance) ;
    
    R visit(DatatypeRestriction instance) ;
  }
  
  public interface PartialVisitor extends Visitor {
    default R otherwise(DataRange instance) {
      throw new IllegalStateException("Non-exhaustive patterns when matching: " + (instance));
    }
    
    default R visit(DataComplementOf instance) {
      return otherwise((instance));
    }
    
    default R visit(DataIntersectionOf instance) {
      return otherwise((instance));
    }
    
    default R visit(DataOneOf instance) {
      return otherwise((instance));
    }
    
    default R visit(DataUnionOf instance) {
      return otherwise((instance));
    }
    
    default R visit(Datatype instance) {
      return otherwise((instance));
    }
    
    default R visit(DatatypeRestriction instance) {
      return otherwise((instance));
    }
  }
  
  public static final class DataComplementOf extends hydra.langs.owl.syntax.DataRange implements Serializable {
    public final hydra.langs.owl.syntax.DataComplementOf value;
    
    public DataComplementOf (hydra.langs.owl.syntax.DataComplementOf value) {
      this.value = value;
    }
    
    @Override
    public boolean equals(Object other) {
      if (!(other instanceof DataComplementOf)) {
        return false;
      }
      DataComplementOf o = (DataComplementOf) (other);
      return value.equals(o.value);
    }
    
    @Override
    public int hashCode() {
      return 2 * value.hashCode();
    }
    
    @Override
    public  R accept(Visitor visitor) {
      return visitor.visit(this);
    }
  }
  
  public static final class DataIntersectionOf extends hydra.langs.owl.syntax.DataRange implements Serializable {
    public final hydra.langs.owl.syntax.DataIntersectionOf value;
    
    public DataIntersectionOf (hydra.langs.owl.syntax.DataIntersectionOf value) {
      this.value = value;
    }
    
    @Override
    public boolean equals(Object other) {
      if (!(other instanceof DataIntersectionOf)) {
        return false;
      }
      DataIntersectionOf o = (DataIntersectionOf) (other);
      return value.equals(o.value);
    }
    
    @Override
    public int hashCode() {
      return 2 * value.hashCode();
    }
    
    @Override
    public  R accept(Visitor visitor) {
      return visitor.visit(this);
    }
  }
  
  public static final class DataOneOf extends hydra.langs.owl.syntax.DataRange implements Serializable {
    public final hydra.langs.owl.syntax.DataOneOf value;
    
    public DataOneOf (hydra.langs.owl.syntax.DataOneOf value) {
      this.value = value;
    }
    
    @Override
    public boolean equals(Object other) {
      if (!(other instanceof DataOneOf)) {
        return false;
      }
      DataOneOf o = (DataOneOf) (other);
      return value.equals(o.value);
    }
    
    @Override
    public int hashCode() {
      return 2 * value.hashCode();
    }
    
    @Override
    public  R accept(Visitor visitor) {
      return visitor.visit(this);
    }
  }
  
  public static final class DataUnionOf extends hydra.langs.owl.syntax.DataRange implements Serializable {
    public final hydra.langs.owl.syntax.DataUnionOf value;
    
    public DataUnionOf (hydra.langs.owl.syntax.DataUnionOf value) {
      this.value = value;
    }
    
    @Override
    public boolean equals(Object other) {
      if (!(other instanceof DataUnionOf)) {
        return false;
      }
      DataUnionOf o = (DataUnionOf) (other);
      return value.equals(o.value);
    }
    
    @Override
    public int hashCode() {
      return 2 * value.hashCode();
    }
    
    @Override
    public  R accept(Visitor visitor) {
      return visitor.visit(this);
    }
  }
  
  public static final class Datatype extends hydra.langs.owl.syntax.DataRange implements Serializable {
    public final hydra.langs.owl.syntax.Datatype value;
    
    public Datatype (hydra.langs.owl.syntax.Datatype value) {
      this.value = value;
    }
    
    @Override
    public boolean equals(Object other) {
      if (!(other instanceof Datatype)) {
        return false;
      }
      Datatype o = (Datatype) (other);
      return value.equals(o.value);
    }
    
    @Override
    public int hashCode() {
      return 2 * value.hashCode();
    }
    
    @Override
    public  R accept(Visitor visitor) {
      return visitor.visit(this);
    }
  }
  
  public static final class DatatypeRestriction extends hydra.langs.owl.syntax.DataRange implements Serializable {
    public final hydra.langs.owl.syntax.DatatypeRestriction value;
    
    public DatatypeRestriction (hydra.langs.owl.syntax.DatatypeRestriction value) {
      this.value = value;
    }
    
    @Override
    public boolean equals(Object other) {
      if (!(other instanceof DatatypeRestriction)) {
        return false;
      }
      DatatypeRestriction o = (DatatypeRestriction) (other);
      return value.equals(o.value);
    }
    
    @Override
    public int hashCode() {
      return 2 * value.hashCode();
    }
    
    @Override
    public  R accept(Visitor visitor) {
      return visitor.visit(this);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy