Class BinaryRegister

java.lang.Object
com.pervasive.datarush.tokens.scalar.BinaryRegister
All Implemented Interfaces:
DataRegister, BinarySettable, BinaryValued, ScalarRegister, ScalarSettable, ScalarValued, TokenSettable, TokenValued, ScalarTyped, TokenTyped, Serializable

public final class BinaryRegister extends Object implements ScalarRegister, BinarySettable
A mutable BinaryValued object.
See Also:
  • Constructor Summary

    Constructors
    Constructor
    Description
    Creates a new null-valued register.
  • Method Summary

    Modifier and Type
    Method
    Description
    final byte[]
    Gets the contained binary value.
    final byte[]
    Gets a reference to the contained binary value.
    Gets the data type of the token.
    final boolean
    Indicates whether the token is null valued.
    final boolean
    Indicates whether the value is the zero value for the type.
    void
    set(byte[] data)
    Sets the container to the given binary data.
    void
    set(byte[] data, int offset, int length)
    Sets the container to a subsequence of the given binary data.
    void
    Sets the contained value to the given token value.
    void
    Sets the contained value to be null valued.
    void
    setRef(byte[] ref)
    Sets the container to the given byte array reference.
    void
    Sets the contained value to be zero valued.
     

    Methods inherited from class java.lang.Object

    clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait

    Methods inherited from interface com.pervasive.datarush.types.ScalarTyped

    getType

    Methods inherited from interface com.pervasive.datarush.tokens.scalar.ScalarValued

    getType, isZero

    Methods inherited from interface com.pervasive.datarush.tokens.TokenValued

    isNull
  • Constructor Details

    • BinaryRegister

      public BinaryRegister()
      Creates a new null-valued register.
  • Method Details

    • setNull

      public void setNull()
      Description copied from interface: TokenSettable
      Sets the contained value to be null valued.
      Specified by:
      setNull in interface TokenSettable
    • setZero

      public void setZero()
      Description copied from interface: TokenSettable
      Sets the contained value to be zero valued.
      Specified by:
      setZero in interface TokenSettable
    • set

      public void set(byte[] data)
      Description copied from interface: BinarySettable
      Sets the container to the given binary data.

      The input array is copied to prevent later modification of the value that is set. To avoid this overhead and prevent the data copy, use the BinarySettable.setRef(byte[]) method instead.

      Specified by:
      set in interface BinarySettable
      Parameters:
      data - binary value to which to set the container
    • set

      public void set(byte[] data, int offset, int length)
      Description copied from interface: BinarySettable
      Sets the container to a subsequence of the given binary data. The specified subsequence is copied from the input array.
      Specified by:
      set in interface BinarySettable
      Parameters:
      data - binary data containing the subsequence to which to set the container
      offset - starting offset of the subsequence
      length - length of the subsequence, in bytes
    • setRef

      public void setRef(byte[] ref)
      Description copied from interface: BinarySettable
      Sets the container to the given byte array reference.

      While this call avoids the overhead seen with BinarySettable.set(byte[]), the caller must guarantee that the input array will not be modified subsequent to this call. Failure to comply may result in the dataflow exhibiting unexpected behavior.

      Specified by:
      setRef in interface BinarySettable
      Parameters:
      ref - binary value to which to set the container
    • set

      public void set(TokenValued value)
      Description copied from interface: TokenSettable
      Sets the contained value to the given token value. The given value must have a type compatible with this object.
      Specified by:
      set in interface TokenSettable
      Parameters:
      value - the value to which to set the container
    • getType

      public final ScalarTokenType getType()
      Description copied from interface: TokenValued
      Gets the data type of the token. This type will dictate the valid values that can be contained.
      Specified by:
      getType in interface ScalarTyped
      Specified by:
      getType in interface ScalarValued
      Specified by:
      getType in interface TokenTyped
      Specified by:
      getType in interface TokenValued
      Returns:
      the token type.
    • asBinary

      public final byte[] asBinary()
      Description copied from interface: BinaryValued
      Gets the contained binary value.

      The array returned is a copy of the binary data contained in the object. To avoid this overhead, use BinaryValued.asBinaryRef() instead.

      Specified by:
      asBinary in interface BinaryValued
      Returns:
      the contained value as a byte[]. If null valued, as indicated by TokenValued.isNull(), null is returned.
    • asBinaryRef

      public final byte[] asBinaryRef()
      Description copied from interface: BinaryValued
      Gets a reference to the contained binary value.

      While this call avoids the overhead seen with BinaryValued.asBinary(), the caller must guarantee that the returned array will not be modified. Failure to comply may result in the dataflow exhibiting unexpected behavior, as other operators may (or may not) see the modified value.

      Specified by:
      asBinaryRef in interface BinaryValued
      Returns:
      a reference to the byte[] holding the contained value. If null valued, as indicated by TokenValued.isNull(), null is returned.
    • isZero

      public final boolean isZero()
      Description copied from interface: ScalarValued
      Indicates whether the value is the zero value for the type. Zero values are not stored in sparse representation formats.
      Specified by:
      isZero in interface ScalarValued
      Returns:
      true if the value is the zero value, false otherwise.
    • toString

      public String toString()
      Overrides:
      toString in class Object
    • isNull

      public final boolean isNull()
      Description copied from interface: TokenValued
      Indicates whether the token is null valued. Tokens support null values analogous to SQL. Before accessing the value of the container, it is usually best to ensure it is not null valued using this method.
      Specified by:
      isNull in interface TokenValued
      Returns:
      true if the token is null valued, false otherwise