Skip to content

Commit 3da492f

Browse files
stefanbellergitster
authored andcommitted
patch-ids.c: use hashmap correctly
As alluded to in the previous patch, the code in patch-ids.c is using the hashmaps API wrong. Luckily we do not have a bug, as all hashmap functionality that we use here (hashmap_get) passes through the keydata. If hashmap_get_next were to be used, a bug would occur as that passes NULL for the key_data. So instead use the hashmap API correctly and provide the caller required data in the compare function via the first argument that always gets passed and was setup via the hashmap_init function. Signed-off-by: Stefan Beller <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 7663cdc commit 3da492f

File tree

1 file changed

+4
-4
lines changed

1 file changed

+4
-4
lines changed

patch-ids.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -35,10 +35,10 @@ int commit_patch_id(struct commit *commit, struct diff_options *options,
3535
* the side of safety. The actual value being negative does not have
3636
* any significance; only that it is non-zero matters.
3737
*/
38-
static int patch_id_cmp(const void *unused_cmp_data,
38+
static int patch_id_cmp(struct diff_options *opt,
3939
struct patch_id *a,
4040
struct patch_id *b,
41-
struct diff_options *opt)
41+
const void *unused_keydata)
4242
{
4343
if (is_null_oid(&a->patch_id) &&
4444
commit_patch_id(a->commit, opt, &a->patch_id, 0))
@@ -59,7 +59,7 @@ int init_patch_ids(struct patch_ids *ids)
5959
DIFF_OPT_SET(&ids->diffopts, RECURSIVE);
6060
diff_setup_done(&ids->diffopts);
6161
hashmap_init(&ids->patches, (hashmap_cmp_fn)patch_id_cmp,
62-
NULL, 256);
62+
&ids->diffopts, 256);
6363
return 0;
6464
}
6565

@@ -95,7 +95,7 @@ struct patch_id *has_commit_patch_id(struct commit *commit,
9595
if (init_patch_id_entry(&patch, commit, ids))
9696
return NULL;
9797

98-
return hashmap_get(&ids->patches, &patch, &ids->diffopts);
98+
return hashmap_get(&ids->patches, &patch, NULL);
9999
}
100100

101101
struct patch_id *add_commit_patch_id(struct commit *commit,

0 commit comments

Comments
 (0)