aboutsummaryrefslogtreecommitdiff
path: root/shared/test.c
diff options
context:
space:
mode:
Diffstat (limited to 'shared/test.c')
-rw-r--r--shared/test.c50
1 files changed, 37 insertions, 13 deletions
diff --git a/shared/test.c b/shared/test.c
index 0968252..287332a 100644
--- a/shared/test.c
+++ b/shared/test.c
@@ -6,34 +6,40 @@
#include <string.h>
#include "protocol.h"
+#include "backlog.h"
+#include "util.h"
void ws_protocol_res_last_records(ws_s_protocol_parsed_req_cmd* parsed_cmd, ws_s_protocol_res* response, bool send) {
- const char* response_text = ""
- "id,temperature,humidity,atmospheric_pressure\n"
- "10dc,2f,c5,7f\n"
- "10dd,30,c6,7f\n"
- "10de,31,c7,7f\n"
- "10df,35,ca,7e\n"
- "10e0,34,c9,7e\n";
+ static unsigned int record_amount = 0;
+ const char* response_header = "id,temperature,humidity,atmospheric_pressure\n";
+ const size_t response_line_size = sizeof("xxxx,xx,xx,xx\n");
if (!send) {
response->success = WS_PROTOCOL_CMD_RETURN_OK;
+ if (sscanf(parsed_cmd->argv[1], "%u", &record_amount) < 1) response->success = WS_PROTOCOL_CMD_RETURN_ERROR;
+ record_amount = WS_MIN(record_amount, ws_backlog_get_record_count());
response->csh = true;
response->msg = ws_bin_s_alloc(0);
- response->msg->bytes = strlen(response_text);
+ response->msg->bytes = strlen(response_header) + response_line_size * record_amount;
} else {
// example send routine
- ws_s_bin* response_test = ws_bin_s_alloc(strlen(response_text));
- strncpy((char*) response_test->data, response_text, strlen(response_text));
- ws_protocol_send_data(response_test);
+ ws_protocol_send_data(response_header, strlen(response_header));
+ char line[response_line_size + 1]; // +1 for null terminator -> sprintf
+ for (unsigned int i = 0; i < record_amount; i++) {
+ ws_s_backlog_record* record = ws_backlog_get_last_record(i);
+ sprintf(line, "%04x,%02x,%02x,%02x\n", record->id, record->sens_temperature, record->sens_humidity, record->sens_atm_pressure);
+ ws_protocol_send_data(line, response_line_size);
+ }
}
}
-void ws_protocol_send_data(ws_s_bin* data) {
- printf("%.*s", data->bytes, data->data);
+void ws_protocol_send_data(const char* data, unsigned int length) {
+ printf("%.*s", length, data);
}
int main() {
+ ws_backlog_alloc(10);
+
// disable echo and enable raw mode
fcntl(STDIN_FILENO, F_SETFL, O_NONBLOCK);
struct termios term;
@@ -45,6 +51,24 @@ int main() {
ws_s_protocol_req_parser_state* parser1 = ws_protocol_req_parser_alloc();
+ ws_backlog_add_record((ws_s_backlog_record) {
+ .sens_temperature = 0x29,
+ .sens_humidity = 0x34,
+ .sens_atm_pressure = 0x69,
+ });
+
+ ws_backlog_add_record((ws_s_backlog_record) {
+ .sens_temperature = 0x00,
+ .sens_humidity = 0x00,
+ .sens_atm_pressure = 0x00,
+ });
+
+ ws_backlog_add_record((ws_s_backlog_record) {
+ .sens_temperature = 0x01,
+ .sens_humidity = 0x01,
+ .sens_atm_pressure = 0x01,
+ });
+
fflush(stdout);
char byte;