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.2.tar.gz (227.5 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.2-py3-none-any.whl (175.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pgntui-0.3.2.tar.gz
  • Upload date:
  • Size: 227.5 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.2.tar.gz
Algorithm Hash digest
SHA256 bd6692f969010fe66b3a9dc9cb38a3cedb315bea5b1d21dce9f3f1195c530bb4
MD5 14bf1a757e60d69a506b8449972db99c
BLAKE2b-256 f56267edac340ea2cfedd12910ab258d86ff800850985dd4b76962db786927d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for pgntui-0.3.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: pgntui-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 175.5 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 703076b8cbd3769b84185de8328ab72902899baebd3625c378cec05cd0117061
MD5 40da94cc02355e1bbb134554c1d60eae
BLAKE2b-256 7923d3f814b95d9dea574e7301ce16ff5567cdf38a21c0939c10ba22729717d1

See more details on using hashes here.

Provenance

The following attestation bundles were made for pgntui-0.3.2-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