mirror of
https://github.com/dankamongmen/notcurses.git
synced 2024-11-06 03:20:26 +00:00
262 lines
12 KiB
Markdown
262 lines
12 KiB
Markdown
% notcurses_init(3)
|
|
% nick black <nickblack@linux.com>
|
|
% v2.4.99
|
|
|
|
# NAME
|
|
|
|
notcurses_init - initialize a notcurses instance
|
|
|
|
# SYNOPSIS
|
|
|
|
**#include <notcurses/notcurses.h>**
|
|
|
|
```c
|
|
#define NCOPTION_INHIBIT_SETLOCALE 0x0001ull
|
|
#define NCOPTION_NO_CLEAR_BITMAPS 0x0002ull
|
|
#define NCOPTION_NO_WINCH_SIGHANDLER 0x0004ull
|
|
#define NCOPTION_NO_QUIT_SIGHANDLERS 0x0008ull
|
|
#define NCOPTION_PRESERVE_CURSOR 0x0010ull
|
|
#define NCOPTION_SUPPRESS_BANNERS 0x0020ull
|
|
#define NCOPTION_NO_ALTERNATE_SCREEN 0x0040ull
|
|
#define NCOPTION_NO_FONT_CHANGES 0x0080ull
|
|
#define NCOPTION_DRAIN_INPUT 0x0100ull
|
|
|
|
typedef enum {
|
|
NCLOGLEVEL_SILENT, // print nothing once fullscreen service begins
|
|
NCLOGLEVEL_PANIC, // default. print diagnostics before we crash/exit
|
|
NCLOGLEVEL_FATAL, // we're hanging around, but we've had a horrible fault
|
|
NCLOGLEVEL_ERROR, // we can't keep doing this, but we can do other things
|
|
NCLOGLEVEL_WARNING, // you probably don't want what's happening to happen
|
|
NCLOGLEVEL_INFO, // "standard information"
|
|
NCLOGLEVEL_VERBOSE, // "detailed information"
|
|
NCLOGLEVEL_DEBUG, // this is honestly a bit much
|
|
NCLOGLEVEL_TRACE, // there's probably a better way to do what you want
|
|
} ncloglevel_e;
|
|
|
|
typedef struct notcurses_options {
|
|
const char* termtype;
|
|
ncloglevel_e loglevel;
|
|
int margin_t, margin_r, margin_b, margin_l;
|
|
uint64_t flags; // from NCOPTION_* bits
|
|
} notcurses_options;
|
|
```
|
|
|
|
**struct notcurses* notcurses_init(const notcurses_options* ***opts***, FILE* ***fp***);**
|
|
|
|
**void notcurses_version_components(int* ***major***, int* ***minor***, int* ***patch***, int* ***tweak***);**
|
|
|
|
**int notcurses_lex_margins(const char* ***op***, notcurses_options* ***opts***);**
|
|
|
|
**int notcurses_cursor_enable(struct notcurses* ***nc***, int ***y***, int ***x***);**
|
|
|
|
**int notcurses_cursor_yx(struct notcurses* ***nc***, int* ***y***, int* ***x***);**
|
|
|
|
**int notcurses_cursor_disable(struct notcurses* ***nc***);**
|
|
|
|
# DESCRIPTION
|
|
|
|
**notcurses_init** prepares the terminal for cursor-addressable (multiline)
|
|
mode. The **FILE** provided as ***fp*** must be writable and attached to a
|
|
terminal, or **NULL**. If it is **NULL**, **/dev/tty** will be opened. The
|
|
**struct notcurses_option** passed as ***opts*** controls behavior. A process
|
|
can have only one Notcurses context active at a time.
|
|
|
|
On success, a pointer to a valid **struct notcurses** is returned. **NULL** is
|
|
returned on failure. Before the process exits, **notcurses_stop(3)** should be
|
|
called to reset the terminal and free up resources.
|
|
|
|
An appropriate **terminfo(5)** entry must exist for the terminal. This entry is
|
|
usually selected using the value of the **TERM** environment variable (see
|
|
**getenv(3)**), but a non-**NULL** value for **termtype** will override this. An
|
|
invalid terminfo specification can lead to reduced performance, reduced
|
|
display capabilities, and/or display errors. notcurses natively targets
|
|
24bpp/8bpc RGB color, and it is thus desirable to use a terminal with the
|
|
**rgb** capability (e.g. xterm's **xterm-direct**).
|
|
|
|
If the terminal advertises support for an "alternate screen" via the **smcup**
|
|
terminfo capability, notcurses will employ it by default. This can be prevented
|
|
by setting **NCOPTION_NO_ALTERNATE_SCREEN** in ***flags***. Users tend to have
|
|
strong opinions regarding the alternate screen, so it's often useful to expose
|
|
this via a command-line option. When the alternate screen is not used, the
|
|
contents of the terminal at startup remain visible until obliterated, on a
|
|
cell-by-cell basis (see **notcurses_plane(3)** for details on clearing the
|
|
screen at startup without using the alternate screen).
|
|
|
|
notcurses hides the cursor by default. It can be dynamically enabled, moved, or
|
|
disabled during execution via **notcurses_cursor_enable** and
|
|
**notcurses_cursor_disable**. It will be hidden while updating the screen.
|
|
The current location of the terminal cursor can be acquired with
|
|
**notcurses_cursor_yx**, whether visible or not.
|
|
|
|
**notcurses_init** typically emits some diagnostics at startup, including version
|
|
information and some details of the configured terminal. This can be inhibited
|
|
with **NCOPTION_SUPPRESS_BANNERS**. This will also inhibit the performance
|
|
summary normally printed by **notcurses_stop(3)**.
|
|
|
|
Notcurses can render to a subregion of the terminal by specifying desired
|
|
margins on all four sides. By default, all margins are zero, and thus rendering
|
|
will be performed on the entirety of the viewing area. This is orthogonal to
|
|
use of the alternate screen; using the alternate screen plus margins will see
|
|
the full screen cleared, followed by rendering to a subregion. Inhibiting the
|
|
alternate screen plus margins will see rendering to a subregion, with the screen
|
|
outside this region not cleared. Margins are best-effort. Supplying any
|
|
negative margin is an error. **notcurses_lex_margins** provides lexing a
|
|
margin argument expression in one of two forms:
|
|
|
|
* a single number, which will be applied to all sides, or
|
|
* four comma-delimited numbers, applied to top, right, bottom, and left.
|
|
|
|
To allow future options without requiring redefinition of the structure, the
|
|
**flags** field is only a partially-defined bitfield. Undefined bits should be
|
|
zero. The following flags are defined:
|
|
|
|
* **NCOPTION_INHIBIT_SETLOCALE**: Unless this flag is set, **notcurses_init**
|
|
will call **setlocale(LC_ALL, NULL)**. If the result is either "**C**" or
|
|
"**POSIX**", it will print a diagnostic to **stderr**, and then call
|
|
**setlocale(LC_ALL, "").** This will attempt to set the locale based off
|
|
the **LANG** environment variable. Your program should call **setlocale(3)**
|
|
itself, usually as one of the first lines.
|
|
|
|
* **NCOPTION_NO_CLEAR_BITMAPS**: On entry, make no special attempt to clear any
|
|
preexisting bitmaps. Note that they might still get cleared even if this is
|
|
set, and they might not get cleared even if this is not set.
|
|
|
|
* **NCOPTION_NO_WINCH_SIGHANDLER**: A signal handler will usually be installed
|
|
for **SIGWINCH** and **SIGCONT**, resulting in **NCKEY_RESIZE** events
|
|
being generated on input. With this flag, the handler will not be
|
|
installed.
|
|
|
|
* **NCOPTION_NO_QUIT_SIGHANDLERS**: A signal handler will usually be installed
|
|
for **SIGABRT**, **SIGBUS**, **SIGFPE**, **SIGILL**, **SIGINT**,
|
|
**SIGQUIT**, **SIGSEGV**, and **SIGTERM**, cleaning up the terminal on such
|
|
exceptions. With this flag, the handler will not be installed.
|
|
|
|
* **NCOPTION_SUPPRESS_BANNERS**: Disables the diagnostics and version
|
|
information printed on startup, and the performance summary on exit.
|
|
|
|
* **NCOPTION_NO_ALTERNATE_SCREEN**: Do not use the alternate screen
|
|
(see **terminfo(5)**), even if it is available.
|
|
|
|
* **NCOPTION_NO_FONT_CHANGES**: Do not touch the font. Notcurses might
|
|
otherwise attempt to extend the font, especially in the Linux console.
|
|
|
|
* **NCOPTION_DRAIN_INPUT**: Standard input may be freely discarded. If you do not
|
|
intend to process input, pass this flag. Otherwise, input can buffer up, and
|
|
eventually prevent Notcurses from processing messages from the terminal. It
|
|
will furthermore avoid wasting time processing useless input.
|
|
|
|
## Fatal signals
|
|
|
|
It is important to reset the terminal before exiting, whether terminating due
|
|
to intended operation or a received signal. This is usually accomplished by
|
|
explicitly calling **notcurses_stop(3)** during shutdown. For convenience, notcurses
|
|
by default installs signal handlers for various signals which would typically
|
|
result in process termination (see **signal(7)**). These signal handlers call
|
|
**notcurses_stop(3)** for each **struct notcurses** in the process, and then propagate
|
|
the signal to any previously-configured handler. These handlers are disabled
|
|
upon entry to **notcurses_stop(3)**.
|
|
|
|
To prevent signal handler registration, provide **NCOPTION_NO_QUIT_SIGHANDLERS**.
|
|
No means is provided to selectively register fatal signal handlers. If this is
|
|
done, the caller ought be sure to effect similar functionality themselves.
|
|
|
|
## Resize events
|
|
|
|
**SIGWINCH** (SIGnal WINdow CHange) is delivered to the process when the terminal
|
|
is resized. The default action is to ignore it (**SIG_IGN**). notcurses installs
|
|
a handler for this signal. The handler causes notcurses to update its idea of
|
|
the terminal's size using **TIOCGWINSZ** (see **ioctl_tty(2)**), and generates an
|
|
**NCKEY_RESIZE** input event (see **notcurses_input(3)**. This signal handler can be
|
|
inhibited by setting **NCOPTION_NO_WINCH_SIGHANDLER** in **flags**. If this is
|
|
done, the caller should probably watch for the signal, and invoke
|
|
**notcurses_refresh(3)** or **notcurses_render(3)** upon its receipt.
|
|
|
|
A resize event does not invalidate any references returned earlier by
|
|
notcurses. The content of any new screen area is undefined until the next call
|
|
to **notcurses_render(3)**. This is true even if an existing **struct ncplane**
|
|
(see **notcurses_plane(3)**) overlaps the new area, since the signal could
|
|
arrive while the ncplanes are being modified. Signal handlers are quite
|
|
restricted as to what actions they can perform, so minimal work is performed in
|
|
the handler proper.
|
|
|
|
Thus, in the absence of **NCOPTION_NO_WINCH_SIGHANDLER**, **SIGWINCH** results in:
|
|
|
|
* interruption of some thread to process the signal
|
|
* a **TIOCGWINSZ** **ioctl** to retrieve the new screen size
|
|
* queuing of a **NCKEY_RESIZE** input event (if there is space in the queue)
|
|
|
|
Upon the next call to **notcurses_render(3)** or **notcurses_refresh(3)**, the
|
|
standard plane (see **notcurses_stdplane(3)**) will be resized to the new
|
|
screen size. The next **notcurses_render(3)** call will function as expected
|
|
across the new screen geometry.
|
|
|
|
## The hardware cursor
|
|
|
|
Most terminals provide a cursor, a visual indicator of where output will next
|
|
be placed. There is usually (but not always) some degree of control over what
|
|
glyph forms this cursor, and whether it e.g. blinks.
|
|
|
|
By default, Notcurses disables this cursor in rendered mode. It can be turned
|
|
back on with **notcurses_enable_cursor**, which has immediate effect (there is
|
|
no need to call **notcurses_render(3)**). If already visible, this function
|
|
updates the location. Each time the physical screen is updated, Notcurses will
|
|
disable the cursor, write the update, move the cursor back to this location,
|
|
and finally make the cursor visible. **notcurses_cursor_yx** retrieves the
|
|
location of the cursor, whether visible or not. **notcurses_disable_cursor**
|
|
hides the cursor.
|
|
|
|
You generally shouldn't need to touch the terminal cursor. It's only really
|
|
relevant with echoed user input, and you don't want echoed user input in
|
|
rendered mode (instead, read the input, and write it to a plane yourself).
|
|
A subprocess can be streamed to a plane with an **ncsubproc**, etc.
|
|
|
|
If the **NCOPTION_PRESERVE_CURSOR** flag is provided, the cursor's location
|
|
will be determined at startup, and the standard plane's virtual cursor will
|
|
be placed to match it (instead of in the upper-left corner). Combined with
|
|
**NCOPTION_NO_ALTERNATE_SCREEN** and a scrolling standard plane, this allows
|
|
rendered mode to be used as a normal scrolling shell application.
|
|
|
|
# RETURN VALUES
|
|
|
|
**NULL** is returned on failure. Otherwise, the return value points at a valid
|
|
**struct notcurses**, which can be used until it is provided to
|
|
**notcurses_stop(3)**.
|
|
|
|
**notcurses_cursor_disable** returns -1 if the cursor is already invisible.
|
|
|
|
# ENVIRONMENT VARIABLES
|
|
|
|
The **NOTCURSES_LOGLEVEL** environment variable, if defined, ought be an
|
|
integer between -1 and 7. These values correspond to **NCLOGLEVEL_SILENT**
|
|
through **NCLOGLEVEL_TRACE**, and override the **loglevel** field of
|
|
**notcurses_options**.
|
|
|
|
The **TERM** environment variable will be used by **setupterm(3ncurses)** to
|
|
select an appropriate terminfo database.
|
|
|
|
# NOTES
|
|
|
|
Several command-line options and keybindings are recommended for Notcurses
|
|
rendered-mode programs:
|
|
|
|
* **-l[0-8]** ought be mapped to the various **NCLOGLEVEL** values.
|
|
Alternatively, map **-v** to **NCLOGLEVEL_WARNING**, and map
|
|
**-vv** to **NCLOGLEVEL_INFO**.
|
|
* **-k** ought be mapped to **NCOPTION_NO_ALTERNATE_SCREEN**.
|
|
* Ctrl+L ought be mapped to **notcurses_refresh(3)**.
|
|
|
|
# SEE ALSO
|
|
|
|
**getenv(3)**,
|
|
**setlocale(3)**,
|
|
**termios(3)**,
|
|
**notcurses(3)**,
|
|
**notcurses_input(3)**,
|
|
**notcurses_plane(3)**,
|
|
**notcurses_refresh(3)**,
|
|
**notcurses_render(3)**,
|
|
**notcurses_stop(3)**,
|
|
**setupterm(3ncurses)**,
|
|
**terminfo(5)**,
|
|
**signal(7)**
|