summaryrefslogtreecommitdiffstats
path: root/sys/isa
diff options
context:
space:
mode:
authorsos <sos@FreeBSD.org>1997-08-09 19:24:03 +0000
committersos <sos@FreeBSD.org>1997-08-09 19:24:03 +0000
commit18323be74595d7ce91803e4b0879bacd887b3eb1 (patch)
tree9df4222bfe1933ac74684b706eb20a208b926872 /sys/isa
parent7f6efbc9e18cb812351eeec3ea51132b9c0d9c21 (diff)
downloadFreeBSD-src-18323be74595d7ce91803e4b0879bacd887b3eb1.zip
FreeBSD-src-18323be74595d7ce91803e4b0879bacd887b3eb1.tar.gz
Fix the checks for screenborder for the mousepointer.
Diffstat (limited to 'sys/isa')
-rw-r--r--sys/isa/syscons.c26
1 files changed, 12 insertions, 14 deletions
diff --git a/sys/isa/syscons.c b/sys/isa/syscons.c
index 8b4add5..1dc6542 100644
--- a/sys/isa/syscons.c
+++ b/sys/isa/syscons.c
@@ -25,7 +25,7 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
- * $Id: syscons.c,v 1.228 1997/07/26 07:58:29 phk Exp $
+ * $Id: syscons.c,v 1.229 1997/08/08 22:52:30 sos Exp $
*/
#include "sc.h"
@@ -1051,8 +1051,6 @@ scioctl(dev_t dev, int cmd, caddr_t data, int flag, struct proc *p)
for (i=0; i<5; i++)
(*linesw[(MOUSE_TTY)->t_line].l_rint)(buf[i],MOUSE_TTY);
}
- cur_console->mouse_xpos += mouse->u.data.x;
- cur_console->mouse_ypos += mouse->u.data.y;
if (cur_console->mouse_signal) {
cur_console->mouse_buttons = mouse->u.data.buttons;
/* has controlling process died? */
@@ -1080,8 +1078,11 @@ scioctl(dev_t dev, int cmd, caddr_t data, int flag, struct proc *p)
}
}
}
- if (mouse->u.data.x != 0 || mouse->u.data.y != 0)
+ if (mouse->u.data.x != 0 || mouse->u.data.y != 0) {
+ cur_console->mouse_xpos += mouse->u.data.x;
+ cur_console->mouse_ypos += mouse->u.data.y;
set_mouse_pos(cur_console);
+ }
break;
default:
@@ -3900,25 +3901,22 @@ static void
set_mouse_pos(scr_stat *scp)
{
static int last_xpos = -1, last_ypos = -1;
- /*
- * the margins imposed here are not ideal, we loose
- * a couble of pixels on the borders..
- */
+
if (scp->mouse_xpos < 0)
scp->mouse_xpos = 0;
if (scp->mouse_ypos < 0)
scp->mouse_ypos = 0;
if (scp->status & UNKNOWN_MODE) {
- if (scp->mouse_xpos > scp->xpixel)
+ if (scp->mouse_xpos > scp->xpixel-1)
scp->mouse_xpos = scp->xpixel-1;
- if (scp->mouse_ypos > scp->ypixel)
+ if (scp->mouse_ypos > scp->ypixel-1)
scp->mouse_ypos = scp->ypixel-1;
return;
}
- if (scp->mouse_xpos > (scp->xsize*8)-2)
- scp->mouse_xpos = (scp->xsize*8)-2;
- if (scp->mouse_ypos > (scp->ysize*scp->font_size)-2)
- scp->mouse_ypos = (scp->ysize*scp->font_size)-2;
+ if (scp->mouse_xpos > (scp->xsize*8)-1)
+ scp->mouse_xpos = (scp->xsize*8)-1;
+ if (scp->mouse_ypos > (scp->ysize*scp->font_size)-1)
+ scp->mouse_ypos = (scp->ysize*scp->font_size)-1;
if (scp->mouse_xpos != last_xpos || scp->mouse_ypos != last_ypos) {
scp->status |= MOUSE_MOVED;
OpenPOWER on IntegriCloud