Skip to content

Commit 95e7c38

Browse files
jacob-kellergitster
authored andcommitted
refspec: make sure stack refspec_item variables are zeroed
A couple of functions that used struct refspec_item did not zero out the structure memory. This can result in unexpected behavior, especially if additional parameters are ever added to refspec_item in the future. Use memset to ensure that unset structure members are zero. It may make sense to convert most of these uses of struct refspec_item to use either struct initializers or refspec_item_init_or_die. However, other similar code uses memset. Converting all of these uses has been left as a future exercise. Signed-off-by: Jacob Keller <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 0becfec commit 95e7c38

File tree

2 files changed

+2
-0
lines changed

2 files changed

+2
-0
lines changed

builtin/remote.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -478,6 +478,7 @@ static int get_head_names(const struct ref *remote_refs, struct ref_states *stat
478478
struct ref *fetch_map = NULL, **fetch_map_tail = &fetch_map;
479479
struct refspec_item refspec;
480480

481+
memset(&refspec, 0, sizeof(refspec));
481482
refspec.force = 0;
482483
refspec.pattern = 1;
483484
refspec.src = refspec.dst = "refs/heads/*";

transport.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -443,6 +443,7 @@ void transport_update_tracking_ref(struct remote *remote, struct ref *ref, int v
443443
if (ref->status != REF_STATUS_OK && ref->status != REF_STATUS_UPTODATE)
444444
return;
445445

446+
memset(&rs, 0, sizeof(rs));
446447
rs.src = ref->name;
447448
rs.dst = NULL;
448449

0 commit comments

Comments
 (0)