svn commit: r259129 - in head/sys/dev/vt: . font
Aleksandr Rybalko
ray at FreeBSD.org
Mon Dec 9 15:01:35 UTC 2013
Author: ray
Date: Mon Dec 9 15:01:34 2013
New Revision: 259129
URL: http://svnweb.freebsd.org/changeset/base/259129
Log:
Respect SC_NO_CUTPASTE option. It disable mouse cursor and cut/paste support
for vt(9). Note: /dev/sysmouse not affected.
Sponsored by: The FreeBSD Foundation
Modified:
head/sys/dev/vt/font/vt_mouse_cursor.c
head/sys/dev/vt/vt.h
head/sys/dev/vt/vt_buf.c
head/sys/dev/vt/vt_core.c
head/sys/dev/vt/vt_sysmouse.c
Modified: head/sys/dev/vt/font/vt_mouse_cursor.c
==============================================================================
--- head/sys/dev/vt/font/vt_mouse_cursor.c Mon Dec 9 13:44:07 2013 (r259128)
+++ head/sys/dev/vt/font/vt_mouse_cursor.c Mon Dec 9 15:01:34 2013 (r259129)
@@ -32,6 +32,7 @@ __FBSDID("$FreeBSD$");
#include <dev/vt/vt.h>
+#ifndef SC_NO_CUTPASTE
struct mouse_cursor vt_default_mouse_pointer = {
.map = {
0x00, /* "__ " */
@@ -66,3 +67,4 @@ struct mouse_cursor vt_default_mouse_poi
.w = 8,
.h = 13,
};
+#endif
Modified: head/sys/dev/vt/vt.h
==============================================================================
--- head/sys/dev/vt/vt.h Mon Dec 9 13:44:07 2013 (r259128)
+++ head/sys/dev/vt/vt.h Mon Dec 9 15:01:34 2013 (r259129)
@@ -181,15 +181,17 @@ void vtbuf_init(struct vt_buf *, const t
void vtbuf_grow(struct vt_buf *, const term_pos_t *, int);
void vtbuf_putchar(struct vt_buf *, const term_pos_t *, term_char_t);
void vtbuf_cursor_position(struct vt_buf *, const term_pos_t *);
-void vtbuf_mouse_cursor_position(struct vt_buf *vb, int col, int row);
-void vtbuf_cursor_visibility(struct vt_buf *, int);
void vtbuf_scroll_mode(struct vt_buf *vb, int yes);
void vtbuf_undirty(struct vt_buf *, term_rect_t *, struct vt_bufmask *);
void vtbuf_sethistory_size(struct vt_buf *, int);
-int vtbuf_set_mark(struct vt_buf *vb, int type, int col, int row);
int vtbuf_iscursor(struct vt_buf *vb, int row, int col);
+void vtbuf_cursor_visibility(struct vt_buf *, int);
+#ifndef SC_NO_CUTPASTE
+void vtbuf_mouse_cursor_position(struct vt_buf *vb, int col, int row);
+int vtbuf_set_mark(struct vt_buf *vb, int type, int col, int row);
int vtbuf_get_marked_len(struct vt_buf *vb);
void vtbuf_extract_marked(struct vt_buf *vb, term_char_t *buf, int sz);
+#endif
#define VTB_MARK_NONE 0
#define VTB_MARK_END 1
@@ -389,12 +391,14 @@ struct vt_font {
unsigned int vf_refcount;
};
+#ifndef SC_NO_CUTPASTE
struct mouse_cursor {
uint8_t map[64 * 64 / 8];
uint8_t mask[64 * 64 / 8];
uint8_t w;
uint8_t h;
};
+#endif
const uint8_t *vtfont_lookup(const struct vt_font *vf, term_char_t c);
struct vt_font *vtfont_ref(struct vt_font *vf);
@@ -403,8 +407,10 @@ int vtfont_load(vfnt_t *f, struct vt_f
/* Sysmouse. */
void sysmouse_process_event(mouse_info_t *mi);
+#ifndef SC_NO_CUTPASTE
void vt_mouse_event(int type, int x, int y, int event, int cnt);
void vt_mouse_state(int show);
+#endif
#define VT_MOUSE_SHOW 1
#define VT_MOUSE_HIDE 0
Modified: head/sys/dev/vt/vt_buf.c
==============================================================================
--- head/sys/dev/vt/vt_buf.c Mon Dec 9 13:44:07 2013 (r259128)
+++ head/sys/dev/vt/vt_buf.c Mon Dec 9 15:01:34 2013 (r259129)
@@ -135,6 +135,7 @@ vthistory_getpos(const struct vt_buf *vb
*offset = vb->vb_roffset;
}
+#ifndef SC_NO_CUTPASTE /* Only mouse support use it now. */
/* Translate current view row number to history row. */
static int
vtbuf_wth(struct vt_buf *vb, int row)
@@ -142,6 +143,7 @@ vtbuf_wth(struct vt_buf *vb, int row)
return ((vb->vb_roffset + row) % vb->vb_history_size);
}
+#endif
/* Translate history row to current view row number. */
static int
@@ -531,6 +533,7 @@ vtbuf_cursor_position(struct vt_buf *vb,
}
}
+#ifndef SC_NO_CUTPASTE
void
vtbuf_mouse_cursor_position(struct vt_buf *vb, int col, int row)
{
@@ -691,6 +694,7 @@ vtbuf_set_mark(struct vt_buf *vb, int ty
vtbuf_flush_mark(vb);
return (1);
}
+#endif
void
vtbuf_cursor_visibility(struct vt_buf *vb, int yes)
Modified: head/sys/dev/vt/vt_core.c
==============================================================================
--- head/sys/dev/vt/vt_core.c Mon Dec 9 13:44:07 2013 (r259128)
+++ head/sys/dev/vt/vt_core.c Mon Dec 9 15:01:34 2013 (r259129)
@@ -127,7 +127,9 @@ extern unsigned char vt_logo_image[];
/* Font. */
extern struct vt_font vt_font_default;
+#ifndef SC_NO_CUTPASTE
extern struct mouse_cursor vt_default_mouse_pointer;
+#endif
static int signal_vt_rel(struct vt_window *);
static int signal_vt_acq(struct vt_window *);
@@ -689,12 +691,14 @@ vt_flush(struct vt_device *vd)
struct vt_window *vw = vd->vd_curwindow;
struct vt_font *vf = vw->vw_font;
struct vt_bufmask tmask;
- struct mouse_cursor *m;
unsigned int row, col;
term_rect_t tarea;
term_pos_t size;
term_char_t *r;
+#ifndef SC_NO_CUTPASTE
+ struct mouse_cursor *m;
int bpl, h, w;
+#endif
if (vd->vd_flags & VDF_SPLASH || vw->vw_flags & VWF_BUSY)
return;
@@ -711,11 +715,13 @@ vt_flush(struct vt_device *vd)
vd->vd_flags &= ~VDF_INVALID;
}
+#ifndef SC_NO_CUTPASTE
if ((vw->vw_flags & VWF_MOUSE_HIDE) == 0) {
/* Mark last mouse position as dirty to erase. */
vtbuf_mouse_cursor_position(&vw->vw_buf, vd->vd_mdirtyx,
vd->vd_mdirtyy);
}
+#endif
for (row = tarea.tr_begin.tp_row; row < tarea.tr_end.tp_row; row++) {
if (!VTBUF_DIRTYROW(&tmask, row))
@@ -731,6 +737,7 @@ vt_flush(struct vt_device *vd)
}
}
+#ifndef SC_NO_CUTPASTE
/* Mouse disabled. */
if (vw->vw_flags & VWF_MOUSE_HIDE)
return;
@@ -759,6 +766,7 @@ vt_flush(struct vt_device *vd)
vd->vd_mdirtyx = vd->vd_mx / vf->vf_width;
vd->vd_mdirtyy = vd->vd_my / vf->vf_height;
}
+#endif
}
static void
@@ -1106,6 +1114,7 @@ finish_vt_acq(struct vt_window *vw)
return (EINVAL);
}
+#ifndef SC_NO_CUTPASTE
void
vt_mouse_event(int type, int x, int y, int event, int cnt)
{
@@ -1265,6 +1274,7 @@ vt_mouse_state(int show)
break;
}
}
+#endif
static int
vtterm_ioctl(struct terminal *tm, u_long cmd, caddr_t data,
Modified: head/sys/dev/vt/vt_sysmouse.c
==============================================================================
--- head/sys/dev/vt/vt_sysmouse.c Mon Dec 9 13:44:07 2013 (r259128)
+++ head/sys/dev/vt/vt_sysmouse.c Mon Dec 9 15:01:34 2013 (r259129)
@@ -190,9 +190,11 @@ sysmouse_process_event(mouse_info_t *mi)
sysmouse_buf_store(buf);
+#ifndef SC_NO_CUTPASTE
mtx_unlock(&sysmouse_lock);
vt_mouse_event(mi->operation, x, y, mi->u.event.id, mi->u.event.value);
return;
+#endif
done: mtx_unlock(&sysmouse_lock);
}
@@ -345,7 +347,9 @@ sysmouse_ioctl(struct cdev *dev, u_long
return (EINVAL);
sysmouse_level = level;
+#ifndef SC_NO_CUTPASTE
vt_mouse_state((level == 0)?VT_MOUSE_SHOW:VT_MOUSE_HIDE);
+#endif
return (0);
}
case MOUSE_SETMODE: {
@@ -358,8 +362,10 @@ sysmouse_ioctl(struct cdev *dev, u_long
case 0:
case 1:
sysmouse_level = mode->level;
+#ifndef SC_NO_CUTPASTE
vt_mouse_state((mode->level == 0)?VT_MOUSE_SHOW:
VT_MOUSE_HIDE);
+#endif
break;
default:
return (EINVAL);
More information about the svn-src-head
mailing list