aboutsummaryrefslogtreecommitdiff
path: root/src/vec/ft_vecinsert.c
diff options
context:
space:
mode:
authorCharles <sircharlesaze@gmail.com>2020-04-02 11:20:44 +0200
committerCharles <sircharlesaze@gmail.com>2020-04-02 11:20:44 +0200
commita2452f88fffffe4e2a278578de5ac961858a5b72 (patch)
tree794727721e851a3d90cf3d80096bf5585c5de7bd /src/vec/ft_vecinsert.c
parent1925805cc760061d5742f9d215998561fcd45211 (diff)
downloadlibft-a2452f88fffffe4e2a278578de5ac961858a5b72.tar.gz
libft-a2452f88fffffe4e2a278578de5ac961858a5b72.tar.bz2
libft-a2452f88fffffe4e2a278578de5ac961858a5b72.zip
Fixed ft_vecgrow, Added ft_vecinsert
Diffstat (limited to 'src/vec/ft_vecinsert.c')
-rw-r--r--src/vec/ft_vecinsert.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/vec/ft_vecinsert.c b/src/vec/ft_vecinsert.c
new file mode 100644
index 0000000..1682daa
--- /dev/null
+++ b/src/vec/ft_vecinsert.c
@@ -0,0 +1,36 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_vecinsert.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/04/02 10:46:59 by charles #+# #+# */
+/* Updated: 2020/04/02 11:04:19 by charles ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "libft_vec.h"
+
+/*
+** \brief Insert element in vector
+** \param vec Vector where element is inserted
+** \param i Index where element should be inserted,
+** bound checking is performed
+** \param elem Element to insert
+** \return Passed vector or NULL on error
+*/
+
+t_ftvec *ft_vecinsert(t_ftvec *vec, size_t i, void *elem)
+{
+ if (i > vec->size)
+ return (NULL);
+ if (vec->capacity <= vec->size)
+ if (ft_vecgrow(vec) == NULL)
+ return (NULL);
+ ft_memmove(vec->data + i + 1, vec->data + i,
+ (vec->size - i) * sizeof(void*));
+ vec->data[i] = elem;
+ vec->size++;
+ return (vec);
+}