mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 23:04:20 +01:00
b388eb004d
bmove_allign -> bmove_align Added OLAP function ROLLUP Split mysql_fix_privilege_tables to a script and a .sql data file Added new (MEMROOT*) functions to avoid calling current_thd() when creating some common objects. Added table_alias_charset, for easier --lower-case-table-name handling Better SQL_MODE handling (Setting complex options also sets sub options) New (faster) assembler string functions for x86 BitKeeper/etc/ignore: added libmysqld/sql_state.c client/mysql.cc: Added SQLSTATE to error messages Added new function put_error() to be able to clean up some old code. client/mysqltest.c: Write ERROR SQLSTATE for all errors dbug/dbug.c: Portability fixes include/m_string.h: Rename bmove_allign as bmove_align include/mysql.h: Added SQLSTATE (for embedded version) include/mysql_com.h: Send correct SQLSTATE for the error to the client libmysql/libmysql.c: Changed default error state to HY000 Applied code cleanup patch libmysqld/Makefile.am: Added sql_state.cc libmysqld/libmysqld.c: Added sqlstate mysql-test/r/analyse.result: Updated results mysql-test/r/ansi.result: Updated results mysql-test/r/auto_increment.result: Updated results mysql-test/r/bdb-deadlock.result: Updated results mysql-test/r/bdb.result: Updated results mysql-test/r/comments.result: Updated results mysql-test/r/create.result: Updated results mysql-test/r/ctype_collate.result: Updated results mysql-test/r/delayed.result: Updated results mysql-test/r/delete.result: Updated results mysql-test/r/derived.result: Updated results mysql-test/r/distinct.result: Updated results mysql-test/r/drop.result: Updated results mysql-test/r/err000001.result: Updated results mysql-test/r/explain.result: Updated results mysql-test/r/flush.result: Updated results mysql-test/r/fulltext.result: Updated results mysql-test/r/func_gconcat.result: Updated results mysql-test/r/func_system.result: Updated results mysql-test/r/grant_cache.result: Updated results mysql-test/r/group_by.result: Updated results mysql-test/r/handler.result: Updated results mysql-test/r/heap.result: Updated results mysql-test/r/heap_btree.result: Updated results mysql-test/r/heap_hash.result: Updated results mysql-test/r/innodb.result: Updated results mysql-test/r/innodb_handler.result: Updated results mysql-test/r/insert_select.result: Updated results mysql-test/r/insert_update.result: Updated results mysql-test/r/join.result: Updated results mysql-test/r/join_outer.result: Updated results mysql-test/r/key.result: Updated results mysql-test/r/lock.result: Updated results mysql-test/r/lock_multi.result: Updated results mysql-test/r/merge.result: Updated results mysql-test/r/multi_update.result: Updated results mysql-test/r/myisam.result: Updated results mysql-test/r/null.result: Updated results mysql-test/r/olap.result: Updated results mysql-test/r/order_by.result: Updated results mysql-test/r/packet.result: Updated results mysql-test/r/query_cache.result: Updated results mysql-test/r/row.result: Updated results mysql-test/r/rpl000001.result: Updated results mysql-test/r/rpl000009.result: Updated results mysql-test/r/rpl_empty_master_crash.result: Updated results mysql-test/r/rpl_log.result: Updated results mysql-test/r/rpl_replicate_do.result: Updated results mysql-test/r/rpl_rotate_logs.result: Updated results mysql-test/r/select.result: Updated results mysql-test/r/select_safe.result: Updated results mysql-test/r/show_check.result: Updated results mysql-test/r/sql_mode.result: Updated results mysql-test/r/subselect.result: Updated results mysql-test/r/temp_table.result: Updated results mysql-test/r/truncate.result: Updated results mysql-test/r/type_blob.result: Updated results mysql-test/r/type_decimal.result: Updated results mysql-test/r/type_float.result: Updated results mysql-test/r/type_ranges.result: Updated results mysql-test/r/union.result: Updated results mysql-test/r/update.result: Updated results mysql-test/r/user_var.result: Updated results mysql-test/r/varbinary.result: Updated results mysql-test/r/variables.result: Updated results mysql-test/t/ansi.test: Test of sql_mode mysql-test/t/derived.test: Updated results mysql-test/t/func_system.test: Make this independen of the MySQL server name mysql-test/t/lowercase_table.test: Cleanup mysql-test/t/olap.test: A lot of new tests mysql-test/t/sql_mode.test: More test for sql_mode mysql-test/t/subselect.test: Added a few new tests (to find a bug in the item_ref code) scripts/Makefile.am: Added mysql_fix_privilege_tables.sql scripts/mysql_fix_privilege_tables.sh: Totally new script. This bascily just pipes mysql_fix_privilege_tables.sql through 'mysql' to 'mysqld' sql/Makefile.am: Added sql_state.cc sql/item.cc: Extended Item_field::eq() to be able to better match GROUP BY fields on the command line. Needed for ROLLUP sql/item.h: Added function to be able to avoid calling current_thd() when doing new Item. sql/item_sum.cc: Moved copy_or_same() and some reset() functions from item_sum.h Needed to be able to access thd->mem_root. sql/item_sum.h: Moved some functions to item_sum.cc Added make_unique() for ROLLUP sql/item_uniq.h: Fixed return value sql/mysql_priv.h: Updated MODE flags sql/mysqld.cc: Added ANSI as it's own mode Moved charset_info variables here Cleaned up handler_count handling (for NT) Added table_alias_charset, for easier --lower-case-table-name handling sql/net_serv.cc: New comment sql/protocol.cc: Send SQLSTATE to client sql/set_var.cc: Better SQL_MODE handling (Setting complex options also sets sub options) sql/set_var.h: Better SQL_MODE handling sql/sql_base.cc: Make alias depend on --lower-case-table-names Make find_item_in_list also check database name sql/sql_cache.cc: Indentation cleanup sql/sql_list.h: Added safety assert Addes support of alloc without current_thd() sql/sql_prepare.cc: Update after prototype change sql/sql_select.cc: Added ROLLUP sql/sql_select.h: structures for rollup sql/sql_show.cc: Easier SQL_MODE handling sql/sql_string.cc: Move CHARSET_INFO to mysqld (to be together with all other global variables) sql/sql_string.h: Added function to be able to avoid calling current_thd() when doing new Item. sql/sql_table.cc: Simpler --lower-case-table-name handling sql/sql_union.cc: Update after prototype change sql/sql_yacc.yy: ROLLUP sql/unireg.h: bmove_allign ->bmove_align strings/Makefile.am: Fix to be able to compile str_test.c strings/ctype.c: Removed empty lines strings/str_test.c: Added test of bmove_align strings/strings-x86.s: Faster bmove_align, bmove_upp and strmake strings/strings.asm: move_allg
278 lines
9.5 KiB
C
278 lines
9.5 KiB
C
/* Copyright (C) 2000-2003 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; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
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 */
|
|
|
|
/* Test of all stringfunktions that is coded in assembler */
|
|
|
|
#include <my_global.h>
|
|
#include <stdarg.h>
|
|
#include "m_string.h"
|
|
|
|
#define F_LEN 8
|
|
#define F_CHAR 'A'
|
|
#define F_FILL 'B'
|
|
#define T_LEN 15
|
|
#define T_CHAR 'D'
|
|
#define T_FILL 'E'
|
|
#define F_PREFILL '0'
|
|
#define T_PREFILL '1'
|
|
|
|
static char from_buff[100],to_buff[100];
|
|
static my_string from,to;
|
|
static int errors,tests;
|
|
static int test_strarg(const char *name,...);
|
|
static void init_strings (void); /* Init from and to */
|
|
void test_arg (const char *message,long func_value,long value);
|
|
int compare_buff(const char *message,my_string b1,my_string b2,int length,
|
|
pchar fill, pchar prefill);
|
|
|
|
static int my_test(int a)
|
|
{
|
|
return a ? 1 : 0;
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
static char v1[]="Monty",v2[]="on",v3[]="Montys",v4[]="ty",v5[]="gr",
|
|
v6[]="hohohoo",v7[]="hohoo",v8[]="hohooo",v9[]="t",
|
|
cont[]="qwet";
|
|
errors=tests=0;
|
|
init_strings();
|
|
|
|
test_arg("bcmp(from,to,5)",(long) my_test(bcmp(from,to,5)),1L);
|
|
test_arg("bcmp(from,from,5)",(long) bcmp(from,from,5),0L);
|
|
|
|
test_arg("bcmp(from,to,0)",(long) bcmp(from,to,0),0L);
|
|
test_arg("strend(from)",(long) strend(from),(long) from+F_LEN);
|
|
test_arg("strchr(v1,'M')",(long) strchr(v1,'M'),(long) v1);
|
|
test_arg("strchr(v1,'y')",(long) strchr(v1,'y'),(long) v1+4);
|
|
test_arg("strchr(v1,'x')",(long) strchr(v1,'x'),0L);
|
|
test_arg("strcont(v1,cont)",(long) strcont(v1,cont),(long) v1+3);
|
|
test_arg("strcont(v1,v2)",(long) strcont(v1,v2),(long) v1+1);
|
|
test_arg("strcont(v1,v5)",(long) strcont(v1,v5),0L);
|
|
test_arg("is_prefix(v3,v1)",(long) is_prefix(v3,v1),1L);
|
|
test_arg("is_prefix(v1,v3)",(long) is_prefix(v1,v3),0L);
|
|
test_arg("is_prefix(v3,v4)",(long) is_prefix(v3,v4),0L);
|
|
test_arg("strstr(v1,v1)",(long) strstr(v1,v1),(long) v1);
|
|
test_arg("strstr(v1,v2)",(long) strstr(v1,v2),(long) v1+1);
|
|
test_arg("strstr(v1,v4)",(long) strstr(v1,v4),(long) v1+3);
|
|
test_arg("strstr(v6,v7)",(long) strstr(v6,v7),(long) v6+2);
|
|
test_arg("strstr(v1,v9)",(long) strstr(v1,v9),(long) v1+3);
|
|
test_arg("strstr(v1,v3)",(long) strstr(v1,v3),0L);
|
|
test_arg("strstr(v1,v5)",(long) strstr(v1,v5),0L);
|
|
test_arg("strstr(v6,v8)",(long) strstr(v6,v8),0L);
|
|
|
|
test_arg("strinstr(v1,v4)",(long) strinstr(v1,v4),4L);
|
|
test_arg("strinstr(v1,v5)",(long) strinstr(v1,v5),0L);
|
|
test_arg("strlen(from)",(long) strlen(from),(long) F_LEN);
|
|
test_arg("strlen(\"\")",(long) strlen(""),0L);
|
|
#ifdef HAVE_STRNLEN
|
|
test_arg("strnlen(from,3)",(long) strnlen(from,3),3L);
|
|
test_arg("strnlen(from,0)",(long) strnlen(from,0),0L);
|
|
test_arg("strnlen(from,1000)",(long) strnlen(from,1000),(long) F_LEN);
|
|
#endif
|
|
|
|
test_strarg("bfill(to,4,' ')",(bfill(to,4,' '),0L),INT_MAX32,4,' ',0,0);
|
|
test_strarg("bfill(from,0,' ')",(bfill(from,0,' '),0L),INT_MAX32,0,0);
|
|
test_strarg("bzero(to,3)",(bzero(to,3),0L),INT_MAX32,3,0,0,0);
|
|
test_strarg("bzero(to,0)",(bzero(to,0),0L),INT_MAX32,0,0);
|
|
test_strarg("bmove(to,from,4)",(bmove(to,from,4),0L),INT_MAX32,4,F_CHAR,
|
|
0,0);
|
|
test_strarg("bmove(to,from,0)",(bmove(to,from,0),0L),INT_MAX32,0,0);
|
|
test_strarg("bmove_upp(to+6,from+6,3)",(bmove_upp(to+6,from+6,3),0L),INT_MAX32,
|
|
3,T_CHAR,3,F_CHAR,0,0);
|
|
test_strarg("bmove_upp(to,from,0)",(bmove_upp(to,from,0),0L),INT_MAX32,0,0);
|
|
test_strarg("bmove_align(to,from,8)",(bmove_align(to,from,8),0L),INT_MAX32,
|
|
8,F_CHAR,0,0);
|
|
test_strarg("strappend(to,3,' ')",(strappend(to,3,' '),0L),INT_MAX32,
|
|
3,T_CHAR,1,0,T_LEN-4,T_CHAR,1,0,0,0);
|
|
test_strarg("strappend(to,T_LEN+5,' ')",(strappend(to,T_LEN+5,' '),0L),INT_MAX32,
|
|
T_LEN,T_CHAR,5,' ',1,0,0,0);
|
|
test_strarg("strcat(to,from)",strcat(to,from),to,T_LEN,T_CHAR,
|
|
F_LEN,F_CHAR,1,0,0,0);
|
|
test_strarg("strcat(to,\"\")",strcat(to,""),INT_MAX32,0,0);
|
|
test_strarg("strfill(to,4,' ')",strfill(to,4,' '),to+4,4,' ',1,0,0,0);
|
|
test_strarg("strfill(from,0,' ')",strfill(from,0,' '),from,0,1,0,0);
|
|
test_strarg("strmake(to,from,4)",strmake(to,from,4),to+4,4,F_CHAR,
|
|
1,0,0,0);
|
|
test_strarg("strmake(to,from,0)",strmake(to,from,0),to+0,1,0,0,0);
|
|
test_strarg("strmov(to,from)",strmov(to,from),to+F_LEN,F_LEN,F_CHAR,0,0);
|
|
test_strarg("strmov(to,\"\")",strmov(to,""),to,1,0,0,0);
|
|
test_strarg("strnmov(to,from,2)",strnmov(to,from,2),to+2,2,F_CHAR,0,0);
|
|
test_strarg("strnmov(to,from,F_LEN+5)",strnmov(to,from,F_LEN+5),to+F_LEN,
|
|
F_LEN,F_CHAR,1,0,0,0);
|
|
test_strarg("strnmov(to,\"\",2)",strnmov(to,"",2),to,1,0,0,0);
|
|
test_strarg("strxmov(to,from,\"!!\",NullS)",strxmov(to,from,"!!",NullS),to+F_LEN+2,F_LEN,F_CHAR,2,'!',0,0,0);
|
|
test_strarg("strxmov(to,NullS)",strxmov(to,NullS),to,1,0,0,0);
|
|
test_strarg("strxmov(to,from,from,from,from,from,'!!',from,NullS)",strxmov(to,from,from,from,from,from,"!!",from,NullS),to+F_LEN*6+2,F_LEN,F_CHAR,F_LEN,F_CHAR,F_LEN,F_CHAR,F_LEN,F_CHAR,F_LEN,F_CHAR,2,'!',F_LEN,F_CHAR,1,0,0,0);
|
|
|
|
test_strarg("strxnmov(to,100,from,\"!!\",NullS)",strxnmov(to,100,from,"!!",NullS),to+F_LEN+2,F_LEN,F_CHAR,2,'!',0,0,0);
|
|
test_strarg("strxnmov(to,2,NullS)",strxnmov(to,2,NullS),to,1,0,0,0);
|
|
test_strarg("strxnmov(to,100,from,from,from,from,from,'!!',from,NullS)",strxnmov(to,100,from,from,from,from,from,"!!",from,NullS),to+F_LEN*6+2,F_LEN,F_CHAR,F_LEN,F_CHAR,F_LEN,F_CHAR,F_LEN,F_CHAR,F_LEN,F_CHAR,2,'!',F_LEN,F_CHAR,1,0,0,0);
|
|
test_strarg("strxnmov(to,2,\"!!!\",NullS)",strxnmov(to,2,"!!!",NullS),to+2,2,'!',0,0,0);
|
|
test_strarg("strxnmov(to,2,\"!!\",NullS)",strxnmov(to,2,"!!","xx",NullS),to+2,2,'!',0,0,0);
|
|
test_strarg("strxnmov(to,2,\"!\",\"x\",\"y\",NullS)",strxnmov(to,2,"!","x","y",NullS),to+2,1,'!',1,'x',0,0,0);
|
|
|
|
test_strarg("bchange(to,2,from,4,6)",(bchange(to,2,from,4,6),0L),INT_MAX32,
|
|
4,F_CHAR,2,T_CHAR,0,0);
|
|
|
|
printf("tests: %d errors: %d\n",tests,errors);
|
|
if (errors)
|
|
fputs("--- Some functions doesn't work!! Fix them\n",stderr);
|
|
return(errors > 0);
|
|
} /* main */
|
|
|
|
|
|
/* Init strings */
|
|
|
|
void init_strings(void)
|
|
{
|
|
reg1 int i;
|
|
reg2 char *pos;
|
|
|
|
from=from_buff+3; to=to_buff+3;
|
|
|
|
pos=from_buff; *pos++= F_FILL; *pos++=F_FILL; *pos++=F_PREFILL;
|
|
for (i=0 ; i < F_LEN ; i++)
|
|
*pos++=F_CHAR;
|
|
*pos++=0;
|
|
for (i=0; i<50 ; i++)
|
|
*pos++= F_FILL;
|
|
|
|
pos=to_buff; *pos++= T_FILL; *pos++=T_FILL; *pos++=T_PREFILL;
|
|
for (i=0 ; i < T_LEN ; i++)
|
|
*pos++=T_CHAR;
|
|
*pos++=0;
|
|
for (i=0; i<50 ; i++)
|
|
*pos++= T_FILL;
|
|
} /* init_strings */
|
|
|
|
|
|
/* Test that function return rigth value */
|
|
|
|
void test_arg(const char *message, long int func_value, long int value)
|
|
{
|
|
tests++;
|
|
printf("testing '%s'\n",message);
|
|
if (func_value != value)
|
|
{
|
|
printf("func: '%s' = %ld Should be: %ld\n",message,func_value,value);
|
|
errors++;
|
|
}
|
|
} /* test_arg */
|
|
|
|
/* Test function return value and from and to arrays */
|
|
|
|
static int test_strarg(const char *message,...)
|
|
{
|
|
long func_value,value;
|
|
int error,length;
|
|
char chr,cmp_buff[100],*pos,*pos2;
|
|
va_list pvar;
|
|
|
|
tests++;
|
|
va_start(pvar,message);
|
|
func_value=va_arg(pvar,long);
|
|
value=va_arg(pvar,long);
|
|
|
|
printf("testing '%s'\n",message);
|
|
if (func_value != value && value != INT_MAX32)
|
|
{
|
|
printf("func: '%s' = %ld Should be: %ld\n",message,func_value,value);
|
|
errors++;
|
|
}
|
|
pos= cmp_buff;
|
|
while ((length = va_arg(pvar, int)) != 0)
|
|
{
|
|
chr= (char) (va_arg(pvar, int));
|
|
while (length--)
|
|
*pos++=chr;
|
|
}
|
|
pos2=to+ (int)(pos-cmp_buff);
|
|
while (pos <= cmp_buff+T_LEN)
|
|
*pos++= *pos2++;
|
|
if (compare_buff(message,to,cmp_buff,(int) (pos-cmp_buff),T_FILL,T_PREFILL))
|
|
{
|
|
init_strings();
|
|
va_end(pvar);
|
|
return 1;
|
|
}
|
|
|
|
pos= cmp_buff;
|
|
while ((length = va_arg(pvar, int)) != 0)
|
|
{
|
|
chr= (char) (va_arg(pvar, int));
|
|
while (length--)
|
|
*pos++=chr;
|
|
}
|
|
pos2=from+ (int)(pos-cmp_buff);
|
|
while (pos <= cmp_buff+F_LEN)
|
|
*pos++= *pos2++;
|
|
error=compare_buff(message,from,cmp_buff,(int) (pos-cmp_buff),F_FILL,F_PREFILL);
|
|
init_strings();
|
|
va_end(pvar);
|
|
return (error != 0);
|
|
} /* test_strarg */
|
|
|
|
|
|
/* test if function made right value */
|
|
|
|
int compare_buff(const char *message, my_string b1, my_string b2, int length,
|
|
pchar fill, pchar prefill)
|
|
{
|
|
int i,error=0;
|
|
|
|
if (bcmp(b1,b2,length))
|
|
{
|
|
errors++;
|
|
printf("func: '%s' Buffers differ\nIs: ",message);
|
|
for (i=0 ; i<length ; i++)
|
|
printf("%3d ",b1[i]);
|
|
printf("\nShould be: ");
|
|
for (i=0 ; i<length ; i++)
|
|
printf("%3d ",b2[i]);
|
|
puts("");
|
|
}
|
|
else if (b1[-1] != prefill || b1[-2] != fill || b1[-3] != fill)
|
|
{
|
|
printf("func: '%s' Chars before buffer is changed\n",message);
|
|
errors++;
|
|
error=1;
|
|
}
|
|
else if (b1[length] != fill || b1[length+1] != fill)
|
|
{
|
|
printf("func: '%s' Chars after buffer is changed\n",message);
|
|
errors++;
|
|
error=1;
|
|
}
|
|
return error;
|
|
} /* compare_buff */
|
|
|
|
/* These are here to be loaded and examined */
|
|
|
|
extern void dummy_functions(void);
|
|
|
|
void dummy_functions(void)
|
|
{
|
|
VOID(memchr(from,'a',5));
|
|
VOID(memcmp(from,to,5));
|
|
VOID(memcpy(from,to,5));
|
|
VOID(memset(from,' ',5));
|
|
VOID(strcmp(from,to));
|
|
VOID(strcpy(from,to));
|
|
VOID(strstr(from,to));
|
|
VOID(strrchr(from,'a'));
|
|
return;
|
|
}
|