diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/m_loop.c | 31 | ||||
| -rw-r--r-- | src/p_args.c | 5 | ||||
| -rw-r--r-- | src/p_args_next.c | 5 | ||||
| -rw-r--r-- | src/p_line.c | 8 | ||||
| -rw-r--r-- | src/s_init.c | 1 | ||||
| -rw-r--r-- | src/s_struct.h | 1 | 
6 files changed, 27 insertions, 24 deletions
| diff --git a/src/m_loop.c b/src/m_loop.c index 0a810a0..7dc19e0 100644 --- a/src/m_loop.c +++ b/src/m_loop.c @@ -35,12 +35,12 @@ static void  }  void -	m_dump_hist(t_msh *msh) +	m_dump_hist(char hist[], t_msh *msh)  { -	int32_t	fd;  	char	histfile[PATH_MAX]; +	int32_t	fd; -	if (msh->hist[0] != C_NUL && ft_strlen(msh->hist) > 0) +	if (hist[0] != C_NUL && ft_strlen(hist) > 0)  	{  		u_get_var_value(histfile, "$HISTFILE", PATH_MAX, msh);  		if (histfile[0] != C_NUL) @@ -48,7 +48,7 @@ void  			if ((fd = open(histfile,  				O_WRONLY | O_CREAT | O_APPEND, 0644)) != -1)  			{ -				ft_dprintf(fd, "%s", msh->hist); +				ft_dprintf(fd, "%s", hist);  				close(fd);  			}  		} @@ -56,19 +56,19 @@ void  }  static void -	m_handle_hist(char line[], t_msh *msh) +	m_handle_hist(char hist[], char line[], t_msh *msh)  {  	static uint16_t	hist_i = 0;  	if (hist_i == 0) -		msh->hist[0] = '\0'; -	ft_strlcpy(msh->hist + ft_strlen(msh->hist), line, 4096); -	msh->hist[ft_strlen(msh->hist) + 1] = '\0'; -	msh->hist[ft_strlen(msh->hist)] = '\n'; +		hist[0] = '\0'; +	ft_strlcpy(hist + ft_strlen(hist), line, 4096); +	hist[ft_strlen(hist) + 1] = '\0'; +	hist[ft_strlen(hist)] = '\n';  	hist_i += 1; -	if (hist_i == 255) +	if (hist_i == 254)  	{ -		m_dump_hist(msh); +		m_dump_hist(hist, msh);  		hist_i = 0;  	}  } @@ -76,8 +76,9 @@ static void  uint8_t  	m_loop(int32_t fd, t_msh *msh)  { -	char			*line; -	int8_t			gnl; +	static char	hist[255 * 4096]; +	char		*line; +	int8_t		gnl;  	msh->fd = fd;  	gnl = 1; @@ -93,7 +94,7 @@ uint8_t  			line = m_check_multi_and(fd, line, msh);  			line = m_check_multi_quotes(fd, line, msh);  			if (fd == STDIN_FILENO) -				m_handle_hist(line, msh); +				m_handle_hist(hist, line, msh);  			m_parse_and_run_line(line, msh);  			/* TODO: (null): Bad address on "msh ~> echo a > asd; cat < asd" but not on "msh ~> echo a > asd; cat asd" */  		} @@ -101,6 +102,6 @@ uint8_t  			ft_memdel((void*)&line);  	}  	if (fd == STDIN_FILENO) -		m_dump_hist(msh); +		m_dump_hist(hist, msh);  	return (msh->ret);  } diff --git a/src/p_args.c b/src/p_args.c index 383700f..78cfc06 100644 --- a/src/p_args.c +++ b/src/p_args.c @@ -116,9 +116,10 @@ static uint16_t  		if (ft_iswhitespace(*ptr) &&  			p_meet_whitespace((char*)word, ptr, mode) == TRUE)  		{ -			count += 1;  			ptr = p_skip_whitespace(ptr); -			start[count - 1] = (ptr - word); +			start[count] = (ptr - word); +			if (*ptr != C_NUL) +				count += 1;  			ptr -= 1;  		}  		ptr++; diff --git a/src/p_args_next.c b/src/p_args_next.c index 77f8ced..6fd6b08 100644 --- a/src/p_args_next.c +++ b/src/p_args_next.c @@ -25,8 +25,8 @@ static char  {  	tmp[0] = '\0';  	ft_strlcpy(tmp, -			word + start[i], -			(p_arg_len(word, start[i]) - start[i]) + 1); +		word + start[i], +		(p_arg_len(word, start[i]) - start[i]) + 1);  	return (tmp);  } @@ -63,4 +63,3 @@ uint16_t  	}  	return (i);  } - diff --git a/src/p_line.c b/src/p_line.c index 9c96610..170d8a8 100644 --- a/src/p_line.c +++ b/src/p_line.c @@ -19,6 +19,7 @@  #include "p_lcom.h"  #include "s_destroy.h"  #include "s_struct.h" +#include "u_utils.h"  static void  	p_delete_comments(char line[]) @@ -30,8 +31,11 @@ static void  	{  		if (*ptr == '#')  		{ -			*ptr = '\0'; -			return ; +			if ((ptr - line) == 0 || ft_iswhitespace(*(ptr - 1)) == TRUE) +			{ +				*ptr = '\0'; +				return ; +			}  		}  		ptr++;  	} diff --git a/src/s_init.c b/src/s_init.c index 55f9cf0..9ef856f 100644 --- a/src/s_init.c +++ b/src/s_init.c @@ -175,7 +175,6 @@ t_msh  	init_buptr(msh);  	msh->curr = NULL;  	msh->vars = NULL; -	msh->hist[0] = '\0';  	set_cwd(cwd, msh);  	if ((msh->cwd = ft_strdup(cwd)) == NULL)  		return (NULL); diff --git a/src/s_struct.h b/src/s_struct.h index a1d1828..1089dc6 100644 --- a/src/s_struct.h +++ b/src/s_struct.h @@ -74,7 +74,6 @@ typedef struct		s_msh  	char			ps[4][1024];  	char			env_fork_tmp[128][1024];  	char			sqb_ref[FT_ID_SQB_COUNT][4]; -	char			hist[1037595];  	char			*shname;  	char			*cwd;  	int32_t			fd; | 
