git-compat-util: move alloc macros to git-compat-util.h

alloc_nr, ALLOC_GROW, and ALLOC_GROW_BY are commonly used macros for
dynamic array allocation. Moving these macros to git-compat-util.h with
the other alloc macros focuses alloc.[ch] to allocation for Git objects
and additionally allows us to remove inclusions to alloc.h from files
that solely used the above macros.

Signed-off-by: Calvin Wan <calvinwan@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Calvin Wan 2023-07-05 17:09:24 +00:00 committed by Junio C Hamano
parent da9502ff4d
commit 91c080dff5
88 changed files with 75 additions and 161 deletions

View file

@ -1,7 +1,6 @@
#include "git-compat-util.h"
#include "add-interactive.h"
#include "advice.h"
#include "alloc.h"
#include "editor.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "alias.h"
#include "alloc.h"
#include "config.h"
#include "gettext.h"
#include "strbuf.h"

75
alloc.h
View file

@ -17,79 +17,4 @@ void *alloc_object_node(struct repository *r);
struct alloc_state *allocate_alloc_state(void);
void clear_alloc_state(struct alloc_state *s);
#define alloc_nr(x) (((x)+16)*3/2)
/**
* Dynamically growing an array using realloc() is error prone and boring.
*
* Define your array with:
*
* - a pointer (`item`) that points at the array, initialized to `NULL`
* (although please name the variable based on its contents, not on its
* type);
*
* - an integer variable (`alloc`) that keeps track of how big the current
* allocation is, initialized to `0`;
*
* - another integer variable (`nr`) to keep track of how many elements the
* array currently has, initialized to `0`.
*
* Then before adding `n`th element to the item, call `ALLOC_GROW(item, n,
* alloc)`. This ensures that the array can hold at least `n` elements by
* calling `realloc(3)` and adjusting `alloc` variable.
*
* ------------
* sometype *item;
* size_t nr;
* size_t alloc
*
* for (i = 0; i < nr; i++)
* if (we like item[i] already)
* return;
*
* // we did not like any existing one, so add one
* ALLOC_GROW(item, nr + 1, alloc);
* item[nr++] = value you like;
* ------------
*
* You are responsible for updating the `nr` variable.
*
* If you need to specify the number of elements to allocate explicitly
* then use the macro `REALLOC_ARRAY(item, alloc)` instead of `ALLOC_GROW`.
*
* Consider using ALLOC_GROW_BY instead of ALLOC_GROW as it has some
* added niceties.
*
* DO NOT USE any expression with side-effect for 'x', 'nr', or 'alloc'.
*/
#define ALLOC_GROW(x, nr, alloc) \
do { \
if ((nr) > alloc) { \
if (alloc_nr(alloc) < (nr)) \
alloc = (nr); \
else \
alloc = alloc_nr(alloc); \
REALLOC_ARRAY(x, alloc); \
} \
} while (0)
/*
* Similar to ALLOC_GROW but handles updating of the nr value and
* zeroing the bytes of the newly-grown array elements.
*
* DO NOT USE any expression with side-effect for any of the
* arguments.
*/
#define ALLOC_GROW_BY(x, nr, increase, alloc) \
do { \
if (increase) { \
size_t new_nr = nr + (increase); \
if (new_nr < nr) \
BUG("negative growth in ALLOC_GROW_BY"); \
ALLOC_GROW(x, new_nr, alloc); \
memset((x) + nr, 0, sizeof(*(x)) * (increase)); \
nr = new_nr; \
} \
} while (0)
#endif

View file

@ -9,7 +9,6 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "base85.h"
#include "config.h"
#include "object-store-ll.h"

View file

@ -2,7 +2,6 @@
* Copyright (c) 2005, 2006 Rene Scharfe
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "gettext.h"
#include "git-zlib.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "convert.h"
#include "environment.h"

1
attr.c
View file

@ -7,7 +7,6 @@
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "exec-cmd.h"

View file

@ -6,7 +6,6 @@
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "color.h"
#include "builtin.h"

View file

@ -5,7 +5,6 @@
*/
#define USE_THE_INDEX_VARIABLE
#include "builtin.h"
#include "alloc.h"
#include "config.h"
#include "convert.h"
#include "diff.h"

View file

@ -1,5 +1,4 @@
#include "builtin.h"
#include "alloc.h"
#include "config.h"
#include "entry.h"
#include "gettext.h"

View file

@ -1,6 +1,5 @@
#include "builtin.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "color.h"
#include "editor.h"

View file

@ -1,6 +1,5 @@
#include "builtin.h"
#include "abspath.h"
#include "alloc.h"
#include "gettext.h"
#include "object-file.h"
#include "parse-options.h"

