/*
* Copyright (c) 2018 Goldman Sachs.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Eclipse Distribution License v. 1.0 which accompany this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*/
package org.eclipse.collections.impl.map.mutable.primitive;
import org.eclipse.collections.api.block.function.primitive.ByteFunction;
import org.eclipse.collections.api.factory.map.primitive.MutableByteByteMapFactory;
import org.eclipse.collections.impl.factory.primitive.ByteByteMaps;
import org.eclipse.collections.api.map.primitive.MutableByteByteMap;
import org.eclipse.collections.api.map.primitive.ByteByteMap;
import org.eclipse.collections.impl.utility.Iterate;
MutableByteByteMapFactoryImpl is a factory implementation which creates instances of type MutableByteByteMap
. This file was automatically generated from template file mutablePrimitivePrimitiveMapFactoryImpl.stg. Since: 6.0.
/**
* MutableByteByteMapFactoryImpl is a factory implementation which creates instances of type {@link MutableByteByteMap}.
* This file was automatically generated from template file mutablePrimitivePrimitiveMapFactoryImpl.stg.
*
* @since 6.0.
*/
public enum MutableByteByteMapFactoryImpl implements MutableByteByteMapFactory
{
INSTANCE;
@Override
public MutableByteByteMap empty()
{
return new ByteByteHashMap(0);
}
@Override
public MutableByteByteMap of()
{
return this.empty();
}
@Override
public MutableByteByteMap with()
{
return this.empty();
}
@Override
public MutableByteByteMap ofInitialCapacity(int capacity)
{
return this.withInitialCapacity(capacity);
}
@Override
public MutableByteByteMap withInitialCapacity(int capacity)
{
return new ByteByteHashMap(capacity);
}
@Override
public MutableByteByteMap ofAll(ByteByteMap map)
{
return this.withAll(map);
}
@Override
public MutableByteByteMap withAll(ByteByteMap map)
{
if (map.isEmpty())
{
return this.empty();
}
return new ByteByteHashMap(map);
}
@Override
public <T> MutableByteByteMap from(Iterable<T> iterable, ByteFunction<? super T> keyFunction, ByteFunction<? super T> valueFunction)
{
MutableByteByteMap map = ByteByteMaps.mutable.empty();
Iterate.forEach(iterable, each -> map.put(keyFunction.byteValueOf(each), valueFunction.byteValueOf(each)));
return map;
}
}