| #ifndef OBJECT_STORE_H |
| #define OBJECT_STORE_H |
| |
| #include "oidmap.h" |
| |
| struct alternate_object_database { |
| struct alternate_object_database *next; |
| |
| /* see alt_scratch_buf() */ |
| struct strbuf scratch; |
| size_t base_len; |
| |
| /* |
| * Used to store the results of readdir(3) calls when searching |
| * for unique abbreviated hashes. This cache is never |
| * invalidated, thus it's racy and not necessarily accurate. |
| * That's fine for its purpose; don't use it for tasks requiring |
| * greater accuracy! |
| */ |
| char loose_objects_subdir_seen[256]; |
| struct oid_array loose_objects_cache; |
| |
| /* |
| * Path to the alternative object store. If this is a relative path, |
| * it is relative to the current working directory. |
| */ |
| char path[FLEX_ARRAY]; |
| }; |
| void prepare_alt_odb(struct repository *r); |
| char *compute_alternate_path(const char *path, struct strbuf *err); |
| typedef int alt_odb_fn(struct alternate_object_database *, void *); |
| int foreach_alt_odb(alt_odb_fn, void*); |
| |
| /* |
| * Allocate a "struct alternate_object_database" but do _not_ actually |
| * add it to the list of alternates. |
| */ |
| struct alternate_object_database *alloc_alt_odb(const char *dir); |
| |
| /* |
| * Add the directory to the on-disk alternates file; the new entry will also |
| * take effect in the current process. |
| */ |
| void add_to_alternates_file(const char *dir); |
| |
| /* |
| * Add the directory to the in-memory list of alternates (along with any |
| * recursive alternates it points to), but do not modify the on-disk alternates |
| * file. |
| */ |
| void add_to_alternates_memory(const char *dir); |
| |
| /* |
| * Returns a scratch strbuf pre-filled with the alternate object directory, |
| * including a trailing slash, which can be used to access paths in the |
| * alternate. Always use this over direct access to alt->scratch, as it |
| * cleans up any previous use of the scratch buffer. |
| */ |
| struct strbuf *alt_scratch_buf(struct alternate_object_database *alt); |
| |
| struct packed_git { |
| struct packed_git *next; |
| struct list_head mru; |
| struct pack_window *windows; |
| off_t pack_size; |
| const void *index_data; |
| size_t index_size; |
| uint32_t num_objects; |
| uint32_t num_bad_objects; |
| unsigned char *bad_object_sha1; |
| int index_version; |
| time_t mtime; |
| int pack_fd; |
| unsigned pack_local:1, |
| pack_keep:1, |
| freshened:1, |
| do_not_close:1, |
| pack_promisor:1; |
| unsigned char sha1[20]; |
| struct revindex_entry *revindex; |
| /* something like ".git/objects/pack/xxxxx.pack" */ |
| char pack_name[FLEX_ARRAY]; /* more */ |
| }; |
| |
| struct raw_object_store { |
| /* |
| * Path to the repository's object store. |
| * Cannot be NULL after initialization. |
| */ |
| char *objectdir; |
| |
| /* Path to extra alternate object database if not NULL */ |
| char *alternate_db; |
| |
| struct alternate_object_database *alt_odb_list; |
| struct alternate_object_database **alt_odb_tail; |
| |
| /* |
| * Objects that should be substituted by other objects |
| * (see git-replace(1)). |
| */ |
| struct oidmap *replace_map; |
| |
| /* |
| * private data |
| * |
| * should only be accessed directly by packfile.c |
| */ |
| |
| struct packed_git *packed_git; |
| /* A most-recently-used ordered version of the packed_git list. */ |
| struct list_head packed_git_mru; |
| |
| /* |
| * A fast, rough count of the number of objects in the repository. |
| * These two fields are not meant for direct access. Use |
| * approximate_object_count() instead. |
| */ |
| unsigned long approximate_object_count; |
| unsigned approximate_object_count_valid : 1; |
| |
| /* |
| * Whether packed_git has already been populated with this repository's |
| * packs. |
| */ |
| unsigned packed_git_initialized : 1; |
| }; |
| |
| struct raw_object_store *raw_object_store_new(void); |
| void raw_object_store_clear(struct raw_object_store *o); |
| |
| /* |
| * Put in `buf` the name of the file in the local object database that |
| * would be used to store a loose object with the specified sha1. |
| */ |
| void sha1_file_name(struct repository *r, struct strbuf *buf, const unsigned char *sha1); |
| |
| void *map_sha1_file(struct repository *r, const unsigned char *sha1, unsigned long *size); |
| |
| extern void *read_object_file_extended(const struct object_id *oid, |
| enum object_type *type, |
| unsigned long *size, int lookup_replace); |
| static inline void *read_object_file(const struct object_id *oid, enum object_type *type, unsigned long *size) |
| { |
| return read_object_file_extended(oid, type, size, 1); |
| } |
| |
| /* Read and unpack an object file into memory, write memory to an object file */ |
| int oid_object_info(struct repository *r, const struct object_id *, unsigned long *); |
| |
| extern int hash_object_file(const void *buf, unsigned long len, |
| const char *type, struct object_id *oid); |
| |
| extern int write_object_file(const void *buf, unsigned long len, |
| const char *type, struct object_id *oid); |
| |
| extern int hash_object_file_literally(const void *buf, unsigned long len, |
| const char *type, struct object_id *oid, |
| unsigned flags); |
| |
| extern int pretend_object_file(void *, unsigned long, enum object_type, |
| struct object_id *oid); |
| |
| extern int force_object_loose(const struct object_id *oid, time_t mtime); |
| |
| /* |
| * Open the loose object at path, check its hash, and return the contents, |
| * type, and size. If the object is a blob, then "contents" may return NULL, |
| * to allow streaming of large blobs. |
| * |
| * Returns 0 on success, negative on error (details may be written to stderr). |
| */ |
| int read_loose_object(const char *path, |
| const struct object_id *expected_oid, |
| enum object_type *type, |
| unsigned long *size, |
| void **contents); |
| |
| /* |
| * Convenience for sha1_object_info_extended() with a NULL struct |
| * object_info. OBJECT_INFO_SKIP_CACHED is automatically set; pass |
| * nonzero flags to also set other flags. |
| */ |
| extern int has_sha1_file_with_flags(const unsigned char *sha1, int flags); |
| static inline int has_sha1_file(const unsigned char *sha1) |
| { |
| return has_sha1_file_with_flags(sha1, 0); |
| } |
| |
| /* Same as the above, except for struct object_id. */ |
| extern int has_object_file(const struct object_id *oid); |
| extern int has_object_file_with_flags(const struct object_id *oid, int flags); |
| |
| /* |
| * Return true iff an alternate object database has a loose object |
| * with the specified name. This function does not respect replace |
| * references. |
| */ |
| extern int has_loose_object_nonlocal(const unsigned char *sha1); |
| |
| extern void assert_oid_type(const struct object_id *oid, enum object_type expect); |
| |
| struct object_info { |
| /* Request */ |
| enum object_type *typep; |
| unsigned long *sizep; |
| off_t *disk_sizep; |
| unsigned char *delta_base_sha1; |
| struct strbuf *type_name; |
| void **contentp; |
| |
| /* Response */ |
| enum { |
| OI_CACHED, |
| OI_LOOSE, |
| OI_PACKED, |
| OI_DBCACHED |
| } whence; |
| union { |
| /* |
| * struct { |
| * ... Nothing to expose in this case |
| * } cached; |
| * struct { |
| * ... Nothing to expose in this case |
| * } loose; |
| */ |
| struct { |
| struct packed_git *pack; |
| off_t offset; |
| unsigned int is_delta; |
| } packed; |
| } u; |
| }; |
| |
| /* |
| * Initializer for a "struct object_info" that wants no items. You may |
| * also memset() the memory to all-zeroes. |
| */ |
| #define OBJECT_INFO_INIT {NULL} |
| |
| /* Invoke lookup_replace_object() on the given hash */ |
| #define OBJECT_INFO_LOOKUP_REPLACE 1 |
| /* Allow reading from a loose object file of unknown/bogus type */ |
| #define OBJECT_INFO_ALLOW_UNKNOWN_TYPE 2 |
| /* Do not check cached storage */ |
| #define OBJECT_INFO_SKIP_CACHED 4 |
| /* Do not retry packed storage after checking packed and loose storage */ |
| #define OBJECT_INFO_QUICK 8 |
| /* Do not check loose object */ |
| #define OBJECT_INFO_IGNORE_LOOSE 16 |
| |
| int oid_object_info_extended(struct repository *r, |
| const struct object_id *, |
| struct object_info *, unsigned flags); |
| |
| #endif /* OBJECT_STORE_H */ |