View file

@ -1,5 +1,4 @@
#include "builtin.h"
#include "alloc.h"
#include "gettext.h"
#include "hex.h"
#include "object-file.h"

View file

@ -1,6 +1,5 @@
#include "builtin.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -4,7 +4,6 @@
* Copyright (c) 2006 Junio C Hamano
*/
#include "builtin.h"
#include "alloc.h"
#include "gettext.h"
#include "hex.h"
#include "repository.h"

View file

@ -1,5 +1,4 @@
#include "builtin.h"
#include "alloc.h"
#include "config.h"
#include "delta.h"
#include "environment.h"

View file

@ -6,7 +6,6 @@
*/
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -10,7 +10,6 @@
#include "builtin.h"
#include "abspath.h"
#include "advice.h"
#include "alloc.h"
#include "config.h"
#include "editor.h"
#include "environment.h"

View file

@ -4,7 +4,6 @@
* Copyright (c) Junio C Hamano, 2006, 2009
*/
#include "builtin.h"
#include "alloc.h"
#include "gettext.h"
#include "hex.h"
#include "quote.h"

View file

@ -7,7 +7,6 @@
#include "builtin.h"
#include "abspath.h"
#include "advice.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,5 +1,4 @@
#include "builtin.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "builtin.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "builtin.h"
#include "alloc.h"
#include "config.h"
#include "dir.h"
#include "environment.h"

View file

@ -6,7 +6,6 @@
#define USE_THE_INDEX_VARIABLE
#include "builtin.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "commit.h"
#include "environment.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "builtin.h"
#include "parse-options.h"

View file

@ -5,7 +5,6 @@
*/
#define USE_THE_INDEX_VARIABLE
#include "builtin.h"
#include "alloc.h"
#include "advice.h"
#include "config.h"
#include "lockfile.h"

View file

@ -1,7 +1,6 @@
#define USE_THE_INDEX_VARIABLE
#include "builtin.h"
#include "abspath.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "hex.h"

View file

@ -2,7 +2,6 @@
* Copyright (c) 2011, Google Inc.
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "bulk-checkin.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "environment.h"
#include "hex.h"
#include "lockfile.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "chunk-format.h"
#include "csum-file.h"
#include "gettext.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "commit.h"
#include "commit-graph.h"
#include "decorate.h"

View file

@ -8,7 +8,6 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "advice.h"
#include "alloc.h"
#include "date.h"
#include "branch.h"
#include "config.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "path.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "attr.h"
#include "object.h"
#include "blob.h"

1
diff.c
View file

@ -3,7 +3,6 @@
*/
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "base85.h"
#include "config.h"
#include "convert.h"

View file

@ -3,7 +3,6 @@
* Copyright (C) 2005 Junio C Hamano
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "diff.h"
#include "diffcore.h"
#include "object-store-ll.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "dir.h"
#include "iterator.h"
#include "dir-iterator.h"

1
dir.c
View file

@ -7,7 +7,6 @@
*/
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "convert.h"
#include "dir.h"

View file

@ -17,7 +17,6 @@
* along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "ewok.h"
#define EWAH_MASK(x) ((eword_t)1 << (x % BITS_IN_EWORD))

View file

@ -17,7 +17,6 @@
* along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "ewok.h"
#include "ewok_rlw.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "repository.h"
#include "config.h"
#include "date.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "refs.h"

1
fsck.c
View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "date.h"
#include "dir.h"
#include "hex.h"

View file

