From 24ebd3c309c5d6cad63bbf1b40de8c17aead0366 Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Wed, 19 Feb 2025 23:06:02 +0100 Subject: Add state marshalling and unmarshalling functions MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- libterminput_unmarshal_input.c | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 libterminput_unmarshal_input.c (limited to 'libterminput_unmarshal_input.c') diff --git a/libterminput_unmarshal_input.c b/libterminput_unmarshal_input.c new file mode 100644 index 0000000..ef8606c --- /dev/null +++ b/libterminput_unmarshal_input.c @@ -0,0 +1,30 @@ +/* See LICENSE file for copyright and license details. */ +#include "common.h" + + +int +libterminput_unmarshal_input(struct libterminput_unmarshaller *how, union libterminput_input *what) /* TODO test */ +{ + enum libterminput_type type; + int r; + if (how->load(how, &what->type, sizeof(what->type))) + return -1; + type = what->type; + if (what->type == LIBTERMINPUT_NONE) { + what->keypress.key = LIBTERMINPUT_SYMBOL; + if (how->load(how, &what->type, sizeof(what->type))) + return -1; + } + if (what->type == LIBTERMINPUT_KEYPRESS) + r = libterminput_unmarshal_keypress__(how, &what->keypress); + else if (what->type == LIBTERMINPUT_TEXT) + r = libterminput_unmarshal_text__(how, &what->text); + else if (what->type == LIBTERMINPUT_MOUSEEVENT) + r = libterminput_unmarshal_mouseevent__(how, &what->mouseevent); + else if (what->type == LIBTERMINPUT_CURSOR_POSITION) + r = libterminput_unmarshal_position__(how, &what->position); + else + r = 0; + what->type = type; + return r; +} -- cgit v1.2.3-70-g09d2