summaryrefslogtreecommitdiff
path: root/sys/arch/i386
diff options
context:
space:
mode:
authorAaron Campbell <aaron@cvs.openbsd.org>2000-09-22 17:39:06 +0000
committerAaron Campbell <aaron@cvs.openbsd.org>2000-09-22 17:39:06 +0000
commit5af8bca441cf999491693c8b5f57729b4ae44610 (patch)
treea6485746a0c73d3b7647e2f10239ceb29fdc3413 /sys/arch/i386
parent9a4ed859318cc85ad085a1f18504ea3e952a77b8 (diff)
- Introduce character classes into the console mouse functionality. Lifted from
xterm sources. Basically, base word boundaries by character classes rather than space characters only. - On any console logout, clear the contents of the Copybuffer. (This will have to be documented with an explanation as to why.) Avoids the ability to paste the copybuffer at the ``login:'' prompt after someone has logged out. - Permit copy selection extension under any circumstance as long as the button is held down. However, double-click (word selection) does not yet extend on word boundaries like xterms do. - Sanity checks in current_uid(). - From Jean-Baptiste.Marchand@epita.fr
Diffstat (limited to 'sys/arch/i386')
-rw-r--r--sys/arch/i386/isa/pcvt/pcvt_drv.c6
-rw-r--r--sys/arch/i386/isa/pcvt/pcvt_hdr.h5
-rw-r--r--sys/arch/i386/isa/pcvt/pcvt_mouse.c151
3 files changed, 133 insertions, 29 deletions
diff --git a/sys/arch/i386/isa/pcvt/pcvt_drv.c b/sys/arch/i386/isa/pcvt/pcvt_drv.c
index f92fdf6c7bc..3675c855038 100644
--- a/sys/arch/i386/isa/pcvt/pcvt_drv.c
+++ b/sys/arch/i386/isa/pcvt/pcvt_drv.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcvt_drv.c,v 1.31 2000/09/01 05:46:01 aaron Exp $ */
+/* $OpenBSD: pcvt_drv.c,v 1.32 2000/09/22 17:39:05 aaron Exp $ */
/*
* Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch.
*
@@ -294,6 +294,10 @@ pcclose(Dev_t dev, int flag, int mode, struct proc *p)
reset_usl_modes(vsx);
+ /* remove the selection at logout */
+ bzero(Copybuffer, (vs[0].maxcol + 1) * vs[0].screen_rows);
+ Paste_avail = 0;
+
return(0);
}
diff --git a/sys/arch/i386/isa/pcvt/pcvt_hdr.h b/sys/arch/i386/isa/pcvt/pcvt_hdr.h
index 6829dbc53bb..f35f3b1b361 100644
--- a/sys/arch/i386/isa/pcvt/pcvt_hdr.h
+++ b/sys/arch/i386/isa/pcvt/pcvt_hdr.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcvt_hdr.h,v 1.38 2000/09/04 17:59:49 aaron Exp $ */
+/* $OpenBSD: pcvt_hdr.h,v 1.39 2000/09/22 17:39:05 aaron Exp $ */
/*
* Copyright (c) 1992, 1995 Hellmuth Michaelis and Joerg Wunsch.
@@ -713,10 +713,13 @@ typedef struct video_state {
#define SEL_IN_PROGRESS (1 << 2) /* flag, a selection is in progress */
#define BLANK_TO_EOL (1 << 3) /* flag, there are only blanks
characters to eol */
+#define IN_SELECTION (1 << 4) /* flag, the cursor is currently in
+ the selection */
#define IS_MOUSE_VISIBLE(vsp) ((vsp)->mouse_flags & MOUSE_VISIBLE)
#define IS_SEL_EXISTS(vsp) ((vsp)->mouse_flags & SEL_EXISTS)
#define IS_SEL_IN_PROGRESS(vsp) ((vsp)->mouse_flags & SEL_IN_PROGRESS)
#define IS_BLANK_TO_EOL(vsp) ((vsp)->mouse_flags & BLANK_TO_EOL)
+#define IS_IN_SELECTION(vsp) ((vsp)->mouse_flags & IN_SELECTION)
unsigned char mouse_flags; /* flags, status of the mouse */
} video_state;
diff --git a/sys/arch/i386/isa/pcvt/pcvt_mouse.c b/sys/arch/i386/isa/pcvt/pcvt_mouse.c
index f86d3ed6ceb..c6fb5412865 100644
--- a/sys/arch/i386/isa/pcvt/pcvt_mouse.c
+++ b/sys/arch/i386/isa/pcvt/pcvt_mouse.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pcvt_mouse.c,v 1.2 2000/09/04 17:59:50 aaron Exp $ */
+/* $OpenBSD: pcvt_mouse.c,v 1.3 2000/09/22 17:39:05 aaron Exp $ */
/*
* Copyright (c) 2000 Jean-Baptiste Marchand, Julien Montagne and Jerome Verdon
@@ -269,6 +269,77 @@ skip_spc_left(void)
}
/*
+ * Class of characters
+ * Stolen from xterm sources of the Xfree project (see cvs tag below)
+ * $TOG: button.c /main/76 1997/07/30 16:56:19 kaleb $
+ */
+
+static int charClass[256] = {
+/* NUL SOH STX ETX EOT ENQ ACK BEL */
+ 32, 1, 1, 1, 1, 1, 1, 1,
+/* BS HT NL VT NP CR SO SI */
+ 1, 32, 1, 1, 1, 1, 1, 1,
+/* DLE DC1 DC2 DC3 DC4 NAK SYN ETB */
+ 1, 1, 1, 1, 1, 1, 1, 1,
+/* CAN EM SUB ESC FS GS RS US */
+ 1, 1, 1, 1, 1, 1, 1, 1,
+/* SP ! " # $ % & ' */
+ 32, 33, 34, 35, 36, 37, 38, 39,
+/* ( ) * + , - . / */
+ 40, 41, 42, 43, 44, 45, 46, 47,
+/* 0 1 2 3 4 5 6 7 */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* 8 9 : ; < = > ? */
+ 48, 48, 58, 59, 60, 61, 62, 63,
+/* @ A B C D E F G */
+ 64, 48, 48, 48, 48, 48, 48, 48,
+/* H I J K L M N O */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* P Q R S T U V W */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* X Y Z [ \ ] ^ _ */
+ 48, 48, 48, 91, 92, 93, 94, 48,
+/* ` a b c d e f g */
+ 96, 48, 48, 48, 48, 48, 48, 48,
+/* h i j k l m n o */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* p q r s t u v w */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* x y z { | } ~ DEL */
+ 48, 48, 48, 123, 124, 125, 126, 1,
+/* x80 x81 x82 x83 IND NEL SSA ESA */
+ 1, 1, 1, 1, 1, 1, 1, 1,
+/* HTS HTJ VTS PLD PLU RI SS2 SS3 */
+ 1, 1, 1, 1, 1, 1, 1, 1,
+/* DCS PU1 PU2 STS CCH MW SPA EPA */
+ 1, 1, 1, 1, 1, 1, 1, 1,
+/* x98 x99 x9A CSI ST OSC PM APC */
+ 1, 1, 1, 1, 1, 1, 1, 1,
+/* - i c/ L ox Y- | So */
+ 160, 161, 162, 163, 164, 165, 166, 167,
+/* .. c0 ip << _ R0 - */
+ 168, 169, 170, 171, 172, 173, 174, 175,
+/* o +- 2 3 ' u q| . */
+ 176, 177, 178, 179, 180, 181, 182, 183,
+/* , 1 2 >> 1/4 1/2 3/4 ? */
+ 184, 185, 186, 187, 188, 189, 190, 191,
+/* A` A' A^ A~ A: Ao AE C, */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* E` E' E^ E: I` I' I^ I: */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* D- N~ O` O' O^ O~ O: X */
+ 48, 48, 48, 48, 48, 48, 48, 216,
+/* O/ U` U' U^ U: Y' P B */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* a` a' a^ a~ a: ao ae c, */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* e` e' e^ e: i` i' i^ i: */
+ 48, 48, 48, 48, 48, 48, 48, 48,
+/* d n~ o` o' o^ o~ o: -: */
+ 48, 48, 48, 48, 48, 48, 48, 248,
+/* o/ u` u' u^ u: y' P y: */
+ 48, 48, 48, 48, 48, 48, 48, 48};
+/*
* Function which find the first blank beginning after the current cursor
* position
*/
@@ -278,12 +349,13 @@ skip_char_right(void)
{
unsigned short *current;
unsigned short *limit;
- unsigned char mouse_col = (vsp->mouse % vsp->maxcol);
unsigned char res = 0;
-
+ unsigned char class;
+
current = vsp->Crtat + vsp->cpy_end;
- limit = current + (vsp->maxcol - mouse_col - 1);
- while (((*current & 0x00ff) != ' ') && (current <= limit)) {
+ class = charClass[(*current & 0x00ff)];
+ limit = current + (vsp->maxcol - (vsp->mouse % vsp->maxcol) - 1);
+ while ((charClass[(*current & 0x00ff)] == class) && (current <= limit)){
current++;
res++;
}
@@ -301,12 +373,13 @@ skip_char_left(void)
{
unsigned short *current;
unsigned short *limit;
- unsigned char mouse_col = (vsp->mouse % vsp->maxcol);
unsigned char res = 0;
+ unsigned char class;
current = vsp->Crtat + vsp->cpy_start;
- limit = current - mouse_col;
- while (((*current & 0x00ff) != ' ') && (current >= limit)) {
+ class = charClass[(*current & 0x00ff)];
+ limit = current - (vsp->mouse % vsp->maxcol);
+ while ((charClass[(*current & 0x00ff)] == class) && (current >= limit)){
current--;
res++;
}
@@ -366,10 +439,6 @@ mouse_copy_word()
if (IS_SEL_EXISTS(vsp))
remove_selection();
-
- if (IS_SEL_IN_PROGRESS(vsp))
- vsp->mouse_flags &= ~SEL_IN_PROGRESS;
-
if (IS_MOUSE_VISIBLE(vsp))
inverse_char(vsp->mouse);
@@ -389,9 +458,16 @@ mouse_copy_word()
vsp->cpy_end += right;
vsp->cpy_orig = vsp->cpy_start;
inverse_region(vsp->cpy_start, vsp->cpy_end);
+
+ vsp->mouse_flags |= SEL_IN_PROGRESS;
vsp->mouse_flags |= SEL_EXISTS;
+ /* mouse cursor is in the selection. Moving the cursor inside the
+ selection won't modify (extend or reduce) it */
+ vsp->mouse_flags |= IN_SELECTION;
+
/* mouse cursor hidden in the selection */
+ vsp->mouse_flags &= ~BLANK_TO_EOL;
vsp->mouse_flags &= ~MOUSE_VISIBLE;
}
@@ -406,10 +482,6 @@ mouse_copy_line(void)
if (IS_SEL_EXISTS(vsp))
remove_selection();
-
- if (IS_SEL_IN_PROGRESS(vsp))
- vsp->mouse_flags &= ~(SEL_IN_PROGRESS);
-
if (IS_MOUSE_VISIBLE(vsp))
inverse_char(vsp->mouse);
@@ -418,7 +490,15 @@ mouse_copy_line(void)
vsp->cpy_orig = vsp->cpy_start;
inverse_region(vsp->cpy_start, vsp->cpy_end);
+ vsp->mouse_flags |= SEL_IN_PROGRESS;
vsp->mouse_flags |= SEL_EXISTS;
+
+ /* mouse cursor is in the selection. Moving the cursor inside the
+ selection won't modify (extend or reduce) it */
+ vsp->mouse_flags |= IN_SELECTION;
+
+ /* mouse cursor hidden in the selection */
+ vsp->mouse_flags &= ~BLANK_TO_EOL;
vsp->mouse_flags &= ~MOUSE_VISIBLE;
}
@@ -500,22 +580,33 @@ mouse_copy_extend()
if (vsp->mouse >= vsp->cpy_orig) {
/* lower part of the screen */
- if (vsp->mouse > vsp->cpy_end)
+ if (vsp->mouse > vsp->cpy_end) {
/* extending selection */
+ if (IS_IN_SELECTION(vsp))
+ vsp->mouse_flags &= ~ IN_SELECTION;
inverse_region(vsp->cpy_end + 1,vsp->mouse);
- else
- /* reducing selection */
- inverse_region(vsp->mouse + 1,vsp->cpy_end);
- vsp->cpy_end = vsp->mouse;
+ }
+ else {
+ /* reducing selection, if the cursor is not
+ inside a word or line selection */
+ if (!IS_IN_SELECTION(vsp))
+ inverse_region(vsp->mouse + 1,vsp->cpy_end);
+ }
+ if (!IS_IN_SELECTION(vsp))
+ vsp->cpy_end = vsp->mouse;
}
else {
/* upper part of the screen */
- if (vsp->mouse < vsp->cpy_start)
+ if (vsp->mouse < vsp->cpy_start) {
/* extending selection */
+ if (IS_IN_SELECTION(vsp))
+ vsp->mouse_flags &= ~ IN_SELECTION;
inverse_region(vsp->mouse,vsp->cpy_start - 1);
- else
+ }
+ else {
/* reducing selection */
inverse_region(vsp->cpy_start,vsp->mouse - 1);
+ }
vsp->cpy_start = vsp->mouse;
}
}
@@ -548,11 +639,17 @@ remove_selection()
uid_t
current_uid(void)
{
- pid_t pg; /* process group id */
- struct proc *owner_proc;
+ pid_t pg = 0; /* process group id */
+ struct proc *owner_proc = 0;
+
+ if (vsp->vs_tty && vsp->vs_tty->t_pgrp)
+ pg = vsp->vs_tty->t_pgrp->pg_id;
+ else
+ return (0); /* the uid of root, just to be sure */
+
+ if (pg)
+ owner_proc = pfind(pg);
- pg = vsp->vs_tty->t_pgrp->pg_id;
- owner_proc = pfind(pg);
if (!owner_proc) {
Paste_avail = 0; /* this selection will never be available
because the process doesn't exist... */