Added $ENV_VARIABLES expansion
This commit is contained in:
parent
cc3e1892ef
commit
e6c2e4a479
@ -16,6 +16,7 @@ Work is still in porgress, buf when you will see a "finished" topic assigned to
|
|||||||
* Expand `*` wildcards
|
* Expand `*` wildcards
|
||||||
* Commands I/O redirection with `|` pipes and `>`, `<`, `>>`, `<>` file input/output
|
* Commands I/O redirection with `|` pipes and `>`, `<`, `>>`, `<>` file input/output
|
||||||
* Save history into file and access recent command in another instance of shell
|
* Save history into file and access recent command in another instance of shell
|
||||||
|
* `$ENVIRONMENT_VARIABLES` expansion
|
||||||
|
|
||||||
# Builtin commands
|
# Builtin commands
|
||||||
* `cd`: changes current working directory to the one specified by user. If no arguments provided, shows error.
|
* `cd`: changes current working directory to the one specified by user. If no arguments provided, shows error.
|
||||||
@ -23,7 +24,6 @@ Work is still in porgress, buf when you will see a "finished" topic assigned to
|
|||||||
* `exec`: executes entered command and exits
|
* `exec`: executes entered command and exits
|
||||||
|
|
||||||
# TODO
|
# TODO
|
||||||
* Replace linux `echo` command with builtin one with support of environmental variables
|
|
||||||
* Environmental variables
|
|
||||||
* `Ctrl+Z` running programm with `fd`
|
* `Ctrl+Z` running programm with `fd`
|
||||||
* `$()` subcommands
|
* `$()` subcommands
|
||||||
|
* Setting environment variables with `export` and before commands
|
||||||
|
@ -34,7 +34,7 @@ cmds_p *process_line(char *line)
|
|||||||
{
|
{
|
||||||
free_tmp[j] = '\0';
|
free_tmp[j] = '\0';
|
||||||
|
|
||||||
append_to_str_arr(&(curr_pipe->args), &curr_pipe->args_am, trim_string(tmp, false));
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, trim_string(tmp, false));
|
||||||
|
|
||||||
tmp += strlen(curr_pipe->args[curr_pipe->args_am - 1]) + 1;
|
tmp += strlen(curr_pipe->args[curr_pipe->args_am - 1]) + 1;
|
||||||
|
|
||||||
@ -68,7 +68,7 @@ cmds_p *process_line(char *line)
|
|||||||
free_tmp[i] = '\0';
|
free_tmp[i] = '\0';
|
||||||
if (line[i - 1] != ' ')
|
if (line[i - 1] != ' ')
|
||||||
{
|
{
|
||||||
append_to_str_arr(&(curr_pipe->args), &curr_pipe->args_am, trim_string(tmp, false));
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, trim_string(tmp, false));
|
||||||
tmp += strlen(curr_pipe->args[curr_pipe->args_am - 1]) + 1;
|
tmp += strlen(curr_pipe->args[curr_pipe->args_am - 1]) + 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -122,7 +122,7 @@ cmds_p *process_line(char *line)
|
|||||||
{
|
{
|
||||||
if (line[i - 1] != ' ')
|
if (line[i - 1] != ' ')
|
||||||
{
|
{
|
||||||
append_to_str_arr(&(curr_pipe->args), &curr_pipe->args_am, trim_string(tmp, false));
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, trim_string(tmp, false));
|
||||||
tmp += strlen(curr_pipe->args[curr_pipe->args_am - 1]) + 1;
|
tmp += strlen(curr_pipe->args[curr_pipe->args_am - 1]) + 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -220,6 +220,25 @@ cmds_p *process_line(char *line)
|
|||||||
tmp += j - i + 1;
|
tmp += j - i + 1;
|
||||||
i = j;
|
i = j;
|
||||||
}
|
}
|
||||||
|
else if (line[i] == '$')
|
||||||
|
{
|
||||||
|
tmp++;
|
||||||
|
i++;
|
||||||
|
int j = i;
|
||||||
|
|
||||||
|
for (; j < line_size; j++)
|
||||||
|
if (line[j] == ' ')
|
||||||
|
break;
|
||||||
|
|
||||||
|
free_tmp[j] = '\0';
|
||||||
|
|
||||||
|
char *msg = getenv(tmp);
|
||||||
|
if (msg != NULL)
|
||||||
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, "\n");
|
||||||
|
|
||||||
|
tmp += j - i + 1;
|
||||||
|
i = j;
|
||||||
|
}
|
||||||
else if (line[i] == ' ')
|
else if (line[i] == ' ')
|
||||||
{
|
{
|
||||||
free_tmp[i] = '\0';
|
free_tmp[i] = '\0';
|
||||||
@ -229,7 +248,7 @@ cmds_p *process_line(char *line)
|
|||||||
int sz = expand_wildcatrd(&exp, ap_string);
|
int sz = expand_wildcatrd(&exp, ap_string);
|
||||||
|
|
||||||
for (int l = 0; l < sz; l++)
|
for (int l = 0; l < sz; l++)
|
||||||
append_to_str_arr(&(curr_pipe->args), &curr_pipe->args_am, exp[l]);
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, exp[l]);
|
||||||
|
|
||||||
tmp += strlen(ap_string) + 1;
|
tmp += strlen(ap_string) + 1;
|
||||||
}
|
}
|
||||||
@ -248,7 +267,7 @@ cmds_p *process_line(char *line)
|
|||||||
int sz = expand_wildcatrd(&exp, ap_string);
|
int sz = expand_wildcatrd(&exp, ap_string);
|
||||||
|
|
||||||
for (int l = 0; l < sz; l++)
|
for (int l = 0; l < sz; l++)
|
||||||
append_to_str_arr(&(curr_pipe->args), &curr_pipe->args_am, exp[l]);
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, exp[l]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, trim_string(tmp, false));
|
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, trim_string(tmp, false));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user