-
Notifications
You must be signed in to change notification settings - Fork 5.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Support common operators like `=` on enum types
- Loading branch information
1 parent
3649366
commit 99e67bc
Showing
7 changed files
with
717 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
111 changes: 111 additions & 0 deletions
111
presto-main/src/main/java/com/facebook/presto/type/EnumCasts.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,111 @@ | ||
/* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.facebook.presto.type; | ||
|
||
import com.facebook.presto.common.type.LongEnumType; | ||
import com.facebook.presto.common.type.StandardTypes; | ||
import com.facebook.presto.common.type.Type; | ||
import com.facebook.presto.common.type.VarcharEnumType; | ||
import com.facebook.presto.spi.PrestoException; | ||
import com.facebook.presto.spi.function.ScalarOperator; | ||
import com.facebook.presto.spi.function.SqlType; | ||
import com.facebook.presto.spi.function.TypeParameter; | ||
import io.airlift.slice.Slice; | ||
|
||
import static com.facebook.presto.common.function.OperatorType.CAST; | ||
import static com.facebook.presto.common.type.StandardTypes.BIGINT; | ||
import static com.facebook.presto.spi.StandardErrorCode.INVALID_CAST_ARGUMENT; | ||
|
||
public final class EnumCasts | ||
{ | ||
private EnumCasts() | ||
{ | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = VarcharEnumType.class) | ||
@SqlType("T") | ||
public static Slice castVarcharToEnum(@TypeParameter("T") Type enumType, @SqlType(StandardTypes.VARCHAR) Slice value) | ||
{ | ||
if (!(((VarcharEnumType) enumType).getEnumMap().values().contains(value.toStringUtf8()))) { | ||
throw new PrestoException(INVALID_CAST_ARGUMENT, | ||
String.format( | ||
"No value '%s' in enum '%s'", | ||
value.toStringUtf8(), | ||
enumType.getTypeSignature().getBase())); | ||
} | ||
return value; | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = VarcharEnumType.class) | ||
@SqlType(StandardTypes.VARCHAR) | ||
public static Slice castEnumToVarchar(@SqlType("T") Slice value) | ||
{ | ||
return value; | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType("T") | ||
public static long castBigintToEnum(@TypeParameter("T") Type enumType, @SqlType(BIGINT) long value) | ||
{ | ||
return castLongToEnum(enumType, value); | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType("T") | ||
public static long castIntegerToEnum(@TypeParameter("T") Type enumType, @SqlType(StandardTypes.INTEGER) long value) | ||
{ | ||
return castLongToEnum(enumType, value); | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType("T") | ||
public static long castSmallintToEnum(@TypeParameter("T") Type enumType, @SqlType(StandardTypes.SMALLINT) long value) | ||
{ | ||
return castLongToEnum(enumType, value); | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType("T") | ||
public static long castTinyintToEnum(@TypeParameter("T") Type enumType, @SqlType(StandardTypes.TINYINT) long value) | ||
{ | ||
return castLongToEnum(enumType, value); | ||
} | ||
|
||
private static long castLongToEnum(Type enumType, long value) | ||
{ | ||
if (!((LongEnumType) enumType).getEnumMap().values().contains(value)) { | ||
throw new PrestoException(INVALID_CAST_ARGUMENT, | ||
String.format( | ||
"No value '%d' in enum '%s'", | ||
value, | ||
enumType.getTypeSignature().getBase())); | ||
} | ||
return value; | ||
} | ||
|
||
@ScalarOperator(CAST) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BIGINT) | ||
public static long castEnumToBigint(@SqlType("T") long value) | ||
{ | ||
return value; | ||
} | ||
} |
143 changes: 143 additions & 0 deletions
143
presto-main/src/main/java/com/facebook/presto/type/LongEnumOperators.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
/* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
package com.facebook.presto.type; | ||
|
||
import com.facebook.presto.common.type.AbstractLongType; | ||
import com.facebook.presto.common.type.LongEnumType; | ||
import com.facebook.presto.common.type.StandardTypes; | ||
import com.facebook.presto.spi.function.IsNull; | ||
import com.facebook.presto.spi.function.ScalarOperator; | ||
import com.facebook.presto.spi.function.SqlNullable; | ||
import com.facebook.presto.spi.function.SqlType; | ||
import com.facebook.presto.spi.function.TypeParameter; | ||
import io.airlift.slice.XxHash64; | ||
|
||
import static com.facebook.presto.common.function.OperatorType.BETWEEN; | ||
import static com.facebook.presto.common.function.OperatorType.EQUAL; | ||
import static com.facebook.presto.common.function.OperatorType.GREATER_THAN; | ||
import static com.facebook.presto.common.function.OperatorType.GREATER_THAN_OR_EQUAL; | ||
import static com.facebook.presto.common.function.OperatorType.HASH_CODE; | ||
import static com.facebook.presto.common.function.OperatorType.INDETERMINATE; | ||
import static com.facebook.presto.common.function.OperatorType.IS_DISTINCT_FROM; | ||
import static com.facebook.presto.common.function.OperatorType.LESS_THAN; | ||
import static com.facebook.presto.common.function.OperatorType.LESS_THAN_OR_EQUAL; | ||
import static com.facebook.presto.common.function.OperatorType.NOT_EQUAL; | ||
import static com.facebook.presto.common.function.OperatorType.XX_HASH_64; | ||
import static com.facebook.presto.common.type.StandardTypes.BIGINT; | ||
import static com.facebook.presto.common.type.StandardTypes.BOOLEAN; | ||
|
||
public final class LongEnumOperators | ||
{ | ||
private LongEnumOperators() {} | ||
|
||
@ScalarOperator(EQUAL) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BOOLEAN) | ||
@SqlNullable | ||
public static Boolean equal(@SqlType("T") long left, @SqlType("T") long right) | ||
{ | ||
return left == right; | ||
} | ||
|
||
@ScalarOperator(NOT_EQUAL) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BOOLEAN) | ||
@SqlNullable | ||
public static Boolean notEqual(@SqlType("T") long left, @SqlType("T") long right) | ||
{ | ||
return left != right; | ||
} | ||
|
||
@ScalarOperator(IS_DISTINCT_FROM) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BOOLEAN) | ||
public static boolean isDistinctFrom( | ||
@SqlType("T") long left, | ||
@IsNull boolean leftNull, | ||
@SqlType("T") long right, | ||
@IsNull boolean rightNull) | ||
{ | ||
if (leftNull != rightNull) { | ||
return true; | ||
} | ||
if (leftNull) { | ||
return false; | ||
} | ||
return notEqual(left, right); | ||
} | ||
|
||
@ScalarOperator(HASH_CODE) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BIGINT) | ||
public static long hashCode(@SqlType("T") long value) | ||
{ | ||
return AbstractLongType.hash(value); | ||
} | ||
|
||
@ScalarOperator(XX_HASH_64) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BIGINT) | ||
public static long xxHash64(@SqlType("T") long value) | ||
{ | ||
return XxHash64.hash(value); | ||
} | ||
|
||
@ScalarOperator(INDETERMINATE) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(BOOLEAN) | ||
public static boolean indeterminate(@SqlType("T") long value, @IsNull boolean isNull) | ||
{ | ||
return isNull; | ||
} | ||
|
||
@ScalarOperator(LESS_THAN) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(StandardTypes.BOOLEAN) | ||
public static boolean lessThan(@SqlType("T") long left, @SqlType("T") long right) | ||
{ | ||
return left < right; | ||
} | ||
|
||
@ScalarOperator(LESS_THAN_OR_EQUAL) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(StandardTypes.BOOLEAN) | ||
public static boolean lessThanOrEqual(@SqlType("T") long left, @SqlType("T") long right) | ||
{ | ||
return left <= right; | ||
} | ||
|
||
@ScalarOperator(GREATER_THAN) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(StandardTypes.BOOLEAN) | ||
public static boolean greaterThan(@SqlType("T") long left, @SqlType("T") long right) | ||
{ | ||
return left > right; | ||
} | ||
|
||
@ScalarOperator(GREATER_THAN_OR_EQUAL) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(StandardTypes.BOOLEAN) | ||
public static boolean greaterThanOrEqual(@SqlType("T") long left, @SqlType("T") long right) | ||
{ | ||
return left >= right; | ||
} | ||
|
||
@ScalarOperator(BETWEEN) | ||
@TypeParameter(value = "T", boundedBy = LongEnumType.class) | ||
@SqlType(StandardTypes.BOOLEAN) | ||
public static boolean between(@SqlType("T") long value, @SqlType("T") long min, @SqlType("T") long max) | ||
{ | ||
return min <= value && value <= max; | ||
} | ||
} |
Oops, something went wrong.