All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.protempa.proposition.Sequence Maven / Gradle / Ivy

There is a newer version: 5.2-Alpha-2
Show newest version
/*
 * #%L
 * Protempa Framework
 * %%
 * Copyright (C) 2012 - 2013 Emory University
 * %%
 * 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.
 * #L%
 */
package org.protempa.proposition;

import org.protempa.proposition.visitor.PropositionVisitable;
import org.protempa.proposition.visitor.PropositionVisitor;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
import java.util.RandomAccess;
import java.util.Set;
import org.protempa.proposition.comparator.TemporalPropositionIntervalComparator;

/**
 * A list of Propositions sorted chronologically.
 * 
 * @author Andrew Post
 */
public final class Sequence implements List,
        RandomAccess, PropositionVisitable {

    private static final long serialVersionUID = -6908483602466100689L;
    
    private static final Comparator TEMP_PROP_COMP =
            new TemporalPropositionIntervalComparator();
    private final Set propIds;
    private final List l;
    private boolean sortNeeded;

    public Sequence(String propId) {
        this(propId, null);
    }

    public Sequence(String propId, int initialCapacity) {
        l = new ArrayList<>(initialCapacity);
        this.propIds = Collections.singleton(propId);
    }

    public Sequence(Set propIds) {
        this(propIds, null);
    }

    public Sequence(String propId, List data) {
        this(Collections.singleton(propId), data);
    }

    /**
     *
     */
    public Sequence(Set propIds, List data) {
        if (data != null) {
            l = new ArrayList<>(data);
        } else {
            l = new ArrayList<>();
        }
        this.propIds = propIds;
        if (l.size() > 1) {
            this.sortNeeded = true;
        }
    }

    public Set getPropositionIds() {
        return propIds;
    }

    @Override
    public boolean add(T o) {
        int lsize;
        if (!sortNeeded
                && (lsize = l.size()) > 0
                && TEMP_PROP_COMP.compare(l.get(lsize - 1), o) > 0) {
            sortNeeded = true;
        }
        if (o == null) {
            throw new NullPointerException();
        }
        return l.add(o);
    }

    @Override
    public boolean addAll(Collection c) {
        sortNeeded = true;
        for (T elt : c) {
            if (!add(elt)) {
                return false;
            }
        }
        return true;
    }

    @Override
    public T get(int index) {
        sortIfNeeded();
        return l.get(index);
    }

    @Override
    public int indexOf(Object elem) {
        sortIfNeeded();
        return Collections.binarySearch(l, (TemporalProposition) elem,
                TEMP_PROP_COMP);
    }

    @Override
    public String toString() {
        sortIfNeeded();
        return (propIds != null ? (propIds.toString() + "; ") : "") + this.l;
    }

    @Override
    public int size() {
        return l.size();
    }

    @Override
    public boolean isEmpty() {
        return l.isEmpty();
    }

    @Override
    public void add(int arg0, T arg1) {
        throw new UnsupportedOperationException();
    }

    @Override
    public boolean addAll(int arg0, Collection arg1) {
        throw new UnsupportedOperationException();
    }

    @Override
    public void clear() {
        l.clear();
    }

    @Override
    public boolean contains(Object arg0) {
        return indexOf(arg0) >= 0;
    }

    @Override
    public boolean containsAll(Collection arg0) {
        for (Iterator itr = arg0.iterator(); itr.hasNext();) {
            if (!contains(itr.next())) {
                return false;
            }
        }
        return true;
    }

    @Override
    public Iterator iterator() {
        sortIfNeeded();
        return l.iterator();
    }

    @Override
    public int lastIndexOf(Object elem) {
        return indexOf(elem);
    }

    @Override
    public ListIterator listIterator() {
        sortIfNeeded();
        return l.listIterator();
    }

    @Override
    public ListIterator listIterator(int arg0) {
        sortIfNeeded();
        return l.listIterator(arg0);
    }

    @Override
    public boolean remove(Object arg0) {
        int i = indexOf(arg0);
        if (i >= 0) {
            return remove(i) != null;
        } else {
            return false;
        }
    }

    @Override
    public T remove(int arg0) {
        sortIfNeeded();
        return l.remove(arg0);
    }

    @Override
    public boolean removeAll(Collection c) {
        boolean modified = false;
        for (Iterator itr = iterator(); itr.hasNext();) {
            if (c.contains(itr.next())) {
                itr.remove();
                modified = true;
            }
        }
        return modified;
    }

    @Override
    public boolean retainAll(Collection c) {
        boolean modified = false;
        for (Iterator itr = iterator(); itr.hasNext();) {
            if (!c.contains(itr.next())) {
                itr.remove();
                modified = true;
            }
        }
        return modified;
    }

    @Override
    public T set(int arg0, T arg1) {
        throw new UnsupportedOperationException();
    }

    @Override
    public List subList(int arg0, int arg1) {
        sortIfNeeded();
        return l.subList(arg0, arg1);
    }

    @Override
    public Object[] toArray() {
        sortIfNeeded();
        return l.toArray();
    }

    @Override
    public  E[] toArray(E[] arg0) {
        sortIfNeeded();
        return l.toArray(arg0);
    }

    private void sortIfNeeded() {
        if (sortNeeded) {
            if (l.size() > 1) {
                Collections.sort(l, TEMP_PROP_COMP);
            }
            sortNeeded = false;
        }
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (!(obj instanceof Sequence)) {
            return false;
        }
        Sequence other = (Sequence) obj;
        return this.l.equals(other.l)
                && (this.propIds == other.propIds || (this.propIds != null && this.propIds.equals(other.propIds)));
    }

    @Override
    public int hashCode() {
        int result = this.l.hashCode();
        if (this.propIds != null) {
            result = 37 * result + this.propIds.hashCode();
        }
        return result;
    }

    @Override
    public void accept(PropositionVisitor propositionVisitor) {
        for (Proposition prop : this) {
            prop.accept(propositionVisitor);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy