2 * Copyright © 2010 Keith Packard <keithp@keithp.com>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; version 2 of the License.
8 * This program is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
13 * You should have received a copy of the GNU General Public License along
14 * with this program; if not, write to the Free Software Foundation, Inc.,
15 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
18 package org.altusmetrum.altoslib_2;
24 class AltosTelemetryOrdered implements Comparable<AltosTelemetryOrdered> {
29 public int compareTo(AltosTelemetryOrdered o) {
30 int tick_diff = tick - o.tick;
34 return index - o.index;
37 AltosTelemetryOrdered (AltosTelemetry telem, int index, int tick) {
44 class AltosTelemetryOrderedIterator implements Iterator<AltosTelemetry> {
45 TreeSet<AltosTelemetryOrdered> olist;
46 Iterator<AltosTelemetryOrdered> oiterator;
48 public AltosTelemetryOrderedIterator(Iterable<AltosTelemetry> telems) {
49 olist = new TreeSet<AltosTelemetryOrdered>();
55 for (AltosTelemetry e : telems) {
60 while (t < tick - 32767)
64 olist.add(new AltosTelemetryOrdered(e, index++, tick));
68 oiterator = olist.iterator();
71 public boolean hasNext() {
72 return oiterator.hasNext();
75 public AltosTelemetry next() {
76 return oiterator.next().telem;
79 public void remove () {
83 public class AltosTelemetryIterable implements Iterable<AltosTelemetry> {
84 LinkedList<AltosTelemetry> telems;
86 public Iterator<AltosTelemetry> iterator () {
88 telems = new LinkedList<AltosTelemetry>();
89 return new AltosTelemetryOrderedIterator(telems);
92 public AltosTelemetryIterable (FileInputStream input) {
93 telems = new LinkedList<AltosTelemetry> ();
97 String line = AltosLib.gets(input);
102 AltosTelemetry telem = AltosTelemetry.parse(line);
106 } catch (ParseException pe) {
107 System.out.printf("parse exception %s\n", pe.getMessage());
108 } catch (AltosCRCException ce) {
111 } catch (IOException io) {
112 System.out.printf("io exception\n");