/* ************************************************************************** */
/*                                                                            */
/*                                                        :::      ::::::::   */
/*   s_lalias.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 <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>

#include "s_struct.h"

void
	s_lalias_rebind(t_lalias **lalias, const char name[], const char newval[])
{
	t_lalias	*tmp;

	tmp = *lalias;
	while (tmp != NULL && ft_strncmp(tmp->name, name, ft_strlen(name) + 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);
		tmp = renext;
	}
	*lalias = NULL;
}

t_lalias
	*s_lalias_new(const char name[], const char val[])	
{
	t_lalias		*link;
	static size_t	id = 1;

	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->id = id;
	link->next = NULL;
	id += 1;
	return (link);
}