projects
/
Mograsim.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
PauseableTimeFunction now supports non-integral speed factors
[Mograsim.git]
/
plugins
/
net.mograsim.logic.model
/
src
/
net
/
mograsim
/
logic
/
model
/
LogicExecuter.java
diff --git
a/plugins/net.mograsim.logic.model/src/net/mograsim/logic/model/LogicExecuter.java
b/plugins/net.mograsim.logic.model/src/net/mograsim/logic/model/LogicExecuter.java
index
eb67f8d
..
77a0935
100644
(file)
--- a/
plugins/net.mograsim.logic.model/src/net/mograsim/logic/model/LogicExecuter.java
+++ b/
plugins/net.mograsim.logic.model/src/net/mograsim/logic/model/LogicExecuter.java
@@
-43,15
+43,16
@@
public class LogicExecuter
{
// always execute to keep timeline from "hanging behind" for too long
long current = tf.getAsLong();
{
// always execute to keep timeline from "hanging behind" for too long
long current = tf.getAsLong();
- timeline.executeUntil(timeline.laterThan(current), current + 10);
+ timeline.executeUntil(timeline.laterThan(current), System.currentTimeMillis() + 10);
+ long nextEventTime = timeline.nextEventTime();
long sleepTime;
if (timeline.hasNext())
long sleepTime;
if (timeline.hasNext())
- sleepTime = t
imeline.nextEventTime() - current
;
+ sleepTime = t
f.simulTimeDeltaToRealTimeMillis(nextEventTime - current)
;
else
sleepTime = 10000;
try
{
else
sleepTime = 10000;
try
{
- nextExecSimulTime.set(
current + sleep
Time);
+ nextExecSimulTime.set(
nextEvent
Time);
if (sleepTime > 0)
Thread.sleep(sleepTime);
if (sleepTime > 0)
Thread.sleep(sleepTime);
@@
-130,9
+131,9
@@
public class LogicExecuter
return isPaused.get();
}
return isPaused.get();
}
- public void setSpeed
Percentage(int percentage
)
+ public void setSpeed
Factor(double factor
)
{
{
- tf.setSpeed
Percentage(percentage
);
+ tf.setSpeed
Factor(factor
);
}
private void waitForIsRunning(boolean expectedState)
}
private void waitForIsRunning(boolean expectedState)