set specified external tools configs read only

+ automatic formatting
This commit is contained in:
fros4943 2007-08-22 11:23:50 +00:00
parent 3bb9fda749
commit b67baa7dfc

View file

@ -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.55 2007/05/30 10:51:14 fros4943 Exp $ * $Id: GUI.java,v 1.56 2007/08/22 11:23:50 fros4943 Exp $
*/ */
package se.sics.cooja; package se.sics.cooja;
@ -84,6 +84,7 @@ public class GUI {
public static final String EXTERNAL_TOOLS_USER_SETTINGS_FILENAME = ".cooja.user.properties"; public static final String EXTERNAL_TOOLS_USER_SETTINGS_FILENAME = ".cooja.user.properties";
private static File externalToolsUserSettingsFile = private static File externalToolsUserSettingsFile =
new File(System.getProperty("user.home"), EXTERNAL_TOOLS_USER_SETTINGS_FILENAME); new File(System.getProperty("user.home"), EXTERNAL_TOOLS_USER_SETTINGS_FILENAME);
private static boolean externalToolsUserSettingsFileReadOnly = false;
private static String specifiedContikiPath = null; private static String specifiedContikiPath = null;
@ -107,11 +108,13 @@ public class GUI {
*/ */
public static final FileFilter SAVED_SIMULATIONS_FILES = new FileFilter() { public static final FileFilter SAVED_SIMULATIONS_FILES = new FileFilter() {
public boolean accept(File file) { public boolean accept(File file) {
if (file.isDirectory()) if (file.isDirectory()) {
return true; return true;
}
if (file.getName().endsWith(".csc")) if (file.getName().endsWith(".csc")) {
return true; return true;
}
return false; return false;
} }
@ -208,10 +211,12 @@ public class GUI {
myGUI = this; myGUI = this;
mySimulation = null; mySimulation = null;
myDesktopPane = desktop; myDesktopPane = desktop;
if (menuPlugins == null) if (menuPlugins == null) {
menuPlugins = new JMenu("Plugins"); menuPlugins = new JMenu("Plugins");
if (menuMotePluginClasses == null) }
if (menuMotePluginClasses == null) {
menuMotePluginClasses = new Vector<Class<? extends Plugin>>(); menuMotePluginClasses = new Vector<Class<? extends Plugin>>();
}
// Load default and overwrite with user settings (if any) // Load default and overwrite with user settings (if any)
loadExternalToolsDefaultSettings(); loadExternalToolsDefaultSettings();
@ -328,11 +333,12 @@ public class GUI {
String newHistoryConfig = null; String newHistoryConfig = null;
for (String path: newHistory) { for (String path: newHistory) {
if (newHistoryConfig == null) if (newHistoryConfig == null) {
newHistoryConfig = path; newHistoryConfig = path;
else } else {
newHistoryConfig += ";" + path; newHistoryConfig += ";" + path;
} }
}
setExternalToolsSetting("SIMCFG_HISTORY", newHistoryConfig); setExternalToolsSetting("SIMCFG_HISTORY", newHistoryConfig);
saveExternalToolsUserSettings(); saveExternalToolsUserSettings();
@ -553,10 +559,11 @@ public class GUI {
menu.add(menuItem); menu.add(menuItem);
// Plugins menu // Plugins menu
if (menuPlugins == null) if (menuPlugins == null) {
menuPlugins = new JMenu("Plugins"); menuPlugins = new JMenu("Plugins");
else } else {
menuPlugins.setText("Plugins"); menuPlugins.setText("Plugins");
}
menuPlugins.setMnemonic(KeyEvent.VK_P); menuPlugins.setMnemonic(KeyEvent.VK_P);
menuBar.add(menuPlugins); menuBar.add(menuPlugins);
@ -583,8 +590,9 @@ public class GUI {
menu.add(menuItem); menu.add(menuItem);
// Mote plugins popup menu (not available via menu bar) // Mote plugins popup menu (not available via menu bar)
if (menuMotePluginClasses == null) if (menuMotePluginClasses == null) {
menuMotePluginClasses = new Vector<Class<? extends Plugin>>(); menuMotePluginClasses = new Vector<Class<? extends Plugin>>();
}
return menuBar; return menuBar;
} }
@ -598,8 +606,9 @@ public class GUI {
// Create and set up the window. // Create and set up the window.
frame = new JFrame("COOJA Simulator"); frame = new JFrame("COOJA Simulator");
if (maxSize != null) if (maxSize != null) {
frame.setMaximizedBounds(maxSize); frame.setMaximizedBounds(maxSize);
}
frame.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE); frame.setDefaultCloseOperation(JFrame.DO_NOTHING_ON_CLOSE);
// Add menu bar // Add menu bar
@ -712,8 +721,9 @@ public class GUI {
frame.setLocationRelativeTo(null); frame.setLocationRelativeTo(null);
// Set manual Contiki path if specified // Set manual Contiki path if specified
if (contikiPath != null) if (contikiPath != null) {
setExternalToolsSetting("PATH_CONTIKI", contikiPath); setExternalToolsSetting("PATH_CONTIKI", contikiPath);
}
// Parse project directories and create config // Parse project directories and create config
if (projectDirs == null) { if (projectDirs == null) {
@ -747,8 +757,9 @@ public class GUI {
// Check file permissions and paths // Check file permissions and paths
logger.info("> Checking paths and file permissions"); logger.info("> Checking paths and file permissions");
if (moteTypeID == null) if (moteTypeID == null) {
moteTypeID = "mtype1"; moteTypeID = "mtype1";
}
File contikiBaseDir = new File(getExternalToolsSetting("PATH_CONTIKI")); File contikiBaseDir = new File(getExternalToolsSetting("PATH_CONTIKI"));
File contikiCoreDir = new File(contikiBaseDir, File contikiCoreDir = new File(contikiBaseDir,
getExternalToolsSetting("PATH_COOJA_CORE_RELATIVE")); getExternalToolsSetting("PATH_COOJA_CORE_RELATIVE"));
@ -758,12 +769,15 @@ public class GUI {
+ ContikiMoteType.mapSuffix); + ContikiMoteType.mapSuffix);
File depFile = new File(ContikiMoteType.tempOutputDirectory, moteTypeID File depFile = new File(ContikiMoteType.tempOutputDirectory, moteTypeID
+ ContikiMoteType.dependSuffix); + ContikiMoteType.dependSuffix);
if (libFile.exists()) if (libFile.exists()) {
libFile.delete(); libFile.delete();
if (depFile.exists()) }
if (depFile.exists()) {
depFile.delete(); depFile.delete();
if (mapFile.exists()) }
if (mapFile.exists()) {
mapFile.delete(); mapFile.delete();
}
if (libFile.exists()) { if (libFile.exists()) {
logger.fatal(">> Can't delete output file, aborting: " + libFile); logger.fatal(">> Can't delete output file, aborting: " + libFile);
return false; return false;
@ -804,9 +818,10 @@ public class GUI {
logger.info("> Setting up compilation arguments"); logger.info("> Setting up compilation arguments");
Vector<File> filesToCompile = new Vector<File>(); Vector<File> filesToCompile = new Vector<File>();
filesToCompile.add(mainProcessFile); // main process file filesToCompile.add(mainProcessFile); // main process file
for (String projectDir : projectDirs) for (String projectDir : projectDirs) {
// project directories // project directories
filesToCompile.add(new File(projectDir)); filesToCompile.add(new File(projectDir));
}
String[] projectSources = // project config sources String[] projectSources = // project config sources
gui.getProjectConfig().getStringArrayValue(ContikiMoteType.class, gui.getProjectConfig().getStringArrayValue(ContikiMoteType.class,
"C_SOURCES"); "C_SOURCES");
@ -833,10 +848,11 @@ public class GUI {
sensors = new Vector<String>(); sensors = new Vector<String>();
Vector<String[]> scannedSensorInfo = ContikiMoteTypeDialog Vector<String[]> scannedSensorInfo = ContikiMoteTypeDialog
.scanForSensors(contikiCoreDir); .scanForSensors(contikiCoreDir);
for (String projectDir : projectDirs) for (String projectDir : projectDirs) {
// project directories // project directories
scannedSensorInfo.addAll(ContikiMoteTypeDialog.scanForSensors(new File( scannedSensorInfo.addAll(ContikiMoteTypeDialog.scanForSensors(new File(
projectDir))); projectDir)));
}
for (String[] sensorInfo : scannedSensorInfo) { for (String[] sensorInfo : scannedSensorInfo) {
// logger.info(">> Found and added: " + sensorInfo[1] + " (" + // logger.info(">> Found and added: " + sensorInfo[1] + " (" +
@ -851,10 +867,11 @@ public class GUI {
coreInterfaces = new Vector<String>(); coreInterfaces = new Vector<String>();
Vector<String[]> scannedCoreInterfaceInfo = ContikiMoteTypeDialog Vector<String[]> scannedCoreInterfaceInfo = ContikiMoteTypeDialog
.scanForInterfaces(contikiCoreDir); .scanForInterfaces(contikiCoreDir);
for (String projectDir : projectDirs) for (String projectDir : projectDirs) {
// project directories // project directories
scannedCoreInterfaceInfo.addAll(ContikiMoteTypeDialog scannedCoreInterfaceInfo.addAll(ContikiMoteTypeDialog
.scanForInterfaces(new File(projectDir))); .scanForInterfaces(new File(projectDir)));
}
for (String[] coreInterfaceInfo : scannedCoreInterfaceInfo) { for (String[] coreInterfaceInfo : scannedCoreInterfaceInfo) {
// logger.info(">> Found and added: " + coreInterfaceInfo[1] + " (" + // logger.info(">> Found and added: " + coreInterfaceInfo[1] + " (" +
@ -888,10 +905,11 @@ public class GUI {
Vector<String> autostartProcesses = new Vector<String>(); Vector<String> autostartProcesses = new Vector<String>();
Vector<String[]> scannedProcessInfo = ContikiMoteTypeDialog Vector<String[]> scannedProcessInfo = ContikiMoteTypeDialog
.scanForProcesses(contikiCoreDir); .scanForProcesses(contikiCoreDir);
for (String projectDir : projectDirs) for (String projectDir : projectDirs) {
// project directories // project directories
scannedProcessInfo.addAll(ContikiMoteTypeDialog scannedProcessInfo.addAll(ContikiMoteTypeDialog
.scanForProcesses(new File(projectDir))); .scanForProcesses(new File(projectDir)));
}
for (String[] processInfo : scannedProcessInfo) { for (String[] processInfo : scannedProcessInfo) {
if (processInfo[0].equals(mainProcessFile.getName())) { if (processInfo[0].equals(mainProcessFile.getName())) {
@ -906,8 +924,9 @@ public class GUI {
// processes"); // processes");
Vector<String> autostarters = ContikiMoteTypeDialog Vector<String> autostarters = ContikiMoteTypeDialog
.parseAutostartProcesses(mainProcessFile); .parseAutostartProcesses(mainProcessFile);
if (autostarters != null) if (autostarters != null) {
autostartProcesses.addAll(autostarters); autostartProcesses.addAll(autostarters);
}
} catch (Exception e) { } catch (Exception e) {
logger logger
.fatal(">>> Error when parsing autostart processes, aborting: " .fatal(">>> Error when parsing autostart processes, aborting: "
@ -944,8 +963,9 @@ public class GUI {
// Generate Contiki main source file // Generate Contiki main source file
logger.info("> Generating Contiki main source file"); logger.info("> Generating Contiki main source file");
if (!ContikiMoteType.tempOutputDirectory.exists()) if (!ContikiMoteType.tempOutputDirectory.exists()) {
ContikiMoteType.tempOutputDirectory.mkdir(); ContikiMoteType.tempOutputDirectory.mkdir();
}
if (!ContikiMoteType.tempOutputDirectory.exists()) { if (!ContikiMoteType.tempOutputDirectory.exists()) {
logger.fatal(">> Could not create output directory: " logger.fatal(">> Could not create output directory: "
+ ContikiMoteType.tempOutputDirectory); + ContikiMoteType.tempOutputDirectory);
@ -969,8 +989,9 @@ public class GUI {
moteTypeID, contikiBaseDir, filesToCompile, false, moteTypeID, contikiBaseDir, filesToCompile, false,
ContikiMoteType.CommunicationStack.UIP, ContikiMoteType.CommunicationStack.UIP,
null, System.err); null, System.err);
if (!libFile.exists() || !depFile.exists() || !mapFile.exists()) if (!libFile.exists() || !depFile.exists() || !mapFile.exists()) {
compilationSucceded = false; compilationSucceded = false;
}
if (compilationSucceded) { if (compilationSucceded) {
// logger.info(">> Compilation complete"); // logger.info(">> Compilation complete");
@ -1032,14 +1053,16 @@ public class GUI {
ContikiMote mote = (ContikiMote) moteType.generateMote(simulation); ContikiMote mote = (ContikiMote) moteType.generateMote(simulation);
// Set random position // Set random position
if (mote.getInterfaces().getPosition() != null) if (mote.getInterfaces().getPosition() != null) {
mote.getInterfaces().getPosition().setCoordinates( mote.getInterfaces().getPosition().setCoordinates(
random.nextDouble() * areaSideLength, random.nextDouble() * areaSideLength,
random.nextDouble() * areaSideLength, 0); random.nextDouble() * areaSideLength, 0);
}
// Set unique mote ID's // Set unique mote ID's
if (mote.getInterfaces().getMoteID() != null) if (mote.getInterfaces().getMoteID() != null) {
mote.getInterfaces().getMoteID().setMoteID(nextMoteID++); mote.getInterfaces().getMoteID().setMoteID(nextMoteID++);
}
// Set unique IP address // Set unique IP address
if (mote.getInterfaces().getIPAddress() != null) { if (mote.getInterfaces().getIPAddress() != null) {
@ -1314,11 +1337,12 @@ public class GUI {
if (registerTemporaryPlugin(pluginClass)) { if (registerTemporaryPlugin(pluginClass)) {
// logger.info("Reregistered temporary plugin class: " + // logger.info("Reregistered temporary plugin class: " +
// getDescriptionOf(pluginClass)); // getDescriptionOf(pluginClass));
} else } else {
logger.warn("Could not reregister temporary plugin class: " logger.warn("Could not reregister temporary plugin class: "
+ getDescriptionOf(pluginClass)); + getDescriptionOf(pluginClass));
} }
} }
}
// Register IP distributors // Register IP distributors
String[] ipDistClassNames = projectConfig.getStringArrayValue(GUI.class, String[] ipDistClassNames = projectConfig.getStringArrayValue(GUI.class,
@ -1544,8 +1568,9 @@ public class GUI {
return null; return null;
} }
if (newPlugin == null) if (newPlugin == null) {
return null; return null;
}
// Add to active plugins list // Add to active plugins list
startedPlugins.add(newPlugin); startedPlugins.add(newPlugin);
@ -1580,12 +1605,14 @@ public class GUI {
* @return True if this plugin was registered ok, false otherwise * @return True if this plugin was registered ok, false otherwise
*/ */
public boolean registerTemporaryPlugin(Class<? extends Plugin> newPluginClass) { public boolean registerTemporaryPlugin(Class<? extends Plugin> newPluginClass) {
if (pluginClasses.contains(newPluginClass)) if (pluginClasses.contains(newPluginClass)) {
return false; return false;
}
boolean returnVal = registerPlugin(newPluginClass, true); boolean returnVal = registerPlugin(newPluginClass, true);
if (!returnVal) if (!returnVal) {
return false; return false;
}
pluginClassesTemporary.add(newPluginClass); pluginClassesTemporary.add(newPluginClass);
return true; return true;
@ -1603,19 +1630,23 @@ public class GUI {
for (Component menuComponent : menuPlugins.getMenuComponents()) { for (Component menuComponent : menuPlugins.getMenuComponents()) {
if (menuComponent.getClass().isAssignableFrom(JMenuItem.class)) { if (menuComponent.getClass().isAssignableFrom(JMenuItem.class)) {
JMenuItem menuItem = (JMenuItem) menuComponent; JMenuItem menuItem = (JMenuItem) menuComponent;
if (menuItem.getClientProperty("class").equals(pluginClass)) if (menuItem.getClientProperty("class").equals(pluginClass)) {
menuPlugins.remove(menuItem); menuPlugins.remove(menuItem);
} }
} }
if (menuMotePluginClasses.contains(pluginClass)) }
if (menuMotePluginClasses.contains(pluginClass)) {
menuMotePluginClasses.remove(pluginClass); menuMotePluginClasses.remove(pluginClass);
}
// Remove from plugin vectors (including temporary) // Remove from plugin vectors (including temporary)
if (pluginClasses.contains(pluginClass)) if (pluginClasses.contains(pluginClass)) {
pluginClasses.remove(pluginClass); pluginClasses.remove(pluginClass);
if (pluginClassesTemporary.contains(pluginClass)) }
if (pluginClassesTemporary.contains(pluginClass)) {
pluginClassesTemporary.remove(pluginClass); pluginClassesTemporary.remove(pluginClass);
} }
}
/** /**
* Register a plugin to be included in the GUI. * Register a plugin to be included in the GUI.
@ -1734,11 +1765,12 @@ public class GUI {
mySimulation = sim; mySimulation = sim;
// Set frame title // Set frame title
if (frame != null) if (frame != null) {
frame.setTitle("COOJA Simulator" + " - " + sim.getTitle()); frame.setTitle("COOJA Simulator" + " - " + sim.getTitle());
}
// Open standard plugins (if none opened already) // Open standard plugins (if none opened already)
if (startedPlugins.size() == 0) if (startedPlugins.size() == 0) {
for (Class<? extends Plugin> pluginClass : pluginClasses) { for (Class<? extends Plugin> pluginClass : pluginClasses) {
int pluginType = pluginClass.getAnnotation(PluginType.class).value(); int pluginType = pluginClass.getAnnotation(PluginType.class).value();
if (pluginType == PluginType.SIM_STANDARD_PLUGIN) { if (pluginType == PluginType.SIM_STANDARD_PLUGIN) {
@ -1746,6 +1778,7 @@ public class GUI {
} }
} }
} }
}
/** /**
* Creates a new mote type of the given mote type class. * Creates a new mote type of the given mote type class.
@ -1813,9 +1846,10 @@ public class GUI {
int pluginType = startedPlugin.getClass().getAnnotation( int pluginType = startedPlugin.getClass().getAnnotation(
PluginType.class).value(); PluginType.class).value();
if (pluginType != PluginType.COOJA_PLUGIN if (pluginType != PluginType.COOJA_PLUGIN
&& pluginType != PluginType.COOJA_STANDARD_PLUGIN) && pluginType != PluginType.COOJA_STANDARD_PLUGIN) {
removePlugin((Plugin) startedPlugin, false); removePlugin((Plugin) startedPlugin, false);
} }
}
// Delete simulation // Delete simulation
mySimulation.deleteObservers(); mySimulation.deleteObservers();
@ -1921,14 +1955,16 @@ public class GUI {
} catch (UnsatisfiedLinkError e) { } catch (UnsatisfiedLinkError e) {
showErrorDialog(frame, "Simulation load error", e, false); showErrorDialog(frame, "Simulation load error", e, false);
if (progressDialog != null && progressDialog.isDisplayable()) if (progressDialog != null && progressDialog.isDisplayable()) {
progressDialog.dispose(); progressDialog.dispose();
}
newSim = null; newSim = null;
} catch (SimulationCreationException e) { } catch (SimulationCreationException e) {
showErrorDialog(frame, "Simulation load error", e, false); showErrorDialog(frame, "Simulation load error", e, false);
if (progressDialog != null && progressDialog.isDisplayable()) if (progressDialog != null && progressDialog.isDisplayable()) {
progressDialog.dispose(); progressDialog.dispose();
}
newSim = null; newSim = null;
} }
if (newSim != null) { if (newSim != null) {
@ -1970,13 +2006,14 @@ public class GUI {
progressDialog.setLocationRelativeTo(frame); progressDialog.setLocationRelativeTo(frame);
progressDialog.setDefaultCloseOperation(JDialog.DO_NOTHING_ON_CLOSE); progressDialog.setDefaultCloseOperation(JDialog.DO_NOTHING_ON_CLOSE);
loadThread.start(); loadThread.start();
if (quick) if (quick) {
SwingUtilities.invokeLater(new Runnable() { SwingUtilities.invokeLater(new Runnable() {
public void run() { public void run() {
progressDialog.setVisible(true); progressDialog.setVisible(true);
} }
}); });
} }
}
/** /**
* Reloads current simulation. * Reloads current simulation.
@ -2042,8 +2079,9 @@ public class GUI {
Element root = new Element("simconf"); Element root = new Element("simconf");
root.addContent(simulationElement); root.addContent(simulationElement);
if (pluginsConfig != null) if (pluginsConfig != null) {
root.addContent(pluginsConfig); root.addContent(pluginsConfig);
}
Document doc = new Document(root); Document doc = new Document(root);
XMLOutputter outputter = new XMLOutputter(); XMLOutputter outputter = new XMLOutputter();
@ -2166,8 +2204,9 @@ public class GUI {
if (!saveFile.exists() || saveFile.canWrite()) { if (!saveFile.exists() || saveFile.canWrite()) {
saveSimulationConfig(saveFile); saveSimulationConfig(saveFile);
addToFileHistory(saveFile); addToFileHistory(saveFile);
} else } else {
logger.fatal("No write access to file"); logger.fatal("No write access to file");
}
} else { } else {
logger.info("Save command cancelled by user..."); logger.info("Save command cancelled by user...");
@ -2185,13 +2224,15 @@ public class GUI {
Vector<Mote> newMotes = AddMoteDialog.showDialog(frame, mySimulation, Vector<Mote> newMotes = AddMoteDialog.showDialog(frame, mySimulation,
moteType); moteType);
if (newMotes != null) { if (newMotes != null) {
for (Mote newMote : newMotes) for (Mote newMote : newMotes) {
mySimulation.addMote(newMote); mySimulation.addMote(newMote);
} }
}
} else } else {
logger.warn("No simulation active"); logger.warn("No simulation active");
} }
}
/** /**
* Create a new simulation * Create a new simulation
@ -2236,14 +2277,16 @@ public class GUI {
int n = JOptionPane.showOptionDialog(frame, "Sure you want to quit?", int n = JOptionPane.showOptionDialog(frame, "Sure you want to quit?",
"Close COOJA Simulator", JOptionPane.YES_NO_OPTION, "Close COOJA Simulator", JOptionPane.YES_NO_OPTION,
JOptionPane.QUESTION_MESSAGE, null, options, s1); JOptionPane.QUESTION_MESSAGE, null, options, s1);
if (n != JOptionPane.YES_OPTION) if (n != JOptionPane.YES_OPTION) {
return; return;
} }
}
// Clean up resources // Clean up resources
Object[] plugins = startedPlugins.toArray(); Object[] plugins = startedPlugins.toArray();
for (Object plugin : plugins) for (Object plugin : plugins) {
removePlugin((Plugin) plugin, false); removePlugin((Plugin) plugin, false);
}
// Restore last frame size and position // Restore last frame size and position
if (frame != null) { if (frame != null) {
@ -2323,8 +2366,9 @@ public class GUI {
*/ */
public static void loadExternalToolsDefaultSettings() { public static void loadExternalToolsDefaultSettings() {
String filename = GUI.EXTERNAL_TOOLS_LINUX_SETTINGS_FILENAME; String filename = GUI.EXTERNAL_TOOLS_LINUX_SETTINGS_FILENAME;
if (System.getProperty("os.name").startsWith("Win")) if (System.getProperty("os.name").startsWith("Win")) {
filename = GUI.EXTERNAL_TOOLS_WIN32_SETTINGS_FILENAME; filename = GUI.EXTERNAL_TOOLS_WIN32_SETTINGS_FILENAME;
}
try { try {
InputStream in = GUI.class.getResourceAsStream(filename); InputStream in = GUI.class.getResourceAsStream(filename);
@ -2377,6 +2421,10 @@ public class GUI {
* Save external tools user settings to file. * Save external tools user settings to file.
*/ */
public static void saveExternalToolsUserSettings() { public static void saveExternalToolsUserSettings() {
if (externalToolsUserSettingsFileReadOnly) {
return;
}
try { try {
FileOutputStream out = new FileOutputStream(externalToolsUserSettingsFile); FileOutputStream out = new FileOutputStream(externalToolsUserSettingsFile);
@ -2458,12 +2506,14 @@ public class GUI {
ExternalToolsDialog.showDialog(frame); ExternalToolsDialog.showDialog(frame);
} else if (e.getActionCommand().equals("close plugins")) { } else if (e.getActionCommand().equals("close plugins")) {
Object[] plugins = startedPlugins.toArray(); Object[] plugins = startedPlugins.toArray();
for (Object plugin : plugins) for (Object plugin : plugins) {
removePlugin((Plugin) plugin, false); removePlugin((Plugin) plugin, false);
}
} else if (e.getActionCommand().equals("remove all motes")) { } else if (e.getActionCommand().equals("remove all motes")) {
if (getSimulation() != null) { if (getSimulation() != null) {
if (getSimulation().isRunning()) if (getSimulation().isRunning()) {
getSimulation().stopSimulation(); getSimulation().stopSimulation();
}
while (getSimulation().getMotesCount() > 0) { while (getSimulation().getMotesCount() > 0) {
getSimulation().removeMote(getSimulation().getMote(0)); getSimulation().removeMote(getSimulation().getMote(0));
@ -2481,10 +2531,11 @@ public class GUI {
.getSource()).getClientProperty("class"); .getSource()).getClientProperty("class");
Mote mote = (Mote) ((JMenuItem) e.getSource()).getClientProperty("mote"); Mote mote = (Mote) ((JMenuItem) e.getSource()).getClientProperty("mote");
startPlugin(pluginClass, myGUI, mySimulation, mote); startPlugin(pluginClass, myGUI, mySimulation, mote);
} else } else {
logger.warn("Unhandled action: " + e.getActionCommand()); logger.warn("Unhandled action: " + e.getActionCommand());
} }
} }
}
// // VARIOUS HELP METHODS //// // // VARIOUS HELP METHODS ////
@ -2590,7 +2641,7 @@ public class GUI {
} }
} }
return new URLClassLoader((URL[]) urls.toArray(new URL[urls.size()]), return new URLClassLoader(urls.toArray(new URL[urls.size()]),
parent); parent);
} }
@ -2640,14 +2691,14 @@ public class GUI {
} }
// Parse general command arguments // Parse general command arguments
for (int i = 0; i < args.length; i++) { for (String element : args) {
if (args[i].startsWith("-contiki=")) { if (element.startsWith("-contiki=")) {
String arg = args[i].substring("-contiki=".length()); String arg = element.substring("-contiki=".length());
GUI.specifiedContikiPath = arg; GUI.specifiedContikiPath = arg;
} }
if (args[i].startsWith("-external_tools_config=")) { if (element.startsWith("-external_tools_config=")) {
String arg = args[i].substring("-external_tools_config=".length()); String arg = element.substring("-external_tools_config=".length());
File specifiedExternalToolsConfigFile = new File(arg); File specifiedExternalToolsConfigFile = new File(arg);
if (!specifiedExternalToolsConfigFile.exists()) { if (!specifiedExternalToolsConfigFile.exists()) {
logger.fatal("Specified external tools configuration not found: " + specifiedExternalToolsConfigFile); logger.fatal("Specified external tools configuration not found: " + specifiedExternalToolsConfigFile);
@ -2655,6 +2706,7 @@ public class GUI {
System.exit(1); System.exit(1);
} else { } else {
GUI.externalToolsUserSettingsFile = specifiedExternalToolsConfigFile; GUI.externalToolsUserSettingsFile = specifiedExternalToolsConfigFile;
GUI.externalToolsUserSettingsFileReadOnly = true;
} }
} }
} }
@ -2685,29 +2737,33 @@ public class GUI {
String arg = args[i].substring("-projects=".length()); String arg = args[i].substring("-projects=".length());
String[] argArray = arg.split(","); String[] argArray = arg.split(",");
projectDirs = new Vector<String>(); projectDirs = new Vector<String>();
for (String argValue : argArray) for (String argValue : argArray) {
projectDirs.add(argValue); projectDirs.add(argValue);
}
} else if (args[i].startsWith("-sensors=")) { } else if (args[i].startsWith("-sensors=")) {
String arg = args[i].substring("-sensors=".length()); String arg = args[i].substring("-sensors=".length());
String[] argArray = arg.split(","); String[] argArray = arg.split(",");
sensors = new Vector<String>(); sensors = new Vector<String>();
for (String argValue : argArray) for (String argValue : argArray) {
sensors.add(argValue); sensors.add(argValue);
}
} else if (args[i].startsWith("-interfaces=")) { } else if (args[i].startsWith("-interfaces=")) {
String arg = args[i].substring("-interfaces=".length()); String arg = args[i].substring("-interfaces=".length());
String[] argArray = arg.split(","); String[] argArray = arg.split(",");
coreInterfaces = new Vector<String>(); coreInterfaces = new Vector<String>();
for (String argValue : argArray) for (String argValue : argArray) {
coreInterfaces.add(argValue); coreInterfaces.add(argValue);
}
} else if (args[i].startsWith("-processes=")) { } else if (args[i].startsWith("-processes=")) {
String arg = args[i].substring("-processes=".length()); String arg = args[i].substring("-processes=".length());
String[] argArray = arg.split(","); String[] argArray = arg.split(",");
userProcesses = new Vector<String>(); userProcesses = new Vector<String>();
for (String argValue : argArray) for (String argValue : argArray) {
userProcesses.add(argValue); userProcesses.add(argValue);
}
} else if (args[i].equals("-noautostartscan")) { } else if (args[i].equals("-noautostartscan")) {
addAutostartProcesses = false; addAutostartProcesses = false;
@ -2740,8 +2796,9 @@ public class GUI {
boolean ok = quickStartSimulation(moteTypeID, projectDirs, sensors, boolean ok = quickStartSimulation(moteTypeID, projectDirs, sensors,
coreInterfaces, userProcesses, addAutostartProcesses, numberOfNodes, coreInterfaces, userProcesses, addAutostartProcesses, numberOfNodes,
areaSideLength, delayTime, startSimulation, filename, contikiPath); areaSideLength, delayTime, startSimulation, filename, contikiPath);
if (!ok) if (!ok) {
System.exit(1); System.exit(1);
}
} else if (args.length > 0 && args[0].startsWith("-nogui")) { } else if (args.length > 0 && args[0].startsWith("-nogui")) {
@ -2879,8 +2936,9 @@ public class GUI {
// Create started plugins config // Create started plugins config
Collection<Element> pluginsConfig = getPluginsConfigXML(); Collection<Element> pluginsConfig = getPluginsConfigXML();
if (pluginsConfig != null) if (pluginsConfig != null) {
root.addContent(pluginsConfig); root.addContent(pluginsConfig);
}
// Create and write to document // Create and write to document
Document doc = new Document(root); Document doc = new Document(root);
@ -2914,8 +2972,9 @@ public class GUI {
// Ignore GUI plugins // Ignore GUI plugins
if (pluginType == PluginType.COOJA_PLUGIN if (pluginType == PluginType.COOJA_PLUGIN
|| pluginType == PluginType.COOJA_STANDARD_PLUGIN) || pluginType == PluginType.COOJA_STANDARD_PLUGIN) {
continue; continue;
}
pluginElement = new Element("plugin"); pluginElement = new Element("plugin");
pluginElement.setText(startedPlugin.getClass().getName()); pluginElement.setText(startedPlugin.getClass().getName());
@ -3114,8 +3173,9 @@ public class GUI {
String message = title; String message = title;
// Create message // Create message
if (exception != null) if (exception != null) {
message = exception.getMessage(); message = exception.getMessage();
}
// Create stack trace message list // Create stack trace message list
if (exception != null) { if (exception != null) {
@ -3140,14 +3200,11 @@ public class GUI {
// Create error dialog // Create error dialog
final JDialog errorDialog; final JDialog errorDialog;
if (parentComponent instanceof Dialog) if (parentComponent instanceof Dialog) {
errorDialog = new JDialog((Dialog) parentComponent, title, true); errorDialog = new JDialog((Dialog) parentComponent, title, true);
else if (parentComponent instanceof Frame) } else if (parentComponent instanceof Frame) {
errorDialog = new JDialog((Frame) parentComponent, title, true); errorDialog = new JDialog((Frame) parentComponent, title, true);
// else if (parentComponent instanceof Window) } else {
// errorDialog = new JDialog((Window) parentComponent, title,
// ModalityType.APPLICATION_MODAL);
else {
logger.fatal("Bad parent for error dialog"); logger.fatal("Bad parent for error dialog");
errorDialog = new JDialog((Frame) null, title + " (Java stack trace)"); errorDialog = new JDialog((Frame) null, title + " (Java stack trace)");
} }
@ -3283,8 +3340,9 @@ public class GUI {
errorDialog.setLocationRelativeTo(parentComponent); errorDialog.setLocationRelativeTo(parentComponent);
errorDialog.setVisible(true); errorDialog.setVisible(true);
if (errorDialog.getTitle().equals("-RETRY-")) if (errorDialog.getTitle().equals("-RETRY-")) {
return true; return true;
}
return false; return false;
} }