bebou t tro for
This commit is contained in:
parent
b5c7344851
commit
1252ac48a8
15 changed files with 214 additions and 25 deletions
69
sources/exec/handle_command.c
Normal file
69
sources/exec/handle_command.c
Normal file
|
|
@ -0,0 +1,69 @@
|
|||
/* ************************************************************************** */
|
||||
/* */
|
||||
/* ::: :::::::: */
|
||||
/* handle_command.c :+: :+: :+: */
|
||||
/* +:+ +:+ +:+ */
|
||||
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2024/05/09 15:00:53 by rparodi #+# #+# */
|
||||
/* Updated: 2024/05/09 17:14:32 by rparodi ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "app/env.h"
|
||||
#include "app/state.h"
|
||||
#include "me/types.h"
|
||||
#include "gmr/symbols.h"
|
||||
#include "app/node.h"
|
||||
#include "me/vec/vec_str.h"
|
||||
// #include "app/node/handle_program.h"
|
||||
#include "app/node/handle_command.h"
|
||||
#include "minishell.h"
|
||||
#include "me/string/str_clone.h"
|
||||
#include <time.h>
|
||||
|
||||
t_error handle_command(t_node *self, t_utils *shcat, t_i32 *out_exit_code)
|
||||
{
|
||||
t_usize i;
|
||||
t_spawn_info spawn_info;
|
||||
t_str tmp;
|
||||
|
||||
spawn_info.arguments = vec_str_new(self->childs_count, (void (*)(t_str))free);
|
||||
if (self->kind != sym_command)
|
||||
return (ERROR);
|
||||
i = 0;
|
||||
while (i < self->childs_count)
|
||||
{
|
||||
if (self->childs[i].kind == sym_command_name)
|
||||
spawn_info.binary_path = str_clone(node_getstr(&self->childs[i]));
|
||||
else if (self->childs[i].kind == sym_file_redirect)
|
||||
printf("PAS ENCORE HANDLE FDP redirect!\n");
|
||||
else if (self->childs[i].kind == sym_variable_assignment)
|
||||
printf("PAS ENCORE HANDLE FDP asignement!\n");
|
||||
else
|
||||
{
|
||||
printf("%s %s\n", self->childs[i].kind_str, node_getstr(&self->childs[i]));
|
||||
if (handle_node_getstr(&self->childs[i], shcat, &tmp))
|
||||
return (vec_str_free(spawn_info.arguments), ERROR);
|
||||
if (vec_str_push(&spawn_info.arguments, tmp))
|
||||
return (ERROR);
|
||||
}
|
||||
i++;
|
||||
}
|
||||
vec_str_push_front(&spawn_info.arguments, str_clone(spawn_info.binary_path));
|
||||
vec_str_push(&spawn_info.arguments, NULL);
|
||||
spawn_info.stdin = inherited();
|
||||
spawn_info.stdout = inherited();
|
||||
spawn_info.stderr = inherited();
|
||||
spawn_info.forked_free = NULL;
|
||||
if (build_envp(shcat->env, &spawn_info.environement))
|
||||
return (vec_str_free(spawn_info.arguments), ERROR);
|
||||
if (spawn_process(spawn_info, &shcat->ret))
|
||||
return (ERROR);
|
||||
waitpid(shcat->ret.pid, NULL, 0);
|
||||
close(shcat->ret.stdin.vals.ro.fd);
|
||||
close(shcat->ret.stdout.vals.ro.fd);
|
||||
close(shcat->ret.stderr.vals.ro.fd);
|
||||
*out_exit_code = 0;
|
||||
return (NO_ERROR);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue