Files
ffx/guidance/workflow/optional/preparation-script-design.md

4.1 KiB

Preparation Script Design

Rule set name: preparation-script-design

Rule set ID: PSD

Status: optional, prompt-activated only

Trigger examples:

  • Apply the preparation-script-design rules.
  • Apply PSD rules.

PSD-0001: Apply this rule set only when it is explicitly requested in the prompt.

PSD-0002: Use this rule set for scripts whose purpose is to prepare, verify, or expose a local development or automation environment rather than to perform product runtime behavior.

PSD-0003: Keep a preparation script focused on environment readiness, dependency installation, local helper exposure, and clear verification output; do not mix unrelated product logic into the script.

PSD-0004: Design the script to be idempotent so repeated runs converge on the same prepared state without unnecessary reinstallation or destructive side effects.

PSD-0005: Provide a verification-only mode such as --check that reports readiness without installing, modifying, or creating dependencies.

PSD-0006: Separate component checks from installation steps so the script can report what is missing before or after attempted remediation.

PSD-0007: Group required capabilities into clear purpose-oriented sections such as support toolchains, local package bundles, generated environment helpers, or other relevant readiness areas instead of presenting one undifferentiated dependency list.

PSD-0008: Prefer explicit per-component check helpers over opaque one-shot checks so failures remain traceable and easy to extend.

PSD-0009: Generate or update environment helper files only when they provide a stable, reusable way to expose repo-local or workspace-local tools, paths, or environment variables.

PSD-0010: Generated environment helper files shall be safe to source multiple times and should avoid duplicating path entries or clobbering unrelated user environment state.

PSD-0011: When a preparation flow seeds optional user-owned files such as config templates, do so non-destructively by creating them only when absent unless the prompt explicitly requests overwrite behavior.

PSD-0012: Report status in a concise scan-friendly line format of the shape [status] Label: detail, where the label names the checked component and the detail string stays short and specific.

PSD-0013: Prefer a small canonical status vocabulary in those report lines, with ok for satisfied checks, warn for non-blocking gaps, and a failure status such as failed for blocking or unsuccessful states.

PSD-0014: When a preparation script uses terminal colors in its status output, apply a consistent severity mapping so ok is green, warn is yellow, and all other status levels are red.

PSD-0015: In bracketed status markers such as [ok] or [warn], keep the square brackets uncolored and apply the severity color only to the inner status text.

PSD-0016: Colorized status output shall degrade safely in non-terminal or non-color contexts so the script remains readable and automation-friendly without ANSI support.

PSD-0017: End with an explicit readiness conclusion that distinguishes between successful preparation, incomplete prerequisites, and failed installation attempts.

PSD-0018: Installation logic should use the narrowest supported platform-specific package-manager actions necessary for the declared scope and should fail clearly when no supported installation path is available.

PSD-0019: Treat repo-local helper tooling and local package installation boundaries explicitly rather than assuming global installs, especially when the prepared environment is intended to be reproducible.

PSD-0020: Keep the script suitable for both interactive local developer use and non-interactive automation checks by avoiding prompts during normal execution unless the prompt explicitly requires interactivity.

PSD-0021: When a script depends on generated helper files or adjacent validation helpers, update those supporting files only as needed to keep the preparation flow coherent and usable.

PSD-0022: Verify shell syntax after changes and, when feasible, run a dry readiness check so the resulting preparation flow is validated rather than only written.