PostgreSQL Source Code  git master
pg_locale.h
Go to the documentation of this file.
1 /*-----------------------------------------------------------------------
2  *
3  * PostgreSQL locale utilities
4  *
5  * src/include/utils/pg_locale.h
6  *
7  * Copyright (c) 2002-2023, PostgreSQL Global Development Group
8  *
9  *-----------------------------------------------------------------------
10  */
11 
12 #ifndef _PG_LOCALE_
13 #define _PG_LOCALE_
14 
15 #if defined(LOCALE_T_IN_XLOCALE) || defined(WCSTOMBS_L_IN_XLOCALE)
16 #include <xlocale.h>
17 #endif
18 #ifdef USE_ICU
19 #include <unicode/ucol.h>
20 #endif
21 
22 #ifdef USE_ICU
23 /*
24  * ucol_strcollUTF8() was introduced in ICU 50, but it is buggy before ICU 53.
25  * (see
26  * <https://www.postgresql.org/message-id/flat/f1438ec6-22aa-4029-9a3b-26f79d330e72%40manitou-mail.org>)
27  */
28 #if U_ICU_VERSION_MAJOR_NUM >= 53
29 #define HAVE_UCOL_STRCOLLUTF8 1
30 #else
31 #undef HAVE_UCOL_STRCOLLUTF8
32 #endif
33 #endif
34 
35 /* use for libc locale names */
36 #define LOCALE_NAME_BUFLEN 128
37 
38 /* GUC settings */
39 extern PGDLLIMPORT char *locale_messages;
40 extern PGDLLIMPORT char *locale_monetary;
41 extern PGDLLIMPORT char *locale_numeric;
42 extern PGDLLIMPORT char *locale_time;
44 
45 /* lc_time localization cache */
46 extern PGDLLIMPORT char *localized_abbrev_days[];
47 extern PGDLLIMPORT char *localized_full_days[];
49 extern PGDLLIMPORT char *localized_full_months[];
50 
51 /* is the databases's LC_CTYPE the C locale? */
53 
54 extern bool check_locale(int category, const char *locale, char **canonname);
55 extern char *pg_perm_setlocale(int category, const char *locale);
56 extern void check_strxfrm_bug(void);
57 
58 extern bool lc_collate_is_c(Oid collation);
59 extern bool lc_ctype_is_c(Oid collation);
60 
61 /*
62  * Return the POSIX lconv struct (contains number/money formatting
63  * information) with locale information for all categories.
64  */
65 extern struct lconv *PGLC_localeconv(void);
66 
67 extern void cache_locale_time(void);
68 
69 
70 /*
71  * We define our own wrapper around locale_t so we can keep the same
72  * function signatures for all builds, while not having to create a
73  * fake version of the standard type locale_t in the global namespace.
74  * pg_locale_t is occasionally checked for truth, so make it a pointer.
75  */
77 {
78  char provider;
80  union
81  {
82 #ifdef HAVE_LOCALE_T
83  locale_t lt;
84 #endif
85 #ifdef USE_ICU
86  struct
87  {
88  const char *locale;
89  UCollator *ucol;
90  } icu;
91 #endif
92  int dummy; /* in case we have neither LOCALE_T nor ICU */
93  } info;
94 };
95 
96 typedef struct pg_locale_struct *pg_locale_t;
97 
99 
100 extern void make_icu_collator(const char *iculocstr,
101  const char *icurules,
102  struct pg_locale_struct *resultp);
103 
106 
107 extern char *get_collation_actual_version(char collprovider, const char *collcollate);
108 extern int pg_strcoll(const char *arg1, const char *arg2, pg_locale_t locale);
109 extern int pg_strncoll(const char *arg1, size_t len1,
110  const char *arg2, size_t len2, pg_locale_t locale);
112 extern size_t pg_strxfrm(char *dest, const char *src, size_t destsize,
114 extern size_t pg_strnxfrm(char *dest, size_t destsize, const char *src,
115  size_t srclen, pg_locale_t locale);
117 extern size_t pg_strxfrm_prefix(char *dest, const char *src, size_t destsize,
119 extern size_t pg_strnxfrm_prefix(char *dest, size_t destsize, const char *src,
120  size_t srclen, pg_locale_t locale);
121 
122 extern void icu_validate_locale(const char *loc_str);
123 
124 #ifdef USE_ICU
125 extern int32_t icu_to_uchar(UChar **buff_uchar, const char *buff, size_t nbytes);
126 extern int32_t icu_from_uchar(char **result, const UChar *buff_uchar, int32_t len_uchar);
127 #endif
128 
129 /* These functions convert from/to libc's wchar_t, *not* pg_wchar_t */
130 extern size_t wchar2char(char *to, const wchar_t *from, size_t tolen,
132 extern size_t char2wchar(wchar_t *to, size_t tolen,
133  const char *from, size_t fromlen, pg_locale_t locale);
134 
135 #endif /* _PG_LOCALE_ */
#define PGDLLIMPORT
Definition: c.h:1303
Oid collid
static char * locale
Definition: initdb.c:139
struct pg_locale_struct * pg_locale_t
Definition: pg_locale.h:96
size_t pg_strnxfrm(char *dest, size_t destsize, const char *src, size_t srclen, pg_locale_t locale)
Definition: pg_locale.c:2386
PGDLLIMPORT int icu_validation_level
Definition: pg_locale.c:99
void cache_locale_time(void)
Definition: pg_locale.c:766
bool pg_strxfrm_enabled(pg_locale_t locale)
Definition: pg_locale.c:2318
size_t wchar2char(char *to, const wchar_t *from, size_t tolen, pg_locale_t locale)
Definition: pg_locale.c:2913
struct lconv * PGLC_localeconv(void)
Definition: pg_locale.c:484
int pg_strncoll(const char *arg1, size_t len1, const char *arg2, size_t len2, pg_locale_t locale)
Definition: pg_locale.c:2100
void make_icu_collator(const char *iculocstr, const char *icurules, struct pg_locale_struct *resultp)
Definition: pg_locale.c:1429
bool lc_collate_is_c(Oid collation)
Definition: pg_locale.c:1324
void icu_validate_locale(const char *loc_str)
Definition: pg_locale.c:2833
void check_strxfrm_bug(void)
Definition: pg_locale.c:1178
PGDLLIMPORT char * locale_time
Definition: pg_locale.c:97
pg_locale_t pg_newlocale_from_collation(Oid collid)
Definition: pg_locale.c:1537
PGDLLIMPORT char * localized_abbrev_days[]
Definition: pg_locale.c:108
bool lc_ctype_is_c(Oid collation)
Definition: pg_locale.c:1377
bool pg_locale_deterministic(pg_locale_t locale)
Definition: pg_locale.c:1513
char * get_collation_actual_version(char collprovider, const char *collcollate)
Definition: pg_locale.c:1707
PGDLLIMPORT char * locale_numeric
Definition: pg_locale.c:96
PGDLLIMPORT char * localized_full_days[]
Definition: pg_locale.c:109
char * pg_perm_setlocale(int category, const char *locale)
Definition: pg_locale.c:172
int pg_strcoll(const char *arg1, const char *arg2, pg_locale_t locale)
Definition: pg_locale.c:2065
PGDLLIMPORT char * localized_full_months[]
Definition: pg_locale.c:111
PGDLLIMPORT char * localized_abbrev_months[]
Definition: pg_locale.c:110
PGDLLIMPORT char * locale_monetary
Definition: pg_locale.c:95
bool pg_strxfrm_prefix_enabled(pg_locale_t locale)
Definition: pg_locale.c:2409
PGDLLIMPORT char * locale_messages
Definition: pg_locale.c:94
PGDLLIMPORT struct pg_locale_struct default_locale
Definition: pg_locale.c:1426
size_t pg_strnxfrm_prefix(char *dest, size_t destsize, const char *src, size_t srclen, pg_locale_t locale)
Definition: pg_locale.c:2473
PGDLLIMPORT bool database_ctype_is_c
Definition: pg_locale.c:114
size_t pg_strxfrm(char *dest, const char *src, size_t destsize, pg_locale_t locale)
Definition: pg_locale.c:2350
bool check_locale(int category, const char *locale, char **canonname)
Definition: pg_locale.c:275
size_t pg_strxfrm_prefix(char *dest, const char *src, size_t destsize, pg_locale_t locale)
Definition: pg_locale.c:2436
size_t char2wchar(wchar_t *to, size_t tolen, const char *from, size_t fromlen, pg_locale_t locale)
Definition: pg_locale.c:2984
unsigned int Oid
Definition: postgres_ext.h:31
union pg_locale_struct::@142 info
bool deterministic
Definition: pg_locale.h:79
#define locale_t
Definition: win32_port.h:426