summaryrefslogtreecommitdiff
path: root/Documentation/technical/api-xdiff-interface.txt
diff options
context:
space:
mode:
authorLibravatar Jeff King <peff@peff.net>2016-02-19 06:21:19 -0500
committerLibravatar Junio C Hamano <gitster@pobox.com>2016-02-19 09:40:37 -0800
commit320d0b493a259db3b481f985545b244438e6c086 (patch)
tree6b3a53c1c23c520bc1c54595765224827044f2ea /Documentation/technical/api-xdiff-interface.txt
parentreflog_expire_cfg: NUL-terminate pattern field (diff)
downloadtgif-320d0b493a259db3b481f985545b244438e6c086.tar.xz
add helpers for detecting size_t overflow
Performing computations on size_t variables that we feed to xmalloc and friends can be dangerous, as an integer overflow can cause us to allocate a much smaller chunk than we realized. We already have unsigned_add_overflows(), but let's add unsigned_mult_overflows() to that. Furthermore, rather than have each site manually check and die on overflow, we can provide some helpers that will: - promote the arguments to size_t, so that we know we are doing our computation in the same size of integer that will ultimately be fed to xmalloc - check and die on overflow - return the result so that computations can be done in the parameter list of xmalloc. These functions are a lot uglier to use than normal arithmetic operators (you have to do "st_add(foo, bar)" instead of "foo + bar"). To at least limit the damage, we also provide multi-valued versions. So rather than: st_add(st_add(a, b), st_add(c, d)); you can write: st_add4(a, b, c, d); This isn't nearly as elegant as a varargs function, but it's a lot harder to get it wrong. You don't have to remember to add a sentinel value at the end, and the compiler will complain if you get the number of arguments wrong. This patch adds only the numbered variants required to convert the current code base; we can easily add more later if needed. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'Documentation/technical/api-xdiff-interface.txt')
0 files changed, 0 insertions, 0 deletions