2013-06-24 20:56:30 +02:00
|
|
|
/*
|
|
|
|
Copyright (c) 2013, Spaempresarial - Brazil, Roberto Spadim
|
|
|
|
http://www.spadim.com.br/
|
|
|
|
roberto@spadim.com.br
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
* Neither the name of the Roberto Spadim nor the
|
|
|
|
names of the contributors may be used to endorse or promote products
|
|
|
|
derived from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
DISCLAIMED. IN NO EVENT SHALL ROBERTO SPADIM BE LIABLE FOR ANY
|
|
|
|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
|
|
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2017-06-18 06:42:16 +03:00
|
|
|
#include <my_global.h>
|
2013-06-24 20:56:30 +02:00
|
|
|
#include <sql_class.h> // THD
|
2019-06-16 07:51:59 +04:00
|
|
|
#include <sql_i_s.h> // ST_SCHEMA_TABLE
|
2013-06-24 20:56:30 +02:00
|
|
|
#include <mysql/plugin.h>
|
|
|
|
#include <m_ctype.h>
|
|
|
|
#include "sql_locale.h"
|
|
|
|
|
|
|
|
static MY_LOCALE **locale_list;
|
|
|
|
|
2019-06-16 07:51:59 +04:00
|
|
|
namespace Show {
|
|
|
|
|
2013-06-24 20:56:30 +02:00
|
|
|
/* LOCALES */
|
|
|
|
static ST_FIELD_INFO locale_info_locale_fields_info[]=
|
|
|
|
{
|
2019-06-16 07:51:59 +04:00
|
|
|
Column("ID", SLonglong(4), NOT_NULL, "Id"),
|
|
|
|
Column("NAME", Varchar(255), NOT_NULL, "Name"),
|
|
|
|
Column("DESCRIPTION", Varchar(255), NOT_NULL, "Description"),
|
|
|
|
Column("MAX_MONTH_NAME_LENGTH", SLonglong(4), NOT_NULL),
|
|
|
|
Column("MAX_DAY_NAME_LENGTH", SLonglong(4), NOT_NULL),
|
|
|
|
Column("DECIMAL_POINT", Varchar(2), NOT_NULL),
|
|
|
|
Column("THOUSAND_SEP", Varchar(2), NOT_NULL),
|
|
|
|
Column("ERROR_MESSAGE_LANGUAGE", Varchar(64), NOT_NULL, "Error_Message_Language"),
|
|
|
|
CEnd()
|
2013-06-24 20:56:30 +02:00
|
|
|
};
|
2019-06-16 07:51:59 +04:00
|
|
|
|
|
|
|
} // namespace Show
|
|
|
|
|
2013-06-24 20:56:30 +02:00
|
|
|
static int locale_info_fill_table_locale(THD* thd, TABLE_LIST* tables, COND* cond)
|
|
|
|
{
|
|
|
|
TABLE *table= tables->table;
|
|
|
|
CHARSET_INFO *cs= system_charset_info;
|
|
|
|
|
|
|
|
for (MY_LOCALE **loc= locale_list; *loc; loc++)
|
|
|
|
{
|
|
|
|
/* ID */
|
|
|
|
table->field[0]->store((longlong) (*loc)->number, TRUE);
|
|
|
|
/* NAME */
|
|
|
|
table->field[1]->store((*loc)->name, strlen((*loc)->name), cs);
|
|
|
|
/* DESCRIPTION */
|
|
|
|
table->field[2]->store((*loc)->description, strlen((*loc)->description), cs);
|
|
|
|
/* MAX_MONTH_NAME_LENGTH */
|
|
|
|
table->field[3]->store((longlong) (*loc)->max_month_name_length, TRUE);
|
|
|
|
/* MAX_DAY_NAME_LENGTH */
|
|
|
|
table->field[4]->store((longlong) (*loc)->max_day_name_length, TRUE);
|
|
|
|
/* DECIMAL_POINT */
|
|
|
|
char decimal= (*loc)->decimal_point;
|
|
|
|
table->field[5]->store(&decimal, decimal ? 1 : 0, cs);
|
|
|
|
/* THOUSAND_SEP */
|
|
|
|
char thousand= (*loc)->thousand_sep;
|
|
|
|
table->field[6]->store(&thousand, thousand ? 1 : 0, cs);
|
|
|
|
/* ERROR_MESSAGE_LANGUAGE */
|
|
|
|
table->field[7]->store((*loc)->errmsgs->language,
|
|
|
|
strlen((*loc)->errmsgs->language), cs);
|
|
|
|
if (schema_table_store_record(thd, table))
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int locale_info_plugin_init_locales(void *p)
|
|
|
|
{
|
|
|
|
ST_SCHEMA_TABLE *schema= (ST_SCHEMA_TABLE *)p;
|
2019-06-16 07:51:59 +04:00
|
|
|
schema->fields_info= Show::locale_info_locale_fields_info;
|
2013-06-24 20:56:30 +02:00
|
|
|
schema->fill_table= locale_info_fill_table_locale;
|
|
|
|
|
|
|
|
locale_list = my_locales;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
static struct st_mysql_information_schema locale_info_plugin=
|
|
|
|
{ MYSQL_INFORMATION_SCHEMA_INTERFACE_VERSION };
|
|
|
|
|
|
|
|
/*
|
|
|
|
Plugin library descriptor
|
|
|
|
*/
|
|
|
|
|
|
|
|
maria_declare_plugin(locales)
|
|
|
|
{
|
|
|
|
MYSQL_INFORMATION_SCHEMA_PLUGIN, /* the plugin type (see include/mysql/plugin.h) */
|
|
|
|
&locale_info_plugin, /* pointer to type-specific plugin descriptor */
|
|
|
|
"LOCALES", /* plugin name */
|
|
|
|
"Roberto Spadim, Spaempresarial - Brazil", /* plugin author */
|
|
|
|
"Lists all locales from server.", /* the plugin description */
|
|
|
|
PLUGIN_LICENSE_BSD, /* the plugin license (see include/mysql/plugin.h) */
|
|
|
|
locale_info_plugin_init_locales, /* Pointer to plugin initialization function */
|
|
|
|
0, /* Pointer to plugin deinitialization function */
|
2019-10-10 17:40:21 +02:00
|
|
|
0x0100, /* Numeric version 0xAABB means AA.BB version */
|
2013-06-24 20:56:30 +02:00
|
|
|
NULL, /* Status variables */
|
|
|
|
NULL, /* System variables */
|
|
|
|
"1.0", /* String version representation */
|
2016-03-11 08:59:51 +01:00
|
|
|
MariaDB_PLUGIN_MATURITY_STABLE /* Maturity (see include/mysql/plugin.h)*/
|
2013-06-24 20:56:30 +02:00
|
|
|
}
|
|
|
|
maria_declare_plugin_end;
|