Skip to main content

Textual-based TUI demonstration of par-term-emu-tui-rust terminal emulator

Project description

Par Term Emu TUI Rust

PyPI PyPI - Python Version Runs on Linux | MacOS | Windows Arch x86-64 | ARM | AppleSilicon PyPI - Downloads PyPI - License

A modern terminal emulator TUI built with Textual and par-term-emu-core-rust, featuring efficient rendering, comprehensive ANSI support, and advanced terminal features.

Screenshot

"Buy Me A Coffee"

What's New in v0.3.1

New Color System Features

  • Automatic Contrast Adjustment: iTerm2-compatible minimum contrast system

    • minimum_contrast (0.0-1.0) - Automatic contrast adjustment for live terminal display
    • screenshot_minimum_contrast (0.0-1.0) - Independent contrast setting for screenshots
    • Uses NTSC perceived brightness formula for accurate readability
    • Range: 0.0 (disabled, default) to 1.0 (maximum contrast)
    • Recommended: 0.5 for moderate readability improvements
    • Ensures text remains readable on any background color
  • Bold Text Brightening: Enhanced bold text rendering

    • bold_brightening (default: true) - Use bright ANSI colors (8-15) for bold text with normal colors (0-7)
    • Matches iTerm2's "Use Bright Bold" setting
    • When enabled: Bold red (1) automatically renders as bright red (9)
    • When disabled: Bold text uses original color without brightening

Configuration Example

# Live terminal contrast adjustment
minimum_contrast: 0.5  # Moderate contrast for display

# Screenshot-specific contrast (overrides minimum_contrast for screenshots)
screenshot_minimum_contrast: 0.7  # Higher contrast for screenshots

# Bold text appearance
bold_brightening: true  # Use bright colors for bold text

Previous Release (v0.3.0)

  • Visual Bell Flash: Animated bell icon overlay when terminal receives BEL character (🔔)
  • Install Command Discoverability: install subcommand now visible in --help output
  • KITTY Keyboard Protocol Documentation: Comprehensive guide for enhanced keyboard handling
  • Configuration Expansion: 39 configuration options (up from 30) including new color system features

Improvements

  • Better CLI Help: Install subcommand now visible in main help output
  • Enhanced Documentation: All docs updated to reference install command and new features
  • Code Organization: Added BellFlash widget for visual bell feedback

Documentation

  • New KEYBOARD_PROTOCOL.md - Complete KITTY protocol guide
  • Enhanced USAGE.md - Install command now documented
  • Updated CLAUDE.md - Installation commands reference added
  • Updated all documentation to reflect new scrolling default

Previous Release (v0.2.0)

  • Fixed all lint errors (22 → 0) and achieved 100% type checking compliance
  • Enhanced test suite reliability with all 20 tests passing
  • Added KITTY keyboard protocol support with auto-detection
  • Improved code consistency and type safety across codebase

Quick Start

# Clone and install
git clone https://github.com/paulrobello/par-term-emu-tui-rust.git
cd par-term-emu-tui-rust
uv sync

# Install components (recommended)
par-term-emu-tui-rust install all

# Run the TUI
make run

See the Quick Start Guide for detailed instructions.

Features

  • Efficient Rendering - Textual Line API for optimal performance
  • Full ANSI Support - 16/256/true color, bold, italic, underline, and more
  • Advanced Color System - Bold brightening and automatic contrast adjustment (iTerm2-compatible)
  • Scrollback Buffer - Navigate history with keyboard and mouse
  • Mouse Support - Text selection, clickable URLs, and mouse tracking
  • Hyperlinks - OSC 8 hyperlinks and auto-detected plain text URLs
  • Notifications - OSC 9/777 notification support with toast messages
  • Shell Integration - Working directory tracking, prompt navigation
  • Screenshots - Multiple formats (PNG, SVG, HTML) with auto-capture and contrast control
  • Themes - 12 built-in themes with custom theme support
  • Clipboard - Cross-platform copy/paste with OSC 52 support
  • KITTY Protocol - Enhanced keyboard protocol with auto-detection

See Features for complete feature documentation.

Documentation

Getting Started

Reference

Advanced

Installation

Prerequisites

  • Python 3.12 or higher
  • uv package manager
  • Terminal with true color support

Install from Source

# Clone repository
git clone https://github.com/paulrobello/par-term-emu-tui-rust.git
cd par-term-emu-tui-rust

# Install dependencies
uv sync

# Install all components
par-term-emu-tui-rust install all

See Installation Guide for detailed instructions.

Basic Usage

# Run with default shell
par-term-emu-tui-rust

# Use custom shell
par-term-emu-tui-rust --shell /bin/zsh

# Apply theme
par-term-emu-tui-rust --theme solarized-dark

# Take screenshot
par-term-emu-tui-rust --screenshot 3 --auto-quit 5

Key Bindings

Shortcut Action
Ctrl+Shift+Q Quit application
Ctrl+Shift+S Take screenshot
Ctrl+Shift+C Copy selection
Shift+PageUp/Down Scroll history
Shift+Home/End Jump to top/bottom

See Key Bindings for complete reference.

Configuration

Configuration file location: ~/.config/par-term-emu-tui-rust/config.yaml

Create default configuration:

