summaryrefslogtreecommitdiff
path: root/fs/database.c
diff options
context:
space:
mode:
authorunknown <monty@narttu.mysql.fi>2003-04-22 22:41:59 +0300
committerunknown <monty@narttu.mysql.fi>2003-04-22 22:41:59 +0300
commitac02f54022f2a64ada230ef4a3f446b26b143275 (patch)
tree5d018897c694206dbaf1995bb7862e5d5ad8a93d /fs/database.c
parent43f1511a31a8e47682410ca5b02eb0dd4aba16d8 (diff)
downloadmariadb-git-ac02f54022f2a64ada230ef4a3f446b26b143275.tar.gz
Removed some not used files
Remove the 'fs' file systems as this is not maintained. Moved programs from client to tests tests/deadlock_test.c: Rename: div/deadlock_test.c -> tests/deadlock_test.c BitKeeper/deleted/.del-CorbaFS.idl~719ba9d93c206620: Delete: fs/CorbaFS.idl BitKeeper/deleted/.del-Makefile.am~95f21e278745904c: Delete: fs/Makefile.am BitKeeper/deleted/.del-RunServer.sh~34ea2653535fbb5c: Delete: fs/RunServer.sh BitKeeper/deleted/.del-database.c~af098622e818ce0d: Delete: fs/database.c BitKeeper/deleted/.del-dump.sql~68646092f0c5bc96: Delete: fs/dump.sql BitKeeper/deleted/.del-korbit-kernel-2.4.1-patch~742e5e67c1132b2e: Delete: fs/korbit-kernel-2.4.1-patch BitKeeper/deleted/.del-libmysqlfs.c~70cc07d61deedd16: Delete: fs/libmysqlfs.c BitKeeper/deleted/.del-libmysqlfs.h~7b60f308be50370e: Delete: fs/libmysqlfs.h BitKeeper/deleted/.del-my.cnf~bbd975fd6377e704: Delete: fs/my.cnf BitKeeper/deleted/.del-mysqlcorbafs.c~fc58c116eeea996a: Delete: fs/mysqlcorbafs.c BitKeeper/deleted/.del-mysqlcorbafs.h~414821d6836e655a: Delete: fs/mysqlcorbafs.h BitKeeper/deleted/.del-mysqlcorbafs_test.c~8bb3afa230542e05: Delete: fs/mysqlcorbafs_test.c BitKeeper/deleted/.del-README~b9f437fbd6dce7a5: Delete: fs/README BitKeeper/deleted/.del-mysqlfsck~247a2d2b9729b95e: Delete: fs/mysqlfsck tests/insert_test.c: Rename: client/insert_test.c -> tests/insert_test.c tests/list_test.c: Rename: client/list_test.c -> tests/list_test.c tests/select_test.c: Rename: client/select_test.c -> tests/select_test.c BitKeeper/deleted/.del-thimble.cc~3fa3754a4c639242: Delete: client/thimble.cc tests/thread_test.c: Rename: client/thread_test.c -> tests/thread_test.c tests/connect_test.c: Rename: client/connect_test.c -> tests/connect_test.c tests/showdb_test.c: Rename: client/showdb_test.c -> tests/showdb_test.c tests/ssl_test.c: Rename: client/ssl_test.c -> tests/ssl_test.c BitKeeper/deleted/.del-mysql_install.c~8c089740d79a92: Delete: extra/mysql_install.c BitKeeper/deleted/.del-cache_manager.cc~c506b365b140d30c: Delete: sql/cache_manager.cc BitKeeper/deleted/.del-cache_manager.h~adb8639e510c6f6e: Delete: sql/cache_manager.h client/Makefile.am: Move insert_test, select_test and thread_test under 'tests' extra/Makefile.am: Remove not used program mysql_install sql/item_strfunc.cc: Simple optimization sql/item_sum.cc: Simple code cleanup. tests/Makefile.am: Added test programs
Diffstat (limited to 'fs/database.c')
-rw-r--r--fs/database.c628
1 files changed, 0 insertions, 628 deletions
diff --git a/fs/database.c b/fs/database.c
deleted file mode 100644
index 0ff12e433ee..00000000000
--- a/fs/database.c
+++ /dev/null
@@ -1,628 +0,0 @@
-/* Copyright (C) 2000 db AB & db Finland AB & TCX DataKonsult 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
- */
-
-/*
- * Database functions
- *
- * Using these functions we emulate filesystem behaviour on top of SQL
- * database.
- * Written by Tõnu Samuel <tonu@please.do.not.remove.this.spam.ee>
- *
- * FIXME:
- * - Direct handling of database handlers without SQL parsing overhead
- * - connection pool
- * - configurable function name/file name mappings
- */
-
-
-#include "libmysqlfs.h"
-#include "mysqlcorbafs.h"
-#include <unistd.h>
-#include <string.h>
-#include <my_sys.h>
-
-DYNAMIC_ARRAY field_array;
-
-/*
- * ** dbConnect -- connects to the host and selects DB.
- * ** Also checks whether the tablename is a valid table name.
- * */
-int db_connect(char *host, char *user,char *passwd)
-{
- DBUG_ENTER("db_connect");
- DBUG_PRINT("enter",("host: '%s', user: '%s', passwd: '%s'", host, user, passwd));
-
- if (verbose)
- {
- fprintf(stderr, "# Connecting to %s...\n", host ? host : "localhost");
- }
- mysql_init(&connection);
- if (opt_compress)
- mysql_options(&connection,MYSQL_OPT_COMPRESS,NullS);
-#ifdef HAVE_OPENSSL
- if (opt_use_ssl)
- mysql_ssl_set(&connection, opt_ssl_key, opt_ssl_cert, opt_ssl_ca,
- opt_ssl_capath);
-#endif
- if (!(sock= mysql_real_connect(&connection,host,user,passwd,
- NULL,opt_mysql_port,opt_mysql_unix_port,0)))
- {
- DBerror(&connection, "when trying to connect");
- DBUG_RETURN(1);
- }
- DBUG_RETURN(0);
-} /* dbConnect */
-
-
-/*
- * ** dbDisconnect -- disconnects from the host.
- * */
-void db_disconnect(char *host)
-{
- DBUG_ENTER("db_disconnect");
- DBUG_PRINT("enter",("host: '%s'", host));
- if (verbose)
- fprintf(stderr, "# Disconnecting from %s...\n", host ? host : "localhost");
- mysql_close(sock);
- DBUG_VOID_RETURN;
-} /* dbDisconnect */
-
-#define OUTPUT(x) strcpy(buffptr,x); buffptr+=strlen(x);
-#define OUTPUT_TOP(x) strcpy(topptr,x); topptr+=strlen(x);
-#define OUTPUT_MIDDLE(x) strcpy(midptr,x); midptr+=strlen(x);
-#define OUTPUT_BOTTOM(x) strcpy(botptr,x); botptr+=strlen(x);
-#define OUTPUT_HEADER(x) strcpy(hdrptr,x); hdrptr+=strlen(x);
-
-void db_show_result(MYSQL* sock, char *b, struct format *f)
-{
- MYSQL_ROW row;
- MYSQL_RES *result;
- MYSQL_FIELD *field;
- char *buffptr;
- char topseparator[BUFLEN]="";
- char middleseparator[BUFLEN]="";
- char bottomseparator[BUFLEN]="";
- char header[BUFLEN]="";
- char *topptr=topseparator;
- char *midptr=middleseparator;
- char *botptr=bottomseparator;
- char *hdrptr=header;
- uint i,count, length;
-
- DBUG_ENTER("db_show_result");
- DBUG_PRINT("enter",("b: '%s', f '%x'", b, f));
-
- result=mysql_store_result(sock);
-
- buffptr=b;
- OUTPUT(f->tablestart)
-
- OUTPUT_TOP(f->leftuppercorner);
- OUTPUT_MIDDLE(f->leftcross);
- OUTPUT_BOTTOM(f->leftdowncorner);
- OUTPUT_HEADER(f->headerrowstart);
-
-
- count=mysql_num_fields(result);
-// while ((field = mysql_fetch_field(result)))
- for(i=0 ; i < count ; ++i)
- {
- field = mysql_fetch_field(result);
- length=(uint) strlen(field->name);
- OUTPUT_HEADER(f->headercellstart);
-
- length=max(length,field->max_length);
- if (length < 4 && !IS_NOT_NULL(field->flags))
- length=4; // Room for "NULL"
- field->max_length=length;
-
- memset(topptr,'=',field->max_length);
- memset(midptr,'-',field->max_length);
- memset(botptr,'=',field->max_length);
-
- sprintf(hdrptr,"%-*s",field->max_length,field->name);
- //num_flag[off]= IS_NUM(field->type);
-
- topptr+=field->max_length;
- midptr+=field->max_length;
- botptr+=field->max_length;
- hdrptr+=field->max_length;
-
- if(i<count-1) {
- OUTPUT_TOP(f->topcross);
- OUTPUT_MIDDLE(f->middlecross);
- OUTPUT_BOTTOM(f->bottomcross);
- OUTPUT_HEADER(f->headercellseparator);
- }
- }
- OUTPUT_TOP(f->rightuppercorner);
- OUTPUT_MIDDLE(f->rightcross);
- OUTPUT_BOTTOM(f->rightdowncorner);
-
- OUTPUT_HEADER(f->headercellend);
- OUTPUT_HEADER(f->headerrowend);
-
- OUTPUT(topseparator);
- OUTPUT(header);
- OUTPUT(middleseparator);
- while(row=mysql_fetch_row(result)) {
- mysql_field_seek(result,0);
-
- OUTPUT(f->contentrowstart);
- for(i=0 ; i < mysql_field_count(sock); ++i) {
- field = mysql_fetch_field(result);
- OUTPUT(f->contentcellstart);
- sprintf(buffptr,"%-*s",field->max_length,row[i]);
- buffptr+=field->max_length;
-
- if(i==mysql_field_count(sock))
- {
- OUTPUT(f->contentcellend);
- } else {
- OUTPUT(f->contentcellseparator);
- }
- }
- OUTPUT(f->contentrowend);
- }
- OUTPUT(bottomseparator);
- OUTPUT(f->tableend);
-
- mysql_free_result(result);
- DBUG_VOID_RETURN;
-}
-
-
-int db_function(char *b,const char *server, const char *database,const char *table,const char *field, const char *value, const char* path, struct func_st *function)
-{
- char buff[BUFLEN];
- int i;
- DBUG_ENTER("db_function");
- DBUG_PRINT("enter",("buffer: '%s', database: '%s', table: '%s', field: '%s', path: '%s'", b, database, table, field,path));
-
- if(*database) {
- if (mysql_select_db(sock,database))
- {
- printf("error when changing database to'%s'\n",database);
- DBUG_RETURN(-1);
- }
- }
-
- sprintf(buff,"%s",function->function);
- search_and_replace("$database",database,buff);
- search_and_replace("$table",table,buff);
- search_and_replace("$field",field,buff);
- search_and_replace("$value",value,buff);
- DBUG_PRINT("info",("path: '%s'",path));
- DBUG_PRINT("info",("sum: '%d'",(database[0] ? strlen(database)+1 : 0) +(table[0] ? strlen(table)+1 : 0) +(field[0] ? strlen(field)+1 : 0) +(value[0] ? strlen(value)+1 : 0) +1));
- search_and_replace("$*",path+
- (server[0] ? strlen(server)+1 : 0) +
- (database[0] ? strlen(database)+1 : 0) +
- (table[0] ? strlen(table)+1 : 0) +
- (field[0] ? strlen(field)+1 : 0) +
- (value[0] ? strlen(value)+1 : 0) +
- function->length +
- 1,buff);
- DBUG_PRINT("info",("Executing constructed function query: '%s'", buff));
- if (mysql_query(sock, buff))
- {
- printf("error when executing '%s'\n",buff);
- sprintf(b,"ERROR %d: %s",mysql_error(sock),mysql_error(sock));
- DBUG_VOID_RETURN;
- }
-
- db_show_result(sock, b, &Human);
- DBUG_PRINT("info",("Returning: %s", b));
- DBUG_RETURN(1);
-}
-
-int db_show_field(char *b,const char *database,const char *table, const char *field,const char *value, const char *param)
-{
- MYSQL_RES *result;
- MYSQL_ROW row;
- char buff[BUFLEN];
- int i=0;
- my_string *ptr;
- DBUG_ENTER("db_show_field");
- DBUG_PRINT("enter",("buffer: '%s', database: '%s', table: '%s', field: '%s' value: '%s'", b, database, table, field, value));
-
- /* We cant output fields when one of these variables is missing */
- if (!(database[0] && table[0] && field[0]))
- DBUG_RETURN(-1);
-
- my_init_dynamic_array(&field_array, sizeof(buff), 4096, 1024);
-
- if (mysql_select_db(sock,database))
- {
- printf("error when changing database to'%s'\n",database);
- delete_dynamic(&field_array);
- DBUG_RETURN(-1);
- }
-
- if(param) {
- sprintf(buff,"%s",param);
- } else {
- sprintf(buff,"select %s from %s where %s='%s' LIMIT 1",field,table,field,value);
- }
- if (mysql_query(sock, buff))
- {
- printf("error when executing '%s'\n",buff);
- delete_dynamic(&field_array);
- DBUG_RETURN(-1);
- }
-
-
- db_show_result(sock,b,&Human);
-/* if(result=mysql_use_result(sock)) {
- while(row=mysql_fetch_row(result))
- {
- strcpy(&b[i][BUFLEN],row[0]);
- DBUG_PRINT("info",("field %s at %x", &b[i*BUFLEN],&b[i*BUFLEN]));
-// ptr = (*dynamic_element(&field_array,i,row[0]));
- i++;
- }
- }
-// fix_filenames((char *)b);
- mysql_free_result(result);
- */
- delete_dynamic(&field_array);
- DBUG_RETURN(i);
-
-}
-int db_show_fields(char *b,const char *database,const char *table)
-{
- MYSQL_RES *result;
- MYSQL_ROW row;
- MYSQL_FIELD *field;
- char buff[BUFLEN];
- int i=0;
-
- DBUG_ENTER("show_fields");
- DBUG_PRINT("enter",("buffer: '%s', database: '%s', table: '%s'", b, database, table));
- if (mysql_select_db(sock,database))
- {
- printf("error when changing database to'%s'\n",database);
- DBUG_RETURN(-1);
- }
- if(result=mysql_list_fields(sock,buff,NULL)) {
-
- while(row=mysql_fetch_row(result))
- {
- strcpy(&b[i*BUFLEN],row[0]);
- DBUG_PRINT("info",("field %s at %x", &b[i*BUFLEN],&b[i*BUFLEN]));
- i++;
- }
- }
- mysql_free_result(result);
- DBUG_RETURN(i);
-}
-
-int db_show_primary_keys(char *b,const char *database, const char *table)
-{
- MYSQL_RES *result;
- MYSQL_ROW row;
- char buff[BUFLEN];
- char buff2[BUFLEN];
- unsigned int i;
-
- DBUG_ENTER("db_show_primary_keys");
- DBUG_PRINT("enter",("buffer: '%s', database: '%s', table: '%s'", b, database, table));
- if (mysql_select_db(sock,database))
- {
- printf("error when changing database to '%s'\n",database);
- DBUG_RETURN(-1);
- }
- sprintf(buff,"show keys from %s",table);
- if (mysql_query(sock, buff))
- {
- printf("error when executing '%s'\n",buff);
- DBUG_RETURN(0);
- }
- buff2[0]='\0';
- if(result=mysql_use_result(sock)) {
- while(row=mysql_fetch_row(result)) {
- if(!strcasecmp(row[2],"PRIMARY")) {
- strcat(buff2,row[4]);
- strcat(buff2,",\"_\",");
- }
- }
- buff2[strlen(buff2)-5]='\0';
- if(!buff2[0])
- DBUG_RETURN(-1); // No PRIMARY keys in table
- DBUG_PRINT("info",("Keys: %s<- \n", buff2));
- } else
- DBUG_RETURN(-1); // No keys in table
-
- sprintf(buff,"SELECT CONCAT(%s) AS X FROM %s LIMIT 256",buff2,table);
- if (mysql_query(sock, buff))
- {
- printf("error when executing '%s'\n",buff);
- DBUG_RETURN(0);
- }
- i=0;
- if(result=mysql_use_result(sock)) {
- while(row=mysql_fetch_row(result))
- {
- strcpy(&b[i*BUFLEN],row[0]);
- fix_filenames(&b[i*BUFLEN]);
- DBUG_PRINT("info",("primarykey %s at %x, %i", &b[i*BUFLEN],&b[i*BUFLEN],i));
- if(i++ >= MAXDIRS)
- break;
- }
- }
- mysql_free_result(result);
- DBUG_RETURN(i);
-}
-
-
-int db_show_keys(char *b,const char *database, const char *table)
-{
- MYSQL_RES *result;
- MYSQL_ROW row;
- char buff[BUFLEN];
- int i=0;
-
- DBUG_ENTER("show_keys");
- DBUG_PRINT("enter",("buffer: '%s', database: '%s', table: '%s'", b, database, table));
- if (mysql_select_db(sock,database))
- {
- printf("error when changing database to'%s'\n",database);
- DBUG_RETURN(-1);
- }
- sprintf(buff,"show keys from %s",table);
- if (mysql_query(sock, buff))
- {
- printf("error when executing '%s'\n",buff);
- DBUG_RETURN(0);
- }
- if(result=mysql_use_result(sock)) {
- while(row=mysql_fetch_row(result))
- {
- strcpy(&b[i*BUFLEN],row[0]);
- DBUG_PRINT("info",("Key %s at %x", &b[i*BUFLEN],&b[i*BUFLEN]));
- i++;
- }
- }
- mysql_free_result(result);
- DBUG_RETURN(i);
-}
-
-
-int db_show_tables(char *b,const char *database)
-{
- MYSQL_RES *result;
- MYSQL_ROW row;
- char buff[BUFLEN];
- int i=0;
-
- DBUG_ENTER("db_show_tables");
- DBUG_PRINT("enter",("buffer: '%s', database: '%s'", b, database));
- if (mysql_select_db(sock,database))
- {
- printf("error when changing database to '%s'\n",database);
- DBUG_RETURN(-1);
- }
-
- if(result=mysql_list_tables(sock,NULL)) {
- while(row=mysql_fetch_row(result))
- {
- strcpy(&b[i*BUFLEN],row[0]);
- DBUG_PRINT("info",("table %s at %x", &b[i*BUFLEN],&b[i*BUFLEN]));
- i++;
- }
- }
- mysql_free_result(result);
- DBUG_RETURN(i);
-}
-
-/*
- * Finds all servers we are connected to
- * and stores them in array supplied.
- * returns count of servers
- */
-int
-db_show_servers(char *b,int size)
-{
- char* bufptr;
- char* buff[BUFLEN*2];
- DBUG_ENTER("db_show_servers");
- DBUG_PRINT("enter",("buffer: '%s', size: '%d'", b, size));
- bufptr=mysql_get_host_info(sock);
- // FIXME: Actually we need to escape prohibited symbols in filenames
- fix_filenames(bufptr);
- strcpy(b,bufptr);
- DBUG_RETURN(1);
-}
-
-/*
- * Finds all databases in server
- * and stores them in array supplied.
- * returns count of databases
- */
-int
-db_show_databases(char *b,int size)
-{
- MYSQL_RES *result;
- MYSQL_ROW row;
- char buff[BUFLEN];
- int i=0;
-
- DBUG_ENTER("db_show_databases");
- DBUG_PRINT("enter",("buffer: '%s', size: '%d'", b, size));
- result=mysql_list_dbs(sock,NULL);
- while(row=mysql_fetch_row(result))
- {
- strcpy(&b[i*BUFLEN],row[0]);
- DBUG_PRINT("info",("database %s at %x", &b[i*BUFLEN],&b[i*BUFLEN]));
- i++;
- }
- mysql_free_result(result);
- DBUG_RETURN(i);
-}
-
-void db_load_formats()
-{
-
- /* In future we should read these variables
- * from configuration file/database here */
-
- /* HTML output */
- HTML.tablestart="<table>\n";
-
- HTML.headerrowstart="<tr>";
- HTML.headercellstart="<th>";
- HTML.headercellseparator="</th><th>";
- HTML.headercellend="</th>";
- HTML.headerrowend="</tr>\n";
- HTML.headerformat=0;
-
- HTML.leftuppercorner="";
- HTML.rightuppercorner="";
- HTML.leftdowncorner="";
- HTML.rightdowncorner="";
- HTML.topcross="";
- HTML.middlecross="";
- HTML.bottomcross="";
- HTML.leftcross="";
- HTML.rightcross="";
- HTML.bottomcross="";
-
- HTML.contentrowstart="<tr>";
- HTML.contentcellstart="<td>";
- HTML.contentcellseparator="</td><td>";
- HTML.contentcellend="</td>";
- HTML.contentrowend="</tr>\n";
- HTML.headerformat=0;
-
- HTML.footerrowstart="";
- HTML.footercellstart="";
- HTML.footercellseparator="";
- HTML.footercellend="";
- HTML.footerrowend="\n";
- HTML.footerformat=0;
-
- HTML.tableend="</table>\n";
-
-/* Nice to look mysql client like output */
-
- Human.tablestart="\n";
-
- Human.headerrowstart="| ";
- Human.headercellstart="";
- Human.headercellseparator=" | ";
- Human.headercellend=" |";
- Human.headerrowend="\n";
- Human.headerformat=1;
-
- Human.leftuppercorner="/=";
- Human.rightuppercorner="=\\\n";
- Human.leftdowncorner="\\=";
- Human.rightdowncorner="=/\n";
- Human.leftcross="+-";
- Human.rightcross="-+\n";
- Human.topcross="=T=";
- Human.middlecross="-+-";
- Human.bottomcross="=`=";
-
- Human.contentrowstart="| ";
- Human.contentcellstart="";
- Human.contentcellseparator=" | ";
- Human.contentcellend=" |";
- Human.contentrowend="\n";
- Human.contentformat=1;
-
- Human.footerrowstart="";
- Human.footercellstart="";
- Human.footercellseparator="";
- Human.footercellend="";
- Human.footerrowend="\n";
- Human.footerformat=1;
-
- Human.tableend="\n";
-
-/* Comma-separated format. For machine reading */
-
- /* XML */
-
-/*
- tee_fprintf(PAGER,"<?xml version=\"1.0\"?>\n\n<resultset statement=\"%s\">", statement);
- (void) tee_fputs("\n <row>\n", PAGER);
- data=(char*) my_malloc(lengths[i]*5+1, MYF(MY_WME));
- tee_fprintf(PAGER, "\t<%s>", (fields[i].name ?
- (fields[i].name[0] ? fields[i].name :
- " &nbsp; ") : "NULL"));
- xmlencode(data, cur[i]);
- tee_fprintf(PAGER, "</%s>\n", (fields[i].name ?
- (fields[i].name[0] ? fields[i].name :
- " &nbsp; ") : "NULL"));
- </row>\n" </resultset>\n*/
-}
-
-gptr db_load_functions()
-{
- char *functions[]={
- "database",".tables","SHOW TABLES","0",
- "table",".status","SHOW TABLE STATUS FROM $table","0",
- "table",".count","SELECT COUNT(*) FROM $table","0",
- "table",".table","SELECT * FROM $table","0",
- "table",".check","CHECK TABLE $table","0",
- "table",".repair","REPAIR TABLE $table","0",
- "key",".min","SELECT MIN($key) FROM $table","0",
- "key",".max","SELECT MAX($key) FROM $table","0",
- "key",".avg","SELECT AVG($key) FROM $table","0",
- "server",".uptime","SHOW STATUS like 'Uptime'","0",
- "server",".version","SELECT VERSION()","0",
- "server",".execute","$*","1",
- "root",".connect","CONNECT $*","0",
- NULL,NULL,NULL,NULL
- };
- char buff[BUFLEN];
- int i=0;
- struct func_st func;
- DBUG_ENTER("db_load_functions");
- my_init_dynamic_array(&functions_array, sizeof(struct func_st), 4096, 1024);
- while(functions[i]) {
- strcpy(func.type_s, functions[i]); /* Type in string: "table"` */
- strcpy(func.filename, functions[i+1]); /* Name like it appears on FS: "count" */
- strcpy(func.function, functions[i+2]); /* Query: "SELECT COUNT(*) FROM `%table`" */
- func.continuous= atoi(functions[i+3]); /* Query: "If command can be continued" */
-
- if(!strcasecmp(func.type_s,"server"))
- func.type=SERVER_FUNCTION;
- else if(!strcasecmp(func.type_s,"table"))
- func.type=TABLE_FUNCTION;
- else if(!strcasecmp(func.type_s,"key"))
- func.type=KEY_FUNCTION;
- else if(!strcasecmp(func.type_s,"database"))
- func.type=DATABASE_FUNCTION;
- else if(!strcasecmp(func.type_s,"field"))
- func.type=FIELD_FUNCTION;
- else if(!strcasecmp(func.type_s,"root"))
- func.type=ROOT_FUNCTION;
- else func.type=NONE_FUNCTION;
-
- func.length=strlen(func.filename); /* Filename length */
- DBUG_PRINT("info",("func.type_s: %s",func.type_s));
- DBUG_PRINT("info",("func.filename: %s",func.filename));
- DBUG_PRINT("info",("func.function: %s",func.function));
- DBUG_PRINT("info",("func.type: %d",func.type));
- DBUG_PRINT("info",("func.continuous: %d",func.continuous));
- DBUG_PRINT("info",("i: %d",i));
- insert_dynamic(&functions_array,(gptr)&func);
- i+=4;
- }
- DBUG_RETURN((gptr)&functions_array);
-}