mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 13:02:28 +01:00
f83113df07
Removed compiler warnings extra/libevent/epoll.c: Removed compiler warnings extra/libevent/evbuffer.c: Removed compiler warnings extra/libevent/event.c: Removed compiler warnings extra/libevent/select.c: Removed compiler warnings extra/libevent/signal.c: Removed compiler warnings include/m_ctype.h: Define CHARSET_INFO, MY_CHARSET_HANDLER, MY_COLLATION_HANDLER, MY_UNICASE_INFO, MY_UNI_CTYPE and MY_UNI_IDX as const structures. Declare that pointers point to const data include/m_string.h: Declare that pointers point to const data include/my_sys.h: Redefine variables and function prototypes include/mysql.h: Declare charset as const include/mysql.h.pp: Declare charset as const include/mysql/plugin.h: Declare charset as const include/mysql/plugin.h.pp: Declare charset as const mysys/charset-def.c: Charset can't be of type CHARSET_INFO as they are changed when they are initialized. mysys/charset.c: Functions that change CHARSET_INFO must use 'struct charset_info_st' Add temporary variables to not have to change all_charsets[] (Which now is const) sql-common/client.c: Added cast to const sql/item_cmpfunc.h: Added cast to avoid compiler error. sql/sql_class.cc: Added cast to const sql/sql_lex.cc: Added cast to const storage/maria/ma_ft_boolean_search.c: Added cast to avoid compiler error. storage/maria/ma_ft_parser.c: Added cast to avoid compiler error. storage/maria/ma_search.c: Added cast to const storage/myisam/ft_boolean_search.c: Added cast to avoid compiler error storage/myisam/ft_parser.c: Added cast to avoid compiler error storage/myisam/mi_search.c: Added cast to const storage/pbxt/src/datadic_xt.cc: Added cast to const storage/pbxt/src/ha_pbxt.cc: Added cast to const Removed compiler warning by changing prototype of XTThreadPtr() storage/pbxt/src/myxt_xt.h: Character sets should be const storage/pbxt/src/xt_defs.h: Character sets should be const storage/xtradb/btr/btr0cur.c: Removed compiler warning strings/conf_to_src.c: Added const Functions that change CHARSET_INFO must use 'struct charset_info_st' strings/ctype-big5.c: Made arrays const strings/ctype-bin.c: Made arrays const strings/ctype-cp932.c: Made arrays const strings/ctype-czech.c: Made arrays const strings/ctype-euc_kr.c: Made arrays const strings/ctype-eucjpms.c: Made arrays const strings/ctype-extra.c: Made arrays const strings/ctype-gb2312.c: Made arrays const strings/ctype-gbk.c: Made arrays const strings/ctype-latin1.c: Made arrays const strings/ctype-mb.c: Made arrays const strings/ctype-simple.c: Made arrays const strings/ctype-sjis.c: Made arrays const strings/ctype-tis620.c: Made arrays const strings/ctype-uca.c: Made arrays const strings/ctype-ucs2.c: Made arrays const strings/ctype-ujis.c: Made arrays const strings/ctype-utf8.c: Made arrays const strings/ctype-win1250ch.c: Made arrays const strings/ctype.c: Made arrays const Added cast to const Functions that change CHARSET_INFO must use 'struct charset_info_st' strings/int2str.c: Added cast to const
201 lines
8 KiB
C
201 lines
8 KiB
C
/* Copyright (C) 2000 MySQL AB
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
#include "mysys_priv.h"
|
|
|
|
/*
|
|
Include all compiled character sets into the client
|
|
If a client don't want to use all of them, he can define his own
|
|
init_compiled_charsets() that only adds those that he wants
|
|
*/
|
|
|
|
#ifdef HAVE_UCA_COLLATIONS
|
|
|
|
#ifdef HAVE_CHARSET_ucs2
|
|
extern struct charset_info_st my_charset_ucs2_icelandic_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_latvian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_romanian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_slovenian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_polish_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_estonian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_spanish_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_swedish_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_turkish_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_czech_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_danish_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_lithuanian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_slovak_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_spanish2_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_roman_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_persian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_esperanto_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_hungarian_uca_ci;
|
|
extern struct charset_info_st my_charset_ucs2_croatian_uca_ci;
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_utf8
|
|
extern struct charset_info_st my_charset_utf8_icelandic_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_latvian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_romanian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_slovenian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_polish_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_estonian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_spanish_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_swedish_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_turkish_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_czech_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_danish_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_lithuanian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_slovak_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_spanish2_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_roman_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_persian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_esperanto_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_hungarian_uca_ci;
|
|
extern struct charset_info_st my_charset_utf8_croatian_uca_ci;
|
|
#ifdef HAVE_UTF8_GENERAL_CS
|
|
extern struct charset_info_st my_charset_utf8_general_cs;
|
|
#endif
|
|
#endif
|
|
|
|
#endif /* HAVE_UCA_COLLATIONS */
|
|
|
|
my_bool init_compiled_charsets(myf flags __attribute__((unused)))
|
|
{
|
|
CHARSET_INFO *cs;
|
|
|
|
add_compiled_collation(&my_charset_bin);
|
|
add_compiled_collation(&my_charset_filename);
|
|
|
|
add_compiled_collation(&my_charset_latin1);
|
|
add_compiled_collation(&my_charset_latin1_bin);
|
|
add_compiled_collation(&my_charset_latin1_german2_ci);
|
|
|
|
#ifdef HAVE_CHARSET_big5
|
|
add_compiled_collation(&my_charset_big5_chinese_ci);
|
|
add_compiled_collation(&my_charset_big5_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_cp1250
|
|
add_compiled_collation(&my_charset_cp1250_czech_ci);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_cp932
|
|
add_compiled_collation(&my_charset_cp932_japanese_ci);
|
|
add_compiled_collation(&my_charset_cp932_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_latin2
|
|
add_compiled_collation(&my_charset_latin2_czech_ci);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_eucjpms
|
|
add_compiled_collation(&my_charset_eucjpms_japanese_ci);
|
|
add_compiled_collation(&my_charset_eucjpms_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_euckr
|
|
add_compiled_collation(&my_charset_euckr_korean_ci);
|
|
add_compiled_collation(&my_charset_euckr_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_gb2312
|
|
add_compiled_collation(&my_charset_gb2312_chinese_ci);
|
|
add_compiled_collation(&my_charset_gb2312_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_gbk
|
|
add_compiled_collation(&my_charset_gbk_chinese_ci);
|
|
add_compiled_collation(&my_charset_gbk_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_sjis
|
|
add_compiled_collation(&my_charset_sjis_japanese_ci);
|
|
add_compiled_collation(&my_charset_sjis_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_tis620
|
|
add_compiled_collation(&my_charset_tis620_thai_ci);
|
|
add_compiled_collation(&my_charset_tis620_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_ucs2
|
|
add_compiled_collation(&my_charset_ucs2_general_ci);
|
|
add_compiled_collation(&my_charset_ucs2_bin);
|
|
#ifdef HAVE_UCA_COLLATIONS
|
|
add_compiled_collation(&my_charset_ucs2_unicode_ci);
|
|
add_compiled_collation(&my_charset_ucs2_icelandic_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_latvian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_romanian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_slovenian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_polish_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_estonian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_spanish_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_swedish_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_turkish_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_czech_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_danish_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_lithuanian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_slovak_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_spanish2_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_roman_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_persian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_esperanto_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_hungarian_uca_ci);
|
|
add_compiled_collation(&my_charset_ucs2_croatian_uca_ci);
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_ujis
|
|
add_compiled_collation(&my_charset_ujis_japanese_ci);
|
|
add_compiled_collation(&my_charset_ujis_bin);
|
|
#endif
|
|
|
|
#ifdef HAVE_CHARSET_utf8
|
|
add_compiled_collation(&my_charset_utf8_general_ci);
|
|
add_compiled_collation(&my_charset_utf8_bin);
|
|
#ifdef HAVE_UTF8_GENERAL_CS
|
|
add_compiled_collation(&my_charset_utf8_general_cs);
|
|
#endif
|
|
#ifdef HAVE_UCA_COLLATIONS
|
|
add_compiled_collation(&my_charset_utf8_unicode_ci);
|
|
add_compiled_collation(&my_charset_utf8_icelandic_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_latvian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_romanian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_slovenian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_polish_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_estonian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_spanish_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_swedish_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_turkish_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_czech_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_danish_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_lithuanian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_slovak_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_spanish2_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_roman_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_persian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_esperanto_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_hungarian_uca_ci);
|
|
add_compiled_collation(&my_charset_utf8_croatian_uca_ci);
|
|
#endif
|
|
#endif
|
|
|
|
/* Copy compiled charsets */
|
|
for (cs=compiled_charsets; cs->name; cs++)
|
|
add_compiled_collation((struct charset_info_st *) cs);
|
|
|
|
return FALSE;
|
|
}
|