summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-09-11 17:45:49 +0200
committerJozanLeClerc <bousset.rudy@gmail.com>2020-09-11 17:45:49 +0200
commit6e74d376f1a888f4730b9fa39df1b34b251eb3f5 (patch)
treeeb602453b996ca6c67dbe2d281b8252b1e1ed429 /src
parentBetter (diff)
download42-minishell-6e74d376f1a888f4730b9fa39df1b34b251eb3f5.tar.gz
42-minishell-6e74d376f1a888f4730b9fa39df1b34b251eb3f5.tar.bz2
42-minishell-6e74d376f1a888f4730b9fa39df1b34b251eb3f5.tar.xz
42-minishell-6e74d376f1a888f4730b9fa39df1b34b251eb3f5.tar.zst
42-minishell-6e74d376f1a888f4730b9fa39df1b34b251eb3f5.zip
Aliases list in progress
Diffstat (limited to '')
-rw-r--r--src/s_destroy.c1
-rw-r--r--src/s_lalias.c78
-rw-r--r--src/s_lalias.h5
-rw-r--r--src/s_lvars.c17
-rw-r--r--src/s_struct.h2
-rw-r--r--src/u_alias.c43
-rw-r--r--src/u_alias.h26
-rw-r--r--src/u_vars.h2
8 files changed, 163 insertions, 11 deletions
diff --git a/src/s_destroy.c b/src/s_destroy.c
index 6626bd9..f9ce3c4 100644
--- a/src/s_destroy.c
+++ b/src/s_destroy.c
@@ -13,6 +13,7 @@
#include <libft.h>
#include "s_destroy.h"
+#include "s_lalias.h"
#include "s_lvars.h"
void
diff --git a/src/s_lalias.c b/src/s_lalias.c
index 3bbee14..b4b9430 100644
--- a/src/s_lalias.c
+++ b/src/s_lalias.c
@@ -10,9 +10,85 @@
/* */
/* ************************************************************************** */
+#include <libft.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <errno.h>
+
#include "s_struct.h"
+void
+ s_lalias_rebind(t_lalias **lalias,
+ const char newname[],
+ const char newval[])
+{
+ t_lalias *tmp;
+
+ tmp = *lalias;
+ while (tmp != NULL &&
+ ft_strncmp(tmp->name, newname, ft_strlen(newname) + 1) != 0)
+ {
+ tmp = tmp->next;
+ }
+ if (tmp == NULL)
+ {
+ return ;
+ }
+ ft_memdel((void*)&tmp->val);
+ if ((tmp->val = ft_strdup(newval)) == NULL)
+ {
+ ft_dprintf(STDERR_FILENO, "%s\n", strerror(errno));
+ }
+}
+
+void
+ s_lalias_add_front(t_lalias **lalias, t_lalias *new)
+{
+ if (lalias == NULL || new == NULL)
+ {
+ return ;
+ }
+ new->next = *lalias;
+ *lalias = new;
+}
+
+void
+ s_lalias_clear(t_lalias **lalias)
+{
+ t_lalias *tmp;
+ t_lalias *renext;
+
+ if (lalias == NULL)
+ return ;
+ tmp = *lalias;
+ while (tmp != NULL)
+ {
+ renext = tmp->next;
+ ft_memdel((void*)&tmp->name);
+ ft_memdel((void*)&tmp->val);
+ ft_memdel((void*)&tmp);
+ }
+ *lalias = NULL;
+}
+
t_lalias
-*s_lalias_new(const char name[], const char val[])
+ *s_lalias_new(const char name[], const char val[])
{
+ t_lalias *link;
+
+ if ((link = (t_lalias*)malloc(sizeof(t_lalias))) == NULL)
+ {
+ return (NULL);
+ }
+ if ((link->name = ft_strdup(name)) == NULL)
+ {
+ return (NULL);
+ }
+ if ((link->val = ft_strdup(val)) == NULL)
+ {
+ return (NULL);
+ }
+ link->next = NULL;
+ return (link);
}
diff --git a/src/s_lalias.h b/src/s_lalias.h
index 8add358..5218a88 100644
--- a/src/s_lalias.h
+++ b/src/s_lalias.h
@@ -15,6 +15,11 @@
#include "s_struct.h"
+void s_lalias_rebind(t_lalias **lalias,
+ const char name[],
+ const char newval[]);
+void s_lalias_add_front(t_lalias **lalias, t_lalias *new);
+void s_lalias_clear(t_lalias **lalias);
t_lalias *s_lalias_new(const char name[], const char val[]);
#endif
diff --git a/src/s_lvars.c b/src/s_lvars.c
index 3eb4943..e4b054e 100644
--- a/src/s_lvars.c
+++ b/src/s_lvars.c
@@ -11,8 +11,8 @@
/* ************************************************************************** */
#include <libft.h>
-#include <string.h>
#include <stdlib.h>
+#include <string.h>
#include <errno.h>
#include <unistd.h>
@@ -24,7 +24,7 @@ void
t_lvars *tmp;
tmp = *lvars;
- while (tmp && ft_strncmp(tmp->name, name, ft_strlen(name) + 1))
+ while (tmp != NULL && ft_strncmp(tmp->name, name, ft_strlen(name) + 1) != 0)
{
tmp = tmp->next;
}
@@ -33,10 +33,9 @@ void
return ;
}
ft_memdel((void*)&tmp->val);
- if (!(tmp->val = ft_strdup(newval)))
+ if ((tmp->val = ft_strdup(newval)) == NULL)
{
ft_dprintf(STDERR_FILENO, "%s\n", strerror(errno));
- exit(FT_RET_ALLOC);
}
}
@@ -71,7 +70,7 @@ void
void
lvars_add_front(t_lvars **alvars, t_lvars *new)
{
- if (!alvars || !new)
+ if (alvars == NULL || new == NULL)
{
return ;
}
@@ -88,7 +87,7 @@ void
if (lvars == NULL)
return ;
tmp = *lvars;
- while (tmp)
+ while (tmp != NULL)
{
renext = tmp->next;
ft_memdel((void*)&tmp->name);
@@ -104,15 +103,15 @@ t_lvars
{
t_lvars *link;
- if (!(link = (t_lvars*)malloc(sizeof(t_lvars))))
+ if ((link = (t_lvars*)malloc(sizeof(t_lvars))) == NULL)
{
return (NULL);
}
- if (!(link->name = ft_strdup(name)))
+ if ((link->name = ft_strdup(name)) == NULL)
{
return (NULL);
}
- if (!(link->val = ft_strdup(val)))
+ if ((link->val = ft_strdup(val)) == NULL)
{
return (NULL);
}
diff --git a/src/s_struct.h b/src/s_struct.h
index d678c36..963d5ad 100644
--- a/src/s_struct.h
+++ b/src/s_struct.h
@@ -28,7 +28,7 @@ typedef struct s_lvars
typedef struct s_lalias
{
char *name;
- char *value;
+ char *val;
struct s_lalias *next;
} t_lalias;
diff --git a/src/u_alias.c b/src/u_alias.c
new file mode 100644
index 0000000..6253d60
--- /dev/null
+++ b/src/u_alias.c
@@ -0,0 +1,43 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* u_alias.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */
+/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */
+/* */
+/* ************************************************************************** */
+
+#include <libft.h>
+#include <stddef.h>
+
+#include "d_define.h"
+#include "s_struct.h"
+
+void
+ u_get_alias_value(char str[], const char name[], size_t dstsize, t_msh *msh)
+{
+ t_lalias *ptr;
+
+ str[0] = C_NUL;
+ ptr = msh->alias;
+ while (ptr != NULL && ft_strncmp(tmp->name, name, ft_strlen(name)) != 0)
+ {
+ ptr = ptr->next;
+ }
+ if (ptr != NULL)
+ {
+ ft_strlcpy(str, tmp->value, dstsize);
+ }
+}
+
+void
+ u_set_alias_value(const char name[], const char value[], t_msh *msh)
+{
+ t_lalias *tmp;
+
+ tmp = msh->alias;
+ while (tmp)
+}
diff --git a/src/u_alias.h b/src/u_alias.h
new file mode 100644
index 0000000..c660484
--- /dev/null
+++ b/src/u_alias.h
@@ -0,0 +1,26 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* u_alias.h :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */
+/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */
+/* */
+/* ************************************************************************** */
+
+#ifndef U_ALIAS_H
+#define U_ALIAS_H
+
+#include <stddef.h>
+
+#include "s_struct.h"
+
+void u_get_alias_value(char str[],
+ const char name[],
+ size_t dstsize,
+ t_msh *msh);
+void u_set_alias_value(const char name[], const char value[], t_msh *msh);
+
+#endif
diff --git a/src/u_vars.h b/src/u_vars.h
index fbdaffc..27c975f 100644
--- a/src/u_vars.h
+++ b/src/u_vars.h
@@ -13,6 +13,8 @@
#ifndef U_VARS_H
#define U_VARS_H
+#include <stddef.h>
+
#include "s_struct.h"
void u_get_custom_var(char str[],