Persistent terminal sessions for Neovim.
Processes survive Neovim restarts. Terminal rendering is delegated to Neovim's native terminal (jobstart(..., { term = true })) while pterm keeps PTY processes alive.
# Create a new persistent session (forks into background)
pterm new mysession
pterm new mysession -- /bin/zsh # custom command
# Attach bridge mode (for terminal clients)
pterm attach mysession
# Attach if exists, otherwise create and attach
pterm open mysession
pterm open mysession -- /bin/zsh
# List active sessions (optionally filter by prefix)
pterm list
pterm list myprefix
# Get socket path for a session
pterm socket mysession
# Redraw terminal (resend snapshot to all clients)
pterm redraw mysession
# Print diagnostic state dump as JSON
pterm dump mysession
# Kill a session
pterm kill mysessionSession names may contain / for hierarchical sessions. Killing a parent session also kills all children.
pterm new parent
pterm new parent/child
pterm kill parent # kills parent and parent/child:Pterm dev " opens/creates named session
:Pterm dev zsh " opens/creates session with custom command
:PtermList " list sessions
:PtermRedraw dev " redraw a session
:PtermDump dev " open diagnostic state dump as JSON
:PtermKill dev " kill a sessionpterm opens a terminal buffer backed by jobstart({ "pterm", "attach", <name> }, { term = true }).
The Lua module also exports functions for programmatic use: open, attach, detach, list, kill, redraw, dump.
- Neovim 0.10+
- Nix (with flakes enabled)
- Linux / macOS
This plugin is designed to be installed via Nix flakes. Add pterm as a flake input and include it in your Neovim plugin list.
{
inputs = {
pterm.url = "github:ttak0422/pterm";
};
}Add inputs.pterm.packages.${system}.pterm to your Neovim plugin list and call setup().
require("pterm").setup()
-- Default configuration:
require("pterm").setup({
-- Default shell command
shell = vim.env.SHELL or "/bin/sh",
-- Socket directory (nil = let daemon decide)
socket_dir = nil,
-- Automatically redraw on BufEnter / TermEnter to recover from rendering
-- corruption that can occur during mode or window focus switches.
auto_redraw = true,
-- Cooldown window in milliseconds for automatic redraws. The first
-- BufEnter / TermEnter redraw fires immediately; repeated events are
-- suppressed until the cooldown expires.
auto_redraw_delay_ms = 1000,
})pterm provides an optional Telescope extension for fuzzy-finding sessions.
-- Call after telescope.setup()
require("telescope").load_extension("pterm"):Telescope pterm sessionsEach session is shown as <name> (<directory>), where the directory is the
basename of the session shell's current working directory. The daemon tracks
cd inside the session and refreshes it periodically. Connected
sessions are marked with a ✔ prefix.
The preview pane shows the tail of each session's current terminal screen,
trimmed to the preview width.
If no existing session matches the current Telescope query, pressing Enter
creates or opens a session using the prompt text as the session name.
MIT