Added setting environment variables with APPLICATION_INSIGHTS_NO_DIAGNOSTIC_CHANNEL=trueCHROME_DESKTOP=code-oss.desktopCOLORTERM=truecolorDBUS_SESSION_BUS_ADDRESS='unix:path=/run/user/1000/bus'DISPLAY=:0GIT_ASKPASS=/usr/lib/code/extensions/git/dist/askpass.shGTK_MODULES=canberra-gtk-moduleHOME=/home/dshI3SOCK=/run/user/1000/i3/ipc-socket.521LANG=en_US.UTF-8LESS=-RLESSHISTFILE=-LESSPROMPT='?f%f .?ltLine %lt:?pt%pt\%:?btByte %bt:-...'LESS_TERMCAP_mb=$'\C-[[31m'LESS_TERMCAP_md=$'\C-[[31m'LESS_TERMCAP_me=$'\C-[[0m'LESS_TERMCAP_se=$'\C-[[0m'LESS_TERMCAP_so=$'\C-[[47;30m'LESS_TERMCAP_ue=$'\C-[[0m'LESS_TERMCAP_us=$'\C-[[32m'LOGNAME=dshLS_COLORS='rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=00:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lz4=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31:*.zip=01;31:*.z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.zst=01;31:*.tzst=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.cab=01;31:*.wim=01;31:*.swm=01;31:*.dwm=01;31:*.esd=01;31:*.jpg=01;35:*.jpeg=01;35:*.mjpg=01;35:*.mjpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.webp=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.m4a=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.oga=00;36:*.opus=00;36:*.spx=00;36:*.xspf=00;36:'MAIL=/var/spool/mail/dshMANWIDTH=120MOZ_PLUGIN_PATH=/usr/lib/mozilla/pluginsNO_AT_BRIDGE=1OLDPWD=/mnt/hdd/Work/Development/C/myshellPATH=/home/dsh/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/bin:/usr/bin/site_perl:/usr/bin/vendor_perl:/usr/bin/core_perlPWD=/mnt/hdd/Work/Development/C/myshellSHELL=/bin/zshSHLVL=3TERM=xterm-256colorTERM_PROGRAM=vscodeTERM_PROGRAM_VERSION=1.46.1USER=dshVSCODE_GIT_ASKPASS_MAIN=/usr/lib/code/extensions/git/dist/askpass-main.jsVSCODE_GIT_ASKPASS_NODE=/usr/lib/electron7/electronVSCODE_GIT_IPC_HANDLE=/run/user/1000/vscode-git-55765a537b.sockWINDOWPATH=1XAUTHORITY=/home/dsh/.XauthorityXDG_CONFIG_HOME=/home/dsh/.configXDG_RUNTIME_DIR=/run/user/1000XDG_SEAT=seat0XDG_SESSION_CLASS=userXDG_SESSION_ID=1XDG_SESSION_TYPE=ttyXDG_VTNR=1 and before command locally

This commit is contained in:
Dm1tr1y147 2020-07-18 20:34:20 +05:00
parent 9febe996db
commit 885bd34da3
6 changed files with 100 additions and 46 deletions

View File

@ -18,13 +18,14 @@ Work is still in porgress, buf when you will see a "finished" topic assigned to
* Save history into file and access recent command in another instance of shell
* `$ENVIRONMENT_VARIABLES` expansion
* Own `execvpe` implimentation as `mexecvpe` with commands getting from `$PATH`
* Setting environment variables with `export` and locally before command
# Builtin commands
* `cd`: changes current working directory to the one specified by user. If no arguments provided, shows error.
* `exit`: exits shell
* `exec`: executes entered command and exits
* `export`: sets environment variable
* `exit`: exits shell
# TODO
* `Ctrl+Z` running programm with `fd`
* `$()` subcommands
* Setting environment variables with `export` and before commands
* ~~`Ctrl+Z` running programm with `fd`~~
* ~~`$()` subcommands~~

View File

@ -67,6 +67,9 @@ typedef struct commands
cmd_pipe *pipe;
ssize_t pipes_am;
char **envs;
ssize_t envs_am;
struct status stat;
struct commands *next;
cmd_sep sep_next;
@ -75,12 +78,12 @@ typedef struct commands
typedef struct
{
struct history hist;
char **envs;
int last_status;
} t_;
//Globals defenition
extern t_ term;
extern char **environ;
extern char *builtin[];
// shell.c file
@ -96,13 +99,14 @@ int expand_wildcatrd(char ***arr, char *input);
// execute.c file
int execute_with_pipes(cmds_p *command);
int execute(cmd_pipe *command);
int launch(cmd_pipe *command);
int execute(cmd_pipe *command, char **envp);
int launch(cmd_pipe *command, char **envp);
int mexecvpe(char *file, char **argv, char **envp);
int sh_cd(char **args);
int sh_exec(char **args, char **envp);
int sh_export(char **args);
int sh_exit(char **args);
int sh_exec(char **args);
void redirect_fd(int old, int new);

View File

