org.dihedron.patterns.functional.FunctionalList Maven / Gradle / Ivy
/**
* Copyright (c) 2012-2014, Andrea Funto'. All rights reserved.
*
* This file is part of the Dihedron Common Utilities library ("Commons").
*
* "Commons" is free software: you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation, either version 3 of the License, or (at your option)
* any later version.
*
* "Commons" is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
* A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with "Commons". If not, see .
*/
package org.dihedron.patterns.functional;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
/**
* A list proving a way to iterate over its elements in a pseudo-functinal way.
*
* @author Andrea Funto'
*/
public class FunctionalList extends Functional implements List {
/**
* The wrapped list.
*/
private final List list;
/**
* Constructor.
*
* @param list
* the wrapped list.
*/
public FunctionalList(List list) {
this.list = list;
}
/**
* @see java.util.List#size()
*/
@Override
public int size() {
return list.size();
}
/**
* @see java.util.List#isEmpty()
*/
@Override
public boolean isEmpty() {
return list.isEmpty();
}
/**
* @see java.util.List#contains(java.lang.Object)
*/
@Override
public boolean contains(Object o) {
return list.contains(o);
}
/**
* @see java.util.List#iterator()
*/
@Override
public Iterator iterator() {
return list.iterator();
}
/**
* @see java.util.List#toArray()
*/
@Override
public Object[] toArray() {
return list.toArray();
}
/**
* @see java.util.List#toArray(java.lang.Object[])
*/
@Override
public T[] toArray(T[] a) {
return list.toArray(a);
}
/**
* @see java.util.List#add(java.lang.Object)
*/
@Override
public boolean add(E e) {
return list.add(e);
}
/**
* @see java.util.List#remove(java.lang.Object)
*/
@Override
public boolean remove(Object o) {
return list.remove(o);
}
/**
* @see java.util.List#containsAll(java.util.Collection)
*/
@Override
public boolean containsAll(Collection> c) {
return list.containsAll(c);
}
/**
* @see java.util.List#addAll(java.util.Collection)
*/
@Override
public boolean addAll(Collection extends E> c) {
return list.addAll(c);
}
/**
* @see java.util.List#addAll(int, java.util.Collection)
*/
@Override
public boolean addAll(int index, Collection extends E> c) {
return list.addAll(index, c);
}
/**
* @see java.util.List#removeAll(java.util.Collection)
*/
@Override
public boolean removeAll(Collection> c) {
return list.removeAll(c);
}
/**
* @see java.util.List#retainAll(java.util.Collection)
*/
@Override
public boolean retainAll(Collection> c) {
return list.retainAll(c);
}
/**
* @see java.util.List#clear()
*/
@Override
public void clear() {
list.clear();
}
/**
* @see java.util.List#get(int)
*/
@Override
public E get(int index) {
return list.get(index);
}
/**
* @see java.util.List#set(int, java.lang.Object)
*/
@Override
public E set(int index, E element) {
return list.set(index, element);
}
/**
* @see java.util.List#add(int, java.lang.Object)
*/
@Override
public void add(int index, E element) {
list.add(index, element);
}
/**
* @see java.util.List#remove(int)
*/
@Override
public E remove(int index) {
return list.remove(index);
}
/**
* @see java.util.List#indexOf(java.lang.Object)
*/
@Override
public int indexOf(Object o) {
return list.indexOf(o);
}
/**
* @see java.util.List#lastIndexOf(java.lang.Object)
*/
@Override
public int lastIndexOf(Object o) {
return list.lastIndexOf(o);
}
/**
* @see java.util.List#listIterator()
*/
@Override
public ListIterator listIterator() {
return list.listIterator();
}
/**
* @see java.util.List#listIterator(int)
*/
@Override
public ListIterator listIterator(int index) {
return list.listIterator(index);
}
/**
* @see java.util.List#subList(int, int)
*/
@Override
public List subList(int fromIndex, int toIndex) {
return list.subList(fromIndex, toIndex);
}
/**
* @see org.dihedron.patterns.functional.Functional#forEach(java.lang.Object, org.dihedron.patterns.functional.Fx)
*/
@Override
@SuppressWarnings("unchecked")
public S forEach(S state, Fx functor) {
S newState = state;
for(E element : list) {
newState = functor.apply(newState, (LE)element);
}
return newState;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy