blob: 639bfa5340e783d60575a102b7da51e9184f372a [file] [log] [blame]
Junio C Hamano74986462006-04-23 16:52:20 -07001#ifndef CACHE_TREE_H
2#define CACHE_TREE_H
3
brian m. carlsone0a92802017-05-01 02:28:56 +00004#include "cache.h"
Junio C Hamanob9d37a52009-04-20 03:58:18 -07005#include "tree.h"
Junio C Hamanob65982b2009-05-20 15:57:22 -07006#include "tree-walk.h"
Junio C Hamanob9d37a52009-04-20 03:58:18 -07007
Junio C Hamano74986462006-04-23 16:52:20 -07008struct cache_tree;
9struct cache_tree_sub {
10 struct cache_tree *cache_tree;
Nguyễn Thái Ngọc Duy3cf773e2012-12-16 11:15:27 +070011 int count; /* internally used by update_one() */
Junio C Hamano74986462006-04-23 16:52:20 -070012 int namelen;
13 int used;
14 char name[FLEX_ARRAY];
15};
16
17struct cache_tree {
18 int entry_count; /* negative means "invalid" */
brian m. carlsone0a92802017-05-01 02:28:56 +000019 struct object_id oid;
Junio C Hamano74986462006-04-23 16:52:20 -070020 int subtree_nr;
21 int subtree_alloc;
22 struct cache_tree_sub **down;
23};
24
25struct cache_tree *cache_tree(void);
Junio C Hamanobad68ec2006-04-24 21:18:58 -070026void cache_tree_free(struct cache_tree **);
Nguyễn Thái Ngọc Duya5400ef2014-06-13 19:19:31 +070027void cache_tree_invalidate_path(struct index_state *, const char *);
Junio C Hamano7927a552006-04-27 01:33:07 -070028struct cache_tree_sub *cache_tree_sub(struct cache_tree *, const char *);
Junio C Hamano74986462006-04-23 16:52:20 -070029
Pierre Habouzit1dffb8f2007-09-25 10:22:44 +020030void cache_tree_write(struct strbuf *, struct cache_tree *root);
Junio C Hamanobad68ec2006-04-24 21:18:58 -070031struct cache_tree *cache_tree_read(const char *buffer, unsigned long size);
Junio C Hamano74986462006-04-23 16:52:20 -070032
Junio C Hamanobad68ec2006-04-24 21:18:58 -070033int cache_tree_fully_valid(struct cache_tree *);
Nguyễn Thái Ngọc Duyd0cfc3e2014-06-13 19:19:32 +070034int cache_tree_update(struct index_state *, int);
Nguyễn Thái Ngọc Duyc207e9e2018-11-10 06:49:02 +010035void cache_tree_verify(struct repository *, struct index_state *);
Thomas Rast996277c2011-12-06 18:43:37 +010036
Elijah Newren724dd762019-08-17 11:41:32 -070037/* bitmasks to write_index_as_tree flags */
Junio C Hamanod11b8d32009-05-20 11:04:35 -070038#define WRITE_TREE_MISSING_OK 1
39#define WRITE_TREE_IGNORE_CACHE_TREE 2
Nguyễn Thái Ngọc Duye859c692012-01-16 09:36:46 +070040#define WRITE_TREE_DRY_RUN 4
41#define WRITE_TREE_SILENT 8
David Turneraecf5672014-07-05 21:06:56 -070042#define WRITE_TREE_REPAIR 16
Junio C Hamanod11b8d32009-05-20 11:04:35 -070043
44/* error return codes */
Junio C Hamano45525bd2008-01-10 22:49:35 -080045#define WRITE_TREE_UNREADABLE_INDEX (-1)
46#define WRITE_TREE_UNMERGED_INDEX (-2)
47#define WRITE_TREE_PREFIX_ERROR (-3)
48
Elijah Newren724dd762019-08-17 11:41:32 -070049struct tree* write_in_core_index_as_tree(struct repository *repo);
brian m. carlsonfc5cb992018-03-12 02:27:23 +000050int write_index_as_tree(struct object_id *oid, struct index_state *index_state, const char *index_path, int flags, const char *prefix);
Nguyễn Thái Ngọc Duyc207e9e2018-11-10 06:49:02 +010051void prime_cache_tree(struct repository *, struct index_state *, struct tree *);
Junio C Hamanob9d37a52009-04-20 03:58:18 -070052
Nguyễn Thái Ngọc Duy9ab34f92018-06-30 11:20:23 +020053int cache_tree_matches_traversal(struct cache_tree *, struct name_entry *ent, struct traverse_info *info);
Junio C Hamanob65982b2009-05-20 15:57:22 -070054
Nguyễn Thái Ngọc Duyf8adbec2019-01-24 15:29:12 +070055#ifdef USE_THE_INDEX_COMPATIBILITY_MACROS
Nguyễn Thái Ngọc Duy07096c92018-08-13 18:14:19 +020056static inline int write_cache_as_tree(struct object_id *oid, int flags, const char *prefix)
57{
58 return write_index_as_tree(oid, &the_index, get_index_file(), flags, prefix);
59}
60
61static inline int update_main_cache_tree(int flags)
62{
63 if (!the_index.cache_tree)
64 the_index.cache_tree = cache_tree();
65 return cache_tree_update(&the_index, flags);
66}
67#endif
68
Junio C Hamano74986462006-04-23 16:52:20 -070069#endif