mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-20 18:09:21 +03:00
lib: Add an API to construct a MutableTree
from a commit
This is nicer than having the caller parse the commit object, or indirect via the `OstreeRepoFile*` object of the root. Will be used in ostree-rs-ext around tar parsing.
This commit is contained in:
parent
5bf4b1dabc
commit
868776a296
@ -268,6 +268,7 @@ OstreeLzmaDecompressorClass
|
|||||||
<FILE>ostree-mutable-tree</FILE>
|
<FILE>ostree-mutable-tree</FILE>
|
||||||
OstreeMutableTree
|
OstreeMutableTree
|
||||||
ostree_mutable_tree_new
|
ostree_mutable_tree_new
|
||||||
|
ostree_mutable_tree_new_from_commit
|
||||||
ostree_mutable_tree_new_from_checksum
|
ostree_mutable_tree_new_from_checksum
|
||||||
ostree_mutable_tree_check_error
|
ostree_mutable_tree_check_error
|
||||||
ostree_mutable_tree_set_metadata_checksum
|
ostree_mutable_tree_set_metadata_checksum
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
LIBOSTREE_2021.5 {
|
LIBOSTREE_2021.5 {
|
||||||
global:
|
global:
|
||||||
ostree_sepolicy_new_from_commit;
|
ostree_sepolicy_new_from_commit;
|
||||||
|
ostree_mutable_tree_new_from_commit;
|
||||||
} LIBOSTREE_2021.4;
|
} LIBOSTREE_2021.4;
|
||||||
|
|
||||||
/* Stub section for the stable release *after* this development one; don't
|
/* Stub section for the stable release *after* this development one; don't
|
||||||
|
@ -681,3 +681,39 @@ ostree_mutable_tree_new_from_checksum (OstreeRepo *repo,
|
|||||||
out->metadata_checksum = g_strdup (metadata_checksum);
|
out->metadata_checksum = g_strdup (metadata_checksum);
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ostree_mutable_tree_new_from_commit:
|
||||||
|
* @repo: The repo which contains the objects refered by the checksums.
|
||||||
|
* @rev: ref or SHA-256 checksum
|
||||||
|
*
|
||||||
|
* Creates a new OstreeMutableTree with the contents taken from the given commit.
|
||||||
|
* The data will be loaded from the repo lazily as needed.
|
||||||
|
*
|
||||||
|
* Returns: (transfer full): A new tree
|
||||||
|
* Since: 2021.5
|
||||||
|
*/
|
||||||
|
OstreeMutableTree *
|
||||||
|
ostree_mutable_tree_new_from_commit (OstreeRepo *repo,
|
||||||
|
const char *rev,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
g_autofree char *commit = NULL;
|
||||||
|
if (!ostree_repo_resolve_rev (repo, rev, FALSE, &commit, error))
|
||||||
|
return NULL;
|
||||||
|
g_autoptr(GVariant) commit_v = NULL;
|
||||||
|
if (!ostree_repo_load_commit (repo, commit, &commit_v, NULL, error))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
g_autoptr(GVariant) contents_checksum_v = NULL;
|
||||||
|
g_autoptr(GVariant) metadata_checksum_v = NULL;
|
||||||
|
char contents_checksum[OSTREE_SHA256_STRING_LEN + 1];
|
||||||
|
char metadata_checksum[OSTREE_SHA256_STRING_LEN + 1];
|
||||||
|
g_variant_get_child (commit_v, 6, "@ay", &contents_checksum_v);
|
||||||
|
ostree_checksum_inplace_from_bytes (g_variant_get_data (contents_checksum_v),
|
||||||
|
contents_checksum);
|
||||||
|
g_variant_get_child (commit_v, 7, "@ay", &metadata_checksum_v);
|
||||||
|
ostree_checksum_inplace_from_bytes (g_variant_get_data (metadata_checksum_v),
|
||||||
|
metadata_checksum);
|
||||||
|
return ostree_mutable_tree_new_from_checksum (repo, contents_checksum, metadata_checksum);
|
||||||
|
}
|
||||||
|
@ -52,6 +52,12 @@ GType ostree_mutable_tree_get_type (void) G_GNUC_CONST;
|
|||||||
_OSTREE_PUBLIC
|
_OSTREE_PUBLIC
|
||||||
OstreeMutableTree *ostree_mutable_tree_new (void);
|
OstreeMutableTree *ostree_mutable_tree_new (void);
|
||||||
|
|
||||||
|
_OSTREE_PUBLIC
|
||||||
|
OstreeMutableTree *
|
||||||
|
ostree_mutable_tree_new_from_commit (OstreeRepo *repo,
|
||||||
|
const char *rev,
|
||||||
|
GError **error);
|
||||||
|
|
||||||
_OSTREE_PUBLIC
|
_OSTREE_PUBLIC
|
||||||
OstreeMutableTree * ostree_mutable_tree_new_from_checksum (OstreeRepo *repo,
|
OstreeMutableTree * ostree_mutable_tree_new_from_checksum (OstreeRepo *repo,
|
||||||
const char *contents_checksum,
|
const char *contents_checksum,
|
||||||
|
@ -638,20 +638,14 @@ ostree_builtin_commit (int argc, char **argv, OstreeCommandInvocation *invocatio
|
|||||||
|
|
||||||
if (opt_base)
|
if (opt_base)
|
||||||
{
|
{
|
||||||
g_autofree char *base_commit = NULL;
|
mtree = ostree_mutable_tree_new_from_commit (repo, opt_base, error);
|
||||||
g_autoptr(GFile) base_root = NULL;
|
if (!mtree)
|
||||||
if (!ostree_repo_read_commit (repo, opt_base, &base_root, &base_commit, cancellable, error))
|
|
||||||
goto out;
|
goto out;
|
||||||
OstreeRepoFile *rootf = (OstreeRepoFile*) base_root;
|
|
||||||
|
|
||||||
mtree = ostree_mutable_tree_new_from_checksum (repo,
|
|
||||||
ostree_repo_file_tree_get_contents_checksum (rootf),
|
|
||||||
ostree_repo_file_tree_get_metadata_checksum (rootf));
|
|
||||||
|
|
||||||
if (opt_selinux_policy_from_base)
|
if (opt_selinux_policy_from_base)
|
||||||
{
|
{
|
||||||
g_assert (modifier);
|
g_assert (modifier);
|
||||||
if (!ostree_repo_commit_modifier_set_sepolicy_from_commit (modifier, repo, base_commit, cancellable, error))
|
if (!ostree_repo_commit_modifier_set_sepolicy_from_commit (modifier, repo, opt_base, cancellable, error))
|
||||||
goto out;
|
goto out;
|
||||||
/* Don't try to handle it twice */
|
/* Don't try to handle it twice */
|
||||||
opt_selinux_policy_from_base = FALSE;
|
opt_selinux_policy_from_base = FALSE;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user