Commit 37d4fd2b authored by Tom Lane's avatar Tom Lane

Improve reporting of newlocale() failures in CREATE COLLATION.

The standardized errno code for "no such locale" failures is ENOENT, which
we were just reporting at face value, viz "No such file or directory".
Per gripe from Thom Brown, this might confuse users, so add an errdetail
message to clarify what it means.  Also, report newlocale() failures as
ERRCODE_INVALID_PARAMETER_VALUE rather than using
errcode_for_file_access(), since newlocale()'s errno values aren't
necessarily tied directly to file access failures.
parent faf5cee7
...@@ -707,8 +707,7 @@ cache_locale_time(void) ...@@ -707,8 +707,7 @@ cache_locale_time(void)
* otherwise returns the pointer to a static area which * otherwise returns the pointer to a static area which
* contains the iso formatted locale name. * contains the iso formatted locale name.
*/ */
static static char *
char *
IsoLocaleName(const char *winlocname) IsoLocaleName(const char *winlocname)
{ {
#if (_MSC_VER >= 1400) /* VC8.0 or later */ #if (_MSC_VER >= 1400) /* VC8.0 or later */
...@@ -937,6 +936,27 @@ lc_ctype_is_c(Oid collation) ...@@ -937,6 +936,27 @@ lc_ctype_is_c(Oid collation)
} }
/* simple subroutine for reporting errors from newlocale() */
static void
report_newlocale_failure(const char *localename)
{
/* copy errno in case one of the ereport auxiliary functions changes it */
int save_errno = errno;
/*
* ENOENT means "no such locale", not "no such file", so clarify that
* errno with an errdetail message.
*/
ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("could not create locale \"%s\": %m",
localename),
(save_errno == ENOENT ?
errdetail("The operating system could not find any locale data for the locale name \"%s\".",
localename) : 0)));
}
/* /*
* Create a locale_t from a collation OID. Results are cached for the * Create a locale_t from a collation OID. Results are cached for the
* lifetime of the backend. Thus, do not free the result with freelocale(). * lifetime of the backend. Thus, do not free the result with freelocale().
...@@ -995,10 +1015,7 @@ pg_newlocale_from_collation(Oid collid) ...@@ -995,10 +1015,7 @@ pg_newlocale_from_collation(Oid collid)
result = _create_locale(LC_ALL, collcollate); result = _create_locale(LC_ALL, collcollate);
#endif #endif
if (!result) if (!result)
ereport(ERROR, report_newlocale_failure(collcollate);
(errcode_for_file_access(),
errmsg("could not create locale \"%s\": %m",
collcollate)));
} }
else else
{ {
...@@ -1008,16 +1025,10 @@ pg_newlocale_from_collation(Oid collid) ...@@ -1008,16 +1025,10 @@ pg_newlocale_from_collation(Oid collid)
loc1 = newlocale(LC_COLLATE_MASK, collcollate, NULL); loc1 = newlocale(LC_COLLATE_MASK, collcollate, NULL);
if (!loc1) if (!loc1)
ereport(ERROR, report_newlocale_failure(collcollate);
(errcode_for_file_access(),
errmsg("could not create locale \"%s\": %m",
collcollate)));
result = newlocale(LC_CTYPE_MASK, collctype, loc1); result = newlocale(LC_CTYPE_MASK, collctype, loc1);
if (!result) if (!result)
ereport(ERROR, report_newlocale_failure(collctype);
(errcode_for_file_access(),
errmsg("could not create locale \"%s\": %m",
collctype)));
#else #else
/* /*
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment