altoslib, altosui: Restructured state management now does TM eeprom files
[fw/altos] / altoslib / AltosTelemetryReader.java
index f365b82118eb320e6fd8421d804517db95818af6..3915927c5df0666714af79a3a90700eb15f02f69 100644 (file)
@@ -27,16 +27,18 @@ public class AltosTelemetryReader extends AltosFlightReader {
        AltosRecord     previous;
        double          frequency;
        int             telemetry;
+       AltosState      state = null;
 
        LinkedBlockingQueue<AltosLine> telem;
 
-       public AltosRecord read() throws InterruptedException, ParseException, AltosCRCException, IOException {
+       public AltosState read() throws InterruptedException, ParseException, AltosCRCException, IOException {
                AltosLine l = telem.take();
                if (l.line == null)
                        throw new IOException("IO error");
                AltosRecord     next = AltosTelemetry.parse(l.line, previous);
                previous = next;
-               return next;
+               state = new AltosState (next, state);
+               return state;
        }
 
        public void flush() {
@@ -107,6 +109,14 @@ public class AltosTelemetryReader extends AltosFlightReader {
                return log.file();
        }
 
+       public boolean has_monitor_battery() {
+               return link.has_monitor_battery();
+       }
+
+       public double monitor_battery() {
+               return link.monitor_battery();
+       }
+
        public AltosTelemetryReader (AltosLink in_link)
                throws IOException, InterruptedException, TimeoutException {
                link = in_link;