The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Win32::OLE::NLS - OLE National Language Support

SYNOPSIS

missing

DESCRIPTION

This module provides access to the national language support features in the OLENLS.DLL.

Functions

CompareString(LCID,FLAGS,STR1,STR2)

Compare STR1 and STR2 in the LCID locale. FLAGS indicate the character traits to be used or ignored when comparing the two strings.

NORM_IGNORECASE		Ignore case
NORM_IGNOREKANATYPE	Ignore hiragana/katakana character differences
NORM_IGNORENONSPACE	Ignore accents, diacritics, and vowel marks
NORM_IGNORESYMBOLS	Ignore symbols
NORM_IGNOREWIDTH	Ignore character width

Possible return values are:

0	Function failed
1	STR1 is less than STR2
2	STR1 is equal to STR2
3	STR1 is greater than STR2

Note that you can subtract 2 from the return code to get values comparable to the cmp operator.

LCMapString(LCID,FLAGS,STR)

LCMapString translates STR using LCID dependent translation. Flags contains a combination of the following options:

LCMAP_LOWERCASE		Lowercase
LCMAP_UPPERCASE		Uppercase
LCMAP_HALFWIDTH		Narrow characters
LCMAP_FULLWIDTH		Wide characters
LCMAP_HIRAGANA		Hiragana
LCMAP_KATAKANA		Katakana
LCMAP_SORTKEY		Character sort key

The following normalization options can be combined with LCMAP_SORTKEY:

NORM_IGNORECASE		Ignore case
NORM_IGNOREKANATYPE	Ignore hiragana/katakana character differences
NORM_IGNORENONSPACE	Ignore accents, diacritics, and vowel marks
NORM_IGNORESYMBOLS	Ignore symbols
NORM_IGNOREWIDTH	Ignore character width

The return value is the translated string.

GetLocaleInfo(LCID,LCTYPE)

Retrieve locale setting LCTYPE from the locale specified by LCID. Use LOCALE_NOUSEROVERRIDE | LCTYPE to always query the locale database. Otherwise user changes to win.ini through the windows control panel take precedence when retrieving values for the system default locale. See the documentation below for a list of valid LCTYPE values.

The return value is the contents of the requested locale setting.

GetStringType(LCID,TYPE,STR)

Retrieve type information from locale LCID about each character in STR. The requested TYPE can be one of the following 3 levels:

CT_CTYPE1		ANSI C and POSIX type information
CT_CTYPE2		Text layout type information
CT_CTYPE3		Text processing type information

The return value is a list of values, each of wich is a bitwise OR of the applicable type bits from the corresponding table below:

@ct = GetStringType(LOCALE_SYSTEM_DEFAULT, CT_CTYPE1, "String");

ANSI C and POSIX character type information:

C1_UPPER		Uppercase
C1_LOWER		Lowercase
C1_DIGIT		Decimal digits
C1_SPACE		Space characters
C1_PUNCT		Punctuation
C1_CNTRL		Control characters
C1_BLANK		Blank characters
C1_XDIGIT		Hexadecimal digits
C1_ALPHA		Any letter

Text layout type information:

C2_LEFTTORIGHT		Left to right
C2_RIGHTTOLEFT		Right to left
C2_EUROPENUMBER		European number, European digit
C2_EUROPESEPARATOR	European numeric separator
C2_EUROPETERMINATOR	European numeric terminator
C2_ARABICNUMBER		Arabic number
C2_COMMONSEPARATOR	Common numeric separator
C2_BLOCKSEPARATOR	Block separator
C2_SEGMENTSEPARATOR	Segment separator
C2_WHITESPACE		White space
C2_OTHERNEUTRAL		Other neutrals
C2_NOTAPPLICABLE	No implicit direction (e.g. ctrl codes)

Text precessing type information:

C3_NONSPACING		Nonspacing mark
C3_DIACRITIC		Diacritic nonspacing mark
C3_VOWELMARK		Vowel nonspacing mark
C3_SYMBOL		Symbol
C3_KATAKANA		Katakana character
C3_HIRAGANA		Hiragana character
C3_HALFWIDTH		Narrow character
C3_FULLWIDTH		Wide character
C3_IDEOGRAPH		Ideograph
C3_ALPHA		Any letter
C3_NOTAPPLICABLE	Not applicable
GetSystemDefaultLangID()

Returns the system default language identifier.

GetSystemDefaultLCID()

Returns the system default locale identifier.

GetUserDefaultLangID()

Returns the user default language identifier.

GetUserDefaultLCID()

Returns the user default locale identifier.

SendSettingChange()

Sends a WM_SETTINGCHANGE message to all top level windows.

SetLocaleInfo(LCID, LCTYPE, LCDATA)

Changes an item in the user override part of the locale setting LCID. It doesn't change the system default database. The following LCTYPEs are changeable:

LOCALE_ICALENDARTYPE	LOCALE_SDATE
LOCALE_ICURRDIGITS	LOCALE_SDECIMAL
LOCALE_ICURRENCY	LOCALE_SGROUPING
LOCALE_IDIGITS		LOCALE_SLIST
LOCALE_IFIRSTDAYOFWEEK	LOCALE_SLONGDATE
LOCALE_IFIRSTWEEKOFYEAR	LOCALE_SMONDECIMALSEP
LOCALE_ILZERO		LOCALE_SMONGROUPING
LOCALE_IMEASURE		LOCALE_SMONTHOUSANDSEP
LOCALE_INEGCURR		LOCALE_SNEGATIVESIGN
LOCALE_INEGNUMBER	LOCALE_SPOSITIVESIGN
LOCALE_IPAPERSIZE	LOCALE_SSHORTDATE
LOCALE_ITIME		LOCALE_STHOUSAND
LOCALE_S1159		LOCALE_STIME
LOCALE_S2359		LOCALE_STIMEFORMAT
LOCALE_SCURRENCY	LOCALE_SYEARMONTH

You have to call SendSettingChange() to activate these changes for subsequent Win32::OLE::Variant object formatting because the OLE subsystem seems to cache locale information.

MAKELANGID(LANG,SUBLANG)

Creates a language identifier from a primary language and a sublanguage.

PRIMARYLANGID(LANGID)

Retrieves the primary language from a language identifier.

SUBLANGID(LANGID)

Retrieves the sublanguage from a language identifier.

MAKELCID(LANGID)

Creates a locale identifies from a language identifier.

LANGIDFROMLCID(LCID)

Retrieves a language identifier from a locale identifier.

Locale Types

LOCALE_ILANGUAGE

The language identifier (in hex).

LOCALE_SLANGUAGE

The localized name of the language.

LOCALE_SENGLANGUAGE

The ISO Standard 639 English name of the language.

LOCALE_SABBREVLANGNAME

The three-letter abbreviated name of the language. The first two letters are from the ISO Standard 639 language name abbreviation. The third letter indicates the sublanguage type.

LOCALE_SNATIVELANGNAME

The native name of the language.

LOCALE_ICOUNTRY

The country code, which is based on international phone codes.

LOCALE_SCOUNTRY

The localized name of the country.

LOCALE_SENGCOUNTRY

The English name of the country.

LOCALE_SABBREVCTRYNAME

The ISO Standard 3166 abbreviated name of the country.

LOCALE_SNATIVECTRYNAME

The native name of the country.

LOCALE_IDEFAULTLANGUAGE

Language identifier for the principal language spoken in this locale.

LOCALE_IDEFAULTCOUNTRY

Country code for the principal country in this locale.

LOCALE_IDEFAULTANSICODEPAGE

The ANSI code page associated with this locale. Format: 4 Unicode decimal digits plus a Unicode null terminator.

XXX This should be translated by GetLocaleInfo. XXX

LOCALE_IDEFAULTCODEPAGE

The OEM code page associated with the country.

LOCALE_SLIST

Characters used to separate list items (often a comma).

LOCALE_IMEASURE

Default measurement system:

0	metric system (S.I.)
1	U.S. system
LOCALE_SDECIMAL

Characters used for the decimal separator (often a dot).

LOCALE_STHOUSAND

Characters used as the separator between groups of digits left of the decimal.

LOCALE_SGROUPING

Sizes for each group of digits to the left of the decimal. An explicit size is required for each group. Sizes are separated by semicolons. If the last value is 0, the preceding value is repeated. To group thousands, specify 3;0.

LOCALE_IDIGITS

The number of fractional digits.

LOCALE_ILZERO

Whether to use leading zeros in decimal fields. A setting of 0 means use no leading zeros; 1 means use leading zeros.

LOCALE_SNATIVEDIGITS

The ten characters that are the native equivalent of the ASCII 0-9.

LOCALE_INEGNUMBER

Negative number mode.

0 	(1.1)
1 	-1.1
2 	-1.1
3 	1.1
4 	1.1
LOCALE_SCURRENCY

The string used as the local monetary symbol.

LOCALE_SINTLSYMBOL

Three characters of the International monetary symbol specified in ISO 4217, Codes for the Representation of Currencies and Funds, followed by the character separating this string from the amount.

LOCALE_SMONDECIMALSEP

Characters used for the monetary decimal separators.

LOCALE_SMONTHOUSANDSEP

Characters used as monetary separator between groups of digits left of the decimal.

LOCALE_SMONGROUPING

Sizes for each group of monetary digits to the left of the decimal. An explicit size is needed for each group. Sizes are separated by semicolons. If the last value is 0, the preceding value is repeated. To group thousands, specify 3;0.

LOCALE_ICURRDIGITS

Number of fractional digits for the local monetary format.

LOCALE_IINTLCURRDIGITS

Number of fractional digits for the international monetary format.

