|
|
@ -5,6 +5,7 @@
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <limits.h>
|
|
|
|
#include <limits.h>
|
|
|
|
#include <locale.h>
|
|
|
|
#include <locale.h>
|
|
|
|
|
|
|
|
#include <pwd.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdio.h>
|
|
|
@ -881,11 +882,23 @@ void
|
|
|
|
execsh(void) {
|
|
|
|
execsh(void) {
|
|
|
|
char **args;
|
|
|
|
char **args;
|
|
|
|
char *envshell = getenv("SHELL");
|
|
|
|
char *envshell = getenv("SHELL");
|
|
|
|
|
|
|
|
const struct passwd *pass = getpwuid(getuid());
|
|
|
|
|
|
|
|
char buf[sizeof(long) * 8 + 1];
|
|
|
|
|
|
|
|
|
|
|
|
unsetenv("COLUMNS");
|
|
|
|
unsetenv("COLUMNS");
|
|
|
|
unsetenv("LINES");
|
|
|
|
unsetenv("LINES");
|
|
|
|
unsetenv("TERMCAP");
|
|
|
|
unsetenv("TERMCAP");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(pass) {
|
|
|
|
|
|
|
|
setenv("LOGNAME", pass->pw_name, 1);
|
|
|
|
|
|
|
|
setenv("USER", pass->pw_name, 1);
|
|
|
|
|
|
|
|
setenv("SHELL", pass->pw_shell, 0);
|
|
|
|
|
|
|
|
setenv("HOME", pass->pw_dir, 0);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
snprintf(buf, sizeof(buf), "%lu", xw.win);
|
|
|
|
|
|
|
|
setenv("WINDOWID", buf, 1);
|
|
|
|
|
|
|
|
|
|
|
|
signal(SIGCHLD, SIG_DFL);
|
|
|
|
signal(SIGCHLD, SIG_DFL);
|
|
|
|
signal(SIGHUP, SIG_DFL);
|
|
|
|
signal(SIGHUP, SIG_DFL);
|
|
|
|
signal(SIGINT, SIG_DFL);
|
|
|
|
signal(SIGINT, SIG_DFL);
|
|
|
@ -2795,8 +2808,8 @@ main(int argc, char *argv[]) {
|
|
|
|
run:
|
|
|
|
run:
|
|
|
|
setlocale(LC_CTYPE, "");
|
|
|
|
setlocale(LC_CTYPE, "");
|
|
|
|
tnew(80, 24);
|
|
|
|
tnew(80, 24);
|
|
|
|
ttynew();
|
|
|
|
|
|
|
|
xinit();
|
|
|
|
xinit();
|
|
|
|
|
|
|
|
ttynew();
|
|
|
|
selinit();
|
|
|
|
selinit();
|
|
|
|
run();
|
|
|
|
run();
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|