Polished echo, and the builtins should work now (not tested in pipes)

This commit is contained in:
Maix0 2024-08-11 11:42:44 +02:00
parent 85910da2fd
commit 45a55df528
9 changed files with 118 additions and 57 deletions

View file

@ -6,7 +6,7 @@
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/10 18:43:18 by maiboyer #+# #+# */
/* Updated: 2024/08/10 19:48:59 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:21:35 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -16,7 +16,7 @@
#include "me/string/string.h"
#include "me/types.h"
t_error builtin_cd____(t_state *state, t_spawn_info info)
t_error builtin_cd____(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
return (ERROR);
}

View file

@ -6,7 +6,7 @@
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/10 18:43:18 by maiboyer #+# #+# */
/* Updated: 2024/08/10 19:47:34 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:30:09 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -16,7 +16,7 @@
#include "me/string/string.h"
#include "me/types.h"
t_error builtin_echo__(t_state *state, t_spawn_info info)
t_error builtin_echo__(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
t_usize i;
bool print_line;
@ -25,21 +25,22 @@ t_error builtin_echo__(t_state *state, t_spawn_info info)
print_line = true;
i = 1;
s = string_new(1024);
if (i < info.arguments.len && str_compare(info.arguments.buffer[i], "-n"))
if (i < info.args.len && str_compare(info.args.buffer[i], "-n"))
{
print_line = false;
i++;
}
while (i < info.arguments.len - 1)
while (i < info.args.len - 1)
{
string_push(&s, info.arguments.buffer[i++]);
string_push(&s, info.args.buffer[i++]);
string_push_char(&s, ' ');
}
if (i < info.arguments.len)
string_push(&s, info.arguments.buffer[i]);
if (i < info.args.len)
string_push(&s, info.args.buffer[i]);
if (print_line)
string_push_char(&s, '\n');
// TODO: change the null to the actual redirection thingy, this needs to be done in the handle_builtin function beforehand
me_printf_fd(NULL, "%s", s.buf);
return (NO_ERROR);
me_printf_fd(info.stdout, "%s", s.buf);
string_free(s);
return (*exit_code = 0, NO_ERROR);
}

View file

@ -6,7 +6,7 @@
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/07 14:22:50 by rparodi #+# #+# */
/* Updated: 2024/08/10 19:57:32 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:25:42 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -18,7 +18,7 @@
struct s_print_env_state
{
t_state *state;
t_spawn_info *info;
t_builtin_spawn_info *info;
};
static t_error _print_env(t_usize _idx, const t_str *key, t_str *value, void *vctx)
@ -36,12 +36,12 @@ static t_error _print_env(t_usize _idx, const t_str *key, t_str *value, void *vc
return (NO_ERROR);
}
t_error builtin_env___(t_state *state, t_spawn_info info)
t_error builtin_env___(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
struct s_print_env_state ctx;
ctx.info = &info;
ctx.state = state;
hmap_env_iter(state->env, _print_env, &ctx);
return (NO_ERROR);
return (*exit_code = 0, NO_ERROR);
}

View file

@ -6,7 +6,7 @@
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/10 18:43:18 by maiboyer #+# #+# */
/* Updated: 2024/08/10 20:01:36 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:26:03 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -14,14 +14,15 @@
#include "me/convert/str_to_numbers.h"
#include "me/types.h"
t_error builtin_exit__(t_state *state, t_spawn_info info)
t_error builtin_exit__(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
t_i32 exit_code;
t_i32 actual_exit_code;
if (info.arguments.len < 2)
exit_code = 0;
else if (str_to_i32(info.arguments.buffer[1], 10, &exit_code))
if (info.args.len < 2)
actual_exit_code = 0;
else if (str_to_i32(info.args.buffer[1], 10, &actual_exit_code))
return (ERROR);
me_exit(exit_code);
*exit_code = actual_exit_code;
me_exit(actual_exit_code);
return (NO_ERROR);
}

View file

@ -6,17 +6,17 @@
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/07 14:13:41 by rparodi #+# #+# */
/* Updated: 2024/08/10 19:58:12 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:26:08 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
#include "exec/builtins.h"
#include "me/types.h"
t_error builtin_export(t_state *state, t_spawn_info info)
t_error builtin_export(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
if (info.arguments.len == 1)
return (builtin_env___(state, info));
if (info.args.len == 1)
return (builtin_env___(state, info, exit_code));
return (NO_ERROR);
return (*exit_code = 0, NO_ERROR);
}

View file

@ -6,7 +6,7 @@
/* By: rparodi <rparodi@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/07 13:58:37 by rparodi #+# #+# */
/* Updated: 2024/08/10 19:44:12 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:26:12 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -15,7 +15,7 @@
#include "me/string/string.h"
#include "me/types.h"
t_error builtin_pwd___(t_state *state, t_spawn_info info)
t_error builtin_pwd___(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
t_string s;
@ -24,5 +24,5 @@ t_error builtin_pwd___(t_state *state, t_spawn_info info)
string_reserve(&s, s.capacity * 2);
printf("%s\n", s.buf);
string_free(s);
return (NO_ERROR);
return (*exit_code = 0, NO_ERROR);
}

View file

@ -6,7 +6,7 @@
/* By: maiboyer <maiboyer@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/08/10 18:43:18 by maiboyer #+# #+# */
/* Updated: 2024/08/10 19:49:25 by maiboyer ### ########.fr */
/* Updated: 2024/08/11 11:26:16 by maiboyer ### ########.fr */
/* */
/* ************************************************************************** */
@ -16,7 +16,7 @@
#include "me/string/string.h"
#include "me/types.h"
t_error builtin_unset_(t_state *state, t_spawn_info info)
t_error builtin_unset_(t_state *state, t_builtin_spawn_info info, t_i32 *exit_code)
{
return (ERROR);
return (*exit_code = 0, ERROR);
}