summaryrefslogtreecommitdiff
path: root/regress/lib/libedit/read/test_read_char.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@cvs.openbsd.org>2016-02-11 15:37:21 +0000
committerIngo Schwarze <schwarze@cvs.openbsd.org>2016-02-11 15:37:21 +0000
commitc8f415f56ec08c1882b84869abd96ff384b0df47 (patch)
treed47cea5204e2b20b805b5e6d6e9253015c30ff43 /regress/lib/libedit/read/test_read_char.c
parente78ab6e0d496e6e1ec2748d74cc02da4d647e937 (diff)
Slowly start a unit test suite for libedit; Christos is right that
fiddling with the internals of that code is dangerous without it. Intentionally not linked to the build yet, because many of the tests still fail: The related bugfixes are too intrusive right now and will go in after unlock.
Diffstat (limited to 'regress/lib/libedit/read/test_read_char.c')
-rw-r--r--regress/lib/libedit/read/test_read_char.c114
1 files changed, 114 insertions, 0 deletions
diff --git a/regress/lib/libedit/read/test_read_char.c b/regress/lib/libedit/read/test_read_char.c
new file mode 100644
index 00000000000..94487134c05
--- /dev/null
+++ b/regress/lib/libedit/read/test_read_char.c
@@ -0,0 +1,114 @@
+/*
+ * Copyright (c) 2016 Ingo Schwarze <schwarze@openbsd.org>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <err.h>
+#include <locale.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "read.c"
+
+/*
+ * Glue for unit tests of libedit/read.c.
+ * Rather than linking in all the various libedit modules,
+ * provide dummies for those functions called in read.c.
+ * Most aren't actually called in read_char().
+ * Requires "make obj && make depend" in src/lib/libedit.
+ */
+
+#define EL EditLine *el __attribute__((__unused__))
+#define UU __attribute__((__unused__))
+
+int ch_enlargebufs(EL, size_t addlen UU) { return 1; }
+void ch_reset(EL, int mclear UU) { }
+void el_resize(EL) { }
+int el_set(EL, int op UU, ...) { return 0; }
+void re_clear_display(EL) { }
+void re_clear_lines(EL) { }
+void re_refresh(EL) { }
+void re_refresh_cursor(EL) { }
+void sig_clr(EL) { }
+void sig_set(EL) { }
+void terminal__flush(EL) { }
+void terminal_beep(EL) { }
+int tty_cookedmode(EL) { return 0; }
+int tty_rawmode(EL) { return 0; }
+
+int
+keymacro_get(EL, Char *ch, keymacro_value_t *val)
+{
+ val->str = NULL;
+ *ch = '\0';
+ return XK_STR;
+}
+
+#undef EL
+#undef UU
+
+/*
+ * Unit test steering program for editline/read.c, read_char().
+ * Reads from standard input until read_char() returns 0.
+ * Writes the code points read to standard output in %x format.
+ * If EILSEQ is set after read_char(), indicating that there were some
+ * garbage bytes before the character, the code point gets * prefixed.
+ * The return value is indicated by appending to the code point:
+ * a comma for 1, a full stop for 0, [%d] otherwise.
+ * Errors out on unexpected failure (setlocale failure, malloc
+ * failure, or unexpected errno).
+ * Since ENOMSG is very unlikely to occur, it is used to make
+ * sure that read_char() doesn't clobber errno.
+ */
+
+int
+main(void)
+{
+ EditLine el;
+ int irc;
+ Char cp;
+
+ if (setlocale(LC_CTYPE, "en_US.UTF-8") == NULL)
+ err(1, "setlocale");
+ el.el_flags = CHARSET_IS_UTF8;
+ el.el_infd = STDIN_FILENO;
+ if ((el.el_signal = calloc(1, sizeof(*el.el_signal))) == NULL)
+ err(1, NULL);
+ do {
+ errno = ENOMSG;
+ irc = read_char(&el, &cp);
+ switch (errno) {
+ case ENOMSG:
+ break;
+ case EILSEQ:
+ putchar('*');
+ break;
+ default:
+ err(1, NULL);
+ }
+ printf("%x", cp);
+ switch (irc) {
+ case 1:
+ putchar(',');
+ break;
+ case 0:
+ putchar('.');
+ break;
+ default:
+ printf("[%d]", irc);
+ break;
+ }
+ } while (irc != 0);
+ return 0;
+}