Man Linux: Main Page and Category List

NAME

       mailx - send and receive Internet mail

SYNOPSIS

       mailx [-BDdEFintv~] [-s subject] [-a attachment ] [-c cc-addr] [-b bcc-
              addr] [-r from-addr] [-h hops] [-A account]
              [-S variable[=value]] to-addr . . .
       mailx [-BDdeEHiInNRv~] [-T name] [-A account] [-S variable[=value]] -f
              [name]
       mailx [-BDdeEinNRv~] [-A account] [-S variable[=value]] [-u user]

DESCRIPTION

       Mailx is an intelligent mail processing system,  which  has  a  command
       syntax  reminiscent  of  ed(1)  with lines replaced by messages.  It is
       based on Berkeley Mail 8.1, is intended to provide the functionality of
       the  POSIX  mailx  command, and offers extensions for MIME, IMAP, POP3,
       SMTP, and S/MIME.  Mailx provides  enhanced  features  for  interactive
       use,  such  as  caching  and  disconnected  operation for IMAP, message
       threading, scoring, and filtering.  It is also usable as a  mail  batch
       language, both for sending and receiving mail.

       The following options are accepted:

       -A name
              Executes  an  account  command  (see  below)  for name after the
              startup files have been read.

       -a file
              Attach the given file to the message.

       -B     Make standard input and standard output line-buffered.

       -b address
              Send blind carbon copies to  list.   List  should  be  a  comma-
              separated list of names.

       -c address
              Send carbon copies to list of users.

       -D     Start   in  disconnected  mode;  see  the  description  for  the
              disconnected variable option.

       -d     Enables debugging messages and disables the actual  delivery  of
              messages.    Unlike  -v,  this  option  is  intended  for  mailx
              development only.

       -e     Just check if mail is present in the system  mailbox.   If  yes,
              return an exit status of zero, else, a non-zero value.

       -E     If an outgoing message does not contain any text in its first or
              only message part, do not  send  it  but  discard  it  silently,
              effectively   setting  the  skipemptybody  variable  at  program
              startup.  This is  useful  for  sending  messages  from  scripts
              started by cron(8).

       -f [file]
              Read  in the contents of the user’s mbox (or the specified file)
              for processing; when mailx is quit, it writes undeleted messages
              back  to this file.  The string file is handled as described for
              the folder command below.

       -F     Save the message to send in a file named after the local part of
              the first recipient’s address.

       -H     Print header summaries for all messages and exit.

       -h hops
              Invoke  sendmail  with the specified hop count.  This option has
              no effect when SMTP is used for sending mail.

       -i     Ignore tty interrupt signals.  This is particularly useful  when
              using mailx on noisy phone lines.

       -I     Shows  the  ‘Newsgroup:’  or  ‘Article-Id:’ fields in the header
              summary.  Only applicable in combination with -f.

       -n     Inhibits reading /etc/nail.rc upon startup.  This option  should
              be activated for mailx scripts that are invoked on more than one
              machine, because the contents of that file  may  differ  between
              them.

       -N     Inhibits  the  initial  display  of message headers when reading
              mail or editing a mail folder.

       -q file
              Start the message with the contents of the specified file.   May
              be given in send mode only.

       -r address
              Sets  the From address. Overrides any from variable specified in
              environment or startup files.  Tilde escapes are disabled.   The
              -r  address options are passed to the mail transfer agent unless
              SMTP is used.  This option exists for compatibility only; it  is
              recommended to set the from variable directly instead.

       -R     Opens any folders read-only.

       -s subject
              Specify  subject  on command line (only the first argument after
              the -s flag is used as a subject; be careful to  quote  subjects
              containing spaces).

       -S variable[=value]
              Sets  the  internal  option  variable  and,  in case of a string
              option, assigns value to it.

       -T name
              Writes the ‘Message-Id:’ and ‘Article-Id:’ header fields of each
              message  read  in  the file name.  Implies -I.  Compressed files
              are handled as described for the folder command below.

       -t     The message to be sent is expected to contain a  message  header
              with  ‘To:’,  ‘Cc:’,  or  ‘Bcc:’  fields  giving its recipients.
              Recipients specified on the command line are ignored.

       -u user
              Reads the mailbox of the given user name.

       -v     Verbose mode.  The details of  delivery  are  displayed  on  the
              user’s terminal.

       -V     Print mailx’s version and exit.

       -~     Enable tilde escapes even if not in interactive mode.

   Sending mail
       To  send  a  message  to  one or more people, mailx can be invoked with
       arguments which are the names of people to whom the mail will be  sent.
       The  user  is  then  expected  to  type  in his message, followed by an
       ‘control-D’ at the beginning of a line.  The section below Replying  to
       or originating mail, describes some features of mailx available to help
       when composing letters.

   Reading mail
       In normal usage mailx is given no arguments and checks the user’s  mail
       out  of  the  post  office,  then  prints out a one line header of each
       message found.  The current message  is  initially  the  first  message
       (numbered  1)  and  can be printed using the print command which can be
       abbreviated ‘p’).  The user can move among  the  messages  much  as  he
       moves  between  lines  in  ed(1),  with the commands ‘+’ and ‘-’ moving
       backwards and forwards, and simple numbers.

   Disposing of mail
       After examining a message the user can delete ‘d’) the message or reply
       ‘r’)  to  it.   Deletion  causes  the mailx program to forget about the
       message.  This is not irreversible; the message can be  undeleted  ‘u’)
       by giving its number, or the mailx session can be aborted by giving the
       exit ‘x’) command.  Deleted messages will, however,  usually  disappear
       never to be seen again.

   Specifying messages
       Commands  such  as  print  and  delete  can  be given a list of message
       numbers as arguments to apply to a number of messages  at  once.   Thus
       ‘delete  1  2’  deletes  messages  1  and 2, while ‘delete 1-5’ deletes
       messages 1 through 5.  In sorted or threaded mode  (see  the  sort  and
       thread  commands),  ‘delete  1-5’ deletes the messages that are located
       between (and including) messages 1 through  5  in  the  sorted/threaded
       order,  as  shown in the header summary.  The following special message
       names exist:

       :n     All new messages.

       :o     All old messages (any not in state read or new).

       :u     All unread messages.

       :d     All deleted messages (for the undelete command).

       :r     All read messages.

       :f     All ‘flagged’ messages.

       :a     All answered messages (cf. the markanswered variable).

       :t     All messages marked as draft.

       :k     All ‘killed’ messages.

       :j     All messages classified as junk.

       .      The current message.

       ;      The message that was previously the current message.

       ,      The parent message of the current message, that is  the  message
              with  the  Message-ID  given  in the ‘In-Reply-To:’ field or the
              last entry of the ‘References:’ field of the current message.

       -      The next  previous  undeleted  message,  or  the  next  previous
              deleted  message  for  the undelete command.  In sorted/threaded
              mode, the next previous  such  message  in  the  sorted/threaded
              order.

       +      The  next undeleted message, or the next deleted message for the
              undelete  command.   In  sorted/threaded  mode,  the  next  such
              message in the sorted/threaded order.

       ^      The  first  undeleted  message, or the first deleted message for
              the undelete command.  In sorted/threaded mode, the  first  such
              message in the sorted/threaded order.

       $      The  last message.  In sorted/threaded mode, the last message in
              the sorted/threaded order.

       &x     In threaded mode, selects the message addressed with x, where  x
              is  any  other  message specification, and all messages from the
              thread that begins at it.  Otherwise, it is identical to x.   If
              x  is  omitted, the thread beginning with the current message is
              selected.

       *      All messages.

       ‘      All messages that were included in  the  message  list  for  the
              previous command.

       /string
              All  messages  that  contain  string  in the subject field (case
              ignored).  See also the searchheaders variable.   If  string  is
              empty,  the  string from the previous specification of that type
              is used again.

       address
              All messages from address.

       (criterion)
              All messages that satisfy the given IMAP-style SEARCH criterion.
              This addressing mode is available with all types of folders; for
              folders not located on IMAP servers, or for  servers  unable  to
              execute  the  SEARCH  command,  mailx  will  perform  the search
              locally.  Strings must be enclosed by double quotes ‘"’ in their
              entirety  if they contain white space or parentheses; within the
              quotes, only backslash ‘\’ is recognized as an escape character.
              All  string searches are case-insensitive.  When the description
              indicates that the ‘envelope’ representation of an address field
              is  used,  this  means that the search string is checked against
              both a list constructed as

              ("real name" "source-route" "local-part" "domain-part")

              for each address, and the addresses without real names from  the
              respective   header   field.    Criteria  can  be  nested  using
              parentheses.

       (criterion1 criterion2 ... criterionN)
              All messages that satisfy all of the given criteria.

       (or criterion1 criterion2)
              All messages that satisfy either criterion1  or  criterion2,  or
              both.   To  connect  more  than  two  criteria  using ‘or’, (or)
              specifications have to be nested using  additional  parentheses,
              as  with ‘(or a (or b c))’; ‘(or a b c)’ means ((a or b) and c).
              For a simple ‘or’  operation  of  independent  criteria  on  the
              lowest  nesting level, it is possible to achieve similar effects
              by using three separate criteria, as with ‘(a) (b) (c)’.

       (not criterion)
              All messages that do not satisfy criterion.

       (bcc string)
              All   messages   that   contain   string   in   the   ‘envelope’
              representation of the Bcc: field.

       (cc string)
              All   messages   that   contain   string   in   the   ‘envelope’
              representation of the Cc: field.

       (from string)
              All   messages   that   contain   string   in   the   ‘envelope’
              representation of the From: field.

       (subject string)
              All messages that contain string in the Subject: field.

       (to string)
              All   messages   that   contain   string   in   the   ‘envelope’
              representation of the To: field.

       (header name string)
              All messages that contain string in the specified Name: field.

       (body string)
              All messages that contain string in their body.

       (text string)
              All messages that contain string in their header or body.

       (larger size)
              All messages that are larger than size (in bytes).

       (smaller size)
              All messages that are smaller than size (in bytes).

       (before date)
              All messages that were received before date; date must be in the
              form d[d]-mon-yyyy, where d[d] is the day of the month as one or
              two digits, mon is the name of the month—one  of  ‘Jan’,  ‘Feb’,
              ‘Mar’,  ‘Apr’,  ‘May’, ‘Jun’, ‘Jul’, ‘Aug’, ‘Sep’, ‘Oct’, ‘Nov’,
              or  ‘Dec’,  and  yyyy  is  the  year  as   four   digits;   e.g.
              "30-Aug-2004".

       (on date)
              All messages that were received on the specified date.

       (since date)
              All messages that were received since the specified date.

       (sentbefore date)
              All messages that were sent on the specified date.

       (senton date)
              All messages that were sent on the specified date.

       (sentsince date)
              All messages that were sent since the specified date.

       ()     The   same   criterion   as   for  the  previous  search.   This
              specification cannot be used as part of another  criterion.   If
              the  previous  command  line contained more than one independent
              criterion, the last of those criteria is used.

       A practical method to read a set of messages is to issue a from command
       with  the  search criteria first to check for appropriate messages, and
       to read each single message then by typing ‘‘’ repeatedly.

   Replying to or originating mail
       The reply command can be used to  set  up  a  response  to  a  message,
       sending  it back to the person who it was from.  Text the user types in
       then, up to an end-of-file, defines the contents of the message.  While
       the  user is composing a message, mailx treats lines beginning with the
       character ‘~’ specially.  For instance, typing ‘~m’ (alone on  a  line)
       will  place  a  copy  of  the  current  message into the response right
       shifting it by a tabstop (see  indentprefix  variable,  below).   Other
       escapes  will  set  up subject fields, add and delete recipients to the
       message, attach files to it and allow the user to escape to  an  editor
       to  revise  the  message  or  to  a shell to run some commands.  (These
       options are given in the summary below.)

   Ending a mail processing session
       The user can end a mailx session with the quit (‘q’) command.  Messages
       which  have  been  examined go to the user’s mbox file unless they have
       been deleted in which case they are discarded.  Unexamined messages  go
       back to the post office.  (See the -f option above).

   Personal and systemwide distribution lists
       It  is  also  possible to create a personal distribution lists so that,
       for instance, the user can send mail to ‘cohorts’ and have it go  to  a
       group of people.  Such lists can be defined by placing a line like

               alias cohorts bill ozalp jkf mark kridle@ucbcory

       in  the file .mailrc in the user’s home directory.  The current list of
       such aliases can be displayed with the alias command in mailx.   System
       wide  distribution  lists  can  be created by editing /etc/aliases, see
       aliases(5) and sendmail(8); these are kept in a different  syntax.   In
       mail  the user sends, personal aliases will be expanded in mail sent to
       others so that they will be able to reply to  the  recipients.   System
       wide  aliases  are  not  expanded  when the mail is sent, but any reply
       returned to the machine will have the system wide alias expanded as all
       mail goes through sendmail.

   Recipient address specifications
       When an address is used to name a recipient (in any of To, Cc, or Bcc),
       names of local mail folders and pipes to external commands can also  be
       specified;  the  message  text is then written to them.  The rules are:
       Any name which starts with  a  ‘|’  character  specifies  a  pipe,  the
       command string following the ‘|’ is executed and the message is sent to
       its standard input; any other name which contains a  ‘@’  character  is
       treated  as  a  mail  address;  any  other name which starts with a ‘+’
       character specifies a folder name; any other name which contains a  ‘/’
       character  but  no ‘!’  or ‘%’ character before also specifies a folder
       name; what remains is treated as a mail  address.   Compressed  folders
       are handled as described for the folder command below.

   Network mail (Internet / ARPA, UUCP, Berknet)
       See  mailaddr(7)  for  a description of network addresses.  Mailx has a
       number of options which can be set in the .mailrc  file  to  alter  its
       behavior;  thus  ‘set askcc’ enables the askcc feature.  (These options
       are summarized below).

   MIME types
       For any outgoing attachment, mailx tries to determine the content type.
       It  does this by reading MIME type files whose lines have the following
       syntax:

               type/subtype      extension [extension . . .]

       where type/subtype  are  strings  describing  the  file  contents,  and
       extension  is  the part of a filename starting after the last dot.  Any
       line not immediately beginning with an ASCII alphabetical character  is
       ignored  by  mailx.  If there is a match with the extension of the file
       to attach, the given type/subtype pair is used.  Otherwise, or  if  the
       filename   has   no   extension,   the   content  types  text/plain  or
       application/octet-stream are used, the first for text or  international
       text files, the second for any file that contains formatting characters
       other than newlines and horizontal tabulators.

   Character sets
       Mailx normally detects the character set  of  the  terminal  using  the
       LC_CTYPE  locale  setting.  If the locale cannot be used appropriately,
       the ttycharset variable should be set to  provide  an  explicit  value.
       When  reading  messages,  their  text  is  converted  to  the  terminal
       character set if possible.  Unprintable  characters  and  illegal  byte
       sequences are detected and replaced by Unicode substitute characters or
       question marks unless the  print-all-chars  is  set  at  initialization
       time.

       The  character set for outgoing messages is not necessarily the same as
       the one used on the terminal.  If an  outgoing  text  message  contains
       characters  not representable in US-ASCII, the character set being used
       must be declared within its header.  Permissible values can be declared
       using  the sendcharsets variable, separated by commas; mailx tries each
       of the values in order and uses the  first  appropriate  one.   If  the
       message  contains  characters  that cannot be represented in any of the
       given character sets, the message will not be sent, and its  text  will
       be  saved  to  the ‘dead.letter’ file.  Messages that contain NUL bytes
       are not converted.

       Outgoing attachments are converted if they  are  plain  text.   If  the
       sendcharsets variable contains more than one character set name, the ~@
       tilde escape will ask for the character sets for individual attachments
       if it is invoked without arguments.

       Best  results  are usually achieved when mailx is run in a UTF-8 locale
       on a UTF-8 capable terminal.  In this setup,  characters  from  various
       countries  can  be  displayed,  while  it is still possible to use more
       simple character sets for sending to retain maximum compatibility  with
       older mail clients.

   Commands
       Each  command  is  typed  on  a  line by itself, and may take arguments
       following the command word.  The command  need  not  be  typed  in  its
       entirety  –  the  first command which matches the typed prefix is used.
       For commands which take message lists as arguments, if no message  list
       is  given,  then the next message forward which satisfies the command’s
       requirements is used.  If there are no messages forward of the  current
       message,  the  search  proceeds  backwards,  and  if  there are no good
       messages at all, mailx  types  ‘applicable  messages’  and  aborts  the
       command.  If the command begins with a # sign, the line is ignored.

       The arguments to commands can be quoted, using the following methods:

       ·      An  argument  can be enclosed between paired double-quotes "" or
              single-quotes ’’; any white  space,  shell  word  expansion,  or
              backslash  characters within the quotes are treated literally as
              part of the argument.  A double-quote will be treated  literally
              within single-quotes and vice versa. These special properties of
              the quote marks occur only when they are paired at the beginning
              and end of the argument.

       ·      A backslash outside of the enclosing quotes is discarded and the
              following  character  is  treated  literally  as  part  of   the
              argument.

       ·      An  unquoted backslash at the end of a command line is discarded
              and the next line continues the command.

       Filenames,   where   expected,   are   subjected   to   the   following
       transformations, in sequence:

       ·      If  the  filename  begins  with  an  unquoted plus sign, and the
              folder variable is defined, the plus sign will  be  replaced  by
              the  value  of  the  folder variable followed by a slash. If the
              folder variable is unset or is set to null, the filename will be
              unchanged.

       ·      Shell word expansions are applied to the filename.  If more than
              a single pathname results from this expansion and the command is
              expecting one file, an error results.

       The following commands are provided:

       -      Print out the preceding message.  If given a numeric argument n,
              goes to the n’th previous message and prints it.

       ?      Prints a brief summary of commands.

       !      Executes the shell (see sh(1) and csh(1)) command which follows.

       |      A synonym for the pipe command.

       account
              (ac)  Creates, selects or lists an email account.  An account is
              formed by a  group  of  commands,  primarily  of  those  to  set
              variables.   With  two  arguments, of which the second is a ‘{’,
              the first argument gives an  account  name,  and  the  following
              lines  create  a group of commands for that account until a line
              containing  a  single  ‘}’  appears.   With  one  argument,  the
              previously  created  group  of  commands for the account name is
              executed, and a  folder  command  is  executed  for  the  system
              mailbox  or  inbox of that account.  Without arguments, the list
              of accounts and their contents are printed.  As an example,

                  account myisp {
                      set folder=imaps://mylogin@imap.myisp.example
                      set record=+Sent
                      set from="myname@myisp.example (My Name)"
                      set smtp=smtp.myisp.example
                  }

              creates an account named ‘myisp’ which can later be selected  by
              specifying ‘account myisp’.

       alias  (a) With no arguments, prints out all currently-defined aliases.
              With one argument, prints out that alias.  With  more  than  one
              argument, creates a new alias or changes an old one.

       alternates
              (alt)  The alternates command is useful if the user has accounts
              on several machines.  It can be used to inform  mailx  that  the
              listed  addresses  all  belong  to  the  invoking user.  When he
              replies to messages, mailx will not send a copy of  the  message
              to  any  of the addresses listed on the alternates list.  If the
              alternates command is given with no argument, the current set of
              alternate names is displayed.

       answered
              (ans)  Takes  a  message list and marks each message as a having
              been answered.  This mark has no technical meaning in  the  mail
              system;  it  just  causes  messages  to  be marked in the header
              summary, and makes them specially addressable.

       cache  Only applicable to cached IMAP mailboxes; takes a  message  list
              and reads the specified messages into the IMAP cache.

       call   Calls a macro (see the define command).

       cd     Same as chdir.

       certsave
              Only applicable to S/MIME signed messages.  Takes a message list
              and a file name and saves the certificates contained within  the
              message  signatures to the named file in both human-readable and
              PEM  format.   The  certificates  can  later  be  used  to  send
              encrypted  messages  to the messages’ originators by setting the
              smime-encrypt-user@host variable.

       chdir  (ch) Changes the user’s working directory to that specified,  if
              given.   If  no  directory  is given, then changes to the user’s
              login directory.

       classify
              (cl) Takes a list of messages and examines  their  contents  for
              characteristics of junk mail using Bayesian filtering.  Messages
              considered to be junk are then marked as such.   The  junk  mail
              database is not changed.

       collapse
              (coll)  Only  applicable to threaded mode.  Takes a message list
              and makes all replies to  these  messages  invisible  in  header
              summaries, unless they are in state ‘new’.

       connect
              (conn)  If  operating  in  disconnected mode on an IMAP mailbox,
              switch to online mode and  connect  to  the  mail  server  while
              retaining  the  mailbox  status.   See  the  description  of the
              disconnected variable for more information.

       copy   (c) The copy command does the same thing that save does,  except
              that  it  does  not mark the messages it is used on for deletion
              when the user quits.  Compressed files and  IMAP  mailboxes  are
              handled as described for the folder command.

       Copy   (C)  Similar  to  copy,  but  saves the messages in a file named
              after the local part of the sender address of the first message.

       decrypt
              (dec)  For  unencrypted  messages,  this command is identical to
              copy.  Encrypted messages are first decrypted, if possible,  and
              then copied.

       Decrypt
              (Dec) Similar to decrypt, but saves the messages in a file named
              after the local part of the sender address of the first message.

       define (def)  Defines  a  macro.   A  macro definition is a sequence of
              commands in the following form:

                  define name {
                      command1
                      command2
                      ...
                      commandN
                  }

              Once defined, a macro can be explicitly invoked using  the  call
              command, or can be implicitly invoked by setting the folder-hook
              or folder-hook-fullname variables.

       defines
              Prints the currently defined macros including their contents.

       delete (d) Takes a list of messages as argument and marks them  all  as
              deleted.   Deleted  messages will not be saved in mbox, nor will
              they be available for most other commands.

       discard
              Same as ignore.

       disconnect
              (disco) If operating in online mode on an IMAP  mailbox,  switch
              to  disconnected  mode  while retaining the mailbox status.  See
              the  description  of  the   disconnected   variable   for   more
              information.   A  list  of  messages  may optionally be given as
              argument; the respective messages are then read into  the  cache
              before  the  connection  is  closed.   Thus  ‘disco *’ makes the
              entire current mailbox available for disconnected use.

       dp or dt
              Deletes the current message and prints  the  next  message.   If
              there is no next message, mailx says ‘at EOF’.

       draft  Takes  a  message  list and marks each message as a draft.  This
              mark has no technical meaning in the mail system; it just causes
              messages  to  be  marked  in  the header summary, and makes them
              specially addressable.

       echo   Echoes its arguments, resolving special names as documented  for
              the  folder  command.   The  escape  sequences ‘\a’, ‘\b’, ‘\c’,
              ‘\f’, ‘\n’, ‘\r’, ‘\t’, ‘\v’, ‘\\’, and ‘\0num’ are  interpreted
              as with the echo(1) command.

       edit   (e)  Takes a list of messages and points the text editor at each
              one  in  turn.   Modified  contents  are  discarded  unless  the
              writebackedited variable is set.

       else   Marks  the  end  of  the  then-part  of  an if statement and the
              beginning of the part to take effect if the condition of the  if
              statement is false.

       endif  Marks the end of an if statement.

       exit   (ex  or  x)  Effects  an  immediate  return to the Shell without
              modifying the user’s system mailbox, his mbox file, or his  edit
              file in -f.

       file   (fi) The same as folder.

       flag   (fl)  Takes  a  message list and marks the messages as ‘flagged’
              for  urgent/special  attention.   This  mark  has  no  technical
              meaning  in  the  mail  system;  it  just  causes messages to be
              highlighted in the header  summary,  and  makes  them  specially
              addressable.

       folders
              With  no  arguments, list the names of the folders in the folder
              directory.  With an existing folder as an argument,  lists  then
              names  of  folders  below  the  named  folder;  e.g. the command
              ‘folders @’ lists the folders on the base level of  the  current
              IMAP server.  See also the imap-list-depth variable.

       folder (fold) The folder command switches to a new mail file or folder.
              With no arguments, it tells the user which file he is  currently
              reading.   If  an  argument  is given, it will write out changes
              (such as deletions) the user has made in the  current  file  and
              read  in  the new file.  Some special conventions are recognized
              for the name.  # means the previous file, % means  the  invoking
              user’s  system  mailbox,  %user  means  users system mailbox, &
              means the invoking user’s mbox file, and +file means a  file  in
              the  folder  directory.  %:filespec expands to the same value as
              filespec, but the file is handled as a system mailbox  e. g.  by
              the  mbox  and  save  commands.   If the name matches one of the
              strings defined with the shortcut command, it is replaced by its
              long  form  and expanded.  If the name ends with .gz or .bz2, it
              is treated as compressed with gzip(1) or bzip2(1), respectively.
              Likewise, if name does not exist, but either name.gz or name.bz2
              exists, the compressed file  is  used.   If  name  refers  to  a
              directory with the subdirectories ‘tmp’, ‘new’, and ‘cur’, it is
              treated as a folder in maildir format.  A name of the form

                     protocol://[user@]host[:port][/file]

              is taken as an Internet mailbox  specification.   The  supported
              protocols  are  currently  imap  (IMAP  v4r1),  imaps (IMAP with
              SSL/TLS encryption), pop3 (POP3), and pop3s (POP3  with  SSL/TLS
              encryption).  If user contains special characters, in particular
              ‘/’ or ‘%’, they must be escaped in URL notation,  as  ‘%2F’  or
              ‘%25’.   The  optional  file part applies to IMAP only; if it is
              omitted, the default ‘INBOX’ is used.  If mailx is connected  to
              an  IMAP  server,  a  name  of  the  form @mailbox refers to the
              mailbox on that server.  If the ‘folder’ variable refers  to  an
              IMAP  account,  the special name ‘%’ selects the ‘INBOX’ on that
              account.

       Followup
              (F) Similar to Respond, but saves the message in  a  file  named
              after the local part of the first recipient’s address.

       followup
              (fo)  Similar  to respond, but saves the message in a file named
              after the local part of the first recipient’s address.

       followupall
              Similar to followup, but responds to all  recipients  regardless
              of the flipr and Replyall variables.

       followupsender
              Similar  to Followup, but responds to the sender only regardless
              of the flipr and Replyall variables.

       forward
              (fwd) Takes a  message  and  the  address  of  a  recipient  and
              forwards  the  message to him.  The text of the original message
              is included in the new one, with the  value  of  the  fwdheading
              variable  printed  before.  The fwdignore and fwdretain commands
              specify which header fields are included  in  the  new  message.
              Only  the  first  part of a multipart message is included unless
              the forward-as-attachment option is set.

       Forward
              (Fwd) Similar to forward, but saves the message in a file  named
              after the local part of the recipient’s address.

       from   (f)  Takes  a list of messages and prints their message headers,
              piped through the pager if  the  output  does  not  fit  on  the
              screen.

       fwdignore
              Specifies which header fields are to be ignored with the forward
              command.  This  command  has  no  effect  when  the  forward-as-
              attachment option is set.

       fwdretain
              Specifies  which  header  fields  are  to  be  retained with the
              forward command.  fwdretain overrides fwdignore.   This  command
              has no effect when the forward-as-attachment option is set.

       good   (go) Takes a list of messages and marks all of them as not being
              junk mail.  Data from these messages is then inserted  into  the
              junk mail database for future classification.

       headers
              (h)  Lists  the current range of headers, which is an 18-message
              group.  If a ‘+’ argument is given,  then  the  next  18-message
              group  is  printed, and if a ‘-’ argument is given, the previous
              18-message group is printed.

       help   A synonym for ?.

       hold   (ho, also preserve) Takes a message list and marks each  message
              therein  to  be saved in the user’s system mailbox instead of in
              mbox.  Does not override the  delete  command.   mailx  deviates
              from  the  POSIX standard with this command, as a ‘next’ command
              issued after ‘hold’ will display the following message, not  the
              current one.

       if     Commands  in mailx’s startup files can be executed conditionally
              depending on whether the user is sending or receiving mail  with
              the if command.  For example:

                      if receive
                              commands . . .
                      endif

              An else form is also available:

                      if receive
                              commands . . .
                      else
                              commands . . .
                      endif

              Note  that  the  only  allowed conditions are receive, send, and
              term (execute command if standard input is a tty).

       ignore Add the list of header fields named to the ignored list.  Header
              fields in the ignore list are not printed on the terminal when a
              message is printed.  This command is very handy for  suppression
              of  certain machine-generated header fields.  The Type and Print
              commands can be  used  to  print  a  message  in  its  entirety,
              including  ignored  fields.   If  ignore  is  executed  with  no
              arguments, it lists the current set of ignored fields.

       imap   Sends command strings  directly  to  the  current  IMAP  server.
              Mailx  operates  always  in  IMAP  selected state on the current
              mailbox; commands that  change  this  will  produce  undesirable
              results and should be avoided.  Useful IMAP commands are:

              create Takes  the  name  of  an  IMAP mailbox as an argument and
                     creates it.

              getquotaroot
                     Takes the name of an IMAP  mailbox  as  an  argument  and
                     prints  the  quotas  that  apply to the mailbox.  Not all
                     IMAP servers support this command.

              namespace
                     Takes no arguments and prints  the  Personal  Namespaces,
                     the  Other  User’s Namespaces, and the Shared Namespaces.
                     Each namespace type is printed in parentheses;  if  there
                     are   multiple   namespaces   of  the  same  type,  inner
                     parentheses  separate  them.   For  each   namespace,   a
                     namespace  prefix  and  a  hierarchy separator is listed.
                     Not all IMAP servers support this command.

       inc    Same as newmail.

       junk   (j) Takes a list of messages and marks all of them as junk mail.
              Data  from  these  messages  is then inserted into the junk mail
              database for future classification.

       kill   (k) Takes a list of messages and ‘kills’ them.  Killed  messages
              are not printed in header summaries, and are ignored by the next
              command.  The kill command also sets the score of  the  messages
              to negative infinity, so that subsequent score commands will not
              unkill them again.  Killing is only effective  for  the  current
              session  on  a  folder;  when  it  is  quit,  all  messages  are
              automatically unkilled.

       list   Prints the names of all available commands.

       Mail   (M) Similar to mail, but saves the message in a file named after
              the local part of the first recipient’s address.

       mail   (m)  Takes  as argument login names and distribution group names
              and sends mail to those people.

       mbox   Indicate that a list of messages be sent to mbox in  the  user’s
              home  directory  when mailx is quit.  This is the default action
              for messages if unless the hold option is set.   mailx  deviates
              from  the  POSIX standard with this command, as a ‘next’ command
              issued after ‘mbox’ will display the following message, not  the
              current one.

       move   (mv) Acts like copy, but marks the messages for deletion if they
              were transferred successfully.

       Move   (Mv) Similar to move, but moves the messages  to  a  file  named
              after the local part of the sender address of the first message.

       newmail
              Checks for new mail in the current folder without committing any
              changes  before.   If new mail is present, a message is printed.
              If the header variable is set, the headers of each  new  message
              are also printed.

       next   (n) like + or CR) Goes to the next message in sequence and types
              it.  With an argument list, types the next matching message.

       New    Same as unread.

       new    Same as unread.

       online Same as connect.

       noop   If the current folder is located on an IMAP or  POP3  server,  a
              NOOP command is sent.  Otherwise, no operation is performed.

       Pipe   (Pi)  Like  pipe  but  also  pipes ignored header fields and all
              parts of MIME multipart/alternative messages.

       pipe   (pi) Takes a message list and a  shell  command  and  pipes  the
              messages  through the command.  Without an argument, the current
              message is piped through the command given by the cmd  variable.
              If  the   page  variable  is set, every message is followed by a
              formfeed character.

       preserve
              (pre) A synonym for hold.

       Print  (P) Like print but also prints out ignored header fields and all
              parts  of  MIME multipart/alternative messages.  See also print,
              ignore, and retain.

       print  (p) Takes a message list and  types  out  each  message  on  the
              user’s  terminal.   If  the message is a MIME multipart message,
              all parts with a content type of ‘text’ or ‘message’ are  shown,
              the  other  are  hidden  except for their headers.  Messages are
              decrypted  and  converted  to  the  terminal  character  set  if
              necessary.

       probability
              (prob) For each word given as argument, the contents of its junk
              mail database entry are printed.

       quit   (q)  Terminates  the  session,  saving  all  undeleted,  unsaved
              messages  in  the  user’s  mbox  file  in  his  login directory,
              preserving all messages marked with hold or  preserve  or  never
              referenced  in  his  system  mailbox,  and  removing  all  other
              messages from his system  mailbox.   If  new  mail  has  arrived
              during  the  session,  the message ‘You have new mail’ is given.
              If given while editing a mailbox file with the -f flag, then the
              edit  file  is  rewritten.   A  return to the Shell is effected,
              unless the rewrite of edit file fails, in which  case  the  user
              can escape with the exit command.

       redirect
              (red) Same as resend.

       Redirect
              (Red) Same as Resend.

       remove (rem)  Removes  the  named  folders.   The  user  is  asked  for
              confirmation in interactive mode.

       rename (ren) Takes the name of an existing folder and the name for  the
              new  folder  and  renames  the  first  to  the second one.  Both
              folders must be of the same type and  must  be  located  on  the
              current server for IMAP.

       Reply  (R)  Reply to originator.  Does not reply to other recipients of
              the original message.

       reply  (r) Takes a message list and sends mail to the  sender  and  all
              recipients  of  the specified message.  The default message must
              not be deleted.

       replyall
              Similar to reply, but responds to all recipients  regardless  of
              the flipr and Replyall variables.

       replysender
              Similar  to Reply, but responds to the sender only regardless of
              the flipr and Replyall variables.

       Resend Like resend, but does not add any header lines.  This is  not  a
              way  to  hide  the  sender’s  identity, but useful for sending a
              message again to the same recipients.

       resend Takes a list of messages and a user name and sends each  message
              to the named user.  ‘Resent-From:’ and related header fields are
              prepended to the new copy of the message.

       Respond
              Same as Reply.

       respond
              Same as reply.

       respondall
              Same as replyall.

       respondsender
              Same as replysender.

       retain Add the list of header fields named to the retained list.   Only
              the  header  fields in the retain list are shown on the terminal
              when  a  message  is  printed.   All  other  header  fields  are
              suppressed.   The Type and Print commands can be used to print a
              message  in  its  entirety.   If  retain  is  executed  with  no
              arguments, it lists the current set of retained fields.

       Save   (S)  Similar  to  save,  but  saves the messages in a file named
              after the local part of the sender of the first message  instead
              of taking a filename argument.

       save   (s) Takes a message list and a filename and appends each message
              in turn to the end of the file.  If no filename  is  given,  the
              mbox file is used.  The filename in quotes, followed by the line
              count and character count is echoed on the user’s terminal.   If
              editing  a system mailbox, the messages are marked for deletion.
              Compressed files and IMAP mailboxes are handled as described for
              the -f command line option above.

       savediscard
              Same as saveignore.

       saveignore
              Saveignore  is to save what ignore is to print and type.  Header
              fields thus marked are filtered out when  saving  a  message  by
              save  or when automatically saving to mbox.  This command should
              only be applied to header fields that do not contain information
              needed  to  decode  the  message, as MIME content fields do.  If
              saving messages on an IMAP account,  ignoring  fields  makes  it
              impossible  to  copy  the  data  directly  on  the  server, thus
              operation usually becomes much slower.

       saveretain
              Saveretain is to save what retain is to print and type.   Header
              fields  thus  marked are the only ones saved with a message when
              saving by save or when automatically saving to mbox.  Saveretain
              overrides  saveignore.   The  use  of  this  command is strongly
              discouraged since it may strip header fields that are needed  to
              decode the message correctly.

       score  (sc)  Takes  a message list and a floating point number and adds
              the number to the score of each  given  message.   All  messages
              start  at  score 0 when a folder is opened.  When the score of a
              message becomes  negative,  it  is  ‘killed’  with  the  effects
              described  for  the  kill  command; otherwise if it was negative
              before and becomes positive,  it  is  ‘unkilled’.   Scores  only
              refer to the currently opened instance of a folder.

       set    (se)  With  no  arguments,  prints  all  variable  values, piped
              through the pager if the output does  not  fit  on  the  screen.
              Otherwise,  sets option.  Arguments are of the form option=value
              (no space before or after =) or option.  Quotation marks may  be
              placed  around  any  part  of  the assignment statement to quote
              blanks or tabs, i.e. ‘set indentprefix="->"’.   If  an  argument
              begins  with  no,  as in ‘set nosave’, the effect is the same as
              invoking the unset  command  with  the  remaining  part  of  the
              variable (‘unset save’).

       seen   Takes a message list and marks all messages as having been read.

       shell  (sh) Invokes an interactive version of the shell.

       shortcut
              Defines a  shortcut  name  and  its  string  for  expansion,  as
              described  for the folder command.  With no arguments, a list of
              defined shortcuts is printed.

       show   (Sh)  Like  print,  but  performs  neither  MIME  decoding   nor
              decryption so that the raw message text is shown.

       size   Takes  a  message  list and prints out the size in characters of
              each message.

       sort   Create a sorted representation of the current folder, and change
              the  next  command and the addressing modes such that they refer
              to messages in the sorted order.  Message numbers are  the  same
              as  in  regular  mode.   If the header variable is set, a header
              summary in the new order  is  also  printed.   Possible  sorting
              criteria are:

              date   Sort  the messages by their ‘Date:’ field, that is by the
                     time they were sent.

              from   Sort messages by the value of their ‘From:’  field,  that
                     is  by  the  address  of  the  sender.   If  the showname
                     variable is set, the sender’s real name (if any) is used.

              size   Sort the messages by their size.

              score  Sort the messages by their score.

              status Sort  the  messages  by  their message status (new, read,
                     old, etc.).

              subject
                     Sort the messages by their subject.

              thread Create a threaded order, as with the thread command.

              to     Sort messages by the value of their ‘To:’ field, that  is
                     by  the  address  of  the  recipient.   If  the  showname
                     variable is set, the recipient’s real name  (if  any)  is
                     used.

              If  no  argument  is  given,  the  current  sorting criterion is
              printed.

       source The source command reads commands from a file.

       thread (th) Create a threaded representation  of  the  current  folder,
              i.e.  indent  messages that are replies to other messages in the
              header display, and change the next command and  the  addressing
              modes  such  that  they refer to messages in the threaded order.
              Message numbers are the same as  in  unthreaded  mode.   If  the
              header  variable  is  set, a header summary in threaded order is
              also printed.

       top    Takes a message list and prints the top few lines of each.   The
              number  of  lines printed is controlled by the variable toplines
              and defaults to five.

       touch  Takes a message list and marks the messages for  saving  in  the
              mbox  file.   mailx  deviates  from the POSIX standard with this
              command, as a ‘next’ command issued after  ‘mbox’  will  display
              the following message, not the current one.

       Type   (T) Identical to the Print command.

       type   (t) A synonym for print.

       unalias
              Takes a list of names defined by alias commands and discards the
              remembered groups of users.  The group names no longer have  any
              significance.

       unanswered
              Takes  a  message list and marks each message as not having been
              answered.

       uncollapse
              (unc) Only applicable to threaded mode.  Takes  a  message  list
              and  makes  the  message and all replies to it visible in header
              summaries again.  When a message becomes the current message, it
              is  automatically  made  visible.   Also  when  a  message  with
              collapsed replies is printed, all  of  these  are  automatically
              uncollapsed.

       undef  Undefines each of the named macros.  It is not an error to use a
              name that does not  belong  to  one  of  the  currently  defined
              macros.

       undelete
              (u)  Takes  a  message  list and marks each message as not being
              deleted.

       undraft
              Takes a message list and marks each message as a draft.

       unflag Takes a message  list  and  marks  each  message  as  not  being
              ‘flagged’.

       unfwdignore
              Removes  the  header field names from the list of ignored fields
              for the forward command.

       unfwdretain
              Removes the header field names from the list of retained  fields
              for the forward command.

       ungood Takes  a  message  list  and undoes the effect of a good command
              that was previously applied on exactly these messages.

       unignore
              Removes the header field names from the list of ignored  fields.

       unjunk Takes  a  message  list  and undoes the effect of a junk command
              that was previously applied on exactly these messages.

       unkill Takes a message list and ‘unkills’ each message.  Also sets  the
              score of the messages to 0.

       Unread Same as unread.

       unread (U)  Takes  a  message list and marks each message as not having
              been read.

       unretain
              Removes the header field names from the list of retained fields.

       unsaveignore
              Removes  the  header field names from the list of ignored fields
              for saving.

       unsaveretain
              Removes the header field names from the list of retained  fields
              for saving.

       unset  Takes  a  list  of  option  names  and discards their remembered
              values; the inverse of set.

       unshortcut
              Deletes the shortcut names given as arguments.

       unsort Disable sorted  or  threaded  mode  (see  the  sort  and  thread
              commands),  return  to  normal  message order and, if the header
              variable is set, print a header summary.

       unthread
              (unth) Same as unsort.

       verify (verif) Takes a message list and verifies each  message.   If  a
              message  is not an S/MIME signed message, verification will fail
              for it.  The verification process  checks  if  the  message  was
              signed  using a valid certificate, if the message sender’s email
              address matches one of those contained within  the  certificate,
              and if the message content has been altered.

       visual (v)  Takes a message list and invokes the display editor on each
              message.    Modified   contents   are   discarded   unless   the
              writebackedited variable is set.

       write  (w)  For  conventional messages, the body without all headers is
              written.  The output is decrypted and converted  to  its  native
              format,  if  necessary.   If the output file exists, the text is
              appended.—If a message is in MIME multipart  format,  its  first
              part  is  written  to  the  specified  file  as for conventional
              messages, and the user is asked for  a  filename  to  save  each
              other  part;  if  the  contents  of the first part are not to be
              saved, ‘write /dev/null’  can  be  used.   For  the  second  and
              subsequent  parts,  if  the  filename  given  starts  with a ‘|’
              character, the part  is  piped  through  the  remainder  of  the
              filename  interpreted  as  a  shell command.  In non-interactive
              mode, only the parts  of  the  multipart  message  that  have  a
              filename  given  in  the  part header are written, the other are
              discarded.  The original message is never marked for deletion in
              the  originating  mail folder.  For attachments, the contents of
              the destination file are  overwritten  if  the  file  previously
              existed.   No special handling of compressed files is performed.

       xit    (x) A synonym for exit.

       z      Mailx presents message headers in windowfuls as described  under
              the  headers  command.  The z command scrolls to the next window
              of messages.  If an argument is given, it specifies  the  window
              to  use.   A  number  prefixed  by ‘+’ or ‘-’ indicates that the
              window is calculated in relation to  the  current  position.   A
              number without a prefix specifies an absolute window number, and
              a ‘$’ lets mailx scroll to the last window of messages.

       Z      Similar to z, but scrolls to the next or  previous  window  that
              contains at least one new or ‘flagged’ message.

   Tilde escapes
       Here  is  a summary of the tilde escapes, which are used when composing
       messages  to  perform  special  functions.   Tilde  escapes  are   only
       recognized  at  the  beginning  of  lines.   The name ‘tilde escape’ is
       somewhat of a misnomer since the actual escape character can be set  by
       the option escape.

       ~!command
              Execute the indicated shell command, then return to the message.

       ~.     Same effect as typing the end-of-file character.

       ~<filename
              Identical to ~r.

       ~<!command
              Command is executed using the shell.   Its  standard  output  is
              inserted into the message.

       ~@ [filename . . . ]
              With  no  arguments,  edit the attachment list.  First, the user
              can edit all existing attachment data.  If an attachment’s  file
              name  is  left  empty, that attachment is deleted from the list.
              When the end of the attachment list is reached, mailx  will  ask
              for  further attachments, until an empty file name is given.  If
              filename arguments are specified, all of them  are  appended  to
              the  end  of the attachment list.  Filenames which contain white
              space can only be specified with the first method  (no  filename
              arguments).

       ~A     Inserts  the  string contained in the Sign variable (same as ‘~i
              Sign’).   The  escape  sequences  ‘\t’  (tabulator)   and   ‘\n’
              (newline) are understood.

       ~a     Inserts  the  string contained in the sign variable (same as ‘~i
              sign’).   The  escape  sequences  ‘\t’  (tabulator)   and   ‘\n’
              (newline) are understood.

       ~bname . . .
              Add the given names to the list of carbon copy recipients but do
              not make the names visible  in  the  Cc:  line  (‘blind’  carbon
              copy).

       ~cname . . .
              Add the given names to the list of carbon copy recipients.

       ~d     Read  the file ‘dead.letter’ from the user’s home directory into
              the message.

       ~e     Invoke the text editor on the message collected so  far.   After
              the editing session is finished, the user may continue appending
              text to the message.

       ~fmessages
              Read the named messages into the  message  being  sent.   If  no
              messages  are  specified,  read in the current message.  Message
              headers  currently  being  ignored  (by  the  ignore  or  retain
              command)  are  not  included.  For MIME multipart messages, only
              the first printable part is included.

       ~Fmessages
              Identical to ~f, except all message headers and all  MIME  parts
              are included.

       ~h     Edit  the  message  header  fields  ‘To:’,  ‘Cc:’,  ‘Bcc:’,  and
              ‘Subject:’ by typing each one in turn and allowing the  user  to
              append  text to the end or modify the field by using the current
              terminal erase and kill characters.

       ~H     Edit the message header fields ‘From:’, ‘Reply-To:’,  ‘Sender:’,
              and ‘Organization:’ in the same manner as described for ~h.  The
              default  values  for  these  fields  originate  from  the  from,
              replyto,  and ORGANIZATION variables.  If this tilde command has
              been used, changing the variables has no effect on  the  current
              message anymore.

       ~ivariable
              Insert  the  value  of  the  specified variable into the message
              adding a newline character at the end.  If the variable is unset
              or  empty,  the message remains unaltered.  The escape sequences
              ‘\t’ (tabulator) and ‘\n’ (newline) are understood.

       ~mmessages
              Read the named messages into the message being sent, indented by
              a  tab  or  by  the  value  of indentprefix.  If no messages are
              specified, read the current message.  Message headers  currently
              being  ignored  (by  the  ignore  or  retain  command)  are  not
              included.  For MIME multipart messages, only the first printable
              part is included.

       ~Mmessages
              Identical  to  ~m, except all message headers and all MIME parts
              are included.

       ~p     Print out the message collected so far, prefaced by the  message
              header  fields  and followed by the attachment list, if any.  If
              the message text is longer than the screen  size,  it  is  piped
              through the pager.

       ~q     Abort   the   message   being   sent,  copying  the  message  to
              ‘dead.letter’ in the user’s home directory if save is set.

       ~rfilename
              Read the named file into the message.

       ~sstring
              Cause the named string to become the current subject field.

       ~tname . . .
              Add the given names to the direct recipient list.

       ~v     Invoke an alternate editor (defined by the VISUAL option) on the
              message collected so far.  Usually, the alternate editor will be
              a screen editor.  After the editor is quit, the user may  resume
              appending text to the end of the message.

       ~wfilename
              Write  the message onto the named file.  If the file exists, the
              message is appended to it.

       ~x     Same as ~q,  except  that  the  message  is  not  saved  to  the
              ‘dead.letter’ file.

       ~|command
              Pipe  the  message  through  the  command  as  a filter.  If the
              command gives no output or  terminates  abnormally,  retain  the
              original  text of the message.  The command fmt(1) is often used
              as command to rejustify the message.

       ~:mailx-command
              Execute the given mailx command.  Not all commands, however, are
              allowed.

       ~_mailx-command
              Identical to ~:.

       ~~string
              Insert the string of text in the message prefaced by a single ~.
              If the escape character has been changed, that character must be
              doubled in order to send it at the beginning of a line.

   Variable options
       Options  are  controlled  via set and unset commands, see their entries
       for a syntax description.  An option is also set if  it  is  passed  to
       mailx  as  part  of the environment (this is not restricted to specific
       variables as in the POSIX standard).  A value given in a  startup  file
       overrides a value imported from the environment.  Options may be either
       binary, in which case it is only significant to see  whether  they  are
       set or not; or string, in which case the actual value is of interest.

   Binary options
       The binary options include the following:

       allnet Causes  only  the  local  part  to  be  evaluated when comparing
              addresses.

       append Causes messages saved in mbox to be appended to the  end  rather
              than prepended.  This should always be set.

       ask or asksub
              Causes mailx to prompt for the subject of each message sent.  If
              the user responds with simply a newline, no subject  field  will
              be sent.

       askatend
              Causes  the  prompts  for ‘Cc:’ and ‘Bcc:’ lists to appear after
              the message has been edited.

       askattach
              If set, mailx asks for files  to  attach  at  the  end  of  each
              message.   Responding with a newline indicates not to include an
              attachment.

       askcc  Causes the user  to  be  prompted  for  additional  carbon  copy
              recipients  (at the end of each message if askatend or bsdcompat
              is  set).   Responding  with  a  newline  indicates  the  user’s
              satisfaction with the current list.

       askbcc Causes  the user to be prompted for additional blind carbon copy
              recipients (at the end of each message if askatend or  bsdcompat
              is  set).   Responding  with  a  newline  indicates  the  user’s
              satisfaction with the current list.

       asksign
              Causes the user to be prompted if the message is to be signed at
              the  end  of  each  message.  The smime-sign variable is ignored
              when this variable is set.

       autocollapse
              Causes threads to be collapsed automatically when threaded  mode
              is entered (see the collapse command).

       autoinc
              Same as newmail.

       autoprint
              Causes  the  delete  command  to  behave  like  dp - thus, after
              deleting a message, the next one will be typed automatically.

       autothread
              Causes threaded mode (see the  thread  command)  to  be  entered
              automatically when a folder is opened.

       bang   Enables  the  substitution  of  ‘!’  by the contents of the last
              command line in shell escapes.

       bsdannounce
              Causes automatic display of a header summary after  executing  a
              folder command.

       bsdcompat
              Sets  some cosmetical features to traditional BSD style; has the
              same affect  as  setting  ‘askatend’  and  all  other  variables
              prefixed  with  ‘bsd’,  setting prompt to ‘& ’, and changing the
              default pager to more.

       bsdflags
              Changes the letters printed in the  first  column  of  a  header
              summary to traditional BSD style.

       bsdheadline
              Changes   the   display  of  columns  in  a  header  summary  to
              traditional BSD style.

       bsdmsgs
              Changes some informational messages to traditional BSD style.

       bsdorder
              Causes the ‘Subject:’ field  to  appear  immediately  after  the
              ‘To:’ field in message headers and with the ~h tilde command.

       bsdset Changes  the output format of the set command to traditional BSD
              style.

       chained-junk-tokens
              Normally,   the   Bayesian   junk   mail   filter   bases    its
              classifications  on  single word tokens extracted from messages.
              If this option is set, adjacent words  are  combined  to  pairs,
              which are then used as additional tokens.  This usually improves
              the accuracy of the filter, but also  increases  the  junk  mail
              database five- to tenfold.

       datefield
              The date in a header summary is normally the date of the mailbox
              ‘From ’ line of the message.  If this variable is set, the  date
              as given in the ‘Date:’ header field is used, converted to local
              time.

       debug  Prints debugging messages and disables the  actual  delivery  of
              messages.   Unlike  verbose,  this  option is intended for mailx
              development only.

       disconnected
              When an IMAP mailbox is selected and this variable  is  set,  no
              connection  to  the  server  is  initiated.   Instead,  data  is
              obtained from the local cache (see imap-cache).  Mailboxes  that
              are  not  present  in  the  cache and messages that have not yet
              entirely been fetched from the  server  are  not  available;  to
              fetch  all  messages  in  a mailbox at once, the command ‘copy *
              /dev/null’ can be used while still in online mode.  Changes that
              are  made  to IMAP mailboxes in disconnected mode are queued and
              committed later when a connection to that server  is  opened  in
              online mode.  This procedure is not completely reliable since it
              cannot be guaranteed that the IMAP unique identifiers (UIDs)  on
              the server still match the ones in the cache at that time.  Data
              is saved to ‘dead.letter’ when this problem occurs.

       disconnected-user@host
              The  specified  account  is  handled  as   described   for   the
              disconnected   variable   above,  but  other  accounts  are  not
              affected.

       dot    The binary option dot causes mailx to interpret a  period  alone
              on a line as the terminator of a message the user is sending.

       editheaders
              When  a  message  is  edited while being composed, its header is
              included  in  the  editable   text.    ‘To:’,   ‘Cc:’,   ‘Bcc:’,
              ‘Subject:’, ‘From:’, ‘Reply-To:’, ‘Sender:’, and ’Organization:’
              fields are accepted within the header, other fields are ignored.

       emptybox
              If  set, an empty mailbox file is not removed.  This may improve
              the interoperability with other mail user agents  when  using  a
              common folder directory.

       emptystart
              If  the  mailbox  is  empty,  mailx normally prints No mail for
              user and exits immediately.   If  this  option  is  set,  mailx
              starts even with an empty mailbox.

       flipr  Exchanges  the Respond with the respond commands and vice-versa.

       forward-as-attachment
              Original messages are normally sent  as  inline  text  with  the
              forward  command, and only the first part of a multipart message
              is included.  With  this  option,  messages  are  sent  as  MIME
              message/rfc822 attachments, and all of their parts are included.
              The  fwdignore  and  fwdretain  options  are  ignored  when  the
              forward-as-attachment option is set.

       fullnames
              When  replying  to a message, mailx normally removes the comment
              parts of email addresses, which by convention contain  the  full
              names  of  the  recipients.   If  this  variable  is  set,  such
              stripping is not performed, and comments are retained.

       header Causes the header summary to be written  at  startup  and  after
              commands  that  affect  the  number  of messages or the order of
              messages in the current folder; enabled by default.

       hold   This option is used to hold messages in the  system  mailbox  by
              default.

       ignore Causes  interrupt  signals  from  the terminal to be ignored and
              echoed as @’s.

       ignoreeof
              An option related to dot is ignoreeof which makes  mailx  refuse
              to  accept  a control-d as the end of a message.  Ignoreeof also
              applies to mailx command mode.

       imap-use-starttls
              Causes mailx to issue a STARTTLS command to make an  unencrypted
              IMAP  session  SSL/TLS  encrypted.   This  functionality  is not
              supported by all servers, and is not  used  if  the  session  is
              already encrypted by the IMAPS method.

       imap-use-starttls-user@host
              Activates imap-use-starttls for a specific account.

       keep   This  option  causes mailx to truncate the user’s system mailbox
              instead of deleting it when it is empty.  This should always  be
              set,  since  it prevents malicious users from creating fake mail
              folders in a world-writable spool directory.

       keepsave
              When a message is  saved,  it  is  usually  discarded  from  the
              originating  folder  when  mailx  is  quit.  Setting this option
              causes all saved message to be retained.

       markanswered
              When a message is replied to and this variable  is  set,  it  is
              marked  as  having  been  answered.   This mark has no technical
              meaning in the mail system; it just causes messages to be marked
              in the header summary, and makes them specially addressable.

       metoo  Usually,  when a group is expanded that contains the sender, the
              sender is removed  from  the  expansion.   Setting  this  option
              causes the sender to be included in the group.

       newmail
              Checks  for  new mail in the current folder each time the prompt
              is printed.  For IMAP mailboxes, the server is then  polled  for
              new   mail,  which  may  result  in  delayed  operation  if  the
              connection to the server is slow.  A maildir folder must be  re-
              scanned to determine if new mail has arrived.

              If  this  variable  is  set to the special value nopoll, an IMAP
              server is not actively asked for new  mail,  but  new  mail  may
              still be detected and announced with any other IMAP command that
              is sent to the server.  A maildir folder is not scanned then.

              In any case,  the  IMAP  server  may  send  notifications  about
              messages that have been deleted on the server by another process
              or client.  In this  case,  ‘Expunged  n  messages’  is  printed
              regardless  of  this  variable,  and  message  numbers  may have
              changed.

       noheader
              Setting the option noheader is the same as giving the -N flag on
              the command line.

       outfolder
              Causes the filename given in the record variable and the sender-
              based filenames for the Copy and Save commands to be interpreted
              relative  to  the  directory given in the folder variable rather
              than to the current directory unless it is an absolute pathname.

       page   If  set, each message the pipe command prints out is followed by
              a formfeed character.

       piperaw
              Send messages to the pipe command without  performing  MIME  and
              character set conversions.

       pop3-use-apop
              If  this variable is set, the APOP authentication method is used
              when a connection to a POP3 server is initiated.  The  advantage
              of  this  method over the usual USER/PASS authentication is that
              the password is not sent over the network in  clear  text.   The
              connection  fails  if  the  server  does  not  support  the APOP
              command.

       pop3-use-apop-user@host
              Enables pop3-use-apop for a specific account.

       pop3-use-starttls
              Causes mailx to issue a STLS command to make an unencrypted POP3
              session  SSL/TLS encrypted.  This functionality is not supported
              by all servers, and is  not  used  if  the  session  is  already
              encrypted by the POP3S method.

       pop3-use-starttls-user@host
              Activates pop3-use-starttls for a specific account.

       print-all-chars
              This  option  causes  all characters to be considered printable.
              It is only effective if given in  a  startup  file.   With  this
              option  set,  some  character  sequences in messages may put the
              user’s terminal in an undefined state when  printed;  it  should
              only be used as a last resort if no working system locale can be
              found.

       print-alternatives
              When a  MIME  message  part  of  type  multipart/alternative  is
              displayed  and  it  contains a subpart of type text/plain, other
              parts are normally discarded.  Setting this variable causes  all
              subparts to be displayed, just as if the surrounding part was of
              type multipart/mixed.

       quiet  Suppresses the printing of the version when first invoked.

       record-resent
              If both this variable and  the  record  variable  are  set,  the
              resend and Resend commands save messages to the record folder as
              it is normally only done for newly composed messages.

       reply-in-same-charset
              If this variable is set, mailx  first  tries  to  use  the  same
              character  set  of  the  original  message for replies.  If this
              fails, the sendcharsets variable is evaluated as usual.

       Replyall
              Reverses the sense of reply and Reply commands.

       save   When the user  aborts  a  message  with  two  RUBOUT  (interrupt
              characters)   mailx  copies  the  partial  letter  to  the  file
              ‘dead.letter’ in the home directory.   This  option  is  set  by
              default.

       searchheaders
              If this option is set, then a message-list specifier in the form
              ‘/x:y’ will expand to all messages containing the substring  ‘y’
              in the header field ‘x’.  The string search is case insensitive.

       sendwait
              When sending a message, wait until the mail transfer agent exits
              before  accepting  further commands.  If the mail transfer agent
              returns a non-zero exit status, the exit status  of  mailx  will
              also be non-zero.

       showlast
              Setting  this  option  causes mailx to start at the last message
              instead of the first one when opening a mail folder.

       showname
              Causes mailx to use the sender’s real name instead of the  plain
              address   in   the   header   field   summary   and  in  message
              specifications.

       showto Causes the recipient of the message to be shown  in  the  header
              summary if the message was sent by the user.

       skipemptybody
              If an outgoing message does not contain any text in its first or
              only message part, do not send it but discard it  silently  (see
              also the -E option).

       smime-force-encryption
              Causes mailx to refuse sending unencrypted messages.

       smime-sign
              If  this  variable  is  set, outgoing messages are S/MIME signed
              with the user’s  private  key.   Signing  a  message  enables  a
              recipient  to  verify  that the sender used a valid certificate,
              that the email addresses in the certificate match those  in  the
              message  header,  and  that  the  message  content  has not been
              altered.  It does not change the message text, and  people  will
              be able to read the message as usual.

       smime-no-default-ca
              Do  not  load  the  default  CA  locations when verifying S/MIME
              signed messages.  Only applicable if  S/MIME  support  is  built
              using OpenSSL.

       smtp-use-starttls
              Causes mailx to issue a STARTTLS command to make an SMTP session
              SSL/TLS  encrypted.   Not  all  servers  support  this  command;
              because   of   common   implementation  defects,  it  cannot  be
              automatically determined whether a server supports it or not.

       ssl-no-default-ca
              Do not load the default CA locations to  verify  SSL/TLS  server
              certificates.  Only applicable if SSL/TLS support is built using
              OpenSSL.

       ssl-v2-allow
              Accept  SSLv2  connections.   These  are  normally  not  allowed
              because this protocol version is insecure.

       stealthmua
              Inhibits  the  generation of the Message-Id: and User-Agent:
              header fields that include obvious references to  mailx.   There
              are  two pitfalls associated with this: First, the message id of
              outgoing messages is not known anymore.  Second, an  expert  may
              still  use the remaining information in the header to track down
              the originating mail user agent.

       verbose
              Setting the option verbose is the same as using the -v  flag  on
              the  command  line.  When mailx runs in verbose mode, details of
              the actual message delivery and protocol conversations for IMAP,
              POP3,  and  SMTP,  as  well  as of other internal processes, are
              displayed on the user’s terminal, This is  sometimes  useful  to
              debug  problems.   Mailx  prints all data that is sent to remote
              servers in clear texts, including passwords, so care  should  be
              taken  that  no  unauthorized option can view the screen if this
              option is enabled.

       writebackedited
              If this variable is set, messages modified  using  the  edit  or
              visual  commands  are written back to the current folder when it
              is quit.  This is only possible for  writable  folders  in  mbox
              format.   Setting  this variable also disables MIME decoding and
              decryption for the editing commands.

   String Options
       The string options include the following:

       attrlist
              A sequence of characters to print in the ‘attribute’ column of a
              header  summary,  each for one type of messages in the following
              order: new, unread but old, new but read, read and  old,  saved,
              preserved,  mboxed, flagged, answered, draft, killed, start of a
              collapsed thread, collapsed, classified as junk.  The default is
              ‘NUROSPMFATK+-J’,  or  ‘NU  *HMFATK+-J’ if bsdflags or the SYSV3
              environment variable are set.

       autobcc
              Specifies a list of recipients to which a blind carbon  copy  of
              each outgoing message will be sent automatically.

       autocc Specifies  a  list  of recipients to which a carbon copy of each
              outgoing message will be sent automatically.

       autosort
              Causes  sorted  mode  (see  the  sort  command)  to  be  entered
              automatically  with  the  value of this option as sorting method
              when a folder is opened.

       cmd    The default value for the pipe command.

       crt    The valued option crt is used as a threshold  to  determine  how
              long  a message must be before PAGER is used to read it.  If crt
              is set without a value, then the height of the  terminal  screen
              stored  in  the  system  is  used  to compute the threshold (see
              stty(1)).

       DEAD   The name of the file to use for saving aborted  messages.   This
              defaults to ‘dead.letter’ in the user’s home directory.

       EDITOR Pathname  of  the  text editor to use in the edit command and ~e
              escape.  If not defined, then a default editor is used.

       encoding
              The default MIME encoding to use in outgoing text  messages  and
              message  parts.  Valid values are 8bit or quoted-printable.  The
              default is 8bit.  In case the mail transfer system is not  ESMTP
              compliant, quoted-printable should be used instead.  If there is
              no need to encode a message, 7bit transfer mode is used, without
              regard  to  the  value  of this variable.  Binary data is always
              encoded in base64 mode.

       escape If defined,  the  first  character  of  this  option  gives  the
              character to use in the place of ~ to denote escapes.

       folder The  name  of  the  directory  to  use  for  storing  folders of
              messages.  All folder names that begin with ‘+’ refer  to  files
              below  that directory.  If the directory name begins with a ‘/’,
              mailx considers it to be an absolute  pathname;  otherwise,  the
              folder directory is found relative to the user’s home directory.

              The directory name may also refer to an IMAP account; any  names
              that  begin  with  ‘+’  then  refer  to  IMAP  mailboxes on that
              account.  An IMAP folder is normally given in the form

                  imaps://mylogin@imap.myisp.example

              In this case, the ‘+’ and ‘@’ prefixes for folder names have the
              same effect (see the folder command).

              Some IMAP servers do not accept the creation of mailboxes in the
              hierarchy base; they require that they are created as subfolders
              of ‘INBOX’.  With such servers, a folder name of the form

                  imaps://mylogin@imap.myisp.example/INBOX.

              should  be  used  (the  last character is the server’s hierarchy
              delimiter).  Folder names prefixed by ‘+’  will  then  refer  to
              folders  below ‘INBOX’, while folder names prefixed by ‘@’ refer
              to folders below the hierarchy base.   See  the  imap  namespace
              command  for  a  method  to  detect  the  appropriate prefix and
              delimiter.

       folder-hook
              When a folder is opened and this  variable  is  set,  the  macro
              corresponding  to  the  value of this variable is executed.  The
              macro is also invoked when new mail arrives, but  message  lists
              for  commands executed from the macro only include newly arrived
              messages then.

       folder-hook-fullname
              When a folder named fullname is opened, the macro  corresponding
              to  the value of this variable is executed.  Unlike other folder
              specifications, the fully expanded name  of  a  folder,  without
              metacharacters,   is  used  to  avoid  ambiguities.   The  macro
              specified with folder-hook is not executed if this  variable  is
              effective  for  a folder (unless it is explicitly invoked within
              the called macro).

       from   The address (or a list of addresses) to  put  into  the  From:
              field  of  the  message header.  If replying to a message, these
              addresses are handled as if they were in  the  alternates  list.
              If  the  machine’s  hostname  is  not valid at the Internet (for
              example at a dialup machine), either this variable  or  hostname
              have to be set to get correct Message-ID header fields.  If from
              contains more than one address, the sender variable must also be
              set.

       fwdheading
              The  string  to  print  before  the  text  of a message with the
              forward command (unless the  forward-as-attachment  variable  is
              set).   Defaults  to  ‘‘--------  Original Message --------’’ if
              unset.  If it is set to the empty string, no heading is printed.

       headline
              A format string to use for the header summary, similar to printf
              formats.  A ‘%’ character introduces a format specifier.  It may
              be  followed  by  a  number  indicating the field width.  If the
              field is a number, the width may be  negative,  which  indicates
              that it is to be left-aligned.  Valid format specifiers are:

                  %a    Message attributes.
                  %c    The score of the message.
                  %d    The date when the message was received.
                  %e    The indenting level in threaded mode.
                  %f    The address of the message sender.
                  %i    The message thread structure.
                  %l    The number of lines of the message.
                  %m    Message number.
                  %o    The number of octets (bytes) in the message.
                  %s    Message subject (if any).
                  %S    Message subject (if any) in double quotes.
                  %t    The position in threaded/sorted order.
                  %>    A ‘>’ for the current message, otherwise ‘ ’.
                  %<    A ‘<’ for the current message, otherwise ‘ ’.
                  %%    A ‘%’ character.

              The     default    is    ‘%>%a%m %18f %16d %4l/%-5o %i%s’,    or
              ‘%>%a%m %20f  %16d %3l/%-5o %i%S’ if bsdcompat is set.

       hostname
              Use this string  as  hostname  when  expanding  local  addresses
              instead  of the value obtained from uname(2) and getaddrinfo(3).

       imap-auth
              Sets the IMAP authentication method.  Valid values  are  ‘login’
              for  the  usual  password-based  authentication  (the  default),
              ‘cram-md5’, which is a password-based authentication  that  does
              not  send  the  password  over  the  network  in clear text, and
              ‘gssapi’ for GSSAPI-based authentication.

       imap-auth-user@host
              Sets the IMAP authentication method for a specific account.

       imap-cache
              Enables caching of IMAP mailboxes.  The value of  this  variable
              must  point  to  a  directory  that is either existent or can be
              created by mailx.  All contents of the cache can be  deleted  by
              mailx  at  any  time;  it  is not safe to make assumptions about
              them.

       imap-keepalive
              IMAP  servers  may  close  the  connection  after  a  period  of
              inactivity;  the  standard  requires  this  to  be  at  least 30
              minutes,  but  practical  experience  may  vary.   Setting  this
              variable to a numeric value greater than 0 causes a NOOP command
              to  be  sent  each  value  seconds  if  no  other  operation  is
              performed.

       imap-list-depth
              When  retrieving  the  list  of  folders  on an IMAP server, the
              folders command stops after it has reached a  certain  depth  to
              avoid  possible infinite loops.  The value of this variable sets
              the maximum depth allowed.  The default is  2.   If  the  folder
              separator  on  the  current  IMAP  server  is  a slash ‘/’, this
              variable has no effect, and the folders command does not descend
              to subfolders.

       indentprefix
              String  used by the ‘~m’ and ‘~M’ tilde escapes and by the quote
              option for indenting  messages,  in  place  of  the  normal  tab
              character  (^I).   Be  sure  to  quote  the value if it contains
              spaces or tabs.

       junkdb The location of the junk mail database.  The string  is  treated
              like a folder name, as described for the folder command.

              The  files  in  the  junk  mail  database are normally stored in
              compress(1) format for saving  space.   If  processing  time  is
              considered  more  important,  uncompress(1) can be used to store
              them in plain form.  Mailx will then work using the uncompressed
              files.

       LISTER Pathname  of  the directory lister to use in the folders command
              when operating on local mailboxes.  Default is /bin/ls.

       MAIL   Is used as the user’s mailbox, if  set.   Otherwise,  a  system-
              dependent default is used.  Can be a protocol:// string (see the
              folder command for more information).

       MAILX_HEAD
              A string to put at the  beginning  of  each  new  message.   The
              escape   sequences  ‘\t’  (tabulator)  and  ‘\n’  (newline)  are
              understood.

       MAILX_TAIL
              A string to put at the end of  each  new  message.   The  escape
              sequences ‘\t’ (tabulator) and ‘\n’ (newline) are understood.

       maximum-unencoded-line-length
              Messages  that  contain  lines  longer  than  the  value of this
              variable are encoded in quoted-printable even  if  they  contain
              only  ASCII characters.  The maximum effective value is 950.  If
              set to 0,  all  ASCII  text  messages  are  encoded  in  quoted-
              printable.  S/MIME signed messages are always encoded in quoted-
              printable regardless of the value of this variable.

       MBOX   The name of the mbox file.  It can be the name of a folder.  The
              default is ‘mbox’ in the user’s home directory.

       NAIL_EXTRA_RC
              The name of an optional startup file to be read after ~/.mailrc.
              This variable is ignored if it is imported from the environment;
              it  has an effect only if it is set in /etc/nail.rc or ~/.mailrc
              to   allow   bypassing   the   configuration    with    e.    g.
              ‘MAILRC=/dev/null’.   Use  this  file  for commands that are not
              understood by other mailx implementations.

       newfolders
              If this variable has the  value  maildir,  newly  created  local
              folders will be in maildir format.

       nss-config-dir
              A  directory  that  contains  the  files  certN.db  to  retrieve
              certificates, keyN.db to retrieve private keys,  and  secmod.db,
              where  N  is  a  digit.   These  are  usually taken from Mozilla
              installations,   so    an    appropriate    value    might    be
              ‘~/.mozilla/firefox/default.clm’.  Mailx opens these files read-
              only and does not  modify  them.   However,  if  the  files  are
              modified by Mozilla while mailx is running, it will print a ‘Bad
              database’ message.  It may be  necessary  to  create  copies  of
              these  files  that  are  exclusively  used  by mailx then.  Only
              applicable if S/MIME and SSL/TLS support is built using  Network
              Security Services (NSS).

       ORGANIZATION
              The  value  to put into the Organization: field of the message
              header.

       PAGER  Pathname of the program to use in the more command or  when  crt
              variable  is  set.   The  default  paginator  pg(1)  or,  in BSD
              compatibility mode, more(1)  is  used  if  this  option  is  not
              defined.

       password-user@host
              Set  the  password for user when connecting to host.  If no such
              variable is defined for a host, the user will  be  asked  for  a
              password  on  standard input.  Specifying passwords in a startup
              file is generally a security risk, the file should  be  readable
              by the invoking user only.

       pipe-content/subcontent
              When a MIME message part of content/subcontent type is displayed
              or it is replied to, its text is filtered through the  value  of
              this variable interpreted as a shell command.  Special care must
              be taken when  using  such  commands  as  mail  viruses  may  be
              distributed by this method; if messages of type application/x-sh
              were filtered through the shell, for example, a  message  sender
              could  easily  execute  arbitrary  code  on  the system mailx is
              running on.

       pop3-keepalive
              POP3  servers  may  close  the  connection  after  a  period  of
              inactivity;  the  standard  requires  this  to  be  at  least 10
              minutes,  but  practical  experience  may  vary.   Setting  this
              variable to a numeric value greater than 0 causes a NOOP command
              to  be  sent  each  value  seconds  if  no  other  operation  is
              performed.

       prompt The  string  printed  when  a  command is accepted.  Defaults to
              ‘? ’, or to ‘& ’ if the bsdcompat variable is set.

       quote  If set, mailx  starts  a  replying  message  with  the  original
              message  prefixed  by  the  value  of the variable indentprefix.
              Normally, a heading consisting of  ‘Fromheaderfield  wrote:’  is
              printed  before  the  quotation.   If  the  string  noheading is
              assigned to the quote variable, this heading is omitted.  If the
              string   headers  is  assigned,  the  headers  selected  by  the
              ignore/retain commands are printed above the message body,  thus
              quote  acts  like  an  automatic ~m command then.  If the string
              allheaders is  assigned,  all  headers  are  printed  above  the
              message  body,  and all MIME parts are included, thus quote acts
              like an automatic ~M command then.

       record If defined, gives the pathname of the folder used to record  all
              outgoing  mail.   If  not  defined, then outgoing mail is not so
              saved.  When saving to this folder fails,  the  message  is  not
              sent but saved to the ‘dead.letter’ file instead.

       replyto
              A  list  of  addresses  to put into the Reply-To: field of the
              message header.  If replying to a message,  such  addresses  are
              handled as if they were in the alternates list.

       screen When  mailx  initially prints the message headers, it determines
              the number to print by looking at the  speed  of  the  terminal.
              The  faster  the  terminal,  the  more  it  prints.  This option
              overrides  this  calculation  and  specifies  how  many  message
              headers  are  printed.   This  number is also used for scrolling
              with the z command.

       sendcharsets
              A comma-separated list of character set names that can  be  used
              in  Internet  mail.  When a message that contains characters not
              representable in US-ASCII is prepared for sending,  mailx  tries
              to convert its text to each of the given character sets in order
              and uses the first appropriate one.  The default is ‘utf-8’.

              Character sets assigned to this variable should  be  ordered  in
              ascending  complexity.  That is, the list should start with e.g.
              ‘iso-8859-1’ for compatibility with older  mail  clients,  might
              contain  some other language-specific character sets, and should
              end with ‘utf-8’  to  handle  messages  that  combine  texts  in
              multiple languages.

       sender An  address  that  is  put  into the ‘Sender:’ field of outgoing
              messages.  This field needs not normally  be  present.   It  is,
              however,  required  if  the ‘From:’ field contains more than one
              address.  It can also be used to indicate  that  a  message  was
              sent  on  behalf of somebody other; in this case, ‘From:’ should
              contain the address of the person that took  responsibility  for
              the  message,  and  ‘Sender:’  should contain the address of the
              person that actually sent the message.  The  sender  address  is
              handled as if it were in the alternates list.

       sendmail
              To use an alternate mail delivery system, set this option to the
              full pathname of the program to use.  This should be  used  with
              care.

       SHELL  Pathname of the shell to use in the ! command and the ~! escape.
              A default shell is used if this option is not defined.

       Sign   A string for use with the ~A command.

       sign   A string for use with the ~a command.

       signature
              Must correspond to the name of a readable  file  if  set.
              The  file’s  content  is then appended to each singlepart
              message and to the first part of each multipart  message.
              Be  warned  that  there  is  no  possibility  to edit the
              signature for an individual message.

       smime-ca-dir
              Specifies  a   directory   with   CA   certificates   for
              verification  of  S/MIME  signed messages.  The format is
              the         same         as         described          in
              SSL_CTX_load_verify_locations(3).    Only  applicable  if
              S/MIME support is built using OpenSSL.

       smime-ca-file
              Specifies a file with CA certificates for verification of
              S/MIME  signed  messages.   The  format  is  the  same as
              described  in   SSL_CTX_load_verify_locations(3).    Only
              applicable if S/MIME support is built using OpenSSL.

       smime-cipher-user@host
              Specifies   a   cipher  to  use  when  generating  S/MIME
              encrypted messages  for  user@host.   Valid  ciphers  are
              rc2-40 (RC2 with 40 bits), rc2-64 (RC2 with 64 bits), des
              (DES, 56 bits) and des-ede3 (3DES,  112/168  bits).   The
              default  is 3DES.  It is not recommended to use the other
              ciphers unless a recipient’s client is actually unable to
              handle  3DES  since they are comparatively weak; but even
              so,  the  recipient  should  upgrade  his   software   in
              preference.

       smime-crl-file
              Specifies a file that contains a CRL in PEM format to use
              when  verifying  S/MIME  messages.   Only  applicable  if
              S/MIME support is built using OpenSSL.

       smime-crl-dir
              Specifies  a  directory  that contains files with CRLs in
              PEM format to use when verifying S/MIME  messages.   Only
              applicable if S/MIME support is built using OpenSSL.

       smime-encrypt-user@host
              If  this  variable  is  set,  messages  to  user@host are
              encrypted before sending.  If  S/MIME  support  is  built
              using  OpenSSL,  the value of the variable must be set to
              the name of a file that contains  a  certificate  in  PEM
              format.   If S/MIME support is built using NSS, the value
              of this variable is ignored, but if multiple certificates
              for user@host are available, the smime-nickname-user@host
              variable should be set.  Otherwise a certificate for  the
              recipient is automatically retrieved from the certificate
              database, if possible.

              If a message is sent to multiple recipients, each of them
              for  whom a corresponding variable is set will receive an
              individually encrypted  message;  other  recipients  will
              continue  to receive the message in plain text unless the
              smime-force-encryption   variable   is   set.    It    is
              recommended  to sign encrypted messages, i.e. to also set
              the smime-sign variable.

       smime-nickname-user@host
              Specifies the nickname of a certificate to be  used  when
              encrypting  messages  for user@host .  Only applicable if
              S/MIME support is built using NSS.

       smime-sign-cert
              Points to a file in PEM format that contains  the  user’s
              private  key  as  well as his certificate.  Both are used
              with S/MIME for signing and  decrypting  messages.   Only
              applicable if S/MIME support is built using OpenSSL.

       smime-sign-cert-user@host
              Overrides  smime-sign-cert  for  the  specific addresses.
              When signing messages and the value of the from  variable
              is  set  to  user@host,  the specific file is used.  When
              decrypting messages, their recipient fields (To: and Cc:)
              are  searched  for addresses for which such a variable is
              set.  Mailx always uses the first address  that  matches,
              so  if  the  same message is sent to more than one of the
              user’s  addresses  using   different   encryption   keys,
              decryption might fail.  Only applicable if S/MIME support
              is built using OpenSSL.

       smime-sign-nickname
              Specifies that the named certificate be used for  signing
              mail.   If  this  variable  is  not  set,  but  a  single
              certificate matching the current from address is found in
              the  database,  that  one  is  used  automatically.  Only
              applicable if S/MIME support is built using NSS.

       smime-sign-nickname-user@host
              Overrides smime-sign-nickname  for  a  specific  address.
              Only applicable if S/MIME support is built using NSS.

       smtp   Normally,  mailx invokes sendmail(8) directly to transfer
              messages.  If the smtp variable is set, a SMTP connection
              to  the server specified by the value of this variable is
              used instead.  If  the  SMTP  server  does  not  use  the
              standard  port, a value of server:port can be given, with
              port as a name or as a number.

              There are two possible methods to get  SSL/TLS  encrypted
              SMTP sessions: First, the STARTTLS command can be used to
              encrypt a session after it has been initiated, but before
              any    user-related    data    has    been    sent;   see
              smtp-use-starttls above.   Second,  some  servers  accept
              sessions that are encrypted from their beginning on. This
              mode is configured by assigning smtps://server[:port]  to
              the smtp variable.

              The  SMTP transfer is executed in a child process; unless
              either the sendwait or the verbose variable is set,  this
              process  runs  asynchronously.   If  it  receives  a TERM
              signal, it  will  abort  and  save  the  message  to  the
              ‘dead.letter’ file.

       smtp-auth
              Sets  the SMTP authentication method.  If set to ‘login’,
              or if unset and smtp-auth-user  is  set,  AUTH  LOGIN  is
              used.   If  set  to ‘cram-md5’, AUTH CRAM-MD5 is used; if
              set to ‘plain’, AUTH PLAIN is used.  Otherwise,  no  SMTP
              authentication is performed.

       smtp-auth-user@host
              Overrides   smtp-auth   for  specific  values  of  sender
              addresses, depending on the from variable.

       smtp-auth-password
              Sets the global password for SMTP AUTH.   Both  user  and
              password  have  to be given for AUTH LOGIN and AUTH CRAM-
              MD5.

       smtp-auth-password-user@host
              Overrides  smtp-auth-password  for  specific  values   of
              sender addresses, depending on the from variable.

       smtp-auth-user
              Sets  the  global user name for SMTP AUTH.  Both user and
              password have to be given for AUTH LOGIN and  AUTH  CRAM-
              MD5.

              If this variable is set but neither smtp-auth-password or
              a matching  smtp-auth-password-user@host  can  be  found,
              mailx will as for a password on the user’s terminal.

       smtp-auth-user-user@host
              Overrides  smtp-auth-user  for  specific values of sender
              addresses, depending on the from variable.

       ssl-ca-dir
              Specifies  a   directory   with   CA   certificates   for
              verification   of   SSL/TLS   server  certificates.   See
              SSL_CTX_load_verify_locations(3)  for  more  information.
              Only   applicable  if  SSL/TLS  support  is  built  using
              OpenSSL.

       ssl-ca-file
              Specifies a file with CA certificates for verification of
              SSL/TLS         server         certificates.          See
              SSL_CTX_load_verify_locations(3)  for  more  information.
              Only   applicable  if  SSL/TLS  support  is  built  using
              OpenSSL.

       ssl-cert
              Sets the file  name  for  a  SSL/TLS  client  certificate
              required  by  some  servers.   Only applicable if SSL/TLS
              support is built using OpenSSL.

       ssl-cert-user@host
              Sets an account-specific file name for a  SSL/TLS  client
              certificate required by some servers.  Overrides ssl-cert
              for the specified account.  Only  applicable  if  SSL/TLS
              support is built using OpenSSL.

       ssl-cipher-list
              Specifies a list of ciphers for SSL/TLS connections.  See
              ciphers(1) for  more  information.   Only  applicable  if
              SSL/TLS support is built using OpenSSL.

       ssl-crl-file
              Specifies a file that contains a CRL in PEM format to use
              when  verifying  SSL/TLS   server   certificates.    Only
              applicable if SSL/TLS support is built using OpenSSL.

       ssl-crl-dir
              Specifies  a  directory  that contains files with CRLs in
              PEM  format  to  use  when   verifying   SSL/TLS   server
              certificates.   Only  applicable  if  SSL/TLS  support is
              built using OpenSSL.

       ssl-key
              Sets the file name for  the  private  key  of  a  SSL/TLS
              client   certificate.    If   unset,   the  name  of  the
              certificate file is used.  The file is expected to be  in
              PEM  format.  Only applicable if SSL/TLS support is built
              using OpenSSL.

       ssl-key-user@host
              Sets an account-specific file name for the private key of
              a  SSL/TLS client certificate.  Overrides ssl-key for the
              specified account.  Only applicable if SSL/TLS support is
              built using OpenSSL.

       ssl-method
              Selects  a  SSL/TLS  protocol  version;  valid values are
              ‘ssl2’, ‘ssl3’, and ‘tls1’.   If  unset,  the  method  is
              selected automatically, if possible.

       ssl-method-user@host
              Overrides ssl-method for a specific account.

       ssl-rand-egd
              Gives  the  pathname  to  an  entropy  daemon socket, see
              RAND_egd(3).

       ssl-rand-file
              Gives the pathname to  a  file  with  entropy  data,  see
              RAND_load_file(3).    If  the  file  is  a  regular  file
              writable by the invoking user, new data is written to  it
              after  it  has  been  loaded.  Only applicable if SSL/TLS
              support is built using OpenSSL.

       ssl-verify
              Sets the action to be performed if an error occurs during
              SSL/TLS  server certificate validation.  Valid values are
              ‘strict’ (fail and close connection  immediately),  ‘ask’
              (ask  whether  to  continue  on  standard  input), ‘warn’
              (print a warning and continue), ‘ignore’ (do not  perform
              validation).  The default is ‘ask’.

       ssl-verify-user@host
              Overrides ssl-verify for a specific account.

       toplines
              If  defined, gives the number of lines of a message to be
              printed out with the top  command;  normally,  the  first
              five lines are printed.

       ttycharset
              The  character  set  of  the  terminal mailx operates on.
              There is normally no need  to  set  this  variable  since
              mailx  can determine this automatically by looking at the
              LC_CTYPE locale setting; if this succeeds, the  value  is
              assigned  at  startup  and  will  be displayed by the set
              command.  Note that this is not necessarily  a  character
              set name that can be used in Internet messages.

       VISUAL Pathname  of the text editor to use in the visual command
              and ~v escape.

