No description
Find a file
2026-06-09 05:34:39 -07:00
.project/history feat(tv-anarchy): document search pipeline failure analysis 2026-06-08 22:58:41 -07:00
docs docs(@applications/tv-anarchy): 📝 add technical glossary definitions 2026-06-08 22:14:11 -07:00
Sources feat(fleet): DevicesView + player target rework (partial Host->Device, keeps HostConfig) 2026-06-09 05:34:39 -07:00
Tests/TVAnarchyCoreTests feat(fleet): DevicesView + player target rework (partial Host->Device, keeps HostConfig) 2026-06-09 05:34:39 -07:00
tools refactor(tv-anarchy): rename PlumTV→TVAnarchy and land session work 2026-06-08 22:04:22 -07:00
.gitignore refactor(tv-anarchy): rename PlumTV→TVAnarchy and land session work 2026-06-08 22:04:22 -07:00
build-install.sh refactor(tv-anarchy): rename PlumTV→TVAnarchy and land session work 2026-06-08 22:04:22 -07:00
project.yml refactor(tv-anarchy): rename PlumTV→TVAnarchy and land session work 2026-06-08 22:04:22 -07:00
README.md refactor(tv-anarchy): rename PlumTV→TVAnarchy and land session work 2026-06-08 22:04:22 -07:00

TVAnarchy

Native macOS app (SwiftUI) for the home media stack on plum. Unifies what was previously CLI/MCP-only: pick a playback target (plum's VLC or the HDMI TV on black) and drive transport; later phases add a cached library browser, a download searcher/manager, and a local (MLX) filename→metadata pipeline.

Hybrid architecture: the control plane is native Swift (SSH shell-outs to the deployed black-tv script; HTTP to VLC's Lua interface — zero new runtime deps); the data-heavy plane reuses existing projects (plum-control-mcp, media-recommender) as helper subprocesses. See the build plan for phases.

Build

brew install xcodegen        # if not already present
xcodegen generate            # project.yml -> TVAnarchy.xcodeproj
xcodebuild -scheme TVAnarchy -destination 'platform=macOS' build
# or open TVAnarchy.xcodeproj in Xcode and Run

TVAnarchy.xcodeproj is generated and git-ignored — project.yml is the source of truth.

Layout

  • Sources/TVAnarchyCore/ — framework: models, PlayerTarget protocol + impls, target selector.
  • Sources/TVAnarchy/ — SwiftUI app (App, RootView, feature views).
  • Tests/TVAnarchyCoreTests/ — unit tests for the core (status decoders, mappings).

Targets

  • Plum VLC — HTTP to http://127.0.0.1:8080/requests/… (password from ~/.config/portable-net-tv/config.json or $VLC_HTTP_PASSWORD).
  • Black TVssh lilith@10.9.0.4 /usr/local/bin/black-tv <verb> (the overlay IP; the LAN address flaps). All playback intelligence lives in black-tv on black.