@ -5,13 +5,15 @@
/* Global definitions */
char *builtin[] = {
"cd",
"exit",
"exec"};
"exec",
"export",
"exit"};
int (*builtin_func[])(char **) = {
&sh_cd,
&sh_exit,
&sh_exec};
&sh_exec,
&sh_export,
&sh_exit};
/**
* @brief Redirects command input/output and executes it
@ -36,12 +38,12 @@ int execute_with_pipes(cmds_p *command)
curr->pipefd[1] = tmp_fd[1];
curr->next->pipefd[0] = tmp_fd[0];
status = execute(curr);
status = execute(curr, command->envs);
curr = curr->next;
}
status = execute(curr);
status = execute(curr, command->envs);
return status;
}
@ -52,7 +54,7 @@ int execute_with_pipes(cmds_p *command)
* @param args
* @return int
*/
int execute(cmd_pipe *command)
int execute(cmd_pipe *command, char **envp)
{
if (command->args[0] == NULL)
return 1;
@ -69,7 +71,7 @@ int execute(cmd_pipe *command)
if (strcmp(args[0], builtin[i]) == 0)
return (*builtin_func[i])(args);
return launch(command);
return launch(command, envp);
}
/**
@ -78,7 +80,7 @@ int execute(cmd_pipe *command)
* @param args
* @return int
*/
int launch(cmd_pipe *command)
int launch(cmd_pipe *command, char **envp)
{
pid_t pid, wpid;
int status;
@ -91,7 +93,7 @@ int launch(cmd_pipe *command)
redirect_fd(command->pipefd[1], STDOUT_FILENO);
sh_exec(command->args);
sh_exec(command->args, envp);
}
else if (pid < 0)
{
@ -132,6 +134,54 @@ int sh_cd(char **args)
return 0;
}
/**
* @brief Shell builtin command. Executes command replacing shell with it
*
* @param args
* @return int
*/
int sh_exec(char **args, char **envp)
{
change_mode(0);
signal(SIGINT, SIG_DFL);
if (strcmp(args[0], "exec") == 0)
args = slice_array(args, 1, -1, 1);
if (mexecvpe(args[0], args, envp) < 0)
{
perror("mshell");
}
exit(EXIT_FAILURE);
}
int sh_export(char **args)
{
if (args[1] == NULL)
{
for (int i = 0; environ[i] != NULL; i++)
printf("declare -x %s\n", environ[i]);
return 0;
}
for (int i = 1; args[i] != NULL; i++)
{
char *name = strtok(args[i], "="), *val = strtok(NULL, "=");
if (name == NULL || val == NULL)
{
fprintf(stderr, "export: wrong arguments\n");
return 1;
}
setenv(name, val, true);
printf("Set %s variable to %s\n", name, getenv(name));
}
}
/**
* @brief Shell builtin command. Exits shell
*
@ -143,28 +193,6 @@ int sh_exit(char **args)
exit(0);
}
/**
* @brief Shell builtin command. Executes command replacing shell with it
*
* @param args
* @return int
*/
int sh_exec(char **args)
{
change_mode(0);
signal(SIGINT, SIG_DFL);
if (strcmp(args[0], "exec") == 0)
args = slice_array(args, 1, -1, 1);
if (mexecvpe(args[0], args, NULL) < 0)
{
perror("mshell");
}
exit(EXIT_FAILURE);
}
void redirect_fd(int old, int new)
{
if (old > 0)
@ -194,7 +222,7 @@ int mexecvpe(char *file, char **argv, char **envp)
char buff[file_len + path_len + 1], *subp;
for (char *p = path; ; p = subp)
for (char *p = path;; p = subp)
{
subp = strchr(p, ':');
memcpy(buff, p, subp - p);

View File

@ -227,14 +227,25 @@ cmds_p *process_line(char *line)
int j = i;
for (; j < line_size; j++)
if (line[j] == ' ')
if (line[j] == ' ' || line[j] == ';' || line[j] == '&' || line[j] == '|' || line[j] == '>' || 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");
char *msg = NULL;
for (int k = 0; k < curr_cmd->envs_am; k++)
if (strncmp(curr_cmd->envs[k], tmp, strlen(tmp)) == 0)
msg = strchr(curr_cmd->envs[k], '=') + 1;
if (msg == NULL)
{
msg = getenv(tmp);
if (msg == NULL)
msg = "\n";
}
append_to_str_arr(&curr_pipe->args, &curr_pipe->args_am, msg);
tmp += j - i + 1;
i = j;
@ -243,6 +254,14 @@ cmds_p *process_line(char *line)
{
free_tmp[i] = '\0';
if (curr_cmd->pipe->args[0] == NULL && strchr(tmp, '='))
{
append_to_str_arr(&curr_cmd->envs, &curr_cmd->envs_am, tmp);
tmp += strlen(curr_cmd->envs[curr_cmd->envs_am - 1]) + 1;
continue;
}
char *ap_string = trim_string(tmp, false), **exp = calloc(0, sizeof(char *));
int sz = expand_wildcatrd(&exp, ap_string);

View File

@ -26,7 +26,6 @@ int main()
// Init
t_ init_term()
{
// Entering raw mode
change_mode(1);

View File

@ -66,6 +66,9 @@ cmds_p *new_cmd()
new->pipe = new_cmd_pipe();
new->pipes_am = 1;
new->envs = calloc(0, sizeof(char *));
new->envs_am = 0;
new->stat.s = 0;
new->sep_next = NO_SEP;
new->stat.invert = false;