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

com.anaptecs.spring.service.MultiValuedHeaderBeanParam Maven / Gradle / Ivy

/*
 * anaptecs GmbH, Ricarda-Huch-Str. 71, 72760 Reutlingen, Germany
 *
 * Copyright 2004 - 2019. All rights reserved.
 */
package com.anaptecs.spring.service;

import java.sql.Timestamp;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Collection;
import java.util.Collections;
import java.util.Date;
import java.util.HashSet;
import java.util.Objects;
import java.util.Set;

import com.anaptecs.annotations.MyNotEmptyProperty;
import com.anaptecs.jeaf.validation.api.spring.SpringValidationExecutor;
import com.anaptecs.spring.base.StringCode;
import com.anaptecs.spring.base.TimeUnit;
import com.fasterxml.jackson.annotation.JsonSetter;
import com.fasterxml.jackson.annotation.Nulls;

public class MultiValuedHeaderBeanParam {
  /**
   * Constant for the name of attribute "names".
   */
  public static final String NAMES = "names";

  /**
   * Constant for the name of attribute "ints".
   */
  public static final String INTS = "ints";

  /**
   * Constant for the name of attribute "doubles".
   */
  public static final String DOUBLES = "doubles";

  /**
   * Constant for the name of attribute "codes".
   */
  public static final String CODES = "codes";

  /**
   * Constant for the name of attribute "stringCodeList".
   */
  public static final String STRINGCODELIST = "stringCodeList";

  /**
   * Constant for the name of attribute "startDate".
   */
  public static final String STARTDATE = "startDate";

  /**
   * Constant for the name of attribute "dates".
   */
  public static final String DATES = "dates";

  /**
   * Constant for the name of attribute "timestamps".
   */
  public static final String TIMESTAMPS = "timestamps";

  /**
   * Constant for the name of attribute "calendars".
   */
  public static final String CALENDARS = "calendars";

  /**
   * Constant for the name of attribute "utilDates".
   */
  public static final String UTILDATES = "utilDates";

  /**
   * Constant for the name of attribute "sqlTimestamps".
   */
  public static final String SQLTIMESTAMPS = "sqlTimestamps";

  /**
   * Constant for the name of attribute "timeUnits".
   */
  public static final String TIMEUNITS = "timeUnits";

  /**
   * Constant for the name of attribute "timeUnitArray".
   */
  public static final String TIMEUNITARRAY = "timeUnitArray";

  /**
   * Constant for the name of attribute "base64".
   */
  public static final String BASE64 = "base64";

  private String[] names;

  private int[] ints;

  private Double[] doubles;

  private StringCode[] codes;

  @JsonSetter(nulls = Nulls.SKIP)
  private Set stringCodeList;

  public LocalDate startDate;

  private LocalDate[] dates;

  @JsonSetter(nulls = Nulls.SKIP)
  private Set timestamps;

  private Calendar[] calendars;

  private Date[] utilDates;

  private Timestamp[] sqlTimestamps;

  @JsonSetter(nulls = Nulls.SKIP)
  private Set timeUnits;

  private TimeUnit[] timeUnitArray;

  private byte[] base64;

  /**
   * Default constructor is only intended to be used for deserialization by tools like Jackson for JSON. For "normal"
   * object creation builder should be used instead.
   */
  public MultiValuedHeaderBeanParam( ) {
    stringCodeList = new HashSet();
    timestamps = new HashSet();
    timeUnits = new HashSet();
  }

  /**
   * Initialize object using the passed builder.
   *
   * @param pBuilder Builder that should be used to initialize this object. The parameter must not be null.
   */
  protected MultiValuedHeaderBeanParam( Builder pBuilder ) {
    // Read attribute values from builder.
    names = pBuilder.names;
    ints = pBuilder.ints;
    doubles = pBuilder.doubles;
    codes = pBuilder.codes;
    if (pBuilder.stringCodeList != null) {
      stringCodeList = pBuilder.stringCodeList;
    }
    else {
      stringCodeList = new HashSet();
    }
    startDate = pBuilder.startDate;
    dates = pBuilder.dates;
    if (pBuilder.timestamps != null) {
      timestamps = pBuilder.timestamps;
    }
    else {
      timestamps = new HashSet();
    }
    calendars = pBuilder.calendars;
    utilDates = pBuilder.utilDates;
    sqlTimestamps = pBuilder.sqlTimestamps;
    if (pBuilder.timeUnits != null) {
      timeUnits = pBuilder.timeUnits;
    }
    else {
      timeUnits = new HashSet();
    }
    timeUnitArray = pBuilder.timeUnitArray;
    base64 = pBuilder.base64;
  }

