From e77f83204539399d5d1ce3a4f67441ec0a980ce5 Mon Sep 17 00:00:00 2001 From: 7u83 <7u83@maiil.ru> Date: Thu, 20 Dec 2018 09:42:07 +0100 Subject: [PATCH] new scheduler still not working --- nbproject/project.properties | 2 +- src/opensesim/trader/SimpleTrader.java | 2 +- src/opensesim/world/scheduler/Scheduler.java | 27 ++++++++++++++------ 3 files changed, 21 insertions(+), 10 deletions(-) diff --git a/nbproject/project.properties b/nbproject/project.properties index 41a7766..3fa56a2 100644 --- a/nbproject/project.properties +++ b/nbproject/project.properties @@ -1,4 +1,4 @@ -#Wed, 19 Dec 2018 18:53:48 +0100 +#Thu, 20 Dec 2018 09:38:26 +0100 annotation.processing.enabled=true annotation.processing.enabled.in.editor=false annotation.processing.processors.list= diff --git a/src/opensesim/trader/SimpleTrader.java b/src/opensesim/trader/SimpleTrader.java index f594fab..f9e763b 100644 --- a/src/opensesim/trader/SimpleTrader.java +++ b/src/opensesim/trader/SimpleTrader.java @@ -87,7 +87,7 @@ public class SimpleTrader extends AbstractTrader implements EventListener{ @Override public long receive(Event task) { System.out.printf("Here we are !!! %f\n", getWorld().randNextFloat(12f, 27f)); - // getWorld().schedule(this, 100); + getWorld().schedule(this, 5000); return -1; } diff --git a/src/opensesim/world/scheduler/Scheduler.java b/src/opensesim/world/scheduler/Scheduler.java index dc6cfef..9969ed2 100644 --- a/src/opensesim/world/scheduler/Scheduler.java +++ b/src/opensesim/world/scheduler/Scheduler.java @@ -62,10 +62,10 @@ public class Scheduler { } } Event e = getNextEvent(); - if (e==null){ + if (e == null) { continue; } - + e.listener.receive(e); } } @@ -92,12 +92,23 @@ public class Scheduler { } } - public synchronized Event startTimerTask(EventListener listener, long time) { - // Event e = schedulers.get(next++).startTimerTask(listener, time); -// if (next == schedulers.size()) { - // next = 0; - // } - return null; + public Event startTimerTask(EventListener listener, long time) { + Event e = new Event(listener); + long t = time + clock.currentTimeMillis(); + synchronized (event_queue) { + LinkedList s = event_queue.get(t); + if (s == null) { + s = new LinkedList<>(); + event_queue.put(t, s); + } + + s.add(e); + } + synchronized (clock) { + clock.notifyAll(); + } + return e; + } protected long getDelay() {