Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F97196988
D35552.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
2 KB
Referenced Files
None
Subscribers
None
D35552.diff
View Options
diff --git a/sys/dev/vt/vt_buf.c b/sys/dev/vt/vt_buf.c
--- a/sys/dev/vt/vt_buf.c
+++ b/sys/dev/vt/vt_buf.c
@@ -741,8 +741,8 @@
si = s.tp_row * vb->vb_scr_size.tp_col + s.tp_col;
ei = e.tp_row * vb->vb_scr_size.tp_col + e.tp_col;
- /* Number symbols and number of rows to inject \n */
- sz = ei - si + ((e.tp_row - s.tp_row) * 2);
+ /* Number symbols and number of rows to inject \r */
+ sz = ei - si + (e.tp_row - s.tp_row);
return (sz * sizeof(term_char_t));
}
@@ -750,7 +750,7 @@
void
vtbuf_extract_marked(struct vt_buf *vb, term_char_t *buf, int sz)
{
- int i, r, c, cs, ce;
+ int i, j, r, c, cs, ce;
term_pos_t s, e;
/* Swap according to window coordinates. */
@@ -769,15 +769,28 @@
for (r = s.tp_row; r <= e.tp_row; r++) {
cs = (r == s.tp_row)?s.tp_col:0;
ce = (r == e.tp_row)?e.tp_col:vb->vb_scr_size.tp_col;
- for (c = cs; c < ce; c++) {
+
+ /* Copy characters from terminal window. */
+ j = i;
+ for (c = cs; c < ce; c++)
buf[i++] = vb->vb_rows[r][c];
- }
- /* Add new line for all rows, but not for last one. */
+
+ /* For all rows, but the last one. */
if (r != e.tp_row) {
+ /* Trim trailing word separators, if any. */
+ for (; i != j; i--) {
+ if (TCHAR_CHARACTER(buf[i - 1]) != ' ')
+ break;
+ }
+ /* Add newline character as expected by TTY. */
buf[i++] = '\r';
- buf[i++] = '\n';
}
}
+ /* Zero rest of expected buffer size, if any. */
+ while ((i * sizeof(buf[0])) < sz)
+ buf[i++] = '\0';
+
+ MPASS((i * sizeof(buf[0])) == sz);
}
int
diff --git a/sys/dev/vt/vt_core.c b/sys/dev/vt/vt_core.c
--- a/sys/dev/vt/vt_core.c
+++ b/sys/dev/vt/vt_core.c
@@ -2135,7 +2135,7 @@
buf = VD_PASTEBUF(main_vd);
len /= sizeof(term_char_t);
for (i = 0; i < len; i++) {
- if (buf[i] == '\0')
+ if (TCHAR_CHARACTER(buf[i]) == '\0')
continue;
terminal_input_char(main_vd->vd_curwindow->vw_terminal,
buf[i]);
@@ -2287,8 +2287,7 @@
VD_PASTEBUFSZ(vd) = len;
}
/* Request copy/paste buffer data, no more than `len' */
- vtbuf_extract_marked(&vw->vw_buf, VD_PASTEBUF(vd),
- VD_PASTEBUFSZ(vd));
+ vtbuf_extract_marked(&vw->vw_buf, VD_PASTEBUF(vd), len);
VD_PASTEBUFLEN(vd) = len;
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Sun, Sep 29, 3:21 AM (22 h, 1 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
13094272
Default Alt Text
D35552.diff (2 KB)
Attached To
Mode
D35552: vt: Fix contents of paste buffer for newcons.
Attached
Detach File
Event Timeline
Log In to Comment