mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-01 12:19:28 +00:00
Use err(3) instead of local redefinition. Add usage().
This commit is contained in:
parent
d48dbc786e
commit
958d7c9f1d
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=27419
@ -34,7 +34,11 @@
|
||||
*/
|
||||
|
||||
#ifndef lint
|
||||
#if 0
|
||||
static char sccsid[] = "@(#)args.c 8.1 (Berkeley) 6/6/93";
|
||||
#endif
|
||||
static const char rcsid[] =
|
||||
"$Id$";
|
||||
#endif /* not lint */
|
||||
|
||||
/*
|
||||
@ -42,8 +46,9 @@ static char sccsid[] = "@(#)args.c 8.1 (Berkeley) 6/6/93";
|
||||
* here as well.
|
||||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <ctype.h>
|
||||
#include <err.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include "indent_globs.h"
|
||||
@ -230,8 +235,7 @@ set_option(arg)
|
||||
for (p = pro; p->p_name; p++)
|
||||
if (*p->p_name == *arg && eqin(p->p_name, arg))
|
||||
goto found;
|
||||
fprintf(stderr, "indent: %s: unknown parameter \"%s\"\n", option_source, arg - 1);
|
||||
exit(1);
|
||||
errx(1, "%s: unknown parameter \"%s\"", option_source, arg - 1);
|
||||
found:
|
||||
switch (p->p_type) {
|
||||
|
||||
@ -265,9 +269,7 @@ set_option(arg)
|
||||
break;
|
||||
|
||||
default:
|
||||
fprintf(stderr, "\
|
||||
indent: set_option: internal error: p_special %d\n", p->p_special);
|
||||
exit(1);
|
||||
errx(1, "set_option: internal error: p_special %d", p->p_special);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -281,9 +283,7 @@ indent: set_option: internal error: p_special %d\n", p->p_special);
|
||||
case PRO_INT:
|
||||
if (!isdigit(*param_start)) {
|
||||
need_param:
|
||||
fprintf(stderr, "indent: %s: ``%s'' requires a parameter\n",
|
||||
option_source, arg - 1);
|
||||
exit(1);
|
||||
errx(1, "%s: ``%s'' requires a parameter", option_source, arg - 1);
|
||||
}
|
||||
*p->p_obj = atoi(param_start);
|
||||
break;
|
||||
@ -293,8 +293,6 @@ indent: set_option: internal error: p_special %d\n", p->p_special);
|
||||
break;
|
||||
|
||||
default:
|
||||
fprintf(stderr, "indent: set_option: internal error: p_type %d\n",
|
||||
p->p_type);
|
||||
exit(1);
|
||||
errx(1, "set_option: internal error: p_type %d", p->p_type);
|
||||
}
|
||||
}
|
||||
|
@ -40,7 +40,7 @@
|
||||
.Nm indent
|
||||
.Nd indent and format C program source
|
||||
.Sh SYNOPSIS
|
||||
.Nm indent
|
||||
.Nm
|
||||
.Op Ar input-file Op Ar output-file
|
||||
.Op Fl bad | Fl nbad
|
||||
.Op Fl bap | Fl nbap
|
||||
@ -108,7 +108,7 @@ the backup file is named
|
||||
If
|
||||
.Ar output-file
|
||||
is specified,
|
||||
.Nm indent
|
||||
.Nm
|
||||
checks to make sure it is different from
|
||||
.Ar input-file .
|
||||
.Pp
|
||||
@ -314,7 +314,7 @@ get rid of blank lines after declarations. Default:
|
||||
.Fl nsob .
|
||||
.It Fl \&st
|
||||
Causes
|
||||
.Nm indent
|
||||
.Nm
|
||||
to take its input from stdin, and put its output to stdout.
|
||||
.It Fl T Ns Ar typename
|
||||
Adds
|
||||
@ -331,13 +331,13 @@ a symptom of a problem in C:
|
||||
.Ic typedef
|
||||
causes a syntactic change in the
|
||||
language and
|
||||
.Nm indent
|
||||
.Nm
|
||||
can't find all
|
||||
instances of
|
||||
.Ic typedef .
|
||||
.It Fl troff
|
||||
Causes
|
||||
.Nm indent
|
||||
.Nm
|
||||
to format the program for processing by
|
||||
.Xr troff 1 .
|
||||
It will produce a fancy
|
||||
@ -350,20 +350,20 @@ rather than formatting in place.
|
||||
turns on `verbose' mode;
|
||||
.Fl \&nv
|
||||
turns it off. When in verbose mode,
|
||||
.Nm indent
|
||||
.Nm
|
||||
reports when it splits one line of input into two or more lines of output,
|
||||
and gives some size statistics at completion. The default is
|
||||
.Fl \&nv .
|
||||
.El
|
||||
.Pp
|
||||
You may set up your own `profile' of defaults to
|
||||
.Nm indent
|
||||
.Nm
|
||||
by creating a file called
|
||||
.Pa .indent.pro
|
||||
in your login directory and/or the current directory and including
|
||||
whatever switches you like. A `.indent.pro' in the current directory takes
|
||||
precedence over the one in your login directory. If
|
||||
.Nm indent
|
||||
.Nm
|
||||
is run and a profile file exists, then it is read to set up the program's
|
||||
defaults. Switches on the command line, though, always override profile
|
||||
switches. The switches should be separated by spaces, tabs or newlines.
|
||||
@ -400,13 +400,13 @@ automatically extended in extreme cases.
|
||||
.Pp
|
||||
.Ss Preprocessor lines
|
||||
In general,
|
||||
.Nm indent
|
||||
.Nm
|
||||
leaves preprocessor lines alone. The only
|
||||
reformatting that it will do is to straighten up trailing comments. It
|
||||
leaves embedded comments alone. Conditional compilation
|
||||
.Pq Ic #ifdef...#endif
|
||||
is recognized and
|
||||
.Nm indent
|
||||
.Nm
|
||||
attempts to correctly
|
||||
compensate for the syntactic peculiarities introduced.
|
||||
.Pp
|
||||
@ -433,7 +433,7 @@ profile file
|
||||
.El
|
||||
.Sh HISTORY
|
||||
The
|
||||
.Nm indent
|
||||
.Nm
|
||||
command appeared in
|
||||
.Bx 4.2 .
|
||||
.Sh BUGS
|
||||
|
@ -34,7 +34,7 @@
|
||||
*/
|
||||
|
||||
#ifndef lint
|
||||
char copyright[] =
|
||||
static const char copyright[] =
|
||||
"@(#) Copyright (c) 1985 Sun Microsystems, Inc.\n\
|
||||
@(#) Copyright (c) 1976 Board of Trustees of the University of Illinois.\n\
|
||||
@(#) Copyright (c) 1980, 1993\n\
|
||||
@ -42,10 +42,15 @@ char copyright[] =
|
||||
#endif /* not lint */
|
||||
|
||||
#ifndef lint
|
||||
#if 0
|
||||
static char sccsid[] = "@(#)indent.c 5.17 (Berkeley) 6/7/93";
|
||||
#endif
|
||||
static const char rcsid[] =
|
||||
"$Id$";
|
||||
#endif /* not lint */
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <err.h>
|
||||
#include <fcntl.h>
|
||||
#include <unistd.h>
|
||||
#include <stdio.h>
|
||||
@ -61,6 +66,8 @@ char *out_name = "Standard Output"; /* will always point to name
|
||||
* of output file */
|
||||
char bakfile[MAXPATHLEN] = "";
|
||||
|
||||
static void usage __P((void));
|
||||
|
||||
main(argc, argv)
|
||||
int argc;
|
||||
char **argv;
|
||||
@ -182,30 +189,27 @@ main(argc, argv)
|
||||
in_name = argv[i]; /* remember name of input file */
|
||||
input = fopen(in_name, "r");
|
||||
if (input == 0) /* check for open error */
|
||||
err(in_name);
|
||||
err(1, in_name);
|
||||
continue;
|
||||
}
|
||||
else if (output == 0) { /* we have the output file */
|
||||
out_name = argv[i]; /* remember name of output file */
|
||||
if (strcmp(in_name, out_name) == 0) { /* attempt to overwrite
|
||||
* the file */
|
||||
fprintf(stderr, "indent: input and output files must be different\n");
|
||||
exit(1);
|
||||
errx(1, "input and output files must be different");
|
||||
}
|
||||
output = fopen(out_name, "w");
|
||||
if (output == 0) /* check for create error */
|
||||
err(out_name);
|
||||
err(1, out_name);
|
||||
continue;
|
||||
}
|
||||
fprintf(stderr, "indent: unknown parameter: %s\n", argv[i]);
|
||||
exit(1);
|
||||
errx(1, "unknown parameter: %s", argv[i]);
|
||||
}
|
||||
else
|
||||
set_option(argv[i]);
|
||||
} /* end of for */
|
||||
if (input == 0) {
|
||||
fprintf(stderr, "indent: usage: indent file [ outfile ] [ options ]\n");
|
||||
exit(1);
|
||||
usage();
|
||||
}
|
||||
if (output == 0)
|
||||
if (troff)
|
||||
@ -1126,6 +1130,13 @@ main(argc, argv)
|
||||
} /* end of main while (1) loop */
|
||||
}
|
||||
|
||||
static void
|
||||
usage()
|
||||
{
|
||||
fprintf(stderr, "usage: indent file [ outfile ] [ options ]\n");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
/*
|
||||
* copy input file to backup file if in_name is /blah/blah/blah/file, then
|
||||
* backup file will be ".Bfile" then make the backup file the input and
|
||||
@ -1149,33 +1160,23 @@ bakcopy()
|
||||
/* copy in_name to backup file */
|
||||
bakchn = creat(bakfile, 0600);
|
||||
if (bakchn < 0)
|
||||
err(bakfile);
|
||||
err(1, bakfile);
|
||||
while (n = read(fileno(input), buff, sizeof buff))
|
||||
if (write(bakchn, buff, n) != n)
|
||||
err(bakfile);
|
||||
err(1, bakfile);
|
||||
if (n < 0)
|
||||
err(in_name);
|
||||
err(1, in_name);
|
||||
close(bakchn);
|
||||
fclose(input);
|
||||
|
||||
/* re-open backup file as the input file */
|
||||
input = fopen(bakfile, "r");
|
||||
if (input == 0)
|
||||
err(bakfile);
|
||||
err(1, bakfile);
|
||||
/* now the original input file will be the output */
|
||||
output = fopen(in_name, "w");
|
||||
if (output == 0) {
|
||||
unlink(bakfile);
|
||||
err(in_name);
|
||||
err(1, in_name);
|
||||
}
|
||||
}
|
||||
|
||||
err(msg)
|
||||
char *msg;
|
||||
{
|
||||
extern int errno;
|
||||
char *strerror();
|
||||
|
||||
(void)fprintf(stderr, "indent: %s: %s\n", msg, strerror(errno));
|
||||
exit(1);
|
||||
}
|
||||
|
@ -34,11 +34,16 @@
|
||||
*/
|
||||
|
||||
#ifndef lint
|
||||
#if 0
|
||||
static char sccsid[] = "@(#)io.c 8.1 (Berkeley) 6/6/93";
|
||||
#endif
|
||||
static const char rcsid[] =
|
||||
"$Id$";
|
||||
#endif /* not lint */
|
||||
|
||||
#include <stdio.h>
|
||||
#include <ctype.h>
|
||||
#include <err.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include "indent_globs.h"
|
||||
@ -348,7 +353,7 @@ fill_buffer()
|
||||
register offset = p - in_buffer;
|
||||
in_buffer = (char *) realloc(in_buffer, size);
|
||||
if (in_buffer == 0)
|
||||
err("input line too long");
|
||||
err(1, "input line too long");
|
||||
p = in_buffer + offset;
|
||||
in_buffer_limit = in_buffer + size - 2;
|
||||
}
|
||||
@ -607,8 +612,7 @@ parsefont(f, s0)
|
||||
else if (*s == '-')
|
||||
sizedelta--;
|
||||
else {
|
||||
fprintf(stderr, "indent: bad font specification: %s\n", s0);
|
||||
exit(1);
|
||||
errx(1, "bad font specification: %s", s0);
|
||||
}
|
||||
s++;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user