Annotation of 40BSD/cmd/oldcsh/sh.err.c, revision 1.1

1.1     ! root        1: /* Copyright (c) 1979 Regents of the University of California */
        !             2: #include "sh.h"
        !             3: 
        !             4: /*
        !             5:  * C Shell
        !             6:  */
        !             7: 
        !             8: bool   errspl;                 /* Argument to error was spliced by seterr2 */
        !             9: char   one[2] = { '1', 0 };
        !            10: char   *onev[2] = { one, NOSTR };
        !            11: /*
        !            12:  * Print error string s with optional argument arg.
        !            13:  * This routine always resets or exits.  The flag haderr
        !            14:  * is set so the routine who catches the unwind can propogate
        !            15:  * it if they want.
        !            16:  *
        !            17:  * Note that any open files at the point of error will eventually
        !            18:  * be closed in the routine process in sh.c which is the only
        !            19:  * place error unwinds are ever caught.
        !            20:  */
        !            21: error(s, arg)
        !            22:        char *s;
        !            23: {
        !            24:        register char **v;
        !            25:        register char *ep;
        !            26: 
        !            27:        /*
        !            28:         * Must flush before we print as we wish output before the error
        !            29:         * to go on (some form of) standard output, while output after
        !            30:         * goes on (some form of) diagnostic output.
        !            31:         * If didfds then output will go to 1/2 else to FSHOUT/FSHDIAG.
        !            32:         * See flush in sh.print.c.
        !            33:         */
        !            34:        flush();
        !            35:        haderr = 1;             /* Now to diagnostic output */
        !            36:        timflg = 0;             /* This isn't otherwise reset */
        !            37:        if (v = pargv)
        !            38:                pargv = 0, blkfree(v);
        !            39:        if (v = gargv)
        !            40:                gargv = 0, blkfree(v);
        !            41: 
        !            42:        /*
        !            43:         * A zero arguments causes no printing, else print
        !            44:         * an error diagnostic here.
        !            45:         */
        !            46:        if (s)
        !            47:                printf(s, arg), printf(".\n");
        !            48: 
        !            49:        didfds = 0;             /* Forget about 0,1,2 */
        !            50:        if ((ep = err) && errspl) {
        !            51:                errspl = 0;
        !            52:                xfree(ep);
        !            53:        }
        !            54:        errspl = 0;
        !            55: 
        !            56:        /*
        !            57:         * Reset the state of the input.
        !            58:         * This buffered seek to end of file will also
        !            59:         * clear the while/foreach stack.
        !            60:         */
        !            61:        btoeof();
        !            62: 
        !            63:        /*
        !            64:         * Go away if -e or we are a child shell
        !            65:         */
        !            66:        if (exiterr || child)
        !            67:                exit(1);
        !            68: 
        !            69:        setq("status", onev, &shvhed);
        !            70:        reset();                /* Unwind */
        !            71: }
        !            72: 
        !            73: /*
        !            74:  * Perror is the shells version of perror which should otherwise
        !            75:  * never be called.
        !            76:  */
        !            77: Perror(s)
        !            78:        char *s;
        !            79: {
        !            80: 
        !            81:        /*
        !            82:         * Perror uses unit 2, thus if we didn't set up the fd's
        !            83:         * we must set up unit 2 now else the diagnostic will disappear
        !            84:         */
        !            85:        if (!didfds) {
        !            86:                register int oerrno = errno;
        !            87: 
        !            88:                dcopy(SHDIAG, 2);
        !            89:                errno = oerrno;
        !            90:        }
        !            91:        perror(s);
        !            92:        error(0);               /* To exit or unwind */
        !            93: }
        !            94: 
        !            95: /*
        !            96:  * For builtin functions, the routine bferr may be called
        !            97:  * to print a diagnostic of the form:
        !            98:  *     name: Diagnostic.
        !            99:  * where name has been setup by setname.
        !           100:  * (Made into a macro to save space)
        !           101:  *
        !           102: char   *bname;
        !           103: 
        !           104: setname(cp)
        !           105:        char *cp;
        !           106: {
        !           107: 
        !           108:        bname = cp;
        !           109: }
        !           110:  */
        !           111: 
        !           112: bferr(cp)
        !           113:        char *cp;
        !           114: {
        !           115: 
        !           116:        flush();
        !           117:        haderr = 1;
        !           118:        printf("%s: ", bname);
        !           119:        error(cp);
        !           120: }
        !           121: 
        !           122: /*
        !           123:  * The parser and scanner set up errors for later by calling seterr,
        !           124:  * which sets the variable err as a side effect; later to be tested,
        !           125:  * e.g. in process.
        !           126:  */
        !           127: seterr(s)
        !           128:        char *s;
        !           129: {
        !           130: 
        !           131:        if (err == 0)
        !           132:                err = s, errspl = 0;
        !           133: }
        !           134: 
        !           135: /* Set err to a splice of cp and dp, to be freed later in error() */
        !           136: seterr2(cp, dp)
        !           137:        char *cp, *dp;
        !           138: {
        !           139: 
        !           140:        if (err)
        !           141:                return;
        !           142:        err = strspl(cp, dp);
        !           143:        errspl++;
        !           144: }
        !           145: 
        !           146: /* Set err to a splice of cp with a string form of character d */
        !           147: seterrc(cp, d)
        !           148:        char *cp, d;
        !           149: {
        !           150:        char chbuf[2];
        !           151: 
        !           152:        chbuf[0] = d;
        !           153:        chbuf[1] = 0;
        !           154:        seterr2(cp, chbuf);
        !           155: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.