📊 Full opportunity report: Disk Is the Contract: Inside Threlmark’s Local-First Architecture on ThorstenMeyerAI.com — validation score, market gap, and execution plan.

TL;DR

Threlmark’s local-first approach makes disk the ultimate data contract, replacing databases with simple, resilient file-based storage. This enhances offline capability, data portability, and system transparency.

Threlmark has adopted a novel architecture where the local disk is treated as the definitive source of truth, eschewing traditional databases. This approach simplifies data synchronization, improves offline usability, and makes data more portable across tools, marking a significant shift in how project data is managed. For a detailed explanation, see the original analysis.

Threlmark’s system relies on one file per data item, using atomic write operations to prevent corruption and race conditions. The directory structure acts as a formal data contract, making it easy for external tools to read and modify data without proprietary interfaces. This design prioritizes transparency, resilience, and ease of extension, allowing users to work directly with plain files that reflect the current state of their projects.

Key safety mechanisms include atomic file writes—writing to a temporary file before renaming—and tolerant merging that preserves essential metadata like IDs and timestamps. These ensure data integrity during concurrent edits or unexpected failures. The approach also enables self-healing, where the system reconstructs views from individual files, reducing dependency on a central database or server.

Disk is the contract: inside Threlmark’s architecture — ThorstenMeyerAI.com
ThorstenMeyerAI.com
Threlmark · Technical Deep-Dive
Threlmark · architecture

Disk is the contract: inside a local-first roadmap hub

A Next.js app on top of plain JSON files — no database, no cloud, no accounts. The key decision: the on-disk layout IS the API. Everything else cascades from taking that seriously.

Next.js · TypeScript · JSON-on-disk · MIT · part 2 of the Threlmark series
01The core decision

There is no server-of-record — the files are the record

The UI and any external tool reach the same files through the same discipline. The data root defaults to ~/.threlmark — home-based, because it’s a shared hub every one of your apps points at.

~/.threlmark/ ├─ threlmark.json # manifest ├─ links.json # dependency graph ├─ projects// │ ├─ project.json # meta + wipLimits │ ├─ board.json # lane ordering │ ├─ items/.json # ONE card per file ← source of truth │ ├─ suggestions/ # the Inbox (drop-zone) │ ├─ handoffs/ # recorded agent handoffs │ ├─ reports/ # agent report drop-zone │ └─ ROADMAP.md # human-readable mirror ├─ shared/items/ # cards many projects ref └─ archive/ # archived, still readable

Inspectable

Every artifact is a file you can cat, diff, grep, commit.

Portable · no lock-in

Back up with cp, sync with Dropbox / git, migrate trivially.

Interoperable

Any tool in any language joins by reading / writing files.

Restartable

No in-memory state to lose — stateless over the files.

02Making files safe
SANDISK 2TB Extreme Portable SSD (Old Model) - Up to 1050MB/s, USB-C, USB 3.2 Gen 2, IP65 Water and Dust Resistance, Updated Firmware - External Solid State Drive - SDSSDE61-2T00-G25

SANDISK 2TB Extreme Portable SSD (Old Model) – Up to 1050MB/s, USB-C, USB 3.2 Gen 2, IP65 Water and Dust Resistance, Updated Firmware – External Solid State Drive – SDSSDE61-2T00-G25

Get NVMe solid state performance with up to 1050MB/s read and 1000MB/s write speeds in a portable, high-capacity…

As an affiliate, we earn on qualifying purchases.

As an affiliate, we earn on qualifying purchases.

Two disciplined patterns instead of a database

“Just use files” is easy to get wrong. These two patterns — ported from a battle-tested sibling app — are what make file-based state sound rather than reckless.

Pattern 1

Atomic writes

Write to a temp file in the same dir, then rename() over the target. Rename is atomic on one filesystem — a crash mid-write leaves the complete old file or the complete new one, never a half.

write .tmp-pid-rand fsync rename() over target
Pattern 2 · one file per item

The board heals itself

A single roadmap.json array races when two tools write at once. One file per card makes writes collision-free. Lane order lives in board.json and reconciles on read.

The payoff: an external tool never touches board.json. It writes an item file — the board fixes itself on Threlmark’s next read. Unknown keys are preserved, so the contract is forward-compatible.
03Derived, never stored
SANDISK 512GB Ultra USB 3.0 Flash Drive - SDCZ48-512G-G46, Black

SANDISK 512GB Ultra USB 3.0 Flash Drive – SDCZ48-512G-G46, Black

Transfer speeds up to 10x faster than standard USB 2.0 drives (4MB/s); up to 130MB/s read speed; USB…

As an affiliate, we earn on qualifying purchases.

As an affiliate, we earn on qualifying purchases.

The numbers can’t drift from the files

Anything computable from item state is computed — so the displayed numbers can never disagree with the underlying JSON. Priority is the clearest example: it’s calculated on read, never persisted.

priority — computed on read

Impact weighted heaviest; effort the only axis that subtracts. Reused verbatim from the original tool, so imported cards rank identically.

priority = max(0, round(impact·3 + evidence·2 + fit·2effort·1.5))
a 5 / 5 / 5 / 4 card 29
work-item age
now − lane-entry time. Past threshold (dev 7d, ranked 21d, idea 60d) → stale.
cycle time
first DevelopmentDone. Derived from append-only transitions[].
throughput
items reaching Done per ISO week, 8-week window.
WIP
count per lane; over the cap shows 3 / 2 in red.
04The closed agent loop · press play
Free Fling File Transfer Software for Windows [PC Download]

