forked from Bananymous/banan-os
Shell: Ignore SIGTTOU and set pgroup from parent instead of child
This allows using the shell in linux!
This commit is contained in:
parent
b6e040dfc2
commit
26d6bf338e
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue