Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/bin/csh Don't depend on common declarations.
details: https://anonhg.NetBSD.org/src/rev/0323b9ac60fe
branches: trunk
changeset: 970758:0323b9ac60fe
user: joerg <joerg%NetBSD.org@localhost>
date: Fri Apr 03 18:11:29 2020 +0000
description:
Don't depend on common declarations.
diffstat:
bin/csh/csh.c | 95 ++++++++++++++++++++++++++++++++++-
bin/csh/csh.h | 152 ++++++++++++++++++++++++++++----------------------------
bin/csh/dir.c | 6 +-
bin/csh/dir.h | 4 +-
bin/csh/proc.c | 15 ++++-
bin/csh/proc.h | 16 +++---
6 files changed, 196 insertions(+), 92 deletions(-)
diffs (truncated from 557 to 300 lines):
diff -r 4ea7a9926162 -r 0323b9ac60fe bin/csh/csh.c
--- a/bin/csh/csh.c Fri Apr 03 17:57:30 2020 +0000
+++ b/bin/csh/csh.c Fri Apr 03 18:11:29 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: csh.c,v 1.49 2020/01/12 18:36:55 christos Exp $ */
+/* $NetBSD: csh.c,v 1.50 2020/04/03 18:11:29 joerg Exp $ */
/*-
* Copyright (c) 1980, 1991, 1993
@@ -39,7 +39,7 @@
#if 0
static char sccsid[] = "@(#)csh.c 8.2 (Berkeley) 10/12/93";
#else
-__RCSID("$NetBSD: csh.c,v 1.49 2020/01/12 18:36:55 christos Exp $");
+__RCSID("$NetBSD: csh.c,v 1.50 2020/04/03 18:11:29 joerg Exp $");
#endif
#endif /* not lint */
@@ -77,6 +77,97 @@
* June, 1991
*/
+FILE *cshin, *cshout, *csherr;
+struct timespec time0;
+struct rusage ru0;
+struct varent shvhed, aliases;
+Char HISTSUB;
+int editing;
+
+int child;
+int chkstop;
+int didfds;
+int doneinp;
+int exiterr;
+int haderr;
+int havhash;
+int intact;
+int intty;
+int justpr;
+int loginsh;
+int neednote;
+int noexec;
+int pjobs;
+int setintr;
+int timflg;
+
+Char *arginp;
+Char *ffile;
+int onelflg;
+Char *shtemp;
+
+time_t chktim;
+Char *doldol;
+pid_t backpid;
+gid_t egid, gid;
+uid_t euid, uid;
+int shpgrp;
+int tpgrp;
+
+int opgrp;
+
+int SHIN;
+int SHOUT;
+int SHERR;
+int OLDSTD;
+
+jmp_buf reslab;
+
+Char *gointr;
+
+sig_t parintr;
+sig_t parterm;
+
+struct Bin B;
+
+struct Ain lineloc;
+int cantell;
+Char *lap;
+struct whyle *whyles;
+
+struct wordent *alhistp,*alhistt;
+
+int AsciiOnly;
+int gflag;
+long pnleft;
+Char *pargs;
+Char *pargcp;
+struct Hist Histlist;
+struct wordent paraml;
+int eventno;
+int lastev;
+Char HIST;
+Char HISTSUB;
+const char *bname;
+Char *Vsav;
+Char *Vdp;
+Char *Vexpath;
+char **Vt;
+Char **evalvec;
+Char *evalp;
+Char *word_chars;
+Char *STR_SHELLPATH;
+#ifdef _PATH_BSHELL
+Char *STR_BSHELL;
+#endif
+Char *STR_WORD_CHARS;
+Char **STR_environ;
+#ifdef EDIT
+EditLine *el;
+History *hi;
+#endif
+int editing;
+
Char *dumphist[] = {STRhistory, STRmh, 0, 0};
Char *tildehist[] = {STRsource, STRmh, STRtildothist, 0};
diff -r 4ea7a9926162 -r 0323b9ac60fe bin/csh/csh.h
--- a/bin/csh/csh.h Fri Apr 03 17:57:30 2020 +0000
+++ b/bin/csh/csh.h Fri Apr 03 18:11:29 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: csh.h,v 1.28 2019/01/05 16:54:00 christos Exp $ */
+/* $NetBSD: csh.h,v 1.29 2020/04/03 18:11:29 joerg Exp $ */
/*-
* Copyright (c) 1980, 1991, 1993
@@ -89,7 +89,7 @@
#define xcalloc(n, s) Calloc(n, s)
#include <stdio.h>
-FILE *cshin, *cshout, *csherr;
+extern FILE *cshin, *cshout, *csherr;
#define isdir(d) (S_ISDIR(d.st_mode))
@@ -103,22 +103,22 @@
/*
* Global flags
*/
-int child; /* Child shell ... errors cause exit */
-int chkstop; /* Warned of stopped jobs... allow exit */
-int didfds; /* Have setup i/o fd's for child */
-int doneinp; /* EOF indicator after reset from readc */
-int exiterr; /* Exit if error or non-zero exit status */
-int haderr; /* Reset was because of an error */
-int havhash; /* path hashing is available */
-int intact; /* We are interactive... therefore prompt */
-int intty; /* Input is a tty */
-int justpr; /* Just print because of :p hist mod */
-int loginsh; /* We are a loginsh -> .login/.logout */
-int neednote; /* Need to pnotify() */
-int noexec; /* Don't execute, just syntax check */
-int pjobs; /* want to print jobs if interrupted */
-int setintr; /* Set interrupts on/off -> Wait intr... */
-int timflg; /* Time the next waited for command */
+extern int child; /* Child shell ... errors cause exit */
+extern int chkstop; /* Warned of stopped jobs... allow exit */
+extern int didfds; /* Have setup i/o fd's for child */
+extern int doneinp; /* EOF indicator after reset from readc */
+extern int exiterr; /* Exit if error or non-zero exit status */
+extern int haderr; /* Reset was because of an error */
+extern int havhash; /* path hashing is available */
+extern int intact; /* We are interactive... therefore prompt */
+extern int intty; /* Input is a tty */
+extern int justpr; /* Just print because of :p hist mod */
+extern int loginsh; /* We are a loginsh -> .login/.logout */
+extern int neednote; /* Need to pnotify() */
+extern int noexec; /* Don't execute, just syntax check */
+extern int pjobs; /* want to print jobs if interrupted */
+extern int setintr; /* Set interrupts on/off -> Wait intr... */
+extern int timflg; /* Time the next waited for command */
#ifdef FILEC
extern int filec; /* doing filename expansion */
@@ -127,33 +127,33 @@
/*
* Global i/o info
*/
-Char *arginp; /* Argument input for sh -c and internal `xx` */
-Char *ffile; /* Name of shell file for $0 */
-int onelflg; /* 2 -> need line for -t, 1 -> exit on read */
+extern Char *arginp; /* Argument input for sh -c and internal `xx` */
+extern Char *ffile; /* Name of shell file for $0 */
+extern int onelflg; /* 2 -> need line for -t, 1 -> exit on read */
extern char *seterr; /* Error message from scanner/parser */
-Char *shtemp; /* Temp name for << shell files in /tmp */
+extern Char *shtemp; /* Temp name for << shell files in /tmp */
#include <sys/resource.h>
#include <sys/time.h>
#include <sys/types.h>
-struct timespec time0; /* Time at which the shell started */
-struct rusage ru0;
+extern struct timespec time0; /* Time at which the shell started */
+extern struct rusage ru0;
/*
* Miscellany
*/
-time_t chktim; /* Time mail last checked */
-Char *doldol; /* Character pid for $$ */
-pid_t backpid; /* Pid of the last background process */
-gid_t egid, gid; /* Invokers gid */
-uid_t euid, uid; /* Invokers uid */
-int shpgrp; /* Pgrp of shell */
-int tpgrp; /* Terminal process group */
+extern time_t chktim; /* Time mail last checked */
+extern Char *doldol; /* Character pid for $$ */
+extern pid_t backpid; /* Pid of the last background process */
+extern gid_t egid, gid; /* Invokers gid */
+extern uid_t euid, uid; /* Invokers uid */
+extern int shpgrp; /* Pgrp of shell */
+extern int tpgrp; /* Terminal process group */
/* If tpgrp is -1, leave tty alone! */
-int opgrp; /* Initial pgrp and tty pgrp */
+extern int opgrp; /* Initial pgrp and tty pgrp */
/*
@@ -163,10 +163,10 @@
* (this saves work) but for version 6, this is not usually possible.
* The desired initial values for these descriptors are F{SHIN,...}.
*/
-int SHIN; /* Current shell input (script) */
-int SHOUT; /* Shell output */
-int SHERR; /* Diagnostic output... shell errs go here */
-int OLDSTD; /* Old standard input (def for cmds) */
+extern int SHIN; /* Current shell input (script) */
+extern int SHOUT; /* Shell output */
+extern int SHERR; /* Diagnostic output... shell errs go here */
+extern int OLDSTD; /* Old standard input (def for cmds) */
/*
* Error control
@@ -177,7 +177,7 @@
*/
#include <setjmp.h>
-jmp_buf reslab;
+extern jmp_buf reslab;
#define setexit() (setjmp(reslab))
#define reset() longjmp(reslab, 1)
@@ -185,11 +185,11 @@
#define getexit(a) (void)memcpy((a), reslab, sizeof reslab)
#define resexit(a) (void)memcpy(reslab, (a), sizeof reslab)
-Char *gointr; /* Label for an onintr transfer */
+extern Char *gointr; /* Label for an onintr transfer */
#include <signal.h>
-sig_t parintr; /* Parents interrupt catch */
-sig_t parterm; /* Parents terminate catch */
+extern sig_t parintr; /* Parents interrupt catch */
+extern sig_t parterm; /* Parents terminate catch */
/*
* Lexical definitions.
@@ -210,7 +210,7 @@
#define TRIM ((Char)0x7f) /* Mask to strip quote bit */
#endif
-int AsciiOnly; /* If set only 7 bits is expected in characters */
+extern int AsciiOnly; /* If set only 7 bits is expected in characters */
/*
* Each level of input has a buffered input structure.
@@ -219,13 +219,13 @@
* In other cases, the shell buffers enough blocks to keep all loops
* in the buffer.
*/
-struct Bin {
+extern struct Bin {
off_t Bfseekp; /* Seek pointer */
off_t Bfbobp; /* Seekp of beginning of buffers */
off_t Bfeobp; /* Seekp of end of buffers */
int Bfblocks; /* Number of buffer blocks */
Char **Bfbuf; /* The array of buffer blocks */
-} B;
+} B;
/*
* This structure allows us to seek inside aliases
@@ -243,7 +243,7 @@
#define f_seek fc._f_seek
#define c_seek fc._c_seek
Char **a_seek;
-} ;
+};
extern int aret; /* What was the last character returned */
#define SEEKEQ(a, b) ((a)->type == (b)->type && \
(a)->f_seek == (b)->f_seek && \
@@ -260,9 +260,9 @@
* For whiles, in particular, it reseeks to the beginning of the
* line the while was on; hence the while placement restrictions.
*/
-struct Ain lineloc;
+extern struct Ain lineloc;
Home |
Main Index |
Thread Index |
Old Index