Merge branch 'master' of https://github.com/jzck/42sh
This commit is contained in:
commit
ef00bf3676
1 changed files with 20 additions and 5 deletions
|
|
@ -19,7 +19,7 @@ static int history_parsing_nb_and_previous(char *str, int *i)
|
||||||
if (!ft_strncmp("!!", str + *i, 2))
|
if (!ft_strncmp("!!", str + *i, 2))
|
||||||
{
|
{
|
||||||
ft_realloc_str_history(&(data_singleton()->line.input), *i, 0, 2);
|
ft_realloc_str_history(&(data_singleton()->line.input), *i, 0, 2);
|
||||||
++(*i);
|
(*i) += 2;
|
||||||
return (1);
|
return (1);
|
||||||
}
|
}
|
||||||
else if (str[*i + 1] == '-' && ft_isdigit(str[*i + 2]) &&
|
else if (str[*i + 1] == '-' && ft_isdigit(str[*i + 2]) &&
|
||||||
|
|
@ -34,10 +34,22 @@ static int history_parsing_nb_and_previous(char *str, int *i)
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int check_validity(char *str, int i)
|
||||||
|
{
|
||||||
|
if (i && str[i - 1] == '\\')
|
||||||
|
return (0);
|
||||||
|
else if (!str[i + 1] || str[i + 1] == '"')
|
||||||
|
return (0);
|
||||||
|
return (1);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static int history_parsing_nb_and_name(char *str, int *i)
|
static int history_parsing_nb_and_name(char *str, int *i)
|
||||||
{
|
{
|
||||||
int tmp;
|
int tmp;
|
||||||
|
|
||||||
|
if (!check_validity(str, *i))
|
||||||
|
return (0);
|
||||||
if (history_parsing_nb_and_previous(str, i))
|
if (history_parsing_nb_and_previous(str, i))
|
||||||
return (1);
|
return (1);
|
||||||
else if (ft_isdigit(str[(*i) + 1]) && (size_t)ft_atoi(str + (*i) + 1) <
|
else if (ft_isdigit(str[(*i) + 1]) && (size_t)ft_atoi(str + (*i) + 1) <
|
||||||
|
|
@ -80,23 +92,26 @@ int ft_history_parsing(int has_prompt, char **input)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
char boolean;
|
char boolean;
|
||||||
|
char quote;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
|
quote = 0;
|
||||||
boolean = 0;
|
boolean = 0;
|
||||||
if (!data_singleton()->line.input)
|
|
||||||
return (0);
|
|
||||||
while (data_singleton()->line.input && data_singleton()->line.input[i])
|
while (data_singleton()->line.input && data_singleton()->line.input[i])
|
||||||
{
|
{
|
||||||
if (data_singleton()->line.input[i] == '!')
|
if (data_singleton()->line.input[i] == '\'')
|
||||||
|
quote = quote ? 0 : 1;
|
||||||
|
if (!quote && data_singleton()->line.input[i] == '!')
|
||||||
{
|
{
|
||||||
boolean = 1;
|
boolean = 1;
|
||||||
if (!history_parsing_nb_and_name(data_singleton()->line.input, &i))
|
if (!history_parsing_nb_and_name(data_singleton()->line.input, &i))
|
||||||
boolean = 0;
|
boolean = 0;
|
||||||
else
|
else
|
||||||
break ;
|
i = -1;
|
||||||
}
|
}
|
||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
|
*input = data_singleton()->line.input;
|
||||||
if (boolean)
|
if (boolean)
|
||||||
return (rematch_history_parsing(has_prompt, input));
|
return (rematch_history_parsing(has_prompt, input));
|
||||||
return (0);
|
return (0);
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue