pi-fff-non-ascii-guard

Pi extension that detects and renames non-ASCII filenames before fff-core can panic on UTF-8 byte boundaries.

Packages

Package details

extension

Install pi-fff-non-ascii-guard from npm and Pi will load the resources declared by the package manifest.

$ pi install npm:pi-fff-non-ascii-guard
Package
pi-fff-non-ascii-guard
Version
0.1.6
Published
Jun 8, 2026
Downloads
388/mo · 131/wk
Author
eiei114
License
MIT
Types
extension
Size
25.6 KB
Dependencies
0 dependencies · 2 peers
Pi manifest JSON
{
  "extensions": [
    "./extensions"
  ]
}

Security note

Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.

README

pi-fff-non-ascii-guard

CI Publish npm version npm downloads License: MIT Pi Package Trusted Publishing

Pi extension that prevents fff-core panics caused by non-ASCII filenames.

What this is

A Pi extension that detects and renames non-ASCII filenames before fff-core can panic on UTF-8 byte boundaries. It scans your workspace on session start, warns about problematic filenames, and provides a tool to safely rename them to ASCII slugs.

Problem

fff-core can panic when it slices UTF-8 paths at byte offsets that are not character boundaries — for example, paths containing Japanese characters:

thread '<unnamed>' panicked at crates\fff-core\src\constraints.rs:73:13:
byte index 65 is not a char boundary

This extension prevents the known crash by keeping scanned filenames ASCII-safe.

Features

  • Session-start scan — automatically detects non-ASCII paths when a Pi session begins
  • fff tool gate — blocks grep, find_files, and fff_multi_grep while non-ASCII paths remain (prevents fff-core panic)
  • Warning notification — alerts the LLM when problematic paths are found
  • list_non_ascii_paths tool — list files and directories with non-ASCII path segments
  • sanitize_filenames tool — preview or execute safe ASCII slug renames for files
  • Smart exclusions — skips .git, .obsidian, .pi, .claude, .scratch, and node_modules
  • Collision disambiguation — when two files slug to the same name, appends -2, -3, … and continues

Install

pi install git:github.com/eiei114/pi-fff-non-ascii-guard

For project-local install:

pi install -l git:github.com/eiei114/pi-fff-non-ascii-guard

Quick start

  1. Install the extension (see Install).
  2. Start a Pi session in a workspace that may contain non-ASCII filenames.
  3. If non-ASCII filenames are detected, Pi shows a warning with the file list.
  4. Ask the LLM to call sanitize_filenames with dryRun: true to preview, then dryRun: false to execute.
  5. After paths are ASCII-safe, grep / find_files / fff_multi_grep work again.

While non-ASCII paths exist, Pi blocks fff search tools and returns a fix hint instead of crashing.

Usage summary

list_non_ascii_paths tool

Lists every file and directory whose relative path contains non-ASCII characters. No parameters.

sanitize_filenames tool

Parameter Type Default Description
dryRun boolean true Preview renames without executing

Preview renames:

{ "dryRun": true }

Execute renames:

{ "dryRun": false }

The tool returns a list of planned or completed renames. If two files would collide after slug conversion, targets are auto-suffixed (-2, -3, …) so the batch can proceed without manual renaming.

Package contents

pi-fff-non-ascii-guard/
├── extensions/
│   └── pi-fff-non-ascii-guard.ts   # Extension entry
├── lib/                            # Scan, slug, rename-plan helpers
├── tests/                          # Smoke tests
├── .github/workflows/
│   ├── auto-release.yml            # Auto-tag + release on merge to main
│   ├── ci.yml                      # Validate on PR / push
│   └── publish.yml                 # Publish to npm on tag or release
├── CHANGELOG.md
├── LICENSE                         # MIT
├── SECURITY.md                     # Vulnerability reporting
├── package.json
└── README.md

Development

Clone and validate:

git clone https://github.com/eiei114/pi-fff-non-ascii-guard.git
cd pi-fff-non-ascii-guard
npm test        # smoke tests
npm run check   # tests + npm pack --dry-run

Release

Releases are automated:

  1. Bump version in package.json.
  2. Merge to main.
  3. The Auto Release workflow tags v<version> and creates a GitHub release.
  4. The tag triggers the Publish workflow, which publishes to npm with provenance.

Security

See SECURITY.md for vulnerability reporting.

  • No network requests.
  • No environment variables or secrets read.
  • Only renames files within the current Pi workspace directory.
  • Skips hidden and internal directories (.git, .obsidian, .pi, .claude, .scratch, node_modules).

Real incidents

This extension was created after Pi crashed while updating .pi/monofold.yaml in an Obsidian vault that contained Japanese PDF filenames.

Another crash while editing AGENTS.md in a Roblox repo with Google Apps Script files:

thread '<unnamed>' panicked at crates\fff-core\src\constraints.rs:73:13:
byte index 44 is not a char boundary; it is inside 'な' (bytes 43..46) of
`scripts\SpreadsheetToJson_wrapあり・nullなし.gs`

The fff tool gate blocks grep, find_files, and fff_multi_grep until those paths are renamed.

Observed error:

thread '<unnamed>' panicked at crates\fff-core\src\constraints.rs:73:13:
byte index 65 is not a char boundary; it is inside 'イ' (bytes 63..66) of `2_Literature\2_Tools\Pi Coding Agent - 初心者向け比較ガイド - slides.pdf`

Both offending files were renamed to ASCII slugs:

2_Literature/2_Tools/pi-coding-agent-beginner-guide-slides.pdf
2_Literature/PKM/3x-zettelkasten-ai-serial-acceleration.pdf

Links

License

MIT © Keisu