  /**
   * Method returns a new builder.
   *
   * @return {@link Builder} New builder that can be used to create new MultiValuedHeaderBeanParam objects.
   */
  public static Builder builder( ) {
    return new Builder();
  }

  /**
   * Convenience method to create new instance of class MultiValuedHeaderBeanParam.
   *
   *
   * @param pInts Value to which {@link #ints} should be set.
   *
   * @return {@link com.anaptecs.spring.service.MultiValuedHeaderBeanParam}
   */
  public static MultiValuedHeaderBeanParam of( int[] pInts ) {
    MultiValuedHeaderBeanParam.Builder lBuilder = MultiValuedHeaderBeanParam.builder();
    lBuilder.setInts(pInts);
    return lBuilder.build();
  }

  /**
   * Class implements builder to create a new instance of class MultiValuedHeaderBeanParam.
   */
  public static class Builder {
    private String[] names;

    private int[] ints;

    private Double[] doubles;

    private StringCode[] codes;

    private Set stringCodeList;

    private LocalDate startDate;

    private LocalDate[] dates;

    private Set timestamps;

    private Calendar[] calendars;

    private Date[] utilDates;

    private Timestamp[] sqlTimestamps;

    private Set timeUnits;

    private TimeUnit[] timeUnitArray;

    private byte[] base64;

    /**
     * Use {@link MultiValuedHeaderBeanParam#builder()} instead of private constructor to create new builder.
     */
    protected Builder( ) {
    }

    /**
     * Use {@link MultiValuedHeaderBeanParam#builder(MultiValuedHeaderBeanParam)} instead of private constructor to
     * create new builder.
     */
    protected Builder( MultiValuedHeaderBeanParam pObject ) {
      if (pObject != null) {
        // Read attribute values from passed object.
        this.setNames(pObject.names);
        this.setInts(pObject.ints);
        this.setDoubles(pObject.doubles);
        this.setCodes(pObject.codes);
        this.setStringCodeList(pObject.stringCodeList);
        this.setStartDate(pObject.startDate);
        this.setDates(pObject.dates);
        this.setTimestamps(pObject.timestamps);
        this.setCalendars(pObject.calendars);
        this.setUtilDates(pObject.utilDates);
        this.setSqlTimestamps(pObject.sqlTimestamps);
        this.setTimeUnits(pObject.timeUnits);
        this.setTimeUnitArray(pObject.timeUnitArray);
        this.setBase64(pObject.base64);
      }
    }

    /**
     * Method returns a new builder.
     *
     * @return {@link Builder} New builder that can be used to create new MultiValuedHeaderBeanParam objects.
     */
    public static Builder newBuilder( ) {
      return new Builder();
    }

    /**
     * Method creates a new builder and initialize it with the data from the passed object.
     *
     * @param pObject Object that should be used to initialize the builder. The parameter may be null.
     * @return {@link Builder} New builder that can be used to create new MultiValuedHeaderBeanParam objects. The method
     * never returns null.
     */
    public static Builder newBuilder( MultiValuedHeaderBeanParam pObject ) {
      return new Builder(pObject);
    }

