Merge branch 'jk/misc-uninitialized-fixes'
Various fixes to codepaths gcc 9 had trouble following dataflow. * jk/misc-uninitialized-fixes: pack-objects: drop packlist index_pos optimization test-read-cache: drop namelen variable diff-delta: set size out-parameter to 0 for NULL delta bulk-checkin: zero-initialize hashfile_checkpoint pack-objects: use object_id in packlist_alloc() git-am: handle missing "author" when parsing commit
This commit is contained in:
commit
d8ce144e11
@ -1272,7 +1272,9 @@ static void get_commit_info(struct am_state *state, struct commit *commit)
|
|||||||
buffer = logmsg_reencode(commit, NULL, get_commit_output_encoding());
|
buffer = logmsg_reencode(commit, NULL, get_commit_output_encoding());
|
||||||
|
|
||||||
ident_line = find_commit_header(buffer, "author", &ident_len);
|
ident_line = find_commit_header(buffer, "author", &ident_len);
|
||||||
|
if (!ident_line)
|
||||||
|
die(_("missing author line in commit %s"),
|
||||||
|
oid_to_hex(&commit->object.oid));
|
||||||
if (split_ident_line(&id, ident_line, ident_len) < 0)
|
if (split_ident_line(&id, ident_line, ident_len) < 0)
|
||||||
die(_("invalid ident line: %.*s"), (int)ident_len, ident_line);
|
die(_("invalid ident line: %.*s"), (int)ident_len, ident_line);
|
||||||
|
|
||||||
|
@ -610,12 +610,12 @@ static int mark_tagged(const char *path, const struct object_id *oid, int flag,
|
|||||||
void *cb_data)
|
void *cb_data)
|
||||||
{
|
{
|
||||||
struct object_id peeled;
|
struct object_id peeled;
|
||||||
struct object_entry *entry = packlist_find(&to_pack, oid, NULL);
|
struct object_entry *entry = packlist_find(&to_pack, oid);
|
||||||
|
|
||||||
if (entry)
|
if (entry)
|
||||||
entry->tagged = 1;
|
entry->tagged = 1;
|
||||||
if (!peel_ref(path, &peeled)) {
|
if (!peel_ref(path, &peeled)) {
|
||||||
entry = packlist_find(&to_pack, &peeled, NULL);
|
entry = packlist_find(&to_pack, &peeled);
|
||||||
if (entry)
|
if (entry)
|
||||||
entry->tagged = 1;
|
entry->tagged = 1;
|
||||||
}
|
}
|
||||||
@ -996,12 +996,11 @@ static int no_try_delta(const char *path)
|
|||||||
* few lines later when we want to add the new entry.
|
* few lines later when we want to add the new entry.
|
||||||
*/
|
*/
|
||||||
static int have_duplicate_entry(const struct object_id *oid,
|
static int have_duplicate_entry(const struct object_id *oid,
|
||||||
int exclude,
|
int exclude)
|
||||||
uint32_t *index_pos)
|
|
||||||
{
|
{
|
||||||
struct object_entry *entry;
|
struct object_entry *entry;
|
||||||
|
|
||||||
entry = packlist_find(&to_pack, oid, index_pos);
|
entry = packlist_find(&to_pack, oid);
|
||||||
if (!entry)
|
if (!entry)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -1141,13 +1140,12 @@ static void create_object_entry(const struct object_id *oid,
|
|||||||
uint32_t hash,
|
uint32_t hash,
|
||||||
int exclude,
|
int exclude,
|
||||||
int no_try_delta,
|
int no_try_delta,
|
||||||
uint32_t index_pos,
|
|
||||||
struct packed_git *found_pack,
|
struct packed_git *found_pack,
|
||||||
off_t found_offset)
|
off_t found_offset)
|
||||||
{
|
{
|
||||||
struct object_entry *entry;
|
struct object_entry *entry;
|
||||||
|
|
||||||
entry = packlist_alloc(&to_pack, oid->hash, index_pos);
|
entry = packlist_alloc(&to_pack, oid);
|
||||||
entry->hash = hash;
|
entry->hash = hash;
|
||||||
oe_set_type(entry, type);
|
oe_set_type(entry, type);
|
||||||
if (exclude)
|
if (exclude)
|
||||||
@ -1171,11 +1169,10 @@ static int add_object_entry(const struct object_id *oid, enum object_type type,
|
|||||||
{
|
{
|
||||||
struct packed_git *found_pack = NULL;
|
struct packed_git *found_pack = NULL;
|
||||||
off_t found_offset = 0;
|
off_t found_offset = 0;
|
||||||
uint32_t index_pos;
|
|
||||||
|
|
||||||
display_progress(progress_state, ++nr_seen);
|
display_progress(progress_state, ++nr_seen);
|
||||||
|
|
||||||
if (have_duplicate_entry(oid, exclude, &index_pos))
|
if (have_duplicate_entry(oid, exclude))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!want_object_in_pack(oid, exclude, &found_pack, &found_offset)) {
|
if (!want_object_in_pack(oid, exclude, &found_pack, &found_offset)) {
|
||||||
@ -1190,7 +1187,7 @@ static int add_object_entry(const struct object_id *oid, enum object_type type,
|
|||||||
|
|
||||||
create_object_entry(oid, type, pack_name_hash(name),
|
create_object_entry(oid, type, pack_name_hash(name),
|
||||||
exclude, name && no_try_delta(name),
|
exclude, name && no_try_delta(name),
|
||||||
index_pos, found_pack, found_offset);
|
found_pack, found_offset);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1199,17 +1196,15 @@ static int add_object_entry_from_bitmap(const struct object_id *oid,
|
|||||||
int flags, uint32_t name_hash,
|
int flags, uint32_t name_hash,
|
||||||
struct packed_git *pack, off_t offset)
|
struct packed_git *pack, off_t offset)
|
||||||
{
|
{
|
||||||
uint32_t index_pos;
|
|
||||||
|
|
||||||
display_progress(progress_state, ++nr_seen);
|
display_progress(progress_state, ++nr_seen);
|
||||||
|
|
||||||
if (have_duplicate_entry(oid, 0, &index_pos))
|
if (have_duplicate_entry(oid, 0))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!want_object_in_pack(oid, 0, &pack, &offset))
|
if (!want_object_in_pack(oid, 0, &pack, &offset))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
create_object_entry(oid, type, name_hash, 0, 0, index_pos, pack, offset);
|
create_object_entry(oid, type, name_hash, 0, 0, pack, offset);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1507,7 +1502,7 @@ static int can_reuse_delta(const unsigned char *base_sha1,
|
|||||||
* First see if we're already sending the base (or it's explicitly in
|
* First see if we're already sending the base (or it's explicitly in
|
||||||
* our "excluded" list).
|
* our "excluded" list).
|
||||||
*/
|
*/
|
||||||
base = packlist_find(&to_pack, &base_oid, NULL);
|
base = packlist_find(&to_pack, &base_oid);
|
||||||
if (base) {
|
if (base) {
|
||||||
if (!in_same_island(&delta->idx.oid, &base->idx.oid))
|
if (!in_same_island(&delta->idx.oid, &base->idx.oid))
|
||||||
return 0;
|
return 0;
|
||||||
@ -2568,7 +2563,7 @@ static void add_tag_chain(const struct object_id *oid)
|
|||||||
* it was included via bitmaps, we would not have parsed it
|
* it was included via bitmaps, we would not have parsed it
|
||||||
* previously).
|
* previously).
|
||||||
*/
|
*/
|
||||||
if (packlist_find(&to_pack, oid, NULL))
|
if (packlist_find(&to_pack, oid))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
tag = lookup_tag(the_repository, oid);
|
tag = lookup_tag(the_repository, oid);
|
||||||
@ -2592,7 +2587,7 @@ static int add_ref_tag(const char *path, const struct object_id *oid, int flag,
|
|||||||
|
|
||||||
if (starts_with(path, "refs/tags/") && /* is a tag? */
|
if (starts_with(path, "refs/tags/") && /* is a tag? */
|
||||||
!peel_ref(path, &peeled) && /* peelable? */
|
!peel_ref(path, &peeled) && /* peelable? */
|
||||||
packlist_find(&to_pack, &peeled, NULL)) /* object packed? */
|
packlist_find(&to_pack, &peeled)) /* object packed? */
|
||||||
add_tag_chain(oid);
|
add_tag_chain(oid);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -2788,7 +2783,7 @@ static void show_object(struct object *obj, const char *name, void *data)
|
|||||||
for (p = strchr(name, '/'); p; p = strchr(p + 1, '/'))
|
for (p = strchr(name, '/'); p; p = strchr(p + 1, '/'))
|
||||||
depth++;
|
depth++;
|
||||||
|
|
||||||
ent = packlist_find(&to_pack, &obj->oid, NULL);
|
ent = packlist_find(&to_pack, &obj->oid);
|
||||||
if (ent && depth > oe_tree_depth(&to_pack, ent))
|
if (ent && depth > oe_tree_depth(&to_pack, ent))
|
||||||
oe_set_tree_depth(&to_pack, ent, depth);
|
oe_set_tree_depth(&to_pack, ent, depth);
|
||||||
}
|
}
|
||||||
@ -3019,7 +3014,7 @@ static void loosen_unused_packed_objects(void)
|
|||||||
|
|
||||||
for (i = 0; i < p->num_objects; i++) {
|
for (i = 0; i < p->num_objects; i++) {
|
||||||
nth_packed_object_oid(&oid, p, i);
|
nth_packed_object_oid(&oid, p, i);
|
||||||
if (!packlist_find(&to_pack, &oid, NULL) &&
|
if (!packlist_find(&to_pack, &oid) &&
|
||||||
!has_sha1_pack_kept_or_nonlocal(&oid) &&
|
!has_sha1_pack_kept_or_nonlocal(&oid) &&
|
||||||
!loosened_object_can_be_discarded(&oid, p->mtime))
|
!loosened_object_can_be_discarded(&oid, p->mtime))
|
||||||
if (force_object_loose(&oid, p->mtime))
|
if (force_object_loose(&oid, p->mtime))
|
||||||
|
@ -197,7 +197,7 @@ static int deflate_to_pack(struct bulk_checkin_state *state,
|
|||||||
git_hash_ctx ctx;
|
git_hash_ctx ctx;
|
||||||
unsigned char obuf[16384];
|
unsigned char obuf[16384];
|
||||||
unsigned header_len;
|
unsigned header_len;
|
||||||
struct hashfile_checkpoint checkpoint;
|
struct hashfile_checkpoint checkpoint = {0};
|
||||||
struct pack_idx_entry *idx = NULL;
|
struct pack_idx_entry *idx = NULL;
|
||||||
|
|
||||||
seekback = lseek(fd, 0, SEEK_CUR);
|
seekback = lseek(fd, 0, SEEK_CUR);
|
||||||
|
@ -326,6 +326,8 @@ create_delta(const struct delta_index *index,
|
|||||||
const unsigned char *ref_data, *ref_top, *data, *top;
|
const unsigned char *ref_data, *ref_top, *data, *top;
|
||||||
unsigned char *out;
|
unsigned char *out;
|
||||||
|
|
||||||
|
*delta_size = 0;
|
||||||
|
|
||||||
if (!trg_buf || !trg_size)
|
if (!trg_buf || !trg_size)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
@ -144,7 +144,7 @@ static inline void reset_all_seen(void)
|
|||||||
|
|
||||||
static uint32_t find_object_pos(const struct object_id *oid)
|
static uint32_t find_object_pos(const struct object_id *oid)
|
||||||
{
|
{
|
||||||
struct object_entry *entry = packlist_find(writer.to_pack, oid, NULL);
|
struct object_entry *entry = packlist_find(writer.to_pack, oid);
|
||||||
|
|
||||||
if (!entry) {
|
if (!entry) {
|
||||||
die("Failed to write bitmap index. Packfile doesn't have full closure "
|
die("Failed to write bitmap index. Packfile doesn't have full closure "
|
||||||
|
@ -1061,7 +1061,7 @@ int rebuild_existing_bitmaps(struct bitmap_index *bitmap_git,
|
|||||||
|
|
||||||
entry = &bitmap_git->pack->revindex[i];
|
entry = &bitmap_git->pack->revindex[i];
|
||||||
nth_packed_object_oid(&oid, bitmap_git->pack, entry->nr);
|
nth_packed_object_oid(&oid, bitmap_git->pack, entry->nr);
|
||||||
oe = packlist_find(mapping, &oid, NULL);
|
oe = packlist_find(mapping, &oid);
|
||||||
|
|
||||||
if (oe)
|
if (oe)
|
||||||
reposition[i] = oe_in_pack_pos(mapping, oe) + 1;
|
reposition[i] = oe_in_pack_pos(mapping, oe) + 1;
|
||||||
|
@ -68,8 +68,7 @@ static void rehash_objects(struct packing_data *pdata)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct object_entry *packlist_find(struct packing_data *pdata,
|
struct object_entry *packlist_find(struct packing_data *pdata,
|
||||||
const struct object_id *oid,
|
const struct object_id *oid)
|
||||||
uint32_t *index_pos)
|
|
||||||
{
|
{
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
int found;
|
int found;
|
||||||
@ -79,9 +78,6 @@ struct object_entry *packlist_find(struct packing_data *pdata,
|
|||||||
|
|
||||||
i = locate_object_entry_hash(pdata, oid, &found);
|
i = locate_object_entry_hash(pdata, oid, &found);
|
||||||
|
|
||||||
if (index_pos)
|
|
||||||
*index_pos = i;
|
|
||||||
|
|
||||||
if (!found)
|
if (!found)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -153,8 +149,7 @@ void prepare_packing_data(struct repository *r, struct packing_data *pdata)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct object_entry *packlist_alloc(struct packing_data *pdata,
|
struct object_entry *packlist_alloc(struct packing_data *pdata,
|
||||||
const unsigned char *sha1,
|
const struct object_id *oid)
|
||||||
uint32_t index_pos)
|
|
||||||
{
|
{
|
||||||
struct object_entry *new_entry;
|
struct object_entry *new_entry;
|
||||||
|
|
||||||
@ -177,12 +172,19 @@ struct object_entry *packlist_alloc(struct packing_data *pdata,
|
|||||||
new_entry = pdata->objects + pdata->nr_objects++;
|
new_entry = pdata->objects + pdata->nr_objects++;
|
||||||
|
|
||||||
memset(new_entry, 0, sizeof(*new_entry));
|
memset(new_entry, 0, sizeof(*new_entry));
|
||||||
hashcpy(new_entry->idx.oid.hash, sha1);
|
oidcpy(&new_entry->idx.oid, oid);
|
||||||
|
|
||||||
if (pdata->index_size * 3 <= pdata->nr_objects * 4)
|
if (pdata->index_size * 3 <= pdata->nr_objects * 4)
|
||||||
rehash_objects(pdata);
|
rehash_objects(pdata);
|
||||||
else
|
else {
|
||||||
pdata->index[index_pos] = pdata->nr_objects;
|
int found;
|
||||||
|
uint32_t pos = locate_object_entry_hash(pdata,
|
||||||
|
&new_entry->idx.oid,
|
||||||
|
&found);
|
||||||
|
if (found)
|
||||||
|
BUG("duplicate object inserted into hash");
|
||||||
|
pdata->index[pos] = pdata->nr_objects;
|
||||||
|
}
|
||||||
|
|
||||||
if (pdata->in_pack)
|
if (pdata->in_pack)
|
||||||
pdata->in_pack[pdata->nr_objects - 1] = NULL;
|
pdata->in_pack[pdata->nr_objects - 1] = NULL;
|
||||||
|
@ -183,12 +183,10 @@ static inline void packing_data_unlock(struct packing_data *pdata)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct object_entry *packlist_alloc(struct packing_data *pdata,
|
struct object_entry *packlist_alloc(struct packing_data *pdata,
|
||||||
const unsigned char *sha1,
|
const struct object_id *oid);
|
||||||
uint32_t index_pos);
|
|
||||||
|
|
||||||
struct object_entry *packlist_find(struct packing_data *pdata,
|
struct object_entry *packlist_find(struct packing_data *pdata,
|
||||||
const struct object_id *oid,
|
const struct object_id *oid);
|
||||||
uint32_t *index_pos);
|
|
||||||
|
|
||||||
static inline uint32_t pack_name_hash(const char *name)
|
static inline uint32_t pack_name_hash(const char *name)
|
||||||
{
|
{
|
||||||
|
@ -4,11 +4,10 @@
|
|||||||
|
|
||||||
int cmd__read_cache(int argc, const char **argv)
|
int cmd__read_cache(int argc, const char **argv)
|
||||||
{
|
{
|
||||||
int i, cnt = 1, namelen;
|
int i, cnt = 1;
|
||||||
const char *name = NULL;
|
const char *name = NULL;
|
||||||
|
|
||||||
if (argc > 1 && skip_prefix(argv[1], "--print-and-refresh=", &name)) {
|
if (argc > 1 && skip_prefix(argv[1], "--print-and-refresh=", &name)) {
|
||||||
namelen = strlen(name);
|
|
||||||
argc--;
|
argc--;
|
||||||
argv++;
|
argv++;
|
||||||
}
|
}
|
||||||
@ -24,7 +23,7 @@ int cmd__read_cache(int argc, const char **argv)
|
|||||||
|
|
||||||
refresh_index(&the_index, REFRESH_QUIET,
|
refresh_index(&the_index, REFRESH_QUIET,
|
||||||
NULL, NULL, NULL);
|
NULL, NULL, NULL);
|
||||||
pos = index_name_pos(&the_index, name, namelen);
|
pos = index_name_pos(&the_index, name, strlen(name));
|
||||||
if (pos < 0)
|
if (pos < 0)
|
||||||
die("%s not in index", name);
|
die("%s not in index", name);
|
||||||
printf("%s is%s up to date\n", name,
|
printf("%s is%s up to date\n", name,
|
||||||
|
Loading…
Reference in New Issue
Block a user