S - Java class of source valuesT - Java class of transformed valuespublic interface Transform<S,T>
extends java.io.Serializable
 Implementations of this interface can be used to transform values, check or types, and project
 predicates to predicates on partition values.
| Modifier and Type | Method and Description | 
|---|---|
| T | apply(S value)Transforms a value to its corresponding partition value. | 
| boolean | canTransform(Type type)Checks whether this function can be applied to the given  Type. | 
| default java.lang.String | dedupName()Return the unique transform name to check if similar transforms for the same source field
 are added multiple times in partition spec builder. | 
| Type | getResultType(Type sourceType)Returns the  Typeproduced by this transform given a source type. | 
| default boolean | isIdentity()Return whether this transform is the identity transform. | 
| default boolean | preservesOrder()Whether the transform preserves the order of values (is monotonic). | 
| UnboundPredicate<T> | project(java.lang.String name,
       BoundPredicate<S> predicate)Transforms a  predicateto an inclusive predicate on the partition
 values produced byapply(Object). | 
| UnboundPredicate<T> | projectStrict(java.lang.String name,
             BoundPredicate<S> predicate)Transforms a  predicateto a strict predicate on the partition values
 produced byapply(Object). | 
| default boolean | satisfiesOrderOf(Transform<?,?> other)Whether ordering by this transform's result satisfies the ordering of another transform's result. | 
| default java.lang.String | toHumanString(T value)Returns a human-readable String representation of a transformed value. | 
T apply(S value)
value - a source valueboolean canTransform(Type type)
Type.type - a typeType getResultType(Type sourceType)
Type produced by this transform given a source type.sourceType - a typedefault boolean preservesOrder()
A transform preserves order for values when for any given a and b, if a < b then apply(a) <= apply(b).
default boolean satisfiesOrderOf(Transform<?,?> other)
For example, sorting by day(ts) will produce an ordering that is also by month(ts) or year(ts). However, sorting by day(ts) will not satisfy the order of hour(ts) or identity(ts).
UnboundPredicate<T> project(java.lang.String name, BoundPredicate<S> predicate)
predicate to an inclusive predicate on the partition
 values produced by apply(Object).
 This inclusive transform guarantees that if pred(v) is true, then projected(apply(v)) is true.
name - the field name for partition valuespredicate - a predicate for source valuesUnboundPredicate<T> projectStrict(java.lang.String name, BoundPredicate<S> predicate)
predicate to a strict predicate on the partition values
 produced by apply(Object).
 This strict transform guarantees that if strict(apply(v)) is true, then pred(v) is also true.
name - the field name for partition valuespredicate - a predicate for source valuesdefault boolean isIdentity()
default java.lang.String toHumanString(T value)
null values will return "null"
value - a transformed valuedefault java.lang.String dedupName()