2019-11-17 02:38:25 +00:00
# notcurses
2019-12-13 22:14:15 +00:00
blingful TUI library for modern terminal emulators. definitely not curses.
2020-02-18 03:48:07 +00:00
* birthed screaming into this world by [nick black ](https://nick-black.com/dankwiki/index.php/Hack_on ) (< nickblack @ linux . com > )
2020-01-22 11:51:25 +00:00
* C++ wrappers by [marek habersack ](http://twistedcode.net/blog/ ) (< grendel @ twistedcode . net > )
2019-11-17 10:04:41 +00:00
2020-01-22 11:51:25 +00:00
for more information, see [dankwiki ](https://nick-black.com/dankwiki/index.php/Notcurses )
2020-04-24 05:18:48 +00:00
and the [man pages ](https://nick-black.com/notcurses ). There's also a reference
[in this repo ](USAGE.md ).
2020-03-21 15:58:50 +00:00
In addition, there is
2020-03-17 14:56:01 +00:00
[Doxygen ](https://nick-black.com/notcurses/html/ ) output. There is a [mailing
list](https://groups.google.com/forum/#!forum/notcurses) which can be reached
via notcurses@googlegroups.com.
2019-12-22 04:31:57 +00:00
2020-04-02 18:01:57 +00:00
I wrote a coherent [guidebook ](https://nick-black.com/htp-notcurses.pdf ), which
is available for free download, or [paperback purchase ](https://amazon.com/dp/B086PNVNC9 ).
2020-04-30 05:14:42 +00:00
Notcurses is available in the Arch [AUR ](https://aur.archlinux.org/packages/notcurses/ ),
and from [Debian Unstable ](https://packages.debian.org/source/sid/notcurses ).
Packages for Fedora 33 and Ubuntu Focal are available from [DSSCAW ](https://www.dsscaw.com/apt.html ).
2020-05-11 16:30:53 +00:00
Notcurses is available from the FreeBSD [Ports Collection ](https://www.freshports.org/devel/notcurses/ ).
2020-02-03 20:26:29 +00:00
2019-12-16 07:00:33 +00:00
[![Build Status ](https://drone.dsscaw.com:4443/api/badges/dankamongmen/notcurses/status.svg )](https://drone.dsscaw.com:4443/dankamongmen/notcurses)
[![License ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://opensource.org/licenses/Apache-2.0)
2019-11-25 05:26:35 +00:00
* [Introduction ](#introduction )
2019-11-29 03:32:49 +00:00
* [Requirements ](#requirements )
2019-12-24 00:16:57 +00:00
* [Building ](#building )
2019-11-29 06:58:45 +00:00
* [Included tools ](#included-tools )
2019-11-25 05:26:35 +00:00
* [Differences from NCURSES ](#differences-from-ncurses )
2019-11-29 03:32:49 +00:00
* [Features missing relative to NCURSES ](#features-missing-relative-to-ncurses )
2019-12-06 23:33:20 +00:00
* [Adapting NCURSES programs ](#adapting-ncurses-programs )
2019-12-16 07:00:33 +00:00
* [Environment notes ](#environment-notes )
2020-03-13 09:07:33 +00:00
* [TrueColor detection ](#TrueColor-detection )
2019-12-16 07:00:33 +00:00
* [Fonts ](#fonts )
2020-01-05 23:36:33 +00:00
* [FAQs ](#faqs )
2019-12-13 18:00:29 +00:00
* [Supplemental material ](#supplemental-material )
* [Useful links ](#useful-links )
2019-12-16 07:00:33 +00:00
* [Other TUI libraries ](#other-tui-libraries-of-note )
2019-12-13 18:00:29 +00:00
* [History ](#history )
* [Thanks ](#thanks )
2019-11-25 05:26:35 +00:00
## Introduction
2019-11-18 05:05:32 +00:00
* **What it is**: a library facilitating complex TUIs on modern terminal
2019-11-23 21:09:37 +00:00
emulators, supporting vivid colors and Unicode to the maximum degree
2020-04-21 05:50:53 +00:00
possible. Many tasks delegated to Curses can be achieved using Notcurses
2019-11-23 21:09:37 +00:00
(and vice versa).
2019-11-18 04:09:06 +00:00
2019-11-18 05:05:32 +00:00
* **What it is not**: a source-compatible X/Open Curses implementation, nor a
2020-04-27 01:21:43 +00:00
replacement for NCURSES on existing systems.
2019-11-18 04:09:06 +00:00
2020-04-21 05:50:53 +00:00
Notcurses abandons the X/Open Curses API bundled as part of the Single UNIX
2019-11-19 11:53:50 +00:00
Specification. The latter shows its age, and seems not capable of making use of
2020-03-13 09:07:33 +00:00
terminal functionality such as unindexed 24-bit color ("TrueColor", not to be
confused with the 8-bit indexed 24-bit "extended color" of NCURSES).
For some necessary background, consult Thomas E. Dickey's
2020-01-05 23:36:33 +00:00
superb and authoritative [NCURSES FAQ ](https://invisible-island.net/ncurses/ncurses.faq.html#xterm_16MegaColors ).
2020-04-21 05:50:53 +00:00
As such, Notcurses is not a drop-in Curses replacement. It is almost certainly
2019-11-23 14:06:54 +00:00
less portable, and definitely tested on less hardware. Sorry about that.
Ultimately, I hope to properly support all terminals *supporting the features
necessary for complex TUIs*. I would argue that teletypes etc. are
fundamentally unsuitable. Most operating systems seem reasonable targets, but I
only have Linux and FreeBSD available for testing.
2019-11-21 16:00:40 +00:00
2020-04-21 05:50:53 +00:00
Whenever possible, Notcurses makes use of the Terminfo library shipped with
2019-11-23 14:07:35 +00:00
NCURSES, benefiting greatly from its portability and thoroughness.
2019-11-18 04:09:06 +00:00
2020-04-21 05:50:53 +00:00
Notcurses opens up advanced functionality for the interactive user on
2019-11-18 04:09:06 +00:00
workstations, phones, laptops, and tablets, at the expense of e.g.
2020-04-18 01:08:22 +00:00
some industrial and retail terminals.
2019-11-18 04:09:06 +00:00
Why use this non-standard library?
2019-12-14 10:33:34 +00:00
* Thread safety, and efficient use in parallel programs, has been a design
consideration from the beginning.
2019-11-18 04:09:06 +00:00
2019-12-14 22:34:10 +00:00
* A svelter design than that codified by X/Open:
2019-12-14 10:33:34 +00:00
* Exported identifiers are prefixed to avoid common namespace collisions.
* The library object exports a minimal set of symbols. Where reasonable,
`static inline` header-only code is used. This facilitates compiler
optimizations, and reduces loader time.
2019-11-18 04:09:06 +00:00
2020-04-18 01:08:22 +00:00
* All APIs natively support the Universal Character Set (Unicode). The `cell`
2020-04-26 21:32:08 +00:00
API is based around Unicode's [Extended Grapheme Cluster ](https://unicode.org/reports/tr29/ ) concept.
2019-12-14 10:33:34 +00:00
* Visual features including images, fonts, video, high-contrast text, sprites,
and transparent regions. All APIs natively support 24-bit color, quantized
down as necessary for the terminal.
2019-11-18 17:16:26 +00:00
2019-11-23 14:05:32 +00:00
* It's Apache2-licensed in its entirety, as opposed to the
2019-11-23 14:12:00 +00:00
[drama in several acts ](https://invisible-island.net/ncurses/ncurses-license.html )
2019-11-23 14:05:32 +00:00
that is the NCURSES license (the latter is [summarized ](https://invisible-island.net/ncurses/ncurses-license.html#issues_freer )
as "a restatement of MIT-X11").
2019-12-14 10:33:34 +00:00
Much of the above can be had with NCURSES, but they're not what NCURSES was
*designed* for. The most fundamental advantage in my mind, though, is
2020-04-21 05:50:53 +00:00
that Notcurses is of the multithreaded era. On the other hand, if you're
2019-12-14 11:40:01 +00:00
targeting industrial or critical applications, or wish to benefit from the
time-tested reliability and portability of Curses, you should by all means use
that fine library.
2019-11-21 14:06:36 +00:00
2019-11-25 03:24:41 +00:00
## Requirements
2020-02-18 17:36:16 +00:00
* (build) A C11 and a C++17 compiler
* (build) CMake 3.14.0+
* (build+runtime) From NCURSES: terminfo 6.1+
2020-04-21 03:26:41 +00:00
* (OPTIONAL) (build+runtime) From QR-Code-generator: [libqrcodegen ](https://github.com/nayuki/QR-Code-generator ) 1.5.0+
2020-04-14 15:59:41 +00:00
* (OPTIONAL) (build+runtime) From [FFMpeg ](https://www.ffmpeg.org/ ): libswscale 5.0+, libavformat 57.0+, libavutil 56.0+
2020-04-26 01:50:42 +00:00
* (OPTIONAL) (build+runtime) [OpenImageIO ](https://github.com/OpenImageIO/oiio ) 2.1+
2020-02-19 01:03:20 +00:00
* (OPTIONAL) (testing) [Doctest ](https://github.com/onqtam/doctest ) 2.3.5+
2020-02-18 17:36:16 +00:00
* (OPTIONAL) (documentation) [pandoc ](https://pandoc.org/index.html ) 1.19.2+
2020-04-14 15:59:41 +00:00
* (OPTIONAL) (python bindings): Python 3.7+, [CFFI ](https://pypi.org/project/cffi/ ) 1.13.2+
* (OPTIONAL) (rust bindings): rust 1.40.0+, cargo 0.40.0+, [bindgen ](https://crates.io/crates/bindgen ) 0.53.0+
2020-05-11 16:30:53 +00:00
* (runtime) Linux 5.3+ or FreeBSD 12+
2019-11-25 03:24:41 +00:00
2019-12-24 00:16:57 +00:00
### Building
* Create a subdirectory, traditionally `build` . Enter the directory.
* `cmake ..` . You might want to set e.g. `CMAKE_BUILD_TYPE` .
* `make`
* `make test`
2020-04-24 07:48:56 +00:00
The default multimedia engine is FFmpeg. You can select a different engine
using `USE_MULTIMEDIA` . Valid values are `ffmpeg` , `oiio` (for OpenImageIO),
or `none` .
2019-12-24 00:16:57 +00:00
If you have unit test failures, *please* file a bug including the output of
`./notcurses-tester > log 2>&1` (`make test` also runs `notcurses-tester` , but
hides important output).
To watch the bitchin' demo, run `./notcurses-demo -p ../data` . More details can
be found on the `notcurses-demo(1)` man page.
2019-11-29 06:58:45 +00:00
## Included tools
2020-03-25 08:06:38 +00:00
Six binaries are installed as part of notcurses:
2019-11-29 06:58:45 +00:00
* `notcurses-demo` : some demonstration code
* `notcurses-view` : renders visual media (images/videos)
* `notcurses-input` : decode and print keypresses
2020-02-05 22:29:42 +00:00
* `notcurses-planereels` : play around with ncreels
2019-12-14 00:22:11 +00:00
* `notcurses-tester` : unit testing
2020-03-25 08:06:38 +00:00
* `notcurses-tetris` : a tetris clone
2019-11-29 06:58:45 +00:00
2019-12-21 21:02:27 +00:00
To run `notcurses-demo` from a checkout, provide the `tests/` directory via
the `-p` argument. Demos requiring data files will otherwise abort. The base
delay used in `notcurses-demo` can be changed with `-d` , accepting a
floating-point multiplier. Values less than 1 will speed up the demo, while
values greater than 1 will slow it down.
`notcurses-tester` expects `../tests/` to exist, and be populated with the
necessary data files. It can be run by itself, or via `make test` .
2019-11-23 14:05:32 +00:00
## Differences from NCURSES
The biggest difference, of course, is that notcurses is not an implementation
of X/Open (aka XSI) Curses, nor part of SUS4-2018.
The detailed differences between notcurses and NCURSES probably can't be fully
2020-01-24 05:33:28 +00:00
enumerated, and if they could, no one would want to read them. With that said,
2019-11-23 14:05:32 +00:00
some design decisions might surprise NCURSES programmers:
* There is no distinct `PANEL` type. The z-buffer is a fundamental property,
and all drawable surfaces are ordered along the z axis. There is no
equivalent to `update_panels()` .
* Scrolling is disabled by default, and cannot be globally enabled.
2019-11-23 21:03:38 +00:00
* The Curses `cchar_t` has a fixed-size array of `wchar_t` . The notcurses
`cell` instead supports a UTF-8 encoded extended grapheme cluster of
2020-04-04 04:03:51 +00:00
arbitrary length. The only supported charsets are `ANSI_X3.4-1968` and
`UTF-8` .
2019-11-23 14:05:32 +00:00
* The hardware cursor is disabled by default, when supported (`civis` capability).
* Echoing of input is disabled by default, and `cbreak` mode is used by default.
* Colors are always specified as 24 bits in 3 components (RGB). If necessary,
these will be quantized for the actual terminal. There are no "color pairs".
* There is no distinct "pad" concept (these are NCURSES `WINDOW` s created with
the `newpad()` function). All drawable surfaces can exceed the display size.
* Multiple threads can freely call into notcurses, so long as they're not
accessing the same data. In particular, it is always safe to concurrently
2019-12-14 12:23:49 +00:00
mutate different `ncplane` s in different threads.
2019-11-23 14:05:32 +00:00
* NCURSES has thread-ignorant and thread-semi-safe versions, trace-enabled and
traceless versions, and versions with and without support for wide characters.
2019-11-23 21:09:37 +00:00
notcurses is one library: no tracing, UTF-8, thread safety.
2019-12-05 05:26:33 +00:00
* There is no `ESCDELAY` concept; notcurses expects that all bytes of a
2019-12-13 18:00:29 +00:00
keyboard escape sequence arrive at the same time. This improves latency
2019-12-05 05:26:33 +00:00
and simplifies the API.
2019-12-14 00:22:11 +00:00
* It is an error in NCURSES to print to the bottommost, rightmost coordinate of
the screen when scrolling is disabled (because the cursor cannot be advanced).
Failure to advance the cursor does not result in an error in notcurses (but
attempting to print at the cursor when it has been advanced off the plane
*does* ).
2019-11-23 14:05:32 +00:00
### Features missing relative to NCURSES
This isn't "features currently missing", but rather "features I do not intend
to implement".
* There is no support for soft labels (`slk_init()`, etc.).
* There is no concept of subwindows which share memory with their parents.
* There is no tracing functionality ala `trace(3NCURSES)` . Superior external
tracing solutions exist, such as `bpftrace` .
2019-11-29 03:08:26 +00:00
2019-12-06 23:33:20 +00:00
### Adapting NCURSES programs
2019-12-14 12:23:49 +00:00
Do you really want to do such a thing? NCURSES and the Curses API it implements
are far more portable and better-tested than notcurses is ever likely to be.
Will your program really benefit from notcurses's advanced features? If not,
it's probably best left as it is.
2019-12-06 23:33:20 +00:00
Otherwise, most NCURSES concepts have clear partners in notcurses. Any functions
making implicit use of `stdscr` ought be replaced with their explicit
equivalents. `stdscr` ought then be replaced with the result of
`notcurses_stdplane()` (the standard plane). `PANEL` s become `ncplane` s; the
Panels API is otherwise pretty close. Anything writing a bare character will
become a simple `cell` ; multibyte or wide characters become complex `cell` s.
2019-12-14 12:23:49 +00:00
Color no longer uses "color pairs". You can easily enough hack together a
simple table mapping your colors to RGB values, and color pairs to foreground
and background indices into said table. That'll work for the duration of a
porting effort, certainly.
2019-12-06 23:33:20 +00:00
2019-12-14 12:23:49 +00:00
I have adapted two large (~5k lines of C UI code each) programs from NCURSES to
2019-12-07 03:45:08 +00:00
notcurses, and found it a fairly painless process. It was helpful to introduce
a shim layer, e.g. `compat_mvwprintw` for NCURSES's `mvwprintw` :
```c
static int
compat_mvwprintw(struct ncplane* nc, int y, int x, const char* fmt, ...){
va_list va;
va_start(va, fmt);
2020-01-09 06:48:42 +00:00
if(ncplane_vprintf_yx(nc, y, x, fmt, va) < 0 ) {
2019-12-07 03:45:08 +00:00
va_end(va);
return ERR;
}
va_end(va);
return OK;
}
```
2019-12-06 23:33:20 +00:00
2019-12-14 12:23:49 +00:00
These are pretty obvious, implementation-wise.
2019-11-29 10:54:50 +00:00
## Environment notes
* If your terminal has an option about default interpretation of "ambiguous-width
characters" (this is actually a technical term from Unicode), ensure it is
2019-12-18 10:31:29 +00:00
set to **Wide** , not narrow. If that doesn't work, ensure it is set to
**Narrow** , heh.
2019-11-29 10:54:50 +00:00
* If you can disable BiDi in your terminal, do so while running notcurses
applications, until I have that handled better. notcurses doesn't recognize
the BiDi state machine transitions, and thus merrily continues writing
2019-12-18 10:31:29 +00:00
left-to-right. Likewise, ultra-wide glyphs will have interesting effects.
﷽!
2019-11-29 10:54:50 +00:00
2019-12-24 05:47:31 +00:00
* The unit tests assume dimensions of at least 80x24. They might work in a
2019-12-14 10:33:34 +00:00
smaller terminal. They might not. Don't file bugs on it.
2020-03-13 09:07:33 +00:00
### TrueColor detection
2019-12-16 21:53:11 +00:00
2020-03-13 09:07:33 +00:00
notcurses aims to use only information found in the terminal's terminfo entry to detect capabilities, TrueColor
2019-12-16 21:53:11 +00:00
being one of them. Support for this is indicated by terminfo having a flag, added in NCURSES 6.1, named `RGB` set
to `true` . However, as of today there are few and far between terminfo entries which have the capability in their
2020-03-13 09:07:33 +00:00
database entry and so TrueColor won't be used in most cases. Terminal emulators have had for years a kludge to
2019-12-16 21:53:11 +00:00
work around this limitation of terminfo in the form of the `COLORTERM` environment variable which, if set to either
`truecolor` or `24bit` does the job of indicating the capability of sending the escapes 48 and 38 together with a
2019-12-18 10:02:02 +00:00
tripartite RGB (0 ≤ c ≤ 255 for all three components) to specify fore- and background colors.
2019-12-16 21:53:11 +00:00
Checking for `COLORTERM` admittedly goes against the goal stated at the top of this section but, for all practical
purposes, makes the detection work quite well **today** .
2019-12-16 07:00:33 +00:00
### Fonts
2019-12-18 10:31:29 +00:00
Fonts end up being a whole thing, little of which is pleasant. I'll write this
up someday **FIXME** .
2019-12-18 10:02:02 +00:00
2020-01-05 23:36:33 +00:00
### FAQs
2019-12-18 10:02:02 +00:00
2020-01-05 23:36:33 +00:00
* *Q:* Why didn't you just use Sixel?
* *A:* Many terminal emulators don't support Sixel. Sixel doesn't work well
with mouse selection. With that said, I do intend to support Sixel soon,
as a backend, when available, for certain types of drawing.
* *Q:* I'm not seeing `NCKEY_RESIZE` until I press some other key.
* *A:* You've almost certainly failed to mask `SIGWINCH` in some thread, and
that thread is receiving the signal instead of the thread which called
`notcurses_getc_blocking()` . As a result, the `poll()` is not
interrupted. Call `pthread_sigmask()` before spawning any threads.
2019-12-16 07:00:33 +00:00
2020-01-18 21:06:57 +00:00
* *Q:* One of the demos claimed to spend more than 100% of its runtime rendering. Do you know how to count?
* *A:* Runtime is wall clock time. A multithreaded demo can spend more than the wall-clock time rendering if the threads contend.
2020-01-25 16:06:08 +00:00
* *Q:* Using the C++ wrapper, how can I ensure that the `NotCurses` destructor is run when I return from `main()` ?
* *A:* As noted in the [C++ FAQ ](https://isocpp.org/wiki/faq/dtors#artificial-block-to-control-lifetimes ), wrap it in an artificial scope (this assumes your `NotCurses` is scoped to `main()` ).
2020-01-27 03:24:56 +00:00
* *Q:* How do I hide a plane I want to make visible later?
2020-04-30 05:14:42 +00:00
* *A:* Either move it above and to the left of the screen (preventing resizes from making it visible), or place it underneath another (opaque) plane (the latter performs better).
2020-01-27 03:24:56 +00:00
2020-02-12 17:29:28 +00:00
* *Q:* Why isn't there an `ncplane_box_yx()` ? Do you hate orthogonality, you dullard?
* *A:* `ncplane_box()` and friends already have far too many arguments, you monster.
2020-05-04 05:09:17 +00:00
* *Q:* Why doesn't Notcurses support 10- or 16-bit color?
* *A:* Notcurses supports 24 bits of color, spread across three eight-bit channels. You presumably mean 10-bit-per-channel color. Notcurses will support it when a terminal supports it.
2020-03-26 03:10:31 +00:00
* *Q:* You seem a creative guy. Why the least creative name ever?
* *A:* I really didn't expect this to go anywhere.
2019-12-13 18:00:29 +00:00
## Supplemental material
### Useful links
2019-11-29 03:08:26 +00:00
* [BiDi in Terminal Emulators ](https://terminal-wg.pages.freedesktop.org/bidi/ )
* [The Xterm FAQ ](https://invisible-island.net/xterm/xterm.faq.html )
2019-12-23 03:45:20 +00:00
* [XTerm Control Sequences ](https://invisible-island.net/xterm/ctlseqs/ctlseqs.pdf )
2019-11-29 03:08:26 +00:00
* [The NCURSES FAQ ](https://invisible-island.net/ncurses/ncurses.faq.html )
* [ECMA-35 Character Code Structure and Extension Techniques ](https://www.ecma-international.org/publications/standards/Ecma-035.htm ) (ISO/IEC 2022)
* [ECMA-43 8-bit Coded Character Set Structure and Rules ](https://www.ecma-international.org/publications/standards/Ecma-043.htm )
* [ECMA-48 Control Functions for Coded Character Sets ](https://www.ecma-international.org/publications/standards/Ecma-048.htm ) (ISO/IEC 6429)
* [Unicode 12.1 Full Emoji List ](https://unicode.org/emoji/charts/full-emoji-list.html )
2019-12-02 15:39:48 +00:00
* [Unicode Standard Annex #29 Text Segmentation ](http://www.unicode.org/reports/tr29 )
2019-11-29 03:08:26 +00:00
* [Unicode Standard Annex #15 Normalization Forms ](https://unicode.org/reports/tr15/ )
2019-11-29 09:57:09 +00:00
* [The TTY demystified ](http://www.linusakesson.net/programming/tty/ )
2019-12-14 10:33:34 +00:00
* [Dark Corners of Unicode ](https://eev.ee/blog/2015/09/12/dark-corners-of-unicode/ )
* [UTF-8 Decoder Capability and Stress Test ](https://www.cl.cam.ac.uk/~mgk25/ucs/examples/UTF-8-test.txt )
2019-12-13 18:00:29 +00:00
2019-12-23 03:45:20 +00:00
#### Useful man pages
* Linux: [console_codes(4) ](http://man7.org/linux/man-pages/man4/console_codes.4.html )
* Linux: [termios(3) ](http://man7.org/linux/man-pages/man3/termios.3.html )
* Linux: [ioctl_tty(2) ](http://man7.org/linux/man-pages/man2/ioctl_tty.2.html )
* Linux: [ioctl_console(2) ](http://man7.org/linux/man-pages/man2/ioctl_console.2.html )
* Portable: [terminfo(5) ](http://man7.org/linux/man-pages/man5/terminfo.5.html )
2019-12-23 07:47:34 +00:00
* Portable: [user_caps(5) ](http://man7.org/linux/man-pages/man5/user_caps.5.html )
2019-12-23 03:45:20 +00:00
2019-12-13 18:00:29 +00:00
### History
2020-05-11 16:30:53 +00:00
* 2020-05-10: Notcurses [1.4.0 "the saga continues" ](https://github.com/dankamongmen/notcurses/releases/tag/v1.4.0 ).
* 2020-05-09: Notcurses is [accepted into FreeBSD ](https://github.com/dankamongmen/notcurses/issues/575 ).
2020-04-21 05:50:53 +00:00
* 2020-04-19: Notcurses is [accepted into Debian ](https://bugs.debian.org/950492 ).
* 2020-04-12: Notcurses [1.3.0 "hypnotize" ](https://github.com/dankamongmen/notcurses/releases/tag/v1.3.0 ).
2020-05-09 10:08:23 +00:00
* A new [hype video ](https://vimeo.com/410787965 ) is never really publicized.
2020-04-21 05:50:53 +00:00
* 2020-04-08: The Notcurses book [is published ](https://amazon.com/dp/B086PNVNC9 ).
* 2020-03-23: Notcurses is featured on [Linux World News ](https://lwn.net/Articles/815811/ ).
* 2020-02-17: Notcurses [1.2.0 "check the résumé, my record's impeccable" ](https://github.com/dankamongmen/notcurses/releases/tag/v1.2.0 ).
* 2019-01-19: Notcurses [1.1.0 "all the hustlas they love it just to see one of us make it" ](https://github.com/dankamongmen/notcurses/releases/tag/v1.1.0 ).
2020-01-19 20:04:42 +00:00
Much better video support, pulsing planes, palette256.
2020-05-09 10:08:23 +00:00
* The new [hype video ](https://www.youtube.com/watch?v=-H1WkopWJNMk ) gets a lot of attention.
2020-04-21 05:50:53 +00:00
* 2019-01-04: Notcurses [1.0.0 "track team, crack fiend, dying to geek" ](https://github.com/dankamongmen/notcurses/releases/tag/v1.0.0 )
2020-01-04 13:39:20 +00:00
is released, six days ahead of schedule. 147 issues closed. 702 commits.
2020-04-21 05:50:53 +00:00
* 2019-12-18: Notcurses [0.9.0 "You dig in! You dig out! You get out!" ](https://github.com/dankamongmen/notcurses/releases/tag/v0.9.0 ),
2019-12-18 10:31:29 +00:00
and also the first contributor besides myself (@grendello). Last major
pre-GA release.
2020-04-21 05:50:53 +00:00
* 2019-12-05: Notcurses [0.4.0 "TRAP MUSIC ALL NIGHT LONG" ](https://github.com/dankamongmen/notcurses/releases/tag/v0.4.0 ),
2020-05-09 10:08:23 +00:00
the first generally usable notcurses.
* I prepare a [demo ](https://www.youtube.com/watch?v=eEv2YRyiEVM ), and release it on YouTube.
2020-02-05 22:29:42 +00:00
* November 2019: I begin work on [Outcurses ](https://github.com/dankamongmen/ncreels ).
Outcurses is a collection of routines atop NCURSES, including ncreels.
2019-12-13 18:00:29 +00:00
I study the history of NCURSES, primarily using Thomas E. Dickey's FAQ and
the mailing list archives.
2020-02-05 22:29:42 +00:00
* 2019-11-14: I file [Outcurses issue #56 ](https://github.com/dankamongmen/ncreels/issues/56 )
2020-03-13 09:07:33 +00:00
regarding use of TrueColor in outcurses. This is partially inspired by
2019-12-13 18:00:29 +00:00
Lexi Summer Hale's essay [everything you ever wanted to know about terminals ](http://xn--rpa.cc/irl/term.html ).
I get into contact with Thomas E. Dickey and confirm that what I'm hoping
to do doesn't really fit in with the codified Curses API.
* 2019-11-16: I make the [first commit ](https://github.com/dankamongmen/notcurses/commit/635d7039d79e4f94ba645e8cb601e3a6d82a6b30 )
2020-04-21 05:50:53 +00:00
to Notcurses.
2019-12-13 18:00:29 +00:00
* September 2019: I extracted fade routines from Growlight and Omphalos, and
offered them to NCURSES as extensions. They are not accepted, which is
2020-02-05 22:29:42 +00:00
understandable. I mention that I intend to extract ncreels, and offer to
2019-12-13 18:00:29 +00:00
include them in the CDK (Curses Development Kit). [Growlight issue #43 ](https://github.com/dankamongmen/growlight/issues/43 )
is created regarding this extraction. A few minor patches go into NCURSES.
* 2011, 2013: I develop [Growlight ](https://github.com/dankamongmen/growlight )
and [Omphalos ](https://github.com/dankamongmen/omphalos ), complicated TUIs
making extensive use of NCURSES.
### Thanks
* Notcurses could never be what it is without decades of tireless, likely
thankless work by Thomas E. Dickey on NCURSES. His FAQ is a model of
engineering history. He exemplifies documentation excellence and
2019-12-17 02:29:59 +00:00
conservative, thoughtful stewardship. The free software community owes
2019-12-13 18:00:29 +00:00
Mr. Dickey a great debt.
2020-04-21 05:50:53 +00:00
* Robert Edmonds provided tremendous assistance Debianizing the package,
and David Cantrell did likewise for Fedora. Both are hella engineers.
2019-12-13 18:00:29 +00:00
* Justine Tunney, one of my first friends at Google NYC, was always present
with support, and pointed out the useful memstream functionality of
POSIX, eliminating the need for me to cons up something similar.
* I one night read the entirety of Lexi Summer Hale's [essays ](http://xn--rpa.cc/irl/index.html ),
and woke up intending to write notcurses.
2020-01-19 09:39:15 +00:00
* NES art was lifted from [The Spriters Resource ](https://www.spriters-resource.com/nes/ )
and [NES Sprite ](http://nes-sprite.resampled.ru/ ), the kind of sites that
make the Internet great. It probably violates any number of copyrights. C'est la vie.
2020-01-19 07:31:08 +00:00
* Mark Ferrari, master of the pixel, for no good reason allowed me to reproduce
his incredible and groundbreaking color-cycling artwork. Thanks Mark!
2019-12-13 18:00:29 +00:00
* Finally, the [demoscene ](https://en.wikipedia.org/wiki/Demoscene ) and general
l33t scene of the 90s and early twenty-first century endlessly inspired a
young hax0r. There is great joy in computing; no one will drive us from
this paradise Turing has created!
> “Our fine arts were developed, their types and uses were established, in times
very different from the present, by men whose power of action upon things was
insignificant in comparison with ours. But the amazing growth of our
techniques, the adaptability and precision they have attained, the ideas and
habits they are creating, make it a certainty that _profound changes are
2019-12-14 23:44:04 +00:00
impending in the ancient craft of the Beautiful_.” —Paul Valéry