Skip to main content

Cross-platform TUI for NMEA 2000 with canboat decoding and pluggable drivers

Project description

pgntui

Cross-platform TUI for NMEA 2000 with canboat decoding.

Read live N2K frames through pluggable drivers, decode them with the canboat PGN database, and route values into JSON-defined dashboards. Record sessions to .pgnlog and replay them later — no boat required.

Install

The easiest path is pipx:

pipx install pgntui

If your system Python is older than 3.11, point pipx at a newer interpreter:

pipx install --python python3.12 pgntui

Or run in a project venv:

python3 -m venv .venv && . .venv/bin/activate
pip install pgntui

Standalone single-file binaries for macOS (arm64, x86_64), Linux (x86_64) and Windows (x86_64) are attached to each GitHub release.

Quickstart

Scaffold the example workspace and launch:

pgntui --example      # writes the example workspace at the OS default location
pgntui                # opens the TUI; no driver yet, debug tab will be empty

Replay a recording:

pgntui replay path/to/session.pgnlog

Run with a real driver — pgntui picks the driver named in config.toml:

pgntui                # uses driver.name from <workspace>/config.toml

Workspace layout

pgntui reads everything from a workspace directory. By default the location follows platformdirs.user_config_dir("pgntui"):

OS Default workspace
Linux ~/.config/pgntui
macOS ~/Library/Application Support/pgntui
Windows %APPDATA%\pgntui

Override with --workspace <path> on the command line.

Layout:

<workspace>/
  config.toml            # driver + theme + paths
  signals/*.json         # signal definitions (PGN -> field -> widget)
  containers/*.json      # dashboard layouts (tab -> grid of signals)
  recordings/            # .pgnlog files written by the R hotkey
  logs/                  # CSV exports

Run pgntui --example to drop a working sample inside this directory.

Drivers

Built-in driver entry points (pgntui.drivers):

  • actisense-ngt1 — Actisense NGT-1 USB serial gateway (pyserial)
  • file-replay — replay an Actisense .pgnlog capture

Pick one in config.toml:

[driver]
name = "actisense-ngt1"
port = "/dev/tty.usbserial-XXXX"   # macOS / Linux
# port = "COM4"                    # Windows
baud = 115200

Third-party drivers can register additional entry points under the pgntui.drivers group.

Signal types

Signal JSON files declare how each PGN field renders:

  • analog_in — gauge / numeric readout (RPM, speed, depth, temperature)
  • digital_in — boolean lamp (alarm, anchor light, bilge pump state)
  • analog_out — write-back analog control (sends an outbound frame)
  • digital_out — write-back toggle (sends an outbound frame)

analog_out and digital_out need --enable-write on the CLI and app.write_enabled = true in config.toml; otherwise they render as read-only.

Themes

Six builtins ship in the wheel:

  • dark (default)
  • light
  • amber-crt
  • green-phosphor
  • mono-ascii
  • rainbow-disco

Custom themes are JSON files referenced from config.toml:

[app]
theme = "dark"

Replay

Replay an Actisense-format .pgnlog:

pgntui replay capture.pgnlog

The replay driver respects the original frame spacing. Press the R hotkey inside the TUI to start/stop recording the live stream to a new .pgnlog file under <workspace>/recordings/.

Hotkeys

Tab / Shift+Tab     next / previous container tab
D                   jump to Debug tab
R                   start / stop recording
Q / Ctrl+Q          quit immediately
?                   show help line in status bar

Layout sketch

+---------------------------------------------------+
|  pgntui                                           |
+---------------------------------------------------+
| [Main] [Engine] [Nav] [Debug]                     |
+---------------------------------------------------+
|  RPM     1450    Speed   6.8 kn   Depth 12.3 m    |
|  +----+         +----+           +----+           |
|  |####|         |##  |           |#   |           |
|  +----+         +----+           +----+           |
|                                                   |
|  Bilge OFF     Anchor Light ON                    |
+---------------------------------------------------+
| [Tab] Next  [D] Debug  [R] Rec  [Q] Quit          |
| status: idle                                      |
+---------------------------------------------------+

Status

Alpha. Reasonable to dogfood on a known-good boat or a bench rig.

  • Works: TUI shell, canboat decoder, signal routing, file replay, Actisense NGT-1 driver (read), recording.
  • Partial: NGT-1 write-back is wired but field-tested only against a tiny PGN subset.
  • Not yet: TwoCAN / Yacht Devices native drivers, more layout primitives, per-signal alarm thresholds in the UI.

Bug reports and patches welcome — file an issue at https://github.com/phobicdotno/pgntui/issues.

License

MIT. See LICENSE.

Links

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pgntui-0.3.0.tar.gz (223.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pgntui-0.3.0-py3-none-any.whl (175.4 kB view details)

Uploaded Python 3

File details

Details for the file pgntui-0.3.0.tar.gz.

File metadata

  • Download URL: pgntui-0.3.0.tar.gz
  • Upload date:
  • Size: 223.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pgntui-0.3.0.tar.gz
Algorithm Hash digest
SHA256 e78d1402441943b538900c69581714f7555d90336df0d70687be1b764ffdaf55
MD5 b6370b6726ffb4db2caafe615508c772
BLAKE2b-256 1341b74e3eb291de8eb529bd0e6f20c60b01a4aca2b73708dcf10f1356ab8749

See more details on using hashes here.

Provenance

The following attestation bundles were made for pgntui-0.3.0.tar.gz:

Publisher: release.yml on phobicdotno/pgntui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pgntui-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: pgntui-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 175.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pgntui-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a6a1ddc4c09789db102b769db64727c18c291aee911055dc99917177d51144e0
MD5 f704dbe9d0ca60c0bf7ecb481f9076d0
BLAKE2b-256 d3e7d7ca899179251241373ab4c4dbe843daa9d91be9686c9aa98c120a871962

See more details on using hashes here.

Provenance

The following attestation bundles were made for pgntui-0.3.0-py3-none-any.whl:

Publisher: release.yml on phobicdotno/pgntui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page