Package io.substrait.type
Class ImmutableType.Struct
java.lang.Object
io.substrait.type.Type.Struct
io.substrait.type.ImmutableType.Struct
- All Implemented Interfaces:
FunctionArg,NullableType,ParameterizedType,TypeExpression,Type
- Enclosing class:
- ImmutableType
Immutable implementation of
Type.Struct.
Use the builder to create immutable instances:
ImmutableType.Struct.builder().
-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from interface io.substrait.expression.FunctionArg
FunctionArg.FuncArgVisitor<R,C extends VisitationContext, E extends Throwable>, FunctionArg.ProtoFrom Nested classes/interfaces inherited from interface io.substrait.function.ParameterizedType
ParameterizedType.BaseParameterizedType, ParameterizedType.NullableParameterizedType, ParameterizedType.RequiredParameterizedVisitorException, ParameterizedType.StringLiteralNested classes/interfaces inherited from interface io.substrait.type.Type
Type.Binary, Type.Bool, Type.Date, Type.Decimal, Type.FixedBinary, Type.FixedChar, Type.FP32, Type.FP64, Type.Func, Type.I16, Type.I32, Type.I64, Type.I8, Type.IntervalCompound, Type.IntervalDay, Type.IntervalYear, Type.ListType, Type.Map, Type.Parameter, Type.ParameterBooleanValue, Type.ParameterDataType, Type.ParameterEnumValue, Type.ParameterIntegerValue, Type.ParameterNull, Type.ParameterStringValue, Type.PrecisionTime, Type.PrecisionTimestamp, Type.PrecisionTimestampTZ, Type.Str, Type.Struct, Type.Time, Type.Timestamp, Type.TimestampTZ, Type.UserDefined, Type.UUID, Type.VarCharNested classes/interfaces inherited from interface io.substrait.function.TypeExpression
TypeExpression.BaseTypeExpression, TypeExpression.BinaryOperation, TypeExpression.IfOperation, TypeExpression.IntegerLiteral, TypeExpression.NotOperation, TypeExpression.RequiredTypeExpressionVisitorException, TypeExpression.ReturnProgram -
Method Summary
Modifier and TypeMethodDescriptionstatic ImmutableType.Struct.Builderbuilder()Creates a builder forStruct.static ImmutableType.StructcopyOf(Type.Struct instance) Creates an immutable copy of aType.Structvalue.booleanThis instance is equal to all instances ofStructthat have equal attribute values.fields()inthashCode()Computes a hash code from attributes:nullable,fields.booleannullable()toString()Prints the immutable valueStructwith attribute values.final ImmutableType.StructwithFields(Type... elements) Copy the current immutable object with elements that replace the content offields.final ImmutableType.StructwithFields(Iterable<? extends Type> elements) Copy the current immutable object with elements that replace the content offields.final ImmutableType.StructwithNullable(boolean value) Copy the current immutable object by setting a value for thenullableattribute.Methods inherited from class io.substrait.type.Type.Struct
acceptMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface io.substrait.function.ParameterizedType
isWildcardMethods inherited from interface io.substrait.type.Type
accept, equalsIgnoringNullability
-
Method Details
-
nullable
public boolean nullable()- Returns:
- The value of the
nullableattribute
-
fields
- Specified by:
fieldsin classType.Struct- Returns:
- The value of the
fieldsattribute
-
withNullable
Copy the current immutable object by setting a value for thenullableattribute. A value equality check is used to prevent copying of the same value by returningthis.- Parameters:
value- A new value for nullable- Returns:
- A modified copy or the
thisobject
-
withFields
Copy the current immutable object with elements that replace the content offields.- Parameters:
elements- The elements to set- Returns:
- A modified copy of
thisobject
-
withFields
Copy the current immutable object with elements that replace the content offields. A shallow reference equality check is used to prevent copying of the same value by returningthis.- Parameters:
elements- An iterable of fields elements to set- Returns:
- A modified copy or
thisif not changed
-
equals
This instance is equal to all instances ofStructthat have equal attribute values. -
hashCode
public int hashCode()Computes a hash code from attributes:nullable,fields. -
toString
Prints the immutable valueStructwith attribute values. -
copyOf
Creates an immutable copy of aType.Structvalue. Uses accessors to get values to initialize the new immutable instance. If an instance is already immutable, it is returned as is.- Parameters:
instance- The instance to copy- Returns:
- A copied immutable Struct instance
-
builder
Creates a builder forStruct.ImmutableType.Struct.builder() .nullable(boolean) // requirednullable.addFields|addAllFields(io.substrait.type.Type) //fieldselements .build();- Returns:
- A new Struct builder
-