Documentation Comments
Use this form to comment on this topic. You can also provide any general observations about the Online Documentation, or request that additional information be added in a future release.
Reality V15.2 Online Documentation (MoTW) Revision 3
ML and MR Codes - Mask Decimal with Alignment (English) (m618307+ml_mr.htm)
The ML and MR codes format numbers. ML aligns the result to the left; MR, to the right. The codes provide the following capabilities:
Decimal precision and scaling
Zero suppress
Thousands separator
Credit codes
Currency symbol
Inclusion of literal character strings
Input conversion carries out a correct inversion with a number that has only thousands separators and a decimal point.
[ML||MR]{precision{scaling}}{Z}{,}{creditIndicator}{$}{formatMask}
ML Specifies left alignment.
MR Specifies right alignment.
precision Defines the decimal precision.
scaling Defines scaling and rounding.
, Use thousands separators.
creditIndicator Use the credit indicator.
$ Use the currency symbol.
formatMask A format mask.
The processor applies the alignment specified by the ML or MR code at a different stage from that specified by attribute 9 of the data definition item. First, the processor formats the data with symbols and filler characters and with left or right alignment as specified by the ML or MR code. Then it places this formatted data in an output field of blank spaces whose length is specified by the contents of attribute 10 of the definition item and whose alignment is specified by attribute 9 of that item.
In addition to having its own flexible literal specification, English handles literals enclosed in parentheses, as specified by the SMA standard. Therefore, if a site converts from another system to a Reality system, existing ML and MR codes need not be changed.
The ML and MR codes allow you to specify the decimal precision of a number's output format. You can specify up to nine places.
The ML and MR codes also allow you to specify the scaling of a number. The scale factor follows the decimal precision in the parameters.
precision Defines the decimal precision. The number precision (0-9) specifies the number of digits to be output following the decimal point. The processor inserts trailing zeros or rounds if necessary (see the DataBasic ROUND function for details). If precision is omitted or 0 is specified, the processor does not output a decimal point.
You can change the decimal point symbol by executing the SET-DEC command.
scaling Defines scaling. The value is descaled (divided) by that power of 10. For example, if scaling = 2, the value is divided by 100; if scaling = 3, the value is divided by 1000, and so on.
If scaling is omitted, precision is used as the scaling factor.
The precision and scaling parameters can only be applied to numbers. Numeric data is defined as containing:
If the data contains any other characters, the precision and scaling parameters are ignored.
Notes
In addition to any formatting specified, the following conversions are applied to numeric data:
Leading zeros (ignoring any sign character) are removed unless immediately preceding the decimal point. For example:
"0034.56" → "34.56"
"00.56" → "0.56"
"-00087" → "-87"
If the string contains a decimal point followed by one or more digits, but there are no digits before the decimal point, a zero character is inserted before the decimal point. For example:
"+.5" → "+0.5"
If there is a trailing decimal point, it is removed. For example:
"+5." → "+5"
If the only numeric characters are zeros, any leading + or - sign is removed. For example:
"-0.0" → "0.0"
The following examples illustrate the effect of the decimal precision and scaling parameters. All the examples use the ML code. The MR code would produce the same formatted data but right aligned.
| Code | Stored Value | Formatted Data | 
|---|---|---|
| ML | 123456789 | 123456789 | 
| ML2 | 123456789 | 1234567.89 | 
| ML24 | 123456789 | 12345.68 | 
| ML05 | 123456789 | 1235 | 
| ML26 | 123456789 | 123.46 | 
If you had invoked the SET-DEC command to specify the comma as the decimal point symbol, the output in the last example would be:
123,46
The ML and MR codes allow you to suppress leading zeros of the displayed data. However, the processor always outputs a zero if that would be the only digit to precede the decimal point.
Z indicates suppress leading zeros. However, the output always includes a zero preceding the decimal point for values between 1 and -1.
The following examples illustrate zero suppression.
| Code | Stored Value | Formatted Data | 
|---|---|---|
| MRZ | 0000 | |
| ML2Z | 0001 | 0.01 | 
| MR2Z | 0123 | 1.23 | 
The ML and MR codes allow you to include a thousands separator in the output. The syntax uses a comma to specify this feature, but you can use the SET-THOUS command to specify another symbol to be used in the display.
, is the thousands separator symbol. It specifies insertion of thousands separators every three digits to the left of the decimal point.
You can change the display separator symbol by executing the SET-THOUS command.
The following examples illustrate specifying thousands separator.
| Code | Stored Value | Formatted Data | 
|---|---|---|
| ML | 123456789 | 123456789 | 
| ML, | 123456789 | 123,456,789 | 
| MR, | 123456789 | 123,456,789 | 
If you had previously invoked the SET-THOUS command to specify the period as the thousands separator symbol, the output of the last example would be:
123.456.789
The ML and MR codes allow you to specify a credit indicator to be included in the display. If you specify a credit indicator, the processor outputs either the credit characters or blank spaces depending on the value of the data.
creditIndicator is the credit indicator. It appends or encloses the value with appropriate credit characters:
COutput the literal CR  after negative values.
DOutput the literal DB  after positive values.
EEnclose negative values in angle brackets <>.
MOutput negative values with a trailing minus sign.
NSuppress minus sign for negative values.
If a value is negative and you have not specified one of these indicators, the processor displays the value with a leading minus sign.
These examples illustrate the use of various indicators for displaying negative numbers. The examples all use the MR code, but the ML code produces the same formatted data.
| Code | Stored Value | Formatted Data | 
|---|---|---|
| MR | 12345678 | 12345678 | 
| MR | -12345678 | -12345678 | 
| MRC | 12345678 | 12345678 | 
| MRC | -12345678 | 12345678CR | 
| MRD | 12345678 | 12345678DB | 
| MRD | -12345678 | 12345678 | 
| MRE | 12345678 | 12345678 | 
| MRE | -12345678 | <123454678> | 
| MRM | 12345678 | 12345678 | 
| MRM | -12345678 | 12345678- | 
| MRN | 12345678 | 12345678 | 
| MRN | -12345678 | 12345678 | 
The ML and MR codes allow you to specify a currency symbol in the display. The syntax uses the dollar sign ($) to specify this feature, but you can specify another display symbol by using the SET-MONEY command.
$ indicates that a currency symbol is to be included. The processor adds a floating currency symbol in front of the value.
You can change the display currency symbol by executing the SET-MONEY command.
These examples illustrate how to specify that a currency symbol be included in the display.
| Code | Stored Value | Formatted Data | 
|---|---|---|
| MR$ | 12345678 | $12345678 | 
| ML$ | -12345678 | $-12345678 | 
If you had invoked the SET-MONEY command to specify D as the currency symbol, the last example would be:
D-12345678
The ML and MR codes allow you to specify a format mask.
formatMask is a format mask with the following format:
{&char}{(}mask{)}
where:
&charSpecifies a fill character to be used instead of blanks, asterisks or zeros. char can be any literal character.
maskThe required format. This can be any combination of literal and fill characters. The formatted value overwrites the fill characters as necessary.
#{count} Blank.
*{count} Asterisk.
%{count} Zero.
Where count specifies the number of fill characters (default, 1).
Notes
If there is no opening parenthesis, a trailing close parenthesis is treated as part of the mask.
The easiest way to understand how the processor handles literals and format codes is by example. Say that we have four different data definitions, all pointing at the same data value:
123456
Parts of data definition items:
| LL | RR | 
| 008: ML2,$&*BAL*10 009: L 010: 15 | 008: MR2,$&*BAL*10 009: R 010: 15 | 
| LR | RL | 
| 008: ML2,$&*BAL*10 009: R 010: 15 | 008: MR2,$&*BAL*10 009: L 010: 15 | 
All four definitions are alike except that:
When the processor handles an ML or MR code, it formats the data using all the parameters specified before the start of the format mask.
The processor would format the data the same way for all these attributes. Each would produce this formatted data:
$1,234.56
The processor then formats the literal and the filler fields, and each of these attributes would produce the following formatted literal field:
BAL**********
The processor then moves the formatted data into the filler field of the formatted literal. The ML code processor moves from the left end of the data to the left end of the filler field; the MR code processor moves from the right to the right. The results are:
| Attributes LL and LR | Attributes RR and RL | 
| BAL$1,234.56* | BAL*$1,234.56 | 
The processor then moves each filled-in, formatted literal to the display field, aligning it left or right depending on whether there is an L or an R on line 9 of the data definition item. The results for these attributes would be:
| Attribute LL | Attribute LR | Attribute RR | Attribute RL | 
| BAL$1,23456* | BAL$1,23456* | BAL*$1,23456 | BAL*$1,23456 | 
In the following examples fields are created so that the values are aligned.
| Code | Stored Value | Alignment | Output Field (Column Width = 15) | 
|---|---|---|---|
| 123456789012345 | |||
| MR2#10 | 1234 | L |      12.34 | 
| MR2#10 | 1234 | R |           12.34 | 
| ML2%10 | 1234 | L | 12.3400000 | 
| MR2%10 | 1234 | R |      0000012.34 | 
| ML2*10 | 1234 | L | 12.34***** | 
| ML2*10 | 1234 | R |      12.34***** | 
Note that the result in each example is effectively done in two steps:
The following examples illustrate the alignment of the currency symbol through the use of the &x format option:
| Code | Stored Value | Output Field (Left-aligned; Column Width = 20) | 
|---|---|---|
| 12345678901234567890 | ||
| MR2,$#15 | 12345678 |     $123,456.78 | 
| MR2,&$#15 | 12345678 | $$$$$123,456.78 | 
| ML2,$*15 | 12345678 | $123,456.78***** | 
| MR2,$#15 | 12345678 | $     123,456.78 | 
| MR2,C$*15 | -12345678 | $***123,456.78CR | 
Note that the character immediately following the ampersand (&) fills the columns without data as specified by #n.
The following examples illustrate the use of left zero fill for a three character numeric field.
| Code | Stored Value | Output | 
|---|---|---|
| MR%3 | 1 | 001 | 
| MR%3 | 10 | 010 | 
| MR%3 | 100 | 100 | 
The following examples illustrate the use of literals. Note that fields of blanks interspersed with literal characters are specified. The stored value is inserted into the blank fields.
| Code | Stored Value | Output | 
|---|---|---|
| ML###-##-#### | 123456789 | 123-45-6789 | 
| ML#3-#2-#4 | 123456789 | 123-45-6789 | 
The last examples illustrate the insertion of literal phrases for output:
| Code | Stored Value | Output | 
|---|---|---|
| MLSocial Security No. #3-#2-#4 | 123456789 | Social Security No. 123-45-6789 | 
| MLTEL: (#3) #3-#4 Ext: #2 | 123456789012 | TEL: (123) 456-7890 Ext: 12 | 
| ML((#3) #3-#4 Ext: #2 | 123456789012 | (123) 456-7890 Ext: 12 | 
Note that in the last example double opening parentheses are used. The system ignores a single opening parenthesis immediately following the ML in order to accommodate the ML and MR syntax that may be transferred from other MultiValue systems.