par-term-emu-tui-rust --init-config

Essential settings:

# Theme & Colors
theme: "dark-background"
bold_brightening: true           # Use bright colors for bold text
minimum_contrast: 0.0            # Display contrast (0.0=off, 0.5=moderate, 1.0=max)

# Scrollback
scrollback_lines: 10000

# Clipboard
auto_copy_selection: true
middle_click_paste: true

# Screenshots
screenshot_format: "png"
screenshot_minimum_contrast: 0.0  # Screenshot contrast (overrides minimum_contrast)

# Keyboard Protocol
keyboard_protocol_enabled: false
keyboard_protocol_auto_detect: false

See Configuration Reference for all options.

Technology

  • Python 3.12+ - Application logic
  • Textual - TUI framework
  • par-term-emu-core-rust - Terminal emulation (Rust)
  • PyYAML - Configuration
  • pyperclip - Clipboard support
  • xdg-base-dirs - XDG compliance

Security & Safety Notes

Par Term Emu TUI Rust aims to provide sensible, configurable defaults for potentially sensitive features:

  • Clipboard access (OSC 52) Controlled by expose_system_clipboard:

    • When true (default), terminal applications can read/write the system clipboard via OSC 52 escape sequences.
    • When false, clipboard reads from applications are blocked.
  • Clickable URLs Clickable links (OSC 8 and auto-detected plain URLs) are allowed only for configured schemes:

    • allowed_url_schemes defaults to: http, https, ftp, ftps, file, mailto.
    • Unknown/unsupported schemes are blocked; when warn_on_unknown_url_scheme is true, a non-fatal warning is shown in the TUI instead of opening the link.
  • Escape sequence safety Some sequences can be powerful (and potentially dangerous). You can harden behavior with:

    • disable_insecure_sequences: when true, the Rust core filters out escape sequences considered risky.

See the Configuration Reference for details and recommended values for locked-down environments.

Architecture

graph TD
    App[TerminalApp]
    Widget[TerminalWidget]
    Core[Terminal Core Rust]
    Render[Rendering Engine]
    Display[Display]

    App --> Widget
    Widget --> Core
    Core --> Render
    Render --> Display

    style App fill:#e65100,stroke:#ff9800,stroke-width:3px,color:#ffffff
    style Widget fill:#1b5e20,stroke:#4caf50,stroke-width:2px,color:#ffffff
    style Core fill:#0d47a1,stroke:#2196f3,stroke-width:2px,color:#ffffff
    style Render fill:#4a148c,stroke:#9c27b0,stroke-width:2px,color:#ffffff
    style Display fill:#880e4f,stroke:#c2185b,stroke-width:2px,color:#ffffff

See Architecture for detailed system design.

Contributing

Contributions are welcome! Please read the Contributing Guide for:

  • Development setup
  • Code quality standards
  • Testing requirements
  • Pull request process

Development Setup

# Clone repository
git clone https://github.com/paulrobello/par-term-emu-tui-rust.git
cd par-term-emu-tui-rust

# Install dependencies
uv sync

# Install pre-commit hooks
uv run pre-commit install

# Run quality checks
make checkall

Resources

Troubleshooting

For common issues and solutions, see the Troubleshooting Guide.

Quick diagnostics:

# Enable debug logging
par-term-emu-tui-rust --debug

# Test with minimal config
par-term-emu-tui-rust --auto-quit 2

License

This project is licensed under the MIT License - see the LICENSE file for details.

Author

Paul Robello - probello@gmail.com

Acknowledgments

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

par_term_emu_tui_rust-0.3.1.tar.gz (316.8 kB view details)

Uploaded Source

Built Distribution

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

par_term_emu_tui_rust-0.3.1-py3-none-any.whl (80.4 kB view details)

Uploaded Python 3

File details

Details for the file par_term_emu_tui_rust-0.3.1.tar.gz.

File metadata

  • Download URL: par_term_emu_tui_rust-0.3.1.tar.gz
  • Upload date:
  • Size: 316.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for par_term_emu_tui_rust-0.3.1.tar.gz
Algorithm Hash digest
SHA256 7c648b9e1e4f39e80a7fbbb3fd73d134eed5de1eb065bdd6b73be5c4d5ece420
MD5 38bd9834a35c9529bcc3dae9ac996161
BLAKE2b-256 46d0a3556d021f44d76e8d5c290fe7cef6275e02b8cc7f64188d24b80a07831a

See more details on using hashes here.

Provenance

The following attestation bundles were made for par_term_emu_tui_rust-0.3.1.tar.gz:

Publisher: deployment.yml on paulrobello/par-term-emu-tui-rust

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file par_term_emu_tui_rust-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for par_term_emu_tui_rust-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1c0cc70cced68293ee1abdf05bcb15115f42d69b556998bec9076263df42f53f
MD5 0c17e91c79efa94357a4a857bf24e6a3
BLAKE2b-256 1fb54ecd3bce21a59c3cbd4df31aa8ebb2685c21c2b628124fc2e2511d016ef4

See more details on using hashes here.

Provenance

The following attestation bundles were made for par_term_emu_tui_rust-0.3.1-py3-none-any.whl:

Publisher: deployment.yml on paulrobello/par-term-emu-tui-rust

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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