summaryrefslogtreecommitdiff
path: root/src/libostree/ostree-repo-private.h
diff options
context:
space:
mode:
authorColin Walters <walters@verbum.org>2021-04-09 00:35:54 +0000
committerColin Walters <walters@verbum.org>2021-04-09 21:54:44 +0000
commit6f84aff0ae72b6b6b8b0b1c388c6a937c32160c8 (patch)
tree657b47c548e8980556b731288291b4b8ad7069f9 /src/libostree/ostree-repo-private.h
parent020f6cb6521c2b237871d194488cc59079beed6a (diff)
downloadostree-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.h10
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,