package pre13; import java.util.Vector; /** * A queue of layout tasks. * * @author Timothy Prinzing * @version 1.2 07/16/99 */ public class LayoutQueue { Vector tasks; Thread worker; static LayoutQueue defaultQueue; public LayoutQueue() { tasks = new Vector(); } public static LayoutQueue getDefaultQueue() { if (defaultQueue == null) { defaultQueue = new LayoutQueue(); } return defaultQueue; } /** * Set the default layout queue. */ public static void setDefaultQueue(LayoutQueue q) { defaultQueue = q; } /** * Add a task that is not needed immediately because * the results are not believed to be visible. */ public synchronized void addTask(Runnable task) { if (worker == null) { worker = new LayoutThread(); worker.start(); } tasks.addElement(task); notifyAll(); } /** * Used by the worker thread to get a new task to execute */ protected synchronized Runnable waitForWork() { while (tasks.size() == 0) { try { wait(); } catch (InterruptedException ie) { return null; } } Runnable work = (Runnable) tasks.firstElement(); tasks.removeElementAt(0); return work; } /** * low priority thread to perform layout work forever */ class LayoutThread extends Thread { LayoutThread() { super("text-layout"); setPriority(Thread.MIN_PRIORITY); } public void run() { Runnable work; do { work = waitForWork(); if (work != null) { work.run(); } } while (work != null); } } }