Skip to content

0.17.0

Latest
Compare
Choose a tag to compare
@github-actions github-actions released this 12 Apr 03:34
· 81 commits to trunk since this release

mosiac17

New:

  • Terminal and LocalTerminal are now renamed to TerminalState and LocalTerminalState, 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.
  • Bind TerminalState.focused to a Lifecycle and expose into the composition as LocalLifecycleOwner. This allows using Compose lifecycle helpers such as LifecycleResumeEffect 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 to StaticLogger 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 logging AnnotatedStrings will come in a future release.
  • runMosaicMain function replaces the existing runMosaicBlocking for use specifically in fun 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 called StaticEffect to better indicate that it only renders its content once.
  • runMosaic and runMosaicBlocking now accept a NonInteractivePolicy 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.