1 .\" $NetBSD: intro.3,v 1.8 2003/08/07 16:44:28 agc Exp $
3 .\" Copyright (c) 1980, 1993
4 .\" The Regents of the University of California. All rights reserved.
6 .\" Redistribution and use in source and binary forms, with or without
7 .\" modification, are permitted provided that the following conditions
9 .\" 1. Redistributions of source code must retain the above copyright
10 .\" notice, this list of conditions and the following disclaimer.
11 .\" 2. Redistributions in binary form must reproduce the above copyright
12 .\" notice, this list of conditions and the following disclaimer in the
13 .\" documentation and/or other materials provided with the distribution.
14 .\" 3. Neither the name of the University nor the names of its contributors
15 .\" may be used to endorse or promote products derived from this software
16 .\" without specific prior written permission.
18 .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
19 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 .\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
22 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 .\" @(#)intro.3 8.1 (Berkeley) 6/4/93
34 This is a description of how to actually use the screen package.
35 For simplicity, we assume all updating, reading, etc.
38 although a different window can of course be specified.
39 .sh 2 "Initialization"
41 In order to use the screen package,
42 the routines must know about terminal characteristics,
48 These functions are performed by
50 Since it must allocate space for the windows,
51 it can overflow core when attempting to do so.
52 On this rather rare occasion,
58 be called before any of the routines which affect windows are used.
60 the program will core dump as soon as either
65 However, it is usually best to wait to call it
66 until after you are sure you will need it,
67 like after checking for startup errors.
68 Terminal status changing routines
73 should be called after
76 After the initial window allocation done by
78 specific window characteristics can be set.
79 Scrolling can be enabled by calling
81 If you want the cursor to be left after the last change, use
85 will move the cursor to the window's current \*y after updating it.
86 Additional windows can be created by using the functions
91 allows you to delete an existing window.
96 control the size of the terminal.
97 They are initially implicitly set by
99 but can be altered explicitly by the user followed by a call to
101 Note that any call to
103 will always delete any existing
107 before creating new ones so this change is best done before the initial call to
113 used to change what will go on a window are
118 adds a character at the current \*y,
119 returning ERR if it would cause the window to illegally scroll,
121 printing a character in the lower right-hand corner
122 of a terminal which automatically scrolls
123 if scrolling is not allowed.
125 changes the current \*y to whatever you want them to be.
126 It returns ERR if you try to move off the window.
127 As mentioned above, you can combine the two into
129 to do both things in one call.
131 The other output functions
138 to add characters to the window.
140 After a change has been made to the window,
143 when you want the portion of the terminal covered by the window
144 to reflect the change.
145 In order to optimize finding changes,
147 assumes that any part of the window not changed
150 of that window has not been changed on the terminal,
152 that you have not refreshed a portion of the terminal
153 with an overlapping window.
154 If this is not the case,
160 are provided to make it look like a desired part of window has been changed,
163 to check that whole subsection of the terminal for changes.
169 it will make the screen look like the image of
171 This is useful for implementing a command
172 which would redraw the screen in case it got messed up.
175 Input is essentially a mirror image of output.
176 The complementary function to
184 to echo the character.
185 Since the screen package needs to know what is on the terminal at all times,
186 if characters are to be echoed,
187 the tty must be in raw or cbreak mode.
190 sets it to be cbreak,
191 and then reads in the character.
194 In order to perform certain optimizations,
198 some things must be done
199 before the screen routines start up.
200 These functions are performed in
206 In order to clean up after the routines,
210 It restores tty modes to what they were
214 The terminal state module uses the variable
216 to save the original terminal state which is then restored upon a call to
219 anytime after the call to initscr,
221 should be called before exiting.
224 should always be called
228 which free the storage of the windows.