DosGetCp: Difference between revisions
No edit summary |
mNo edit summary |
||
Line 1: | Line 1: | ||
This call allows a process to query the current process code page and the prepared system code pages. | |||
This | |||
== | This is the legacy function. It is recommended to use: "[[DosQueryCp]]". [https://books.google.com.ec/books?id=u7WbsmbttwYC&pg=PT372&lpg=PT372&dq#v=onepage&q&f=false] | ||
==Syntax== | ==Syntax== | ||
DosGetCp (Length, CodePageList, DataLength) | |||
DosGetCp | |||
==Parameters== | ==Parameters== | ||
; Length (USHORT) - input : Length, in bytes, of CodePageList. This length should be at least 2 bytes. If the length is less than the bytes needed to return all the prepared system code pages than the returned CodePageList is truncated. | ;Length (USHORT) - input : Length, in bytes, of CodePageList. This length should be at least 2 bytes. If the length is less than the bytes needed to return all the prepared system code pages than the returned CodePageList is truncated. | ||
; CodePageList (PUSHORT) - output : Address of the list of available system code pages. The format of the information returned in this list is: | ; CodePageList (PUSHORT) - output : Address of the list of available system code pages. The format of the information returned in this list is: | ||
::1 - Current code page identifier | |||
::2 - The first prepared code page | |||
::3 - The second prepared code page | |||
::N - Other prepared system code pages. | |||
; DataLength (PUSHORT) - output : Address of the length, in bytes, of the returned data. | |||
==Return Code== | ==Return Code== | ||
rc (USHORT) - return | rc (USHORT) - return | ||
Return code descriptions are: | Return code descriptions are: | ||
* 0 NO_ERROR | |||
* 0 | * 473 ERROR_CPLIST_TOO_SMALL | ||
* 473 | |||
==Remarks== | ==Remarks== | ||
If the process code page identifier was previously set by DosSetCp or inherited by a process, it is returned to the caller. | If the process code page identifier was previously set by [[DosSetCp]] or inherited by a process, it is returned to the caller. | ||
An input list size (length) of two bytes returns only the current process code page identifier. If CodePageList length is too small to hold all the available information, then as much information as possible is provided in the available space and ERROR_CPLIST_TOO_SMALL is returned. | An input list size (length) of two bytes returns only the current process code page identifier. If CodePageList length is too small to hold all the available information, then as much information as possible is provided in the available space and ERROR_CPLIST_TOO_SMALL is returned. | ||
Line 39: | Line 29: | ||
===Family API Considerations=== | ===Family API Considerations=== | ||
Some options operate differently in the DOS mode than in OS/2 mode. Therefore, the following restriction applies to DosGetCp when coding for the DOS mode: | Some options operate differently in the DOS mode than in OS/2 mode. Therefore, the following restriction applies to DosGetCp when coding for the DOS mode: | ||
The current process code page, and no more than one prepared system code page, is returned. | The current process code page, and no more than one prepared system code page, is returned. | ||
==Example Code== | ==Example Code== | ||
Line 67: | Line 55: | ||
USHORT rc; | USHORT rc; | ||
rc = DosGetCp(sizeof(CpList), /* Length of list */ | |||
CpList, /* List */ | |||
&CpSize); /* Length of returned list */ | |||
</PRE> | </PRE> | ||
===MASM Binding=== | ===MASM Binding=== | ||
<PRE> | <PRE> | ||
Line 84: | Line 73: | ||
</PRE> | </PRE> | ||
==Related Functions== | ==Related Functions== | ||
* | *[[DosSetCp]] | ||
[[Category:Dos]] | [[Category:Dos]] |
Revision as of 14:00, 14 August 2017
This call allows a process to query the current process code page and the prepared system code pages.
This is the legacy function. It is recommended to use: "DosQueryCp". [1]
Syntax
DosGetCp (Length, CodePageList, DataLength)
Parameters
- Length (USHORT) - input
- Length, in bytes, of CodePageList. This length should be at least 2 bytes. If the length is less than the bytes needed to return all the prepared system code pages than the returned CodePageList is truncated.
- CodePageList (PUSHORT) - output
- Address of the list of available system code pages. The format of the information returned in this list is:
- 1 - Current code page identifier
- 2 - The first prepared code page
- 3 - The second prepared code page
- N - Other prepared system code pages.
- DataLength (PUSHORT) - output
- Address of the length, in bytes, of the returned data.
Return Code
rc (USHORT) - return
Return code descriptions are:
- 0 NO_ERROR
- 473 ERROR_CPLIST_TOO_SMALL
Remarks
If the process code page identifier was previously set by DosSetCp or inherited by a process, it is returned to the caller.
An input list size (length) of two bytes returns only the current process code page identifier. If CodePageList length is too small to hold all the available information, then as much information as possible is provided in the available space and ERROR_CPLIST_TOO_SMALL is returned.
If no codepages were prepared with the CODEPAGE command, a length of two and current codepage identifier value of zero is returned.
Family API Considerations
Some options operate differently in the DOS mode than in OS/2 mode. Therefore, the following restriction applies to DosGetCp when coding for the DOS mode:
The current process code page, and no more than one prepared system code page, is returned.
Example Code
C Binding
#define INCL_DOSNLS USHORT rc = DosGetCp(Length, CodePageList, DataLength); USHORT Length; /* Length of list */ PUSHORT CodePageList; /* List (returned) */ PUSHORT DataLength; /* Length of list (returned) */ USHORT rc; /* return code */
This example gets the current code page and then up to 3 other prepared codepages.
#define INCL_DOSNLS USHORT CpList[8]; USHORT CpSize; USHORT rc; rc = DosGetCp(sizeof(CpList), /* Length of list */ CpList, /* List */ &CpSize); /* Length of returned list */
MASM Binding
EXTRN DosGetCp:FAR INCL_DOSNLS EQU 1 PUSH WORD Length ;Length of list PUSH@ WORD CodePageList ;List (returned) PUSH@ WORD DataLength ;Length of list (returned) CALL DosGetCp Returns WORD