From f827cd182725ae93b3db454a2d0fc75b5d4cd81d Mon Sep 17 00:00:00 2001 From: Chuck Coffing Date: Mon, 15 Jan 2024 20:04:40 -0800 Subject: [PATCH 1/2] Modernize and improve portability of screen - O_NDELAY is more standard than FNDELAY - Fix sig handler prototypes - Clean up errno - Use PATH_MAX - Standardize gethostname prototype - Fix usage of ELKS so compiles on Linux too - etc... --- elkscmd/screen/ansi.c | 2 +- elkscmd/screen/screen.c | 92 +++++++++++++++++------------------------ elkscmd/screen/screen.h | 5 +-- 3 files changed, 42 insertions(+), 57 deletions(-) diff --git a/elkscmd/screen/ansi.c b/elkscmd/screen/ansi.c index 89c799bb1..2273d26dd 100644 --- a/elkscmd/screen/ansi.c +++ b/elkscmd/screen/ansi.c @@ -15,7 +15,7 @@ char AnsiVersion[] = "ansi 2.0a (ELKS) 25-Apr-2020"; #include #include #include -#include +#include #include #include #include "screen.h" diff --git a/elkscmd/screen/screen.c b/elkscmd/screen/screen.c index 9d0610dc4..ae0f48b48 100644 --- a/elkscmd/screen/screen.c +++ b/elkscmd/screen/screen.c @@ -16,32 +16,31 @@ static char ScreenVersion[] = "screen 2.0a.2 (ELKS) 30-Apr-2020"; -#include -#include +#include #include -#include #include -#include -#include #include +#include +#include +#include +#include +#include +#include #include -#include -#include #include #include +#include #include +#include +#include #include -#include #ifdef ELKS -#include #include -#define SIGTTOU 27 /* background tty write attempted */ #else -#include -#include -#include -#include +#include +#define OPEN_MAX 1024 +extern char **environ; #endif #ifdef UTMP @@ -78,12 +77,12 @@ extern int status; extern time_t TimeDisplayed; extern char AnsiVersion[]; extern int flowctl; -extern int errno; extern int sys_nerr; extern char *MakeTermcap(int aflag); extern char *getlogin(void); -static int AttacherFinit(void); -static int SigHup(void); +static void AttacherFinit(int signum); +static void SigChld(int signum); +static void SigHup(int signum); static char *MakeBellMsg(int n); static char *GetTtyName(void); static char PtyName[32], TtyName[32]; @@ -98,7 +97,7 @@ static char DefaultPath[] = ":/bin:/usr/bin"; static char PtyProto[] = "/dev/ptyXY"; static char TtyProto[] = "/dev/ttyXY"; static int TtyMode = 0622; -static char SockPath[512]; +static char SockPath[PATH_MAX]; static char SockDir[] = "screen"; static char *SockNamePtr, *SockName; static int ServerSocket; @@ -207,7 +206,7 @@ main(int ac, char **av) struct timeval tv; time_t now; char buf[IOSIZE], *myname = (ac == 0) ? "screen" : av[0]; - char rc[256]; + char rc[PATH_MAX]; struct stat st; while (ac > 0) { @@ -295,7 +294,6 @@ main(int ac, char **av) } gethostname(HostName, MAXSTR); - HostName[MAXSTR - 1] = '\0'; if ((ap = strchr(HostName, '.'))) *ap = '\0'; strcat(SockPath, "/"); @@ -354,7 +352,9 @@ main(int ac, char **av) signal(SIGTERM, Finit); #ifdef BSDJOBS signal(SIGTTIN, SIG_IGN); +#ifdef SIGTTOU signal(SIGTTOU, SIG_IGN); +#endif #endif InitKeytab(); if ((n = MakeWindow(*av, av, aflag, 0, (char *)0)) == -1) { @@ -365,7 +365,7 @@ main(int ac, char **av) Msg(0, "MakeWindow failed"); exit(1); } - sprintf(rc, "%.*s/.screenrc", 245, home); + sprintf(rc, "%.*s/.screenrc", PATH_MAX - 11, home); /* TODO better limit for PATH_MAX */ ReadRc(rc); /* need to allocate memory for win0 first */ SetCurrWindow(n); HasWindow = 1; @@ -504,18 +504,16 @@ SigHandler(void) return 0; } -static int -SigChld(void) +static void +SigChld(int signum) { GotSignal = 1; - return 0; } -static int -SigHup(void) +static void +SigHup(int signum) { Detach(0); - return 0; } static int @@ -566,11 +564,11 @@ CheckWindows(void) return; } } - Finit(); + Finit(0); } -static int -Finit(void) +static void +Finit(int signum) { struct win *p, **pp; @@ -679,7 +677,7 @@ ProcessInput(char *buf, int len) for (pp = wtab; pp < wtab + MAXWIN; ++pp) if (*pp) FreeWindow(*pp); - Finit(); + Finit(0); /* NOTREACHED */ case KEY_DETACH: p = buf; @@ -860,7 +858,7 @@ MakeWindow(char *prog, char **args, int aflag, int StartAt, char *dir) Msg(0, "No more PTYs."); return -1; } - fcntl(f, F_SETFL, FNDELAY); + fcntl(f, F_SETFL, O_NDELAY); if ((p = *pp = (struct win *)malloc(sizeof(struct win))) == 0) { nomem: @@ -925,7 +923,9 @@ MakeWindow(char *prog, char **args, int aflag, int StartAt, char *dir) signal(SIGQUIT, SIG_DFL); signal(SIGTERM, SIG_DFL); signal(SIGTTIN, SIG_DFL); +#ifdef SIGTTOU signal(SIGTTOU, SIG_DFL); +#endif setuid(getuid()); setgid(getgid()); if (dir && chdir(dir) == -1) { @@ -1011,7 +1011,7 @@ WriteFile(int dump) int i, j, k; char *p; FILE *f; - char fn[1024]; + char fn[PATH_MAX]; int pid, s; if (dump) @@ -1253,17 +1253,16 @@ Attach(int how) return 0; } -static int -AttacherFinit(void) +static void +AttacherFinit(int signum) { exit(0); } -static int -ReAttach(void) +static void +ReAttach(int signum) { Attach(MSG_CONT); - return 0; } static void @@ -1923,26 +1922,13 @@ register len; { #endif int -gethostname(char *host, int size) +gethostname(char *host, size_t size) { strncpy(host, "elks", size); + host[size - 1] = '\0'; return 0; } -#ifndef GETPGID -gid_t -getpgid(pid_t pid){ - return pid; -} -#endif - -#ifndef SETPGID -void -setpgid(pid_t pid) -{ -} -#endif - static int enableRawMode(int fd) { diff --git a/elkscmd/screen/screen.h b/elkscmd/screen/screen.h index d6f8e3136..a85e91a4b 100644 --- a/elkscmd/screen/screen.h +++ b/elkscmd/screen/screen.h @@ -111,7 +111,6 @@ struct mode { }; static int SigHandler(void); -static int SigChld(void); static int DoWait(void); static void CheckWindows(void); static int ProcessInput(char *buf, int len); @@ -157,7 +156,7 @@ static int ShowInfo(void); static void screen_execvpe(char *prog, char **args, char **env); static void WriteFile(int dump); static void KillWindow(struct win **pp); -static int Finit(void); +static void Finit(int signum); static int InitKeytab(void); int InitTerm(void); int FinitTerm(void); @@ -167,7 +166,7 @@ void DoESC(int c, int intermediate); int ResetScreen(struct win *p); void RemoveStatus(struct win *p); int MakeStatus(char *msg, struct win *wp); -int gethostname(char *host, int size); +int gethostname(char *host, size_t size); static int enableRawMode(int fd); static void disableRawMode(int fd); From e63b610b8edec9ee1e7ddd493e7d13d590519b03 Mon Sep 17 00:00:00 2001 From: Chuck Coffing Date: Mon, 15 Jan 2024 20:04:46 -0800 Subject: [PATCH 2/2] Fix warnings in screen --- elkscmd/screen/ansi.c | 3 +++ elkscmd/screen/ansi.h | 2 -- elkscmd/screen/screen.c | 57 ++++++++++++++++++++++++++++++++++++----- elkscmd/screen/screen.h | 51 ------------------------------------ 4 files changed, 54 insertions(+), 59 deletions(-) diff --git a/elkscmd/screen/ansi.c b/elkscmd/screen/ansi.c index 2273d26dd..732bdd3e3 100644 --- a/elkscmd/screen/ansi.c +++ b/elkscmd/screen/ansi.c @@ -51,6 +51,9 @@ enum move_t { extern char *getenv(), *tgetstr(), *tgoto(); +static void RedisplayLine(char *os, char *oa, char *of, int y, int from, int to); +static void DisplayLine(char *os, char *oa, char *of, char *s, char *as, char *fs, int y, int from, int to); + int rows, cols; int status; int flowctl; diff --git a/elkscmd/screen/ansi.h b/elkscmd/screen/ansi.h index 8a6c6aec2..f71a54ee4 100644 --- a/elkscmd/screen/ansi.h +++ b/elkscmd/screen/ansi.h @@ -9,7 +9,6 @@ int InitTerm(void); int FinitTerm(void); static int AddCap(char *s); char *MakeTermcap(int aflag); -static void DisplayLine(char *os, char *oa, char *of, char *s, char *as, char *fs, int y, int from, int to); static int MakeString(char *cap, char *buf, char *s); static int Special(int c); static int DoCSI(int c, int intermediate); @@ -64,7 +63,6 @@ static int SaveAttr(int newattr); static int RestoreAttr(int oldattr); static int FillWithEs(void); static int Redisplay(void); -static void RedisplayLine(char *os, char *oa, char *of, int y, int from, int to); static int MakeBlankLine(char *p, int n); int Activate(struct win *wp); diff --git a/elkscmd/screen/screen.c b/elkscmd/screen/screen.c index ae0f48b48..0a7349b37 100644 --- a/elkscmd/screen/screen.c +++ b/elkscmd/screen/screen.c @@ -70,6 +70,52 @@ static char ttys[] = "/etc/ttys"; #define Ctrl(c) ((c)&037) +static int SigHandler(void); +static int DoWait(void); +static void CheckWindows(void); +static int ProcessInput(char *buf, int len); +static void SwitchWindow(int n); +static int SetCurrWindow(int n); +static int NextWindow(void); +static int PreviousWindow(void); +static int FreeWindow(struct win *wp); +static int ShowWindows(void); +static int MakeServerSocket(void); +static int MakeClientSocket(int err); +static int SendCreateMsg(int s, int ac, char **av, int aflag); +static int SendErrorMsg(char *fmt,...); +static void ReceiveMsg(int s); +static int ExecCreate(struct msg *mp); +static void ReadRc(char *fn); +static int Parse(char *fn, char *buf, char **args); +static char **SaveArgs(int argc, char **argv); +static int MakeNewEnv(void); +static int IsSymbol(char *e, char *s); +static char *Filename(char *s); +static int IsNum(char *s, int base); +static int RemoveUtmp(int slot); +static int SetUtmp(char *name); +static int InitUtmp(void); +static int MoreWindows(void); +static int MakeWindow(char *prog, char **args, int aflag, int StartAt, char *dir); +static int GetSockName(void); +static int Kill(int pid, int sig); +static void Attacher(void); +static int Attach(int how); +static void Detach(int suspend); +static int SetTTY(int fd, struct mode *mp); +static int GetTTY(int fd, struct mode *mp); +static int ShowInfo(void); +static void screen_execvpe(char *prog, char **args, char **env); +static void WriteFile(int dump); +static void KillWindow(struct win **pp); +static void Finit(int signum); +static int InitKeytab(void); +static int enableRawMode(int fd); +static void disableRawMode(int fd); +static void brktty(void); +static void freetty(void); + extern char *blank, Term[]; extern int rows, cols; extern int ISO2022; @@ -77,7 +123,6 @@ extern int status; extern time_t TimeDisplayed; extern char AnsiVersion[]; extern int flowctl; -extern int sys_nerr; extern char *MakeTermcap(int aflag); extern char *getlogin(void); static void AttacherFinit(int signum); @@ -94,8 +139,6 @@ static int ESCseen; static int GotSignal; static char DefaultShell[] = "/bin/sh"; static char DefaultPath[] = ":/bin:/usr/bin"; -static char PtyProto[] = "/dev/ptyXY"; -static char TtyProto[] = "/dev/ttyXY"; static int TtyMode = 0622; static char SockPath[PATH_MAX]; static char SockDir[] = "screen"; @@ -106,9 +149,11 @@ static char Esc = Ctrl('a'); static char MetaEsc = 'a'; static char *home; static int HasWindow; +#ifdef UTMP static int utmp, utmpf; static char UtmpName[] = "/etc/utmp"; static char *LoginName; +#endif static char *BellString = "Bell in window %"; static int mflag, nflag, fflag, rflag; static char HostName[MAXSTR]; @@ -199,7 +244,7 @@ main(int ac, char **av) int n, len; struct win **pp, *p; char *ap; - int s, x = 0; + int s; fd_set r_readfd, w_writefd, e_errfd; int aflag = 0; int lflag = 0; @@ -766,7 +811,7 @@ SetCurrWindow(int n) return 0; } -int +static int NextWindow(void) { struct win **pp; @@ -1746,7 +1791,7 @@ static char * MakeBellMsg(int n) { static char buf[MAXSTR]; - char *p = buf, *s = BellString; + char *p = buf, *s; for (s = BellString; *s && p < buf + MAXSTR - 1; s++) *p++ = (*s == '%') ? n + '0' : *s; diff --git a/elkscmd/screen/screen.h b/elkscmd/screen/screen.h index a85e91a4b..59515c314 100644 --- a/elkscmd/screen/screen.h +++ b/elkscmd/screen/screen.h @@ -110,54 +110,9 @@ struct mode { #endif }; -static int SigHandler(void); -static int DoWait(void); -static void CheckWindows(void); -static int ProcessInput(char *buf, int len); -static void SwitchWindow(int n); -static int SetCurrWindow(int n); -int NextWindow(void); -static int PreviousWindow(void); -static int FreeWindow(struct win *wp); -static int ShowWindows(void); -static void DisplayLine(char *, char *, char *, char *, char *, char *, int, int, int); -static void RedisplayLine(char *, char *, char *, int, int, int); - -static int CheckSockName(int client); -static int MakeServerSocket(void); -static int MakeClientSocket(int err); -static int SendCreateMsg(int s, int ac, char **av, int aflag); -static int SendErrorMsg(char *fmt,...); -static void ReceiveMsg(int s); -static int ExecCreate(struct msg *mp); -static void ReadRc(char *fn); -static int Parse(char *fn, char *buf, char **args); -static char **SaveArgs(int argc, char **argv); -static int MakeNewEnv(void); -static int IsSymbol(char *e, char *s); void Msg(int err, char *fmt,...); int bclear(char *p, int n); -static char *Filename(char *s); -static int IsNum(char *s, int base); -static int RemoveUtmp(int slot); -static int SetUtmp(char *name); -static int InitUtmp(void); -static int MoreWindows(void); -int MakeWindow(char *prog, char **args, int aflag, int StartAt, char *dir); -static int GetSockName(void); -static int Kill(int pid, int sig); -static void Attacher(void); -static int Attach(int how); -static void Detach(int suspend); -static int SetTTY(int fd, struct mode *mp); -static int GetTTY(int fd, struct mode *mp); -static int ShowInfo(void); -static void screen_execvpe(char *prog, char **args, char **env); -static void WriteFile(int dump); -static void KillWindow(struct win **pp); -static void Finit(int signum); -static int InitKeytab(void); int InitTerm(void); int FinitTerm(void); void WriteString(struct win *wp, char *buf, int len); @@ -168,12 +123,6 @@ void RemoveStatus(struct win *p); int MakeStatus(char *msg, struct win *wp); int gethostname(char *host, size_t size); -static int enableRawMode(int fd); -static void disableRawMode(int fd); - -static void brktty(void); -static void freetty(void); - void exit_with_usage(char *myname); int display_help(void);