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

net.sf.mmm.util.validation.base.ObjectValidatorBuilder Maven / Gradle / Ivy

There is a newer version: 8.7.0
Show newest version
/* Copyright (c) The m-m-m Team, Licensed under the Apache License, Version 2.0
 * http://www.apache.org/licenses/LICENSE-2.0 */
package net.sf.mmm.util.validation.base;

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

import net.sf.mmm.util.lang.api.Builder;

/**
 * This is the base class to create instances of {@link AbstractValidator} using the builder pattern.
 *
 * @param  the generic type of the value to {@link AbstractValidator#validate(Object) validate}.
 * @param  the generic type of the {@link #and() parent builder}.
 * @param  the generic type of this builder itself (this).
 *
 * @author hohwille
 * @since 7.1.0
 */
public abstract class ObjectValidatorBuilder>
    implements Builder>, ValidatorRegistry {

  private final PARENT parent;

  private final List> validators;

  /**
   * The constructor.
   *
   * @param parent the {@link #and() parent} builder.
   */
  public ObjectValidatorBuilder(PARENT parent) {
    super();
    this.validators = new ArrayList<>();
    this.parent = parent;
  }

  /**
   * @param  the generic type of the value to {@link AbstractValidator#validate(Object) validate}.
   * @param builder the {@link ObjectValidatorBuilder}.
   * @return the {@link List} of validators.
   */
  protected  List> getValidators(ObjectValidatorBuilder builder) {

    return builder.validators;
  }

  /**
   * @return the parent {@link Builder} or {@code null} if {@literal } is void.
   */
  public PARENT and() {

    return this.parent;
  }

  /**
   * @return this build instance for fluent API calls.
   */
  @SuppressWarnings("unchecked")
  protected SELF self() {

    return (SELF) this;
  }

  /**
   * @param validator the {@link AbstractValidator} to add to this builder.
   * @return this build instance for fluent API calls.
   */
  public SELF add(AbstractValidator validator) {

    this.validators.add(validator);
    return self();
  }

  /**
   * Value is {@link ValidatorMandatory mandatory}.
   *
   * @return this build instance for fluent API calls.
   */
  public SELF mandatory() {

    return add(ValidatorMandatory.getInstance());
  }

  /**
   * This method allows to define a range in a generic way. If you have a properly typed builder please use more
   * specific methods such as {@link CompareableValidatorBuilder#range(net.sf.mmm.util.value.api.Range)} instead.
   *
   * @param min the minimum value allowed or {@code null} for no lower bound.
   * @param max the maximum value allowed or {@code null} for no upper bound.
   * @return this build instance for fluent API calls.
   */
  public abstract SELF range(String min, String max);

  /**
   * @return the {@link AbstractValidator}
   */
  @Override
  public AbstractValidator build() {

    int size = this.validators.size();
    if (size == 0) {
      return ValidatorNone.getInstance();
    } else if (size == 1) {
      return this.validators.get(0);
    } else {
      AbstractValidator[] array = this.validators.toArray(new AbstractValidator[size]);
      return new ComposedValidator<>(array);
    }
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy