From 9c9e5ac17efca1cc22fd8cf69fb75a1e4701efe7 Mon Sep 17 00:00:00 2001 From: Charles Date: Wed, 15 Jul 2020 13:27:31 +0200 Subject: Added export/unset builtin error message and status code --- src/env.c | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) (limited to 'src/env.c') diff --git a/src/env.c b/src/env.c index bdc2498..1ed5162 100644 --- a/src/env.c +++ b/src/env.c @@ -6,7 +6,7 @@ /* By: cacharle +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2020/02/28 09:21:24 by cacharle #+# #+# */ -/* Updated: 2020/07/13 11:09:39 by charles ### ########.fr */ +/* Updated: 2020/07/15 13:02:04 by charles ### ########.fr */ /* */ /* ************************************************************************** */ @@ -77,6 +77,20 @@ char *env_search(t_env env, char *key) return (NULL); } +int env_search_index(t_env env, char *key) +{ + size_t i; + + i = 0; + while (i < env->size - 1) + { + if (env_keycmp(env->data[i], key) == 0) + return (i); + i++; + } + return (-1); +} + char *env_search_first_match(t_env env, const char *haystack) { size_t len; @@ -107,28 +121,20 @@ char *env_search_first_match(t_env env, const char *haystack) char *env_export(t_env env, char *key, char *value) { char *joined; - size_t i; + int i; if ((joined = ft_strjoin3(key, "=", value)) == NULL) return (NULL); - if (env_search(env, key) == NULL) + i = env_search_index(env, key); + if (i == -1) { if (ft_vecinsert(env, env->size - 1, joined) == NULL) return (NULL); } else { - i = 0; - while (i < env->size - 1) - { - if (env_keycmp(env->data[i], key) == 0) - { - free(env->data[i]); - env->data[i] = joined; - break; - } - i++; - } + free(env->data[i]); + env->data[i] = joined; } return (joined); } -- cgit