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_marshal_input.c | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 libterminput_marshal_input.c (limited to 'libterminput_marshal_input.c') diff --git a/libterminput_marshal_input.c b/libterminput_marshal_input.c new file mode 100644 index 0000000..9949838 --- /dev/null +++ b/libterminput_marshal_input.c @@ -0,0 +1,27 @@ +/* See LICENSE file for copyright and license details. */ +#include "common.h" + + +int +libterminput_marshal_input(struct libterminput_marshaller *how, const union libterminput_input *what) /* TODO test */ +{ + enum libterminput_type type = what->type; + if (how->store(how, &type, sizeof(type))) + return -1; + if (type == LIBTERMINPUT_NONE) { + if (what->keypress.key == LIBTERMINPUT_SYMBOL) + type = LIBTERMINPUT_KEYPRESS; + if (how->store(how, &type, sizeof(type))) + return -1; + } + if (type == LIBTERMINPUT_KEYPRESS) + return libterminput_marshal_keypress__(how, &what->keypress); + else if (type == LIBTERMINPUT_TEXT) + return libterminput_marshal_text__(how, &what->text); + else if (type == LIBTERMINPUT_MOUSEEVENT) + return libterminput_marshal_mouseevent__(how, &what->mouseevent); + else if (type == LIBTERMINPUT_CURSOR_POSITION) + return libterminput_marshal_position__(how, &what->position); + else + return 0; +} -- cgit v1.2.3-70-g09d2