minor fix for non-GUI simulations: stop simulation and clean-up before shutting down COOJA
This commit is contained in:
parent
ca6c8818b1
commit
1dba4d40ca
2 changed files with 29 additions and 11 deletions
|
@ -26,18 +26,28 @@
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* $Id: LogScriptEngine.java,v 1.18 2009/09/17 13:20:48 fros4943 Exp $
|
* $Id: LogScriptEngine.java,v 1.19 2009/10/23 11:55:53 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.plugins;
|
package se.sics.cooja.plugins;
|
||||||
|
|
||||||
import java.lang.reflect.UndeclaredThrowableException;
|
import java.lang.reflect.UndeclaredThrowableException;
|
||||||
import java.util.*;
|
import java.util.Hashtable;
|
||||||
|
import java.util.Observable;
|
||||||
|
import java.util.Observer;
|
||||||
import java.util.concurrent.Semaphore;
|
import java.util.concurrent.Semaphore;
|
||||||
import javax.script.*;
|
|
||||||
|
import javax.script.Invocable;
|
||||||
|
import javax.script.ScriptEngine;
|
||||||
|
import javax.script.ScriptEngineManager;
|
||||||
|
import javax.script.ScriptException;
|
||||||
|
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
import se.sics.cooja.*;
|
|
||||||
|
import se.sics.cooja.GUI;
|
||||||
|
import se.sics.cooja.Mote;
|
||||||
|
import se.sics.cooja.Simulation;
|
||||||
|
import se.sics.cooja.TimeEvent;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Loads and executes a Contiki test script.
|
* Loads and executes a Contiki test script.
|
||||||
|
@ -442,7 +452,20 @@ public class LogScriptEngine {
|
||||||
};
|
};
|
||||||
private TimeEvent quitEvent = new TimeEvent(0) {
|
private TimeEvent quitEvent = new TimeEvent(0) {
|
||||||
public void execute(long time) {
|
public void execute(long time) {
|
||||||
|
simulation.stopSimulation();
|
||||||
|
new Thread() {
|
||||||
|
public void run() {
|
||||||
|
try { Thread.sleep(500); } catch (InterruptedException e) { }
|
||||||
simulation.getGUI().doQuit(false);
|
simulation.getGUI().doQuit(false);
|
||||||
|
};
|
||||||
|
}.start();
|
||||||
|
new Thread() {
|
||||||
|
public void run() {
|
||||||
|
try { Thread.sleep(2000); } catch (InterruptedException e) { }
|
||||||
|
logger.warn("Killing COOJA");
|
||||||
|
System.exit(1);
|
||||||
|
};
|
||||||
|
}.start();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* $Id: ScriptRunner.java,v 1.22 2009/06/24 14:08:14 fros4943 Exp $
|
* $Id: ScriptRunner.java,v 1.23 2009/10/23 11:55:53 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.plugins;
|
package se.sics.cooja.plugins;
|
||||||
|
@ -349,11 +349,6 @@ public class ScriptRunner extends VisPlugin {
|
||||||
scriptTextArea.setEnabled(true);
|
scriptTextArea.setEnabled(true);
|
||||||
logger.info("Test script deactivated");
|
logger.info("Test script deactivated");
|
||||||
setTitle("Contiki Test Editor");
|
setTitle("Contiki Test Editor");
|
||||||
|
|
||||||
/* Automatically exit COOJA */
|
|
||||||
if (!GUI.isVisualized()) {
|
|
||||||
System.exit(1);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue