EbcdicToAscii (String function): Difference between revisions
| m 1 revision | m first pass, match syntax diagram to template and fix tags; still some broken links | ||
| Line 1: | Line 1: | ||
| {{Template:String:EbcdicToAscii subtitle}} | {{Template:String:EbcdicToAscii subtitle}} | ||
| <var>EbcdicToAscii</var> is an <var>[[Intrinsic classes|intrinsic]]</var> function that converts an EBCDIC string to ASCII (ISO 8859-1) using the current <var>[[Unicode]]</var> tables.  Optionally, character references, entity references, and <code>'&'</code> references are converted to the represented ASCII character. | |||
| using the current <var>Unicode</var> tables. | |||
| Optionally, character references, entity references, and  | |||
| ==Syntax== | ==Syntax== | ||
| {{Template:String:EbcdicToAscii syntax}} | {{Template:String:EbcdicToAscii syntax}} | ||
| ===Syntax terms=== | ===Syntax terms=== | ||
| <table class="syntaxTable"> | <table class="syntaxTable"> | ||
| <tr><th>% | <tr><th>%string</th> | ||
| <td>A string variable to receive the method object string translated to Ascii. </td></tr> | <td>A string variable to receive the method object <var class="term">string</var> translated to Ascii.</td></tr> | ||
| <tr><th>string</th> | <tr><th><var class="term">string</var></th> | ||
| <td>An EBCDIC character string.  | <td>An EBCDIC character string.</td></tr> | ||
| <tr><th>CharacterDecode | <tr><th><var class="term">CharacterDecode</var></th> | ||
| <td>The optional (name required) CharacterDecode argument is a Boolean:  | <td>The optional (name required) <var class="term">CharacterDecode</var> argument is a [[Boolean enumeration]]: | ||
| <ul><li>If its value is <code>True</code>, an ampersand (<code>&</code>) in the input EBCDIC string is allowed <b><i>only</i></b> as the beginning of one of these types of character or entity reference:<ul><li>The substring ''''&amp;''''. This substring is converted to a single ''''&'''' character.<li>A hexadecimal character reference (for example, the six characters <code>'&#x90;'</code> for the ASCII <i>Device Control String</i> character (X'90')). The character reference is converted to the referenced character.<li>As of <var class=product>Sirius Mods</var> version 7.6, an XHTML entity reference (for example, the six characters <code>'&copy;'</code> for the <i>copyright</i> character). The entity reference is converted to the referenced character. A decimal character reference (for example, &#172;) is <b><i>not</i></b> allowed.</ul><li>If its value is <code>False</code>, the default, an ampersand is treated only as a normal character.</ul></td></tr> | |||
| </table> | </table> | ||
| ===Exceptions=== | ===Exceptions=== | ||
| <var>EbcdicToAscii</var> can throw the following exception: | |||
| <dl> | <dl> | ||
| <dt>[[CharacterTranslationException]] | <dt><var>[[CharacterTranslationException class|CharacterTranslationException]]</var> | ||
| <dd>If the method encounters a translation problem, | <dd>If the method encounters a translation problem, properties of the exception object may indicate the location and type of problem. | ||
| properties of the exception object may indicate the location and type of problem. | |||
| </dl> | </dl> | ||
| ==Usage notes== | ==Usage notes== | ||
| <ul> | |||
| < | <li><var>EbcdicToAscii</var> is available as of <var class="product">Sirius Mods</var> version 7.3. | ||
| </ | </ul> | ||
| ==Examples== | ==Examples== | ||
| The following fragment shows calls of <var>EbcdicToAscii</var> against a variety of EBCDIC characters. | <ol><li>The following fragment shows calls of <var>EbcdicToAscii</var> against a variety of EBCDIC characters. | ||
| The [[X (String function)|X]] constant function is used in the example. | The [[X (String function)|X]] constant function is used in the example. | ||
| <p class="code">%e  | <p class="code">%e string Len 20 | ||
| %a  | %a string Len 20 | ||
| %e = '12' | %e = '12' | ||
| %a = %e: | %a = %e:EbcdicToAscii | ||
| Print %a: | Print %a:StringToHex | ||
| %e = '1&#x0A;2' | %e = '1&#x0A;2' | ||
| %a = %e: | %a = %e:EbcdicToAscii(CharacterDecode=True) | ||
| Print %a: | Print %a:StringToHex | ||
| %e = '&copy;' | %e = '&copy;' | ||
| %a = %e: | %a = %e:EbcdicToAscii(CharacterDecode=True) | ||
| Print %a: | Print %a:StringToHex | ||
| %e = 'F1FFF2':X | %e = 'F1FFF2':X | ||
| %a = %e: | %a = %e:EbcdicToAscii | ||
| </p> | </p> | ||
| Line 57: | Line 53: | ||
| 310A32 | 310A32 | ||
| A9 | A9 | ||
| CANCELLING REQUEST: MSIR.0751: Class STRING, function | CANCELLING REQUEST: MSIR.0751: Class STRING, function EBCDICTOASCII:  | ||
|    CHARACTER TRANSLATIONEXCEPTION exception: EBCDIC character X'FF' | |||
|   without valid translation to ASCII at byte position 2 ... | |||
| </p> | |||
| </ol> | |||
| ==See also== | |||
| <ul><li>You can find the list of XHTML entities on the Internet at the following URL: | |||
| <p class="code">http://www.w3.org/TR/xhtml1/dtds.html#h-A2 | |||
| </p> | </p> | ||
| <li>There is more information about the [[Unicode tables]]. | |||
| <li>The inverse of the <var>EbcdicToAscii</var> method is [[AsciiToEbcdic (String function)|AsciiToEbcdic]]. | |||
| </ul> | |||
| {{Template:String:EbcdicToAscii footer}} | {{Template:String:EbcdicToAscii footer}} | ||
Revision as of 05:09, 31 January 2011
Convert EBCDIC string to ASCII (String class)
EbcdicToAscii is an intrinsic function that converts an EBCDIC string to ASCII (ISO 8859-1) using the current Unicode tables.  Optionally, character references, entity references, and '&' references are converted to the represented ASCII character.
Syntax
%outString = string:EbcdicToAscii[( [CharacterDecode= boolean])] Throws CharacterTranslationException
Syntax terms
| %string | A string variable to receive the method object string translated to Ascii. | 
|---|---|
| string | An EBCDIC character string. | 
| CharacterDecode | The optional (name required) CharacterDecode argument is a Boolean enumeration: 
 | 
Exceptions
EbcdicToAscii can throw the following exception:
- CharacterTranslationException
- If the method encounters a translation problem, properties of the exception object may indicate the location and type of problem.
Usage notes
- EbcdicToAscii is available as of Sirius Mods version 7.3.
Examples
- The following fragment shows calls of EbcdicToAscii against a variety of EBCDIC characters.
The X constant function is used in the example.
%e string Len 20 %a string Len 20 %e = '12' %a = %e:EbcdicToAscii Print %a:StringToHex %e = '1
2' %a = %e:EbcdicToAscii(CharacterDecode=True) Print %a:StringToHex %e = '©' %a = %e:EbcdicToAscii(CharacterDecode=True) Print %a:StringToHex %e = 'F1FFF2':X %a = %e:EbcdicToAscii The result is: 3132 310A32 A9 CANCELLING REQUEST: MSIR.0751: Class STRING, function EBCDICTOASCII: CHARACTER TRANSLATIONEXCEPTION exception: EBCDIC character X'FF' without valid translation to ASCII at byte position 2 ... 
See also
- You can find the list of XHTML entities on the Internet at the following URL:
- There is more information about the Unicode tables.
- The inverse of the EbcdicToAscii method is AsciiToEbcdic.