summaryrefslogtreecommitdiff
path: root/pack-bitmap.h
diff options
context:
space:
mode:
Diffstat (limited to 'pack-bitmap.h')
-rw-r--r--pack-bitmap.h19
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