com.github.tonivade.purefun.data.ImmutableArray Maven / Gradle / Ivy
/*
* Copyright (c) 2018-2021, Antonio Gabriel Muñoz Conejo
* Distributed under the terms of the MIT License
*/
package com.github.tonivade.purefun.data;
import static java.util.Collections.unmodifiableList;
import static java.util.stream.Collectors.collectingAndThen;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collector;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import com.github.tonivade.purefun.Equal;
import com.github.tonivade.purefun.Function1;
import com.github.tonivade.purefun.Kind;
import com.github.tonivade.purefun.Matcher1;
public interface ImmutableArray extends Sequence {
List toList();
@Override
ImmutableArray append(E element);
@Override
ImmutableArray remove(E element);
@Override
ImmutableArray appendAll(Sequence extends E> other);
@Override
ImmutableArray removeAll(Sequence extends E> other);
@Override
ImmutableArray reverse();
ImmutableArray sort(Comparator super E> comparator);
E get(int position);
ImmutableArray remove(int position);
ImmutableArray replace(int position, E element);
ImmutableArray insert(int position, E element);
ImmutableArray insertAll(int position, Sequence extends E> elements);
default ImmutableArray drop(int n) {
return ImmutableArray.from(stream().skip(n));
}
@Override
default ImmutableArray map(Function1 super E, ? extends R> mapper) {
return ImmutableArray.from(stream().map(mapper::apply));
}
@Override
default ImmutableArray flatMap(Function1 super E, ? extends Kind> mapper) {
return ImmutableArray.from(stream().flatMap(mapper.andThen(SequenceOf::narrowK).andThen(Sequence::stream)::apply));
}
@Override
default ImmutableArray filter(Matcher1 super E> matcher) {
return ImmutableArray.from(stream().filter(matcher::match));
}
@Override
default ImmutableArray filterNot(Matcher1 super E> matcher) {
return filter(matcher.negate());
}
static ImmutableArray from(Iterable extends T> iterable) {
return from(Sequence.asStream(iterable.iterator()));
}
static ImmutableArray from(Stream extends T> stream) {
return new JavaBasedImmutableArray<>(stream.collect(Collectors.toCollection(ArrayList::new)));
}
@SafeVarargs
static ImmutableArray of(T... elements) {
return from(Arrays.stream(elements));
}
@SuppressWarnings("unchecked")
static ImmutableArray empty() {
return (ImmutableArray) JavaBasedImmutableArray.EMPTY;
}
static Collector> toImmutableArray() {
return collectingAndThen(Collectors.toCollection(ArrayList::new), JavaBasedImmutableArray::new);
}
final class JavaBasedImmutableArray implements ImmutableArray, Serializable {
private static final long serialVersionUID = 5728385935547829871L;
private static final ImmutableArray> EMPTY = new JavaBasedImmutableArray<>(new ArrayList<>());
private static final Equal> EQUAL =
Equal.>of().comparing(a -> a.backend);
private final List backend;
private JavaBasedImmutableArray(ArrayList backend) {
this.backend = unmodifiableList(backend);
}
@Override
public int size() {
return backend.size();
}
@Override
public boolean contains(E element) {
return backend.contains(element);
}
@Override
public ImmutableArray reverse() {
ArrayList list = copy();
Collections.reverse(list);
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray sort(Comparator super E> comparator) {
ArrayList list = copy();
list.sort(comparator);
return new JavaBasedImmutableArray<>(list);
}
@Override
public Iterator iterator() {
return backend.iterator();
}
@Override
public ImmutableArray append(E element) {
ArrayList list = copy();
list.add(element);
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray remove(E element) {
ArrayList list = copy();
list.remove(element);
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray appendAll(Sequence extends E> other) {
ArrayList list = copy();
list.addAll(other.toCollection());
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray removeAll(Sequence extends E> other) {
ArrayList list = copy();
list.removeAll(other.toCollection());
return new JavaBasedImmutableArray<>(list);
}
@Override
public E get(int position) {
return backend.get(position);
}
@Override
public ImmutableArray replace(int position, E element) {
ArrayList list = copy();
list.set(position, element);
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray remove(int position) {
ArrayList list = copy();
list.remove(position);
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray insert(int position, E element) {
ArrayList list = copy();
list.add(position, element);
return new JavaBasedImmutableArray<>(list);
}
@Override
public ImmutableArray insertAll(int position, Sequence extends E> elements) {
ArrayList list = copy();
list.addAll(position, elements.toCollection());
return new JavaBasedImmutableArray<>(list);
}
@Override
public List toList() {
return copy();
}
@Override
public int hashCode() {
return Objects.hash(backend);
}
@Override
public boolean equals(Object obj) {
return EQUAL.applyTo(this, obj);
}
@Override
public String toString() {
return "ImmutableArray(" + backend + ")";
}
private ArrayList copy() {
return new ArrayList<>(backend);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy