forked from Atlas-Scientific/Ezo_I2c_lib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEzo_i2c_util.cpp
46 lines (37 loc) · 1.99 KB
/
Ezo_i2c_util.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#include <Ezo_i2c_util.h>
// prints the boards name and I2C address
void print_device_info(Ezo_board &Device) {
Serial.print(Device.get_name());
Serial.print(" ");
Serial.print(Device.get_address());
}
// used for printing either a success_string message if a command was successful or the error type if it wasnt
void print_success_or_error(Ezo_board &Device, const char* success_string) {
switch (Device.get_error()) { //switch case based on what the response code is.
case Ezo_board::SUCCESS:
Serial.print(success_string); //the command was successful, print the success string
break;
case Ezo_board::FAIL:
Serial.print("Failed "); //means the command has failed.
break;
case Ezo_board::NOT_READY:
Serial.print("Pending "); //the command has not yet been finished calculating.
break;
case Ezo_board::NO_DATA:
Serial.print("No Data "); //the sensor has no data to send.
break;
}
}
void receive_and_print_response(Ezo_board &Device) {
char receive_buffer[32]; //buffer used to hold each boards response
Device.receive_cmd(receive_buffer, 32); //put the response into the buffer
print_success_or_error(Device, " - "); //print if our response is an error or not
print_device_info(Device); //print our boards name and address
Serial.print(": ");
Serial.println(receive_buffer); //print the boards response
}
void receive_and_print_reading(Ezo_board &Device) { // function to decode the reading after the read command was issued
Serial.print(Device.get_name()); Serial.print(": "); // print the name of the circuit getting the reading
Device.receive_read_cmd(); //get the response data and put it into the [Device].reading variable if successful
print_success_or_error(Device, String(Device.get_last_received_reading(), 2).c_str()); //print either the reading or an error message
}