|
|
|
|
File: [XFree86 CVS] / xc / programs / xterm / cursor.c
(download)
Revision: 1.1.1.1 (vendor branch), Wed Apr 27 06:12:34 1994 UTC (19 years, 1 month ago) by dawes Branch: X11R6 CVS Tags: xf-3_1_Zd, xf-3_1_2e, xf-3_1_2d, xf-3_1_2c, xf-3_1_2b, xf-3_1_2a, xf-3_1_2Bd, xf-3_1_2Bc, xf-3_1_2Bb, xf-3_1_2Ba, xf-3_1_2B, xf-3_1_2Af, xf-3_1_2Ae, xf-3_1_2Ad, xf-3_1_2Ac, xf-3_1_2Ab, xf-3_1_2Aa, xf-3_1_2A, xf-3_1_2-branch, xf-3_1_2-S, xf-3_1_2, xf-3_1_1h, xf-3_1_1g, xf-3_1_1f, xf-3_1_1e, xf-3_1_1d, xf-3_1_1c, xf-3_1_1b, xf-3_1_1a, xf-3_1_1Z, xf-3_1_1Dc, xf-3_1_1Db, xf-3_1_1Da, xf-3_1_1D, xf-3_1_1Cd, xf-3_1_1Cc, xf-3_1_1Cb, xf-3_1_1Ca, xf-3_1_1C, xf-3_1_1Bi, xf-3_1_1Bh, xf-3_1_1Bg, xf-3_1_1Bf, xf-3_1_1Be, xf-3_1_1Bd, xf-3_1_1Bc, xf-3_1_1Bb, xf-3_1_1Ba, xf-3_1_1B, xf-3_1_1Ad, xf-3_1_1Ac, xf-3_1_1Ab, xf-3_1_1Aa, xf-3_1_1A, xf-3_1_1-u1, xf-3_1_1-u, xf-3_1_1, xf-3_1_0g, xf-3_1_0f, xf-3_1_0e, xf-3_1_0d, xf-3_1_0c, xf-3_1_0b, xf-3_1_0a, xf-3_1_0Zg, xf-3_1_0Zf, xf-3_1_0Ze, xf-3_1_0Zd, xf-3_1_0Zc, xf-3_1_0Zb, xf-3_1_0Za, xf-3_1_0Z, xf-3_1_0Ce, xf-3_1_0Cd, xf-3_1_0Cc, xf-3_1_0Cb, xf-3_1_0Ca, xf-3_1_0C, xf-3_1_0Bf, xf-3_1_0Be, xf-3_1_0Bd, xf-3_1_0Bc, xf-3_1_0Bb, xf-3_1_0Ba, xf-3_1_0B, xf-3_1_0Ae, xf-3_1_0Ad, xf-3_1_0Ac, xf-3_1_0Ab, xf-3_1_0Aa, xf-3_1_0A, xf-3_1, xf-3_0d, xf-3_0c, xf-3_0b, xf-3_0a, xf-3_0_0e, xf-3_0_0d, xf-3_0_0c, xf-3_0_0b, xf-3_0_0a, xf-3_0_0-branch, xf-3_0Z, xf-3_0Fe, xf-3_0Fd, xf-3_0Fc, xf-3_0Fb, xf-3_0Fa, xf-3_0F, xf-3_0Ec, xf-3_0Eb, xf-3_0Ea, xf-3_0E, xf-3_0Dl, xf-3_0Dk, xf-3_0Dj, xf-3_0Di, xf-3_0Dh, xf-3_0Dg, xf-3_0Df, xf-3_0De, xf-3_0Dd, xf-3_0Dc, xf-3_0Db, xf-3_0Da, xf-3_0D, xf-3_0Ce, xf-3_0Cd, xf-3_0Cc, xf-3_0Cb, xf-3_0Ca, xf-3_0C, xf-3_0Bc, xf-3_0Bb, xf-3_0Ba, xf-3_0B, xf-3_0Ac, xf-3_0Ab, xf-3_0Aa, xf-3_0A, xf-3_0, seq-4321, seq-4316, seq-4304, seq-4282, seq-4114, seq-4104, seq-4086, seq-4084, seq-4081, seq-4074, seq-4060, seq-4057, seq-4055, seq-4052, seq-4039, seq-4035, seq-4031, seq-4024, seq-4010, seq-3977, seq-3637, seq-3600, seq-3583, XC, X11R6_PRE_11, X11R6_9, X11R6_8, X11R6_7, X11R6_6, X11R6_5, X11R6_4, X11R6_3, X11R6_2, X11R6_13, X11R6_12, X11R6_11, X11R6_10, X11R6_1, X11R6_0, X11R6-4_3, X11R6-4_2, X11R6-4_1, X11R6-4_0, X11R6-3_2, X11R6-3_1, X11R6-3_0, X11R6-1_1, X11R6-1_0, R6_1-BETA Changes since 1.1: +0 -0 lines X11R6 Public Patch 0 |
/*
* $XConsortium: cursor.c,v 1.14 93/09/20 17:42:23 hersh Exp $
*/
/*
* Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
*
* All Rights Reserved
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose and without fee is hereby granted,
* provided that the above copyright notice appear in all copies and that
* both that copyright notice and this permission notice appear in
* supporting documentation, and that the name of Digital Equipment
* Corporation not be used in advertising or publicity pertaining to
* distribution of the software without specific, written prior permission.
*
*
* DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
* ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
* DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
* ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
* ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
* SOFTWARE.
*/
/* cursor.c */
#include "ptyx.h" /* also gets Xlib.h */
static void _CheckSelection(screen)
register TScreen *screen;
{
extern XtermWidget term; /* %%% gross */
if (screen->cur_row > screen->endHRow ||
(screen->cur_row == screen->endHRow &&
screen->cur_col >= screen->endHCol)) {}
else
DisownSelection(term);
}
/*
* Moves the cursor to the specified position, checking for bounds.
* (this includes scrolling regions)
* The origin is considered to be 0, 0 for this procedure.
*/
CursorSet(screen, row, col, flags)
register TScreen *screen;
register int row, col;
unsigned flags;
{
register int maxr;
col = (col < 0 ? 0 : col);
screen->cur_col = (col <= screen->max_col ? col : screen->max_col);
maxr = screen->max_row;
if (flags & ORIGIN) {
row += screen->top_marg;
maxr = screen->bot_marg;
}
row = (row < 0 ? 0 : row);
screen->cur_row = (row <= maxr ? row : maxr);
screen->do_wrap = 0;
_CheckSelection(screen);
}
/*
* moves the cursor left n, no wrap around
*/
CursorBack(screen, n)
register TScreen *screen;
int n;
{
register int i, j, k, rev;
extern XtermWidget term;
if((rev = (term->flags & (REVERSEWRAP | WRAPAROUND)) ==
(REVERSEWRAP | WRAPAROUND)) && screen->do_wrap)
n--;
if ((screen->cur_col -= n) < 0) {
if(rev) {
if((i = (j = screen->max_col + 1) * screen->cur_row +
screen->cur_col) < 0) {
k = j * (screen->max_row + 1);
i += ((-i) / k + 1) * k;
}
screen->cur_row = i / j;
screen->cur_col = i % j;
} else
screen->cur_col = 0;
}
screen->do_wrap = 0;
_CheckSelection(screen);
}
/*
* moves the cursor forward n, no wraparound
*/
CursorForward(screen, n)
register TScreen *screen;
int n;
{
screen->cur_col += n;
if (screen->cur_col > screen->max_col)
screen->cur_col = screen->max_col;
screen->do_wrap = 0;
_CheckSelection(screen);
}
/*
* moves the cursor down n, no scrolling.
* Won't pass bottom margin or bottom of screen.
*/
CursorDown(screen, n)
register TScreen *screen;
int n;
{
register int max;
max = (screen->cur_row > screen->bot_marg ?
screen->max_row : screen->bot_marg);
screen->cur_row += n;
if (screen->cur_row > max)
screen->cur_row = max;
screen->do_wrap = 0;
_CheckSelection(screen);
}
/*
* moves the cursor up n, no linestarving.
* Won't pass top margin or top of screen.
*/
CursorUp(screen, n)
register TScreen *screen;
int n;
{
register int min;
min = (screen->cur_row < screen->top_marg ?
0 : screen->top_marg);
screen->cur_row -= n;
if (screen->cur_row < min)
screen->cur_row = min;
screen->do_wrap = 0;
_CheckSelection(screen);
}
/*
* Moves cursor down amount lines, scrolls if necessary.
* Won't leave scrolling region. No carriage return.
*/
Index(screen, amount)
register TScreen *screen;
register int amount;
{
register int j;
/*
* indexing when below scrolling region is cursor down.
* if cursor high enough, no scrolling necessary.
*/
if (screen->cur_row > screen->bot_marg
|| screen->cur_row + amount <= screen->bot_marg) {
CursorDown(screen, amount);
return;
}
CursorDown(screen, j = screen->bot_marg - screen->cur_row);
Scroll(screen, amount - j);
}
/*
* Moves cursor up amount lines, reverse scrolls if necessary.
* Won't leave scrolling region. No carriage return.
*/
RevIndex(screen, amount)
register TScreen *screen;
register int amount;
{
/*
* reverse indexing when above scrolling region is cursor up.
* if cursor low enough, no reverse indexing needed
*/
if (screen->cur_row < screen->top_marg
|| screen->cur_row-amount >= screen->top_marg) {
CursorUp(screen, amount);
return;
}
RevScroll(screen, amount - (screen->cur_row - screen->top_marg));
CursorUp(screen, screen->cur_row - screen->top_marg);
}
/*
* Moves Cursor To First Column In Line
*/
CarriageReturn(screen)
register TScreen *screen;
{
screen->cur_col = 0;
screen->do_wrap = 0;
_CheckSelection(screen);
}
/*
* Save Cursor and Attributes
*/
CursorSave(term, sc)
register XtermWidget term;
register SavedCursor *sc;
{
register TScreen *screen = &term->screen;
sc->row = screen->cur_row;
sc->col = screen->cur_col;
sc->flags = term->flags;
sc->curgl = screen->curgl;
sc->curgr = screen->curgr;
memmove( sc->gsets, screen->gsets, sizeof(screen->gsets));
}
/*
* Restore Cursor and Attributes
*/
CursorRestore(term, sc)
register XtermWidget term;
register SavedCursor *sc;
{
register TScreen *screen = &term->screen;
memmove( screen->gsets, sc->gsets, sizeof(screen->gsets));
screen->curgl = sc->curgl;
screen->curgr = sc->curgr;
term->flags &= ~(BOLD|INVERSE|UNDERLINE|ORIGIN);
term->flags |= sc->flags & (BOLD|INVERSE|UNDERLINE|ORIGIN);
CursorSet (screen, (term->flags & ORIGIN) ? sc->row - screen->top_marg
: sc->row, sc->col, term->flags);
}
|
Powered by ViewCVS 0.9.2 |