/* * This file is part of the Jikes RVM project (http://jikesrvm.org). * * This file is licensed to You under the Common Public License (CPL); * You may not use this file except in compliance with the License. You * may obtain a copy of the License at * * http://www.opensource.org/licenses/cpl1.0.php * * See the COPYRIGHT.txt file distributed with this work for information * regarding copyright ownership. */ package org.jikesrvm.compilers.opt; import java.util.Iterator; import org.jikesrvm.util.VM_LinkedList; final class OPT_Queue<T> implements Iterable<T> { private final VM_LinkedList<T> elements = new VM_LinkedList<T>(); OPT_Queue() { } OPT_Queue(T e) { elements.add(e); } T insert(T e) { elements.add(e); // Insert at tail return e; } T remove() { return elements.remove(0); // Remove from head } boolean isEmpty() { return elements.isEmpty(); } public Iterator<T> iterator() { return elements.iterator(); } }