Files
Ken Johnson 20cd593465 Milestone 0.3.2 (closing): HWM docs + coverage map
Documents the HWM API in architecture.md and surfaces it in
README.md's feature list. Includes the auto-bump pattern, the
multi-tenant convention (each tosser registers as a named user
in the same lastread file), and the per-format coverage map.

Coverage decisions for 0.3.x:

  JAM        -- native (.JLR)              [shipped 0.3.0]
  Squish     -- native (.SQL)              [shipped 0.3.1]
  MSG / PKT  -- spec has no HWM, returns -1  [structural]
  PCBoard    -- USERS file too entangled, deferred
  Wildcat    -- WC SDK exposes only per-message MarkMsgRead,
                no per-user HWM primitive; defer until either
                the SDK gains the call or we reverse-engineer
                the user-conference state file
  Hudson     -- LASTREAD.BBS is per-(user, board) and the
  GoldBase     base instance doesn't carry board context;
  EzyCom       needs API design before impl

For deferred formats, GetHWM honestly returns -1 and the caller
falls back to its own state (e.g. NR's dupedb keyed by area).
This matches the "no fakery" principle: don't pretend a format
supports HWM when it doesn't, and don't silently sidecar in a
location consumers can't discover.

The 0.3.0 / 0.3.1 trio gives NetReader native HWM coverage for
the two formats that account for the overwhelming majority of
real-world FidoNet areas (JAM, Squish). Everything else falls
back to dupedb.

No code changes in this commit -- docs only.
2026-04-17 16:02:51 -07:00
..