Free Fling File Transfer Software for Windows [PC Download]

Intuitive interface of a conventional FTP client

As an affiliate, we earn on qualifying purchases.

As an affiliate, we earn on qualifying purchases.

A handoff is a first-class flow event

The genuinely 2026-shaped part: most building is done by AI agents, so Threlmark closes the loop. Watch a card go from ranked to Done without anyone dragging it.

Handoff → report → self-move

The brief carries a reporting protocol. The agent reports through REST or the filesystem — and a done report moves the card itself.

Ranked
Add price-drop alertsscore 31 · ready
Development
Handed off 🤖
Done
▶ preferred — REST
POST /api/projects/:id/
items/:itemId/report

Direct call. Applied immediately.

▶ fallback — filesystem
drop reports/.json
→ ingested on read

Robust even if the server’s down at finish time.

🤖 claude done: price-drop alerts shipped · typecheck + lint + build passed — card moved to Done
05Portfolio score & deployment
Tsubosan Hand tool Workmanship file set of 5 ST-06 from Japan

Tsubosan Hand tool Workmanship file set of 5 ST-06 from Japan

Tsubosan Hand tool file ST-06

As an affiliate, we earn on qualifying purchases.

As an affiliate, we earn on qualifying purchases.

A small formula, and an honest hosting caveat

Because items are globally addressable (/), the Portfolio ranks everything together by a status-weighted score — finishing beats starting, blockers get a boost.

Portfolio ranking — status-weighted

In-flight work floats to the top; bottlenecks cost the most, so blockers get nudged up.

score = priority · statusWeight (+ 0.1 · blockedCount · priority)
1.3
development
1.0
ranked
0.85
idea
0.15
done
Path 1

Static read-only demo

Seeded data, writes to localStorage. Try-before-you-clone.

Path 2

Personal Node instance

Password-gated, persistent backed-up THRELMARK_DATA_DIR.

Path 3

Multi-tenant SaaS

Add accounts + per-tenant isolation. A separate build.

The elegant part: the store interface src/lib/*/store.ts is the natural seam — the same boundary that keeps the local tool simple is the one you’d extend for multi-tenancy. The architecture doesn’t fight that future; it just doesn’t pay for it until you need it.
ThorstenMeyerAI.com
Threlmark · open source (MIT) · github.com/MeyerThorsten/threlmark · part 2 of a series · file layout, formula, weights & agent-loop channels are Threlmark’s actual mechanics.

Impacts of Disk as the Single Data Source

This architecture shifts the paradigm from centralized databases to decentralized, file-based data management. It enhances offline capabilities, reduces vendor lock-in, and simplifies data recovery. For users, this means more control over their data, easier integration with external tools, and increased system resilience. For developers, it introduces new challenges in managing file concurrency and conflict resolution but ultimately results in a more transparent and flexible system.

Evolution of Data Management in Project Tools

Traditional project management tools rely heavily on centralized databases or cloud services, which can introduce lock-in, complicate offline use, and obscure data structure. Threlmark’s approach builds on the growing trend towards local-first, peer-to-peer, and file-based systems, emphasizing user control and system transparency. This development aligns with broader movements advocating for open, interoperable, and resilient data architectures.

“Treating the disk as the contract simplifies data handling and enhances offline usability, making the system more resilient and flexible.”

— Thorsten Meyer, Threlmark Developer

Unresolved Challenges and Future Risks

It is not yet clear how well this architecture scales with very large datasets or complex collaboration scenarios involving many simultaneous users. The potential for manual errors or conflicts in manual file editing remains a concern, and the system’s ability to handle extensive concurrent modifications without conflicts is still being tested. For more insights, see the original analysis.

Next Steps for Threlmark’s Local-First System

Threlmark plans to further develop conflict resolution mechanisms, improve self-healing features, and test scalability with larger datasets. User feedback and real-world usage will guide enhancements, particularly around multi-user collaboration and automated conflict management. Expect updates that refine the directory structure and safety protocols to support broader adoption.

Key Questions

How does Threlmark prevent data corruption during file writes?

Threlmark uses atomic write operations, where data is first written to a temporary file, then renamed over the original, preventing corruption if a write is interrupted.

Can external tools safely modify Threlmark data?

Yes, the directory structure is a formal contract, allowing external tools to read and write files directly, provided they follow the agreed format.

What are the main advantages of this architecture?

It offers offline capability, data portability, transparency, and resilience against server or cloud failures, reducing vendor lock-in and simplifying data recovery.

What challenges does this approach face?

Managing concurrent edits, conflict resolution, and scaling with large datasets are ongoing challenges that Threlmark aims to address in future updates.

Source: ThorstenMeyerAI.com

You May Also Like

What Refresh Rate Actually Changes in Phones, TVs, and Monitors

Understanding what a higher refresh rate actually changes in phones, TVs, and monitors reveals why your visuals feel smoother and more responsive—keep reading to learn more.

The gigawatt gap. Why China is structurally positioned for AI power and the US is engineering around its grid.

China leverages centralized planning and renewable energy to close the gigawatt gap in AI infrastructure, challenging US dominance.

Matter vs HomeKit vs Alexa: The Compatibility Choice That Can Break Your Setup

Like choosing the right smart home platform can make or break your setup, understanding the differences between Matter, HomeKit, and Alexa is essential.

4K Vs 1440P Vs 1080P for Work: the Text Clarity Winner Might Surprise You

Unlock the truth behind 4K, 1440p, and 1080p for work—discover which resolution actually provides the clearest text and why it might surprise you.