tmux2html

:cat2: Render full tmux windows or individual panes as HTML

Github星跟踪图

tmux2html

tmux2html captures full tmux windows or individual panes then parses their
contents into HTML in living color.
The output can either be still snapshots, or animated sequences.

With a web server that uses gzip compression, the size over the network is
negligible for reasonably sized windows or panes.

Examples

Some of these may be large in dimensions. You'll need to zoom out if you want
to see all panes at once. These are not raster graphics!

If you decide to look at the telnet animations yourself and don't know how to
exit, use Ctrl-] then type quit. For the Star Wars animation, press
Ctrl-]<enter> to get the prompt.

Rationale

This was a weekend project I made for fun and I have no particular use for it
beyond annoying my friends about how bad they should feel for not using tmux.
I also thought it would be neat to have a render of my sessions that didn't
result in an image using some crummy font on a headless server.

I suppose you can use cron to capture screens and display it on your website,
or use it to create terminal snippets for your blog. You could also load a
pane render in elinks within your coworker's session. The only limit is your
imagination, my friend. :sparkles:

What people think of tmux2html

tmux2html 便利そう。

@nakamuray

aaaaoooooo

@l4utert

9:39:46 PM Jef Myers: what the fuck is tmux?

— Jef Myers

Requirements

  • tmux 1.8
  • Python 2.7 or 3.4 (could be wrong since it's not tested in lower versions)

Installation

pip install tmux2html

Usage

tmux2html 4 -o window_5_in_current_session.html
tmux2html .0 -o first_pane_in_current_window.html
tmux2html other:1.2 -o second_window_third_pane_in_other_session.html

Command Line Options

  • target (positional) - Target window or pane. Uses tmux's target syntax, but
    always 0-indexed. (e.g. sess:1.2 - Session - sess, Window 2, Pane 3.
    Default target is window.)
  • -o, --output - Output file. Prints to stdout if omitted.
  • -m, --mode - Output file permissions. Default - 644
  • --light - Light background.
  • --interval - Number of seconds between captures.
  • --duration - Number of seconds to capture. 0 for indefinite recording, -1
    to disable.
  • --stream - Continuously renders until stopped and adds a script to auto
    refresh based on --interval. See the notes below for more info.
  • --fg - Foreground color. Can be a color index or R,G,B
  • --bg - Background color. Can be a color index or R,G,B
  • --full - Renders the full history of a single pane
  • --history - Specifies the maximum number of pane history lines to include
    (implies --full)

Limitations

  • The cursor is not displayed.
  • Basic colors will not match your terminal's configured colors.
  • Animations aren't perfect with a lot of splits and fast resizing.
  • Animations won't capture scrolling the pane's history (selection mode).
    Scrolling in the pane's history is now recorded in animations.
  • In animations, a pane is updated with the full pane's content. Only the
    changed lines are updated on a per-pane basis.
  • Zoomed panes will ruin all the fun.
  • Your imagination :stars:

Notes

  • Still captures are plain HTML and CSS.
  • Animations use Javascript.
  • To keep the size reasonable with animations,
    pako is used to inflate the gzipped frame
    contents. Combined with decompression of frame content, the animations will
    use a fair amount of CPU. So, you shouldn't run animations indefinitely on
    your low performance or battery operated fun machines.
  • --stream doesn't actually "stream", per se. It keeps writing to the same
    file and adds a script that reloads the contents. This can be used to
    have a live feed of a window or pane. However, it's not elegant. If you set
    the interval to too low, your might unintentionally DDoS your own web server.
    Caveat Emptor.
  • The font stack includes Powerline and
    Nerd fonts because I'm pedantic
    and want to see those fancy glyphs. It falls back to monospace if you
    don't have any of those fonts installed. The caveat: if you have more than
    one of those fonts installed, the first one in the font stack might not be
    your favorite and you'll be forced to set your monitor on fire and buy a new
    one.

To Do

  • If there's practical use for animations in the future, only lines that are
    different should be updated to keep the size low.
  • Tell people to follow me on Twitter
    (@cloudsiphon) if they would like to stay
    up to date on tmux2html, but don't be pushy about it.

Similar Projects

  • gotty - Share your terminal as a web
    application
  • asciinema - Terminal session
    recorder

License

  • tmux2html: MIT
  • pako: MIT

主要指标

概览
名称与所有者tweekmonster/tmux2html
主编程语言Python
编程语言Python (语言数: 5)
平台
许可证MIT License
所有者活动
创建于2016-03-30 02:23:00
推送于2024-01-20 10:19:59
最后一次提交2016-08-11 23:24:43
发布数7
最新版本名称0.1.11 (发布于 2016-04-15 13:09:37)
第一版名称0.1.5 (发布于 )
用户参与
星数723
关注者数12
派生数12
提交数69
已启用问题?
问题数13
打开的问题数4
拉请求数1
打开的拉请求数2
关闭的拉请求数2
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?