cleaning up after a removed simulation by the removed() methods +
exposing methods for loading simulations from external plugins + minor bug fix: the reload progress dialog sometimes disappear even when a simulation is loading
This commit is contained in:
parent
467cf88bcd
commit
977809144f
1 changed files with 35 additions and 44 deletions
|
@ -24,7 +24,7 @@
|
||||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
* $Id: GUI.java,v 1.151 2009/11/02 13:18:27 fros4943 Exp $
|
* $Id: GUI.java,v 1.152 2009/11/13 08:49:26 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja;
|
package se.sics.cooja;
|
||||||
|
@ -1580,24 +1580,17 @@ public class GUI extends Observable {
|
||||||
* @param mote Mote
|
* @param mote Mote
|
||||||
*/
|
*/
|
||||||
public void closeMotePlugins(Mote mote) {
|
public void closeMotePlugins(Mote mote) {
|
||||||
Vector<Plugin> pluginsToRemove = new Vector<Plugin>();
|
for (Plugin p: startedPlugins.toArray(new Plugin[0])) {
|
||||||
|
int pluginType = p.getClass().getAnnotation(PluginType.class).value();
|
||||||
for (Plugin startedPlugin : startedPlugins) {
|
|
||||||
int pluginType = startedPlugin.getClass().getAnnotation(PluginType.class).value();
|
|
||||||
|
|
||||||
if (pluginType != PluginType.MOTE_PLUGIN) {
|
if (pluginType != PluginType.MOTE_PLUGIN) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
Mote pluginMote = (Mote) startedPlugin.getTag();
|
Mote pluginMote = (Mote) p.getTag();
|
||||||
if (pluginMote == mote) {
|
if (pluginMote == mote) {
|
||||||
pluginsToRemove.add(startedPlugin);
|
removePlugin(p, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Plugin pluginToRemove: pluginsToRemove) {
|
|
||||||
removePlugin(pluginToRemove, false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2032,25 +2025,38 @@ public class GUI extends Observable {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new mote type of the given mote type class.
|
* Creates a new mote type of the given mote type class.
|
||||||
|
* This may include displaying a dialog for user configurations.
|
||||||
*
|
*
|
||||||
* @param moteTypeClass
|
* If mote type is created successfully, the add motes dialog will appear.
|
||||||
* Mote type class
|
*
|
||||||
|
* @param moteTypeClass Mote type class
|
||||||
*/
|
*/
|
||||||
public void doCreateMoteType(Class<? extends MoteType> moteTypeClass) {
|
public void doCreateMoteType(Class<? extends MoteType> moteTypeClass) {
|
||||||
|
doCreateMoteType(moteTypeClass, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new mote type of the given mote type class.
|
||||||
|
* This may include displaying a dialog for user configurations.
|
||||||
|
*
|
||||||
|
* @param moteTypeClass Mote type class
|
||||||
|
* @param addMotes Show add motes dialog after successfully adding mote type
|
||||||
|
*/
|
||||||
|
public void doCreateMoteType(Class<? extends MoteType> moteTypeClass, boolean addMotes) {
|
||||||
if (mySimulation == null) {
|
if (mySimulation == null) {
|
||||||
logger.fatal("Can't create mote type (no simulation)");
|
logger.fatal("Can't create mote type (no simulation)");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Stop simulation (if running)
|
|
||||||
mySimulation.stopSimulation();
|
mySimulation.stopSimulation();
|
||||||
|
|
||||||
// Create mote type
|
// Create mote type
|
||||||
MoteType newMoteType = null;
|
MoteType newMoteType = null;
|
||||||
boolean moteTypeOK = false;
|
|
||||||
try {
|
try {
|
||||||
newMoteType = moteTypeClass.newInstance();
|
newMoteType = moteTypeClass.newInstance();
|
||||||
moteTypeOK = newMoteType.configureAndInit(GUI.getTopParentContainer(), mySimulation, isVisualized());
|
if (!newMoteType.configureAndInit(GUI.getTopParentContainer(), mySimulation, isVisualized())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mySimulation.addMoteType(newMoteType);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.fatal("Exception when creating mote type", e);
|
logger.fatal("Exception when creating mote type", e);
|
||||||
if (isVisualized()) {
|
if (isVisualized()) {
|
||||||
|
@ -2059,11 +2065,8 @@ public class GUI extends Observable {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add mote type to simulation
|
|
||||||
if (moteTypeOK) {
|
|
||||||
mySimulation.addMoteType(newMoteType);
|
|
||||||
|
|
||||||
/* Allow user to immediately add motes */
|
/* Allow user to immediately add motes */
|
||||||
|
if (addMotes) {
|
||||||
doAddMotes(newMoteType);
|
doAddMotes(newMoteType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2115,6 +2118,7 @@ public class GUI extends Observable {
|
||||||
// Delete simulation
|
// Delete simulation
|
||||||
mySimulation.deleteObservers();
|
mySimulation.deleteObservers();
|
||||||
mySimulation.stopSimulation();
|
mySimulation.stopSimulation();
|
||||||
|
mySimulation.removed();
|
||||||
|
|
||||||
/* Clear current mote relations */
|
/* Clear current mote relations */
|
||||||
MoteRelation relations[] = getMoteRelations();
|
MoteRelation relations[] = getMoteRelations();
|
||||||
|
@ -2223,18 +2227,7 @@ public class GUI extends Observable {
|
||||||
|
|
||||||
progressDialog = new RunnableInEDT<JDialog>() {
|
progressDialog = new RunnableInEDT<JDialog>() {
|
||||||
public JDialog work() {
|
public JDialog work() {
|
||||||
final JDialog progressDialog;
|
final JDialog progressDialog = new JDialog((Window) GUI.getTopParentContainer(), progressTitle, ModalityType.APPLICATION_MODAL);
|
||||||
|
|
||||||
if (GUI.getTopParentContainer() instanceof Window) {
|
|
||||||
progressDialog = new JDialog((Window) GUI.getTopParentContainer(), progressTitle, ModalityType.APPLICATION_MODAL);
|
|
||||||
} else if (GUI.getTopParentContainer() instanceof Frame) {
|
|
||||||
progressDialog = new JDialog((Frame) GUI.getTopParentContainer(), progressTitle, ModalityType.APPLICATION_MODAL);
|
|
||||||
} else if (GUI.getTopParentContainer() instanceof Dialog) {
|
|
||||||
progressDialog = new JDialog((Dialog) GUI.getTopParentContainer(), progressTitle, ModalityType.APPLICATION_MODAL);
|
|
||||||
} else {
|
|
||||||
logger.warn("No parent container");
|
|
||||||
progressDialog = new JDialog((Frame) null, progressTitle, ModalityType.APPLICATION_MODAL);
|
|
||||||
}
|
|
||||||
|
|
||||||
JPanel progressPanel = new JPanel(new BorderLayout());
|
JPanel progressPanel = new JPanel(new BorderLayout());
|
||||||
JProgressBar progressBar;
|
JProgressBar progressBar;
|
||||||
|
@ -2253,9 +2246,6 @@ public class GUI extends Observable {
|
||||||
loadThread.interrupt();
|
loadThread.interrupt();
|
||||||
doRemoveSimulation(false);
|
doRemoveSimulation(false);
|
||||||
}
|
}
|
||||||
if (progressDialog.isDisplayable()) {
|
|
||||||
progressDialog.dispose();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -2380,9 +2370,6 @@ public class GUI extends Observable {
|
||||||
loadThread.interrupt();
|
loadThread.interrupt();
|
||||||
doRemoveSimulation(false);
|
doRemoveSimulation(false);
|
||||||
}
|
}
|
||||||
if (progressDialog.isDisplayable()) {
|
|
||||||
progressDialog.dispose();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -2544,6 +2531,10 @@ public class GUI extends Observable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (getSimulation() != null) {
|
||||||
|
doRemoveSimulation(false);
|
||||||
|
}
|
||||||
|
|
||||||
// Clean up resources
|
// Clean up resources
|
||||||
Object[] plugins = startedPlugins.toArray();
|
Object[] plugins = startedPlugins.toArray();
|
||||||
for (Object plugin : plugins) {
|
for (Object plugin : plugins) {
|
||||||
|
@ -3186,7 +3177,7 @@ public class GUI extends Observable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Simulation loadSimulationConfig(StringReader stringReader, boolean quick)
|
public Simulation loadSimulationConfig(StringReader stringReader, boolean quick)
|
||||||
throws SimulationCreationException {
|
throws SimulationCreationException {
|
||||||
try {
|
try {
|
||||||
SAXBuilder builder = new SAXBuilder();
|
SAXBuilder builder = new SAXBuilder();
|
||||||
|
@ -3203,7 +3194,7 @@ public class GUI extends Observable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Simulation loadSimulationConfig(Element root, boolean quick, Long manualRandomSeed)
|
public Simulation loadSimulationConfig(Element root, boolean quick, Long manualRandomSeed)
|
||||||
throws SimulationCreationException {
|
throws SimulationCreationException {
|
||||||
Simulation newSim = null;
|
Simulation newSim = null;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue