package org.eclipse.collections.impl.map.immutable;
import java.util.Map;
import java.util.Objects;
import org.eclipse.collections.api.factory.map.ImmutableMapFactory;
import org.eclipse.collections.api.map.ImmutableMap;
public class ImmutableMapFactoryImpl implements ImmutableMapFactory
{
public static final ImmutableMapFactory INSTANCE = new ImmutableMapFactoryImpl();
@Override
public <K, V> ImmutableMap<K, V> empty()
{
return (ImmutableMap<K, V>) ImmutableEmptyMap.INSTANCE;
}
@Override
public <K, V> ImmutableMap<K, V> of()
{
return this.empty();
}
@Override
public <K, V> ImmutableMap<K, V> with()
{
return this.empty();
}
@Override
public <K, V> ImmutableMap<K, V> of(K key, V value)
{
return this.with(key, value);
}
@Override
public <K, V> ImmutableMap<K, V> with(K key, V value)
{
return new ImmutableSingletonMap<>(key, value);
}
@Override
public <K, V> ImmutableMap<K, V> of(K key1, V value1, K key2, V value2)
{
return this.with(key1, value1, key2, value2);
}
@Override
public <K, V> ImmutableMap<K, V> with(K key1, V value1, K key2, V value2)
{
if (Objects.equals(key1, key2))
{
return this.of(key1, value2);
}
return new ImmutableDoubletonMap<>(key1, value1, key2, value2);
}
@Override
public <K, V> ImmutableMap<K, V> of(K key1, V value1, K key2, V value2, K key3, V value3)
{
return this.with(key1, value1, key2, value2, key3, value3);
}
@Override
public <K, V> ImmutableMap<K, V> with(K key1, V value1, K key2, V value2, K key3, V value3)
{
if (Objects.equals(key1, key2) && Objects.equals(key2, key3))
{
return this.of(key1, value3);
}
if (Objects.equals(key1, key2))
{
return this.of(key1, value2, key3, value3);
}
if (Objects.equals(key1, key3))
{
return this.of(key2, value2, key1, value3);
}
if (Objects.equals(key2, key3))
{
return this.of(key1, value1, key2, value3);
}
return new ImmutableTripletonMap<>(key1, value1, key2, value2, key3, value3);
}
@Override
public <K, V> ImmutableMap<K, V> of(K key1, V value1, K key2, V value2, K key3, V value3, K key4, V value4)
{
return this.with(key1, value1, key2, value2, key3, value3, key4, value4);
}
@Override
public <K, V> ImmutableMap<K, V> with(K key1, V value1, K key2, V value2, K key3, V value3, K key4, V value4)
{
if (Objects.equals(key1, key2))
{
return this.of(key1, value2, key3, value3, key4, value4);
}
if (Objects.equals(key1, key3))
{
return this.of(key2, value2, key1, value3, key4, value4);
}
if (Objects.equals(key1, key4))
{
return this.of(key2, value2, key3, value3, key1, value4);
}
if (Objects.equals(key2, key3))
{
return this.of(key1, value1, key2, value3, key4, value4);
}
if (Objects.equals(key2, key4))
{
return this.of(key1, value1, key3, value3, key2, value4);
}
if (Objects.equals(key3, key4))
{
return this.of(key1, value1, key2, value2, key3, value4);
}
return new ImmutableQuadrupletonMap<>(key1, value1, key2, value2, key3, value3, key4, value4);
}
@Override
@Deprecated
public <K, V> ImmutableMap<K, V> ofMap(Map<K, V> map)
{
return this.ofAll(map);
}
@Override
public <K, V> ImmutableMap<K, V> ofAll(Map<K, V> map)
{
return this.withAll(map);
}
@Override
public <K, V> ImmutableMap<K, V> withAll(Map<K, V> map)
{
if (map.isEmpty())
{
return this.of();
}
if (map.size() > 4)
{
return new ImmutableUnifiedMap<>(map);
}
Map.Entry<K, V>[] entries = map.entrySet().toArray(new Map.Entry[map.entrySet().size()]);
switch (entries.length)
{
case 1:
return this.of(entries[0].getKey(), entries[0].getValue());
case 2:
return this.of(
entries[0].getKey(), entries[0].getValue(),
entries[1].getKey(), entries[1].getValue());
case 3:
return this.of(
entries[0].getKey(), entries[0].getValue(),
entries[1].getKey(), entries[1].getValue(),
entries[2].getKey(), entries[2].getValue());
case 4:
return this.of(
entries[0].getKey(), entries[0].getValue(),
entries[1].getKey(), entries[1].getValue(),
entries[2].getKey(), entries[2].getValue(),
entries[3].getKey(), entries[3].getValue());
default:
throw new AssertionError();
}
}
}