/**
* BlueCove - Java library for Bluetooth
* Copyright (C) 2006-2009 Vlad Skarzhevskyy
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
* @author vlads
* @version $Id$
*/
package org.bluecove.tester.obex;
import javax.microedition.lcdui.Command;
import javax.microedition.lcdui.CommandListener;
import javax.microedition.lcdui.Displayable;
import org.bluecove.tester.log.Logger;
import org.bluecove.tester.me.LoggerCanvas;
import org.bluecove.tester.util.ThreadUtils;
public class BlueCoveObexCanvas extends LoggerCanvas implements CommandListener, TestControl {
static final Command exitCommand = new Command("Exit", Command.EXIT, 0);
static final Command continueCommand = new Command("1-Continue", Command.ITEM, 1);
static final Command startRunCommand = new Command("*-Run", Command.ITEM, 2);
static final Command selectTestCommand = new Command("Select Test", Command.ITEM, 3);
static final Command clearCommand = new Command("#-Clear", Command.ITEM, 8);
private Object pauseLock = new Object();
private boolean pauseOn = false;
public BlueCoveObexCanvas() {
super();
super.setTitle("BlueCoveO");
TestSelector.testControl = this;
logTimeStamp = true;
addCommand(exitCommand);
addCommand(startRunCommand);
addCommand(selectTestCommand);
addCommand(clearCommand);
setCommandListener(this);
}
protected String getCanvasTitleText() {
return "BlueCoveO Tester";
}
public void pause(String mesage) {
addCommand(continueCommand);
Logger.info("pause: " + mesage);
pauseOn = true;
while (pauseOn) {
synchronized (pauseLock) {
try {
pauseLock.wait();
} catch (InterruptedException e) {
throw new RuntimeException("Pause Interrupted");
}
}
}
}
protected void runContinue() {
removeCommand(continueCommand);
pauseOn = false;
synchronized (pauseLock) {
pauseLock.notifyAll();
}
}
public void commandAction(final Command c, Displayable d) {
Runnable r = new Runnable() {
public void run() {
if (c == exitCommand) {
BlueCoveObexMIDlet.exit();
} else if (c == clearCommand) {
clearLog();
} else if (c == startRunCommand) {
TestSelector.runTest();
} else if (c == selectTestCommand) {
TestSelector.selectTest();
} else if (c == continueCommand) {
runContinue();
} else {
if (c != null) {
Logger.info("Command " + c.getLabel() + " not found");
}
}
}
};
ThreadUtils.invokeLater(r, c.getLabel());
}
protected void keyPressed(int keyCode) {
switch (keyCode) {
case '0':
logScrollBottom();
break;
case '3':
TestSelector.selectTest();
break;
case '*':
Runnable r = new Runnable() {
public void run() {
TestSelector.runTest();
}
};
ThreadUtils.invokeLater(r, "RunTests");
break;
case '1':
runContinue();
break;
case '#':
clearLog();
break;
default:
logLinesMove(getGameAction(keyCode));
}
repaint();
}
protected void keyRepeated(int keyCode) {
logLinesMove(getGameAction(keyCode));
}
}