ENVIRONMENT VARIABLES

       Besides the variables described above, mailx uses the  following
       environment strings:

       HOME   The user’s home directory.

       LANG, LC_ALL, LC_COLLATE, LC_CTYPE, LC_MESSAGES
              See locale(7).

       MAILRC Is  used  as  startup  file  instead of ~/.mailrc if set.
              When mailx scripts are invoked on behalf of other  users,
              this variable should be set to ‘/dev/null’ to avoid side-
              effects from reading their configuration files.

       NAILRC If this variable is set and MAILRC is not set, it is read
              as startup file.

       SYSV3  Changes  the  letters  printed  in  the first column of a
              header summary.

       TMPDIR Used as directory for temporary files instead of /tmp, if
              set.

FILES

       ~/.mailrc
              File giving initial commands.

       /etc/nail.rc
              System wide initialization file.

       ~/.mime.types
              Personal MIME types.

       /etc/mime.types
              System wide MIME types.

EXAMPLES

   Getting started
       The  mailx command has two distinct usages, according to whether
       one wants to send or receive mail.  Sending mail is  simple:  to
       send   a  message  to  a  user  whose  email  address  is,  say,
       <bill@host.example>, use the shell command:

           $ mailx bill@host.example

       then type your message.  Mailx will prompt  you  for  a  message
       subject  first;  after that, lines typed by you form the body of
       the message.  When you reach the end of the message, type an EOT
       (control-d)  at  the beginning of a line, which will cause mailx
       to echo ‘EOT’ and return you to the shell.

       If, while you are composing the message you decide that  you  do
       not  wish  to send it after all, you can abort the letter with a
       RUBOUT.   Typing  a  single  RUBOUT  causes   mailx   to   print
       ‘(Interrupt  --  one  more  to  kill  letter)’.  Typing a second
       RUBOUT causes mailx to save your  partial  letter  on  the  file
       ‘dead.letter’ in your home directory and abort the letter.  Once
       you have sent mail to someone, there is no way to undo the  act,
       so be careful.

       If  you  want  to send the same message to several other people,
       you can list their email addresses on the command line.  Thus,

           $ mailx sam@workstation.example bob@server.example
           Subject: Fees
           Tuition fees are due next Friday.  Don’t forget!
           <Control-d>
           EOT
           $

       will  send  the  reminder  to  <sam@workstation.example>.    and
       <bob@server.example>.

       To read your mail, simply type

           $ mailx

       Mailx  will  respond  by  typing its version number and date and
       then listing the messages you have waiting.  Then it will type a
       prompt  and  await  your  command.   The  messages  are assigned
       numbers starting with 1—you refer to  the  messages  with  these
       numbers.  Mailx keeps track of which messages are new (have been
       sent since you last read your mail) and read (have been read  by
       you).  New messages have an N next to them in the header listing
       and old, but unread messages have a U next to them.  Mailx keeps
       track  of  new/old  and read/unread messages by putting a header
       field called Status into your messages.

       To look at a specific message, use the type command,  which  may
       be  abbreviated  to  simply  t  .   For  example, if you had the
       following messages:

           O 1 drfoo@myhost.example Wed Sep  1 19:52  18/631 "Fees"
           O 2 sam@friends.example  Thu Sep  2 00:08  30/895

       you could examine the first message by giving the command:

           type 1

       which might cause mailx to respond with, for example:

           Message  1:
           From drfoo@myhost.example Wed Sep  1 19:52:25 2004
           Subject: Fees
           Status: R

           Tuition fees are due next Wednesday.  Don’t forget!

       Many mailx commands that operate  on  messages  take  a  message
       number  as  an  argument  like  the  type  command.   For  these
       commands, there is a notion of  a  current  message.   When  you
       enter  the  mailx  program, the current message is initially the
       first (or the first recent) one.  Thus, you can often  omit  the
       message number and use, for example,

           t

       to  type  the  current message.  As a further shorthand, you can
       type a message by simply giving its message number.  Hence,

           1

       would type the first message.

       Frequently, it is useful to read the messages in your mailbox in
       order,  one  after  another.   You  can read the next message in
       mailx by simply typing a newline.  As a special  case,  you  can
       type  a newline as your first command to mailx to type the first
       message.

       If, after typing a message,  you  wish  to  immediately  send  a
       reply, you can do so with the reply command.  This command, like
       type, takes a message number as an argument.  mailx then  begins
       a  message  addressed to the user who sent you the message.  You
       may then type in your letter in reply, followed by a <control-d>
       at the beginning of a line, as before.

       Note  that  mailx  copies  the  subject header from the original
       message.   This  is  useful  in  that  correspondence  about   a
       particular  matter will tend to retain the same subject heading,
       making it easy to recognize.  If there are other  header  fields
       in  the  message, like ‘Cc:’, the information found will also be
       used.

       Sometimes you will receive a  message  that  has  been  sent  to
       several people and wish to reply only to the person who sent it.
       Reply with a capital R replies to a message, but sends a copy to
       the sender only.

       If  you  wish,  while  reading  your  mail, to send a message to
       someone, but not as a reply to one of  your  messages,  you  can
       send  the message directly with the mail command, which takes as
       arguments the names of the recipients you wish to send to.   For
       example, to send a message to <frank@machine.example>, you would
       do:

           mail frank@machine.example

       To delete a message from the mail folder, you can use the delete
       command.  In addition to not saving deleted messages, mailx will
       not let you type them,  either.   The  effect  is  to  make  the
       message disappear altogether, along with its number.

       Many  features  of mailx can be tailored to your liking with the
       set command.  The  set  command  has  two  forms,  depending  on
       whether  you  are  setting  a  binary option or a valued option.
       Binary options are either on or off.   For  example,  the  askcc
       option informs mailx that each time you send a message, you want
       it to prompt you for a ‘Cc:’  header,  to  be  included  in  the
       message.  To set the askcc option, you would type

           set askcc

       Valued  options  are  values  which  mailx uses to adapt to your
       tastes.  For example, the record option  tells  mailx  where  to
       save messages sent by you, and is specified by

           set record=Sent

       for example.  Note that no spaces are allowed in set record=Sent
       .

       Mailx includes a  simple  facility  for  maintaining  groups  of
       messages  together  in folders.  To use the folder facility, you
       must tell mailx where you  wish  to  keep  your  folders.   Each
       folder  of messages will be a single file.  For convenience, all
       of your folders are kept in a single directory of your choosing.
       To  tell mailx where your folder directory is, put a line of the
       form

           set folder=letters

       in your .mailrc file.  If, as in the example above, your  folder
       directory does not begin with a ‘/’, mailx will assume that your
       folder  directory  is  to  be  found  starting  from  your  home
       directory.

       Anywhere  a  file  name  is expected, you can use a folder name,
       preceded with ‘+’.  For example, to put a message into a  folder
       with the save command, you can use:

           save +classwork

       to  save  the  current  message in the classwork folder.  If the
       classwork folder does not yet exist, it will be  created.   Note
       that  messages  which  are  saved  with  the  save  command  are
       automatically removed from your system mailbox.

       In order to make a copy of a message in a folder without causing
       that  message  to  be  removed from your system mailbox, use the
       copy command, which is identical in all other  respects  to  the
       save command.

       The  folder  command can be used to direct mailx to the contents
       of a different folder.  For example,

           folder +classwork

       directs mailx to read the contents of the classwork folder.  All
       of the commands that you can use on your system mailbox are also
       applicable to folders, including type, delete,  and  reply.   To
       inquire which folder you are currently editing, use simply:

           folder

       To list your current set of folders, use the folders command.

       Finally,  the  help  command  is  available to print out a brief
       summary of the most important mailx commands.

       While typing in a message to be sent  to  others,  it  is  often
       useful  to  be  able  to  invoke  the text editor on the partial
       message, print the message, execute a shell command, or do  some
       other  auxiliary  function.   Mailx  provides these capabilities
       through tilde escapes , which consist of  a  tilde  (~)  at  the
       beginning  of  a  line,  followed  by  a  single character which
       indicates the function to be performed.  For example,  to  print
       the text of the message so far, use:

           ~p

       which  will  print  a  line  of  dashes,  the recipients of your
       message, and the text of the message so far.  A list of the most
       important tilde escapes is available with ‘~?’.

   IMAP or POP3 client setup
       First  you  need the following data from your ISP: the host name
       of the IMAP or POP3 server, user  name  and  password  for  this
       server, and a notice whether the server uses SSL/TLS encryption.
       Assuming the host name is ‘server.myisp.example’ and  your  user
       name for that server is ‘mylogin’, you can refer to this account
       using the folder command or -f command line option with

           imaps://mylogin@server.myisp.example

       (This string is not necessarily the same as your  Internet  mail
       address.)   You  can  replace  ‘imaps://’  with ‘imap://’ if the
       server does not support SSL/TLS.  (If SSL/TLS support  is  built
       using  NSS,  the  nss-config-dir  variable  must be set before a
       connection can be initiated,  see  above).   Use  ‘pop3s://’  or
       ‘pop3://’  if  the  server  does not offer IMAP.  You should use
       IMAP if you can, though; first because it requires fewer network
       operations  than  POP3 to get the contents of the mailbox and is
       thus  faster;  and  second  because   message   attributes   are
       maintained by the IMAP server, so you can easily distinguish new
       and old messages each time you connect.  Even if the server does
       not  accept  IMAPS  or POP3S connections, it is possible that it
       supports the STARTTLS method to make a session SSL/TLS encrypted
       after  the  initial  connection  has  been performed, but before
       authentication begins.  The only reliable method to see if  this
       works is to try it; enter one of

           set imap-use-starttls
           set pop3-use-starttls

       before you initiate the connection.

       As  you  probably  want messages to be deleted from this account
       after saving them, prefix it with ‘%:’.   The  shortcut  command
       can  be used to avoid typing that many characters every time you
       want to connect:

           shortcut myisp %:imaps://mylogin@server.myisp.example

       You might want to put this string into a startup file.   As  the
       shortcut command is specific to this implementation of mailx and
       will confuse other implementations, it should  not  be  used  in
       ~/.mailrc, instead, put

           set NAIL_EXTRA_RC=~/.nailrc

       in ~/.mailrc and create a file ~/.nailrc containing the shortcut
       command above.  You can  then  access  your  remote  mailbox  by
       invoking  ‘mailx  -f myisp’ on the command line, or by executing
       ‘fi myisp’ within mailx.

       If you want to use more than one IMAP mailbox on a server, or if
       you  want  to  use  the  IMAP  server  for mail storage too, the
       account  command  (which  is  also   mailx-specific)   is   more
       appropriate   than  the  shortcut  command.   You  can  put  the
       following in ~/.nailrc:

           account myisp {
               set folder=imaps://mylogin@server.myisp.example
               set record=+Sent MBOX=+mbox outfolder
           }

       and can then access incoming mail for this account  by  invoking
       ‘mailx -A myisp’ on the command line, or by executing ‘ac myisp’
       within mailx.  After that, a command like ‘copy 1  +otherfolder’
       will  refer  to  otherfolder on the IMAP server.  In particular,
       ‘fi &’ will change to the mbox folder, and ‘fi +Sent’ will  show
       your  recorded  sent mail, with both folders located on the IMAP
       server.

       Mailx will ask you for a password string each time  you  connect
       to  a  remote account.  If you can reasonably trust the security
       of your workstation, you can give this password in  the  startup
       file as

           set password-mylogin@server.myisp.example="SECRET"

       You  should  change  the  permissions  of this file to 0600, see
       chmod(1).

       Mailx supports different authentication methods  for  both  IMAP
       and  POP3.  If Kerberos is used at your location, you can try to
       activate GSSAPI-based authentication by

           set imap-auth=gssapi

       The advantage of this method is that mailx does not need to know
       your  password at all, nor needs to send sensitive data over the
       network.  Otherwise, the options

           set imap-auth=cram-md5
           set pop3-use-apop

       for IMAP and POP3, respectively,  offer  authentication  methods
       that  avoid to send the password in clear text over the network,
       which is especially important if SSL/TLS cannot be used.  If the
       server  does  not  offer  any  of  these authentication methods,
       conventional user/password based authentication  must  be  used.
       It   is  sometimes  helpful  to  set  the  verbose  option  when
       authentication problems occur.  Mailx will display all data sent
       to  the  server  in  clear  text on the screen with this option,
       including  passwords.   You  should  thus  take  care  that   no
       unauthorized  person  can look at your terminal when this option
       is set.

       If you  regularly  use  the  same  workstation  to  access  IMAP
       accounts,  you can greatly enhance performance by enabling local
       caching of IMAP messages.  For any message that has  been  fully
       or  partially  fetched from the server, a local copy is made and
       is used when the message is accessed  again,  so  most  data  is
       transferred  over  the  network  once  only.  To enable the IMAP
       cache, select a local directory name and put

           set imap-cache=~/localdirectory

       in the startup file.  All files within  that  directory  can  be
       overwritten  or  deleted by mailx at any time, so you should not
       use the directory to store other information.

       Once the cache  contains  some  messages,  it  is  not  strictly
       necessary  anymore  to  open  a connection to the IMAP server to
       access them.  When mailx is invoked with the -D option, or  when
       the  disconnected  variable is set, only cached data is used for
       any folder you open.  Messages that have not yet been completely
       cached  are  not  available  then, but all other messages can be
       handled  as  usual.   Changes  made   to   IMAP   mailboxes   in
       disconnected  mode are committed to the IMAP server next time it
       is used in online mode.  Synchronizing the local status with the
       status   on   the   server   is   thus   partially  within  your
       responsibility; if you forget to initiate a  connection  to  the
       server again before you leave your location, changes made on one
       workstation are not available on others.  Also if you alter IMAP
       mailboxes from a workstation while uncommitted changes are still
       pending on another, the latter data  may  become  invalid.   The
       same  might  also  happen  because  of  internal  server  status
       changes.  You should thus carefully  evaluate  this  feature  in
       your environment before you rely on it.

       Many  servers  will close the connection after a short period of
       inactivity. Use one of

           set pop3-keepalive=30
           set imap-keepalive=240

       to send a keepalive message each 30 seconds for POP3, or each  4
       minutes for IMAP.

       If  you  encounter  problems connecting to a SSL/TLS server, try
       the ssl-rand-egd and ssl-rand-file variables  (see  the  OpenSSL
       FAQ  for  more information) or specify the protocol version with
       ssl-method.  Contact your ISP if you need a  client  certificate
       or  if  verification  of  the  server certificate fails.  If the
       failed certificate is indeed valid, fetch its CA certificate  by
       executing the shell command

           $ openssl s_client </dev/null -showcerts -connect \
                  server.myisp.example:imaps 2>&1 | tee log

       (see  s_client(1))  and put it into the file specified with ssl-
       ca-file.  The data you  need  is  located  at  the  end  of  the
       certificate chain within (and including) the ‘BEGIN CERTIFICATE’
       and ‘END CERTIFICATE’ lines.  (Note that it is possible to fetch
       a  forged  certificate  by this method.  You can only completely
       rely on the authenticity of the CA certificate if you  fetch  it
       in  a  way that is trusted by other means, such as by personally
       receiving the certificate on storage media.)

   Creating a score file or message filter
       The scoring commands are best separated from other configuration
       for  clarity,  and  are  mostly  mailx  specific.   It  is  thus
       recommended to put them in a separate file that is sourced  from
       your NAIL_EXTRA_RC as follows:

           source ~/.scores

       The .scores file could then look as follows:

           define list {
               score (subject "important discussion") +10
               score (subject "annoying discussion") -10
               score (from "nicefellow@goodnet") +15
               score (from "badguy@poornet") -5
               move (header x-spam-flag "+++++") +junk
           }
           set folder-hook-imap://user@host/public.list=list

       In    this    scheme,    you    would    see   any   mail   from
       ‘nicefellow@goodnet’, even  if  the  surrounding  discussion  is
       annoying;   but   you   normally   would   not   see  mail  from
       ‘badguy@poornet’,  unless  he  participates  in  the   important
       discussion.   Messages  that  are  marked with five or more plus
       characters  in  their  ‘X-Spam-Flag’  field  (inserted  by  some
       server-side  filtering  software) are moved to the folder ‘junk’
       in the folder directory.

       Be aware that all criteria in () lead to substring  matches,  so
       you      would     also     score     messages     from     e.g.
       ‘notsobadguy@poornetmakers’ negative here.  It  is  possible  to
       select addresses exactly using "address" message specifications,
       but these cannot be executed remotely and will  thus  cause  all
       headers  to  be  downloaded  from IMAP servers while looking for
       matches.

       When searching messages on an IMAP server, best  performance  is
       usually  achieved by sending as many criteria as possible in one
       large () specification, because each single  such  specification
       will result in a separate network operation.

   Activating the Bayesian filter
       The  Bayesian  junk  mail  filter  works  by examining the words
       contained in messages.  You decide yourself what a good and what
       a  bad  message  is.   Thus  the  resulting  filter is your very
       personal one; once it is correctly set up, it will  filter  only
       messages similar to those previously specified by you.

       To  use  the  Bayesian  filter,  a  location  for  the junk mail
       database must be defined first:

           set junkdb=~/.junkdb

       The junk mail database does not contain actual  words  extracted
       from  messages,  but  hashed representations of them.  A foreign
       person  who  can  read  the  database  could  only  examine  the
       frequency of previously known words in your mail.

       If  you have sufficient disk space (several 10 MB) available, it
       is recommended that you set the chained-junk-tokens option.  The
       filter  will  then  also consider two-word tokens, improving its
       accuracy.

       A set of good messages and junk messages must now be  available;
       it  is  also  possible to use the incoming new messages for this
       purpose, although it will of course take  some  time  until  the
       filter  becomes useful then.  Do not underestimate the amount of
       statistical data needed; some  hundred  messages  are  typically
       necessary   to  get  satisfactory  results,  and  many  thousand
       messages for best operation.  You have to pass the good messages
       to  the good command, and the junk messages to the junk command.
       If you ever accidentally mark a good message as  junk  or  vice-
       versa, call the ungood or unjunk command to correct this.

       Once  a  reasonable amount of statistics has been collected, new
       messages can be classified automatically.  The classify  command
       marks  all messages that the filter considers to be junk, but it
       does  not  perform  any  action  on  them  by  default.   It  is
       recommended  that you move these messages into a separate folder
       just for the case that false positives occur, or to pass them to
       the  junk  command  later again to further improve the junk mail
       database.  To automatically move incoming  junk  messages  every
       time the inbox is opened, put lines like the following into your
       .scores file (or whatever name you gave to the file in the  last
       example):

           define junkfilter {
               classify (smaller 20000) :n
               move :j +junk
           }
           set folder-hook-imap://user@host/INBOX=junkfilter

       If  you  set  the  verbose  option  before  running the classify
       command, mailx prints the words it uses for calculating the junk
       status  along  with  their  statistical probabilities.  This can
       help you to find out why some messages are not classified as you
       would  like them to be.  To see the statistical probability of a
       given word, use the probability command.

       If a junk message was not  recognized  as  such,  use  the  junk
       command to correct this.  Also if you encounter a false positive
       (a good message that was wrongly classified as junk), pass it to
       the good command.

       Since  the  classify command must examine the entire text of all
       new messages in the respective folder, this will also cause  all
       of  them to be downloaded from the IMAP server.  You should thus
       restrict the size  of  messages  for  automatic  filtering.   If
       server-based  filtering is also available, you might try if that
       works for you first.

   Reading HTML mail
       You need either the w3m or lynx utility or another  command-line
       web browser that can write plain text to standard output.

           set pipe-text/html="w3m -dump -T text/html"

       or

           set pipe-text/html="lynx -dump -force_html /dev/stdin"

       will  then  cause HTML message parts to be converted into a more
       friendly form.

   Viewing PDF attachments
       Most PDF viewers do not accept input directly from a  pipe.   It
       is  thus  necessary to store the attachment in a temporary file,
       as with

           set pipe-application/pdf="cat >/tmp/mailx$$.pdf; \
                  acroread /tmp/mailx$$.pdf; rm /tmp/mailx$$.pdf"

       Note that security defects are discovered in  PDF  viewers  from
       time  to  time.   Automatical  command  execution  like this can
       compromise your system security, in particular if you  stay  not
       always informed about such issues.

   Signed and encrypted messages with S/MIME
       S/MIME  provides  two  central  mechanisms:  message signing and
       message encryption.  A signed  message  contains  some  data  in
       addition  to  the  regular text.  The data can be used to verify
       that the message was sent using a valid  certificate,  that  the
       sender’s  address  in  the  message  header  matches that in the
       certificate, and that the message text  has  not  been  altered.
       Signing  a  message  does not change its regular text; it can be
       read regardless of whether the recipient’s software is  able  to
       handle S/MIME.  It is thus usually possible to sign all outgoing
       messages if  so  desired.—Encryption,  in  contrast,  makes  the
       message  text  invisible  for  all  people except those who have
       access to the secret decryption key.  To encrypt a message,  the
       specific recipient’s public encryption key must be known.  It is
       thus not possible to send encrypted mail to people unless  their
       key  has  been  retrieved  from either previous communication or
       public key directories.   A  message  should  always  be  signed
       before  it  is  encrypted.  Otherwise, it is still possible that
       the encrypted message text is altered.

       A central  concept  to  S/MIME  is  that  of  the  certification
       authority  (CA).   A  CA  is  a  trusted institution that issues
       certificates.   For  each  of  these  certificates,  it  can  be
       verified  that  it  really originates from the CA, provided that
       the CA’s own certificate is  previously  known.   A  set  of  CA
       certificates  is usually delivered with OpenSSL and installed on
       your system.  If you trust the source of your  OpenSSL  software
       installation,  this offers reasonable security for S/MIME on the
       Internet.  In general, a certificate cannot be more secure  than
       the  method  its CA certificate has been retrieved with, though.
       Thus if you download a CA certificate from the Internet, you can
       only  trust  the  messages  you verify using that certificate as
       much as you trust the download process.

       The first thing you need for  participating  in  S/MIME  message
       exchange  is your personal certificate, including a private key.
       The certificate contains public information, in particular  your
       name  and your email address, and the public key that is used by
       others to  encrypt  messages  for  you,  and  to  verify  signed
       messages  they supposedly received from you.  The certificate is
       included in each signed message you send.  The private key  must
       be  kept  secret.   It  is  used  to  decrypt messages that were
       previously encrypted with your public key, and to sign messages.

       For  personal  use,  it  is  recommended  that  you get a S/MIME
       certificate from one of the major CAs on the Internet using your
       WWW  browser.  (Many CAs offer such certificates for free.)  You
       will usually receive a combined certificate and private  key  in
       PKCS#12  format  which  mailx does not directly accept if S/MIME
       support is built using OpenSSL.  To convert it  to  PEM  format,
       use the following shell command:

           $ openssl pkcs12 -in cert.p12 -out cert.pem -clcerts \
               -nodes

       If you omit the -nodes parameter, you can specifiy an additional
       PEM pass phrase for protecting the private key.  Mailx will then
       ask  you  for  that pass phrase each time it signs or decrypts a
       message.  You can then use

           set smime-sign-cert-myname@myisp.example=cert.pem

       to make this private key and certificate known to mailx.

       If S/MIME support is built using NSS, the PKCS#12 file  must  be
       installed  using  Mozilla  (provided  that nss-config-dir is set
       appropriately, see above), and no further  action  is  necessary
       unless multiple user certificates for the same email address are
       installed.  In this case, the smime-sign-nickname  variable  has
       to be set appropriately.

       You can now sign outgoing messages.  Just use

           set smime-sign

       to do so.

       From  each signed message you send, the recipient can fetch your
       certificate and use it to  send  encrypted  mail  back  to  you.
       Accordingly  if  somebody sends you a signed message, you can do
       the same.  First use the verify command to check the validity of
       the  certificate.  After that, retrieve the certificate and tell
       mailx that it should use it for encryption:

           certsave filename
           set smime-encrypt-user@host=filename

       If S/MIME support is built using NSS, the saved certificate must
       be  installed  using  Mozilla.   The value of the smime-encrypt-
       user@host is ignored then, but if multiple certificates for  the
       recipient  are  available, the smime-nickname-user@host variable
       must be set.

       You should carefully consider if you prefer to  store  encrypted
       messages  in  decrypted form.  If you do, anybody who has access
       to your mail folders can read them, but if you do not, you might
       be unable to read them yourself later if you happen to lose your
       private key.  The decrypt command saves  messages  in  decrypted
       form,  while  the  save,  copy,  and  move  commands  leave them
       encrypted.

       Note that neither  S/MIME  signing  nor  encryption  applies  to
       message  subjects  or  other  header  fields.  Thus they may not
       contain sensitive information for encrypted messages, and cannot
       be  trusted even if the message content has been verified.  When
       sending  signed  messages,  it  is  recommended  to  repeat  any
       important header information in the message text.

   Using CRLs with S/MIME or SSL/TLS
       Certification  authorities  (CAs)  issue  certificate revocation
       lists (CRLs) on a regular basis.  These lists contain the serial
       numbers  of  certificates  that have been declared invalid after
       they have been issued.  Such usually happens because the private
       key  for the certificate has been compromised, because the owner
       of the certificate has left the organization that  is  mentioned
       in  the  certificate,  etc.   To seriously use S/MIME or SSL/TLS
       verification, an up-to-date CRL is required for each trusted CA.
       There  is  otherwise  no method to distinguish between valid and
       invalidated certificates.  Mailx currently offers  no  mechanism
       to fetch CRLs, or to access them on the Internet, so you have to
       retrieve them by some external mechanism.

       If S/MIME and SSL/TLS support are  built  using  OpenSSL,  mailx
       accepts  CRLs  in  PEM  format  only; CRLs in DER format must be
       converted, e.g. with the shell command

           $ openssl crl -inform DER -in crl.der -out crl.pem

       To tell mailx about the CRLs, a directory that contains all  CRL
       files  (and  no other files) must be created.  The smime-crl-dir
       or ssl-crl-dir variables, respectively,  must  then  be  set  to
       point to that directory.  After that, mailx requires a CRL to be
       present for each CA that is used to verify a certificate.

       If S/MIME and SSL/TLS support are built using NSS, CRLs  can  be
       imported  in  Mozilla applications (provided that nss-config-dir
       is set appropriately).

   Sending mail from scripts
       If you want to send mail from scripts, you must  be  aware  that
       mailx  reads  the  user’s  configuration  files  by default.  So
       unless your script is only intended for your  own  personal  use
       (as  e.g.  a  cron job), you need to circumvent this by invoking
       mailx like

           MAILRC=/dev/null mailx -n

       You then need to create  a  configuration  for  mailx  for  your
       script.  This can be done by either pointing the MAILRC variable
       to a custom configuration file, or by passing the  configuration
       in  environment  variables.   Since  many  of  the configuration
       options are not valid shell variables, the env command is useful
       in this situation.  An invocation could thus look like

           env MAILRC=/dev/null from=scriptreply@domain smtp=host \
                 smtp-auth-user=login smtp-auth-password=secret \
                 smtp-auth=login mailx -n -s "subject" \
                 -a attachment_file recipient@domain <content_file