LOCALE_ICURRENCY

Positive currency mode.

0	Prefix, no separation.
1	Suffix, no separation.
2	Prefix, 1-character separation.
3	Suffix, 1-character separation.
LOCALE_INEGCURR

Negative currency mode.

0	($1.1)
1	-$1.1
2	$-1.1
3	$1.1-
4	$(1.1$)
5	-1.1$
6	1.1-$
7	1.1$-
8	-1.1 $ (space before $)
9	-$ 1.1 (space after $)
10	1.1 $- (space before $)
LOCALE_ICALENDARTYPE

The type of calendar currently in use.

1	Gregorian (as in U.S.)
2	Gregorian (always English strings)
3	Era: Year of the Emperor (Japan)
4	Era: Year of the Republic of China
5	Tangun Era (Korea)
LOCALE_IOPTIONALCALENDAR

The additional calendar types available for this LCID. Can be a null-separated list of all valid optional calendars. Value is 0 for "None available" or any of the LOCALE_ICALENDARTYPE settings.

XXX null separated list should be translated by GetLocaleInfo XXX

LOCALE_SDATE

Characters used for the date separator.

LOCALE_STIME

Characters used for the time separator.

LOCALE_STIMEFORMAT

Time-formatting string.

LOCALE_SSHORTDATE

Short Date_Time formatting strings for this locale.

LOCALE_SLONGDATE

Long Date_Time formatting strings for this locale.

LOCALE_IDATE

Short Date format-ordering specifier.

0	Month - Day - Year
1	Day - Month - Year
2	Year - Month - Day
LOCALE_ILDATE

Long Date format ordering specifier. Value can be any of the valid LOCALE_IDATE settings.

LOCALE_ITIME

Time format specifier.

0	AM/PM 12-hour format.
1	24-hour format.
LOCALE_ITIMEMARKPOSN

Whether the time marker string (AM|PM) precedes or follows the time string. 0 Suffix (9:15 AM). 1 Prefix (AM 9:15).

LOCALE_ICENTURY

Whether to use full 4-digit century.

0	Two digit.
1	Full century.
LOCALE_ITLZERO

Whether to use leading zeros in time fields.

0	No leading zeros.
1	Leading zeros for hours.
LOCALE_IDAYLZERO

Whether to use leading zeros in day fields. Values as for LOCALE_ITLZERO.

LOCALE_IMONLZERO

Whether to use leading zeros in month fields. Values as for LOCALE_ITLZERO.

LOCALE_S1159

String for the AM designator.

LOCALE_S2359

String for the PM designator.

LOCALE_IFIRSTWEEKOFYEAR

Specifies which week of the year is considered first.

0	Week containing 1/1 is the first week of the year.
1	First full week following 1/1is the first week of the year.
2	First week with at least 4 days is the first week of the year.
LOCALE_IFIRSTDAYOFWEEK

Specifies the day considered first in the week. Value "0" means SDAYNAME1 and value "6" means SDAYNAME7.

LOCALE_SDAYNAME1 .. LOCALE_SDAYNAME7

Long name for Monday .. Sunday.

LOCALE_SABBREVDAYNAME1 .. LOCALE_SABBREVDAYNAME7

Abbreviated name for Monday .. Sunday.

LOCALE_SMONTHNAME1 .. LOCALE_SMONTHNAME12

Long name for January .. December.

LOCALE_SMONTHNAME13

Native name for 13th month, if it exists.

LOCALE_SABBREVMONTHNAME1 .. LOCALE_SABBREVMONTHNAME12

Abbreviated name for January .. December.

LOCALE_SABBREVMONTHNAME13

Native abbreviated name for 13th month, if it exists.

LOCALE_SPOSITIVESIGN

String value for the positive sign.

LOCALE_SNEGATIVESIGN

String value for the negative sign.

LOCALE_IPOSSIGNPOSN

Formatting index for positive values.

0 Parentheses surround the amount and the monetary symbol.
1 The sign string precedes the amount and the monetary symbol.
2 The sign string precedes the amount and the monetary symbol.
3 The sign string precedes the amount and the monetary symbol.
4 The sign string precedes the amount and the monetary symbol.
LOCALE_INEGSIGNPOSN

Formatting index for negative values. Values as for LOCALE_IPOSSIGNPOSN.

LOCALE_IPOSSYMPRECEDES

If the monetary symbol precedes, 1. If it succeeds a positive amount, 0.

LOCALE_IPOSSEPBYSPACE

If the monetary symbol is separated by a space from a positive amount, 1. Otherwise, 0.

LOCALE_INEGSYMPRECEDES

If the monetary symbol precedes, 1. If it succeeds a negative amount, 0.

LOCALE_INEGSEPBYSPACE

If the monetary symbol is separated by a space from a negative amount, 1. Otherwise, 0.

AUTHORS/COPYRIGHT

This module is part of the Win32::OLE distribution.