This commit is contained in:
Loic Deridder
2025-02-12 13:48:54 +01:00
parent 256724e601
commit 3ac1625f5a
12 changed files with 89 additions and 61 deletions

View File

@@ -14,7 +14,7 @@
int execute_command(t_ast_n *node)
{
if (!node || (node->state == _CMD && node->cmd == NULL))
if (!node || (node->state == _CMD && node->cmd == NULL))
return (0);
if (node->state == _CMD)
handle_redir(node);

View File

@@ -13,6 +13,7 @@
#include "../includes/minishell.h"
#include <readline/history.h>
#include <readline/readline.h>
#include <termios.h>
static void add_prevhistory(t_msh *msh)
{
@@ -49,13 +50,13 @@ int interactive_mode(t_msh *msh)
int main(int ac, char **av, char **envp)
{
t_msh *msh;
struct termios term;
t_msh *msh;
struct termios term;
(void)av;
tcgetattr(STDIN_FILENO, &term);
term.c_cc[VQUIT] = _POSIX_VDISABLE;
tcsetattr(STDIN_FILENO, TCSANOW, &term);
tcgetattr(STDIN_FILENO, &term);
term.c_cc[VQUIT] = _POSIX_VDISABLE;
tcsetattr(STDIN_FILENO, TCSANOW, &term);
msh = init_msh(envp);
init_sig();
add_prevhistory(msh);

View File

@@ -72,13 +72,7 @@ void read_hereinput(char *limiter, t_node *lst, t_msh *msh)
ft_fprintf(2, "heredoc> ");
r = read(0, &c, 1);
if (r == 0)
{
ft_fprintf(2, "\n");
ft_fprintf(1, "%s\n", limiter);
free_linked_list(lst);
free_msh(msh);
exit(EXIT_SUCCESS);
}
exit_heredoc(limiter, msh, lst);
while (r && c != '\n' && c != '\0')
{
if (c != '\n' && c != '\0')
@@ -87,12 +81,7 @@ void read_hereinput(char *limiter, t_node *lst, t_msh *msh)
}
buf[i] = '\0';
if (ft_strncmp(buf, limiter, ft_strlen(limiter)) == 0)
{
ft_fprintf(1, "%s\n", buf);
free_msh(msh);
free_linked_list(lst);
exit(EXIT_SUCCESS);
}
end_heredoc(buf, msh, lst);
buf[i++] = '\n';
buf[i] = '\0';
ft_fprintf(1, "%s", buf);
@@ -128,7 +117,7 @@ void parse_heredoc(char *limiter, t_node *lst, t_msh *msh)
void create_heredoc(t_node *lst, t_msh *msh)
{
t_node *tmp;
t_node *tmp;
tmp = lst;
while (lst)

View File

@@ -0,0 +1,30 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* heredoc_utils.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: lderidde <lderidde@student.s19.be> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/02/12 13:41:03 by lderidde #+# #+# */
/* Updated: 2025/02/12 13:41:03 by lderidde ### ########.fr */
/* */
/* ************************************************************************** */
#include "../../includes/minishell.h"
void exit_heredoc(char *limiter, t_msh *msh, t_node *lst)
{
ft_fprintf(2, "\n");
ft_fprintf(1, "%s\n", limiter);
free_linked_list(lst);
free_msh(msh);
exit(EXIT_SUCCESS);
}
void end_heredoc(char *buf, t_msh *msh, t_node *lst)
{
ft_fprintf(1, "%s\n", buf);
free_msh(msh);
free_linked_list(lst);
exit(EXIT_SUCCESS);
}

View File

@@ -11,6 +11,7 @@
/* ************************************************************************** */
#include "../includes/minishell.h"
#include <sys/ioctl.h>
static void handle_input(char *in, t_msh *msh)
{
@@ -50,16 +51,17 @@ char *get_pwd(void)
char *powerline(t_msh *msh)
{
char *pwd;
char *input;
char *prompt;
char *separator;
struct winsize w;
char *pwd;
char *input;
char *prompt;
char *separator;
struct winsize w;
ioctl(STDOUT_FILENO, TIOCGWINSZ, &w);
ioctl(STDOUT_FILENO, TIOCGWINSZ, &w);
pwd = get_pwd();
separator = rep_c('-', w.ws_col);
prompt = ft_sprintf("%s%s%s\n%s  MMOAT %s%s %s%s %s%s%s ", SEP, separator, RESET, POW1, POW2, POW3,
prompt = ft_sprintf("%s%s%s\n%s  MMOAT %s%s %s%s %s%s%s ",
SEP, separator, RESET, POW1, POW2, POW3,
POW4, pwd, RESET, POW5, RESET);
input = readline(prompt);
handle_input(input, msh);

View File

@@ -43,5 +43,4 @@ void handle_sigint(int sig)
void handle_sigquit(int sig)
{
(void)sig;
// ft_printf("\b\b");
}