@furbyhaxx/pi-session-naming
Pi extension for automatic session titles, rename, browsing, and session listing.
Package details
Install @furbyhaxx/pi-session-naming from npm and Pi will load the resources declared by the package manifest.
$ pi install npm:@furbyhaxx/pi-session-naming- Package
@furbyhaxx/pi-session-naming- Version
0.2.1- Published
- May 13, 2026
- Downloads
- 34/mo · 34/wk
- Author
- furbyhaxx
- License
- MIT
- Types
- extension
- Size
- 114.2 KB
- Dependencies
- 0 dependencies · 5 peers
Pi manifest JSON
{
"extensions": [
"./extensions/session/index.ts"
]
}Security note
Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.
README
pi-session-naming
A pi coding-agent extension for automatic session titles, manual session renaming, project session browsing, and session listing.
It uses pi's default theme tokens (accent, dim, warning, selectedBg, etc.), so rendering follows the active pi theme. No custom theme. Shocking restraint, really.
Install
Install from GitHub:
pi install git:https://github.com/furbyhaxx/pi-session-naming
Or clone the repo and install from the local checkout:
git clone https://github.com/furbyhaxx/pi-session-naming
cd pi-session-naming
npm install
pi install path/to/cloned/repo
Load directly without installing:
pi -e path/to/cloned/repo
After npm publishing, the package is intended to install as:
pi install npm:@furbyhaxx/pi-session-naming
Features
- Auto-generates a title for unnamed sessions.
- Generates conventional-style titles such as
fix(auth): refresh token flow. - Restricts scopes to a single lowercase alphanumeric word with configurable length, because
feat(pi-fancy-editor): ...is chaos wearing a hat. - Uses built-in title tags plus optional user-supplied tag guidance.
- Adds lightweight project context from common manifest files, not just npm packages.
- Can disable tags for plain description-only titles.
- Uses a configured lightweight model, or auto-selects a known title model.
- Retries title generation and falls back once to the current session model when different.
- Avoids overwriting manual titles.
- Uses temporary datetime titles for trivial/vague prompts and retries later after meaningful activity.
- Adds
/rename [name]and/rename auto. - Adds
/sessionsfor interactive project session browsing, switching, renaming, and deletion. - Adds fixed
--list-sessions [filter]and--jsonCLI listing flags.
Commands and flags
/rename Open an input prompt for the current session title
/rename <title> Set a manual session title
/rename auto Force title generation from current context
/sessions Browse project sessions interactively
--list-sessions [filter] List project sessions and exit
--json Emit session listing as JSON when listing is active
Configuration
Configuration lives in pi's regular settings.json.
Global settings:
${PI_CODING_AGENT_DIR:-~/.pi/agent}/settings.json
Project settings override global settings:
./.pi/settings.json
This extension reads both scopes through pi's SettingsManager and deep-merges only its own session.titleGeneration, session.rename, and session.browser blocks. Snake-case aliases for the new keys are accepted (title_generation, max_length, scope_max_length, use_tags, builtin_tags, etc.). Unknown settings outside the current schema are ignored.
Defaults
{
"session": {
"titleGeneration": {
"enabled": true,
"language": "auto",
"model": "auto",
"retries": 3,
"emojis": false,
"maxLength": 52,
"scopeMaxLength": 12,
"maxMessageCount": -1,
"includeTools": true,
"useTags": true,
"builtinTags": true,
"tags": []
},
"browser": {
"enabled": true,
"command": "sessions",
"pageSize": 12,
"delete": {
"enabled": true,
"useTrash": true,
"confirmPresses": 2
}
},
"rename": {
"enabled": true,
"command": "rename",
"interactiveWhenEmpty": true
}
}
}
Title generation options
| Key | Default | Meaning |
|---|---|---|
enabled |
true |
Enables automatic title generation. |
language |
"auto" |
auto tells the LLM to use the user's message language; any other string instructs that language. |
model |
"auto" |
auto, or {provider}/{model}{:thinking} such as deepseek/deepseek-v4-flash or deepseek/deepseek-v4-flash:high. |
retries |
3 |
Number of attempts for the selected title model before trying the current session model once when different. |
emojis |
false |
Allows or forbids emojis in generated titles. |
maxLength |
52 |
Maximum length of the description part after the tag, e.g. only choco cookies in research(recipe): choco cookies. |
scopeMaxLength |
12 |
Maximum length for optional scopes. Scopes are normalized to lowercase and must be one alphanumeric word: auth, not auth-service. |
maxMessageCount |
-1 |
Maximum number of latest textified message entries from the active session branch sent inside <session-transcript>. 0 or -1 sends the whole branch transcript. |
includeTools |
true |
Includes textified tool-result messages in <session-transcript>. When false, only user and assistant text messages are sent. |
useTags |
true |
Enables the prefixed tag format (research(recipe): ...). When false, titles are plain descriptions. |
builtinTags |
true |
Enables the built-in tag list. When false, only user-provided tags are available. |
tags |
[] |
Additional lowercase custom tags. Entries may be strings ("meet") or ["name", "guidance"] pairs. Invalid tags are ignored. |
Built-in title tags
Built-in tags include short model-facing guidance for when each tag should apply:
feat, add, fix, refactor, perf, style, test, bench, docs, build, ops, chore,
onboard, scaffold, bootstrap, init, skill, analyze, audit, review, research,
investigate, debug, troubleshoot, plan, design, propose, compare, evaluate,
explain, summarize, document, configure, migrate, prototype, validate, wire
Example
{
"session": {
"titleGeneration": {
"language": "auto",
"model": "github-copilot/gpt-5.4-mini:low",
"retries": 3,
"emojis": false,
"maxLength": 52,
"scopeMaxLength": 12,
"maxMessageCount": -1,
"includeTools": true,
"useTags": true,
"builtinTags": true,
"tags": [
["cook", "Use when cooking"],
["book", "Use when reading or writing about books"],
"meet"
]
}
}
}
To use only your own tag list:
{
"session": {
"titleGeneration": {
"builtinTags": false,
"tags": [["cook", "Use when cooking"], "book", "meet"]
}
}
}
Title-generation project context
For title generation, the extension sends compact project identity metadata when it can detect it. It does not send full manifest files. It also sends the configured textified session branch inside <session-transcript>.
By default, maxMessageCount: -1 sends all textified user/assistant/tool-result message entries from the active session branch. Set a positive maxMessageCount to send only the latest N entries, or set includeTools: false to omit tool-result messages.
Project metadata is sent as a single context line like:
projects: rust:furbyhaxx-core (Cargo.toml), python:furbyhaxx-tools (pyproject.toml)
Detected manifests include package.json, Cargo.toml, pyproject.toml, pubspec.yaml, go.mod, composer.json, pom.xml, Gradle settings/build files, .gemspec, mix.exs, and deno.json/deno.jsonc.
Package manifest
The pi package manifest exposes only the session extension entry point:
{
"pi": {
"extensions": ["./extensions/session/index.ts"]
}
}
Development
npm install
npm run typecheck
npm test
npm pack --dry-run
Pi loads the TypeScript source directly; the build script only typechecks and does not emit artifacts.