diff options
| author | Paul Eggert | 2021-01-22 11:45:38 -0800 |
|---|---|---|
| committer | Paul Eggert | 2021-01-22 12:02:55 -0800 |
| commit | a900e641fa1fd765799f12a7f699f768ebfccfe8 (patch) | |
| tree | a874eba952d3e51190a2bfe26cfe6c1635e9fda1 /lib/malloc/dynarray_resize_clear.c | |
| parent | 9143eba0c6861f467c18bc52d66e6f5c573be56b (diff) | |
| download | emacs-a900e641fa1fd765799f12a7f699f768ebfccfe8.tar.gz emacs-a900e641fa1fd765799f12a7f699f768ebfccfe8.zip | |
Update from Gnulib by running admin/merge-gnulib
Diffstat (limited to 'lib/malloc/dynarray_resize_clear.c')
| -rw-r--r-- | lib/malloc/dynarray_resize_clear.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/lib/malloc/dynarray_resize_clear.c b/lib/malloc/dynarray_resize_clear.c new file mode 100644 index 00000000000..99c2cc87c31 --- /dev/null +++ b/lib/malloc/dynarray_resize_clear.c | |||
| @@ -0,0 +1,35 @@ | |||
| 1 | /* Increase the size of a dynamic array and clear the new part. | ||
| 2 | Copyright (C) 2017-2021 Free Software Foundation, Inc. | ||
| 3 | This file is part of the GNU C Library. | ||
| 4 | |||
| 5 | The GNU C Library is free software; you can redistribute it and/or | ||
| 6 | modify it under the terms of the GNU General Public | ||
| 7 | License as published by the Free Software Foundation; either | ||
| 8 | version 3 of the License, or (at your option) any later version. | ||
| 9 | |||
| 10 | The GNU C Library is distributed in the hope that it will be useful, | ||
| 11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 13 | General Public License for more details. | ||
| 14 | |||
| 15 | You should have received a copy of the GNU General Public | ||
| 16 | License along with the GNU C Library; if not, see | ||
| 17 | <https://www.gnu.org/licenses/>. */ | ||
| 18 | |||
| 19 | #include <dynarray.h> | ||
| 20 | #include <string.h> | ||
| 21 | |||
| 22 | bool | ||
| 23 | __libc_dynarray_resize_clear (struct dynarray_header *list, size_t size, | ||
| 24 | void *scratch, size_t element_size) | ||
| 25 | { | ||
| 26 | size_t old_size = list->used; | ||
| 27 | if (!__libc_dynarray_resize (list, size, scratch, element_size)) | ||
| 28 | return false; | ||
| 29 | /* __libc_dynarray_resize already checked for overflow. */ | ||
| 30 | char *array = list->array; | ||
| 31 | memset (array + (old_size * element_size), 0, | ||
| 32 | (size - old_size) * element_size); | ||
| 33 | return true; | ||
| 34 | } | ||
| 35 | libc_hidden_def (__libc_dynarray_resize_clear) | ||