diff options
author | Colin Walters <walters@verbum.org> | 2021-04-09 00:35:54 +0000 |
---|---|---|
committer | Colin Walters <walters@verbum.org> | 2021-04-09 21:54:44 +0000 |
commit | 6f84aff0ae72b6b6b8b0b1c388c6a937c32160c8 (patch) | |
tree | 657b47c548e8980556b731288291b4b8ad7069f9 /src/libostree/ostree-repo-private.h | |
parent | 020f6cb6521c2b237871d194488cc59079beed6a (diff) | |
download | ostree-6f84aff0ae72b6b6b8b0b1c388c6a937c32160c8.tar.gz |
repo: Add ostree_repo_write_regfile
This API is push rather than pull, which makes it much more
suitable to use cases like parsing a tar file from external
code.
Now, we have a large mess in this area internally because
the original file writing code was pull based, but static
deltas hit the same problem of wanting a push API, so I added
this special `OstreeRepoBareContent` just for writing regular
files from a push API.
Eventually...I'd like to deprecate the pull based API,
and rework things so that for regular files the push API
is the default, and then `write_content_object()` would
be split up into archive/bare cases.
In this world the `ostree_repo_write_content()` API would
then need to hackily bridge pull to push and it'd be
less efficient.
Anyways for now due to this bifurcation, this API only
works on non-archive repositories, but that's fine for
now because that's what I want for the `ostree-ext-container`
bits.
Diffstat (limited to 'src/libostree/ostree-repo-private.h')
-rw-r--r-- | src/libostree/ostree-repo-private.h | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src/libostree/ostree-repo-private.h b/src/libostree/ostree-repo-private.h index 6c01bc6b..14b29c0b 100644 --- a/src/libostree/ostree-repo-private.h +++ b/src/libostree/ostree-repo-private.h @@ -462,6 +462,16 @@ _ostree_repo_bare_content_commit (OstreeRepo *self, GCancellable *cancellable, GError **error); +OstreeContentWriter * +_ostree_content_writer_new (OstreeRepo *repo, + const char *checksum, + guint uid, + guint gid, + guint mode, + guint64 content_len, + GVariant *xattrs, + GError **error); + gboolean _ostree_repo_load_file_bare (OstreeRepo *self, const char *checksum, |