229 lines
6.2 KiB
Groff
229 lines
6.2 KiB
Groff
.\" $NetBSD: intro.3,v 1.9 2003/11/02 11:16:03 wiz Exp $
|
|
.\"
|
|
.\" Copyright (c) 1980, 1993
|
|
.\" The Regents of the University of California. All rights reserved.
|
|
.\"
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
.\" modification, are permitted provided that the following conditions
|
|
.\" are met:
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
.\" 3. Neither the name of the University nor the names of its contributors
|
|
.\" may be used to endorse or promote products derived from this software
|
|
.\" without specific prior written permission.
|
|
.\"
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
.\" SUCH DAMAGE.
|
|
.\"
|
|
.\" @(#)intro.3 8.1 (Berkeley) 6/4/93
|
|
.\"
|
|
.sh 1 Usage
|
|
.pp
|
|
This is a description of how to actually use the screen package.
|
|
For simplicity, we assume all updating, reading, etc.
|
|
is applied to
|
|
.Vn stdscr ,
|
|
although a different window can of course be specified.
|
|
.sh 2 "Initialization"
|
|
.pp
|
|
In order to use the screen package,
|
|
the routines must know about terminal characteristics,
|
|
and the space for
|
|
.Vn curscr
|
|
and
|
|
.Vn stdscr
|
|
must be allocated.
|
|
These functions are performed by
|
|
.Fn initscr .
|
|
Since it must allocate space for the windows,
|
|
it can overflow core when attempting to do so.
|
|
On this rather rare occasion,
|
|
.Fn initscr
|
|
returns ERR.
|
|
.Fn initscr
|
|
must
|
|
.bi always
|
|
be called before any of the routines which affect windows are used.
|
|
If it is not,
|
|
the program will core dump as soon as either
|
|
.Vn curscr
|
|
or
|
|
.Vn stdscr
|
|
are referenced.
|
|
However, it is usually best to wait to call it
|
|
until after you are sure you will need it,
|
|
like after checking for startup errors.
|
|
Terminal status changing routines
|
|
like
|
|
.Fn nl
|
|
and
|
|
.Fn cbreak
|
|
should be called after
|
|
.Fn initscr .
|
|
.pp
|
|
After the initial window allocation done by
|
|
.Fn initscr ,
|
|
specific window characteristics can be set.
|
|
Scrolling can be enabled by calling
|
|
.Fn scrollok .
|
|
If you want the cursor to be left after the last change, use
|
|
.Fn leaveok .
|
|
If this isn't done,
|
|
.Fn refresh
|
|
will move the cursor to the window's current \*y after updating it.
|
|
Additional windows can be created by using the functions
|
|
.Fn newwin
|
|
and
|
|
.Fn subwin .
|
|
.Fn delwin
|
|
allows you to delete an existing window.
|
|
The variables
|
|
.Vn LINES
|
|
and
|
|
.Vn COLS
|
|
control the size of the terminal.
|
|
They are initially implicitly set by
|
|
.Fn initscr ,
|
|
but can be altered explicitly by the user followed by a call to
|
|
.Fn initscr .
|
|
Note that any call to
|
|
.Fn initscr ,
|
|
will always delete any existing
|
|
.Vn stdscr
|
|
and/or
|
|
.Vn curscr
|
|
before creating new ones so this change is best done before the initial call to
|
|
.Fn initscr .
|
|
.pp
|
|
.sh 2 "Output"
|
|
.pp
|
|
The basic functions
|
|
used to change what will go on a window are
|
|
.Fn addch
|
|
and
|
|
.Fn move .
|
|
.Fn addch
|
|
adds a character at the current \*y,
|
|
returning ERR if it would cause the window to illegally scroll,
|
|
.i i.e. ,
|
|
printing a character in the lower right-hand corner
|
|
of a terminal which automatically scrolls
|
|
if scrolling is not allowed.
|
|
.Fn move
|
|
changes the current \*y to whatever you want them to be.
|
|
It returns ERR if you try to move off the window.
|
|
As mentioned above, you can combine the two into
|
|
.Fn mvaddch
|
|
to do both things in one call.
|
|
.pp
|
|
The other output functions
|
|
(such as
|
|
.Fn addstr
|
|
and
|
|
.Fn printw )
|
|
all call
|
|
.Fn addch
|
|
to add characters to the window.
|
|
.pp
|
|
After a change has been made to the window,
|
|
you must call
|
|
.Fn refresh .
|
|
when you want the portion of the terminal covered by the window
|
|
to reflect the change.
|
|
In order to optimize finding changes,
|
|
.Fn refresh
|
|
assumes that any part of the window not changed
|
|
since the last
|
|
.Fn refresh
|
|
of that window has not been changed on the terminal,
|
|
.i i.e. ,
|
|
that you have not refreshed a portion of the terminal
|
|
with an overlapping window.
|
|
If this is not the case,
|
|
the routines
|
|
.Fn touchwin ,
|
|
.Fn touchline ,
|
|
and
|
|
.Fn touchoverlap
|
|
are provided to make it look like a desired part of window has been changed,
|
|
thus forcing
|
|
.Fn refresh
|
|
to check that whole subsection of the terminal for changes.
|
|
.pp
|
|
If you call
|
|
.Fn wrefresh
|
|
with
|
|
.Vn curscr ,
|
|
it will make the screen look like the image of
|
|
.Vn curscr .
|
|
This is useful for implementing a command
|
|
which would redraw the screen in case it got messed up.
|
|
.sh 2 Input
|
|
.pp
|
|
Input is essentially a mirror image of output.
|
|
The complementary function to
|
|
.Fn addch
|
|
is
|
|
.Fn getch
|
|
which,
|
|
if echo is set,
|
|
will call
|
|
.Fn addch
|
|
to echo the character.
|
|
Since the screen package needs to know what is on the terminal at all times,
|
|
if characters are to be echoed,
|
|
the tty must be in raw or cbreak mode.
|
|
If it is not,
|
|
.Fn getch
|
|
sets it to be cbreak,
|
|
and then reads in the character.
|
|
.sh 2 "Termination"
|
|
.pp
|
|
In order to perform certain optimizations,
|
|
and,
|
|
on some terminals,
|
|
to work at all,
|
|
some things must be done
|
|
before the screen routines start up.
|
|
These functions are performed in
|
|
.Fn getttmode
|
|
and
|
|
.Fn setterm ,
|
|
which are called by
|
|
.Fn initscr .
|
|
In order to clean up after the routines,
|
|
the routine
|
|
.Fn endwin
|
|
is provided.
|
|
It restores tty modes to what they were
|
|
when
|
|
.Fn initscr
|
|
was first called.
|
|
The terminal state module uses the variable
|
|
.Vn curses_termios
|
|
to save the original terminal state which is then restored upon a call to
|
|
.Fn endwin .
|
|
Thus,
|
|
anytime after the call to initscr,
|
|
.Fn endwin
|
|
should be called before exiting.
|
|
Note however, that
|
|
.Fn endwin
|
|
should always be called
|
|
.b before
|
|
the final calls to
|
|
.Fn delwin ,
|
|
which free the storage of the windows.
|