* line in a queue. Dealing with that queue is left up to other
* threads.
*/
-class AltosSerialReader implements Runnable {
+
+public class AltosSerial implements Runnable {
+
SWIGTYPE_p_altos_file altos;
LinkedList<LinkedBlockingQueue<String>> monitors;
LinkedBlockingQueue<String> reply_queue;
}
}
+ public void putc(char c) {
+ libaltos.altos_putchar(altos, c);
+ }
+
+ public void print(String data) {
+ for (int i = 0; i < data.length(); i++)
+ putc(data.charAt(i));
+ }
+
+ public void printf(String format, Object ... arguments) {
+ print(String.format(format, arguments));
+ }
+
public void open(altos_device device) throws FileNotFoundException {
close();
altos = libaltos.altos_open(device);
input_thread = new Thread(this);
input_thread.start();
}
- public AltosSerialReader () {
+
+ public AltosSerial() {
altos = null;
input_thread = null;
line = "";
reply_queue = new LinkedBlockingQueue<String> ();
}
}
-
-public class AltosSerial {
- AltosSerialReader reader = null;
-
- public void close() {
- reader.close();
- }
-
- public void open(altos_device device) throws FileNotFoundException {
- reader.open(device);
- }
-
- void init() {
- reader = new AltosSerialReader();
- }
-
- public void add_monitor(LinkedBlockingQueue<String> q) {
- reader.add_monitor(q);
- }
-
- public void remove_monitor(LinkedBlockingQueue<String> q) {
- reader.remove_monitor(q);
- }
-
- public AltosSerial() {
- init();
- }
-
- public AltosSerial(altos_device device) throws FileNotFoundException {
- init();
- open(device);
- }
-}
flightInfoModel[col].addRow(name, value);
}
- public void info_add_row(int col, String name, String format, Object value) {
- flightInfoModel[col].addRow(name, String.format(format, value));
- }
-
- public void info_add_row(int col, String name, String format, Object v1, Object v2) {
- flightInfoModel[col].addRow(name, String.format(format, v1, v2));
- }
-
- public void info_add_row(int col, String name, String format, Object v1, Object v2, Object v3) {
- flightInfoModel[col].addRow(name, String.format(format, v1, v2, v3));
+ public void info_add_row(int col, String name, String format, Object... parameters) {
+ flightInfoModel[col].addRow(name, String.format(format, parameters));
}
public void info_add_deg(int col, String name, double v, int pos, int neg) {
/* If the rocket isn't on the pad, then report height */
if (state.state > AltosTelemetry.ao_flight_pad) {
- voice.speak(String.format("%d meters", (int) (state.height + 0.5)));
+ voice.speak("%d meters", (int) (state.height + 0.5));
}
/* If the rocket is coming down, check to see if it has landed;
else
voice.speak("rocket may have crashed");
if (state.gps != null)
- voice.speak(String.format("bearing %d degrees, range %d meters",
- (int) (state.from_pad.bearing + 0.5),
- (int) (state.from_pad.distance + 0.5)));
+ voice.speak("bearing %d degrees, range %d meters",
+ (int) (state.from_pad.bearing + 0.5),
+ (int) (state.from_pad.distance + 0.5));
++reported_landing;
}
}
voice.speak(state.data.state);
switch (state.state) {
case AltosTelemetry.ao_flight_fast:
- voice.speak(String.format("max speed %d meters per second",
- (int) (state.max_speed + 0.5)));
+ voice.speak("max speed %d meters per second",
+ (int) (state.max_speed + 0.5));
break;
case AltosTelemetry.ao_flight_drogue:
- voice.speak(String.format("max height %d meters",
- (int) (state.max_height + 0.5)));
+ voice.speak("max height %d meters",
+ (int) (state.max_height + 0.5));
break;
}
}