summaryrefslogtreecommitdiff
path: root/t/t4013/diff.diff_--no-index_--name-status_--_dir2_dir
diff options
context:
space:
mode:
authorLibravatar Elia Pinto <gitter.spiros@gmail.com>2015-04-30 14:44:14 +0200
committerLibravatar Junio C Hamano <gitster@pobox.com>2015-05-05 15:26:48 -0700
commit89c855ed3cbe64bea93ea081d0e96077e9ee8517 (patch)
tree72ce4c2b43a79f93f955ceafd7cf8f4ebdab6fb7 /t/t4013/diff.diff_--no-index_--name-status_--_dir2_dir
parentGit 2.2.2 (diff)
downloadtgif-89c855ed3cbe64bea93ea081d0e96077e9ee8517.tar.xz
git-compat-util.h: implement a different ARRAY_SIZE macro for for safely deriving the size of array
To get number of elements in an array git use the ARRAY_SIZE macro defined as: #define ARRAY_SIZE(x) (sizeof(x)/sizeof((x)[0])) The problem with it is a possibility of mistakenly passing to it a pointer instead an array. The ARRAY_SIZE macro as conventionally defined does not provide good type-safety and the open-coded approach is more fragile, more verbose and provides no improvement in type-safety. Use instead a different but compatible ARRAY_SIZE() macro, which will also break compile if you try to use it on a pointer. This implemention revert to the original code if the compiler doesn't know the typeof and __builtin_types_compatible_p GCC extensions. This can ensure our code is robust to changes, without needing a gratuitous macro or constant. A similar ARRAY_SIZE implementation also exists in the linux kernel. Credits to Rusty Russell and his ccan library. Signed-off-by: Elia Pinto <gitter.spiros@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t4013/diff.diff_--no-index_--name-status_--_dir2_dir')
0 files changed, 0 insertions, 0 deletions