aboutsummaryrefslogtreecommitdiff
path: root/src/vec/ft_vecgrow.c
diff options
context:
space:
mode:
authorCharles <sircharlesaze@gmail.com>2020-04-01 21:21:10 +0200
committerCharles <sircharlesaze@gmail.com>2020-04-01 21:21:10 +0200
commita1675f56b35f5521a91851bae8ca650706374ae6 (patch)
tree73bf00503b27ac4e548ae66bf7789eff4eb8eede /src/vec/ft_vecgrow.c
parent9316f2063255bd4a0abd5c38d4c065969a8980bb (diff)
downloadlibft-a1675f56b35f5521a91851bae8ca650706374ae6.tar.gz
libft-a1675f56b35f5521a91851bae8ca650706374ae6.tar.bz2
libft-a1675f56b35f5521a91851bae8ca650706374ae6.zip
Added vector
Diffstat (limited to 'src/vec/ft_vecgrow.c')
-rw-r--r--src/vec/ft_vecgrow.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/src/vec/ft_vecgrow.c b/src/vec/ft_vecgrow.c
new file mode 100644
index 0000000..bb8b8c7
--- /dev/null
+++ b/src/vec/ft_vecgrow.c
@@ -0,0 +1,43 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_vecgrow.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/04/01 19:13:07 by charles #+# #+# */
+/* Updated: 2020/04/01 21:15:20 by charles ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "libft_vec.h"
+
+/*
+** \brief Vector Growth factor
+*/
+
+#define FT_VEC_GROWTH_FACTOR 1.5
+
+/*
+** \brief Grow the vector capacity by a constant factor
+** \param vec Vector to grow
+** \return Passed vector of NULL on error
+*/
+
+t_ftvec *ft_vecgrow(t_ftvec *vec)
+{
+ size_t new_capacity;
+ void **new_data;
+
+ if (vec->capacity <= 1)
+ new_capacity = 2;
+ else
+ new_capacity = vec->capacity * FT_VEC_GROWTH_FACTOR;
+ if ((new_data = (void**)malloc(sizeof(void*) * new_capacity)) == NULL)
+ return (NULL);
+ ft_memcpy(new_data, vec->data, vec->size);
+ free(vec->data);
+ vec->data = new_data;
+ vec->capacity = new_capacity;
+ return (vec);
+}