    /**
     * Method sets attribute {@link #names}.
* * @param pNames Collection to which {@link #names} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setNames( String[] pNames ) { // Assign value to attribute if (pNames != null) { names = new String[pNames.length]; System.arraycopy(pNames, 0, names, 0, pNames.length); } else { names = null; } return this; } /** * Method sets attribute {@link #ints}.
* * @param pInts Value to which {@link #ints} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setInts( @MyNotEmptyProperty int[] pInts ) { // Assign value to attribute if (pInts != null) { ints = new int[pInts.length]; System.arraycopy(pInts, 0, ints, 0, pInts.length); } else { ints = null; } return this; } /** * Method sets attribute {@link #doubles}.
* * @param pDoubles Collection to which {@link #doubles} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setDoubles( Double[] pDoubles ) { // Assign value to attribute if (pDoubles != null) { doubles = new Double[pDoubles.length]; System.arraycopy(pDoubles, 0, doubles, 0, pDoubles.length); } else { doubles = null; } return this; } /** * Method sets attribute {@link #codes}.
* * @param pCodes Collection to which {@link #codes} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setCodes( StringCode[] pCodes ) { // Assign value to attribute if (pCodes != null) { codes = new StringCode[pCodes.length]; System.arraycopy(pCodes, 0, codes, 0, pCodes.length); } else { codes = null; } return this; } /** * Method sets association {@link #stringCodeList}.
* * @param pStringCodeList Collection to which {@link #stringCodeList} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setStringCodeList( Set pStringCodeList ) { // To ensure immutability we have to copy the content of the passed collection. if (pStringCodeList != null) { stringCodeList = new HashSet(pStringCodeList); } else { stringCodeList = null; } return this; } /** * Method adds the passed objects to association {@link #stringCodeList}.
* * @param pStringCodeList Array of objects that should be added to {@link #stringCodeList}. The parameter may be * null. * @return {@link Builder} Instance of this builder to support chaining. Method never returns null. */ public Builder addToStringCodeList( StringCode... pStringCodeList ) { if (pStringCodeList != null) { if (stringCodeList == null) { stringCodeList = new HashSet(); } stringCodeList.addAll(Arrays.asList(pStringCodeList)); } return this; } /** * Method sets attribute {@link #startDate}.
* * @param pStartDate Value to which {@link #startDate} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setStartDate( LocalDate pStartDate ) { // Assign value to attribute startDate = pStartDate; return this; } /** * Method sets attribute {@link #dates}.
* * @param pDates Collection to which {@link #dates} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setDates( LocalDate[] pDates ) { // Assign value to attribute if (pDates != null) { dates = new LocalDate[pDates.length]; System.arraycopy(pDates, 0, dates, 0, pDates.length); } else { dates = null; } return this; } /** * Method sets association {@link #timestamps}.
* * @param pTimestamps Collection to which {@link #timestamps} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setTimestamps( Set pTimestamps ) { // To ensure immutability we have to copy the content of the passed collection. if (pTimestamps != null) { timestamps = new HashSet(pTimestamps); } else { timestamps = null; } return this; } /** * Method adds the passed objects to association {@link #timestamps}.
* * @param pTimestamps Array of objects that should be added to {@link #timestamps}. The parameter may be null. * @return {@link Builder} Instance of this builder to support chaining. Method never returns null. */ public Builder addToTimestamps( LocalDateTime... pTimestamps ) { if (pTimestamps != null) { if (timestamps == null) { timestamps = new HashSet(); } timestamps.addAll(Arrays.asList(pTimestamps)); } return this; } /** * Method sets attribute {@link #calendars}.
* * @param pCalendars Collection to which {@link #calendars} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setCalendars( Calendar[] pCalendars ) { // Assign value to attribute if (pCalendars != null) { calendars = new Calendar[pCalendars.length]; System.arraycopy(pCalendars, 0, calendars, 0, pCalendars.length); } else { calendars = null; } return this; } /** * Method sets attribute {@link #utilDates}.
* * @param pUtilDates Collection to which {@link #utilDates} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setUtilDates( Date[] pUtilDates ) { // Assign value to attribute if (pUtilDates != null) { utilDates = new Date[pUtilDates.length]; System.arraycopy(pUtilDates, 0, utilDates, 0, pUtilDates.length); } else { utilDates = null; } return this; } /** * Method sets attribute {@link #sqlTimestamps}.
* * @param pSqlTimestamps Collection to which {@link #sqlTimestamps} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setSqlTimestamps( Timestamp[] pSqlTimestamps ) { // Assign value to attribute if (pSqlTimestamps != null) { sqlTimestamps = new Timestamp[pSqlTimestamps.length]; System.arraycopy(pSqlTimestamps, 0, sqlTimestamps, 0, pSqlTimestamps.length); } else { sqlTimestamps = null; } return this; } /** * Method sets association {@link #timeUnits}.
* * @param pTimeUnits Collection to which {@link #timeUnits} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setTimeUnits( Set pTimeUnits ) { // To ensure immutability we have to copy the content of the passed collection. if (pTimeUnits != null) { timeUnits = new HashSet(pTimeUnits); } else { timeUnits = null; } return this; } /** * Method adds the passed objects to association {@link #timeUnits}.
* * @param pTimeUnits Array of objects that should be added to {@link #timeUnits}. The parameter may be null. * @return {@link Builder} Instance of this builder to support chaining. Method never returns null. */ public Builder addToTimeUnits( TimeUnit... pTimeUnits ) { if (pTimeUnits != null) { if (timeUnits == null) { timeUnits = new HashSet(); } timeUnits.addAll(Arrays.asList(pTimeUnits)); } return this; } /** * Method sets association {@link #timeUnits}.
* * @param pTimeUnits Array with objects to which {@link #timeUnits} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setTimeUnits( TimeUnit... pTimeUnits ) { // Copy the content of the passed array. if (pTimeUnits != null) { timeUnits = new HashSet(Arrays.asList(pTimeUnits)); } else { timeUnits = null; } return this; } /** * Method sets attribute {@link #timeUnitArray}.
* * @param pTimeUnitArray Collection to which {@link #timeUnitArray} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setTimeUnitArray( TimeUnit[] pTimeUnitArray ) { // Assign value to attribute if (pTimeUnitArray != null) { timeUnitArray = new TimeUnit[pTimeUnitArray.length]; System.arraycopy(pTimeUnitArray, 0, timeUnitArray, 0, pTimeUnitArray.length); } else { timeUnitArray = null; } return this; } /** * Method sets attribute {@link #base64}.
* * @param pBase64 Value to which {@link #base64} should be set. * @return {@link Builder} Instance of this builder to support chaining setters. Method never returns null. */ public Builder setBase64( byte[] pBase64 ) { // Assign value to attribute if (pBase64 != null) { base64 = new byte[pBase64.length]; System.arraycopy(pBase64, 0, base64, 0, pBase64.length); } else { base64 = null; } return this; } /** * Method creates a new instance of class MultiValuedHeaderBeanParam. The object will be initialized with the values * of the builder. * * @return MultiValuedHeaderBeanParam Created object. The method never returns null. */ public MultiValuedHeaderBeanParam build( ) { MultiValuedHeaderBeanParam lObject = new MultiValuedHeaderBeanParam(this); SpringValidationExecutor.getValidationExecutor().validateObject(lObject); return lObject; } } /** * Method returns attribute {@link #names}.
* * @return {@link String[]} Value to which {@link #names} is set. */ public String[] getNames( ) { String[] lReturnValue; if (names != null) { lReturnValue = new String[names.length]; System.arraycopy(names, 0, lReturnValue, 0, names.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #names}.
* * @param pNames Value to which {@link #names} should be set. */ public void setNames( String[] pNames ) { // Assign value to attribute if (pNames != null) { names = new String[pNames.length]; System.arraycopy(pNames, 0, names, 0, pNames.length); } else { names = null; } } /** * Method returns attribute {@link #ints}.
* * @return int[] Value to which {@link #ints} is set. */ @MyNotEmptyProperty public int[] getInts( ) { int[] lReturnValue; if (ints != null) { lReturnValue = new int[ints.length]; System.arraycopy(ints, 0, lReturnValue, 0, ints.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #ints}.
* * @param pInts Value to which {@link #ints} should be set. */ public void setInts( @MyNotEmptyProperty int[] pInts ) { // Assign value to attribute if (pInts != null) { ints = new int[pInts.length]; System.arraycopy(pInts, 0, ints, 0, pInts.length); } else { ints = null; } } /** * Method returns attribute {@link #doubles}.
* * @return {@link Double[]} Value to which {@link #doubles} is set. */ public Double[] getDoubles( ) { Double[] lReturnValue; if (doubles != null) { lReturnValue = new Double[doubles.length]; System.arraycopy(doubles, 0, lReturnValue, 0, doubles.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #doubles}.
* * @param pDoubles Value to which {@link #doubles} should be set. */ public void setDoubles( Double[] pDoubles ) { // Assign value to attribute if (pDoubles != null) { doubles = new Double[pDoubles.length]; System.arraycopy(pDoubles, 0, doubles, 0, pDoubles.length); } else { doubles = null; } } /** * Method returns attribute {@link #codes}.
* * @return {@link StringCode[]} Value to which {@link #codes} is set. */ public StringCode[] getCodes( ) { StringCode[] lReturnValue; if (codes != null) { lReturnValue = new StringCode[codes.length]; System.arraycopy(codes, 0, lReturnValue, 0, codes.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #codes}.
* * @param pCodes Value to which {@link #codes} should be set. */ public void setCodes( StringCode[] pCodes ) { // Assign value to attribute if (pCodes != null) { codes = new StringCode[pCodes.length]; System.arraycopy(pCodes, 0, codes, 0, pCodes.length); } else { codes = null; } } /** * Method returns association {@link #stringCodeList}.
* * @return {@link Set} Value to which {@link #stringCodeList} is set. The method never returns null and * the returned collection is unmodifiable. */ public Set getStringCodeList( ) { // Return all StringCode objects as unmodifiable collection. return Collections.unmodifiableSet(stringCodeList); } /** * Method adds the passed object to {@link #stringCodeList}. * * @param pStringCodeList Object that should be added to {@link #stringCodeList}. The parameter must not be null. */ public void addToStringCodeList( StringCode pStringCodeList ) { // Add passed object to collection of associated StringCode objects. stringCodeList.add(pStringCodeList); } /** * Method adds all passed objects to {@link #stringCodeList}. * * @param pStringCodeList Collection with all objects that should be added to {@link #stringCodeList}. The parameter * must not be null. */ public void addToStringCodeList( Collection pStringCodeList ) { // Add all passed objects. for (StringCode lNextObject : pStringCodeList) { this.addToStringCodeList(lNextObject); } } /** * Method removes the passed object from {@link #stringCodeList}.
* * @param pStringCodeList Object that should be removed from {@link #stringCodeList}. The parameter must not be null. */ public void removeFromStringCodeList( StringCode pStringCodeList ) { // Remove passed object from collection of associated StringCode objects. stringCodeList.remove(pStringCodeList); } /** * Method removes all objects from {@link #stringCodeList}. */ public void clearStringCodeList( ) { // Remove all objects from association "stringCodeList". stringCodeList.clear(); } /** * Method returns attribute {@link #startDate}.
* * @return {@link LocalDate} Value to which {@link #startDate} is set. */ public LocalDate getStartDate( ) { return startDate; } /** * Method sets attribute {@link #startDate}.
* * @param pStartDate Value to which {@link #startDate} should be set. */ public void setStartDate( LocalDate pStartDate ) { // Assign value to attribute startDate = pStartDate; } /** * Method returns attribute {@link #dates}.
* * @return {@link LocalDate[]} Value to which {@link #dates} is set. */ public LocalDate[] getDates( ) { LocalDate[] lReturnValue; if (dates != null) { lReturnValue = new LocalDate[dates.length]; System.arraycopy(dates, 0, lReturnValue, 0, dates.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #dates}.
* * @param pDates Value to which {@link #dates} should be set. */ public void setDates( LocalDate[] pDates ) { // Assign value to attribute if (pDates != null) { dates = new LocalDate[pDates.length]; System.arraycopy(pDates, 0, dates, 0, pDates.length); } else { dates = null; } } /** * Method returns association {@link #timestamps}.
* * @return {@link Set} Value to which {@link #timestamps} is set. The method never returns null and the * returned collection is unmodifiable. */ public Set getTimestamps( ) { // Return all LocalDateTime objects as unmodifiable collection. return Collections.unmodifiableSet(timestamps); } /** * Method adds the passed object to {@link #timestamps}. * * @param pTimestamps Object that should be added to {@link #timestamps}. The parameter must not be null. */ public void addToTimestamps( LocalDateTime pTimestamps ) { // Add passed object to collection of associated LocalDateTime objects. timestamps.add(pTimestamps); } /** * Method adds all passed objects to {@link #timestamps}. * * @param pTimestamps Collection with all objects that should be added to {@link #timestamps}. The parameter must not * be null. */ public void addToTimestamps( Collection pTimestamps ) { // Add all passed objects. for (LocalDateTime lNextObject : pTimestamps) { this.addToTimestamps(lNextObject); } } /** * Method removes the passed object from {@link #timestamps}.
* * @param pTimestamps Object that should be removed from {@link #timestamps}. The parameter must not be null. */ public void removeFromTimestamps( LocalDateTime pTimestamps ) { // Remove passed object from collection of associated LocalDateTime objects. timestamps.remove(pTimestamps); } /** * Method removes all objects from {@link #timestamps}. */ public void clearTimestamps( ) { // Remove all objects from association "timestamps". timestamps.clear(); } /** * Method returns attribute {@link #calendars}.
* * @return {@link Calendar[]} Value to which {@link #calendars} is set. */ public Calendar[] getCalendars( ) { Calendar[] lReturnValue; if (calendars != null) { lReturnValue = new Calendar[calendars.length]; System.arraycopy(calendars, 0, lReturnValue, 0, calendars.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #calendars}.
* * @param pCalendars Value to which {@link #calendars} should be set. */ public void setCalendars( Calendar[] pCalendars ) { // Assign value to attribute if (pCalendars != null) { calendars = new Calendar[pCalendars.length]; System.arraycopy(pCalendars, 0, calendars, 0, pCalendars.length); } else { calendars = null; } } /** * Method returns attribute {@link #utilDates}.
* * @return {@link Date[]} Value to which {@link #utilDates} is set. */ public Date[] getUtilDates( ) { Date[] lReturnValue; if (utilDates != null) { lReturnValue = new Date[utilDates.length]; System.arraycopy(utilDates, 0, lReturnValue, 0, utilDates.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #utilDates}.
* * @param pUtilDates Value to which {@link #utilDates} should be set. */ public void setUtilDates( Date[] pUtilDates ) { // Assign value to attribute if (pUtilDates != null) { utilDates = new Date[pUtilDates.length]; System.arraycopy(pUtilDates, 0, utilDates, 0, pUtilDates.length); } else { utilDates = null; } } /** * Method returns attribute {@link #sqlTimestamps}.
* * @return {@link Timestamp[]} Value to which {@link #sqlTimestamps} is set. */ public Timestamp[] getSqlTimestamps( ) { Timestamp[] lReturnValue; if (sqlTimestamps != null) { lReturnValue = new Timestamp[sqlTimestamps.length]; System.arraycopy(sqlTimestamps, 0, lReturnValue, 0, sqlTimestamps.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #sqlTimestamps}.
* * @param pSqlTimestamps Value to which {@link #sqlTimestamps} should be set. */ public void setSqlTimestamps( Timestamp[] pSqlTimestamps ) { // Assign value to attribute if (pSqlTimestamps != null) { sqlTimestamps = new Timestamp[pSqlTimestamps.length]; System.arraycopy(pSqlTimestamps, 0, sqlTimestamps, 0, pSqlTimestamps.length); } else { sqlTimestamps = null; } } /** * Method returns association {@link #timeUnits}.
* * @return {@link Set} Value to which {@link #timeUnits} is set. The method never returns null and the * returned collection is unmodifiable. */ public Set getTimeUnits( ) { // Return all TimeUnit objects as unmodifiable collection. return Collections.unmodifiableSet(timeUnits); } /** * Method adds the passed object to {@link #timeUnits}. * * @param pTimeUnits Object that should be added to {@link #timeUnits}. The parameter must not be null. */ public void addToTimeUnits( TimeUnit pTimeUnits ) { // Add passed object to collection of associated TimeUnit objects. timeUnits.add(pTimeUnits); } /** * Method adds all passed objects to {@link #timeUnits}. * * @param pTimeUnits Collection with all objects that should be added to {@link #timeUnits}. The parameter must not be * null. */ public void addToTimeUnits( Collection pTimeUnits ) { // Add all passed objects. for (TimeUnit lNextObject : pTimeUnits) { this.addToTimeUnits(lNextObject); } } /** * Method removes the passed object from {@link #timeUnits}.
* * @param pTimeUnits Object that should be removed from {@link #timeUnits}. The parameter must not be null. */ public void removeFromTimeUnits( TimeUnit pTimeUnits ) { // Remove passed object from collection of associated TimeUnit objects. timeUnits.remove(pTimeUnits); } /** * Method removes all objects from {@link #timeUnits}. */ public void clearTimeUnits( ) { // Remove all objects from association "timeUnits". timeUnits.clear(); } /** * Method returns attribute {@link #timeUnitArray}.
* * @return {@link TimeUnit[]} Value to which {@link #timeUnitArray} is set. */ public TimeUnit[] getTimeUnitArray( ) { TimeUnit[] lReturnValue; if (timeUnitArray != null) { lReturnValue = new TimeUnit[timeUnitArray.length]; System.arraycopy(timeUnitArray, 0, lReturnValue, 0, timeUnitArray.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #timeUnitArray}.
* * @param pTimeUnitArray Value to which {@link #timeUnitArray} should be set. */ public void setTimeUnitArray( TimeUnit[] pTimeUnitArray ) { // Assign value to attribute if (pTimeUnitArray != null) { timeUnitArray = new TimeUnit[pTimeUnitArray.length]; System.arraycopy(pTimeUnitArray, 0, timeUnitArray, 0, pTimeUnitArray.length); } else { timeUnitArray = null; } } /** * Method returns attribute {@link #base64}.
* * @return byte[] Value to which {@link #base64} is set. */ public byte[] getBase64( ) { byte[] lReturnValue; if (base64 != null) { lReturnValue = new byte[base64.length]; System.arraycopy(base64, 0, lReturnValue, 0, base64.length); } else { lReturnValue = null; } return lReturnValue; } /** * Method sets attribute {@link #base64}.
* * @param pBase64 Value to which {@link #base64} should be set. */ public void setBase64( byte[] pBase64 ) { // Assign value to attribute if (pBase64 != null) { base64 = new byte[pBase64.length]; System.arraycopy(pBase64, 0, base64, 0, pBase64.length); } else { base64 = null; } } @Override public int hashCode( ) { final int lPrime = 31; int lResult = 1; lResult = lPrime * lResult + Arrays.hashCode(names); lResult = lPrime * lResult + Arrays.hashCode(ints); lResult = lPrime * lResult + Arrays.hashCode(doubles); lResult = lPrime * lResult + Arrays.hashCode(codes); lResult = lPrime * lResult + Objects.hashCode(stringCodeList); lResult = lPrime * lResult + Objects.hashCode(startDate); lResult = lPrime * lResult + Arrays.hashCode(dates); lResult = lPrime * lResult + Objects.hashCode(timestamps); lResult = lPrime * lResult + Arrays.hashCode(calendars); lResult = lPrime * lResult + Arrays.hashCode(utilDates); lResult = lPrime * lResult + Arrays.hashCode(sqlTimestamps); lResult = lPrime * lResult + Objects.hashCode(timeUnits); lResult = lPrime * lResult + Arrays.hashCode(timeUnitArray); lResult = lPrime * lResult + Arrays.hashCode(base64); return lResult; } @Override public boolean equals( Object pObject ) { boolean lEquals; if (this == pObject) { lEquals = true; } else if (pObject == null) { lEquals = false; } else if (this.getClass() != pObject.getClass()) { lEquals = false; } else { MultiValuedHeaderBeanParam lOther = (MultiValuedHeaderBeanParam) pObject; lEquals = Arrays.equals(names, lOther.names) && Arrays.equals(ints, lOther.ints) && Arrays.equals(doubles, lOther.doubles) && Arrays.equals(codes, lOther.codes) && Objects.equals(stringCodeList, lOther.stringCodeList) && Objects.equals(startDate, lOther.startDate) && Arrays.equals(dates, lOther.dates) && Objects.equals(timestamps, lOther.timestamps) && Arrays.equals(calendars, lOther.calendars) && Arrays.equals(utilDates, lOther.utilDates) && Arrays.equals(sqlTimestamps, lOther.sqlTimestamps) && Objects.equals(timeUnits, lOther.timeUnits) && Arrays.equals(timeUnitArray, lOther.timeUnitArray) && Arrays.equals(base64, lOther.base64); } return lEquals; } /** * Method returns a StringBuilder that can be used to create a String representation of this object. The returned * StringBuilder also takes care about attributes of super classes. * * @return {@link StringBuilder} StringBuilder representing this object. The method never returns null. */ public StringBuilder toStringBuilder( String pIndent ) { StringBuilder lBuilder = new StringBuilder(); lBuilder.append(pIndent); lBuilder.append(this.getClass().getName()); lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("names: "); if (names != null) { lBuilder.append(Arrays.toString(names)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("ints: "); if (ints != null) { lBuilder.append(Arrays.toString(ints)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("doubles: "); if (doubles != null) { lBuilder.append(Arrays.toString(doubles)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("codes: "); if (codes != null) { lBuilder.append(Arrays.toString(codes)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("stringCodeList: "); if (stringCodeList != null) { lBuilder.append(stringCodeList.size()); lBuilder.append(" element(s)"); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); if (stringCodeList != null) { for (StringCode lNext : stringCodeList) { lBuilder.append(lNext.toStringBuilder(pIndent + " ")); lBuilder.append(System.lineSeparator()); } } lBuilder.append(pIndent); lBuilder.append("startDate: "); lBuilder.append(startDate); lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("dates: "); if (dates != null) { lBuilder.append(Arrays.toString(dates)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("timestamps: "); if (timestamps != null) { lBuilder.append(timestamps.size()); lBuilder.append(" element(s)"); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); if (timestamps != null) { for (LocalDateTime lNext : timestamps) { lBuilder.append(pIndent + " "); lBuilder.append(lNext.toString()); lBuilder.append(System.lineSeparator()); } } lBuilder.append(pIndent); lBuilder.append("calendars: "); if (calendars != null) { lBuilder.append(Arrays.toString(calendars)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("utilDates: "); if (utilDates != null) { lBuilder.append(Arrays.toString(utilDates)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("sqlTimestamps: "); if (sqlTimestamps != null) { lBuilder.append(Arrays.toString(sqlTimestamps)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("timeUnits: "); if (timeUnits != null) { lBuilder.append(timeUnits.size()); lBuilder.append(" element(s)"); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); if (timeUnits != null) { for (TimeUnit lNext : timeUnits) { lBuilder.append(pIndent + " "); lBuilder.append(lNext.toString()); lBuilder.append(System.lineSeparator()); } } lBuilder.append(pIndent); lBuilder.append("timeUnitArray: "); if (timeUnitArray != null) { lBuilder.append(Arrays.toString(timeUnitArray)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); lBuilder.append(pIndent); lBuilder.append("base64: "); if (base64 != null) { lBuilder.append(Arrays.toString(base64)); } else { lBuilder.append(" null"); } lBuilder.append(System.lineSeparator()); return lBuilder; } /** * Method creates a new String with the values of all attributes of this class. All references to other objects will * be ignored. * * @return {@link String} String representation of this object. The method never returns null. */ @Override public String toString( ) { return this.toStringBuilder("").toString(); } /** * Method creates a new builder and initializes it with the data of this object. * * @return {@link Builder} New builder that can be used to create new MultiValuedHeaderBeanParam objects. The method * never returns null. */ public Builder toBuilder( ) { return new Builder(this); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy