Oops, CAN and SUB should abort the sequence (return to first state), not remain

in the same state.
This commit is contained in:
Nicholas Marriott 2009-06-25 15:53:44 +00:00
parent c3c14817c9
commit 4eed190649

View File

@ -1,4 +1,4 @@
/* $OpenBSD: input.c,v 1.4 2009/06/04 14:15:50 nicm Exp $ */ /* $OpenBSD: input.c,v 1.5 2009/06/04 14:24:49 nicm Exp $ */
/* /*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net> * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@ -400,6 +400,9 @@ input_state_sequence_first(u_char ch, struct input_ctx *ictx)
/* Abort sequence and begin with new. */ /* Abort sequence and begin with new. */
input_state(ictx, input_state_escape); input_state(ictx, input_state_escape);
} else if (ch != 0x18 && ch != 0x1a) { /* CAN and SUB */ } else if (ch != 0x18 && ch != 0x1a) { /* CAN and SUB */
/* Abort sequence. */
input_state(ictx, input_state_first);
} else {
/* Handle C0 immediately. */ /* Handle C0 immediately. */
input_handle_c0_control(ch, ictx); input_handle_c0_control(ch, ictx);
} }
@ -465,6 +468,9 @@ input_state_sequence_next(u_char ch, struct input_ctx *ictx)
/* Abort sequence and begin with new. */ /* Abort sequence and begin with new. */
input_state(ictx, input_state_escape); input_state(ictx, input_state_escape);
} else if (ch != 0x18 && ch != 0x1a) { /* CAN and SUB */ } else if (ch != 0x18 && ch != 0x1a) { /* CAN and SUB */
/* Abort sequence. */
input_state(ictx, input_state_first);
} else {
/* Handle C0 immediately. */ /* Handle C0 immediately. */
input_handle_c0_control(ch, ictx); input_handle_c0_control(ch, ictx);
} }