Skip to main content

Code editor for who don't know how to use vi

Project description

Textual Code

Code editor for who don't know how to use vi

Screenshot

[!WARNING]
This project is in the early stages of development. It is not ready for use yet.

What is Textual Code?

Textual Code is a TUI-based code editor that feels familiar right from the start.

You’ve probably had to SSH into a server at some point just to tweak a few lines of code. However, vi or Emacs can be overkill for quick fixes, requiring you to remember a whole host of commands for even the simplest changes. Furthermore, nano doesn’t always provide enough features for comfortable coding, and setting up a GUI editor on a remote server can be a real hassle.

That’s why Textual Code was created. You likely use a GUI editor like VS Code or Sublime Text in your day-to-day work, and Textual Code offers a similar experience with no learning curve. It behaves much like any other code editor you’re used to.

We’re not asking you to switch to Textual Code as your main editor. Just remember it’s there when you need to jump onto a server and make a few quick edits. It’s that simple.

Features

  • Commonly used shortcuts, such as Ctrl+S to save and Ctrl+F to search
  • Command palette for quick access to all features, and no need to remember shortcuts
  • Multiple cursors
  • Mouse support
  • Find and replace from workspace
  • Explore files in the sidebar
  • Open files to tabs
  • Syntax highlighting
  • Image file preview in the terminal

Installation

[!TIP] We recommend using uv for installation and management.

# Using pip
pip install textual-code

# Using uv (recommended)
uv tool install textual-code

# Run without installing
uvx textual-code

Usage

To open the textual code, run the following command in your workspace:

textual-code

Troubleshooting

Keyboard shortcuts not working

Some terminal emulators intercept certain key combinations before they reach the application. If a shortcut does not work as expected, run the following command and press the shortcut to verify that your terminal recognizes it:

[!TIP] We recommend using uvx as it requires no separate installation.

# Using pip
pip install textual-dev
textual keys

# Run without installing (recommended)
uvx --from textual-dev textual keys

Development

(You need to use devcontainer to run the code)

To run the development version directly:

uv run textual-code

To run with the Textual dev console (shows logs and events), open two terminals:

# Terminal 1: start the console
uv run textual console

# Terminal 2: run the app in dev mode
uv run textual run --dev textual_code:main

Installing Hooks

Install pre-commit hooks to automatically run linting, formatting, type checking, and language checks before each commit:

uv run pre-commit install

Running Tests

See docs/testing-guide.md for patterns, best practices, and gotchas.

# Unit/integration tests — parallel (~2.5 min)
uv run pytest tests/ -n $(( $(nproc) * 2 )) -m "not serial"

# Snapshot tests — must run serially
uv run pytest tests/ -m serial

# Update snapshots after UI changes
uv run pytest tests/snapshots/test_snapshots.py --snapshot-update

# Single file
uv run pytest tests/editor/test_code_editor.py

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

textual_code-0.5.0.tar.gz (903.2 kB view details)

Uploaded Source

Built Distribution

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

textual_code-0.5.0-py3-none-any.whl (170.0 kB view details)

Uploaded Python 3

File details

Details for the file textual_code-0.5.0.tar.gz.

File metadata

  • Download URL: textual_code-0.5.0.tar.gz
  • Upload date:
  • Size: 903.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for textual_code-0.5.0.tar.gz
Algorithm Hash digest
SHA256 8f82d4a7b9705a2d542644f3c8f4ae811c83013eff781586b854c0786834c81d
MD5 231a37c8030af0b9c5f625dee22c6749
BLAKE2b-256 339f8f8279b61a9c45289f5d5bd853b88c5cf0968ef879d81f04b1795eb1260b

See more details on using hashes here.

File details

Details for the file textual_code-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: textual_code-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 170.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.3 {"installer":{"name":"uv","version":"0.11.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for textual_code-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9558f14b8f58207633cfaaff9e0ba606863e442dc738be8ae24edb4b3b4e772a
MD5 9142883b6526e3a5ac48a8059ed5030f
BLAKE2b-256 1a519e3874420ba9c27d93f2c82f9ffacfde2c3e0f950295bf5df4420aa8d703

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