Processing the Command Line

The sendmail program's ability to perform different tasks necessitates that the command line be processed in steps.

First: Prescanning the Command Line

When sendmail begins to run, it performs a preliminary scan of its command-line arguments. It does this because some actions need to be performed before its configuration file is read. The -d command-line switch is processed during the pre-scanning phase.

Second: Processing Prior to the Switches

After the command-line switches are prescanned, but before they are processed in full, sendmail performs two important internal tasks.

Initialize the environment

The environmental variables that are given to sendmail when it is first run are ignored. When running delivery agents, sendmail provides a small, customized environment. See "The Environment" for a detailed discussion of this step.

Initialize macros

Certain macros are next declared and assigned values. The $w macro (see $w), $j macro (see $v), and the $=w class macro (see $=w) are given values that identify the current host. The $m macro (see $m) is given a value that is the local domain name. The $k macro (see $k) and the $=k class (see $=k) are also given values at this time. The $v macro (see ) is assigned a value that is the current version of the sendmail program. The $b macro (see $b) is given the current date and time as its value.

Third: Process Switches

Command-line switches are processed by sendmail as they appear in the command line, from left to right. The processing of switches ends when an argument is found that lacks a leading - character or when a -- argument is found.

Fourth: Read the Configuration File

The fact that the configuration file is read after the command-line switches are processed can lead to some confusion. Some, but not all, command-line switches can overwrite some configuration file commands. Since there is no general rule, we describe the behavior of each item (such as macros and options) in a chapter dedicated to each.

Fifth: Collect Recipients

The final step sendmail undertakes in processing its command line is gathering the list of recipients. Each recipient (or list of recipients if more than one is contained in a single command-line argument) is fully processed for delivery, and any error messages are printed before delivery is actually undertaken.

If sendmail is running in a mode that doesn't require recipients, any list of recipients in the command line is silently ignored.