Skip to main content

A lightweight terminal launcher for interactive CLI tools.

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 yes Executable to run
args list of strings no [] Arguments passed to the command
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.
  • on_exit must be "restart" or "exit".
  • args must be a list (not a bare string).
  • 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" }

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.1.0.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.1.0-py3-none-any.whl (44.1 kB view details)

Uploaded Python 3

File details

Details for the file launchline-0.1.0.tar.gz.

File metadata

  • Download URL: launchline-0.1.0.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.1.0.tar.gz
Algorithm Hash digest
SHA256 9a1760621d3b3880bf481b8a9a57439517ad3f3ea0dcad57a2a0a900684fca0b
MD5 c5a0850a14b58e7c1a9190c34f0f6039
BLAKE2b-256 6578f23ca4759afec663e2a33e94c3407f4bfa6db7efb26e791fea608c90a2dc

See more details on using hashes here.

Provenance

The following attestation bundles were made for launchline-0.1.0.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.1.0-py3-none-any.whl.

File metadata

  • Download URL: launchline-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 44.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for launchline-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d72212e751ef83576821cd09d72281da9b7d10c1cf638bbfb74e2e9555915aac
MD5 70f08038f97cbbef18078e652db323db
BLAKE2b-256 372bf52345d981ae8af7d573b01dcb504653c6733cb42f5bd2da319ba0d3bacb

See more details on using hashes here.

Provenance

The following attestation bundles were made for launchline-0.1.0-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