diff options
Diffstat (limited to 'pack-bitmap.h')
-rw-r--r-- | pack-bitmap.h | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/pack-bitmap.h b/pack-bitmap.h index b4510d5ccd..09acf02f7b 100644 --- a/pack-bitmap.h +++ b/pack-bitmap.h @@ -3,6 +3,7 @@ #include "ewah/ewok.h" #include "khash.h" +#include "pack-objects.h" struct bitmap_disk_entry { uint32_t object_pos; @@ -20,10 +21,16 @@ struct bitmap_disk_header { static const char BITMAP_IDX_SIGNATURE[] = {'B', 'I', 'T', 'M'}; +#define NEEDS_BITMAP (1u<<22) + enum pack_bitmap_opts { BITMAP_OPT_FULL_DAG = 1 }; +enum pack_bitmap_flags { + BITMAP_FLAG_REUSE = 0x1 +}; + typedef int (*show_reachable_fn)( const unsigned char *sha1, enum object_type type, @@ -39,5 +46,17 @@ void test_bitmap_walk(struct rev_info *revs); char *pack_bitmap_filename(struct packed_git *p); int prepare_bitmap_walk(struct rev_info *revs); int reuse_partial_packfile_from_bitmap(struct packed_git **packfile, uint32_t *entries, off_t *up_to); +int rebuild_existing_bitmaps(struct packing_data *mapping, khash_sha1 *reused_bitmaps, int show_progress); + +void bitmap_writer_show_progress(int show); +void bitmap_writer_set_checksum(unsigned char *sha1); +void bitmap_writer_build_type_index(struct pack_idx_entry **index, uint32_t index_nr); +void bitmap_writer_reuse_bitmaps(struct packing_data *to_pack); +void bitmap_writer_select_commits(struct commit **indexed_commits, + unsigned int indexed_commits_nr, int max_bitmaps); +void bitmap_writer_build(struct packing_data *to_pack); +void bitmap_writer_finish(struct pack_idx_entry **index, + uint32_t index_nr, + const char *filename); #endif |