Class ImmutableJoin.Builder

java.lang.Object
io.substrait.relation.ImmutableJoin.Builder
Enclosing class:
ImmutableJoin

public static final class ImmutableJoin.Builder extends Object
Builds instances of type ImmutableJoin. Initialize attributes and then invoke the build() method to create an immutable instance.

Builder is not thread-safe and generally should not be stored in a field or collection, but instead used immediately to create instances.

  • Method Details

    • from

      public final ImmutableJoin.Builder from(HasExtension instance)
      Fill a builder with attribute values from the provided io.substrait.relation.HasExtension instance.
      Parameters:
      instance - The instance from which to copy values
      Returns:
      this builder for use in a chained invocation
    • from

      public final ImmutableJoin.Builder from(Rel instance)
      Fill a builder with attribute values from the provided io.substrait.relation.Rel instance.
      Parameters:
      instance - The instance from which to copy values
      Returns:
      this builder for use in a chained invocation
    • from

      public final ImmutableJoin.Builder from(AbstractRel instance)
      Fill a builder with attribute values from the provided io.substrait.relation.AbstractRel instance.
      Parameters:
      instance - The instance from which to copy values
      Returns:
      this builder for use in a chained invocation
    • from

      public final ImmutableJoin.Builder from(Join instance)
      Fill a builder with attribute values from the provided io.substrait.relation.Join instance.
      Parameters:
      instance - The instance from which to copy values
      Returns:
      this builder for use in a chained invocation
    • from

      public final ImmutableJoin.Builder from(BiRel instance)
      Fill a builder with attribute values from the provided io.substrait.relation.BiRel instance.
      Parameters:
      instance - The instance from which to copy values
      Returns:
      this builder for use in a chained invocation
    • extension

      public final ImmutableJoin.Builder extension(AdvancedExtension extension)
      Initializes the optional value extension to extension.
      Parameters:
      extension - The value for extension
      Returns:
      this builder for chained invocation
    • extension

      public final ImmutableJoin.Builder extension(Optional<? extends AdvancedExtension> extension)
      Initializes the optional value extension to extension.
      Parameters:
      extension - The value for extension
      Returns:
      this builder for use in a chained invocation
    • remap

      public final ImmutableJoin.Builder remap(Rel.Remap remap)
      Initializes the optional value remap to remap.
      Parameters:
      remap - The value for remap
      Returns:
      this builder for chained invocation
    • remap

      public final ImmutableJoin.Builder remap(Optional<? extends Rel.Remap> remap)
      Initializes the optional value remap to remap.
      Parameters:
      remap - The value for remap
      Returns:
      this builder for use in a chained invocation
    • commonExtension

      public final ImmutableJoin.Builder commonExtension(AdvancedExtension commonExtension)
      Initializes the optional value commonExtension to commonExtension.
      Parameters:
      commonExtension - The value for commonExtension
      Returns:
      this builder for chained invocation
    • commonExtension

      public final ImmutableJoin.Builder commonExtension(Optional<? extends AdvancedExtension> commonExtension)
      Initializes the optional value commonExtension to commonExtension.
      Parameters:
      commonExtension - The value for commonExtension
      Returns:
      this builder for use in a chained invocation
    • hint

      public final ImmutableJoin.Builder hint(Hint hint)
      Initializes the optional value hint to hint.
      Parameters:
      hint - The value for hint
      Returns:
      this builder for chained invocation
    • hint

      public final ImmutableJoin.Builder hint(Optional<? extends Hint> hint)
      Initializes the optional value hint to hint.
      Parameters:
      hint - The value for hint
      Returns:
      this builder for use in a chained invocation
    • left

      public final ImmutableJoin.Builder left(Rel left)
      Initializes the value for the left attribute.
      Parameters:
      left - The value for left
      Returns:
      this builder for use in a chained invocation
    • right

      public final ImmutableJoin.Builder right(Rel right)
      Initializes the value for the right attribute.
      Parameters:
      right - The value for right
      Returns:
      this builder for use in a chained invocation
    • condition

      public final ImmutableJoin.Builder condition(Expression condition)
      Initializes the optional value condition to condition.
      Parameters:
      condition - The value for condition
      Returns:
      this builder for chained invocation
    • condition

      public final ImmutableJoin.Builder condition(Optional<? extends Expression> condition)
      Initializes the optional value condition to condition.
      Parameters:
      condition - The value for condition
      Returns:
      this builder for use in a chained invocation
    • postJoinFilter

      public final ImmutableJoin.Builder postJoinFilter(Expression postJoinFilter)
      Initializes the optional value postJoinFilter to postJoinFilter.
      Parameters:
      postJoinFilter - The value for postJoinFilter
      Returns:
      this builder for chained invocation
    • postJoinFilter

      public final ImmutableJoin.Builder postJoinFilter(Optional<? extends Expression> postJoinFilter)
      Initializes the optional value postJoinFilter to postJoinFilter.
      Parameters:
      postJoinFilter - The value for postJoinFilter
      Returns:
      this builder for use in a chained invocation
    • joinType

      public final ImmutableJoin.Builder joinType(Join.JoinType joinType)
      Initializes the value for the joinType attribute.
      Parameters:
      joinType - The value for joinType
      Returns:
      this builder for use in a chained invocation
    • build

      public ImmutableJoin build()
      Builds a new ImmutableJoin.
      Returns:
      An immutable instance of Join
      Throws:
      IllegalStateException - if any required attributes are missing