summaryrefslogtreecommitdiff
path: root/altosui/altoslib/src
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2012-01-02 20:34:38 -0800
committerKeith Packard <keithp@keithp.com>2012-06-02 19:27:52 -0700
commit4c88b0ca96758b663c82395e63b338043d1c1a10 (patch)
tree84a9c45ece572b126a7ca8c8d20b45ae8e1736f6 /altosui/altoslib/src
parentead8f1cfca2c454d18dce56479899f2b423d8bdd (diff)
altosui: Move AltosConfigData.java to library
Create a new 'AltosLink' which exposes how to talk to the remote device abstractly via 'get_reply' and 'printf' methods. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'altosui/altoslib/src')
-rw-r--r--altosui/altoslib/src/org/altusmetrum/AltosLib/AltosConfigData.java13
-rw-r--r--altosui/altoslib/src/org/altusmetrum/AltosLib/AltosLink.java26
2 files changed, 29 insertions, 10 deletions
diff --git a/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosConfigData.java b/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosConfigData.java
index ef34dd3e..0bc5d5a8 100644
--- a/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosConfigData.java
+++ b/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosConfigData.java
@@ -17,11 +17,6 @@
package altosui;
-import java.awt.*;
-import java.awt.event.*;
-import javax.swing.*;
-import javax.swing.filechooser.FileNameExtensionFilter;
-import javax.swing.table.*;
import java.io.*;
import java.util.*;
import java.text.*;
@@ -29,8 +24,6 @@ import java.util.prefs.*;
import java.util.concurrent.*;
import org.altusmetrum.AltosLib.*;
-import libaltosJNI.*;
-
public class AltosConfigData implements Iterable<String> {
/* Version information */
@@ -138,14 +131,14 @@ public class AltosConfigData implements Iterable<String> {
return 0;
}
- public AltosConfigData(AltosSerial serial_line) throws InterruptedException, TimeoutException {
- serial_line.printf("c s\np\nf\nl\nv\n");
+ public AltosConfigData(AltosLink link) throws InterruptedException, TimeoutException {
+ link.printf("c s\np\nf\nl\nv\n");
lines = new LinkedList<String>();
radio_setting = 0;
radio_frequency = 0;
stored_flight = 0;
for (;;) {
- String line = serial_line.get_reply();
+ String line = link.get_reply();
if (line == null)
throw new TimeoutException();
if (line.contains("Syntax error"))
diff --git a/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosLink.java b/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosLink.java
new file mode 100644
index 00000000..80f3d712
--- /dev/null
+++ b/altosui/altoslib/src/org/altusmetrum/AltosLib/AltosLink.java
@@ -0,0 +1,26 @@
+/*
+ * Copyright © 2011 Keith Packard <keithp@keithp.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; version 2 of the License.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
+ */
+
+package org.altusmetrum.AltosLib;
+
+public interface AltosLink {
+ public void printf(String format, Object ... arguments) throws InterruptedException;
+
+ public String get_reply() throws InterruptedException;
+
+ public String get_reply(int timeout) throws InterruptedException;
+}