X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=altoslib%2FAltosEepromList.java;h=a9551d85b4b9b97924c1072c192caac93e853724;hp=740499d302139f7c353110e8006291815ca52e5e;hb=HEAD;hpb=bd440afc2a6e37b74fffcf1b977e149485095316 diff --git a/altoslib/AltosEepromList.java b/altoslib/AltosEepromList.java index 740499d3..0d15fa5a 100644 --- a/altoslib/AltosEepromList.java +++ b/altoslib/AltosEepromList.java @@ -3,7 +3,8 @@ * * 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. + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of @@ -15,7 +16,7 @@ * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ -package org.altusmetrum.altoslib_5; +package org.altusmetrum.altoslib_14; import java.io.*; import java.util.*; @@ -38,6 +39,12 @@ class AltosEepromFlight { start = in_start; end = in_end; } + + public AltosEepromFlight() { + flight = 0; + start = 0; + end = 0; + } } /* @@ -54,59 +61,17 @@ public class AltosEepromList extends ArrayList { if (remote) link.start_remote(); config_data = new AltosConfigData (link); -// if (config_data.serial == 0) -// throw new IOException("no serial number found"); - - ArrayList flights = new ArrayList(); - - if (config_data.flight_log_max != 0 || config_data.log_format != 0) { - - /* Devices with newer firmware will support the 'l' - * command which will list the region of storage - * occupied by each available flight - */ - link.printf("l\n"); - for (;;) { - String line = link.get_reply(5000); - if (line == null) - throw new TimeoutException(); - if (line.contains("done")) - break; - if (line.contains("Syntax")) - continue; - String[] tokens = line.split("\\s+"); - if (tokens.length < 6) - break; - - int flight = -1, start = -1, end = -1; - try { - if (tokens[0].equals("flight")) - flight = AltosParse.parse_int(tokens[1]); - if (tokens[2].equals("start")) - start = AltosParse.parse_hex(tokens[3]); - if (tokens[4].equals("end")) - end = AltosParse.parse_hex(tokens[5]); - if (flight > 0 && start >= 0 && end > 0) - flights.add(new AltosEepromFlight(flight, start, end)); - } catch (ParseException pe) { System.out.printf("Parse error %s\n", pe.toString()); } - } - } else { - - /* Older devices will hold only a single - * flight. This also assumes that any older - * device will have a 1MB flash device - */ - flights.add(new AltosEepromFlight(0, 0, 0xfff)); - } /* With the list of flights collected, collect more complete * information on them by reading the first block or two of * data. This will add GPS coordinates and a date. For older * firmware, this will also extract the flight number. */ - for (AltosEepromFlight flight : flights) { - add(new AltosEepromLog(config_data, link, - flight.flight, flight.start, flight.end)); + if (config_data.flights != null) { + for (AltosEepromFlight flight : config_data.flights) { + add(new AltosEepromLog(config_data, link, + flight.flight, flight.start, flight.end)); + } } } finally { if (remote) @@ -114,4 +79,4 @@ public class AltosEepromList extends ArrayList { link.flush_output(); } } -} \ No newline at end of file +}