Skip to main content

A lightweight terminal launcher for interactive CLI tools.

Reason this release was yanked:

Bad release version. Use 0.2.0 instead.

Project description

LaunchLine

CI Release

A lightweight terminal launcher for interactive CLI tools. Define your frequently used commands in a TOML config file, then pick them from a fuzzy-searchable menu instead of remembering flags and paths.

LaunchLine demo

Why

Switching between CLI tools — AI assistants, shells, dev utilities — means remembering commands, flags, working directories, and environment variables. LaunchLine puts them all in one menu so you press a number or type a few letters instead.

Features

  • Fuzzy search — type any substring to narrow the list instantly
  • Numbered shortcuts — press a digit to launch directly
  • Per-entry environment and working directory — set once, forget forever
  • Auto-restart or exit — configurable behavior after a tool exits
  • Zero runtime dependencies — pure Python 3.12+, nothing to install beyond itself
  • Auto-generated starter config — creates ~/.config/launchline/config.toml on first run if no config exists
Fuzzy search Arrow-key navigation
Search Navigate

Installation

From PyPI (recommended)

uv tool install launchline

Or with pip:

pip install launchline

From source

git clone https://github.com/mikejhill/launchline.git
cd launchline
uv tool install .

Run without installing

git clone https://github.com/mikejhill/launchline.git
cd launchline
uv sync --group dev
uv run launchline

Quick Start

  1. Run launchline. If no config exists, a starter config is created at ~/.config/launchline/config.toml.
  2. Edit the config to add your tools.
  3. Run launchline again.

Override the config path:

# CLI flag (highest priority)
launchline --config ~/my-config.toml

# Environment variable
export LAUNCHLINE_CONFIG=~/my-config.toml
launchline

Resolution order: --config flag > LAUNCHLINE_CONFIG env var > default path.

Configuration Reference

Config file format is TOML. The file has an optional [settings] table and one or more [[entries]] tables.

[settings]

Key Type Default Description
title string "LaunchLine" Window/tab title shown while the launcher is active
on_exit string "restart" Behavior after a launched tool exits: restart or exit
show_exit bool true Show the Exit entry (shortcut 0) in the menu
clear_on_launch bool true Clear terminal before launching an entry
ghost_text bool true Show the highlighted entry name as an autocomplete hint on prompt
numeric_trigger bool true Pressing a digit immediately launches the matching entry

[[entries]]

Each [[entries]] table defines one launchable tool:

Key Type Required Default Description
name string yes Display name shown in the menu
command string or list of strings yes Executable to run (with optional inline arguments)
args list of strings no [] Additional arguments appended after any inline command args
description string no "" Short description shown next to the name
working_directory string no Working directory for the subprocess
env table no {} Extra environment variables (KEY = "value")

Validation Rules

  • At least one [[entries]] table is required.
  • Every entry must have both name and command.
  • command may be a string ("pwsh") or a list (["ssh", "-t", "host"]). When a list, the first element is the executable and the rest are arguments.
  • on_exit must be "restart" or "exit".
  • args must be a list (not a bare string). These are appended after any arguments provided inline in a command list.
  • env must be a TOML table (not a string or list).
  • If working_directory does not exist at load time, it is silently reset to None (a warning is logged).

Example Config

[settings]
title = "My Tools"
on_exit = "restart"
show_exit = true
clear_on_launch = true
ghost_text = true
numeric_trigger = true

[[entries]]
name = "GitHub Copilot CLI"
command = "copilot"

[[entries]]
name = "Claude Code"
command = "claude"
description = "Anthropic coding agent"
working_directory = "~/projects"

[[entries]]
name = "PowerShell"
command = "pwsh"
args = ["-NoProfile"]
env = { TERM = "xterm-256color" }

[[entries]]
name = "Remote Server"
command = ["ssh", "-t", "my server", "bash"]

Usage

Key Action
19 Launch entry by number
0 Exit (when show_exit is enabled)
Type any text Fuzzy-filter the entry list
Up / Down Move highlight
Enter Launch highlighted entry
Escape Clear filter (or exit if filter is empty)
Backspace Delete last character from filter
Ctrl+U Clear filter

Windows Terminal Integration

Add LaunchLine as a Windows Terminal profile to use it as your default launcher. The package bundles an icon that you can reference via launchline --icon-path:

// In your Windows Terminal settings.json → profiles.list
{
  "name": "LaunchLine",
  "commandline": "launchline",
  "startingDirectory": "%USERPROFILE%",
  // Run: launchline --icon-path
  "icon": "C:/Users/you/.local/lib/.../launchline/assets/launchline.ico"
}

Set it as the default profile to see the launcher every time you open a terminal.

Development

uv sync --group dev
uv run pytest
uv run ruff check .
uv run mypy src

License

MIT

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

launchline-0.2.1.dev0.tar.gz (25.9 MB view details)

Uploaded Source

Built Distribution

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

launchline-0.2.1.dev0-py3-none-any.whl (44.5 kB view details)

Uploaded Python 3

File details

Details for the file launchline-0.2.1.dev0.tar.gz.

File metadata

  • Download URL: launchline-0.2.1.dev0.tar.gz
  • Upload date:
  • Size: 25.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for launchline-0.2.1.dev0.tar.gz
Algorithm Hash digest
SHA256 34cf27ebe5fb79ebd6735519ef4f338fe4291d723e49307a744c2657f8b0422d
MD5 c483bb872d50b41b778126e8af24346f
BLAKE2b-256 98a6f69985b65fdf6c886ba6d74d53999fde57206ed6a29efed0658371184cbc

See more details on using hashes here.

Provenance

The following attestation bundles were made for launchline-0.2.1.dev0.tar.gz:

Publisher: release.yml on mikejhill/launchline

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

File details

Details for the file launchline-0.2.1.dev0-py3-none-any.whl.

File metadata

File hashes

Hashes for launchline-0.2.1.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 eadda965ebbe6064e3448f8491108a84485210f70e78e3182d1b2f35ff65b0b3
MD5 edef99f5fdfb80bd7d85e36c5f6b8d68
BLAKE2b-256 e29cd5bf11eec8fa91455b0d77e57c3a162d3a0c0ba0ffff93c99640a1c0b01a

See more details on using hashes here.

Provenance

The following attestation bundles were made for launchline-0.2.1.dev0-py3-none-any.whl:

Publisher: release.yml on mikejhill/launchline

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