Annotation of OpenXM_contrib/gnuplot/docs/checkdoc.c, Revision 1.1
1.1 ! maekawa 1: /*
! 2: * $Id: checkdoc.c,v 1.17 1998/04/14 00:16:57 drd Exp $
! 3: *
! 4: */
! 5:
! 6: /* GNUPLOT - checkdoc.c */
! 7:
! 8: /*[
! 9: * Copyright 1986 - 1993, 1998 Thomas Williams, Colin Kelley
! 10: *
! 11: * Permission to use, copy, and distribute this software and its
! 12: * documentation for any purpose with or without fee is hereby granted,
! 13: * provided that the above copyright notice appear in all copies and
! 14: * that both that copyright notice and this permission notice appear
! 15: * in supporting documentation.
! 16: *
! 17: * Permission to modify the software is granted, but not the right to
! 18: * distribute the complete modified source code. Modifications are to
! 19: * be distributed as patches to the released version. Permission to
! 20: * distribute binaries produced by compiling modified sources is granted,
! 21: * provided you
! 22: * 1. distribute the corresponding source modifications from the
! 23: * released version in the form of a patch file along with the binaries,
! 24: * 2. add special version identification to distinguish your version
! 25: * in addition to the base release version number,
! 26: * 3. provide your name and address as the primary contact for the
! 27: * support of your modified version, and
! 28: * 4. retain our contact information in regard to use of the base
! 29: * software.
! 30: * Permission to distribute the released version of the source code along
! 31: * with corresponding source modifications in the form of a patch file is
! 32: * granted with same provisions 2 through 4 for binary distributions.
! 33: *
! 34: * This software is provided "as is" without express or implied warranty
! 35: * to the extent permitted by applicable law.
! 36: ]*/
! 37:
! 38: /*
! 39: * checkdoc -- check a doc file for correctness of first column.
! 40: *
! 41: * Prints out lines that have an illegal first character.
! 42: * First character must be space, digit, or ?, @, #, %,
! 43: * or line must be empty.
! 44: *
! 45: * usage: checkdoc [docfile]
! 46: * Modified by Russell Lang from hlp2ms.c by Thomas Williams
! 47: *
! 48: * Original version by David Kotz used the following one line script!
! 49: * sed -e '/^$/d' -e '/^[ 0-9?@#%]/d' gnuplot.doc
! 50: *
! 51: */
! 52:
! 53: #ifdef HAVE_CONFIG_H
! 54: #include "config.h"
! 55: #endif
! 56:
! 57: #include "ansichek.h"
! 58: #include "stdfn.h"
! 59: #include "doc2x.h"
! 60:
! 61: void convert __PROTO((FILE *, FILE *));
! 62: void process_line __PROTO((char *, FILE *));
! 63:
! 64: int main(argc, argv)
! 65: int argc;
! 66: char **argv;
! 67: {
! 68: FILE *infile;
! 69: infile = stdin;
! 70:
! 71: if (argc > 2) {
! 72: fprintf(stderr, "Usage: %s [infile]\n", argv[0]);
! 73: exit(EXIT_FAILURE);
! 74: }
! 75: if (argc == 2)
! 76: if ((infile = fopen(argv[1], "r")) == (FILE *) NULL) {
! 77: fprintf(stderr, "%s: Can't open %s for reading\n",
! 78: argv[0], argv[1]);
! 79: exit(EXIT_FAILURE);
! 80: }
! 81: convert(infile, stdout);
! 82: exit(EXIT_SUCCESS);
! 83: }
! 84:
! 85: void convert(a, b)
! 86: FILE *a, *b;
! 87: {
! 88: static char line[MAX_LINE_LEN+1];
! 89:
! 90: while (get_line(line, sizeof(line), a)) {
! 91: process_line(line, b);
! 92: }
! 93: }
! 94:
! 95: void process_line(line, b)
! 96: char *line;
! 97: FILE *b;
! 98: {
! 99: /* check matching backticks within a paragraph */
! 100:
! 101: static int count = 0;
! 102:
! 103: if (line[0] == ' ') {
! 104: char *p = line;
! 105:
! 106: /* skip/count leading spaces */
! 107:
! 108: while (*++p == ' ');
! 109:
! 110: if (*p == '\n') {
! 111: /* it is not clear if this is an error, but it is an
! 112: * inconsistency, so flag it
! 113: */
! 114: fprintf(b, "spaces-only line %s:%d\n", termdoc_filename, termdoc_lineno);
! 115: } else {
! 116: /* accumulate count of backticks. Do not check odd-ness
! 117: * until end of paragraph (non-space in column 1)
! 118: */
! 119: for (; *p; ++p)
! 120: if (*p == '`')
! 121: ++count;
! 122: }
! 123: } else {
! 124: if (count & 1) {
! 125: fprintf(b,
! 126: "mismatching backticks before %s:%d\n",
! 127: termdoc_filename, termdoc_lineno);
! 128: }
! 129: count = 0;
! 130: }
! 131:
! 132: if (strchr(line, '\t'))
! 133: fprintf(b, "tab character in line %s:%d\n", termdoc_filename, termdoc_lineno);
! 134:
! 135: switch (line[0]) { /* control character */
! 136: case '?':{ /* interactive help entry */
! 137: break; /* ignore */
! 138: }
! 139: case '<':{ /* term docs */
! 140: break; /* ignore */
! 141: }
! 142: case '@':{ /* start/end table */
! 143: break; /* ignore */
! 144: }
! 145: case '#':{ /* latex table entry */
! 146: break; /* ignore */
! 147: }
! 148: case '%':{ /* troff table entry */
! 149: break; /* ignore */
! 150: }
! 151: case '^':{ /* html entry */
! 152: break; /* ignore */
! 153: }
! 154: case '\n': /* empty text line */
! 155: case ' ':{ /* normal text line */
! 156: break;
! 157: }
! 158: default:{
! 159: if (isdigit((int)line[0])) { /* start of section */
! 160: /* ignore */
! 161: } else
! 162: /* output bad line */
! 163: fprintf(b, "%s:%d:%s", termdoc_filename, termdoc_lineno, line);
! 164: break;
! 165: }
! 166: }
! 167: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>