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

org.btrplace.scheduler.runner.disjoint.model.ElementSubSet Maven / Gradle / Ivy

/*
 * Copyright (c) 2017 University Nice Sophia Antipolis
 *
 * This file is part of btrplace.
 * This library 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.
 *
 * This library 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 this program.  If not, see .
 */

package org.btrplace.scheduler.runner.disjoint.model;

import org.btrplace.model.Element;

import java.util.*;

/**
 * A set of elements in a {@link SplittableElementSet}
 * that are in the same partition.
 * 

* This set is considered as immutable. * * @author Fabien Hermenier */ public class ElementSubSet implements Set { private int from; private int to; private int curIdx; private SplittableElementSet index; /** * Make a new subset. * * @param parent the splittable parent set * @param key the current partition identifier * @param lb the lower bound in the backend array where elements start to have the given key * @param ub the upper bound in the backend array where elements ends to have the given key (exclusive) */ public ElementSubSet(SplittableElementSet parent, int key, int lb, int ub) { this.index = parent; this.curIdx = key; this.from = lb; this.to = ub; } @Override public int size() { return to - from; } @Override public boolean isEmpty() { return to == from; } @Override @SuppressWarnings("squid:S1166") //ClassClassException public boolean contains(Object o) { try { Element x = (Element) o; return index.getRespectiveIndex().get(x.id()) == curIdx; } catch (ClassCastException ex) { return false; } } @Override public Iterator iterator() { return new IndexEntryIterator<>(index.getValues(), from, to); } @Override public Object[] toArray() { throw new UnsupportedOperationException(); } @Override public Object[] toArray(Object[] a) { throw new UnsupportedOperationException(); } @Override public boolean add(E o) { throw new UnsupportedOperationException(); } @Override public boolean remove(Object o) { throw new UnsupportedOperationException(); } @Override public boolean containsAll(Collection c) { for (Object o : c) { if (!contains(o)) { return false; } } return true; } @Override public boolean addAll(Collection c) { throw new UnsupportedOperationException(); } @Override public boolean retainAll(Collection c) { throw new UnsupportedOperationException(); } @Override public boolean removeAll(Collection c) { throw new UnsupportedOperationException(); } @Override public void clear() { throw new UnsupportedOperationException(); } @Override public String toString() { StringBuilder b = new StringBuilder("{").append(index.getValues().get(from)); for (int i = from + 1; i < to; i++) { b.append(", ").append(index.getValues().get(i)); } return b.append('}').toString(); } /** * The iterator associated to an {@link ElementSubSet}. * * @author Fabien Hermenier */ public static class IndexEntryIterator implements Iterator { private List values; private int to; private int cursor; /** * Make a new iterator. * * @param v the values to iterate on * @param lb the initial index. * @param ub the last index (exclusive) */ public IndexEntryIterator(List v, int lb, int ub) { this.values = v; this.to = ub; this.cursor = lb; } @Override public boolean hasNext() { return cursor != to; } @Override public E next() { if (cursor == to) { throw new NoSuchElementException(); } return values.get(cursor++); } @Override public void remove() { throw new UnsupportedOperationException(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy