| Top |  |  |  |  | 
| In-memory modifiable filesystem treeIn-memory modifiable filesystem tree — Modifiable filesystem tree | 
| OstreeMutableTree * | ostree_mutable_tree_new () | 
| 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_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.
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
.
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);
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
.