2020-01-02 02:23:11 +00:00
|
|
|
% notcurses_init(3)
|
|
|
|
% nick black <nickblack@linux.com>
|
2020-11-10 15:50:30 +00:00
|
|
|
% v2.0.4
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
# NAME
|
|
|
|
|
2020-01-04 07:37:55 +00:00
|
|
|
notcurses_init - initialize a notcurses instance
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
# SYNOPSIS
|
|
|
|
|
2020-04-19 22:46:32 +00:00
|
|
|
**#include <notcurses/notcurses.h>**
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
```c
|
2020-07-13 05:21:41 +00:00
|
|
|
#define NCOPTION_INHIBIT_SETLOCALE 0x0001ull
|
|
|
|
#define NCOPTION_VERIFY_SIXEL 0x0002ull
|
|
|
|
#define NCOPTION_NO_WINCH_SIGHANDLER 0x0004ull
|
|
|
|
#define NCOPTION_NO_QUIT_SIGHANDLERS 0x0008ull
|
|
|
|
#define NCOPTION_SUPPRESS_BANNERS 0x0020ull
|
|
|
|
#define NCOPTION_NO_ALTERNATE_SCREEN 0x0040ull
|
|
|
|
#define NCOPTION_NO_FONT_CHANGES 0x0080ull
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
NCLOGLEVEL_SILENT, // default. print nothing once fullscreen service begins
|
|
|
|
NCLOGLEVEL_PANIC, // print diagnostics immediately related to crashing
|
|
|
|
NCLOGLEVEL_FATAL, // we're hanging around, but we've had a horrible fault
|
|
|
|
NCLOGLEVEL_ERROR, // we can't keep doin' 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;
|
2020-05-09 08:45:51 +00:00
|
|
|
|
2020-01-02 02:23:11 +00:00
|
|
|
typedef struct notcurses_options {
|
|
|
|
const char* termtype;
|
|
|
|
FILE* renderfp;
|
2020-07-13 05:21:41 +00:00
|
|
|
ncloglevel_e loglevel;
|
2020-03-13 09:07:33 +00:00
|
|
|
int margin_t, margin_r, margin_b, margin_l;
|
2020-07-13 05:21:41 +00:00
|
|
|
uint64_t flags; // from NCOPTION_* bits
|
2020-01-02 02:23:11 +00:00
|
|
|
} notcurses_options;
|
|
|
|
```
|
|
|
|
|
2020-11-06 21:49:35 +00:00
|
|
|
**struct notcurses* notcurses_init(const notcurses_options* ***opts***, FILE* ***fp***);**
|
2020-04-29 07:24:11 +00:00
|
|
|
|
2020-11-06 21:49:35 +00:00
|
|
|
**void notcurses_version_components(int* ***major***, int* ***minor***, int* ***patch***, int* ***tweak***);**
|
2020-07-09 06:17:55 +00:00
|
|
|
|
2020-11-06 21:49:35 +00:00
|
|
|
**int notcurses_lex_margins(const char* ***op***, notcurses_options* ***opts***);**
|
2020-01-02 02:23:11 +00:00
|
|
|
|
2020-11-06 21:49:35 +00:00
|
|
|
**int notcurses_cursor_enable(struct notcurses* ***nc***, int ***y***, int ***x***);**
|
2020-08-25 06:54:46 +00:00
|
|
|
|
2020-11-06 21:49:35 +00:00
|
|
|
**int notcurses_cursor_disable(struct notcurses* ***nc***);**
|
2020-08-25 06:54:46 +00:00
|
|
|
|
2020-01-02 02:23:11 +00:00
|
|
|
# DESCRIPTION
|
|
|
|
|
2020-05-09 02:33:39 +00:00
|
|
|
**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
|
2020-01-02 02:23:11 +00:00
|
|
|
**struct notcurses_option** passed as **opts** controls behavior. Only one
|
|
|
|
instance should be associated with a given terminal at a time, though it is no
|
2020-05-09 02:33:39 +00:00
|
|
|
problem to have multiple instances in a given process.
|
|
|
|
|
|
|
|
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.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
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
|
2020-07-13 05:21:41 +00:00
|
|
|
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.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
2020-08-25 10:23:15 +00:00
|
|
|
notcurses hides the cursor by default. It can be dynamically enabled, moved, or
|
2020-08-25 06:54:46 +00:00
|
|
|
disabled during execution via **notcurses_cursor_enable(3)** and
|
2020-08-25 10:23:15 +00:00
|
|
|
**notcurses_cursor_disable(3)**.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
**notcurses_init** typically emits some diagnostics at startup, including version
|
|
|
|
information and some details of the configured terminal. This can be inhibited
|
2020-07-13 05:21:41 +00:00
|
|
|
with **NCOPTION_SUPPRESS_BANNERS**. This will also inhibit the performance
|
|
|
|
summary normally printed by **notcurses_stop(3)**.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
2020-03-13 09:07:33 +00:00
|
|
|
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. This is the only means by which existing
|
|
|
|
output can be undisturbed by notcurses. Margins are best-effort. Supplying any
|
2020-04-29 07:24:11 +00:00
|
|
|
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.
|
2020-03-13 09:07:33 +00:00
|
|
|
|
2020-05-09 08:45:51 +00:00
|
|
|
To allow future options without requiring redefinition of the structure, the
|
2020-10-07 11:24:04 +00:00
|
|
|
**flags** field is only a partially-defined bitfield. Undefined bits should be
|
2020-05-09 08:45:51 +00:00
|
|
|
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
|
2020-11-04 17:27:36 +00:00
|
|
|
"**POSIX**", it will print a diagnostic to **stderr**, and then call
|
2020-05-09 08:45:51 +00:00
|
|
|
**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.
|
|
|
|
|
2020-07-13 05:21:41 +00:00
|
|
|
* **NCOPTION_VERIFY_SIXEL**: Checking for Sixel support requires writing an
|
|
|
|
escape, and then reading an inline reply from the terminal. Since this can
|
|
|
|
interact poorly with actual user input, it's not done unless Sixel will
|
|
|
|
actually be used. Set this flag to unconditionally test for Sixel support
|
|
|
|
in **notcurses_init**.
|
|
|
|
|
|
|
|
* **NCOPTION_NO_WINCH_SIGHANDLER**: A signal handler will usually be installed
|
|
|
|
for **SIGWINCH**, 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 **SIGINT**, **SIGQUIT**, **SIGSEGV**, **SIGTERM**, and **SIGABRT**,
|
|
|
|
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.
|
2020-05-09 08:45:51 +00:00
|
|
|
|
2020-01-02 02:23:11 +00:00
|
|
|
## 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
|
2020-08-24 04:35:41 +00:00
|
|
|
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
|
2020-01-02 02:23:11 +00:00
|
|
|
the signal to any previously-configured handler. These handlers are disabled
|
|
|
|
upon entry to **notcurses_stop(3)**.
|
|
|
|
|
|
|
|
To prevent signal handler registration, set **no_quit_sighandlers** to **true**.
|
|
|
|
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
|
2020-07-13 05:21:41 +00:00
|
|
|
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.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
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
|
2020-08-24 04:35:41 +00:00
|
|
|
to **notcurses_render(3)**. This is true even if an existing **struct ncplane**
|
2020-05-09 00:56:39 +00:00
|
|
|
(see **notcurses_plane(3)**) overlaps the new area, since the signal could
|
2020-01-02 02:23:11 +00:00
|
|
|
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.
|
|
|
|
|
2020-07-13 05:21:41 +00:00
|
|
|
Thus, in the absence of **NCOPTION_NO_WINCH_SIGHANDLER**, **SIGWINCH** results in:
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
* 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)
|
|
|
|
|
2020-04-08 09:39:41 +00:00
|
|
|
Upon the next call to **notcurses_render(3)** or **notcurses_refresh(3)**, the
|
2020-01-24 05:33:28 +00:00
|
|
|
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.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
# RETURN VALUES
|
|
|
|
|
|
|
|
**NULL** is returned on failure. Otherwise, the return value points at a valid
|
2020-01-24 05:33:28 +00:00
|
|
|
**struct notcurses**, which can be used until it is provided to
|
|
|
|
**notcurses_stop(3)**.
|
2020-01-02 02:23:11 +00:00
|
|
|
|
|
|
|
# SEE ALSO
|
|
|
|
|
2020-05-09 00:56:39 +00:00
|
|
|
**getenv(3)**,
|
2020-05-09 08:45:51 +00:00
|
|
|
**setlocale(3)**,
|
2020-05-09 00:56:39 +00:00
|
|
|
**termios(3)**,
|
|
|
|
**notcurses(3)**,
|
|
|
|
**notcurses_input(3)**,
|
|
|
|
**notcurses_plane(3)**,
|
|
|
|
**notcurses_refresh(3)**,
|
|
|
|
**notcurses_render(3)**,
|
|
|
|
**notcurses_stop(3)**,
|
|
|
|
**terminfo(5)**,
|
|
|
|
**signal(7)**
|