fold(1)




NAME

     fold - filter for folding lines


SYNOPSIS

     fold [-bs] [-w width | -width]  [file...]


DESCRIPTION

     The fold utility is a filter that will fold lines  from  its
     input  files,  breaking the lines to have a maximum of width
     column positions (or bytes, if the -b option is  specified).
     Lines will be broken by the insertion of a NEWLINE character
     such that each output line (referred to later in  this  sec-
     tion  as  a segment) is the maximum width possible that does
     not exceed the specified  number  of  column  positions  (or
     bytes). A line will not be broken in the middle of a charac-
     ter. The behavior is undefined if width  is  less  than  the
     number  of  columns  any single character in the input would
     occupy.

     If the CARRIAGE-RETURN, BACKSPACE,  or  TAB  characters  are
     encountered  in  the  input, and the -b option is not speci-
     fied, they will be treated specially:

     BACKSPACE
           The current count of line width will be decremented by
           one,  although  the  count never will become negative.
           fold will not insert a NEWLINE  character  immediately
           before or after any BACKSPACE character.

     CARRIAGE-RETURN
           The current count of line width will be set to 0. fold
           will not insert a NEWLINE character immediately before
           or after any CARRIAGE-RETURN character.

     TAB   Each TAB character encountered will advance the column
           position  pointer to the next tab stop. Tab stops will
           be at each column position n  such  that  n  modulo  8
           equals 1.


OPTIONS

     The following options are supported:

     -b    Counts width in bytes rather than column positions.

     -s    If a segment of a  line  contains  a  blank  character
           within  the  first  width column positions (or bytes),
           breaks the line after the last  such  blank  character
           meeting  the  width  constraints. If there is no blank
           character meeting the requirements, the -s option will
           have  no  effect  for that output segment of the input
           line.

     -w width|-width
           Specifies the maximum line length, in column positions
           (or bytes if -b is specified). If width is not a posi-
           tive decimal number, an error is returned. The default
           value is 80.


OPERANDS

     The following operand is supported:

     file  A path name of a text file to be folded.  If  no  file
           operands  are  specified,  the  standard input will be
           used.


EXAMPLES

     Example 1: Submitting a file of possibly long lines  to  the
     line printer

     An example invocation that submits a file of  possibly  long
     lines  to  the  line  printer (under the assumption that the
     user knows the line width of the printer to be  assigned  by
     lp(1)):

     example% fold -w 132 bigfile | lp


ENVIRONMENT VARIABLES

     See environ(5) for descriptions of the following environment
     variables  that  affect the execution of fold: LANG, LC_ALL,
     LC_CTYPE, LC_MESSAGES, and NLSPATH.


EXIT STATUS

     The following exit values are returned:

     0     All input files were processed successfully.

     >0    An error occurred.


ATTRIBUTES

     See attributes(5) for descriptions of the  following  attri-
     butes:

     ____________________________________________________________
    |       ATTRIBUTE TYPE        |       ATTRIBUTE VALUE       |
    |_____________________________|_____________________________|
    | Availability                | SUNWcsu                     |
    |_____________________________|_____________________________|
    | CSI                         | enabled                     |
    |_____________________________|_____________________________|
    | Interface Stability         | Standard                    |
    |_____________________________|_____________________________|


SEE ALSO

     cut(1), pr(1), attributes(5), environ(5), standards(5)


NOTES

     fold and cut(1) can be used to  create  text  files  out  of
     files  with arbitrary line lengths. fold should be used when
     the contents of long lines need to be kept  contiguous.  cut
     should  be  used when the number of lines (or records) needs
     to remain constant.

     fold is frequently used to send text files to line  printers
     that  truncate,  rather  than  fold,  lines  wider  than the
     printer is able to print (usually 80  or  132  column  posi-
     tions).

     fold may not work correctly if underlining is present.


Man(1) output converted with man2html