mirror of
https://github.com/oliverschmidt/contiki.git
synced 2025-02-04 22:33:19 +00:00
added simulation config backwards compatibility for msp motes
This commit is contained in:
parent
1ca67916a4
commit
d26ba2606b
@ -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: ESBCompileDialog.java,v 1.2 2009/03/09 17:10:14 fros4943 Exp $
|
* $Id: ESBCompileDialog.java,v 1.3 2009/03/11 17:46:59 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.mspmote;
|
package se.sics.cooja.mspmote;
|
||||||
@ -34,18 +34,10 @@ import java.awt.Container;
|
|||||||
import java.io.File;
|
import java.io.File;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
|
||||||
|
import se.sics.cooja.MoteInterface;
|
||||||
import se.sics.cooja.MoteType;
|
import se.sics.cooja.MoteType;
|
||||||
import se.sics.cooja.Simulation;
|
import se.sics.cooja.Simulation;
|
||||||
import se.sics.cooja.dialogs.AbstractCompileDialog;
|
import se.sics.cooja.dialogs.AbstractCompileDialog;
|
||||||
import se.sics.cooja.interfaces.Mote2MoteRelations;
|
|
||||||
import se.sics.cooja.interfaces.Position;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.ESBButton;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.ESBLED;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.ESBLog;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.MspClock;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.MspIPAddress;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.MspMoteID;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.TR1001Radio;
|
|
||||||
|
|
||||||
public class ESBCompileDialog extends AbstractCompileDialog {
|
public class ESBCompileDialog extends AbstractCompileDialog {
|
||||||
private static Logger logger = Logger.getLogger(ESBCompileDialog.class);
|
private static Logger logger = Logger.getLogger(ESBCompileDialog.class);
|
||||||
@ -77,15 +69,9 @@ public class ESBCompileDialog extends AbstractCompileDialog {
|
|||||||
selected = false;
|
selected = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
addMoteInterface(Position.class, selected);
|
for (Class<? extends MoteInterface> intfClass: ((ESBMoteType)moteType).getAllMoteInterfaceClasses()) {
|
||||||
addMoteInterface(MspIPAddress.class, selected);
|
addMoteInterface(intfClass, selected);
|
||||||
addMoteInterface(ESBLog.class, selected);
|
}
|
||||||
addMoteInterface(MspClock.class, selected);
|
|
||||||
addMoteInterface(ESBLED.class, selected);
|
|
||||||
addMoteInterface(ESBButton.class, selected);
|
|
||||||
addMoteInterface(MspMoteID.class, selected);
|
|
||||||
addMoteInterface(TR1001Radio.class, selected);
|
|
||||||
addMoteInterface(Mote2MoteRelations.class, selected);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canLoadFirmware(File file) {
|
public boolean canLoadFirmware(File file) {
|
||||||
@ -103,10 +89,7 @@ public class ESBCompileDialog extends AbstractCompileDialog {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public File getExpectedFirmwareFile(File source) {
|
public File getExpectedFirmwareFile(File source) {
|
||||||
File parentDir = source.getParentFile();
|
return ((ESBMoteType)moteType).getExpectedFirmwareFile(source);
|
||||||
String sourceNoExtension = source.getName().substring(0, source.getName().length()-2);
|
|
||||||
|
|
||||||
return new File(parentDir, sourceNoExtension + ".esb");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeSettingsToMoteType() {
|
public void writeSettingsToMoteType() {
|
||||||
|
@ -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: ESBMoteType.java,v 1.7 2009/03/11 08:42:07 fros4943 Exp $
|
* $Id: ESBMoteType.java,v 1.8 2009/03/11 17:46:59 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.mspmote;
|
package se.sics.cooja.mspmote;
|
||||||
@ -41,6 +41,15 @@ import se.sics.cooja.*;
|
|||||||
import se.sics.cooja.dialogs.CompileContiki;
|
import se.sics.cooja.dialogs.CompileContiki;
|
||||||
import se.sics.cooja.dialogs.MessageList;
|
import se.sics.cooja.dialogs.MessageList;
|
||||||
import se.sics.cooja.dialogs.MessageList.MessageContainer;
|
import se.sics.cooja.dialogs.MessageList.MessageContainer;
|
||||||
|
import se.sics.cooja.interfaces.Mote2MoteRelations;
|
||||||
|
import se.sics.cooja.interfaces.Position;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.ESBButton;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.ESBLED;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.ESBLog;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.MspClock;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.MspIPAddress;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.MspMoteID;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.TR1001Radio;
|
||||||
|
|
||||||
@ClassDescription("ESB Mote Type")
|
@ClassDescription("ESB Mote Type")
|
||||||
@AbstractionLevelDescription("Emulated level")
|
@AbstractionLevelDescription("Emulated level")
|
||||||
@ -184,4 +193,24 @@ public class ESBMoteType extends MspMoteType {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Class<? extends MoteInterface>[] getAllMoteInterfaceClasses() {
|
||||||
|
return new Class[] {
|
||||||
|
Position.class,
|
||||||
|
MspIPAddress.class,
|
||||||
|
ESBLog.class,
|
||||||
|
MspClock.class,
|
||||||
|
ESBLED.class,
|
||||||
|
ESBButton.class,
|
||||||
|
MspMoteID.class,
|
||||||
|
TR1001Radio.class,
|
||||||
|
Mote2MoteRelations.class
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getExpectedFirmwareFile(File source) {
|
||||||
|
File parentDir = source.getParentFile();
|
||||||
|
String sourceNoExtension = source.getName().substring(0, source.getName().length()-2);
|
||||||
|
|
||||||
|
return new File(parentDir, sourceNoExtension + ".esb");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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: MspMoteType.java,v 1.27 2009/03/11 08:42:07 fros4943 Exp $
|
* $Id: MspMoteType.java,v 1.28 2009/03/11 17:46:59 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.mspmote;
|
package se.sics.cooja.mspmote;
|
||||||
@ -214,8 +214,8 @@ public abstract class MspMoteType implements MoteType {
|
|||||||
// Source file
|
// Source file
|
||||||
if (fileSource != null) {
|
if (fileSource != null) {
|
||||||
element = new Element("source");
|
element = new Element("source");
|
||||||
fileSource = GUI.stripAbsoluteContikiPath(fileSource);
|
File file = GUI.stripAbsoluteContikiPath(fileSource);
|
||||||
element.setText(fileSource.getPath().replaceAll("\\\\", "/"));
|
element.setText(file.getPath().replaceAll("\\\\", "/"));
|
||||||
config.add(element);
|
config.add(element);
|
||||||
element = new Element("commands");
|
element = new Element("commands");
|
||||||
element.setText(compileCommands);
|
element.setText(compileCommands);
|
||||||
@ -224,8 +224,8 @@ public abstract class MspMoteType implements MoteType {
|
|||||||
|
|
||||||
// Firmware file
|
// Firmware file
|
||||||
element = new Element("firmware");
|
element = new Element("firmware");
|
||||||
fileFirmware = GUI.stripAbsoluteContikiPath(fileFirmware);
|
File file = GUI.stripAbsoluteContikiPath(fileFirmware);
|
||||||
element.setText(fileFirmware.getPath().replaceAll("\\\\", "/"));
|
element.setText(file.getPath().replaceAll("\\\\", "/"));
|
||||||
config.add(element);
|
config.add(element);
|
||||||
|
|
||||||
// Mote interfaces
|
// Mote interfaces
|
||||||
@ -251,12 +251,17 @@ public abstract class MspMoteType implements MoteType {
|
|||||||
description = element.getText();
|
description = element.getText();
|
||||||
} else if (name.equals("source")) {
|
} else if (name.equals("source")) {
|
||||||
fileSource = new File(element.getText());
|
fileSource = new File(element.getText());
|
||||||
|
} else if (name.equals("command")) {
|
||||||
|
/* Backwards compatibility: command is now commands */
|
||||||
|
logger.warn("Old simulation config detected: old version only supports a single compile command");
|
||||||
|
compileCommands = element.getText();
|
||||||
} else if (name.equals("commands")) {
|
} else if (name.equals("commands")) {
|
||||||
compileCommands = element.getText();
|
compileCommands = element.getText();
|
||||||
} else if (name.equals("firmware")) {
|
} else if (name.equals("firmware")) {
|
||||||
fileFirmware = new File(element.getText());
|
fileFirmware = new File(element.getText());
|
||||||
} else if (name.equals("elf")) {
|
} else if (name.equals("elf")) {
|
||||||
/* Backwards compatibility: elf is now firmware */
|
/* Backwards compatibility: elf is now firmware */
|
||||||
|
logger.warn("Old simulation config detected: firmware specified as elf");
|
||||||
fileFirmware = new File(element.getText());
|
fileFirmware = new File(element.getText());
|
||||||
} else if (name.equals("moteinterface")) {
|
} else if (name.equals("moteinterface")) {
|
||||||
Class<? extends MoteInterface> moteInterfaceClass =
|
Class<? extends MoteInterface> moteInterfaceClass =
|
||||||
@ -275,9 +280,29 @@ public abstract class MspMoteType implements MoteType {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Class<? extends MoteInterface>[] intfClasses = new Class[intfClassList.size()];
|
Class<? extends MoteInterface>[] intfClasses = new Class[intfClassList.size()];
|
||||||
intfClassList.toArray(intfClasses);
|
intfClasses = intfClassList.toArray(intfClasses);
|
||||||
|
|
||||||
|
if (intfClasses.length == 0) {
|
||||||
|
/* Backwards compatibility: No interfaces specifed */
|
||||||
|
logger.warn("Old simulation config detected: no mote interfaces specified, assuming all.");
|
||||||
|
intfClasses = getAllMoteInterfaceClasses();
|
||||||
|
}
|
||||||
setMoteInterfaceClasses(intfClasses);
|
setMoteInterfaceClasses(intfClasses);
|
||||||
|
|
||||||
|
if (fileFirmware == null) {
|
||||||
|
if (fileSource == null) {
|
||||||
|
throw new MoteTypeCreationException("Neither source or firmware specified");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Backwards compatibility: Generate expected firmware file name from source */
|
||||||
|
logger.warn("Old simulation config detected: no firmware file specified, generating expected");
|
||||||
|
fileFirmware = getExpectedFirmwareFile(fileSource);
|
||||||
|
}
|
||||||
|
|
||||||
return configureAndInit(GUI.getTopParentContainer(), simulation, visAvailable);
|
return configureAndInit(GUI.getTopParentContainer(), simulation, visAvailable);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public abstract Class<? extends MoteInterface>[] getAllMoteInterfaceClasses();
|
||||||
|
public abstract File getExpectedFirmwareFile(File source);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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: SkyCompileDialog.java,v 1.1 2009/03/09 16:04:42 fros4943 Exp $
|
* $Id: SkyCompileDialog.java,v 1.2 2009/03/11 17:46:59 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.mspmote;
|
package se.sics.cooja.mspmote;
|
||||||
@ -34,19 +34,10 @@ import java.awt.Container;
|
|||||||
import java.io.File;
|
import java.io.File;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
|
||||||
|
import se.sics.cooja.MoteInterface;
|
||||||
import se.sics.cooja.MoteType;
|
import se.sics.cooja.MoteType;
|
||||||
import se.sics.cooja.Simulation;
|
import se.sics.cooja.Simulation;
|
||||||
import se.sics.cooja.dialogs.AbstractCompileDialog;
|
import se.sics.cooja.dialogs.AbstractCompileDialog;
|
||||||
import se.sics.cooja.interfaces.Mote2MoteRelations;
|
|
||||||
import se.sics.cooja.interfaces.Position;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.MspClock;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.MspIPAddress;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.MspMoteID;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.SkyButton;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.SkyByteRadio;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.SkyFlash;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.SkyLED;
|
|
||||||
import se.sics.cooja.mspmote.interfaces.SkySerial;
|
|
||||||
|
|
||||||
public class SkyCompileDialog extends AbstractCompileDialog {
|
public class SkyCompileDialog extends AbstractCompileDialog {
|
||||||
private static Logger logger = Logger.getLogger(SkyCompileDialog.class);
|
private static Logger logger = Logger.getLogger(SkyCompileDialog.class);
|
||||||
@ -77,16 +68,10 @@ public class SkyCompileDialog extends AbstractCompileDialog {
|
|||||||
if (moteIntfBox.getComponentCount() > 0) {
|
if (moteIntfBox.getComponentCount() > 0) {
|
||||||
selected = false;
|
selected = false;
|
||||||
}
|
}
|
||||||
addMoteInterface(Position.class, selected);
|
|
||||||
addMoteInterface(MspIPAddress.class, selected);
|
for (Class<? extends MoteInterface> intfClass: ((SkyMoteType)moteType).getAllMoteInterfaceClasses()) {
|
||||||
addMoteInterface(Mote2MoteRelations.class, selected);
|
addMoteInterface(intfClass, selected);
|
||||||
addMoteInterface(MspClock.class, selected);
|
}
|
||||||
addMoteInterface(MspMoteID.class, selected);
|
|
||||||
addMoteInterface(SkyButton.class, selected);
|
|
||||||
addMoteInterface(SkyFlash.class, selected);
|
|
||||||
addMoteInterface(SkyByteRadio.class, selected);
|
|
||||||
addMoteInterface(SkySerial.class, selected);
|
|
||||||
addMoteInterface(SkyLED.class, selected);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canLoadFirmware(File file) {
|
public boolean canLoadFirmware(File file) {
|
||||||
@ -104,10 +89,7 @@ public class SkyCompileDialog extends AbstractCompileDialog {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public File getExpectedFirmwareFile(File source) {
|
public File getExpectedFirmwareFile(File source) {
|
||||||
File parentDir = source.getParentFile();
|
return ((SkyMoteType)moteType).getExpectedFirmwareFile(source);
|
||||||
String sourceNoExtension = source.getName().substring(0, source.getName().length()-2);
|
|
||||||
|
|
||||||
return new File(parentDir, sourceNoExtension + ".sky");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeSettingsToMoteType() {
|
public void writeSettingsToMoteType() {
|
||||||
|
@ -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: SkyMoteType.java,v 1.6 2009/03/11 08:42:07 fros4943 Exp $
|
* $Id: SkyMoteType.java,v 1.7 2009/03/11 17:46:59 fros4943 Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package se.sics.cooja.mspmote;
|
package se.sics.cooja.mspmote;
|
||||||
@ -41,6 +41,16 @@ import se.sics.cooja.*;
|
|||||||
import se.sics.cooja.dialogs.CompileContiki;
|
import se.sics.cooja.dialogs.CompileContiki;
|
||||||
import se.sics.cooja.dialogs.MessageList;
|
import se.sics.cooja.dialogs.MessageList;
|
||||||
import se.sics.cooja.dialogs.MessageList.MessageContainer;
|
import se.sics.cooja.dialogs.MessageList.MessageContainer;
|
||||||
|
import se.sics.cooja.interfaces.Mote2MoteRelations;
|
||||||
|
import se.sics.cooja.interfaces.Position;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.MspClock;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.MspIPAddress;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.MspMoteID;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.SkyButton;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.SkyByteRadio;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.SkyFlash;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.SkyLED;
|
||||||
|
import se.sics.cooja.mspmote.interfaces.SkySerial;
|
||||||
|
|
||||||
@ClassDescription("Sky Mote Type")
|
@ClassDescription("Sky Mote Type")
|
||||||
@AbstractionLevelDescription("Emulated level")
|
@AbstractionLevelDescription("Emulated level")
|
||||||
@ -184,4 +194,25 @@ public class SkyMoteType extends MspMoteType {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Class<? extends MoteInterface>[] getAllMoteInterfaceClasses() {
|
||||||
|
return new Class[] {
|
||||||
|
Position.class,
|
||||||
|
MspIPAddress.class,
|
||||||
|
Mote2MoteRelations.class,
|
||||||
|
MspClock.class,
|
||||||
|
MspMoteID.class,
|
||||||
|
SkyButton.class,
|
||||||
|
SkyFlash.class,
|
||||||
|
SkyByteRadio.class,
|
||||||
|
SkySerial.class,
|
||||||
|
SkyLED.class
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getExpectedFirmwareFile(File source) {
|
||||||
|
File parentDir = source.getParentFile();
|
||||||
|
String sourceNoExtension = source.getName().substring(0, source.getName().length()-2);
|
||||||
|
|
||||||
|
return new File(parentDir, sourceNoExtension + ".sky");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user