char *stpcpy ();
char *xmalloc ();
-void cat ();
void error ();
-void next_line_num ();
-void simple_cat ();
+
+static void cat ();
+static void next_line_num ();
+static void simple_cat ();
/* Name under which this program was invoked. */
char *program_name;
/* Name of input file. May be "-". */
-char *infile;
+static char *infile;
/* Descriptor on which input file is open. */
-int input_desc;
+static int input_desc;
/* Descriptor on which output file is open. Always is 1. */
-int output_desc;
+static int output_desc;
/* Buffer for line numbers. */
-char line_buf[13] =
+static char line_buf[13] =
{' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', '0', '\t', '\0'};
/* Position in `line_buf' where printing starts. This will not change
unless the number of lines are more than 999999. */
-char *line_num_print = line_buf + 5;
+static char *line_num_print = line_buf + 5;
/* Position of the first digit in `line_buf'. */
-char *line_num_start = line_buf + 10;
+static char *line_num_start = line_buf + 10;
/* Position of the last digit in `line_buf'. */
-char *line_num_end = line_buf + 10;
+static char *line_num_end = line_buf + 10;
/* Preserves the `cat' function's local `newlines' between invocations. */
-int newlines2 = 0;
+static int newlines2 = 0;
/* Count of non-fatal error conditions. */
-int exit_stat = 0;
+static int exit_stat = 0;
-void
+static void
usage (reason)
char *reason;
{
int output_tabs = 1;
int options = 0;
- static struct option long_options[] =
+ static struct option const long_options[] =
{
{"number-nonblank", 0, NULL, 'b'},
{"number", 0, NULL, 'n'},
/* Plain cat. Copies the file behind `input_desc' to the file behind
`output_desc'. */
-void
+static void
simple_cat (buf, bufsize)
/* Pointer to the buffer, used by reads and writes. */
unsigned char *buf;
A newline character is always put at the end of the buffer, to make
an explicit test for buffer end unnecessary. */
-void
+static void
cat (inbuf, insize, outbuf, outsize, quote,
output_tabs, numbers, numbers_at_empty_lines,
mark_line_ends, squeeze_empty_lines)
/* Compute the next line number. */
-void
+static void
next_line_num ()
{
char *endp = line_num_end;
#define GEN (BIT(26)|BIT(23)|BIT(22)|BIT(16)|BIT(12)|BIT(11)|BIT(10)\
|BIT(8) |BIT(7) |BIT(5) |BIT(4) |BIT(2) |BIT(1) |BIT(0));
-unsigned long r[8];
+static unsigned long r[8];
-void
+static void
fill_r ()
{
int i;
r[i] = (r[i - 1] & SBIT) ? (r[i - 1] << 1) ^ r[0] : r[i - 1] << 1;
}
-unsigned long
+static unsigned long
remainder (m)
int m;
{
/* Number of bytes to read at once. */
#define BUFLEN (1 << 16)
-unsigned long crctab[256] =
+void error ();
+
+static unsigned long const crctab[256] =
{
0x0,
0x04C11DB7, 0x09823B6E, 0x0D4326D9, 0x130476DC, 0x17C56B6B,
char *program_name;
/* Nonzero if any of the files read were the standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* Calculate and print the checksum and length in bytes
of file FILE, or of the standard input if FILE is "-".
If PRINT_NAME is nonzero, print FILE next to the checksum and size.
Return 0 if successful, -1 if an error occurs. */
-int
+static int
cksum (file, print_name)
char *file;
int print_name;
#define min(x, y) ((x) < (y) ? (x) : (y))
/* If nonzero, print lines that are found only in file 1. */
-int only_file_1;
+static int only_file_1;
/* If nonzero, print lines that are found only in file 2. */
-int only_file_2;
+static int only_file_2;
/* If nonzero, print lines that are found in both files. */
-int both;
+static int both;
/* The name this program was run with. */
char *program_name;
-int compare_files ();
void error ();
-void writeline ();
-void usage ();
+static int compare_files ();
+static void writeline ();
+static void usage ();
\f
void
main (argc, argv)
merge them and output the result.
Return 0 if successful, 1 if any errors occur. */
-int
+static int
compare_files (infiles)
char **infiles;
{
CLASS is 1 for a line found only in file 1,
2 for a line only in file 2, 3 for a line in both. */
-void
+static void
writeline (line, stream, class)
struct linebuffer *line;
FILE *stream;
putc ('\n', stream);
}
\f
-void
+static void
usage ()
{
fprintf (stderr, "Usage: %s [-123] file1 file2\n", program_name);
void error ();
-void cleanup ();
-void close_output_file ();
-void create_output_file ();
-void save_line_to_file ();
-void usage ();
+
+static char *xrealloc ();
+static char *xmalloc ();
+static void cleanup ();
+static void close_output_file ();
+static void create_output_file ();
+static void save_line_to_file ();
+static void usage ();
#ifndef TRUE
#define FALSE 0
};
/* Input file descriptor. */
-int input_desc = 0;
+static int input_desc = 0;
/* List of available buffers. */
-struct buffer_record *free_list = NULL;
+static struct buffer_record *free_list = NULL;
/* Start of buffer list. */
-struct buffer_record *head = NULL;
+static struct buffer_record *head = NULL;
/* Partially read line. */
-char *hold_area = NULL;
+static char *hold_area = NULL;
/* Number of chars in `hold_area'. */
-unsigned hold_count = 0;
+static unsigned hold_count = 0;
/* Number of the last line in the buffers. */
-unsigned last_line_number = 0;
+static unsigned last_line_number = 0;
/* Number of the line currently being examined. */
-unsigned current_line = 0;
+static unsigned current_line = 0;
/* Number of the last line in the input file. */
-unsigned last_line_in_file = 0;
+static unsigned last_line_in_file = 0;
/* If TRUE, we have read EOF. */
-boolean have_read_eof = FALSE;
+static boolean have_read_eof = FALSE;
/* Name of output files. */
-char *filename_space = NULL;
+static char *filename_space = NULL;
/* Prefix part of output file names. */
-char *prefix = NULL;
+static char *prefix = NULL;
/* Number of digits to use in output file names. */
-int digits = 2;
+static int digits = 2;
/* Number of files created so far. */
-unsigned files_created = 0;
+static unsigned files_created = 0;
/* Number of bytes written to current file. */
-unsigned bytes_written;
+static unsigned bytes_written;
/* Output file pointer. */
-FILE *output_stream = NULL;
+static FILE *output_stream = NULL;
/* Perhaps it would be cleaner to pass arg values instead of indexes. */
-char **global_argv;
+static char **global_argv;
/* If TRUE, do not print the count of bytes in each output file. */
-boolean suppress_count;
+static boolean suppress_count;
/* If TRUE, remove output files on error. */
-boolean remove_files;
+static boolean remove_files;
/* The compiled pattern arguments, which determine how to split
the input file. */
-struct control *controls;
+static struct control *controls;
/* Number of elements in `controls'. */
-unsigned control_used;
+static unsigned control_used;
/* The name this program was run with. */
char *program_name;
/* Allocate N bytes of memory dynamically, with error checking. */
-char *
+static char *
xmalloc (n)
unsigned n;
{
If P is NULL, run xmalloc.
If N is 0, run free and return NULL. */
-char *
+static char *
xrealloc (p, n)
char *p;
unsigned n;
(even if it is this one), these chars will be placed at the
start of the new buffer. */
-void
+static void
save_to_hold_area (start, num)
char *start;
unsigned num;
/* Read up to MAX chars from the input stream into DEST.
Return the number of chars read. */
-int
+static int
read_input (dest, max)
char *dest;
unsigned max;
/* Initialize existing line record P. */
-void
+static void
clear_line_control (p)
struct line *p;
{
/* Initialize all line records in B. */
-void
+static void
clear_all_line_control (b)
struct buffer_record *b;
{
/* Return a new, initialized line record. */
-struct line *
+static struct line *
new_line_control ()
{
struct line *p;
/* Record LINE_START, which is the address of the start of a line
of length LINE_LEN in the large buffer, in the lines buffer of B. */
-void
+static void
keep_new_line (b, line_start, line_len)
struct buffer_record *b;
char *line_start;
a pointer is kept to this area, which will be used when
the next buffer is filled. */
-unsigned
+static unsigned
record_line_starts (b)
struct buffer_record *b;
{
/* Return a new buffer with room to store SIZE bytes, plus
an extra byte for safety. */
-struct buffer_record *
+static struct buffer_record *
create_new_buffer (size)
unsigned size;
{
/* Return a new buffer of at least MINSIZE bytes. If a buffer of at
least that size is currently free, use it, otherwise create a new one. */
-struct buffer_record *
+static struct buffer_record *
get_new_buffer (min_size)
unsigned min_size;
{
/* Add buffer BUF to the list of free buffers. */
-void
+static void
free_buffer (buf)
struct buffer_record *buf;
{
/* Append buffer BUF to the linked list of buffers that contain
some data yet to be processed. */
-void
+static void
save_buffer (buf)
struct buffer_record *buf;
{
Return TRUE if a new buffer was obtained, otherwise false
(in which case end-of-file must have been encountered). */
-boolean
+static boolean
load_buffer ()
{
struct buffer_record *b;
/* Return the line number of the first line that has not yet been retrieved. */
-unsigned
+static unsigned
get_first_line_in_buffer ()
{
if (head == NULL && !load_buffer ())
next line the logical first line.
Return NULL if there is no more input. */
-struct cstring *
+static struct cstring *
remove_line ()
{
struct cstring *line; /* Return value. */
/* Search the buffers for line LINENUM, reading more input if necessary.
Return a pointer to the line, or NULL if it is not found in the file. */
-struct cstring *
+static struct cstring *
find_line (linenum)
unsigned linenum;
{
/* Return TRUE if at least one more line is available for input. */
-boolean
+static boolean
no_more_lines ()
{
return (find_line (current_line + 1) == NULL) ? TRUE : FALSE;
/* Set the name of the input file to NAME and open it. */
-void
+static void
set_input_file (name)
char *name;
{
If IGNORE is TRUE, do not output lines selected here.
ARGNUM is the index in ARGV of the current pattern. */
-void
+static void
write_to_file (last_line, ignore, argnum)
unsigned last_line;
boolean ignore;
/* Output any lines left after all regexps have been processed. */
-void
+static void
dump_rest_of_file ()
{
struct cstring *line;
/* Handle an attempt to read beyond EOF under the control of record P,
on iteration REPETITION if nonzero. */
-void
+static void
handle_line_error (p, repetition)
struct control *p;
int repetition;
P is the control record.
REPETITION is the repetition number. */
-void
+static void
process_line_count (p, repetition)
struct control *p;
int repetition;
handle_line_error (p, repetition);
}
-void
+static void
regexp_error (p, repetition, ignore)
struct control *p;
int repetition;
it unless P->IGNORE is TRUE.
REPETITION is this repeat-count; 0 means the first time. */
-void
+static void
process_regexp (p, repetition)
struct control *p;
int repetition;
/* Split the input file according to the control records we have built. */
-void
+static void
split_file ()
{
register int i, j;
/* Return the name of output file number NUM. */
-char *
+static char *
make_filename (num)
int num;
{
/* Create the next output file. */
-void
+static void
create_output_file ()
{
char *name;
/* Delete all the files we have created. */
-void
+static void
delete_all_files ()
{
int i;
/* Close the current output file and print the count
of characters in this file. */
-void
+static void
close_output_file ()
{
if (output_stream)
/* Optionally remove files created so far; then exit.
Called when an error detected. */
-void
+static void
cleanup ()
{
if (output_stream)
/* Save line LINE to the output file and
increment the character count for the current file. */
-void
+static void
save_line_to_file (line)
struct cstring *line;
{
/* Return a new, initialized control record. */
-struct control *
+static struct control *
new_control_record ()
{
static unsigned control_allocated = 0; /* Total space allocated. */
Return a TRUE if the string consists entirely of digits,
FALSE if not. */
-boolean
+static boolean
string_to_number (result, num)
int *result;
char *num;
if (*num == '\0')
return FALSE;
- while (ch = *num++)
+ while ((ch = *num++))
{
if (!isdigit (ch))
return FALSE;
P is the control record for this regular expression.
NUM is the numeric part of STR. */
-void
+static void
check_for_offset (argnum, p, str, num)
int argnum;
struct control *p;
and store its value in P.
ARGNUM is the ARGV index of STR. */
-void
+static void
parse_repeat_count (argnum, p, str)
int argnum;
struct control *p;
ARGNUM is the ARGV index of STR.
Unless IGNORE is TRUE, mark these lines for output. */
-struct control *
+static struct control *
extract_regexp (argnum, ignore, str)
int argnum;
boolean ignore;
char delim = *str;
char *closing_delim;
struct control *p;
- char *err;
+ const char *err;
closing_delim = rindex (str + 1, delim);
if (closing_delim == NULL)
/* Extract the break patterns from args START through ARGC - 1 of ARGV.
After each pattern, check if the next argument is a repeat count. */
-void
+static void
parse_patterns (argc, start, argv)
int argc;
int start;
}
}
-void
+static void
interrupt_handler ()
{
error (0, 0, "interrupted");
cleanup ();
}
-struct option longopts[] =
+static struct option const longopts[] =
{
{"digits", 1, NULL, 'n'},
{"quiet", 0, NULL, 's'},
exit (0);
}
-void
+static void
usage ()
{
fprintf (stderr, "\
char *xmalloc ();
char *xrealloc ();
-int set_fields ();
-int cut_file ();
-void cut_stream ();
-void cut_bytes ();
-void cut_fields ();
-void enlarge_line ();
void error ();
-void invalid_list ();
-void usage ();
+
+static int set_fields ();
+static int cut_file ();
+static void cut_stream ();
+static void cut_bytes ();
+static void cut_fields ();
+static void enlarge_line ();
+static void invalid_list ();
+static void usage ();
/* The number of elements allocated for the input line
and the byte or field number.
Enlarged as necessary. */
-int line_size;
+static int line_size;
/* Processed output buffer. */
-char *outbuf;
+static char *outbuf;
/* Where to save next char to output. */
-char *outbufptr;
+static char *outbufptr;
/* Raw line buffer for field mode. */
-char *inbuf;
+static char *inbuf;
/* Where to save next input char. */
-char *inbufptr;
+static char *inbufptr;
/* What can be done about a byte or field. */
enum field_action
In field mode, which `delim'-separated fields to output.
Both bytes and fields are numbered starting with 1,
so the first element of `fields' is unused. */
-enum field_action *fields;
+static enum field_action *fields;
enum operating_mode
{
field_mode
};
-enum operating_mode operating_mode;
+static enum operating_mode operating_mode;
/* If nonzero,
for field mode, do not output lines containing no delimeter characters. */
-int delimited_lines_only;
+static int delimited_lines_only;
/* The delimeter character for field mode. */
-unsigned char delim;
+static unsigned char delim;
/* Nonzero if we have ever read standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* The name this program was run with. */
char *program_name;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"bytes", 1, 0, 'b'},
{"characters", 1, 0, 'c'},
Return the number of fields selected. */
-int
+static int
set_fields (fieldstr)
char *fieldstr;
{
/* Process file FILE to standard output.
Return 0 if successful, 1 if not. */
-int
+static int
cut_file (file)
char *file;
{
return 0;
}
-void
+static void
cut_stream (stream)
FILE *stream;
{
/* Print the file open for reading on stream STREAM
with the bytes marked `field_omit' in `fields' removed from each line. */
-void
+static void
cut_bytes (stream)
FILE *stream;
{
All characters are initially stowed in the raw input buffer, until
at least one field has been found. */
-void
+static void
cut_fields (stream)
FILE *stream;
{
/* Extend the buffers to accomodate at least NEW_SIZE characters. */
-void
+static void
enlarge_line (new_size)
int new_size;
{
line_size = new_size;
}
-void
+static void
invalid_list ()
{
error (2, 0, "invalid byte or field list");
}
-void
+static void
usage ()
{
fprintf (stderr, "\
char *xrealloc ();
void error ();
-FILE *next_file ();
-void add_tabstop ();
-void expand ();
-void parse_tabstops ();
-void usage ();
-void validate_tabstops ();
+static FILE *next_file ();
+static void add_tabstop ();
+static void expand ();
+static void parse_tabstops ();
+static void usage ();
+static void validate_tabstops ();
/* If nonzero, convert blanks even after nonblank characters have been
read on the line. */
-int convert_entire_line;
+static int convert_entire_line;
/* If nonzero, the size of all tab stops. If zero, use `tab_list' instead. */
-int tab_size;
+static int tab_size;
/* Array of the explicit column numbers of the tab stops;
after `tab_list' is exhausted, each additional tab is replaced
by a space. The first column is column 0. */
-int *tab_list;
+static int *tab_list;
/* The index of the first invalid element of `tab_list',
where the next element can be added. */
-int first_free_tab;
+static int first_free_tab;
/* Null-terminated array of input filenames. */
-char **file_list;
+static char **file_list;
/* Default for `file_list' if no files are given on the command line. */
-char *stdin_argv[] =
+static char *stdin_argv[] =
{
"-", NULL
};
/* Nonzero if we have ever read standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* Status to return to the system. */
-int exit_status;
+static int exit_status;
/* The name this program was run with. */
char *program_name;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"tabs", 1, NULL, 't'},
{"initial", 0, NULL, 'i'},
/* Add the comma or blank separated list of tabstops STOPS
to the list of tabstops. */
-void
+static void
parse_tabstops (stops)
char *stops;
{
/* Add tab stop TABVAL to the end of `tab_list', except
if TABVAL is -1, do nothing. */
-void
+static void
add_tabstop (tabval)
int tabval;
{
/* Check that the list of tabstops TABS, with ENTRIES entries,
contains only nonzero, ascending values. */
-void
+static void
validate_tabstops (tabs, entries)
int *tabs;
int entries;
/* Change tabs to spaces, writing to stdout.
Read each file in `file_list', in order. */
-void
+static void
expand ()
{
FILE *fp; /* Input stream. */
Open a filename of `-' as the standard input.
Return NULL if there are no more input files. */
-FILE *
+static FILE *
next_file (fp)
FILE *fp;
{
return NULL;
}
-void
+static void
usage ()
{
fprintf (stderr, "\
#include "system.h"
char *xrealloc ();
-int adjust_column ();
-int fold_file ();
void error ();
+static int adjust_column ();
+static int fold_file ();
+
/* If nonzero, try to break on whitespace. */
-int break_spaces;
+static int break_spaces;
/* If nonzero, count bytes, not column positions. */
-int count_bytes;
+static int count_bytes;
/* If nonzero, at least one of the files we read was standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* The name this program was run with. */
char *program_name;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"bytes", 0, NULL, 'b'},
{"spaces", 0, NULL, 's'},
to stdout, with maximum line length WIDTH.
Return 0 if successful, 1 if an error occurs. */
-int
+static int
fold_file (filename, width)
char *filename;
int width;
printing C will move the cursor to.
The first column is 0. */
-int
+static int
adjust_column (column, c)
int column;
char c;
/* Number of bytes per item we are printing.
If 0, head in lines. */
-int unit_size;
+static int unit_size;
/* If nonzero, print filename headers. */
-int print_headers;
+static int print_headers;
/* When to print the filename banners. */
enum header_mode
multiple_files, always, never
};
-int head ();
-int head_bytes ();
-int head_file ();
-int head_lines ();
-long atou ();
void error ();
-void parse_unit ();
-void usage ();
-void write_header ();
void xwrite ();
+static int head ();
+static int head_bytes ();
+static int head_file ();
+static int head_lines ();
+static long atou ();
+static void parse_unit ();
+static void usage ();
+static void write_header ();
+
/* The name this program was run with. */
char *program_name;
/* Have we ever read standard input? */
-int have_read_stdin;
+static int have_read_stdin;
-struct option long_options[] =
+static struct option const long_options[] =
{
{"bytes", 1, NULL, 'c'},
{"lines", 1, NULL, 'n'},
exit (exit_status);
}
-int
+static int
head_file (filename, number)
char *filename;
long number;
}
}
-void
+static void
write_header (filename)
char *filename;
{
xwrite (1, " <==\n", 5);
}
-int
+static int
head (filename, fd, number)
char *filename;
int fd;
return head_lines (filename, fd, number);
}
-int
+static int
head_bytes (filename, fd, bytes_to_write)
char *filename;
int fd;
return 0;
}
-int
+static int
head_lines (filename, fd, lines_to_write)
char *filename;
int fd;
return 0;
}
-void
+static void
parse_unit (str)
char *str;
{
/* Convert STR, a string of ASCII digits, into an unsigned integer.
Return -1 if STR does not represent a valid unsigned integer. */
-long
+static long
atou (str)
char *str;
{
return *str ? -1 : value;
}
-void
+static void
usage ()
{
fprintf (stderr, "\
static int join_field_1, join_field_2;
/* List of fields to print. */
-struct outlist *outlist;
+static struct outlist *outlist;
/* Last element in `outlist', where a new element can be added. */
-struct outlist *outlist_end;
+static struct outlist *outlist_end;
/* Tab character separating fields; if this is NUL fields are separated
by any nonempty string of white space, otherwise by exactly one
/* When using getopt_long_only, no long option can start with
a character that is a short option. */
-static struct option longopts[] =
+static struct option const longopts[] =
{
{"j", 1, NULL, 'j'},
{"j1", 1, NULL, '1'},
};
\f
/* Format of body lines (-b). */
-char *body_type = "t";
+static char *body_type = "t";
/* Format of header lines (-h). */
-char *header_type = "n";
+static char *header_type = "n";
/* Format of footer lines (-f). */
-char *footer_type = "n";
+static char *footer_type = "n";
/* Format currently being used (body, header, or footer). */
-char *current_type;
+static char *current_type;
/* Regex for body lines to number (-bp). */
-struct re_pattern_buffer body_regex;
+static struct re_pattern_buffer body_regex;
/* Regex for header lines to number (-hp). */
-struct re_pattern_buffer header_regex;
+static struct re_pattern_buffer header_regex;
/* Regex for footer lines to number (-fp). */
-struct re_pattern_buffer footer_regex;
+static struct re_pattern_buffer footer_regex;
/* Pointer to current regex, if any. */
-struct re_pattern_buffer *current_regex = NULL;
+static struct re_pattern_buffer *current_regex = NULL;
/* Separator string to print after line number (-s). */
-char *separator_str = "\t";
+static char *separator_str = "\t";
/* Input section delimiter string (-d). */
-char *section_del = DEFAULT_SECTION_DELIMITERS;
+static char *section_del = DEFAULT_SECTION_DELIMITERS;
/* Header delimiter string. */
-char *header_del = NULL;
+static char *header_del = NULL;
/* Header section delimiter length. */
-int header_del_len;
+static int header_del_len;
/* Body delimiter string. */
-char *body_del = NULL;
+static char *body_del = NULL;
/* Body section delimiter length. */
-int body_del_len;
+static int body_del_len;
/* Footer delimiter string. */
-char *footer_del = NULL;
+static char *footer_del = NULL;
/* Footer section delimiter length. */
-int footer_del_len;
+static int footer_del_len;
/* Input buffer. */
-struct linebuffer line_buf;
+static struct linebuffer line_buf;
/* printf format string for line number. */
-char *print_fmt;
+static char *print_fmt;
/* printf format string for unnumbered lines. */
-char *print_no_line_fmt = NULL;
+static char *print_no_line_fmt = NULL;
/* Starting line number on each page (-v). */
-int page_start = 1;
+static int page_start = 1;
/* Line number increment (-i). */
-int page_incr = 1;
+static int page_incr = 1;
/* If TRUE, reset line number at start of each page (-p). */
-int reset_numbers = TRUE;
+static int reset_numbers = TRUE;
/* Number of blank lines to consider to be one line for numbering (-l). */
-int blank_join = 1;
+static int blank_join = 1;
/* Width of line numbers (-w). */
-int lineno_width = 6;
+static int lineno_width = 6;
/* Line number format (-n). */
-enum number_format lineno_format = FORMAT_RIGHT_NOLZ;
+static enum number_format lineno_format = FORMAT_RIGHT_NOLZ;
/* Current print line number. */
-int line_no;
+static int line_no;
/* The name this program was run with. */
char *program_name;
/* Nonzero if we have ever read standard input. */
-int have_read_stdin;
+static int have_read_stdin;
-enum section check_section ();
char *xmalloc ();
char *xrealloc ();
-int build_type_arg ();
-int nl_file ();
-void usage ();
-void process_file ();
-void proc_header ();
-void proc_body ();
-void proc_footer ();
-void proc_text ();
-void print_lineno ();
-void build_print_fmt ();
void error ();
+
+static enum section check_section ();
+static int build_type_arg ();
+static int nl_file ();
+static void usage ();
+static void process_file ();
+static void proc_header ();
+static void proc_body ();
+static void proc_footer ();
+static void proc_text ();
+static void print_lineno ();
+static void build_print_fmt ();
\f
-struct option longopts[] =
+static struct option const longopts[] =
{
{"header-numbering", 1, NULL, 'h'},
{"body-numbering", 1, NULL, 'b'},
/* Process file FILE to standard output.
Return 0 if successful, 1 if not. */
-int
+static int
nl_file (file)
char *file;
{
/* Read and process the file pointed to by FP. */
-void
+static void
process_file (fp)
FILE *fp;
{
\f
/* Return the type of line in `line_buf'. */
-enum section
+static enum section
check_section ()
{
if (line_buf.length < 2 || memcmp (line_buf.buffer, section_del, 2))
/* Switch to a header section. */
-void
+static void
proc_header ()
{
current_type = header_type;
/* Switch to a body section. */
-void
+static void
proc_body ()
{
current_type = body_type;
/* Switch to a footer section. */
-void
+static void
proc_footer ()
{
current_type = footer_type;
/* Process a regular text line in `line_buf'. */
-void
+static void
proc_text ()
{
static int blank_lines = 0; /* Consecutive blank lines so far. */
\f
/* Print and increment the line number. */
-void
+static void
print_lineno ()
{
printf (print_fmt, line_no);
/* Build the printf format string, based on `lineno_format'. */
-void
+static void
build_print_fmt ()
{
/* 12 = 10 chars for lineno_width, 1 for %, 1 for \0. */
/* Set the command line flag TYPEP and possibly the regex pointer REGEXP,
according to `optarg'. */
-int
+static int
build_type_arg (typep, regexp)
char **typep;
struct re_pattern_buffer *regexp;
{
- char *errmsg;
+ const char *errmsg;
int rval = TRUE;
int optlen;
\f
/* Print a usage message and quit. */
-void
+static void
usage ()
{
fprintf (stderr, "\
#define MAX_FP_TYPE_SIZE sizeof(LONG_DOUBLE)
static enum size_spec fp_type_size[MAX_FP_TYPE_SIZE + 1];
-static struct option long_options[] =
+static struct option const long_options[] =
{
/* POSIX options. */
{"skip-bytes", 1, NULL, 'j'},
#include <sys/types.h>
#include "system.h"
-char *collapse_escapes ();
+void error ();
char *xmalloc ();
char *xrealloc ();
-int paste_parallel ();
-int paste_serial ();
-void error ();
-void usage ();
+
+static char *collapse_escapes ();
+static int paste_parallel ();
+static int paste_serial ();
+static void usage ();
/* Indicates that no delimiter should be added in the current position. */
#define EMPTY_DELIM '\0'
char *program_name;
/* If nonzero, we have read standard input at some point. */
-int have_read_stdin;
+static int have_read_stdin;
/* If nonzero, merge subsequent lines of each file rather than
corresponding lines from each file in parallel. */
-int serial_merge;
+static int serial_merge;
/* The delimeters between lines of input files (used cyclically). */
-char *delims;
+static char *delims;
/* A pointer to the character after the end of `delims'. */
-char *delim_end;
+static char *delim_end;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"serial", 0, 0, 's'},
{"delimiters", 1, 0, 'd'},
Return a pointer to the character after the new end of STRPTR. */
-char *
+static char *
collapse_escapes (strptr)
char *strptr;
{
Return 0 if no errors, 1 if one or more files could not be
opened or read. */
-int
+static int
paste_parallel (nfiles, fnamptr)
int nfiles;
char **fnamptr;
Return 0 if no errors, 1 if one or more files could not be
opened or read. */
-int
+static int
paste_serial (nfiles, fnamptr)
int nfiles;
char **fnamptr;
return errors;
}
-void
+static void
usage ()
{
fprintf (stderr, "\
#define ISDIGIT(c) isdigit (c)
#endif
-int char_to_clump ();
-int read_line ();
-int print_page ();
-int print_stored ();
char *xmalloc ();
char *xrealloc ();
-int open_file ();
-int skip_to_page ();
void error ();
-void getoptarg ();
-void usage ();
-void print_files ();
-void init_header ();
-void init_store_cols ();
-void store_columns ();
-void balance ();
-void store_char ();
-void pad_down ();
-void read_rest_of_line ();
-void print_char ();
-void cleanup ();
+
+static int char_to_clump ();
+static int read_line ();
+static int print_page ();
+static int print_stored ();
+static int open_file ();
+static int skip_to_page ();
+static void getoptarg ();
+static void usage ();
+static void print_files ();
+static void init_header ();
+static void init_store_cols ();
+static void store_columns ();
+static void balance ();
+static void store_char ();
+static void pad_down ();
+static void read_rest_of_line ();
+static void print_char ();
+static void cleanup ();
#ifndef TRUE
#define TRUE 1
#define NULLCOL (COLUMN *)0
/* All of the columns to print. */
-COLUMN *column_vector;
+static COLUMN *column_vector;
/* When printing a single file in multiple downward columns,
we store the leftmost columns contiguously in buff.
To print a line from buff, get the index of the first char
from line_vector[i], and print up to line_vector[i + 1]. */
-char *buff;
+static char *buff;
/* Index of the position in buff where the next character
will be stored. */
-int buff_current;
+static int buff_current;
/* The number of characters in buff.
Used for allocation of buff and to detect overflow of buff. */
-int buff_allocated;
+static int buff_allocated;
/* Array of indices into buff.
Each entry is an index of the first character of a line.
This is used when storing lines to facilitate shuffling when
we do column balancing on the last page. */
-int *line_vector;
+static int *line_vector;
/* Array of horizonal positions.
For each line in line_vector, end_vector[line] is the horizontal
position we are in after printing that line. We keep track of this
so that we know how much we need to pad to prepare for the next
column. */
-int *end_vector;
+static int *end_vector;
/* (-m) True means we're printing multiple files in parallel. */
-int parallel_files = FALSE;
+static int parallel_files = FALSE;
/* (-[0-9]+) True means we're given an option explicitly specifying
number of columns. Used to detect when this option is used with -m. */
-int explicit_columns = FALSE;
+static int explicit_columns = FALSE;
/* (-t) True means we're printing headers and footers. */
-int extremities = TRUE;
+static int extremities = TRUE;
/* True means we need to print a header as soon as we know we've got input
to print after it. */
-int print_a_header;
+static int print_a_header;
/* (-h) True means we're using the standard header rather than a
customized one specified by the -h flag. */
-int standard_header = TRUE;
+static int standard_header = TRUE;
/* (-f) True means use formfeeds instead of newlines to separate pages. */
-int use_form_feed = FALSE;
+static int use_form_feed = FALSE;
/* True means we haven't encountered any filenames in the argument list. */
-int input_is_stdin = TRUE;
+static int input_is_stdin = TRUE;
/* True means we have read the standard input. */
-int have_read_stdin = FALSE;
+static int have_read_stdin = FALSE;
/* True means the -a flag has been given. */
-int print_across_flag = FALSE;
+static int print_across_flag = FALSE;
/* True means we're printing one file in multiple (>1) downward columns. */
-int storing_columns = TRUE;
+static int storing_columns = TRUE;
/* (-b) True means balance columns on the last page as Sys V does. */
-int balance_columns = FALSE;
+static int balance_columns = FALSE;
/* (-l) Number of lines on a page, including header and footer lines. */
-int lines_per_page = 66;
+static int lines_per_page = 66;
/* Number of lines in the header and footer can be reset to 0 using
the -t flag. */
-int lines_per_header = 5;
-int lines_per_body;
-int lines_per_footer = 5;
+static int lines_per_header = 5;
+static int lines_per_body;
+static int lines_per_footer = 5;
/* (-w) Width in characters of the page. Does not include the width of
the margin. */
-int chars_per_line = 72;
+static int chars_per_line = 72;
/* Number of characters in a column. Based on the gutter and page widths. */
-int chars_per_column;
+static int chars_per_column;
/* (-e) True means convert tabs to spaces on input. */
-int untabify_input = FALSE;
+static int untabify_input = FALSE;
/* (-e) The input tab character. */
-char input_tab_char = '\t';
+static char input_tab_char = '\t';
/* (-e) Tabstops are at chars_per_tab, 2*chars_per_tab, 3*chars_per_tab, ...
where the leftmost column is 1. */
-int chars_per_input_tab = 8;
+static int chars_per_input_tab = 8;
/* (-i) True means convert spaces to tabs on output. */
-int tabify_output = FALSE;
+static int tabify_output = FALSE;
/* (-i) The output tab character. */
-char output_tab_char = '\t';
+static char output_tab_char = '\t';
/* (-i) The width of the output tab. */
-int chars_per_output_tab = 8;
+static int chars_per_output_tab = 8;
/* Keeps track of pending white space. When we hit a nonspace
character after some whitespace, we print whitespace, tabbing
if necessary to get to output_position + spaces_not_printed. */
-int spaces_not_printed;
+static int spaces_not_printed;
/* Number of spaces between columns (though tabs can be used when possible to
use up the equivalent amount of space). Not sure if this is worth making
a flag for. BSD uses 0, Sys V uses 1. Sys V looks better. */
-int chars_per_gutter = 1;
+static int chars_per_gutter = 1;
/* (-o) Number of spaces in the left margin (tabs used when possible). */
-int chars_per_margin = 0;
+static int chars_per_margin = 0;
/* Position where the next character will fall.
Leftmost position is 0 + chars_per_margin.
Rightmost position is chars_per_margin + chars_per_line - 1.
This is important for converting spaces to tabs on output. */
-int output_position;
+static int output_position;
/* Horizontal position relative to the current file.
(output_position depends on where we are on the page;
input_position depends on where we are in the file.)
Important for converting tabs to spaces on input. */
-int input_position;
+static int input_position;
/* Count number of failed opens so we can exit with non-zero
status if there were any. */
-int failed_opens = 0;
+static int failed_opens = 0;
/* The horizontal position we'll be at after printing a tab character
of width c_ from the position h_. */
#define tab_width(c_, h_) - h_ % c_ + c_
/* (-NNN) Number of columns of text to print. */
-int columns = 1;
+static int columns = 1;
/* (+NNN) Page number on which to begin printing. */
-int first_page_number = 1;
+static int first_page_number = 1;
/* Number of files open (not closed, not on hold). */
-int files_ready_to_read = 0;
+static int files_ready_to_read = 0;
/* Number of columns with either an open file or stored lines. */
-int cols_ready_to_print = 0;
+static int cols_ready_to_print = 0;
/* Current page number. Displayed in header. */
-int page_number;
+static int page_number;
/* Current line number. Displayed when -n flag is specified.
Otherwise, line numbering is as follows:
1 foo 3 goo 5 too
2 moo 4 hoo 6 zoo */
-int line_number;
+static int line_number;
/* (-n) True means lines should be preceded by numbers. */
-int numbered_lines = FALSE;
-
-/* True means print a number as soon as we know we'll be printing
- from the current column. */
-int print_a_number;
+static int numbered_lines = FALSE;
/* (-n) Character which follows each line number. */
-char number_separator = '\t';
+static char number_separator = '\t';
/* (-n) Width in characters of a line number. */
-int chars_per_number = 5;
+static int chars_per_number = 5;
/* Used when widening the first column to accommodate numbers -- only
needed when printing files in parallel. Includes width of both the
number and the number_separator. */
-int number_width;
+static int number_width;
/* Buffer sprintf uses to format a line number. */
-char *number_buff;
+static char *number_buff;
/* (-v) True means unprintable characters are printed as escape sequences.
control-g becomes \007. */
-int use_esc_sequence = FALSE;
+static int use_esc_sequence = FALSE;
/* (-c) True means unprintable characters are printed as control prefixes.
control-g becomes ^G. */
-int use_cntrl_prefix = FALSE;
+static int use_cntrl_prefix = FALSE;
/* (-d) True means output is double spaced. */
-int double_space = FALSE;
+static int double_space = FALSE;
/* Number of files opened initially in init_files. Should be 1
unless we're printing multiple files in parallel. */
-int total_files = 0;
+static int total_files = 0;
/* (-r) True means don't complain if we can't open a file. */
-int ignore_failed_opens = FALSE;
+static int ignore_failed_opens = FALSE;
/* (-s) True means we separate columns with a specified character. */
-int use_column_separator = FALSE;
+static int use_column_separator = FALSE;
/* Character used to separate columns if the the -s flag has been specified. */
-char column_separator = '\t';
+static char column_separator = '\t';
/* Number of separator characters waiting to be printed as soon as we
know that we have any input remaining to be printed. */
-int separators_not_printed;
+static int separators_not_printed;
/* Position we need to pad to, as soon as we know that we have input
remaining to be printed. */
-int padding_not_printed;
+static int padding_not_printed;
/* True means we should pad the end of the page. Remains false until we
know we have a page to print. */
-int pad_vertically;
+static int pad_vertically;
/* (-h) String of characters used in place of the filename in the header. */
-char *custom_header;
+static char *custom_header;
/* String containing the date, filename or custom header, and "Page ". */
-char *header;
+static char *header;
-int *clump_buff;
+static int *clump_buff;
/* True means we truncate lines longer than chars_per_column. */
-int truncate_lines = FALSE;
+static int truncate_lines = FALSE;
/* The name under which this program was invoked. */
char *program_name;
separator, and k is the optional width of the field used when printing
a number. */
-void
+static void
getoptarg (arg, switch_char, character, number)
char *arg, switch_char, *character;
int *number;
\f
/* Set parameters related to formatting. */
-void
+static void
init_parameters (number_of_files)
int number_of_files;
{
Return 1 if (number_of_files > 0) and no files can be opened,
0 otherwise. */
-int
+static int
init_fps (number_of_files, av)
int number_of_files;
char **av;
Determine the horizontal position desired when we begin
printing a column (p->start_position). */
-void
+static void
init_funcs ()
{
int i, h, h_next;
\f
/* Open a file. Return nonzero if successful, zero if failed. */
-int
+static int
open_file (name, p)
char *name;
COLUMN *p;
If we aren't dealing with multiple files in parallel, we change
the status of all columns in the column list to reflect the close. */
-void
+static void
close_file (p)
COLUMN *p;
{
If we aren't dealing with parallel files, we must change the
status of all columns in the column list. */
-void
+static void
hold_file (p)
COLUMN *p;
{
/* Undo hold_file -- go through the column list and change any
ON_HOLD columns to OPEN. Used at the end of each page. */
-void
+static void
reset_status ()
{
int i = columns;
in each column.
Print the file(s). */
-void
+static void
print_files (number_of_files, av)
int number_of_files;
char **av;
It might be nice to have a "blank headers" option, since
pr -h "" still prints the date and page number. */
-void
+static void
init_header (filename, desc)
char *filename;
int desc;
if we're reading straight from the file)
Keep track of this total so we know when to stop printing */
-void
+static void
init_page ()
{
int j;
reset the status of all files -- any files which where on hold because
of formfeeds are now put back into the lineup. */
-int
+static int
print_page ()
{
int j;
because the last entry tells us the index of the last character,
which we need to know in order to print the last line in buff. */
-void
+static void
init_store_cols ()
{
int total_lines = lines_per_body * columns;
buff_start is the index in buff of the first character in the
current line. */
-void
+static void
store_columns ()
{
int i, j;
balance (line);
}
-void
+static void
balance (total_stored)
int total_stored;
{
/* Store a character in the buffer. */
-void
+static void
store_char (c)
int c;
{
buff[buff_current++] = (char) c;
}
-void
+static void
number (p)
COLUMN *p;
{
/* Print (or store) padding until the current horizontal position
is position. */
-void
+static void
pad_across_to (position)
int position;
{
If the user has requested a formfeed, use one.
Otherwise, use newlines. */
-void
+static void
pad_down (lines)
int lines;
{
hit. Used when we've truncated a line and we no longer need
to print or store its characters. */
-void
+static void
read_rest_of_line (p)
COLUMN *p;
{
of our desired horizontal position and delays printing
until this function is called. */
-void
+static void
print_white_space ()
{
register int h_new;
We keep a count until we know that we'll be printing a line,
then print_separators() is called. */
-void
+static void
print_separators ()
{
for (; separators_not_printed > 0; --separators_not_printed)
/* Print (or store, depending on p->char_func) a clump of N
characters. */
-void
+static void
print_clump (p, n, clump)
COLUMN *p;
int n;
a nonspace is encountered, call print_white_space() to print the
required number of tabs and spaces. */
-void
+static void
print_char (c)
int c;
{
/* Skip to page PAGE before printing. */
-int
+static int
skip_to_page (page)
int page;
{
Formfeeds are assumed to use up two lines at the beginning of
the page. */
-void
+static void
print_header ()
{
if (!use_form_feed)
Return FALSE if we exceed chars_per_column before reading
an end of line character, TRUE otherwise. */
-int
+static int
read_line (p)
COLUMN *p;
{
Return TRUE, meaning there is no need to call read_rest_of_line. */
-int
+static int
print_stored (p)
COLUMN *p;
{
characters in clump_buff. (e.g, the width of '\b' is -1, while the
number of characters is 1.) */
-int
+static int
char_to_clump (c)
int c;
{
Free everything we've xmalloc'ed, except `header'. */
-void
+static void
cleanup ()
{
if (number_buff)
\f
/* Complain, print a usage message, and die. */
-void
+static void
usage (reason)
char *reason;
{
{
char *name;
int val;
-} monthtab[] =
+} const monthtab[] =
{
- "APR", 4,
- "AUG", 8,
- "DEC", 12,
- "FEB", 2,
- "JAN", 1,
- "JUL", 7,
- "JUN", 6,
- "MAR", 3,
- "MAY", 5,
- "NOV", 11,
- "OCT", 10,
- "SEP", 9
+ {"APR", 4},
+ {"AUG", 8},
+ {"DEC", 12},
+ {"FEB", 2},
+ {"JAN", 1},
+ {"JUL", 7},
+ {"JUN", 6},
+ {"MAR", 3},
+ {"MAY", 5},
+ {"NOV", 11},
+ {"OCT", 10},
+ {"SEP", 9}
};
/* During the merge phase, the number of files to merge at once. */
else
logb = 0;
- if (tmp = logb - loga)
+ if ((tmp = logb - loga) != 0)
return tmp;
if (!loga)
else
logb = 0;
- if (tmp = loga - logb)
+ if ((tmp = loga - logb) != 0)
return tmp;
if (!loga)
if (diff)
return key->reverse ? -diff : diff;
- if (diff = lena - lenb)
+ if ((diff = lena - lenb) != 0)
return key->reverse ? -diff : diff;
}
char *xmalloc ();
void error ();
-int convint ();
-int isdigits ();
-int stdread ();
-void line_bytes_split ();
-void bytes_split ();
-void cwrite ();
-void lines_split ();
-void next_file_name ();
+static int convint ();
+static int isdigits ();
+static int stdread ();
+static void line_bytes_split ();
+static void bytes_split ();
+static void cwrite ();
+static void lines_split ();
+static void next_file_name ();
/* Name under which this program was invoked. */
char *program_name;
/* Base name of output files. */
-char *outfile;
+static char *outfile;
/* Pointer to the end of the prefix in OUTFILE.
Suffixes are inserted here. */
-char *outfile_mid;
+static char *outfile_mid;
/* Pointer to the end of OUTFILE. */
-char *outfile_end;
+static char *outfile_end;
/* Status for outfile name generation. */
-unsigned outfile_count = -1;
-unsigned outfile_name_limit = 25 * 26;
-unsigned outfile_name_generation = 1;
+static unsigned outfile_count = -1;
+static unsigned outfile_name_limit = 25 * 26;
+static unsigned outfile_name_generation = 1;
/* Name of input file. May be "-". */
-char *infile;
+static char *infile;
/* Descriptor on which input file is open. */
-int input_desc;
+static int input_desc;
/* Descriptor on which output file is open. */
-int output_desc;
+static int output_desc;
\f
-void
+static void
usage (reason)
char *reason;
{
exit (2);
}
\f
-struct option longopts[] =
+static struct option const longopts[] =
{
{"bytes", 1, NULL, 'b'},
{"lines", 1, NULL, 'l'},
case type_byteslines:
line_bytes_split (num);
break;
+
+ default:
+ abort ();
}
if (close (input_desc) < 0)
/* Return nonzero if the string STR is composed entirely of decimal digits. */
-int
+static int
isdigits (str)
char *str;
{
to mean kilo or `m' to mean mega.
Return 0 if STR is valid, -1 if not. */
-int
+static int
convint (str, val)
char *str;
int *val;
/* Split into pieces of exactly NCHARS bytes.
Use buffer BUF, whose size is BUFSIZE. */
-void
+static void
bytes_split (nchars, buf, bufsize)
int nchars;
char *buf;
/* Split into pieces of exactly NLINES lines.
Use buffer BUF, whose size is BUFSIZE. */
-void
+static void
lines_split (nlines, buf, bufsize)
int nlines;
char *buf;
than NCHARS bytes, and are split on line boundaries except
where lines longer than NCHARS bytes occur. */
-void
+static void
line_bytes_split (nchars)
int nchars;
{
If NEW_FILE_FLAG is nonzero, open the next output file.
Otherwise add to the same output file already in use. */
-void
+static void
cwrite (new_file_flag, bp, bytes)
int new_file_flag;
char *bp;
Return the number of bytes successfully read.
If this is less than NCHARS, do not call `stdread' again. */
-int
+static int
stdread (buf, nchars)
char *buf;
int nchars;
/* Compute the next sequential output file name suffix and store it
into the string `outfile' at the position pointed to by `outfile_mid'. */
-void
+static void
next_file_name ()
{
int x;
#include <getopt.h>
#include "system.h"
-int bsd_sum_file ();
-int sysv_sum_file ();
+static int bsd_sum_file ();
+static int sysv_sum_file ();
+
void error ();
/* The name this program was run with. */
char *program_name;
/* Nonzero if any of the files read were the standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* Right-rotate 32-bit integer variable C. */
#define ROTATE_RIGHT(c) if ((c) & 01) (c) = ((c) >>1) + 0x8000; else (c) >>= 1;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"sysv", 0, NULL, 's'},
{NULL, 0, NULL, 0}
The checksum varies depending on sizeof(int).
Return 0 if successful, -1 if an error occurs. */
-int
+static int
bsd_sum_file (file, print_name)
char *file;
int print_name;
If PRINT_NAME is >0, print FILE next to the checksum and size.
Return 0 if successful, -1 if an error occurs. */
-int
+static int
sysv_sum_file (file, print_name)
char *file;
int print_name;
char *mktemp ();
-RETSIGTYPE cleanup ();
-int tac ();
-int tac_file ();
-int tac_stdin ();
-char *xmalloc ();
-char *xrealloc ();
-void output ();
+static RETSIGTYPE cleanup ();
+static int tac ();
+static int tac_file ();
+static int tac_stdin ();
+static char *xmalloc ();
+static char *xrealloc ();
+static void output ();
+static void save_stdin ();
+static void xwrite ();
+
void error ();
-void save_stdin ();
-void xwrite ();
/* The name this program was run with. */
char *program_name;
/* The string that separates the records of the file. */
-char *separator;
+static char *separator;
/* If nonzero, print `separator' along with the record preceding it
in the file; otherwise with the record following it. */
-int separator_ends_record;
+static int separator_ends_record;
/* 0 if `separator' is to be matched as a regular expression;
otherwise, the length of `separator', used as a sentinel to
stop the search. */
-int sentinel_length;
+static int sentinel_length;
/* The length of a match with `separator'. If `sentinel_length' is 0,
`match_length' is computed every time a match succeeds;
otherwise, it is simply the length of `separator'. */
-int match_length;
+static int match_length;
/* The input buffer. */
-char *buffer;
+static char *buffer;
/* The number of bytes to read at once into `buffer'. */
-unsigned read_size;
+static unsigned read_size;
/* The size of `buffer'. This is read_size * 2 + sentinel_length + 2.
The extra 2 bytes allow `past_end' to have a value beyond the
end of `buffer' and `match_start' to run off the front of `buffer'. */
-unsigned buffer_size;
+static unsigned buffer_size;
/* The compiled regular expression representing `separator'. */
static struct re_pattern_buffer compiled_separator;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"before", 0, &separator_ends_record, 0},
{"regex", 0, &sentinel_length, 0},
int argc;
char **argv;
{
- char *error_message; /* Return value from re_compile_pattern. */
+ const char *error_message; /* Return value from re_compile_pattern. */
int optc, errors;
int have_read_stdin = 0;
file `tempfile' first if it is a pipe.
Return 0 if ok, 1 if an error occurs. */
-int
+static int
tac_stdin ()
{
/* Previous values of signal handlers. */
/* Make a copy of the standard input in `tempfile'. */
-void
+static void
save_stdin ()
{
static char *template = NULL;
/* Print FILE in reverse.
Return 0 if ok, 1 if an error occurs. */
-int
+static int
tac_file (file)
char *file;
{
/* Print in reverse the file open on descriptor FD for reading FILE.
Return 0 if ok, 1 if an error occurs. */
-int
+static int
tac (fd, file)
int fd;
char *file;
/* Print the characters from START to PAST_END - 1.
If START is NULL, just flush the buffer. */
-void
+static void
output (start, past_end)
char *start;
char *past_end;
bytes_in_buffer += bytes_to_add;
}
-RETSIGTYPE
+static RETSIGTYPE
cleanup ()
{
unlink (tempfile);
exit (1);
}
-void
+static void
xwrite (desc, buffer, size)
int desc;
char *buffer;
/* Allocate N bytes of memory dynamically, with error checking. */
-char *
+static char *
xmalloc (n)
unsigned n;
{
/* Change the size of memory area P to N bytes, with error checking. */
-char *
+static char *
xrealloc (p, n)
char *p;
unsigned n;
/* Number of bytes per item we are printing.
If 0, tail in lines. */
-int unit_size;
+static int unit_size;
/* If nonzero, read from end of file until killed. */
-int forever;
+static int forever;
/* If nonzero, count from start of file instead of end. */
-int from_start;
+static int from_start;
/* If nonzero, print filename headers. */
-int print_headers;
+static int print_headers;
/* When to print the filename banners. */
enum header_mode
};
char *xmalloc ();
-int file_lines ();
-int pipe_bytes ();
-int pipe_lines ();
-int start_bytes ();
-int start_lines ();
-int tail ();
-int tail_bytes ();
-int tail_file ();
-int tail_lines ();
-long atou();
-void dump_remainder ();
-void error ();
-void parse_unit ();
-void usage ();
-void write_header ();
void xwrite ();
+void error ();
+
+static int file_lines ();
+static int pipe_bytes ();
+static int pipe_lines ();
+static int start_bytes ();
+static int start_lines ();
+static int tail ();
+static int tail_bytes ();
+static int tail_file ();
+static int tail_lines ();
+static long atou();
+static void dump_remainder ();
+static void parse_unit ();
+static void usage ();
+static void write_header ();
/* The name this program was run with. */
char *program_name;
/* Nonzero if we have ever read standard input. */
-int have_read_stdin;
+static int have_read_stdin;
-struct option long_options[] =
+static struct option const long_options[] =
{
{"bytes", 1, NULL, 'c'},
{"follow", 0, NULL, 'f'},
"-" for FILENAME means the standard input.
Return 0 if successful, 1 if an error occurred. */
-int
+static int
tail_file (filename, number)
char *filename;
long number;
}
}
-void
+static void
write_header (filename)
char *filename;
{
in FD.
Return 0 if successful, 1 if an error occurred. */
-int
+static int
tail (filename, fd, number)
char *filename;
int fd;
using NUMBER characters.
Return 0 if successful, 1 if an error occurred. */
-int
+static int
tail_bytes (filename, fd, number)
char *filename;
int fd;
using NUMBER lines.
Return 0 if successful, 1 if an error occurred. */
-int
+static int
tail_lines (filename, fd, number)
char *filename;
int fd;
byte of the file + 1).
Return 0 if successful, 1 if an error occurred. */
-int
+static int
file_lines (filename, fd, number, pos)
char *filename;
int fd;
Buffer the text as a linked list of LBUFFERs, adding them as needed.
Return 0 if successful, 1 if an error occured. */
-int
+static int
pipe_lines (filename, fd, number)
char *filename;
int fd;
This is a stripped down version of pipe_lines.
Return 0 if successful, 1 if an error occurred. */
-int
+static int
pipe_bytes (filename, fd, number)
char *filename;
int fd;
any extra characters that were read beyond that.
Return 1 on error, 0 if ok. */
-int
+static int
start_bytes (filename, fd, number)
char *filename;
int fd;
any extra characters that were read beyond that.
Return 1 on error, 0 if ok. */
-int
+static int
start_lines (filename, fd, number)
char *filename;
int fd;
to the end. If `forever' is nonzero, keep reading from the
end of the file until killed. */
-void
+static void
dump_remainder (filename, fd)
char *filename;
int fd;
}
}
-void
+static void
parse_unit (str)
char *str;
{
/* Convert STR, a string of ASCII digits, into an unsigned integer.
Return -1 if STR does not represent a valid unsigned integer. */
-long
+static long
atou (str)
char *str;
{
return *str ? -1 : value;
}
-void
+static void
usage ()
{
fprintf (stderr, "\
from upper or lower. In fact, no other character classes are allowed
when translating, but that condition is tested elsewhere. This array
is indexed by values of type enum Upper_Lower_class. */
-static int class_ok[3][3] =
+static int const class_ok[3][3] =
{
{0, 1, 0},
{1, 0, 0},
#define IO_BUF_SIZE BUFSIZ
static unsigned char io_buf[IO_BUF_SIZE];
-char *char_class_name[] =
+static char const* const char_class_name[] =
{
"alnum", "alpha", "blank", "cntrl", "digit", "graph",
"lower", "print", "punct", "space", "upper", "xdigit"
two specification strings and the delete switch is not given. */
static char xlate[N_CHARS];
-static struct option long_options[] =
+static struct option const long_options[] =
{
{"complement", 0, NULL, 'c'},
{"delete", 0, NULL, 'd'},
unsigned int i;
for (i = 0; i < N_CHAR_CLASSES; i++)
- if (strcmp (class_str, char_class_name[i]) == 0)
+ if (strcmp ((const char *) class_str, char_class_name[i]) == 0)
return (enum Char_class) i;
return CC_NO_CLASS;
}
char *xrealloc ();
void error ();
-FILE *next_file ();
-void add_tabstop ();
-void parse_tabstops ();
-void unexpand ();
-void usage ();
-void validate_tabstops ();
+static FILE *next_file ();
+static void add_tabstop ();
+static void parse_tabstops ();
+static void unexpand ();
+static void usage ();
+static void validate_tabstops ();
/* If nonzero, convert blanks even after nonblank characters have been
read on the line. */
-int convert_entire_line;
+static int convert_entire_line;
/* If nonzero, the size of all tab stops. If zero, use `tab_list' instead. */
-int tab_size;
+static int tab_size;
/* Array of the explicit column numbers of the tab stops;
after `tab_list' is exhausted, the rest of the line is printed
unchanged. The first column is column 0. */
-int *tab_list;
+static int *tab_list;
/* The index of the first invalid element of `tab_list',
where the next element can be added. */
-int first_free_tab;
+static int first_free_tab;
/* Null-terminated array of input filenames. */
-char **file_list;
+static char **file_list;
/* Default for `file_list' if no files are given on the command line. */
-char *stdin_argv[] =
+static char *stdin_argv[] =
{
"-", NULL
};
/* Nonzero if we have ever read standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* Status to return to the system. */
-int exit_status;
+static int exit_status;
/* The name this program was run with. */
char *program_name;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"tabs", 1, NULL, 't'},
{"all", 0, NULL, 'a'},
/* Add the comma or blank separated list of tabstops STOPS
to the list of tabstops. */
-void
+static void
parse_tabstops (stops)
char *stops;
{
/* Add tab stop TABVAL to the end of `tab_list', except
if TABVAL is -1, do nothing. */
-void
+static void
add_tabstop (tabval)
int tabval;
{
/* Check that the list of tabstops TABS, with ENTRIES entries,
contains only nonzero, ascending values. */
-void
+static void
validate_tabstops (tabs, entries)
int *tabs;
int entries;
/* Change spaces to tabs, writing to stdout.
Read each file in `file_list', in order. */
-void
+static void
unexpand ()
{
FILE *fp; /* Input stream. */
Open a filename of `-' as the standard input.
Return NULL if there are no more input files. */
-FILE *
+static FILE *
next_file (fp)
FILE *fp;
{
return NULL;
}
-void
+static void
usage ()
{
fprintf (stderr, "\
#define min(x, y) ((x) < (y) ? (x) : (y))
-char *find_field ();
-int different ();
-void check_file ();
void error ();
-void usage ();
-void writeline ();
+
+static char *find_field ();
+static int different ();
+static void check_file ();
+static void usage ();
+static void writeline ();
/* Number of fields to skip on each line when doing comparisons. */
-int skip_fields;
+static int skip_fields;
/* Number of chars to skip after skipping any fields. */
-int skip_chars;
+static int skip_chars;
/* Number of chars to compare; if 0, compare the whole lines. */
-int check_chars;
+static int check_chars;
enum countmode
{
/* Whether and how to precede the output lines with a count of the number of
times they occurred in the input. */
-enum countmode countmode;
+static enum countmode countmode;
enum output_mode
{
};
/* Which lines to output. */
-enum output_mode mode;
+static enum output_mode mode;
/* The name this program was run with. */
char *program_name;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"count", 0, NULL, 'c'},
{"repeated", 0, NULL, 'd'},
/* Process input file INFILE with output to OUTFILE.
If either is "-", use the standard I/O stream for it instead. */
-void
+static void
check_file (infile, outfile)
char *infile, *outfile;
{
/* Given a linebuffer LINE,
return a pointer to the beginning of the line's field to be compared. */
-char *
+static char *
find_field (line)
struct linebuffer *line;
{
but rather to the beginnings of the fields to compare.
OLDLEN and NEWLEN are their lengths. */
-int
+static int
different (old, new, oldlen, newlen)
char *old;
char *new;
If requested, print the number of times it occurred, as well;
LINECOUNT + 1 is the number of times that the line occurred. */
-void
+static void
writeline (line, stream, linecount)
struct linebuffer *line;
FILE *stream;
putc ('\n', stream);
}
\f
-void
+static void
usage ()
{
fprintf (stderr, "\
#define BUFFER_SIZE (16 * 1024)
void error ();
-void wc ();
-void wc_file ();
-void write_counts ();
+
+static void wc ();
+static void wc_file ();
+static void write_counts ();
/* Cumulative number of lines, words, and chars in all files so far. */
-unsigned long total_lines, total_words, total_chars;
+static unsigned long total_lines, total_words, total_chars;
/* Which counts to print. */
-int print_lines, print_words, print_chars;
+static int print_lines, print_words, print_chars;
/* Nonzero if we have ever read the standard input. */
-int have_read_stdin;
+static int have_read_stdin;
/* The name this program was run with. */
char *program_name;
/* The error code to return to the system. */
-int exit_status;
+static int exit_status;
-struct option longopts[] =
+static struct option const longopts[] =
{
{"bytes", 0, NULL, 'c'},
{"chars", 0, NULL, 'c'},
exit (exit_status);
}
-void
+static void
wc_file (file)
char *file;
{
}
}
-void
+static void
wc (fd, file)
int fd;
char *file;
total_chars += chars;
}
-void
+static void
write_counts (lc, wc, cc, file)
unsigned long lc, wc, cc;
char *file;