ref: 9f2eef876275a451b015c22961130b2e507ddd49
parent: e29d8a3ecad734967cdcf2d4ce222ab27e9c524b
author: Ben Harris <[email protected]>
date: Sat Oct 15 17:25:08 EDT 2022
Add assertions that game descriptions consist only of printable ASCII. That they are ASCII is implied by their inclusion in save files. Nothing requires an absence of control characters, but it seems polite to make them slightly readable.
--- a/midend.c
+++ b/midend.c
@@ -395,6 +395,14 @@
return encoded;
}
+static void assert_printable_ascii(char const *s)
+{
+ /* Assert that s is entirely printable ASCII, and hence safe for
+ * writing in a save file. */
+ for (int i = 0; s[i]; i++)
+ assert(s[i] >= 32 && s[i] < 127);
+}
+
static void midend_set_timer(midend *me)
{
me->timing = (me->ourgame->is_timed &&
@@ -503,6 +511,7 @@
*/
me->desc = me->ourgame->new_desc(me->curparams, rs,
&me->aux_info, (me->drawing != NULL));
+ assert_printable_ascii(me->desc);
me->privdesc = NULL;
random_free(rs);
}
@@ -926,6 +935,7 @@
if (movestr == UI_UPDATE)
s = me->states[me->statepos-1].state;
else {
+ assert_printable_ascii(movestr);
s = me->ourgame->execute_move(me->states[me->statepos-1].state,
movestr);
assert(s != NULL);
@@ -1539,6 +1549,10 @@
void midend_supersede_game_desc(midend *me, const char *desc,
const char *privdesc)
{
+ /* Assert that the descriptions consists only of printable ASCII. */
+ assert_printable_ascii(desc);
+ if (privdesc)
+ assert_printable_ascii(privdesc);
sfree(me->desc);
sfree(me->privdesc);
me->desc = dupstr(desc);
@@ -1898,6 +1912,7 @@
msg = "Solve operation failed"; /* _shouldn't_ happen, but can */
return msg;
}
+ assert_printable_ascii(movestr);
s = me->ourgame->execute_move(me->states[me->statepos-1].state, movestr);
assert(s);
@@ -2081,6 +2096,7 @@
*/
if (me->ui) {
char *s = me->ourgame->encode_ui(me->ui);
+ assert_printable_ascii(s);
if (s) {
wr("UI", s);
sfree(s);