Skip to content

Latest commit

 

History

History
112 lines (75 loc) · 3.7 KB

README.md

File metadata and controls

112 lines (75 loc) · 3.7 KB

asciicast tools

Tools for creating recordings of console sessions.

image

Introduction

Originally this project was started as a way of recording from a tmux session using tmux pipe-pane. After doing some research I found out there was already the asciicast format, so figured it made sense to use that as the interchange format.

As for the question of why not just use asciinema rec, I can give a couple of reasons. First, recording directly from a tmux pane means you can start recording without needing to start a new shell session (for example the output of an already running program). Second, I like the idea of small programs that do one thing and one thing well. Finally (the most selfish reason) is I just wanted to see if it was possible to do 😊.

Player

This is a hterm-based player for asciicasts. It depends on hterm_all.js which can be built by running third_party/libapps/hterm/bin/mkdist.sh and copying into the player directory (or using the existing symlink).

A hosted version can be found on the website.

Related projects

Commands

asciicast-pipe

A filter to convert input to asciicast v2 format.

Usage: asciicast-pipe [-h] [-W WIDTH] [-H HEIGHT] [-S SHELL] [-T TERM] [-r]
                      [--encoding ENCODING]

optional arguments:
  -h, --help            show this help message and exit
  -W WIDTH, --width WIDTH
  -H HEIGHT, --height HEIGHT
  -S SHELL, --shell SHELL
  -T TERM, --term TERM
  -r, --force-cr        Force newlines to be treated as CR+NL
  -e, --echo            Echo stdinput to stderr
  --encoding ENCODING

By default the script will attempt to detect the correct terminal settings, but this can be overridden using command-line flags.

This is not expected to be called directly, but rather by a tool like tmux pipe-pane or scriptreplay:

# Convert a typescript+timing information to asciicast
$ scriptreplay -t timing typescript | asciicast-pipe > typescript.cast

# Record terminal session as asciicast
$ script -q -f >(asciicast-pipe > output.cast)

asciicast-pipe can also be used to capture output from simple programs. Use --force-cr (-r) to ensure output contains required carriage returns.

$ ping -c 4 127.0.0.1 | asciicast-pipe --echo --force-cr > ping.cast

tmux-asciicast-pane

Helper-script for recording output from a tmux pane.

Usage: tmux-asciicast-pane [path]

To start recording the current tmux pane, provide an output file to write the asciicast:

$ tmux-asciicast-pane output.cast

To stop recording, just run without any output file specified:

$ tmux-asciicast-pane

Binding to a tmux key

Alternatively you may wish to set up a shortcut in ~/.tmux.conf:

bind-key H pipe-pane -o 'asciicast-pipe -W #{pane_width} -H #{pane_height} -T "${TERM}" -S "${SHELL}" > $HOME/tmux-%Y%m%d%H%M%S.cast' \; display-message 'Toggled logging'

Pressing <tmux-prefix> H will toggle logging to a file in your home directory.

License

Copyright © 2018 David Coles

All code is licensed under MIT License. See LICENSE for details.