private Messenger messenger;
private Task task;
private Toast toast;
- private boolean ready;
+ private boolean running;
private String topic;
private String names;
private Cards cards;
}
/* Private handler methods */
- private void onRegister(Object obj)
+ private void onRegister(Task task)
{
Os.debug("Main: onRegister");
- this.task = (Task)obj;
+ this.task = task;
+ this.running = this.task.isRunning();
+ for (Object obj : this.task.getLog()) {
+ if (String.class.isInstance(obj))
+ this.notice((String)obj);
+ if (Message.class.isInstance(obj))
+ this.onMessage((Message)obj);
+ }
}
- private void onMessage(Object obj)
+ private void onMessage(Message msg)
{
- Message msg = (Message)obj;
-
// Debug
this.debug.append("> " + msg.line + "\n");
this.dscroll.smoothScrollTo(0, this.debug.getBottom());
}
/* Private service methods */
- private void startService()
+ private void register()
{
- Os.debug("Main: startService");
+ Os.debug("Main: register");
startService(new Intent(this, Task.class)
+ .putExtra("Command", Task.REGISTER)
.putExtra("Messenger", this.messenger));
}
- private void stopService()
+ private void connect()
+ {
+ Os.debug("Main: connect");
+ startService(new Intent(this, Task.class)
+ .putExtra("Command", Task.CONNECT));
+ this.running = true;
+ }
+
+ private void disconnect()
+ {
+ Os.debug("Main: disconnect");
+ startService(new Intent(this, Task.class)
+ .putExtra("Command", Task.DISCONNECT));
+ }
+
+ private void exit()
{
- Os.debug("Main: stopService");
stopService(new Intent(this, Task.class));
}
this.cards = new Cards(this);
this.spades.addView(cards);
+ // Attach to background service
+ this.register();
+
} catch (Exception e) {
Os.debug("Error setting content view", e);
return;
@Override
public boolean onPrepareOptionsMenu(Menu menu)
{
- menu.findItem(R.id.connect).setVisible(!this.ready);
- menu.findItem(R.id.disconnect).setVisible(this.ready);
+ menu.findItem(R.id.connect).setVisible(!this.running);
+ menu.findItem(R.id.disconnect).setVisible(this.running);
return true;
}
{
switch (item.getItemId()) {
case R.id.connect:
- this.startService();
+ this.connect();
return true;
case R.id.disconnect:
- this.stopService();
+ this.disconnect();
return true;
case R.id.settings:
this.startActivity(new Intent(this, Prefs.class));
return true;
case R.id.exit:
- this.stopService();
+ this.exit();
this.finish();
return true;
default:
{
switch (msg.what) {
case Task.REGISTER:
- Main.this.onRegister(msg.obj);
+ Main.this.onRegister((Task)msg.obj);
break;
case Task.MESSAGE:
- Main.this.onMessage(msg.obj);
+ Main.this.onMessage((Message)msg.obj);
break;
case Task.CONNECT:
- Main.this.ready = true;
+ Main.this.running = true;
break;
case Task.DISCONNECT:
- Main.this.ready = false;
+ Main.this.running = false;
break;
case Task.NOTIFY:
Main.this.onNotify((String)msg.obj);
package org.pileus.spades;
+import java.util.List;
+import java.util.LinkedList;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
+
import android.app.Notification;
import android.app.PendingIntent;
import android.app.Service;
private Messenger messenger;
private Thread thread;
private Client client;
+ private List<Object> log;
+ private Lock lock;
/* Private methods */
private void command(int cmd, Object value)
{
+ if (cmd == MESSAGE || cmd == NOTIFY) {
+ this.lock.lock();
+ this.log.add(value);
+ this.lock.unlock();
+ }
try {
android.os.Message msg = android.os.Message.obtain();
msg.what = cmd;
this.startForeground(1, note);
}
+ private void handle(int cmd, Messenger mgr)
+ {
+ // Setup communication with Main
+ if (cmd == REGISTER) {
+ Os.debug("Task: handle - register");
+ this.messenger = mgr;
+ this.command(REGISTER, this);
+ }
+
+ // Create client thread
+ if (cmd == CONNECT && this.thread == null) {
+ Os.debug("Task: handle - connect");
+ this.thread = new Thread(this);
+ this.thread.start();
+ }
+
+ // Stop client thread
+ if (cmd == DISCONNECT && this.thread != null) {
+ Os.debug("Task: handle - register");
+ try {
+ this.client.abort();
+ this.thread.join();
+ } catch (Exception e) {
+ Os.debug("Task: error stopping service", e);
+ }
+ }
+ }
+
/* Public methods */
public Message send(String txt)
{
return msg;
}
+ public List<Object> getLog()
+ {
+ this.lock.lock();
+ LinkedList<Object> out = new LinkedList<Object>(this.log);
+ this.lock.unlock();
+ return out;
+ }
+
+ public boolean isRunning()
+ {
+ return this.thread != null;
+ }
+
/* Runnable methods */
@Override
public void run()
Os.debug("Task: onCreate");
super.onCreate();
+ this.log = new LinkedList<Object>();
+ this.lock = new ReentrantLock();
this.client = new Client();
this.prefs = PreferenceManager.getDefaultSharedPreferences(this);
PreferenceManager.setDefaultValues(this, R.xml.prefs, false);
public void onDestroy()
{
Os.debug("Task: onDestroy");
- try {
- this.client.abort();
- this.thread.join();
- } catch (Exception e) {
- Os.debug("Task: error stopping service", e);
- }
+ this.handle(DISCONNECT, null);
}
@Override
{
Os.debug("Task: onStart");
super.onStart(intent, startId);
-
- // Setup communication with Main
- this.messenger = (Messenger)intent.getExtras().get("Messenger");
- this.command(REGISTER, this);
-
- // Create client thread
- if (this.thread == null) {
- this.thread = new Thread(this);
- this.thread.start();
- }
+ int cmd = intent.getExtras().getInt("Command");
+ Messenger mgr = (Messenger)intent.getExtras().get("Messenger");
+ this.handle(cmd, mgr);
}
@Override