Commit 280f1c26 authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

MDEV-11345 Compile english error messages into mysqld executable.

parent f2d3b2ee
...@@ -69,6 +69,9 @@ bool init_errmessage(void) ...@@ -69,6 +69,9 @@ bool init_errmessage(void)
{ {
const char **errmsgs; const char **errmsgs;
bool error= FALSE; bool error= FALSE;
const char *lang= my_default_lc_messages->errmsgs->language;
my_bool use_english;
DBUG_ENTER("init_errmessage"); DBUG_ENTER("init_errmessage");
free_error_messages(); free_error_messages();
...@@ -77,35 +80,63 @@ bool init_errmessage(void) ...@@ -77,35 +80,63 @@ bool init_errmessage(void)
error_message_charset_info= system_charset_info; error_message_charset_info= system_charset_info;
use_english= !strcmp(lang, "english");
if (!use_english)
{
/* Read messages from file. */ /* Read messages from file. */
if (read_texts(ERRMSG_FILE, my_default_lc_messages->errmsgs->language, use_english= !read_texts(ERRMSG_FILE,lang, &original_error_messages);
&original_error_messages)) error= TRUE;
}
if (use_english)
{ {
/* static const struct
No error messages. Create a temporary empty error message so {
that we don't get a crash if some code wrongly tries to access const char* name;
a non existing error message. uint id;
*/ const char* fmt;
}
english_msgs[]=
{
#include <mysqld_ername.h>
};
memset(errors_per_range, 0, sizeof(errors_per_range));
/* Calculate nr of messages per range. */
for (size_t i= 0; i < array_elements(english_msgs); i++)
{
uint id= english_msgs[i].id;
// We rely on the fact the array is sorted by id.
DBUG_ASSERT(i == 0 || english_msgs[i-1].id < id);
errors_per_range[id/ERRORS_PER_RANGE-1]= id%ERRORS_PER_RANGE + 1;
}
size_t all_errors= 0;
for (size_t i= 0; i < MAX_ERROR_RANGES; i++)
all_errors+= errors_per_range[i];
if (!(original_error_messages= (const char***) if (!(original_error_messages= (const char***)
my_malloc(MAX_ERROR_RANGES * sizeof(char**) + my_malloc((all_errors + MAX_ERROR_RANGES)* sizeof(void*),
(ERRORS_PER_RANGE * sizeof(char*)), MYF(MY_ZEROFILL))))
MYF(0))))
DBUG_RETURN(TRUE); DBUG_RETURN(TRUE);
errmsgs= (const char**) (original_error_messages + MAX_ERROR_RANGES);
for (uint i=0 ; i < MAX_ERROR_RANGES ; i++) errmsgs= (const char**)(original_error_messages + MAX_ERROR_RANGES);
original_error_messages[0]= errmsgs;
for (uint i= 1; i < MAX_ERROR_RANGES; i++)
{ {
original_error_messages[i]= errmsgs; original_error_messages[i]=
errors_per_range[i]= ERRORS_PER_RANGE; original_error_messages[i-1] + errors_per_range[i-1];
} }
errors_per_range[2]= 0; // MYSYS error messages
for (const char **ptr= errmsgs;
ptr < errmsgs + ERRORS_PER_RANGE ;
ptr++)
*ptr= "";
error= TRUE; for (uint i= 0; i < array_elements(english_msgs); i++)
{
uint id= english_msgs[i].id;
original_error_messages[id/ERRORS_PER_RANGE-1][id%ERRORS_PER_RANGE]=
english_msgs[i].fmt;
}
} }
/* Register messages for use with my_error(). */ /* Register messages for use with my_error(). */
......
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