Annotation of 43BSD/ucb/indent/io.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1980 Regents of the University of California.
        !             3:  * All rights reserved.  The Berkeley software License Agreement
        !             4:  * specifies the terms and conditions for redistribution.
        !             5:  */
        !             6: 
        !             7: #ifndef lint
        !             8: static char sccsid[] = "@(#)io.c       5.3 (Berkeley) 9/8/85";
        !             9: #endif not lint
        !            10: 
        !            11: /*-
        !            12:  *                       Copyright (C) 1976
        !            13:  *                             by the
        !            14:  *                       Board of Trustees
        !            15:  *                             of the
        !            16:  *                     University of Illinois
        !            17:  *                      All rights reserved
        !            18:  * FILE NAME:
        !            19:  *     io.c
        !            20:  * PURPOSE:
        !            21:  *     Contains routines to handle i/o related stuff for indent.
        !            22:  * GLOBALS:
        !            23:  *     None
        !            24:  * FUNCTIONS:
        !            25:  *     dump_line
        !            26:  *     fill_buffer
        !            27:  *     pad_output
        !            28:  *     count_spaces
        !            29:  *     eqin
        !            30:  *     cmp
        !            31:  *
        !            32:  */
        !            33: /*-
        !            34:  *
        !            35:  *                       Copyright (C) 1976
        !            36:  *                             by the
        !            37:  *                       Board of Trustees
        !            38:  *                             of the
        !            39:  *                     University of Illinois
        !            40:  *
        !            41:  *                      All rights reserved
        !            42:  *
        !            43:  *
        !            44:  * NAME:
        !            45:  *     dump_line
        !            46:  *
        !            47:  * FUNCTION:
        !            48:  *     Does the actual printing of the stored up line
        !            49:  *
        !            50:  * ALGORITHM:
        !            51:  *     For each of the label, code, and comment sections which are used on 
        !            52:  *     this line:
        !            53:  *
        !            54:  *     1) Use pad_output to get the section aligned properly.
        !            55:  *     2) write the section
        !            56:  *
        !            57:  *     The indentation level used for the code is set by ps.ind_level.  After
        !            58:  *     printing, ps.ind_level is set to ps.i_l_follow.
        !            59:  *
        !            60:  *     An extra level of indentation is added if ps.ind_stmt is 1.  After 
        !            61:  *     printing, ps.ind_stmt is set to 1 iff the line just printed has an
        !            62:  *     unterminated, non-declaration statement.
        !            63:  *
        !            64:  * HISTORY:
        !            65:  *     initial coding  November 1976   D A Willcox of CAC
        !            66:  *
        !            67:  */
        !            68: #include "indent_globs.h";
        !            69: 
        !            70: 
        !            71: 
        !            72: int         ff = 014;          /* used to write a form feed */
        !            73: int         comment_open;
        !            74: static      paren_target;
        !            75: 
        !            76: dump_line()
        !            77: {                              /* dump_line is the routine that actually
        !            78:                                 * effects the printing of the new source.
        !            79:                                 * It prints the label section, followed
        !            80:                                 * by the code section with the
        !            81:                                 * appropriate nesting level, followed by
        !            82:                                 * any comments */
        !            83:     register int cur_col,
        !            84:                 temp_col,
        !            85:                 target_col;
        !            86: 
        !            87:     if (ps.procname[0]) {
        !            88:        if (troff)
        !            89:            fprintf(output, ".Pr \"%s\"\n", ps.procname);
        !            90:        ps.ind_level = 0;
        !            91:        ps.procname[0] = 0;
        !            92:     }
        !            93:     if (s_code == e_code && s_lab == e_lab && s_com == e_com) {
        !            94:        if (suppress_blanklines>0) suppress_blanklines--;
        !            95:        else {
        !            96:        ps.bl_line = true;
        !            97:        n_real_blanklines++;
        !            98:        }
        !            99:     }
        !           100:     else if (!inhibit_formatting) {
        !           101:        suppress_blanklines = 0;
        !           102:        ps.bl_line = false;
        !           103:        if (prefix_blankline_requested)
        !           104:            if (swallow_optional_blanklines) {
        !           105:                if (n_real_blanklines == 1)
        !           106:                    n_real_blanklines = 0;
        !           107:            }
        !           108:            else {
        !           109:                if (n_real_blanklines == 0)
        !           110:                    n_real_blanklines = 1;
        !           111:            }
        !           112:        while (--n_real_blanklines >= 0)
        !           113:            putc('\n', output);
        !           114:        n_real_blanklines = 0;
        !           115:        if (ps.ind_level == 0)
        !           116:            ps.ind_stmt = 0;    /* this is a class A kludge. dont do
        !           117:                                 * additional statement indentation if we
        !           118:                                 * are at bracket level 0 */
        !           119: 
        !           120:        if (e_lab != s_lab || e_code != s_code)
        !           121:            ++code_lines;       /* keep count of lines with code */
        !           122: 
        !           123: 
        !           124:        if (e_lab != s_lab) {   /* print lab, if any */
        !           125:            if (comment_open) {
        !           126:                comment_open = 0;
        !           127:                fprintf(output, ".*/\n");
        !           128:            }
        !           129:            while (e_lab > s_lab && (e_lab[-1] == ' ' || e_lab[-1] == '\t'))
        !           130:                e_lab--;
        !           131:            cur_col = pad_output(1, compute_label_target());
        !           132:            fprintf(output, "%.*s", e_lab - s_lab, s_lab);
        !           133:            cur_col = count_spaces(cur_col, s_lab);
        !           134:        }
        !           135:        else
        !           136:            cur_col = 1;        /* there is no label section */
        !           137: 
        !           138:        ps.pcase = false;
        !           139: 
        !           140:        if (s_code != e_code) { /* print code section, if any */
        !           141:            register char *p;
        !           142: 
        !           143:            if (comment_open) {
        !           144:                comment_open = 0;
        !           145:                fprintf(output, ".*/\n");
        !           146:            }
        !           147:            target_col = compute_code_target();
        !           148:            {
        !           149:                register    i;
        !           150: 
        !           151:                for (i = 0; i < ps.p_l_follow; i++)
        !           152:                    if (ps.paren_indents[i] >= 0)
        !           153:                        ps.paren_indents[i] = -(ps.paren_indents[i] + target_col);
        !           154:            }
        !           155:            cur_col = pad_output(cur_col, target_col);
        !           156:            for (p = s_code; p < e_code; p++)
        !           157:                if (*p == 0200)
        !           158:                    fprintf(output, "%d", target_col * 7);
        !           159:                else
        !           160:                    putc(*p, output);
        !           161:            cur_col = count_spaces(cur_col, s_code);
        !           162:        }
        !           163:        if (s_com != e_com)
        !           164:            if (troff) {
        !           165:                register char *p;
        !           166: 
        !           167:                if (e_com[-1] == '/' && e_com[-2] == '*')
        !           168:                    e_com -= 2;
        !           169:                while (e_com > s_com && e_com[-1] == ' ')
        !           170:                    e_com--;
        !           171:                *e_com = 0;
        !           172:                p = s_com;
        !           173:                while (*p == ' ')
        !           174:                    p++;
        !           175:                if (p[0] == '/' && p[1] == '*')
        !           176:                    p += 2;
        !           177:                else if (p[0] == '*')
        !           178:                    p += p[1] == '/' ? 2 : 1;
        !           179:                while (*p == ' ')
        !           180:                    p++;
        !           181:                if (*p == 0)
        !           182:                    goto inhibit_newline;
        !           183:                if (!comment_open) {
        !           184:                    if ('a' <= *p && *p <= 'z')
        !           185:                        *p = *p + 'A' - 'a';
        !           186:                    if (s_code != e_code || s_lab != e_lab) {
        !           187:                        fprintf(output, "\\c\n./* %dp 1 %dp\n",
        !           188:                                ps.com_col * 7, target_col * 7);
        !           189:                    }
        !           190:                    else
        !           191:                        fprintf(output, "./* %dp 0 %dp\n",
        !           192:                                ps.com_col * 7, target_col * 7);
        !           193:                }
        !           194:                comment_open = 1;
        !           195:                while (*p) {
        !           196:                    if (*p == BACKSLASH)
        !           197:                        putc(BACKSLASH, output);
        !           198:                    putc(*p++, output);
        !           199:                }
        !           200:            }
        !           201:            else {              /* print comment, if any */
        !           202:                register    target = ps.com_col;
        !           203:                register char *com_st = s_com;
        !           204: 
        !           205:                target += ps.comment_delta;
        !           206:                while (target <= 0)
        !           207:                    if (*s_com == ' ')
        !           208:                        target++, s_com++;
        !           209:                    else if (*s_com == '\t')
        !           210:                        target = ((target - 1) & ~7) + 9, s_com++;
        !           211:                    else
        !           212:                        target = 1;
        !           213:                if (cur_col > target) { /* if comment cant fit on this
        !           214:                                         * line, put it on next line */
        !           215:                    putc('\n', output);
        !           216:                    cur_col = 1;
        !           217:                    ++ps.out_lines;
        !           218:                }
        !           219:                cur_col = pad_output(cur_col, target);
        !           220:                if (!ps.box_com) {
        !           221:                    if (star_comment_cont && com_st[1] != '*')
        !           222:                        if (com_st[1] == ' ' && com_st[0] == ' ')
        !           223:                            com_st[1] = '*';
        !           224:                        else
        !           225:                            fwrite(" * ", com_st[0] == '\t' ? 2 : com_st[0] == '*' ? 1 : 3, 1, output);
        !           226:                }
        !           227:                fwrite(com_st, e_com - com_st, 1, output);
        !           228:                ps.comment_delta = ps.n_comment_delta;
        !           229:                cur_col = count_spaces(cur_col, com_st);
        !           230:                ++ps.com_lines; /* count lines with comments */
        !           231:            }
        !           232:        if (ps.use_ff)
        !           233:            putc('\014', output);
        !           234:        else
        !           235:            putc('\n', output);
        !           236: inhibit_newline:
        !           237:        ++ps.out_lines;
        !           238:        if (ps.just_saw_decl == 1 && blanklines_after_declarations) {
        !           239:            prefix_blankline_requested = 1;
        !           240:            ps.just_saw_decl = 0;
        !           241:        }
        !           242:        else
        !           243:            prefix_blankline_requested = postfix_blankline_requested;
        !           244:        postfix_blankline_requested = 0;
        !           245:     }
        !           246:     ps.decl_on_line = ps.in_decl;      /* if we are in the middle of a
        !           247:                                         * declaration, remember that fact
        !           248:                                         * for proper comment indentation */
        !           249:     ps.ind_stmt = ps.in_stmt & ~ps.in_decl;    /* next line should be
        !           250:                                                 * indented if we have not
        !           251:                                                 * completed this stmt and
        !           252:                                                 * if we are not in the
        !           253:                                                 * middle of a declaration */
        !           254:     ps.use_ff = false;
        !           255:     ps.dumped_decl_indent = 0;
        !           256:     *(e_lab = s_lab) = '\0';   /* reset buffers */
        !           257:     *(e_code = s_code) = '\0';
        !           258:     *(e_com = s_com) = '\0';
        !           259:     ps.ind_level = ps.i_l_follow;
        !           260:     ps.paren_level = ps.p_l_follow;
        !           261:     paren_target = -ps.paren_indents[ps.paren_level - 1];
        !           262:     return;
        !           263: };
        !           264: 
        !           265: compute_code_target() {
        !           266:     register    target_col = ps.ind_size * ps.ind_level + 1;
        !           267: 
        !           268:     if (ps.paren_level)
        !           269:        if (!lineup_to_parens)
        !           270:            target_col += continuation_indent * ps.paren_level;
        !           271:        else {
        !           272:            register    w;
        !           273:            register    t = paren_target;
        !           274: 
        !           275:            if ((w = count_spaces(t, s_code) - max_col) > 0
        !           276:                && count_spaces(target_col, s_code) <= max_col) {
        !           277:                t -= w + 1;
        !           278:                if (t > target_col)
        !           279:                    target_col = t;
        !           280:            }
        !           281:            else
        !           282:                target_col = t;
        !           283:        }
        !           284:     else if (ps.ind_stmt)
        !           285:        target_col += continuation_indent;
        !           286:     return target_col;
        !           287: }
        !           288: 
        !           289: compute_label_target()
        !           290: {
        !           291:     return
        !           292:        ps.pcase ? (int) (case_ind * ps.ind_size) +1
        !           293:        : *s_lab == '#' ? 1
        !           294:        : ps.ind_size * (ps.ind_level - label_offset) +1;
        !           295: }
        !           296: 
        !           297: 
        !           298: /*
        !           299:  * Copyright (C) 1976 by the Board of Trustees of the University of
        !           300:  * Illinois 
        !           301:  *
        !           302:  * All rights reserved 
        !           303:  *
        !           304:  *
        !           305:  * NAME: fill_buffer 
        !           306:  *
        !           307:  * FUNCTION: Reads one block of input into input_buffer 
        !           308:  *
        !           309:  * HISTORY: initial coding     November 1976   D A Willcox of CAC 1/7/77
        !           310:  * A Willcox of CAC    Added check for switch back to partly full input
        !           311:  * buffer from temporary buffer 
        !           312:  *
        !           313:  */
        !           314: int
        !           315: fill_buffer()
        !           316: {                              /* this routine reads stuff from the input */
        !           317:     int         count;
        !           318:     register char *p;
        !           319:     register int i;
        !           320:     register FILE *f = input;
        !           321: 
        !           322:     if (bp_save != 0) {                /* there is a partly filled input buffer
        !           323:                                 * left */
        !           324:        buf_ptr = bp_save;      /* dont read anything, just switch buffers */
        !           325:        buf_end = be_save;
        !           326:        bp_save = be_save = 0;
        !           327:        if (buf_ptr < buf_end)
        !           328:            return;             /* only return if there is really
        !           329:                                 * something in this buffer */
        !           330:     }
        !           331:     p = in_buffer;
        !           332:     buf_ptr = p;
        !           333:     while ((*p++ = i = getc(f)) != EOF && i != '\n');
        !           334:     if (i == EOF) {
        !           335:        p[-1] = ' ';
        !           336:        *p++ = '\n';
        !           337:        had_eof = true;
        !           338:     }
        !           339:     buf_end = p;
        !           340:     if (p[-2] == '/' && p[-3] == '*') {
        !           341:        if (in_buffer[3] == 'I' && strncmp(in_buffer, "/**INDENT**", 11) == 0)
        !           342:            fill_buffer();      /* flush indent error message */
        !           343:        else {
        !           344:            int         com = 0;
        !           345: 
        !           346:            p = in_buffer;
        !           347:            while (*p == ' ' || *p == '\t')
        !           348:                p++;
        !           349:            if (*p == '/' && p[1] == '*') {
        !           350:                p += 2;
        !           351:                while (*p == ' ' || *p == '\t')
        !           352:                    p++;
        !           353:                if (p[0] == 'I' && p[1] == 'N' && p[2] == 'D' && p[3] == 'E'
        !           354:                    && p[4] == 'N' && p[5] == 'T') {
        !           355:                    p += 6;
        !           356:                    while (*p == ' ' || *p == '\t')
        !           357:                        p++;
        !           358:                    if (*p == '*')
        !           359:                        com = 1;
        !           360:                    else if (*p == 'O')
        !           361:                        if (*++p == 'N')
        !           362:                            p++, com = 1;
        !           363:                        else if (*p == 'F' && *++p == 'F')
        !           364:                            p++, com = 2;
        !           365:                    while (*p == ' ' || *p == '\t')
        !           366:                        p++;
        !           367:                    if (p[0] == '*' && p[1] == '/' && p[2] == '\n' && com) {
        !           368:                        if (s_com != e_com || s_lab != e_lab || s_code != e_code)
        !           369:                            dump_line();
        !           370:                        if (!(inhibit_formatting = com - 1)) {
        !           371:                            n_real_blanklines = 0;
        !           372:                            postfix_blankline_requested = 0;
        !           373:                            prefix_blankline_requested = 0;
        !           374:                            suppress_blanklines = 1;
        !           375:                        }
        !           376:                    }
        !           377:                }
        !           378:            }
        !           379:        }
        !           380:     }
        !           381:     if (inhibit_formatting) {
        !           382:        p = in_buffer;
        !           383:        do
        !           384:            putc(*p, output);
        !           385:        while (*p++ != '\n');
        !           386:     }
        !           387:     return;
        !           388: };
        !           389: 
        !           390: /*
        !           391:  * Copyright (C) 1976 by the Board of Trustees of the University of
        !           392:  * Illinois 
        !           393:  *
        !           394:  * All rights reserved 
        !           395:  *
        !           396:  *
        !           397:  * NAME: pad_output 
        !           398:  *
        !           399:  * FUNCTION: Writes tabs and spaces to move the current column up to the
        !           400:  * desired position. 
        !           401:  *
        !           402:  * ALGORITHM: Put tabs and/or blanks into pobuf, then write pobuf. 
        !           403:  *
        !           404:  * PARAMETERS: current         integer         The current column target
        !           405:  * nteger              The desired column 
        !           406:  *
        !           407:  * RETURNS: Integer value of the new column.  (If current >= target, no
        !           408:  * action is taken, and current is returned. 
        !           409:  *
        !           410:  * GLOBALS: None 
        !           411:  *
        !           412:  * CALLS: write (sys) 
        !           413:  *
        !           414:  * CALLED BY: dump_line 
        !           415:  *
        !           416:  * HISTORY: initial coding     November 1976   D A Willcox of CAC 
        !           417:  *
        !           418:  */
        !           419: pad_output(current, target)    /* writes tabs and blanks (if necessary)
        !           420:                                 * to get the current output position up
        !           421:                                 * to the target column */
        !           422:     int         current;       /* the current column value */
        !           423:     int         target;                /* position we want it at */
        !           424: {
        !           425:     register int curr;         /* internal column pointer */
        !           426:     register int tcur;
        !           427: 
        !           428:     if (troff)
        !           429:        fprintf(output, "\\h'|%dp'", (target - 1) * 7);
        !           430:     else {
        !           431:        if (current >= target)
        !           432:            return (current);   /* line is already long enough */
        !           433:        curr = current;
        !           434:        while ((tcur = ((curr - 1) & tabmask) + tabsize + 1) <= target) {
        !           435:            putc('\t', output);
        !           436:            curr = tcur;
        !           437:        }
        !           438:        while (curr++ < target)
        !           439:            putc(' ', output);  /* pad with final blanks */
        !           440:     }
        !           441:     return (target);
        !           442: };
        !           443: 
        !           444: /*
        !           445:  * Copyright (C) 1976 by the Board of Trustees of the University of
        !           446:  * Illinois 
        !           447:  *
        !           448:  * All rights reserved 
        !           449:  *
        !           450:  *
        !           451:  * NAME: count_spaces 
        !           452:  *
        !           453:  * FUNCTION: Find out where printing of a given string will leave the current
        !           454:  * character position on output. 
        !           455:  *
        !           456:  * ALGORITHM: Run thru input string and add appropriate values to current
        !           457:  * position. 
        !           458:  *
        !           459:  * RETURNS: Integer value of position after printing "buffer" starting in
        !           460:  * column "current". 
        !           461:  *
        !           462:  * HISTORY: initial coding     November 1976   D A Willcox of CAC 
        !           463:  *
        !           464:  */
        !           465: int
        !           466: count_spaces(current, buffer)
        !           467: 
        !           468: /*
        !           469:  * this routine figures out where the character position will be after
        !           470:  * printing the text in buffer starting at column "current" 
        !           471:  */
        !           472:     int         current;
        !           473:     char       *buffer;
        !           474: {
        !           475:     register char *buf;                /* used to look thru buffer */
        !           476:     register int cur;          /* current character counter */
        !           477: 
        !           478:     cur = current;
        !           479: 
        !           480:     for (buf = buffer; *buf != '\0'; ++buf) {
        !           481:        switch (*buf) {
        !           482: 
        !           483:            case '\n':
        !           484:            case 014:           /* form feed */
        !           485:                cur = 1;
        !           486:                break;
        !           487: 
        !           488:            case '\t':
        !           489:                cur = ((cur - 1) & tabmask) + tabsize + 1;
        !           490:                break;
        !           491: 
        !           492:            case '':           /* this is a backspace */
        !           493:                --cur;
        !           494:                break;
        !           495: 
        !           496:            default:
        !           497:                ++cur;
        !           498:                break;
        !           499:        }                       /* end of switch */
        !           500:     }                          /* end of for loop */
        !           501:     return (cur);
        !           502: };
        !           503: 
        !           504: diag(level, msg, a, b)
        !           505: {
        !           506:     if (output == stdout) {
        !           507:        fprintf(stdout, "/**INDENT** %s@%d: ", level == 0 ? "Warning" : "Error", line_no);
        !           508:        fprintf(stdout, msg, a, b);
        !           509:        fprintf(stdout, " */\n");
        !           510:     }
        !           511:     else {
        !           512:        fprintf(stderr, "%s@%d: ", level == 0 ? "Warning" : "Error", line_no);
        !           513:        fprintf(stderr, msg, a, b);
        !           514:        fprintf(stderr, "\n");
        !           515:     }
        !           516: }

unix.superglobalmegacorp.com

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