New:
Terminal
andLocalTerminal
are now renamed toTerminalState
andLocalTerminalState
, respectively, along with some new capabilities:- Add
focused
boolean which defaults to true. If the terminal supports sending focus changes, this will be updated in real time. - Add
theme
property which defaults to 'unknown'. If the terminal supports querying theme state, this will be 'light' or 'dark' and be updated in real time. Note: this is not the OS theme, but instead reflects the theme of the terminal color scheme. - Size property now features the size in pixels in addition to cells. These values will be 0 if unsupported by the terminal.
- Add
- Bind
TerminalState.focused
to aLifecycle
and expose into the composition asLocalLifecycleOwner
. This allows using Compose lifecycle helpers such asLifecycleResumeEffect
and others. - Fancy underline styles (single, double, dashed, dotted, curved) and colors can now be specified for text and annotated string spans.
LocalStaticLogger
composition local provides access toStaticLogger
which allows logging plain strings at arbitrary points for inclusion in the next frame. This can be used from effects, callback, state classes, etc. Support for loggingAnnotatedString
s will come in a future release.runMosaicMain
function replaces the existingrunMosaicBlocking
for use specifically infun main()
or main-like scenarios.
Changed:
- Switched to our own terminal integration and parsing library. Report any issues with keyboard input, incorrect size reporting, or garbled output. This unlocks many of the features listed above, as well as many more planned in the future.
- Only disable the cursor and emit synchronized rendering markers if the terminal reports support for those features.
Static
function is now calledStaticEffect
to better indicate that it only renders its content once.runMosaic
andrunMosaicBlocking
now accept aNonInteractivePolicy
argument which dictates the behavior when Mosaic cannot connect directly to the TTY.
Fixed:
- Prevent final character from being erased when a row writes into the last column of the terminal.
- Do not emit ANSI style reset escape sequence when colors are disabled (such as in testing).
- Do not draw blank spaces at the end of every line.
Removed:
renderMosaic
was removed without replacement. As the capabilities of the library grow, supporting a string as a render target was increasingly difficult.