.TH JUST 1
.UC 4
.SH NAME
just \- text justification program
.SH SYNOPSIS
.nf
just [-<width>] [-t<tolerance>] [file...]
.SH DESCRIPTION
.I Just
takes one or more files containing text and justifies them to a specified
width, sending the result to standard output.
Default <width> is 72. (The default can be changed by creating a file
in the current directory called ".justwidth" and containing a number.)
If no files are given 
.I just
takes its data from standard input.  Thus either of the following commands
show the simplest use of
.I just
.PP
just oldtext > newtext
.br
just < oldtext > newtext
.PP
This is a simple text formatting program, designed for situations
where the more complex facilities of 
.I nroff
or
.I troff
are not required.
It formats according to the following rules:
.PP
1) blank lines remain blank.
.br
2) if a line begins with spaces, these are preserved and it is not
merged with the previous one.
.br
3) lines which begin with 8 or more spaces (equiv one tab),
or which have a '>' sign in column 1, have their layout frozen completely.
.PP
Otherwise each line is merged with the previous line and reformatted so
as to maximise the number of words in the line and then justify it to the
specified width.  During reformatting the following two extra rules are
observed:
.PP
(a) Between any of the sentence 
terminators '.', '?', '!', and a following word on the same line,
a minimum of
two spaces will be preserved if present in the original text.
.PP
(b) Justification (i.e. padding out to the exact width)
is not performed on a line when
it would require the insertion of more than 
.I <tolerance>
extra spaces in any one place.  This rule is added to make
.I just
behave sensibly when formatting to a width allowing only a small
number of words per line, eg for a newspaper column.
The default tolerance is 3.
.PP
These rules
are quite well adapted to the conventions of normal English text, and
enable
.I just
to be used to format letters, and a variety of simple documents.
Rule (3) provides two conventions whereby fragments of program, tables etc,
can be embedded in such documents and protected from reformatting.
Note that 
.I just
can safely be applied to its own output, eg to reformat to different widths.
(Reapplying 
.I just
with the same width will leave the text unchanged.)
.PP
.I Just
removes tabs from lines which it is reformatting, replacing them by
spaces.  (But tabs in frozen lines will be left alone.)
.PP
.I Just
knows about underlining (in the style "underline-backspace-character...")
and handles underlined words and sentences correctly. 
When preparing text which is to be continuously underlined across wordbreaks,
each non-final line of underlined input should have a trailing
underlined space.
.PP
Setting <tolerance> to zero, as in
`just -t0' will cause reformatting without justification.  Specifying a
negative width also has this effect.  That is `just --72' means 
`just -72 -t0'.
.SH SEE ALSO
vi(1)
.br
fmt(1)  - the advantages of just
over fmt are that it can format to different widths
(fmt is fixed at 72), that it does justification, and that it knows about
underlining.  Like fmt, just
is conveniently called from inside vi, by using the `!' command.

Examples, of using
.I just
inside
.I vi:
To reformat a paragraph, position the
cursor at, or just above, the beginning of the paragraph, and say
.br
!}just
.br
To reformat the whole document say
.br
:1,$!just
.br
These are standard applications of the vi `!' command, which pipes
pieces of text through an arbitrary UNIX command called from inside
the editor - see vi documentation for more information.)
.SH BUGS
When preparing input text, you have to remember to leave at least one
space at the front of each line which is not preceded by a blank line
and which you
.I don't
want merged with the previous line, e.g. successive lines of an address.
Note that this means that
.I just
cannot be used to reformat a paragraph all of whose lines are indented.
(This is the one respect in which
.I fmt 
is superior to
.I just.)
.SH AUTHOR
Research Software Limited.
.I Just
is included in the distribution file for Miranda(tm).