diff options
Diffstat (limited to 'altoslib/AltosSensorTM.java')
| -rw-r--r-- | altoslib/AltosSensorTM.java | 82 | 
1 files changed, 36 insertions, 46 deletions
| diff --git a/altoslib/AltosSensorTM.java b/altoslib/AltosSensorTM.java index 75158cbf..754dc5bb 100644 --- a/altoslib/AltosSensorTM.java +++ b/altoslib/AltosSensorTM.java @@ -15,7 +15,7 @@   * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.   */ -package org.altusmetrum.AltosLib; +package org.altusmetrum.altoslib_1;  import java.util.concurrent.TimeoutException; @@ -23,54 +23,44 @@ class AltosSensorTM extends AltosRecordTM {  	public AltosSensorTM(AltosLink link, AltosConfigData config_data) throws InterruptedException, TimeoutException {  		super(); -		link.printf("a\n"); -		for (;;) { -			String line = link.get_reply_no_dialog(5000); -			if (line == null) { -				throw new TimeoutException(); +		String[] items = link.adc(); +		for (int i = 0; i < items.length;) { +			if (items[i].equals("tick:")) { +				tick = Integer.parseInt(items[i+1]); +				i += 2; +				continue; +			} +			if (items[i].equals("accel:")) { +				accel = Integer.parseInt(items[i+1]); +				i += 2; +				continue; +			} +			if (items[i].equals("pres:")) { +				pres = Integer.parseInt(items[i+1]); +				i += 2; +				continue; +			} +			if (items[i].equals("temp:")) { +				temp = Integer.parseInt(items[i+1]); +				i += 2; +				continue; +			} +			if (items[i].equals("batt:")) { +				batt = Integer.parseInt(items[i+1]); +				i += 2; +				continue; +			} +			if (items[i].equals("drogue:")) { +				drogue = Integer.parseInt(items[i+1]); +				i += 2; +				continue;  			} -			if (!line.startsWith("tick:")) +			if (items[i].equals("main:")) { +				main = Integer.parseInt(items[i+1]); +				i += 2;  				continue; -			String[] items = line.split("\\s+"); -			for (int i = 0; i < items.length;) { -				if (items[i].equals("tick:")) { -					tick = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				if (items[i].equals("accel:")) { -					accel = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				if (items[i].equals("pres:")) { -					pres = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				if (items[i].equals("temp:")) { -					temp = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				if (items[i].equals("batt:")) { -					batt = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				if (items[i].equals("drogue:")) { -					drogue = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				if (items[i].equals("main:")) { -					main = Integer.parseInt(items[i+1]); -					i += 2; -					continue; -				} -				i++;  			} -			break; +			i++;  		}  		ground_accel = config_data.accel_cal_plus;  		ground_pres = pres; | 
