Skip to main content

Format xonsh history to post it to Github or another page.

Project description

Format xonsh history to post it to Github or another page.

The mission of xontrib-hist-format is to make commands repeatable, copy-pastable and save time to preparing.

If you like the idea click ⭐ on the repo and stay tuned.

Installation

xpip install xontrib-hist-format
# or: xpip install -U git+https://github.com/anki-code/xontrib-hist-format

Usage

Starting from xonsh 0.10.0 (4283) it's needed to set $XONSH_CAPTURE_ALWAYS before using xontrib-hist-format. Be careful by using this setting and read the env variable description.

$XONSH_CAPTURE_ALWAYS = True
xontrib load hist_format
hist-format --help         # Basic command
hist-md                    # Markdown format shortcut
hist-txt                   # Text format shortcut

Arguments:

usage: hist-format [-h] [-f FORMAT] [-c COMMANDS_COUNT] [-l]
                   [-H [OUTPUT_HEAD_COUNT]] [-T [OUTPUT_TAIL_COUNT]]
                   [-m] [--lines]

Format xonsh history to post it to Github or another page.

optional arguments:
  -h, --help            show this help message and exit
  -f FORMAT, --format FORMAT
                        Format: md, txt.
  -c COMMANDS_COUNT, --commands-count COMMANDS_COUNT
                        Count of commands
  -l, --commands-list   Show commands in distinct section.
  -H [OUTPUT_HEAD_COUNT], --output-head-count [OUTPUT_HEAD_COUNT]
                        Count of lines from output head to show.
  -T [OUTPUT_TAIL_COUNT], --output-tail-count [OUTPUT_TAIL_COUNT]
                        Count of lines from output tail to show.
  -m, --min             Make block minimized i.e. by adding <details> tag in Markdown.
  --lines               Add additional lines before and after.

Note! The clear command is used as marker of the beginning of commands list. If you run commands 1, 2, 3 then run clear, and run 4, 5, 6 and finally run hist-md it will show 4, 5, 6 commands. Feel free to open an issue with feedback on this approach.

Example

Run commands:

echo 123
ls / | head -n 3

Run hist-format:

hist-md -c 2 -l --lines    # latest 2 commands + commands list + header and footer as line

As result you will get the output that you can copy and paste to the Github comment or md-file:


Output:

echo 123
#123

ls / | head -n 3
#boot
#cdrom
#dev

# Prepared by xontrib-hist-format

Commands:

echo 123
ls / | head -n 3

# Prepared by xontrib-hist-format

You can disable the "Prepared by" message by setting XONTRIB_HIST_FORMAT_FOOTER = '' in your environment. If you like this xontrib, tell your friends!


Clipboard

You can redirect the output to clipboard. Example for xclip:

hist-md | xclip

Known issues

Not every command has output in the __xonsh__.history.

Workaround in some cases is to use pipe into head i.e. cat file | head.

Credits

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xontrib_hist_format-0.0.14.tar.gz (4.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xontrib_hist_format-0.0.14-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file xontrib_hist_format-0.0.14.tar.gz.

File metadata

  • Download URL: xontrib_hist_format-0.0.14.tar.gz
  • Upload date:
  • Size: 4.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for xontrib_hist_format-0.0.14.tar.gz
Algorithm Hash digest
SHA256 b6a0dd2602396704d36307c9d44b97d72fad4bc7261db724ef2a50a239ac41b7
MD5 f99f3cf7353bb014ca873a847e3ceef8
BLAKE2b-256 4ac09168615818583da46fa818f3d376744e3cf384060a6cb1db515bf1587bf3

See more details on using hashes here.

File details

Details for the file xontrib_hist_format-0.0.14-py3-none-any.whl.

File metadata

File hashes

Hashes for xontrib_hist_format-0.0.14-py3-none-any.whl
Algorithm Hash digest
SHA256 d9e718280f1b0bd0d8554d71fb2d08a1f58e8d503c44b51745fb292ab312ce33
MD5 ff1c9ef2f6fb9a17e3bc5653ccc1d0db
BLAKE2b-256 eb6466204c5b7a856e26741b9aa8bd52b893b4643ae6e3c9853eb578a32775c5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page