Automatically generated by Pod::Man 4.10 (Pod::Simple 3.35) Standard preamble: ========================================================================..
..
..
Set up some character translations and predefined strings. \*(-- will give an unbreakable dash, \*(PI will give pi, \*(L" will give a left double quote, and \*(R" will give a right double quote. \*(C+ will give a nicer C++. Capital omega is used to do unbreakable dashes and therefore won't be available. \*(C` and \*(C' expand to `' in nroff, nothing in troff, for use with C<>..tr \(*W-
. ds -- \(*W-
. ds PI pi
. if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch
. if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch
. ds L" ""
. ds R" ""
. ds C` ""
. ds C' ""
'br\}
. ds -- \|\(em\|
. ds PI \(*p
. ds L" ``
. ds R" ''
. ds C`
. ds C'
'br\}
Escape single quotes in literal strings from groff's Unicode transform. If the F register is >0, we'll generate index entries on stderr for titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index entries marked with X<> in POD. Of course, you'll have to process the output yourself in some meaningful fashion. Avoid warning from groff about undefined register 'F'...
.nr rF 0
. if \nF \{\
. de IX
. tm Index:\\$1\t\\n%\t"\\$2"
..
. if !\nF==2 \{\
. nr % 0
. nr F 2
. \}
. \}
.\}
.rr rF
Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). Fear. Run. Save yourself. No user-serviceable parts.. \" fudge factors for nroff and troff
. ds #H 0
. ds #V .8m
. ds #F .3m
. ds #[ \f1
. ds #]
.\}
. ds #H ((1u-(\\\\n(.fu%2u))*.13m)
. ds #V .6m
. ds #F 0
. ds #[ \&
. ds #] \&
.\}
. \" simple accents for nroff and troff
. ds ' \&
. ds ` \&
. ds ^ \&
. ds , \&
. ds ~ ~
. ds /
.\}
. ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u"
. ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'
. ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'
. ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'
. ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'
. ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'
.\}
. \" troff and (daisy-wheel) nroff accents
. \" corrections for vroff
. \" for low resolution devices (crt and lpr)
\{\
. ds : e
. ds 8 ss
. ds o a
. ds d- d\h'-1'\(ga
. ds D- D\h'-1'\(hy
. ds th \o'bp'
. ds Th \o'LP'
. ds ae ae
. ds Ae AE
.\}
======================================================================== Title "BUFFCHAN 8" BUFFCHAN 8 "2015-09-12" "INN 2.6.4" "InterNetNews Documentation"
For nroff, turn off justification. Always turn off hyphenation; it makes way too many mistakes in technical documents. "NAME"
buffchan - Buffered file-writing backend for INN
"SYNOPSIS"
Header "SYNOPSIS" \fBbuffchan [
-bru] [
-c lines] [
-C seconds] [
-d
\fIdirectory] [
-f num-fields] [
-l lines] [
-L seconds]
[
-m map] [
-p pid-file] [
-s format]
"DESCRIPTION"
Header "DESCRIPTION" \fBbuffchan reads lines from standard input and copies the initial fields
in each line to the files named by the remaining fields on the line.
\fBbuffchan is intended to be called by
innd as an exploder feed.
The input is interpreted as a sequence of lines. Each line contains a
fixed number of initial fields, followed by a variable number of filename
fields. All fields in a line are separated by whitespace and do not
contain any whitespace. The default number of initial fields is one.
For each line of input, buffchan writes the initial fields, separated
by a space and followed by a newline, to each of the files named in the
filename fields. The output files are kept open and are only flushed or
closed based on the schedule given by the -c, -C, -l, and -L
options.
As an exploder feed (see newsfeeds\|(5) for an explanation), buffchan
interprets lines beginning with an exclamation point as commands. Besides
\f(CW\*(C`!begin\*(C' (which only marks the start of the feed), there are three
supported commands:
"!flush [site]" 4
Item "!flush [site]" The flush command closes and reopens all open files. An optional site can
be specified, in which case
buffchan flushes only that file. This
command is analogous to the
\*(C`ctlinnd flush\*(C' command. This command can be
sent via
innd using
\*(C`ctlinnd send \f(CIbuffchan-site \*(Aqflush \f(CIsite\*(Aq\*(C'.
.Sp
Applications can tell that flush has completed by renaming the file before
issuing the command. When the original file name has reappeared, the
flush is complete. If fchmod\|(3) is available, buffchan also changes
the file to read-only while it's actively writing to it and changes it
back to read/write once it has been closed. It will change the mode back
to read-only only if it reopens the same file.
"!drop [site]" 4
Item "!drop [site]" The drop command is similar to the flush command, except that no files are
reopened. If given an argument, only the specified site is dropped;
otherwise, all sites are dropped. (Note that a site will be restarted if
the input stream mentions the site again.)
.Sp
When a
\*(C`ctlinnd drop site\*(C' command is sent,
innd will automatically
forward the command to
buffchan if the site is listed as a funnel
feeding into the
buffchan exploder. To drop all sites, use
\*(C`ctlinnd
send \f(CIbuffchan-site drop\*(C'.
"!readmap" 4
Item "!readmap" The map file specified with the
-m option, if given, will be reloaded.
Once buffchan opens a file, it keeps it open (in the absence of a drop
command). The input must therefore never specify more files than the
maximum number of files a process may open.
"OPTIONS"
Header "OPTIONS" "-b" 4
Item "-b" Force the output to be buffered. (This is generally the default, but it
may depend on the operating system.) If
-b is given, a buffer size of
\s-1BUFSIZ\s0 (a constant of the system standard I/O library) is used.
"-c lines" 4
Item "-c lines" If the
-c flag is given,
buffchan will close and reopen a file after
every
lines lines are written to the file.
"-C seconds" 4
Item "-C seconds" If the
-C flag is given,
buffchan will close and reopen a file if it
has been open for more than
seconds seconds.
"-d directory" 4
Item "-d directory" This flag may be used to specify a directory the program should change to
before starting. If this flag is used, the default for the
-s flag
(see below) is changed to be a simple
%s (in other words, output files
are considered to be relative to
directory).
"-f num-fields" 4
Item "-f num-fields" By default, each line is expected to contain one fixed field followed by
some number of filename fields. If this flag is given,
num-fields will
be used as the number of initial fixed fields.
"-l lines" 4
Item "-l lines" If the
-l flag is given,
buffchan will flush the output after every
\fIlines lines are written to a file.
"-L seconds" 4
Item "-L seconds" If the
-L flag is given,
buffchan will flush each output file every
\fIseconds seconds.
"-m map" 4
Item "-m map" Map files translate the names in the filename fields on each line into
filenames that should be used instead. It's used primarily when short
names are used in
newsfeeds, but the output files should use the full
domain names of remote peers.
.Sp
In the map file, blank lines and lines starting with a number sign (
\*(C`#\*(C')
are ignored. All other lines should have two host names separated by a
colon. The first field is the name that may appear in the input stream;
the second field names the file to be used when the name in the first
field appears. For example:
.Sp
.Vb 4
# This is a comment
uunet:news.uu.net
foo:
foo.com
munnari:munnari.oz.au
.Ve
"-p pid-file" 4
Item "-p pid-file" If the
-p option is given,
buffchan will write a line containing its
process \s-1ID\s0 (in text) to the specified file when it starts.
"-r" 4
Item "-r" By default,
buffchan sends its error messages to
pathlog/errlog. To
suppress this redirection and send error messages to standard error, use
the
-r flag.
"-s" 4
Item "-s" The
-s flag may be used to specify a format that maps a filename from
the filename fields at the end of each line to an actual filename. This
is a
sprintf\|(3) format string that should contain a single instance of
\f(CW%s, which will be replaced with the value of the filename field
(possibly after mapping with the map file from
-m). The default value
is
pathoutgoing/
%s.
"-u" 4
Item "-u" If the
-u flag is used, the output will be unbuffered.
"EXAMPLES"
Header "EXAMPLES" If
buffchan is invoked with
\*(C`-f 2\*(C' and given the following input:
.Vb 3
news/software/b/132 <1643@munnari.oz.au> foo uunet
news/software/b/133 <102060@litchi.foo.com> uunet munnari
comp/sources/unix/2002 <999@news.foo.com> foo uunet munnari
.Ve
Then the file foo will have these lines:
.Vb 2
news/software/b/132 <1643@munnari.oz.au>
comp/sources/unix/2002 <999@news.foo.com>
.Ve
the file munnari will have these lines:
.Vb 2
news/software/b/133 <102060@litchi.foo.com>
comp/sources/unix/2002 <999@news.foo.com>
.Ve
and the file uunet will have these lines:
.Vb 3
news/software/b/132 <1643@munnari.oz.au>
news/software/b/133 <102060@litchi.foo.com>
comp/sources/unix/2002 <999@news.foo.com>
.Ve
"HISTORY"
Header "HISTORY" Written by Rich
$alz <rsalz@uunet.uu.net> for InterNetNews. Converted to
\s-1POD\s0 by Russ Allbery <eagle@eyrie.org>.
\f(CW$Id: buffchan.pod 9767 2014-12-07 21:13:43Z iulius $
"SEE ALSO"
Header "SEE ALSO" \fBctlinnd\|(8),
filechan\|(8),
inn.conf\|(5),
innd\|(8),
newsfeeds\|(5).