Shell: Ignore SIGTTOU and set pgroup from parent instead of child

This allows using the shell in linux!
This commit is contained in:
Bananymous 2024-10-04 17:23:31 +03:00
parent b6e040dfc2
commit 26d6bf338e
1 changed files with 17 additions and 18 deletions

View File

@ -4,11 +4,14 @@
#include <BAN/Vector.h> #include <BAN/Vector.h>
#include <ctype.h> #include <ctype.h>
#include <limits.h>
#include <pwd.h> #include <pwd.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <sys/stat.h> #include <sys/stat.h>
#include <sys/wait.h>
#include <termios.h> #include <termios.h>
#include <time.h>
#include <unistd.h> #include <unistd.h>
#define ERROR_RETURN(__msg, __ret) do { perror(__msg); return __ret; } while (false) #define ERROR_RETURN(__msg, __ret) do { perror(__msg); return __ret; } while (false)
@ -483,24 +486,6 @@ pid_t execute_command_no_wait(BAN::Vector<BAN::String>& args, int fd_in, int fd_
close(fd_out); close(fd_out);
} }
if (pgrp == 0)
{
if(setpgid(0, 0) == -1)
{
perror("setpgid");
exit(1);
}
if (isatty(0) && tcsetpgrp(0, getpgrp()) == -1)
{
perror("tcsetpgrp");
exit(1);
}
}
else
{
setpgid(0, pgrp);
}
execv(executable_file.data(), cmd_args.data()); execv(executable_file.data(), cmd_args.data());
perror("execv"); perror("execv");
exit(1); exit(1);
@ -509,6 +494,18 @@ pid_t execute_command_no_wait(BAN::Vector<BAN::String>& args, int fd_in, int fd_
if (pid == -1) if (pid == -1)
ERROR_RETURN("fork", -1); ERROR_RETURN("fork", -1);
if (pgrp == 0 && isatty(0))
{
if(setpgid(pid, pid) == -1)
perror("setpgid");
if (tcsetpgrp(0, pid) == -1)
perror("tcsetpgrp");
}
else
{
setpgid(pid, pgrp);
}
return pid; return pid;
} }
@ -791,6 +788,8 @@ int main(int argc, char** argv)
if (signal(SIGINT, [](int) {}) == SIG_ERR) if (signal(SIGINT, [](int) {}) == SIG_ERR)
perror("signal"); perror("signal");
if (signal(SIGTTOU, SIG_IGN) == SIG_ERR)
perror("signal");
tcgetattr(0, &old_termios); tcgetattr(0, &old_termios);