From 68e5bc39e3b01a22e20851910d53618da1bb9b17 Mon Sep 17 00:00:00 2001 From: Artyom Dubinin Date: Wed, 26 Jun 2024 12:23:53 +0300 Subject: [PATCH] Use toString in StringValues --- CHANGELOG.md | 3 +++ README.md | 2 +- .../metadata/ArrayValueToSpaceFormatConverter.java | 4 ++-- .../metadata/DDLTarantoolSpaceMetadataConverter.java | 10 +++++----- .../core/metadata/TarantoolIndexMetadataConverter.java | 4 ++-- .../DefaultStringValueToCharacterConverter.java | 4 ++-- .../defaults/DefaultStringValueToStringConverter.java | 2 +- src/main/java/io/tarantool/driver/package-info.java | 2 +- 8 files changed, 17 insertions(+), 14 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 12ef7865e..32a1daffb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ ## [Unreleased] +## [0.14.0] - 2024-06-26 + ### Bugfixes - Significantly reduce memory allocation overhead and excessive GC pressure ([#401](https://github.com/tarantool/cartridge-java/issues/401)) @@ -19,6 +21,7 @@ - Add support for crud `balance` option ([#462](https://github.com/tarantool/cartridge-java/pull/472)) - Add support for crud `vshard_router` option ([#463](https://github.com/tarantool/cartridge-java/pull/473)) - Add support for crud `fetch_latest_metadata` option ([#465](https://github.com/tarantool/cartridge-java/pull/474)) +- Use toString in StringValues to map incorrect UTF-8 string ### Features diff --git a/README.md b/README.md index 331debcb2..42cf04599 100644 --- a/README.md +++ b/README.md @@ -42,7 +42,7 @@ If you use this code in another project don't forget to add a `cartridge-driver` io.tarantool cartridge-driver - 0.13.0 + 0.14.0 ``` ## Advanced usage diff --git a/src/main/java/io/tarantool/driver/core/metadata/ArrayValueToSpaceFormatConverter.java b/src/main/java/io/tarantool/driver/core/metadata/ArrayValueToSpaceFormatConverter.java index 22c65db8d..4baaa6321 100644 --- a/src/main/java/io/tarantool/driver/core/metadata/ArrayValueToSpaceFormatConverter.java +++ b/src/main/java/io/tarantool/driver/core/metadata/ArrayValueToSpaceFormatConverter.java @@ -43,8 +43,8 @@ public Map fromValue(ArrayValue format) { spaceFormatMetadata.put( fieldMap.get(FORMAT_FIELD_NAME).toString(), new TarantoolFieldMetadataImpl( - fieldMap.get(FORMAT_FIELD_NAME).asStringValue().asString(), - fieldMap.get(FORMAT_FIELD_TYPE).asStringValue().asString(), + fieldMap.get(FORMAT_FIELD_NAME).asStringValue().toString(), + fieldMap.get(FORMAT_FIELD_TYPE).asStringValue().toString(), fieldPosition, isNullable.isPresent() && isNullable.get().asBooleanValue().getBoolean() ) diff --git a/src/main/java/io/tarantool/driver/core/metadata/DDLTarantoolSpaceMetadataConverter.java b/src/main/java/io/tarantool/driver/core/metadata/DDLTarantoolSpaceMetadataConverter.java index 55282c1d6..a8e744047 100644 --- a/src/main/java/io/tarantool/driver/core/metadata/DDLTarantoolSpaceMetadataConverter.java +++ b/src/main/java/io/tarantool/driver/core/metadata/DDLTarantoolSpaceMetadataConverter.java @@ -94,7 +94,7 @@ public TarantoolMetadataContainer fromValue(Value value) { TarantoolSpaceMetadataImpl spaceMetadata = new TarantoolSpaceMetadataImpl(); spaceMetadata.setOwnerId(ID_UNKNOWN); - spaceMetadata.setSpaceName(nameValue.asStringValue().asString()); + spaceMetadata.setSpaceName(nameValue.asStringValue().toString()); Value formatValue = space.get(SPACE_FORMAT_KEY); if (formatValue == null) { @@ -140,14 +140,14 @@ private Map parseIndexes( throw new TarantoolClientException( "Unsupported index metadata format: key '" + INDEX_NAME_KEY + "' must have string value"); } - String indexName = indexNameValue.asStringValue().asString(); + String indexName = indexNameValue.asStringValue().toString(); Value indexTypeValue = indexMap.get(INDEX_TYPE_KEY); if (indexTypeValue == null || !indexTypeValue.isStringValue()) { throw new TarantoolClientException( "Unsupported index metadata format: key '" + INDEX_TYPE_KEY + "' must have string value"); } - String indexType = indexTypeValue.asStringValue().asString(); + String indexType = indexTypeValue.asStringValue().toString(); Value indexUniqueValue = indexMap.get(INDEX_UNIQUE_KEY); if (indexUniqueValue == null || !indexUniqueValue.isBooleanValue()) { @@ -196,7 +196,7 @@ private Map parseIndexes( int fieldNumber; Object fieldPath; if (fieldPathValue.isStringValue()) { - fieldPath = fieldPathValue.asStringValue().asString(); + fieldPath = fieldPathValue.asStringValue().toString(); fieldNumber = getFieldNumberFromFieldPath(fields, (String) fieldPath); } else { fieldNumber = fieldPathValue.asIntegerValue().asInt(); @@ -208,7 +208,7 @@ private Map parseIndexes( throw new TarantoolClientException("Unsupported index metadata format: key '" + INDEX_PARTS_TYPE_KEY + "' must have string value"); } - String fieldType = fieldTypeValue.asStringValue().asString(); + String fieldType = fieldTypeValue.asStringValue().toString(); return new TarantoolIndexPartMetadataImpl<>(fieldNumber, fieldType, fieldPath); }) diff --git a/src/main/java/io/tarantool/driver/core/metadata/TarantoolIndexMetadataConverter.java b/src/main/java/io/tarantool/driver/core/metadata/TarantoolIndexMetadataConverter.java index 1d8371c1c..8c52f4fbd 100644 --- a/src/main/java/io/tarantool/driver/core/metadata/TarantoolIndexMetadataConverter.java +++ b/src/main/java/io/tarantool/driver/core/metadata/TarantoolIndexMetadataConverter.java @@ -61,13 +61,13 @@ public TarantoolIndexMetadata fromValue(ArrayValue value) { indexParts = indexPartsValue.list().stream() .map(partValue -> new TarantoolIndexPartMetadataImpl<>( partValue.asArrayValue().get(0).asIntegerValue().asInt(), - partValue.asArrayValue().get(1).asStringValue().asString() + partValue.asArrayValue().get(1).asStringValue().toString() )).collect(Collectors.toList()); } else { indexParts = indexPartsValue.list().stream() .map(partValue -> new TarantoolIndexPartMetadataImpl<>( partValue.asMapValue().map().get(INDEX_FIELD_KEY).asIntegerValue().asInt(), - partValue.asMapValue().map().get(INDEX_TYPE_KEY).asStringValue().asString() + partValue.asMapValue().map().get(INDEX_TYPE_KEY).asStringValue().toString() )).collect(Collectors.toList()); } } diff --git a/src/main/java/io/tarantool/driver/mappers/converters/value/defaults/DefaultStringValueToCharacterConverter.java b/src/main/java/io/tarantool/driver/mappers/converters/value/defaults/DefaultStringValueToCharacterConverter.java index d98d4302c..cff5d8a83 100644 --- a/src/main/java/io/tarantool/driver/mappers/converters/value/defaults/DefaultStringValueToCharacterConverter.java +++ b/src/main/java/io/tarantool/driver/mappers/converters/value/defaults/DefaultStringValueToCharacterConverter.java @@ -15,13 +15,13 @@ public class DefaultStringValueToCharacterConverter implements ValueConverter new CustomTuple(v.get(0).asIntegerValue().asInt(), v.get(1).asStringValue().asString())) + * (v) -> new CustomTuple(v.get(0).asIntegerValue().asInt(), v.get(1).asStringValue().toString())) * .get(); * * customTuples.forEach(