/* MIT License Copyright (c) 2019 Marcin Borowicz Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #include #include #include #include #include #include "../src/cat.h" static int32_t speed; static uint16_t adr; static uint8_t x; static uint8_t y; static uint8_t bytes_buf[4]; static char msg[16]; static bool quit_flag; static int x_write(const struct cat_variable *var, size_t write_size) { printf("x variable updated internally to: %u\n", x); return 0; } static int y_write(const struct cat_variable *var, size_t write_size) { printf("y variable updated internally to: %u\n", y); return 0; } static int msg_write(const struct cat_variable *var, size_t write_size) { printf("msg variable updated %lu bytes internally to: <%s>\n", write_size, msg); return 0; } static int speed_write(const struct cat_variable *var, size_t write_size) { printf("speed variable updated internally to: %d\n", speed); return 0; } static int adr_write(const struct cat_variable *var, size_t write_size) { printf("adr variable updated internally to: 0x%04X\n", adr); return 0; } static int bytesbuf_write(const struct cat_variable *var, size_t write_size) { int i = 0; printf("bytes_buf variable updated %lu bytes internally to: ", write_size); for (i = 0; i < sizeof(bytes_buf); i++) printf("%02X", bytes_buf[i]); printf("\n"); return 0; } static int go_write(const struct cat_command *cmd, const uint8_t *data, const size_t data_size, const size_t args_num) { int i = 0; printf("<%s>: x=%d y=%d msg=%s @ speed=%d\n", cmd->name, *(uint8_t*)(cmd->var[0].data), *(uint8_t*)(cmd->var[1].data), msg, speed ); printf(": "); for (i = 0; i < sizeof(bytes_buf); i++) printf("%02X", bytes_buf[i]); printf("\n"); return 0; } static int set_write(const struct cat_command *cmd, const uint8_t *data, const size_t data_size, const size_t args_num) { printf("<%s>: SET SPEED TO = %d\n", cmd->name, speed ); return 0; } static int set_read(const struct cat_command *cmd, uint8_t *data, size_t *data_size, const size_t max_data_size) { return 0; } static int test_run(const struct cat_command *cmd) { printf("TEST: <%s>", cmd->name); return 0; } static int quit_run(const struct cat_command *cmd) { printf("QUIT: <%s>", cmd->name); quit_flag = true; return 0; } static int print_cmd_list(const struct cat_command *cmd) { return CAT_RETURN_STATE_PRINT_CMD_LIST_OK; } static struct cat_variable go_vars[] = { { .type = CAT_VAR_UINT_DEC, .data = &x, .data_size = sizeof(x), .write = x_write, .name = "x" }, { .type = CAT_VAR_UINT_DEC, .data = &y, .data_size = sizeof(y), .write = y_write, .name = "y" }, { .type = CAT_VAR_BUF_STRING, .data = msg, .data_size = sizeof(msg), .write = msg_write, .name = "msg" } }; static struct cat_variable set_vars[] = { { .type = CAT_VAR_INT_DEC, .data = &speed, .data_size = sizeof(speed), .write = speed_write, .name = "speed" }, { .type = CAT_VAR_NUM_HEX, .data = &adr, .data_size = sizeof(adr), .write = adr_write, .name = "address" }, { .type = CAT_VAR_BUF_HEX, .data = &bytes_buf, .data_size = sizeof(bytes_buf), .write = bytesbuf_write, .name = "buffer" } }; static struct cat_command cmds[] = { { .name = "+GO", .write = go_write, .var = go_vars, .var_num = sizeof(go_vars) / sizeof(go_vars[0]), .need_all_vars = true }, { .name = "+SET", .write = set_write, .read = set_read, .var = set_vars, .var_num = sizeof(set_vars) / sizeof(set_vars[0]), }, { .name = "#TEST", .run = test_run }, { .name = "#HELP", .run = print_cmd_list, }, { .name = "#QUIT", .run = quit_run }, }; static char buf[128]; static struct cat_command_group cmd_group = { .cmd = cmds, .cmd_num = sizeof(cmds) / sizeof(cmds[0]), }; static struct cat_command_group *cmd_desc[] = { &cmd_group }; static struct cat_descriptor desc = { .cmd_group = cmd_desc, .cmd_group_num = sizeof(cmd_desc) / sizeof(cmd_desc[0]), .buf = buf, .buf_size = sizeof(buf) }; static int write_char(char ch) { putc(ch, stdout); return 1; } static int read_char(char *ch) { *ch = getc(stdin); return 1; } static struct cat_io_interface iface = { .read = read_char, .write = write_char }; int main(int argc, char **argv) { struct cat_object at; cat_init(&at, &desc, &iface, NULL); while ((cat_service(&at) != 0) && (quit_flag == 0)) {}; printf("Bye!\n"); return 0; }