All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog.
This project adheres to Semantic Versioning for its CLI (Command-Line Interface), i.e. for the moulti
command.
Although Moulti's Python packages, modules and functions are obviously available, they do not constitute a public API yet.
- Moulti now requires Textual 1.0.x
- When searching text, the
[esc] Cancel
keybinding, which used to be shown in 1st position in the footer, is now shown in 3rd position Ctrl+c
no longer exits Moulti: useCtrl+q
instead;q
still works- Input fields now support:
- text selection through mouse or Shift+left/right; Ctrl+Shift+left/right works too
- copy/paste through Ctrl+x/c/v
- Moulti now requires Textual 0.89.1
- Moulti now requires Textual 0.88.1
MOULTI_CUSTOM_CSS
users: combined withoffset
,position: absolute
enables various interesting hacks (e.g. multiple steps per row)- New example script:
moulti-scoreboard.bash
- Moulti now requires Textual 0.87.1
- Moulti now requires Textual 0.86.3
- Minor color changes: input fields, buttons, progress bar, some texts in light mode.
MOULTI_CUSTOM_CSS
users: specify& CollapsibleTitle { color: ...; }
to alter the default step title color; an example is available in the documentation.
- Fixed a double-close issue liable to affect any file descriptor inside a given Python process after a Moulti instance exited.
- Introduced snapshot testing and continuous integration.
moulti init
now exits with a non-zero return code when it cannot listen to clients.- Ansible callback plugin: fix
unexpected keyword argument 'caplevel'
warning
- Moulti now requires Textual == 0.83.0
- Focus indicators: fix rendering issue induced by Textual 0.84.0
- Moulti now requires Textual >= 0.83.0
moulti init
used to crash with Textual >= 0.83.0:Screen.ALLOW_IN_MAXIMIZED_VIEW = '#header,SearchInputWidget,' + Screen.ALLOW_IN_MAXIMIZED_VIEW ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ TypeError: can only concatenate str (not "NoneType") to str
moulti run
now setsANSIBLE_FORCE_COLOR=yes
when Ansible is detected, thus generating colors in "PLAY RECAP" and diff (-D
command-line option)
- The console is now based on Textual's
Log
widget instead ofRichLog
; this prevents a bug introduced in Textual 0.80.0 that affects the console when it becomes visible for the first time.
moulti diff
lists generated widgets if the environment variableMOULTI_DIFF_VERBOSE
is setmoulti manpage
lists generated widgets if the environment variableMOULTI_MANPAGE_VERBOSE
is set- the environment variable
MOULTI_QUIT_POLICY
defines how Moulti should behave upon quitting - steps can now be assigned the
inactive
class, which turns them gray
- Ansible callback plugin: steps with "skipping" and "included" lines are affected the new
inactive
class
moulti diff
: delta integrationmoulti diff
: display number of added (+) and removed (-) lines for each hunkdelete
commands now accept multiple ids, e.g.moulti step delete step_1 step_2 step_3
- Pressing
f
maximizes the currently focused step log (similar to zoom pane in tmux)
- Moulti now requires Textual >= 0.79.0
- pipeline() now writes errors on stderr; this affects moulti
load
,diff
andmanpage
commands.
moulti-man
andmoulti manpage
used to ignore the last section of all manpages.
- Text search: it is now possible to search steps (+ the title) for a given pattern (plain or regex, case-sensitive or not).
- The search widget offers an in-memory, non-persistent history.
- The console is now shown or hidden using
z
instead ofn
. - The console now grabs the focus, which makes it easier to scroll.
- Help screen: mention
ctrl+pgup
andctrl+pgdn
.
- the environment variable
MOULTI_ASKPASS_DEFAULT_PROMPT
defines the prompt shown bymoulti-askpass
if none was passed on the command line - Ansible-specific variants of
moulti-askpass
:moulti-askpass-become-password
moulti-askpass-connection-password
moulti-askpass-vault-client
- Ansible callback plugin: override these
ansible-playbook
command-line options to prevent it from reading passwords through the current tty:-k
,-ask-pass
-K
,--ask-become-pass
-J
,--ask-vault-pass
,--ask-vault-password
moulti step
: add options--auto-scroll
and--no-auto-scroll
to control inner auto-scrollingmoulti pass
: significant performance improvements- the environment variable
MOULTI_TAB_SIZE
controls the expansion of tab characters passed to steps
- Steps with a horizontal scrollbar had an extra line above it
Ctrl+t
/Ctrl+y
jumps to the previous/next unanswered questionO
/X
collapses/expands new steps- the environment variable
MOULTI_ENFORCE_COLLAPSIBLE
does the same as soon as Moulti starts Ctrl+o
/Ctrl+x
collapses/expands both existing and new steps- Ansible callback plugin: the environment variable
MOULTI_ANSIBLE_COLLAPSE
specifies parts that should appear collapsed
- Moulti now requires Textual >= 0.76.0
- Footer: the
Dark/Light
keybinding now displays either "Dark" or "Light" - Footer: the
Lock scroll
keybinding now displays either "Lock scroll" or "Unlock scroll"
moulti question add id --button value invalid_style label
now returns an error
- CLI command
moulti question {add,update,get-answer,delete}
- Ansible callback plugin: support
prompt_until()
and thepause
module - quit dialog: buttons now feature keyboard accelerators
moulti pass --read-size
now defaults to8192
.moulti run
: hittingCtrl+c
multiple times now navigates through the quit dialog and eventually terminates the process before exiting.
moulti run
:MOULTI_RUN_OUTPUT=harvest moulti run -- bash -c 'echo a; sleep 3600'
would block upon selecting "Quit and leave the process running in the background".
- help screen (
h
) - Ansible callback plugin: handle
vars_prompt
using inputquestion widgets.
- the quit dialog is now more keyboard-friendly
- ensure only one instance of the quit dialog is shown at any time.
- Ansible callback plugin: do not try to pass text to a divider.
- Ansible callback plugin: handle Ansible >= 2.17
moulti-man
,moulti manpage
: load man pages into Moulti.
moulti_process_lines()
: preventmoulti pass
processes from piling on.
- copy to clipboard: support OSC 52 and introduce the environment variable
MOULTI_CLIPBOARD_COPY
.
- in some situations (e.g. SSH and terminal lacking support for OSC 52), Moulti may fail to copy data to the clipboard AND fail to detect and report that failure.
- footer: fix key text color in light mode.
- performance: throttle calls to step.append(buffer).
- footer: restore the usual look'n feel for Textual >= 0.63.0
- bash functions:
moulti_process_lines()
helps to turn arbitrary output into Moulti stepsmoulti_check_requirements()
helps to ensure required commands are availablestdbuf()
replaces thestdbuf
utility on NetBSD and OpenBSD
- bash functions:
- pip/pipx deploys
moulti-functions.bash
moulti_iso_date()
leverages either GNU date, Perl or Python
- pip/pipx deploys
- moulti no longer systematically loads the
unidiff
module - bash functions:
- detect "python3.x" executables
- no longer depend on GNU date.
- stick to short, non-GNU mktemp command-line options
- Ansible callback plugin:
ansible/moulti.py
moulti run
sets the adequate environment variables to enable the Ansible callback plugin.moulti diff
: load diff data into Moulti.
moulti-askpass
, an askpass helper for Moultimoulti run
automatically setsSSH_ASKPASS
,SSH_ASKPASS_REQUIRE
andSUDO_ASKPASS
environment variables so as to leveragemoulti-askpass
.moulti run --print-env
outputs all environment variables set bymoulti run
.moulti run
: the environment variableMOULTI_RUN_OUTPUT
provides better control on unexpected output.- dividers: non-collapsible steps that simply display text.
moulti set --step-position=bottom
moulti set --step-direction=up
- Programmatic scrolling:
moulti scroll step_id offset
moulti step add --scroll-on-actvity=-1
moulti step update --scroll-on-actvity=false
- "Lock scroll" action to prevent programmatic scrolling
- The "Save" feature now exports the progress bar.
- Fix a pipelining issue causing
moulti load
to emit a traceback.
- Environment variables
MOULTI_ANSI
andMOULTI_ANSI_THEME_*
provide full control over ANSI color themes. tools/gogh2moulti.bash
converts Gogh themes intoMOULTI_ANSI_THEME_*
variables.- Shell completion based on the argcomplete library.
- Bash functions: moulti_exec(): compute and display step duration.
- Tooltips on the Moulti header and step titles.
- Progress bar:
moulti set --progress-bar --progress-target=100 --progress=80
- By default, Moulti no longer alters ANSI colors; the previous behavior can be restored by setting
MOULTI_ANSI=textual_default
. - Use non-ANSI colors in the console.
- Moulti requires textual >= 0.53.
- Fix "next line color" heuristic for step widgets.
- Fix detection of markup errors.
- New layout for button questions: there should no longer be any hidden/unreachable button.
MOULTI_CUSTOM_CSS= moulti init/run
no longer results in a traceback.
- Textual Command Palette (never advertised and offered very little).
- Ability to copy step/question/console contents to clipboard, with or without colors/styles.
- Focus indicators, i.e. visual hints reflecting what part of the UI currently holds focus.
- Highlighting in the console.
- Windows: show explanatory message instead of crashing at startup.
- The key binding to toggle the console is now
n
instead ofc
(which now means "Copy"). - Make it easier to scroll around answered
buttonquestion
widgets. - Revamp the console by making it a proper widget, as opposed to a refurbished step.
- Handle Rich Markup errors and return a suitable error message to clients.
- Fix
moulti pass
on FreeBSD and NetBSD.
- TUI action "Save" that exports step properties and logs to files.
- CLI command
moulti load
that imports step properties and logs from files. - Environment variable
MOULTI_SAVE_PATH
defines where Moulti (TUI) saves files. - Show a modal dialog when users attempt to quit Moulti while the process launched by
moulti run
is still running. This dialog allows users to terminate the process or leave it running in the background. - Environment variable
MOULTI_MODE=light
starts Moulti with dark mode disabled. moulti run
now sets environment variableMOULTI_INSTANCE_PID
.- CLI command
moulti --version
- Documentation: add section "moulti run: dealing with stdin, stdout, stderr"
- Examples: improve
moulti run
commands by using--
. - Update documentation.
- CLI command
moulti buttonquestion {add,update,get-answer,delete}
- CLI command
moulti inputquestion {add,update,get-answer,delete}
moulti
(CLI) now writes error messages on stderr, not stdout.- Examples: upgrade-system.bash now showcases buttonquestion.
- Update documentation.
MOULTI_INSTANCE
environment variable.MOULTI_PASS_CONCURRENCY
environment variable.moulti-pass-concurrency.bash
example script.
moulti wait
now sends a "ping" command.- Update documentation.
- Examples: use
MOULTI_INSTANCE
instead ofMOULTI_SOCKET_PATH
.
- Improve behavior on platforms that do not support abstract Unix sockets (e.g. MacOS).
- Improve behavior on hosts with few CPUs.
- CLI command
moulti init
- CLI command
moulti run
- CLI command
moulti wait --verbose --delay --max-attempts
- CLI command
moulti set --title
- CLI command
moulti step {add,update,delete,clear,append}
- CLI command
moulti pass --append --read-size
moulti
considers environment variablesMOULTI_SOCKET_PATH
,MOULTI_ALLOWED_UID
,MOULTI_ALLOWED_GID
andMOULTI_CUSTOM_CSS
moulti run
sets environment variablesMOULTI_RUN
andMOULTI_SOCKET_PATH
- Documentation
- Examples