svn commit: r270589 - head/sys/dev/vt

Jean-Sebastien Pedron dumbbell at FreeBSD.org
Mon Aug 25 17:08:39 UTC 2014


Author: dumbbell
Date: Mon Aug 25 17:08:38 2014
New Revision: 270589
URL: http://svnweb.freebsd.org/changeset/base/270589

Log:
  vt(4): The cursor coordinates are relative to the drawn area
  
  ... not the whole screen. Don't use font offsets in
  vt_mark_mouse_position_as_dirty().
  
  This fixes a bug where the mouse position wasn't marked as dirty when
  approaching the borders of the drawn area.
  
  MFC after:	1 week

Modified:
  head/sys/dev/vt/vt_core.c

Modified: head/sys/dev/vt/vt_core.c
==============================================================================
--- head/sys/dev/vt/vt_core.c	Mon Aug 25 17:06:18 2014	(r270588)
+++ head/sys/dev/vt/vt_core.c	Mon Aug 25 17:08:38 2014	(r270589)
@@ -860,16 +860,12 @@ vt_mark_mouse_position_as_dirty(struct v
 	y = vd->vd_my_drawn;
 
 	if (vf != NULL) {
-		area.tr_begin.tp_col = (x - vw->vw_offset.tp_col) /
-		    vf->vf_width;
-		area.tr_begin.tp_row = (y - vw->vw_offset.tp_row) /
-		    vf->vf_height;
+		area.tr_begin.tp_col = x / vf->vf_width;
+		area.tr_begin.tp_row = y / vf->vf_height;
 		area.tr_end.tp_col =
-		    ((x + vd->vd_mcursor->width - vw->vw_offset.tp_col) /
-		     vf->vf_width) + 1;
+		    ((x + vd->vd_mcursor->width) / vf->vf_width) + 1;
 		area.tr_end.tp_row =
-		    ((y + vd->vd_mcursor->height - vw->vw_offset.tp_row) /
-		     vf->vf_height) + 1;
+		    ((y + vd->vd_mcursor->height) / vf->vf_height) + 1;
 	} else {
 		/*
 		 * No font loaded (ie. vt_vga operating in textmode).


More information about the svn-src-head mailing list