Skip to content

Commit

Permalink
fix: addressing reviews v3
Browse files Browse the repository at this point in the history
  • Loading branch information
vibhatha committed Jun 28, 2024
1 parent 01a5cac commit 8fce14b
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 20 deletions.
5 changes: 3 additions & 2 deletions dev/archery/archery/integration/datagen.py
Original file line number Diff line number Diff line change
Expand Up @@ -1897,9 +1897,10 @@ def _temp_path():
generate_map_case(),

generate_non_canonical_map_case()
.skip_tester('Java') # TODO(ARROW-8715)
# .skip_tester('Java') # TODO(ARROW-8715)
# Canonical map names are restored on import, so the schemas are unequal
.skip_format(SKIP_C_SCHEMA, 'C++'),
.skip_format(SKIP_C_SCHEMA, 'C++')
.skip_format(SKIP_C_SCHEMA, 'Java'),

generate_nested_case(),

Expand Down
24 changes: 12 additions & 12 deletions java/vector/src/main/codegen/templates/UnionMapWriter.java
Original file line number Diff line number Diff line change
Expand Up @@ -142,25 +142,25 @@ public UnionMapWriter value() {

private String getWriteFieldName() {
Field mapField = this.vector.getField();
if (mapField == null) {
throw new UnsupportedOperationException("MapVector does not have a field.");
}
if (mapField.getChildren().size() != 1) {
throw new UnsupportedOperationException("MapVector does not have a single struct field.");
}
Preconditions.checkNotNull(mapField, "MapVector does not have a field.");
Preconditions.checkArgument(mapField.getChildren().size() == 1,
"MapVector does not have a single struct field.");
Field structField = mapField.getChildren().get(0);
switch (mode) {
case KEY:
if (structField.getChildren().size() == 2) {
return structField.getChildren().get(0).getName();
} else {
if (structField.getChildren().size() == 0) {
// key is not defined in the struct, use default name
return MapVector.KEY_NAME;
} else {
return structField.getChildren().get(0).getName();
}
case VALUE:
if (structField.getChildren().size() == 2) {
return structField.getChildren().get(1).getName();
} else {
if (structField.getChildren().size() < 2) {
// key may or may not have been defined in the struct, but
// value has not been defined.
return MapVector.VALUE_NAME;
} else {
return structField.getChildren().get(1).getName();
}
default:
throw new UnsupportedOperationException("Cannot get field name in OFF mode");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,9 @@
public class MapVector extends ListVector {

/** The default name of the key field in the MapVector. */
public static String KEY_NAME = "key";
public static final String KEY_NAME = "key";
/** The default name of the value field in the MapVector. */
public static String VALUE_NAME = "value";
public static final String VALUE_NAME = "value";

public static final String DATA_VECTOR_NAME = "entries";

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import static org.junit.jupiter.api.Assertions.assertTrue;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Map;
Expand Down Expand Up @@ -1208,15 +1209,13 @@ public void testMakeTransferPairPreserveNullability() {

@Test
public void testValidateKeyValueFieldNames() {
FieldType keyType = new FieldType(false, MinorType.BIGINT.getType(), null, null);
FieldType keyType = FieldType.notNullable(MinorType.BIGINT.getType());
FieldType valueType = FieldType.nullable(MinorType.FLOAT8.getType());

Field keyField = new Field("myKey", keyType, null);
Field valueField = new Field("myValue", valueType, null);

List<Field> structFields = new ArrayList<>(2);
structFields.add(keyField);
structFields.add(valueField);
List<Field> structFields = Arrays.asList(keyField, valueField);

Field structField =
new Field("entry", FieldType.notNullable(ArrowType.Struct.INSTANCE), structFields);
Expand Down

0 comments on commit 8fce14b

Please sign in to comment.