Commit Graph

6 Commits

Author SHA1 Message Date
benclive
f6bd6b7cb3 chore: Ignore errgroup context in decoder (#20880) 2026-02-19 17:53:50 +00:00
Robert Fratto
f9bdab2fc8 chore(dataobj): restructure dataobjs to store metadata at the front of the file (#20865)
Signed-off-by: Robert Fratto <robertfratto@gmail.com>
2026-02-19 10:54:38 -05:00
benclive
3148a77966 chore: improve metastore Section calls (#19157) 2025-09-11 09:27:34 +00:00
Robert Fratto
100e259a8d chore(dataobj): introduce the concept of section info "extensions" (#18832) 2025-08-13 10:14:04 -04:00
Robert Fratto
61c40fca0c chore(dataobj): remove support for deprecated fields (breaking change) (#18822) 2025-08-13 08:16:18 -04:00
Robert Fratto
a237444f0d refactor(dataobj): invert dependency between dataobj and sections (#17762)
Originally, the dataobj package was a higher-level API around sections. This
design caused it to become a bottleneck:

* Implementing any new public behaviour for a section required bubbling it up
  to the dataobj API for it to be exposed, making it tedious to add new
  sections or update existing ones.

* The `dataobj.Builder` pattern was focused on constructing dataobjs for
  storing log data, which will cause friction as we build objects around other
  use cases. 

This PR builds on top of the foundation laid out by #17704 and #17708, fully
inverting the dependency between dataobj and sections:

* The `dataobj` package has no knowledge of what sections exist, and can now be
  used for writing and reading generic sections. Section packages now create
  higher-level APIs around the abstractions provided by `dataobj`.

* Section packages are now public, and callers interact directly with these
  packages for writing and reading section-specific data.

* All logic for a section (encoding, decoding, buffering, reading) is now fully
  self-contained inside the section package. Previously, the implementation of
  each section was spread across three packages
  (`pkg/dataobj/internal/encoding`, `pkg/dataobj/internal/sections/SECTION`,
  `pkg/dataobj`).

* Cutting a section is now a decision made by the caller rather than the
  section implementation. Previously, the logs section builder would create
  multiple sections. 

For the most part, this change is a no-op, with two exceptions:

1. Section cutting is now performed by the caller; however, this shouldn't
   result in any issues. 

2. Removing the high-level `dataobj.Stream` and `dataobj.Record` types will
   temporarily reduce the allocation gains from #16988. I will address this after
   this PR is merged.
2025-05-21 08:04:35 -04:00