patch 8.0.1674: libvterm can't handle an OSC string split
Problem: Libvterm can't handle a long OSC string that is split.
Solution: When an incomplete OSC string is received copy it to the parser
buffer. Increase the size of the parser buffer to be able to
handle longer strings.
diff --git a/src/libvterm/src/parser.c b/src/libvterm/src/parser.c
index c71ea8d..b07bb94 100644
--- a/src/libvterm/src/parser.c
+++ b/src/libvterm/src/parser.c
@@ -288,6 +288,11 @@
done_string(vt, string_start, bytes + pos - string_start);
ENTER_NORMAL_STATE();
}
+ else if (pos + 1 == len) {
+ /* end of input but OSC string isn't finished yet, copy it to
+ * vt->parser.strbuffer to continue it later */
+ more_string(vt, string_start, bytes + pos + 1 - string_start);
+ }
break;
case NORMAL:
diff --git a/src/libvterm/src/vterm.c b/src/libvterm/src/vterm.c
index d9f0e20..f066b01 100644
--- a/src/libvterm/src/vterm.c
+++ b/src/libvterm/src/vterm.c
@@ -52,7 +52,7 @@
vt->parser.callbacks = NULL;
vt->parser.cbdata = NULL;
- vt->parser.strbuffer_len = 64;
+ vt->parser.strbuffer_len = 500; /* should be able to hold an OSC string */
vt->parser.strbuffer_cur = 0;
vt->parser.strbuffer = vterm_allocator_malloc(vt, vt->parser.strbuffer_len);
diff --git a/src/version.c b/src/version.c
index 9f06579..e95a62d 100644
--- a/src/version.c
+++ b/src/version.c
@@ -763,6 +763,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1674,
+/**/
1673,
/**/
1672,