diff options
author | Jonathan Lebon <jlebon@redhat.com> | 2017-09-28 19:08:06 +0000 |
---|---|---|
committer | Atomic Bot <atomic-devel@projectatomic.io> | 2017-09-30 00:05:07 +0000 |
commit | 8fe45362578a43260876134d6547ebd0bb2485c3 (patch) | |
tree | e91911b8e084a18a43b55d5420dcae20d6fba955 /src/libostree/ostree-core-private.h | |
parent | e4a90caeb9d210344e537e2a9b8016dc0e01e15a (diff) | |
download | ostree-8fe45362578a43260876134d6547ebd0bb2485c3.tar.gz |
lib/commit: don't query devino cache for modified files
We can't use the cache if the file we want to commit has been modified
by the client through the file info or xattr modifiers. We would
prematurely look into the cache in `write_dfd_iter_to_mtree_internal`,
regardless of whether any filtering applied.
We remove that path there, and make sure that we only use the cache if
there were no modifications. We rename the `get_modified_xattrs` to
`get_final_xattrs` to reflect the fact that the xattrs may not be
modified.
One tricky bit that took me some time was that we now need to store the
st_dev & st_ino values in the GFileInfo because the cache lookup relies
on it. I'm guessing we regressed on this at some point.
This patch does slightly change the semantics of the xattr callback.
Previously, returning NULL from the cb meant no xattrs at all. Now, it
means to default to the on-disk state. We might want to consider putting
that behind a flag instead. Though it seems like a more useful behaviour
so that callers can only override the files they want to without losing
original on-disk state (and if they don't want that, just return an
empty GVariant).
Closes: #1165
Closes: #1170
Approved by: cgwalters
Diffstat (limited to 'src/libostree/ostree-core-private.h')
-rw-r--r-- | src/libostree/ostree-core-private.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/libostree/ostree-core-private.h b/src/libostree/ostree-core-private.h index 783eacd3..0658a0cb 100644 --- a/src/libostree/ostree-core-private.h +++ b/src/libostree/ostree-core-private.h @@ -89,6 +89,7 @@ _ostree_make_temporary_symlink_at (int tmp_dirfd, GError **error); GFileInfo * _ostree_stbuf_to_gfileinfo (const struct stat *stbuf); +gboolean _ostree_gfileinfo_equal (GFileInfo *a, GFileInfo *b); GFileInfo * _ostree_mode_uidgid_to_gfileinfo (mode_t mode, uid_t uid, gid_t gid); static inline void |