Provided by: libbiblio-lcc-perl_0.09-2_all bug

NAME

       lccnorm - normalize Library of Congress Classification call numbers

SYNOPSIS

       lccnorm [option...] [file...]

       lccnorm -h|--help

       lccnorm -V|--version

DESCRIPTION

       lccnorm transforms LC-style call numbers into a form that may be used in a straight ASCII sort.

       By default, each line of input is assumed to consist of a number of tab-delimited fields, of which the
       first contains an LC-style call number or class.

       If no file is specified, or if the file name "-" is specified, standard input will be processed.

       Normalization of call number ranges is a special challenge, because ranges are not normally specified
       using the exact endpoint.  Consider the range "B708-B713"; while "B708" does indicate the beginning point
       -- a no call number that comes before B 708 can fall within the range -- the end point is only a guide,
       not a strict limit, since the intent is that call numbers such as "B 713 .H94" and "B 713 .W55 L86" do
       fall within the range.  Unfortunately, ranges are often specified ambiguously; for example, the call
       number "B 713.14 G92" might or might not be considered to fall within this range.

OPTIONS

       -d, --delimiter string
           Specify  a  string  other  than  a  single tab (ASCII character 9) to delimit the fields in a line of
           input.  This also provides the default for joining fields in the output; see option -j below.

       -f, --field range
           The call number (or range) is found in the given range of fields.   Fields  are  1-based  (the  first
           field  is field 1, not field 0) and are separated by a single tab character (unless option -d is used
           to specify an alternate delimiter).

           When parsing call numbers (not ranges), all fields are concatenated using a single space to form  the
           call number that will be normalized.

           When parsing ranges, there are four possibilities:

           1 field
               The field contains a range in the form prefix (e.g., "J80"), closed range (e.g., "ML566-566.6" or
               "ML566-ML566.6") or half-open range (e.g., "KME451<KME500").

           2 fields
               The first field is the beginning of the (closed) range, and the second is the end.

           3 fields
               The first field is a prefix common to both the beginning and end of the range, and the second and
               third fields are the remainders.

           4 fields
               The first and third fields together are the beginning of the range, and the second and fourth are
               the end.

           For example, the following all produce identical output:

               $ echo 'PL4501-4509'     | lccnorm -d: -f1
               $ echo 'PL4501:PL4509'   | lccnorm -d: -f1-2
               $ echo 'PL:4501:4509'    | lccnorm -d: -f1-3
               $ echo 'PL:4501:PL:4509' | lccnorm -d: -f1-4

       -j, --join string
           Specify  a  character  to  use  when joining fields for output. The default is to use the same string
           specified in option -d, or a single tab if -d was not given.

       -c  Don't delete the input fields from which call numbers (or ranges) were obtained.  Either the  -b  and
           -e option must be provided to specify where the normalized string is to be placed.

       -b, --begin
           Place normalized strings at the beginning of output lines.

       -e, --end
           Place normalized strings at the end of output lines.

       -D, --die-on-error
           Exit  with  a  non-zero  status as soon as an unnormalizable input is encountered.  The default is to
           issue a warning and normalize to the empty string.

       -v, --verbose
           Be verbose.  This currently has no effect unless used with the -V or --version option.

       -h, --help
           Print help information and exit.

       -V, --version
           Print the version number and exit.  If the -v or --verbose option is specified, print out  additional
           information.

       -M, --manual
           View the manual page for lccnorm.

       -L, --license
           View the license under which lccnorm is distributed.

AUTHOR

       Paul Hoffman (nkuitse AT nkuitse DOT com)

COPYRIGHT

       Copyright 2007 Paul M. Hoffman.

       This module is free software; you can redistribute it and/or modify it under the same terms as Perl:

       a)  the GNU General Public License as published by the Free Software Foundation; either version 1, or (at
           your option) any later version;

           or

       b)  the "Artistic License".

           For the full text of these licenses, see the script file itself or enter the command lccnorm -L.

SEE ALSO

       Biblio::LCC

perl v5.36.0                                       2023-02-05                                        LCCNORM(1p)