org.neo4j.driver.internal.util.Extract Maven / Gradle / Ivy
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [https://neo4j.com]
*
* 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 org.neo4j.driver.internal.util;
import static java.util.Collections.emptyList;
import static java.util.Collections.emptyMap;
import static java.util.Collections.singletonList;
import static java.util.Collections.singletonMap;
import static java.util.Collections.unmodifiableList;
import static java.util.Collections.unmodifiableMap;
import static org.neo4j.driver.Values.value;
import static org.neo4j.driver.internal.util.Iterables.newHashMapWithSize;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import org.neo4j.driver.Record;
import org.neo4j.driver.Value;
import org.neo4j.driver.exceptions.ClientException;
import org.neo4j.driver.internal.InternalPair;
import org.neo4j.driver.internal.value.NodeValue;
import org.neo4j.driver.internal.value.PathValue;
import org.neo4j.driver.internal.value.RelationshipValue;
import org.neo4j.driver.types.MapAccessor;
import org.neo4j.driver.types.Node;
import org.neo4j.driver.types.Path;
import org.neo4j.driver.types.Relationship;
import org.neo4j.driver.util.Pair;
/**
* Utility class for extracting data.
*/
public final class Extract {
private Extract() {
throw new UnsupportedOperationException();
}
public static List list(Value[] values) {
return switch (values.length) {
case 0 -> emptyList();
case 1 -> singletonList(values[0]);
default -> List.of(values);
};
}
public static List list(Value[] data, Function mapFunction) {
var size = data.length;
switch (size) {
case 0 -> {
return emptyList();
}
case 1 -> {
return singletonList(mapFunction.apply(data[0]));
}
default -> {
return Arrays.stream(data).map(mapFunction).toList();
}
}
}
public static Map map(Map data, Function mapFunction) {
if (data.isEmpty()) {
return emptyMap();
} else {
var size = data.size();
if (size == 1) {
var head = data.entrySet().iterator().next();
return singletonMap(head.getKey(), mapFunction.apply(head.getValue()));
} else {
Map map = Iterables.newLinkedHashMapWithSize(size);
for (var entry : data.entrySet()) {
map.put(entry.getKey(), mapFunction.apply(entry.getValue()));
}
return unmodifiableMap(map);
}
}
}
public static Map map(Record record, Function mapFunction) {
var size = record.size();
switch (size) {
case 0 -> {
return emptyMap();
}
case 1 -> {
return singletonMap(record.keys().get(0), mapFunction.apply(record.get(0)));
}
default -> {
Map map = Iterables.newLinkedHashMapWithSize(size);
var keys = record.keys();
for (var i = 0; i < size; i++) {
map.put(keys.get(i), mapFunction.apply(record.get(i)));
}
return unmodifiableMap(map);
}
}
}
public static Iterable> properties(
final MapAccessor map, final Function mapFunction) {
var size = map.size();
switch (size) {
case 0 -> {
return emptyList();
}
case 1 -> {
var key = map.keys().iterator().next();
var value = map.get(key);
return singletonList(InternalPair.of(key, mapFunction.apply(value)));
}
default -> {
List> list = new ArrayList<>(size);
for (var key : map.keys()) {
var value = map.get(key);
list.add(InternalPair.of(key, mapFunction.apply(value)));
}
return unmodifiableList(list);
}
}
}
public static List> fields(final Record map, final Function mapFunction) {
var size = map.keys().size();
switch (size) {
case 0 -> {
return emptyList();
}
case 1 -> {
var key = map.keys().iterator().next();
var value = map.get(key);
return singletonList(InternalPair.of(key, mapFunction.apply(value)));
}
default -> {
List> list = new ArrayList<>(size);
var keys = map.keys();
for (var i = 0; i < size; i++) {
var key = keys.get(i);
var value = map.get(i);
list.add(InternalPair.of(key, mapFunction.apply(value)));
}
return unmodifiableList(list);
}
}
}
public static Map mapOfValues(Map map) {
if (map == null || map.isEmpty()) {
return emptyMap();
}
Map result = newHashMapWithSize(map.size());
for (var entry : map.entrySet()) {
var value = entry.getValue();
assertParameter(value);
result.put(entry.getKey(), value(value));
}
return result;
}
public static void assertParameter(Object value) {
if (value instanceof Node || value instanceof NodeValue) {
throw new ClientException("Nodes can't be used as parameters.");
}
if (value instanceof Relationship || value instanceof RelationshipValue) {
throw new ClientException("Relationships can't be used as parameters.");
}
if (value instanceof Path || value instanceof PathValue) {
throw new ClientException("Paths can't be used as parameters.");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy