Added wildcard explanation for builtin commands
This commit is contained in:
parent
d6ed9d8de0
commit
fcd73c9187
@ -87,6 +87,7 @@ int sh_exec(char **args);
|
|||||||
char *compose_prompt();
|
char *compose_prompt();
|
||||||
|
|
||||||
cmds_p *new_cmd();
|
cmds_p *new_cmd();
|
||||||
|
int expand_wildcatrd(char ***arr, char *input);
|
||||||
|
|
||||||
#define BUILTIN_NUM sizeof(builtin) / sizeof(char *)
|
#define BUILTIN_NUM sizeof(builtin) / sizeof(char *)
|
||||||
|
|
||||||
|
@ -185,6 +185,13 @@ int process_keypress(char c)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Frees user input display
|
||||||
|
*
|
||||||
|
* @param pos
|
||||||
|
* @param n
|
||||||
|
* @param line
|
||||||
|
*/
|
||||||
void free_input(int *pos, int *n, char **line)
|
void free_input(int *pos, int *n, char **line)
|
||||||
{
|
{
|
||||||
char *buff = strdup("");
|
char *buff = strdup("");
|
||||||
|
71
src/shell.c
71
src/shell.c
@ -172,9 +172,14 @@ int process_line(char *line, cmds_p **coms)
|
|||||||
{
|
{
|
||||||
free_tmp[i] = '\0';
|
free_tmp[i] = '\0';
|
||||||
|
|
||||||
append_to_str_arr(&(curr_cmd->args), &args_am, trim_string(tmp, false));
|
char *ap_string = trim_string(tmp, false), **exp = malloc(0);
|
||||||
|
|
||||||
tmp += strlen(curr_cmd->args[args_am - 1]) + 1;
|
int sz = expand_wildcatrd(&exp, ap_string);
|
||||||
|
|
||||||
|
for (int l = 0; l < sz; l++)
|
||||||
|
append_to_str_arr(&(curr_cmd->args), &args_am, exp[l]);
|
||||||
|
|
||||||
|
tmp += strlen(ap_string) + 1;
|
||||||
}
|
}
|
||||||
else if (line[i] == '#')
|
else if (line[i] == '#')
|
||||||
{
|
{
|
||||||
@ -184,6 +189,16 @@ int process_line(char *line, cmds_p **coms)
|
|||||||
|
|
||||||
if (tmp[0] != '\0' && tmp[0] != '#')
|
if (tmp[0] != '\0' && tmp[0] != '#')
|
||||||
{
|
{
|
||||||
|
if (tmp[strlen(tmp) - 1] != '"')
|
||||||
|
{
|
||||||
|
char *ap_string = trim_string(tmp, false), **exp = malloc(0);
|
||||||
|
|
||||||
|
int sz = expand_wildcatrd(&exp, ap_string);
|
||||||
|
|
||||||
|
for (int l = 0; l < sz; l++)
|
||||||
|
append_to_str_arr(&(curr_cmd->args), &args_am, exp[l]);
|
||||||
|
}
|
||||||
|
else
|
||||||
append_to_str_arr(&(curr_cmd->args), &args_am, trim_string(tmp, false));
|
append_to_str_arr(&(curr_cmd->args), &args_am, trim_string(tmp, false));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -215,7 +230,7 @@ int execute(cmds_p *command)
|
|||||||
|
|
||||||
char **args = command->args;
|
char **args = command->args;
|
||||||
|
|
||||||
if (strcmp(command->args[0], "!") == 0)
|
if (strcmp(args[0], "!") == 0)
|
||||||
args = slice_array(args, 1, -1, true);
|
args = slice_array(args, 1, -1, true);
|
||||||
|
|
||||||
for (int i = 0; i < BUILTIN_NUM; i++)
|
for (int i = 0; i < BUILTIN_NUM; i++)
|
||||||
@ -297,27 +312,7 @@ int sh_exec(char **args)
|
|||||||
if (strcmp(args[0], "exec") == 0)
|
if (strcmp(args[0], "exec") == 0)
|
||||||
args = slice_array(args, 1, -1, 1);
|
args = slice_array(args, 1, -1, 1);
|
||||||
|
|
||||||
int amount = get_null_term_arr_size(args) - 1, k = 0;
|
if (execvp(args[0], args) < 0)
|
||||||
char **ex_args = malloc(0);
|
|
||||||
|
|
||||||
for (int i = 0; i < amount; i++)
|
|
||||||
{
|
|
||||||
if (strchr(args[i], '*') || strchr(args[i], '~'))
|
|
||||||
{
|
|
||||||
glob_t globbuf;
|
|
||||||
glob(args[i], GLOB_DOOFFS, NULL, &globbuf);
|
|
||||||
|
|
||||||
for (int j = 0; j < globbuf.gl_pathc; j++)
|
|
||||||
append_to_str_arr(&ex_args, &k, globbuf.gl_pathv[j]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
append_to_str_arr(&ex_args, &k, args[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
ex_args = realloc(ex_args, sizeof(char *) * ++k);
|
|
||||||
ex_args[k - 1] = NULL;
|
|
||||||
|
|
||||||
if (execvp(ex_args[0], ex_args) < 0)
|
|
||||||
{
|
{
|
||||||
perror("myshell3");
|
perror("myshell3");
|
||||||
}
|
}
|
||||||
@ -325,6 +320,11 @@ int sh_exec(char **args)
|
|||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get IP adress of system
|
||||||
|
*
|
||||||
|
* @return char*
|
||||||
|
*/
|
||||||
char *get_ip_addr()
|
char *get_ip_addr()
|
||||||
{
|
{
|
||||||
struct ifaddrs *host, *tmp;
|
struct ifaddrs *host, *tmp;
|
||||||
@ -409,6 +409,11 @@ char *compose_prompt()
|
|||||||
return prompt;
|
return prompt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Initialize command structure
|
||||||
|
*
|
||||||
|
* @return cmds_p*
|
||||||
|
*/
|
||||||
cmds_p *new_cmd()
|
cmds_p *new_cmd()
|
||||||
{
|
{
|
||||||
cmds_p *new = malloc(sizeof(cmds_p));
|
cmds_p *new = malloc(sizeof(cmds_p));
|
||||||
@ -420,3 +425,21 @@ cmds_p *new_cmd()
|
|||||||
|
|
||||||
return new;
|
return new;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int expand_wildcatrd(char ***arr, char *input)
|
||||||
|
{
|
||||||
|
int size = 0;
|
||||||
|
|
||||||
|
if (strchr(input, '*') || strchr(input, '~') || strchr(input, '?'))
|
||||||
|
{
|
||||||
|
glob_t globbuf;
|
||||||
|
int t = glob(input, GLOB_TILDE, NULL, &globbuf);
|
||||||
|
|
||||||
|
for (int j = 0; j < globbuf.gl_pathc; j++)
|
||||||
|
append_to_str_arr(arr, &size, globbuf.gl_pathv[j]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
append_to_str_arr(arr, &size, input);
|
||||||
|
|
||||||
|
return size;
|
||||||
|
}
|
13
src/utils.c
13
src/utils.c
@ -153,6 +153,14 @@ int get_null_term_arr_size(char **arr)
|
|||||||
return ++k;
|
return ++k;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Append string to the end of array
|
||||||
|
*
|
||||||
|
* @param arr
|
||||||
|
* @param sz
|
||||||
|
* @param str
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
int append_to_str_arr(char ***arr, int *sz, char *str)
|
int append_to_str_arr(char ***arr, int *sz, char *str)
|
||||||
{
|
{
|
||||||
(*sz)++;
|
(*sz)++;
|
||||||
@ -170,6 +178,11 @@ int append_to_str_arr(char ***arr, int *sz, char *str)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the current location
|
||||||
|
*
|
||||||
|
* @return char*
|
||||||
|
*/
|
||||||
char *get_curr_dir_name()
|
char *get_curr_dir_name()
|
||||||
{
|
{
|
||||||
char *pwd = malloc(FILENAME_MAX);
|
char *pwd = malloc(FILENAME_MAX);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user