GET_CP_CONVERT_TABLE
The GET_CP_CONVERT_TABLE verb creates and returns a 256-byte conversion table to translate character strings from a source code page to a target code page.
The following structure describes the verb control block used by the GET_CP_CONVERT_TABLE verb.
struct get_cp_convert_table {
unsigned short opcode;
unsigned char opext;
unsigned char reserv2;
unsigned short primary_rc;
unsigned long secondary_rc;
unsigned char reserv3[8];
unsigned short source_cp;
unsigned short target_cp;
unsigned char FAR * conv_tbl_addr;
unsigned char char_not_fnd;
unsigned char substitute_char;
};
Members
-
opcode
-
Supplied parameter. The verb identifying the operation code, SV_GET_CP_CONVERT_TABLE.
-
opext
-
A reserved field.
-
reserv2
-
A reserved field.
-
primary_rc
-
Returned parameter. Specifies the primary return code set by APPC at the completion of the verb. The valid return codes vary depending on the APPC verb issued. See Return Codes for valid error codes for this verb.
-
secondary_rc
-
Returned parameter. Specifies the secondary return code set by APPC at the completion of the verb. The valid return codes vary depending on the APPC verb issued. See Return Codes for valid error codes for this verb.
-
reserv3
-
A reserved field.
-
source_cp
-
Supplied parameter. Specifies the source code page from which characters are converted. The allowed code pages (decimal values) are as follows:
-
ASCII 437, 850, 860, 863, 865
-
EBCDIC 037, 273, 277, 278, 280, 284, 285, 297, 500
User-defined code pages in the range from 65280 through 65535 are also allowed.
ASCII code pages are sometimes referred to as PC code pages; EBCDIC code pages are sometimes referred to as host code pages.
-
target_cp
-
Supplied parameter. Specifies the target code page to which characters are converted. For allowed code pages, see the preceding definition for source_cp.
-
conv_tbl_addr
-
Supplied parameter. Specifies the address of the buffer to contain the 256-byte conversion table. The buffer must be in a writable segment and long enough to contain the table.
-
char_not_fnd
-
Supplied parameter. Specifies the action to take if a character in the source code page does not exist in the target code page:
-
Use SV_ROUND_TRIP to store a unique value in the conversion table for each source code page character.
-
Use SV_SUBSTITUTE to store a substitute character (specified by substitute_char) in the conversion table.
-
substitute_char
-
Supplied parameter. Specifies the character to store in the conversion table when a character from the source code page has no equivalent in the target code page.
Return Codes
-
sv_ok
-
Primary return code; the verb executed successfully.
-
sv_parameter_check
-
Primary return code; the verb did not execute because of a parameter error.
-
sv_invalid_char_not_found
-
Secondary return code; the char_not_fnd parameter contained an invalid value.
-
sv_invalid_data_segment
-
Secondary return code; the 256-byte area specified for the conversion table extended beyond the segment boundary, or the segment was not writable.
-
sv_invalid_source_code_page
-
Secondary return code; the code page specified by source_cp is not supported.
-
sv_invalid_target_code_page
-
Secondary return code; the code page specified by target_cp is not supported.
-
sv_comm_subsystem_not_loaded
-
Primary return code; a required component could not be loaded or terminated while processing the verb. Thus, communication could not take place. Contact the system administrator for corrective action.
-
sv_invalid_verb
-
Primary return code; the opcode parameter did not match the operation code of any verb. No verb executed.
-
sv_invalid_verb_segment
-
Primary return code; the VCB extended beyond the end of the data segment.
-
sv_unexpected_dos_error
-
Primary return code; one of the following conditions occurred:
-
The Microsoft® Windows NT®, Microsoft® Windows® 95, Windows version 3.x, Microsoft® MS-DOS®, or OS/2 system encountered an error while processing the verb. The operating system return code was returned through the secondary return code. If the problem persists, contact the system administrator for corrective action.
-
A CSV was issued from a message loop that was invoked by another application issuing a Windows SendMessage function call, rather than the more common Windows PostMessage function call. Verb processing cannot take place.
-
A CSV was issued when SendMessage invoked your application. You can determine whether your application has been invoked with SendMessage by using the InSendMessage Windows API function call.
Remarks
The type A character set consists of:
-
Uppercase letters.
-
Numerals 0 through 9.
-
Special characters $, #, @, and space.
This character set is supported by a system-supplied type A conversion table.
The first character of the source string must be an uppercase letter or the special character $, #, or @. Spaces are allowed only in trailing positions. Lowercase ASCII letters are translated to uppercase EBCDIC letters when the direction is ASCII to EBCDIC.
The type AE character set consists of:
-
Uppercase letters.
-
Lowercase letters.
-
Numerals 0 through 9.
-
Special characters $, #, @, period, and space.
This character set is supported by a system-supplied type AE conversion table.
The first character of the source string can be any character in the character set except the space.
During conversion, embedded blanks (including blanks in the first position) are converted to 0x00. Although such a conversion will complete, conversion_error is returned as the secondary return code, indicating that the CSV library has completed an irreversible conversion on the supplied data.
For the Windows NT system, a description of COMTBLG should point to the Windows NT registry under \SnaBase\Parameters\Client. For the OS/2 operating system, the directory and file containing the table must be specified by the environment variable COMTBLG. (If the file is not found, the system returns the sv_table_error parameter check.).
The SV_ROUND_TRIP value for char_not_fnd is useful only if you build a second conversion table to convert between the same two code pages in the reverse direction. If you specify the SV_ROUND_TRIP value in building both conversion tables, any character translated from one code page to the other and then back will be unchanged.
When using the SV_SUBSTITUTE value for char_not_fnd, converting the translated character string back to the original code page will not necessarily re-create the original character string.
Use substitute_char only if char_not_fnd is set to SV_SUBSTITUTE.
The value stored in the conversion table is the ASCII value associated with the character. If the table is used for conversion from ASCII to EBCDIC, the character that appears in the converted string is the character associated with the numeric EBCDIC value rather than ASCII.
For example, if you supply the underscore (_) character (ASCII value F6) while creating an ASCII to EBCDIC conversion table, the character that appears in the converted strings will be 6, the character associated with the value F6 in EBCDIC. To use the _ character as the substitute character in an ASCII to EBCDIC conversion table, you should supply the value E1 (the value associated with the _ character in EBCDIC) rather than the actual character.
A code page is a table that associates specific ASCII or EBCDIC values with specific characters. If a character from the source code page does not exist in the target code page, the translated (target) string differs from the original (source) string.