chemaclass/phel-cli-gui

Phel functions to render in the terminal. It uses the Cursor from the Symfony Command module.

Maintainers

Package info

github.com/Chemaclass/phel-cli-gui

Homepage

pkg:composer/chemaclass/phel-cli-gui

Statistics

Installs: 228

Dependents: 1

Suggesters: 0

Stars: 5

Open Issues: 0

0.12.0 2026-06-14 18:30 UTC

README

Build rich terminal interfaces in Phel — render text at arbitrary coordinates, draw framed boxes, paint regions, read raw keypresses, and style output with named formatters.

Powered by Symfony's Console Cursor, exposed behind a small, data-first Phel API.

  • Works with any TTY (ANSI-capable).
  • Zero globals — one managed TerminalGui singleton per process.
  • Pure helpers (parse-key) are easy to test without a real terminal.
  • Diff rendering writes only the cells that changed each frame — see docs/api.md.

Requirements

  • PHP 8.4+
  • ext-pcntl, ext-posix, ext-readline
  • Phel ^0.44

Install

composer require chemaclass/phel-cli-gui

Require the namespace in your Phel file:

(ns my-app.main
  (:require phel-cli-gui.terminal-gui :refer [render read-key draw-box clear-screen]))

Quick start

Draw a bordered box, render text inside it, wait for a key, quit.

(ns my-app.hello
  (:require phel-cli-gui.terminal-gui
            :refer [clear-screen draw-box render read-key cleanup-gui]))

(defn main []
  (clear-screen)
  (draw-box {:x 2 :y 1 :width 30 :height 5 :fill-char \space})
  (render 4 3 "Press any key to exit")
  (loop []
    (if (read-key)
      (cleanup-gui)
      (do (php/usleep 10000) (recur)))))

(main)

Run:

vendor/bin/phel run src/phel/hello.phel

Docs

  • API reference — every public function, grouped by concern.
  • Recipes — copy-paste patterns (diff loop, bordered UI, …).

Example projects

  • phel-snake — classic Snake built with this library.

Development

composer install
composer test     # Phel tests + PHPUnit (test:phel / test:php to scope)
composer format   # phel format

Layout: src/phel/ public API · src/php/ rendering core (Symfony Console wrapper + pure helpers) · tests/ Phel, PHPUnit & bashunit suites · tools/ release automation.

Cut a release with tools/release.sh <version> (add --dry-run to preview) — it gates, rolls the CHANGELOG, tags, pushes, and publishes the GitHub release.

AI-assistant config is managed with agnostic-ai: edit the source under .agnostic-ai/, run agnostic-ai sync; the per-tool files (CLAUDE.md, .claude/…) are generated and git-ignored.

License

MIT © Jose M Valera Reales