org.neo4j.driver.internal.util.Extract Maven / Gradle / Ivy
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* 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 java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
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.Record;
import org.neo4j.driver.Value;
import org.neo4j.driver.exceptions.ClientException;
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 java.util.function.Function;
import org.neo4j.driver.util.Pair;
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.internal.util.Iterables.newHashMapWithSize;
import static org.neo4j.driver.Values.value;
/**
* Utility class for extracting data.
*/
public final class Extract
{
private Extract()
{
throw new UnsupportedOperationException();
}
public static List list( Value[] values )
{
switch ( values.length )
{
case 0:
return emptyList();
case 1:
return singletonList( values[0] );
default:
return unmodifiableList( Arrays.asList( values ) );
}
}
public static List list( Value[] data, Function mapFunction )
{
int size = data.length;
switch ( size )
{
case 0:
return emptyList();
case 1:
return singletonList( mapFunction.apply( data[0] ) );
default:
List result = new ArrayList<>( size );
for ( Value value : data )
{
result.add( mapFunction.apply( value ) );
}
return unmodifiableList( result );
}
}
public static Map map( Map data, Function mapFunction )
{
if ( data.isEmpty() ) {
return emptyMap();
} else {
int size = data.size();
if ( size == 1 ) {
Map.Entry head = data.entrySet().iterator().next();
return singletonMap( head.getKey(), mapFunction.apply( head.getValue() ) );
} else {
Map map = Iterables.newLinkedHashMapWithSize( size );
for ( Map.Entry entry : data.entrySet() )
{
map.put( entry.getKey(), mapFunction.apply( entry.getValue() ) );
}
return unmodifiableMap( map );
}
}
}
public static Map map( Record record, Function mapFunction )
{
int 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 );
List keys = record.keys();
for ( int 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 )
{
int size = map.size();
switch ( size )
{
case 0:
return emptyList();
case 1:
{
String key = map.keys().iterator().next();
Value value = map.get( key );
return singletonList( InternalPair.of( key, mapFunction.apply( value ) ) );
}
default:
{
List> list = new ArrayList<>( size );
for ( String key : map.keys() )
{
Value 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 )
{
int size = map.keys().size();
switch ( size )
{
case 0:
return emptyList();
case 1:
{
String key = map.keys().iterator().next();
Value value = map.get( key );
return singletonList( InternalPair.of( key, mapFunction.apply( value ) ) );
}
default:
{
List> list = new ArrayList<>( size );
List keys = map.keys();
for ( int i = 0; i < size; i++ )
{
String key = keys.get( i );
Value 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 ( Map.Entry entry : map.entrySet() )
{
Object 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