@ -1134,6 +1134,81 @@ static inline void move_array(void *dst, const void *src, size_t n, size_t size)
#define FLEXPTR_ALLOC_STR(x, ptrname, str) \
FLEXPTR_ALLOC_MEM((x), ptrname, (str), strlen(str))
#define alloc_nr(x) (((x)+16)*3/2)
/**
* Dynamically growing an array using realloc() is error prone and boring.
*
* Define your array with:
*
* - a pointer (`item`) that points at the array, initialized to `NULL`
* (although please name the variable based on its contents, not on its
* type);
*
* - an integer variable (`alloc`) that keeps track of how big the current
* allocation is, initialized to `0`;
*
* - another integer variable (`nr`) to keep track of how many elements the
* array currently has, initialized to `0`.
*
* Then before adding `n`th element to the item, call `ALLOC_GROW(item, n,
* alloc)`. This ensures that the array can hold at least `n` elements by
* calling `realloc(3)` and adjusting `alloc` variable.
*
* ------------
* sometype *item;
* size_t nr;
* size_t alloc
*
* for (i = 0; i < nr; i++)
* if (we like item[i] already)
* return;
*
* // we did not like any existing one, so add one
* ALLOC_GROW(item, nr + 1, alloc);
* item[nr++] = value you like;
* ------------
*
* You are responsible for updating the `nr` variable.
*
* If you need to specify the number of elements to allocate explicitly
* then use the macro `REALLOC_ARRAY(item, alloc)` instead of `ALLOC_GROW`.
*
* Consider using ALLOC_GROW_BY instead of ALLOC_GROW as it has some
* added niceties.
*
* DO NOT USE any expression with side-effect for 'x', 'nr', or 'alloc'.
*/
#define ALLOC_GROW(x, nr, alloc) \
do { \
if ((nr) > alloc) { \
if (alloc_nr(alloc) < (nr)) \
alloc = (nr); \
else \
alloc = alloc_nr(alloc); \
REALLOC_ARRAY(x, alloc); \
} \
} while (0)
/*
* Similar to ALLOC_GROW but handles updating of the nr value and
* zeroing the bytes of the newly-grown array elements.
*
* DO NOT USE any expression with side-effect for any of the
* arguments.
*/
#define ALLOC_GROW_BY(x, nr, increase, alloc) \
do { \
if (increase) { \
size_t new_nr = nr + (increase); \
if (new_nr < nr) \
BUG("negative growth in ALLOC_GROW_BY"); \
ALLOC_GROW(x, new_nr, alloc); \
memset((x) + nr, 0, sizeof(*(x)) * (increase)); \
nr = new_nr; \
} \
} while (0)
static inline char *xstrdup_or_null(const char *str)
{
return str ? xstrdup(str) : NULL;

1
help.c
View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "builtin.h"
#include "exec-cmd.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "git-zlib.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "line-range.h"
#include "hex.h"
#include "tag.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "commit.h"
#include "config.h"
#include "gettext.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "dir.h"
#include "gettext.h"
#include "hex.h"

1
midx.c
View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "csum-file.h"
#include "dir.h"

View file

@ -8,7 +8,6 @@
*/
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "convert.h"
#include "environment.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "oid-array.h"
#include "hash-lookup.h"

View file

@ -4,7 +4,6 @@
*/
#include "git-compat-util.h"
#include "oidtree.h"
#include "alloc.h"
#include "hash.h"
struct oidtree_iter_data {

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "commit.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "object.h"
#include "pack.h"
#include "pack-objects.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "entry.h"
#include "gettext.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "commit.h"
#include "environment.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "prio-queue.h"
static inline int compare(struct prio_queue *queue, int i, int j)

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "path.h"
#include "quote.h"
#include "strbuf.h"

View file

@ -4,7 +4,6 @@
* Copyright (C) Linus Torvalds, 2005
*/
#include "git-compat-util.h"
#include "alloc.h"
#include "bulk-checkin.h"
#include "config.h"
#include "date.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "gpg-interface.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "commit.h"
#include "refs.h"
#include "diff.h"

1
refs.c
View file

@ -4,7 +4,6 @@
#include "git-compat-util.h"
#include "advice.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "hashmap.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "gettext.h"
#include "hash.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "config.h"
#include "copy.h"
#include "gettext.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,7 +1,6 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "advice.h"
#include "alloc.h"
#include "config.h"
#include "copy.h"
#include "environment.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "dir.h"
#include "environment.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "hex.h"
#include "repository.h"
#include "tempfile.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "sigchain.h"
#define SIGCHAIN_MAX_SIGNALS 32

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "name-hash.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "gettext.h"
#include "hash.h"
#include "mem-pool.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "string-list.h"
#include "alloc.h"
void string_list_init_nodup(struct string_list *list)
{

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "strvec.h"
#include "alloc.h"
#include "hex.h"
#include "strbuf.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "dir.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "repository.h"
#include "config.h"
#include "submodule-config.h"

View file

@ -1,5 +1,4 @@
#include "test-tool.h"
#include "alloc.h"
#include "commit.h"
#include "commit-reach.h"
#include "config.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "thread-utils.h"
#include "trace.h"
#include "trace2/tr2_tls.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "gettext.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "advice.h"
#include "alloc.h"
#include "config.h"
#include "environment.h"
#include "hex.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "tree-walk.h"
#include "alloc.h"
#include "dir.h"
#include "gettext.h"
#include "hex.h"

View file

@ -1,5 +1,4 @@
#include "git-compat-util.h"
#include "alloc.h"
#include "config.h"
#include "userdiff.h"
#include "attr.h"

View file

@ -1,6 +1,5 @@
#include "git-compat-util.h"
#include "abspath.h"
#include "alloc.h"
#include "environment.h"
#include "gettext.h"
#include "path.h"