line-log: use COPY_ARRAY to fix mis-sized memcpy
commit07f546cda5d818780821a371f011eb253646ddc3
authorVegard Nossum <vegard.nossum@oracle.com>
Sun, 5 Mar 2017 11:44:46 +0000 (5 06:44 -0500)
committerJunio C Hamano <gitster@pobox.com>
Mon, 6 Mar 2017 20:01:02 +0000 (6 12:01 -0800)
tree2619b0a6e9a6724c3b45e53621396c3b6c70833c
parentc3808ca6982b0ad7ee9b87eca9b50b9a24ec08b0
line-log: use COPY_ARRAY to fix mis-sized memcpy

This memcpy meant to get the sizeof a "struct range", not a
"range_set", as the former is what our array holds. Rather
than swap out the types, let's convert this site to
COPY_ARRAY, which avoids the problem entirely (and confirms
that the src and dst types match).

Note for curiosity's sake that this bug doesn't trigger on
I32LP64 systems, but does on ILP32 systems. The mistaken
"struct range_set" has two ints and a pointer. That's 16
bytes on LP64, or 12 on ILP32. The correct "struct range"
type has two longs, which is also 16 on LP64, but only 8 on
ILP32.

Likewise an IL32P64 system would experience the bug.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Vegard Nossum <vegard.nossum@oracle.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
line-log.c