SEE ALSO

       fmt(1),  newaliases(1), openssl(1), pg(1), more(1), vacation(1),
       ssl(3), aliases(5), locale(7), mailaddr(7), sendmail(8)

NOTES

       Variables in the environment passed to mailx cannot be unset.

       The character set conversion relies on  the  iconv(3)  function.
       Its  functionality  differs  widely  between  the various system
       environments mailx runs on.  If the message ‘Cannot convert from
       a  to  b’  appears,  either  some  characters within the message
       header or text are not appropriate for  the  currently  selected
       terminal   character  set,  or  the  needed  conversion  is  not
       supported by the system.  In the first case, it is necessary  to
       set   an   appropriate  LC_CTYPE  locale  (e.g.  en_US)  or  the
       ttycharset variable.  In the second case, the  sendcharsets  and
       ttycharset  variables  must  be set to the same value to inhibit
       character set conversion.  If iconv() is not available  at  all,
       the  value assigned to sendcharsets must match the character set
       that is used on the terminal.

       Mailx expects input text  to  be  in  Unix  format,  with  lines
       separated  by  newline  (^J, \n) characters only.  Non-Unix text
       files that use carriage return (^M, \r) characters  in  addition
       will  be  treated  as  binary  data; to send such files as text,
       strip these characters e. g. by

              tr -d ’\015’ <input | mailx . . .

       or fix the tools that generate them.

       Limitations with IMAP mailboxes are: It is not possible to  edit
       messages,  but  it  is  possible to append them.  Thus to edit a
       message, create a local copy of it,  edit  it,  append  it,  and
       delete  the  original.  The line count for the header display is
       only appropriate if the entire message has been downloaded  from
       the  server.   The  marking of messages as ‘new’ is performed by
       the IMAP server; use of the exit command instead  of  quit  will
       not  cause  it to be reset, and if the autoinc/newmail variables
       are unset, messages that arrived during a session will not be in
       state  ‘new’  anymore  when the folder is opened again.  Also if
       commands queued in disconnected mode  are  committed,  the  IMAP
       server  will  delete  the  ‘new’  flag  for  all messages in the
       changed folder, and new messages will appear as unread  when  it
       is  selected  for viewing later.  The ‘flagged’, ‘answered’, and
       ‘draft’ attributes are usually permanent, but some IMAP  servers
       are  known  to  drop them without notification.  Message numbers
       may change with IMAP every time before the prompt is printed  if
       mailx  is notified by the server that messages have been deleted
       by some other client or process.   In  this  case,  ‘Expunged  n
       messages’ is printed, and message numbers may have changed.

       Limitations  with POP3 mailboxes are: It is not possible to edit
       messages, they can only be copied and deleted.  The  line  count
       for the header display is only appropriate if the entire message
       has been downloaded from the server.   The  status  field  of  a
       message  is  maintained  by the server between connections; some
       servers do not update it at all, and with a  server  that  does,
       the  ‘exit’  command  will  not  cause  the message status to be
       reset.  The ‘newmail’ command and the ‘newmail’ variable have no
       effect.   It  is  not  possible  to  rename  or  to  remove POP3
       mailboxes.

       If a RUBOUT (interrupt) is typed while an IMAP or POP3 operation
       is  in  progress,  mailx  will  wait  until the operation can be
       safely aborted, and will then return to  the  command  loop  and
       print  the  prompt  again.   When a second RUBOUT is typed while
       mailx is waiting for the operation to  complete,  the  operation
       itself  will  be canceled.  In this case, data that has not been
       fetched yet will have to be fetched before the next command  can
       be  performed.   If  the canceled operation was using an SSL/TLS
       encrypted channel, an error  in  the  SSL  transport  will  very
       likely result, and the connection is no longer usable.

       As  mailx  is  a  mail  user  agent, it provides only basic SMTP
       services.  If it fails to contact its upstream SMTP  server,  it
       will  not  make  further  attempts  to transfer the message at a
       later time, and it does not leave other information  about  this
       condition   than   an  error  message  on  the  terminal  and  a
       ‘dead.letter’ file.  This is usually not a problem if  the  SMTP
       server  is  located in the same local network as the computer on
       which mailx is run.  However, care should be taken when using  a
       remote  server  of  an ISP; it might be better to set up a local
       SMTP server then which just acts as a proxy.

       Mailx    immediately    contacts    the    SMTP    server    (or
       /usr/lib/sendmail) even when operating in disconnected mode.  It
       would not make much sense for mailx to defer outgoing mail since
       SMTP servers usually provide much more elaborated delay handling
       than mailx could perform as  a  client.   Thus  the  recommended
       setup  for  sending  mail in disconnected mode is to configure a
       local SMTP server such that it sends outgoing mail as soon as an
       external  network  connection is available again, i.e. to advise
       it to do that from a network startup script.

       The junk mail filter follows  the  concepts  developed  by  Paul
       Graham  in  his  articles,  ‘‘A  Plan  for  Spam’’, August 2002,
       <http://www.paulgraham.com/spam.html>,  and  ‘‘Better   Bayesian
       Filtering’’,                    January                    2003,
       <http://www.paulgraham.com/better.html>.  Chained tokens are due
       to  a  paper  by  Jonathan  A.  Zdziarski,  ‘‘Advanced  Language
       Classification   using   Chained   Tokens’’,   February    2004,
       <http://www.nuclearelephant.com/papers/chained.html>.

       A  mail  command appeared in Version 1 AT&T Unix.  Berkeley Mail
       was written in 1978 by Kurt Shoens.  This man  page  is  derived
       from  from  The Mail Reference Manual originally written by Kurt
       Shoens.   Heirloom  Mailx  enhancements   are   maintained   and
       documented by Gunnar Ritter.

       Portions of this text are reprinted and reproduced in electronic
       form  from  IEEE  Std  1003.1,  2003   Edition,   Standard   for
       Information Technology — Operating System Interface (POSIX), The
       Open Group Base Specifications Issue 6, Copyright © 2001-2003 by
       the  Institute  of Electrical and Electronics Engineers, Inc and
       The Open Group. In the event of  any  discrepancy  between  this
       version  and  the original IEEE and The Open Group Standard, the
       original IEEE  and  The  Open  Group  Standard  is  the  referee
       document.  The  original  Standard  can  be  obtained  online at
       http://www.opengroup.org/unix/online.html .   Redistribution  of
       this  material  is  permitted  so  long  as  this notice remains
       intact.