CC = cc
CFLAGS = -Wall -Wextra -Werror
LIB_DIR = lib
-LIBS = -L $(LIB_DIR)/libft -lft
+LIBS = -L $(LIB_DIR)/libft -lft -lreadline
HEADERS = -I include -I $(LIB_DIR)/libft
VPATH := src
-SRC := main.c debug_tools.c
+SRC := main.c debug_tools.c init.c signal_handling.c repl.c
OBJ_DIR := _obj
OBJ := $(addprefix $(OBJ_DIR)/, $(SRC:%.c=%.o))
/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/22 17:14:49 by dkaiser #+# #+# */
-/* Updated: 2024/06/24 18:51:30 by dkaiser ### ########.fr */
+/* Updated: 2024/06/25 13:52:24 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
# include "debug_tools.h"
# include "libft.h"
+# include <stdio.h>
+# include <readline/readline.h>
+# include <signal.h>
+# include <stdlib.h>
+# include <termios.h>
+# include <unistd.h>
+
+int init(void);
+int init_signal_handling(void);
+
+void repl(const char *prompt);
#endif
/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/24 15:34:14 by dkaiser #+# #+# */
-/* Updated: 2024/06/25 12:48:20 by dkaiser ### ########.fr */
+/* Updated: 2024/06/25 13:13:18 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
--- /dev/null
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* init.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2024/06/24 15:02:24 by dkaiser #+# #+# */
+/* Updated: 2024/06/24 15:25:57 by dkaiser ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "minishell.h"
+
+static void init_terminal(void);
+
+int init(void)
+{
+ int result;
+
+ init_terminal();
+ result = init_signal_handling();
+ return (result);
+}
+
+static void init_terminal(void)
+{
+ struct termios term;
+
+ tcgetattr(0, &term);
+ term.c_lflag &= ~ECHOCTL;
+ tcsetattr(0, TCSANOW, &term);
+}
/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/06/22 17:14:03 by dkaiser #+# #+# */
-/* Updated: 2024/06/22 17:14:36 by dkaiser ### ########.fr */
+/* Updated: 2024/06/25 13:58:24 by dkaiser ### ########.fr */
/* */
/* ************************************************************************** */
int main(void)
{
- return (0);
+ if (init())
+ return (1);
+ repl("Minishell $ ");
}
--- /dev/null
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* repl.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2024/06/24 16:07:04 by dkaiser #+# #+# */
+/* Updated: 2024/06/25 13:50:19 by dkaiser ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "minishell.h"
+
+void repl(const char *prompt)
+{
+ char *input;
+
+ while (1)
+ {
+ input = readline(prompt);
+ if (input == NULL)
+ return ;
+ free(input);
+ }
+}
--- /dev/null
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* signal_handling.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2024/06/24 15:08:43 by dkaiser #+# #+# */
+/* Updated: 2024/06/25 13:33:26 by dkaiser ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "minishell.h"
+
+static void handle_sigint(int status);
+static void handle_sigquit(int status);
+
+int init_signal_handling(void)
+{
+ if (signal(SIGINT, &handle_sigint) == SIG_ERR)
+ return (1);
+ if (signal(SIGQUIT, &handle_sigquit) == SIG_ERR)
+ return (1);
+ return (0);
+}
+
+static void handle_sigint(__attribute__((unused)) int status)
+{
+ write(1, "\n", 1);
+ rl_replace_line("", 0);
+ rl_on_new_line();
+ rl_redisplay();
+}
+
+static void handle_sigquit(__attribute__((unused)) int status)
+{
+ rl_redisplay();
+}