[flink] 06/06: [FLINK-13078][table-common] Add a logical type parser
This is an automated email from the ASF dual-hosted git repository. twalthr pushed a commit to branch release-1.9 in repository https://gitbox.apache.org/repos/asf/flink.git commit b2922105e08ac307835022acbf0bab4ed819d862 Author: Timo Walther AuthorDate: Wed Jul 10 08:52:30 2019 +0200 [FLINK-13078][table-common] Add a logical type parser This adds a parser for all logical types defined in FLIP-37. This closes #9061. --- .../flink/table/types/logical/LogicalType.java | 3 + .../types/logical/utils/LogicalTypeParser.java | 900 + .../apache/flink/table/utils/EncodingUtils.java| 6 +- .../apache/flink/table/utils/TypeStringUtils.java | 12 +- .../flink/table/types/LogicalTypeParserTest.java | 519 5 files changed, 1437 insertions(+), 3 deletions(-) diff --git a/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java index 4e4942a..cc46533 100644 --- a/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java +++ b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java @@ -21,6 +21,7 @@ package org.apache.flink.table.types.logical; import org.apache.flink.annotation.PublicEvolving; import org.apache.flink.table.types.logical.utils.LogicalTypeCasts; import org.apache.flink.table.types.logical.utils.LogicalTypeGeneralization; +import org.apache.flink.table.types.logical.utils.LogicalTypeParser; import org.apache.flink.util.Preconditions; import java.io.Serializable; @@ -98,6 +99,8 @@ public abstract class LogicalType implements Serializable { * Returns a string that fully serializes this instance. The serialized string can be used for * transmitting or persisting a type. * +* See {@link LogicalTypeParser} for the reverse operation. +* * @return detailed string for transmission or persistence */ public abstract String asSerializableString(); diff --git a/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/utils/LogicalTypeParser.java b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/utils/LogicalTypeParser.java new file mode 100644 index 000..b6fcd07 --- /dev/null +++ b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/utils/LogicalTypeParser.java @@ -0,0 +1,900 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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 org.apache.flink.table.types.logical.utils; + +import org.apache.flink.annotation.PublicEvolving; +import org.apache.flink.api.common.typeutils.TypeSerializerSnapshot; +import org.apache.flink.core.memory.DataInputDeserializer; +import org.apache.flink.table.api.ValidationException; +import org.apache.flink.table.types.logical.AnyType; +import org.apache.flink.table.types.logical.ArrayType; +import org.apache.flink.table.types.logical.BigIntType; +import org.apache.flink.table.types.logical.BinaryType; +import org.apache.flink.table.types.logical.BooleanType; +import org.apache.flink.table.types.logical.CharType; +import org.apache.flink.table.types.logical.DateType; +import org.apache.flink.table.types.logical.DayTimeIntervalType; +import org.apache.flink.table.types.logical.DayTimeIntervalType.DayTimeResolution; +import org.apache.flink.table.types.logical.DecimalType; +import org.apache.flink.table.types.logical.DoubleType; +import org.apache.flink.table.types.logical.FloatType; +import org.apache.flink.table.types.logical.IntType; +import org.apache.flink.table.types.logical.LocalZonedTimestampType; +import org.apache.flink.table.types.logical.LogicalType; +import org.apache.flink.table.types.logical.MapType; +import org.apache.flink.table.types.logical.MultisetType; +import org.apache.flink.table.types.logical.NullType; +import org.apache.flink.table.types.logical.RowType; +import org.apache.flink.table.types.logical.SmallIntType; +import org.apache.flink.table.types.logical.TimeType; +import
[flink] 06/06: [FLINK-13078][table-common] Add a logical type parser
This is an automated email from the ASF dual-hosted git repository. twalthr pushed a commit to branch master in repository https://gitbox.apache.org/repos/asf/flink.git commit 479fb070edc4a681d85e4c20a964083751aa3720 Author: Timo Walther AuthorDate: Wed Jul 10 08:52:30 2019 +0200 [FLINK-13078][table-common] Add a logical type parser This adds a parser for all logical types defined in FLIP-37. This closes #9061. --- .../flink/table/types/logical/LogicalType.java | 3 + .../types/logical/utils/LogicalTypeParser.java | 900 + .../apache/flink/table/utils/EncodingUtils.java| 6 +- .../apache/flink/table/utils/TypeStringUtils.java | 12 +- .../flink/table/types/LogicalTypeParserTest.java | 519 5 files changed, 1437 insertions(+), 3 deletions(-) diff --git a/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java index 4e4942a..cc46533 100644 --- a/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java +++ b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/LogicalType.java @@ -21,6 +21,7 @@ package org.apache.flink.table.types.logical; import org.apache.flink.annotation.PublicEvolving; import org.apache.flink.table.types.logical.utils.LogicalTypeCasts; import org.apache.flink.table.types.logical.utils.LogicalTypeGeneralization; +import org.apache.flink.table.types.logical.utils.LogicalTypeParser; import org.apache.flink.util.Preconditions; import java.io.Serializable; @@ -98,6 +99,8 @@ public abstract class LogicalType implements Serializable { * Returns a string that fully serializes this instance. The serialized string can be used for * transmitting or persisting a type. * +* See {@link LogicalTypeParser} for the reverse operation. +* * @return detailed string for transmission or persistence */ public abstract String asSerializableString(); diff --git a/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/utils/LogicalTypeParser.java b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/utils/LogicalTypeParser.java new file mode 100644 index 000..b6fcd07 --- /dev/null +++ b/flink-table/flink-table-common/src/main/java/org/apache/flink/table/types/logical/utils/LogicalTypeParser.java @@ -0,0 +1,900 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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 org.apache.flink.table.types.logical.utils; + +import org.apache.flink.annotation.PublicEvolving; +import org.apache.flink.api.common.typeutils.TypeSerializerSnapshot; +import org.apache.flink.core.memory.DataInputDeserializer; +import org.apache.flink.table.api.ValidationException; +import org.apache.flink.table.types.logical.AnyType; +import org.apache.flink.table.types.logical.ArrayType; +import org.apache.flink.table.types.logical.BigIntType; +import org.apache.flink.table.types.logical.BinaryType; +import org.apache.flink.table.types.logical.BooleanType; +import org.apache.flink.table.types.logical.CharType; +import org.apache.flink.table.types.logical.DateType; +import org.apache.flink.table.types.logical.DayTimeIntervalType; +import org.apache.flink.table.types.logical.DayTimeIntervalType.DayTimeResolution; +import org.apache.flink.table.types.logical.DecimalType; +import org.apache.flink.table.types.logical.DoubleType; +import org.apache.flink.table.types.logical.FloatType; +import org.apache.flink.table.types.logical.IntType; +import org.apache.flink.table.types.logical.LocalZonedTimestampType; +import org.apache.flink.table.types.logical.LogicalType; +import org.apache.flink.table.types.logical.MapType; +import org.apache.flink.table.types.logical.MultisetType; +import org.apache.flink.table.types.logical.NullType; +import org.apache.flink.table.types.logical.RowType; +import org.apache.flink.table.types.logical.SmallIntType; +import org.apache.flink.table.types.logical.TimeType; +import org.apache.flink.table.types.logical.TimestampType;