private static Scheduler singleton;
public static interface Task { public abstract void perform() throws IOException, JSExn; }
- public static void add(Task t) { Scheduler.runnable.append(t); }
+ public static void add(Task t) { Log.debug(Scheduler.class, "scheduling " + t); Scheduler.runnable.append(t); }
public static void init() { if (singleton == null) (singleton = Platform.getScheduler()).run(); }
private static Task current = null;
protected static Queue runnable = new Queue(50);
public void defaultRun() {
while(true) {
- System.out.println("enter");
current = (Task)runnable.remove(true);
try {
// FIXME hideous
s._mousey = s.mousey;
}
}
+ Log.debug(Scheduler.class, "performing " + current);
current.perform();
}
renderAll();
} catch (JSExn e) {
Log.info(Scheduler.class, "a JavaScript thread spawned with ibex.thread() threw an exception:");
- Log.info(Scheduler.class, "JS Exception: " + e.getObject() + "\n" + e.backtrace());
Log.info(Scheduler.class,e);
} catch (Exception e) {
Log.info(Scheduler.class, "a Task threw an exception which was caught by the scheduler:");
t.printStackTrace();
}
// if an Error is thrown it will cause the engine to quit
- System.out.println("leave");
}
}
}