| Top |  |  |  |  | 
| In-memory modifiable filesystem treeIn-memory modifiable filesystem tree — Modifiable filesystem tree | 
| OstreeMutableTree * | ostree_mutable_tree_new () | 
| OstreeMutableTree * | ostree_mutable_tree_new_from_commit () | 
| OstreeMutableTree * | ostree_mutable_tree_new_from_checksum () | 
| gboolean | ostree_mutable_tree_check_error () | 
| void | ostree_mutable_tree_set_metadata_checksum () | 
| const char * | ostree_mutable_tree_get_metadata_checksum () | 
| void | ostree_mutable_tree_set_contents_checksum () | 
| const char * | ostree_mutable_tree_get_contents_checksum () | 
| gboolean | ostree_mutable_tree_replace_file () | 
| gboolean | ostree_mutable_tree_remove () | 
| gboolean | ostree_mutable_tree_ensure_dir () | 
| gboolean | ostree_mutable_tree_lookup () | 
| gboolean | ostree_mutable_tree_ensure_parent_dirs () | 
| gboolean | ostree_mutable_tree_walk () | 
| GHashTable * | ostree_mutable_tree_get_subdirs () | 
| GHashTable * | ostree_mutable_tree_get_files () | 
| gboolean | ostree_mutable_tree_fill_empty_from_dirtree () | 
In order to commit content into an OstreeRepo, it must first be imported into an OstreeMutableTree. There are several high level APIs to create an initiable OstreeMutableTree from a physical filesystem directory, but they may also be computed programmatically.
OstreeMutableTree * ostree_mutable_tree_new_from_commit (OstreeRepo *repo,const char *rev,GError **error);
Creates a new OstreeMutableTree with the contents taken from the given commit. The data will be loaded from the repo lazily as needed.
| repo | The repo which contains the objects refered by the checksums. | |
| rev | ref or SHA-256 checksum | 
Since: 2021.5
OstreeMutableTree * ostree_mutable_tree_new_from_checksum (OstreeRepo *repo,const char *contents_checksum,const char *metadata_checksum);
Creates a new OstreeMutableTree with the contents taken from the given repo and checksums. The data will be loaded from the repo lazily as needed.
| repo | The repo which contains the objects refered by the checksums. | |
| contents_checksum | dirtree checksum | |
| metadata_checksum | dirmeta checksum | 
Since: 2018.7
gboolean ostree_mutable_tree_check_error (OstreeMutableTree *self,GError **error);
In some cases, a tree may be in a "lazy" state that loads data in the background; if an error occurred during a non-throwing API call, it will have been cached. This function checks for a cached error. The tree remains in error state.
Since: 2018.7
void ostree_mutable_tree_set_metadata_checksum (OstreeMutableTree *self,const char *checksum);
const char *
ostree_mutable_tree_get_metadata_checksum
                               (OstreeMutableTree *self);
void ostree_mutable_tree_set_contents_checksum (OstreeMutableTree *self,const char *checksum);
const char *
ostree_mutable_tree_get_contents_checksum
                               (OstreeMutableTree *self);
gboolean ostree_mutable_tree_replace_file (OstreeMutableTree *self,const char *name,const char *checksum,GError **error);
gboolean ostree_mutable_tree_remove (OstreeMutableTree *self,const char *name,gboolean allow_noent,GError **error);
Remove the file or subdirectory named name
 from the mutable tree self
.
| self | Tree | |
| name | Name of file or subdirectory to remove | |
| allow_noent | If  | |
| error | a GError | 
Since: 2018.9
gboolean ostree_mutable_tree_ensure_dir (OstreeMutableTree *self,const char *name,OstreeMutableTree **out_subdir,GError **error);
Returns the subdirectory of self with filename name
, creating an empty one
it if it doesn't exist.
| self | Tree | |
| name | Name of subdirectory of self to retrieve/creates | |
| out_subdir | the subdirectory. | [out][transfer full] | 
| error | a GError | 
gboolean ostree_mutable_tree_lookup (OstreeMutableTree *self,const char *name,char **out_file_checksum,OstreeMutableTree **out_subdir,GError **error);
| self | Tree | |
| name | name | |
| out_file_checksum | checksum. | [out][transfer full] | 
| out_subdir | subdirectory. | [out][transfer full] | 
| error | a GError | 
gboolean ostree_mutable_tree_ensure_parent_dirs (OstreeMutableTree *self,GPtrArray *split_path,const char *metadata_checksum,OstreeMutableTree **out_parent,GError **error);
Create all parent trees necessary for the given split_path
 to
exist.
| self | Tree | |
| split_path | File path components. | [element-type utf8] | 
| metadata_checksum | SHA256 checksum for metadata | |
| out_parent | The parent tree. | [out][transfer full] | 
| error | a GError | 
gboolean ostree_mutable_tree_walk (OstreeMutableTree *self,GPtrArray *split_path,guint start,OstreeMutableTree **out_subdir,GError **error);
Traverse start
 number of elements starting from split_path
; the
child will be returned in out_subdir
.
| self | Tree | |
| split_path | Split pathname. | [element-type utf8] | 
| start | Descend from this number of elements in  | |
| out_subdir | Target parent. | [out][transfer full] | 
| error | Error | 
GHashTable *
ostree_mutable_tree_get_subdirs (OstreeMutableTree *self);
GHashTable *
ostree_mutable_tree_get_files (OstreeMutableTree *self);
gboolean ostree_mutable_tree_fill_empty_from_dirtree (OstreeMutableTree *self,OstreeRepo *repo,const char *contents_checksum,const char *metadata_checksum);
Merges self
 with the tree given by contents_checksum
 and
metadata_checksum
, but only if it's possible without writing new objects to
the repo
.  We can do this if either self
 is empty, the tree given by
contents_checksum
 is empty or if both trees already have the same
contents_checksum
.
 TRUE
if merge was successful, FALSE
if it was not possible.
This function enables optimisations when composing trees. The provided checksums are not loaded or checked when this function is called. Instead the contents will be loaded only when needed.
Since: 2018.7