Commit 3c9ba020 authored by unknown's avatar unknown

udf_example.c, udf.test, Makefile.am:

  Converted "udf_example.cc" to C, avoids C++ runtime lib dependency (bug#21336)


sql/Makefile.am:
  "udf_example.cc" converted to C, avoids C++ runtime lib dependency (bug#21336)
mysql-test/t/udf.test:
  "udf_example.cc" converted to C, avoids C++ runtime lib dependency (bug#21336)
sql/udf_example.c:
  Changes to be strict ansi, except long long
parent 8c4ba968
--source include/have_udf.inc --source include/have_udf.inc
# #
# To run this tests the "sql/udf_example.cc" need to be compiled into # To run this tests the "sql/udf_example.c" need to be compiled into
# udf_example.so and LD_LIBRARY_PATH should be setup to point out where # udf_example.so and LD_LIBRARY_PATH should be setup to point out where
# the library are. # the library are.
# #
......
...@@ -116,7 +116,7 @@ DEFS = -DMYSQL_SERVER \ ...@@ -116,7 +116,7 @@ DEFS = -DMYSQL_SERVER \
@DEFS@ @DEFS@
BUILT_SOURCES = sql_yacc.cc sql_yacc.h lex_hash.h BUILT_SOURCES = sql_yacc.cc sql_yacc.h lex_hash.h
EXTRA_DIST = udf_example.cc $(BUILT_SOURCES) EXTRA_DIST = $(BUILT_SOURCES)
DISTCLEANFILES = lex_hash.h DISTCLEANFILES = lex_hash.h
AM_YFLAGS = -d AM_YFLAGS = -d
...@@ -155,7 +155,7 @@ lex_hash.h: gen_lex_hash$(EXEEXT) ...@@ -155,7 +155,7 @@ lex_hash.h: gen_lex_hash$(EXEEXT)
# For testing of udf_example.so # For testing of udf_example.so
noinst_LTLIBRARIES= udf_example.la noinst_LTLIBRARIES= udf_example.la
udf_example_la_SOURCES= udf_example.cc udf_example_la_SOURCES= udf_example.c
udf_example_la_LDFLAGS= -module -rpath $(pkglibdir) udf_example_la_LDFLAGS= -module -rpath $(pkglibdir)
......
...@@ -127,7 +127,7 @@ typedef long long longlong; ...@@ -127,7 +127,7 @@ typedef long long longlong;
#else #else
#include <my_global.h> #include <my_global.h>
#include <my_sys.h> #include <my_sys.h>
#include <m_string.h> // To get strmov() #include <m_string.h> /* To get strmov() */
#endif #endif
#include <mysql.h> #include <mysql.h>
#include <ctype.h> #include <ctype.h>
...@@ -138,7 +138,6 @@ static pthread_mutex_t LOCK_hostname; ...@@ -138,7 +138,6 @@ static pthread_mutex_t LOCK_hostname;
/* These must be right or mysqld will not find the symbol! */ /* These must be right or mysqld will not find the symbol! */
extern "C" {
my_bool metaphon_init(UDF_INIT *initid, UDF_ARGS *args, char *message); my_bool metaphon_init(UDF_INIT *initid, UDF_ARGS *args, char *message);
void metaphon_deinit(UDF_INIT *initid); void metaphon_deinit(UDF_INIT *initid);
char *metaphon(UDF_INIT *initid, UDF_ARGS *args, char *result, char *metaphon(UDF_INIT *initid, UDF_ARGS *args, char *result,
...@@ -159,7 +158,6 @@ void avgcost_reset( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char *error ...@@ -159,7 +158,6 @@ void avgcost_reset( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char *error
void avgcost_clear( UDF_INIT* initid, char* is_null, char *error ); void avgcost_clear( UDF_INIT* initid, char* is_null, char *error );
void avgcost_add( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char *error ); void avgcost_add( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char *error );
double avgcost( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char *error ); double avgcost( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char *error );
}
/************************************************************************* /*************************************************************************
...@@ -221,7 +219,7 @@ my_bool metaphon_init(UDF_INIT *initid, UDF_ARGS *args, char *message) ...@@ -221,7 +219,7 @@ my_bool metaphon_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
****************************************************************************/ ****************************************************************************/
void metaphon_deinit(UDF_INIT *initid) void metaphon_deinit(UDF_INIT *initid __attribute__((unused)))
{ {
} }
...@@ -267,23 +265,25 @@ static char codes[26] = { ...@@ -267,23 +265,25 @@ static char codes[26] = {
#define NOGHTOF(x) (codes[(x) - 'A'] & 16) /* BDH */ #define NOGHTOF(x) (codes[(x) - 'A'] & 16) /* BDH */
char *metaphon(UDF_INIT *initid, UDF_ARGS *args, char *result, char *metaphon(UDF_INIT *initid __attribute__((unused)),
unsigned long *length, char *is_null, char *error) UDF_ARGS *args, char *result, unsigned long *length,
char *is_null, char *error __attribute__((unused)))
{ {
const char *word=args->args[0]; const char *word=args->args[0];
if (!word) // Null argument const char *w_end;
char *org_result;
char *n, *n_start, *n_end; /* pointers to string */
char *metaph_end; /* pointers to end of metaph */
char ntrans[32]; /* word with uppercase letters */
int KSflag; /* state flag for X to KS */
if (!word) /* Null argument */
{ {
*is_null=1; *is_null=1;
return 0; return 0;
} }
const char *w_end=word+args->lengths[0]; w_end=word+args->lengths[0];
char *org_result=result; org_result=result;
char *n, *n_start, *n_end; /* pointers to string */
char *metaph, *metaph_end; /* pointers to metaph */
char ntrans[32]; /* word with uppercase letters */
char newm[8]; /* new metaph for comparison */
int KSflag; /* state flag for X to KS */
/*-------------------------------------------------------- /*--------------------------------------------------------
* Copy word to internal buffer, dropping non-alphabetic * Copy word to internal buffer, dropping non-alphabetic
...@@ -519,6 +519,8 @@ char *metaphon(UDF_INIT *initid, UDF_ARGS *args, char *result, ...@@ -519,6 +519,8 @@ char *metaphon(UDF_INIT *initid, UDF_ARGS *args, char *result,
my_bool myfunc_double_init(UDF_INIT *initid, UDF_ARGS *args, char *message) my_bool myfunc_double_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
{ {
uint i;
if (!args->arg_count) if (!args->arg_count)
{ {
strcpy(message,"myfunc_double must have at least one argument"); strcpy(message,"myfunc_double must have at least one argument");
...@@ -528,27 +530,28 @@ my_bool myfunc_double_init(UDF_INIT *initid, UDF_ARGS *args, char *message) ...@@ -528,27 +530,28 @@ my_bool myfunc_double_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
** As this function wants to have everything as strings, force all arguments ** As this function wants to have everything as strings, force all arguments
** to strings. ** to strings.
*/ */
for (uint i=0 ; i < args->arg_count; i++) for (i=0 ; i < args->arg_count; i++)
args->arg_type[i]=STRING_RESULT; args->arg_type[i]=STRING_RESULT;
initid->maybe_null=1; // The result may be null initid->maybe_null=1; /* The result may be null */
initid->decimals=2; // We want 2 decimals in the result initid->decimals=2; /* We want 2 decimals in the result */
initid->max_length=6; // 3 digits + . + 2 decimals initid->max_length=6; /* 3 digits + . + 2 decimals */
return 0; return 0;
} }
double myfunc_double(UDF_INIT *initid, UDF_ARGS *args, char *is_null, double myfunc_double(UDF_INIT *initid __attribute__((unused)), UDF_ARGS *args,
char *error) char *is_null, char *error __attribute__((unused)))
{ {
unsigned long val = 0; unsigned long val = 0;
unsigned long v = 0; unsigned long v = 0;
uint i, j;
for (uint i = 0; i < args->arg_count; i++) for (i = 0; i < args->arg_count; i++)
{ {
if (args->args[i] == NULL) if (args->args[i] == NULL)
continue; continue;
val += args->lengths[i]; val += args->lengths[i];
for (uint j=args->lengths[i] ; j-- > 0 ;) for (j=args->lengths[i] ; j-- > 0 ;)
v += args->args[i][j]; v += args->args[i][j];
} }
if (val) if (val)
...@@ -575,22 +578,25 @@ double myfunc_double(UDF_INIT *initid, UDF_ARGS *args, char *is_null, ...@@ -575,22 +578,25 @@ double myfunc_double(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
/* This function returns the sum of all arguments */ /* This function returns the sum of all arguments */
longlong myfunc_int(UDF_INIT *initid, UDF_ARGS *args, char *is_null, longlong myfunc_int(UDF_INIT *initid __attribute__((unused)), UDF_ARGS *args,
char *error) char *is_null __attribute__((unused)),
char *error __attribute__((unused)))
{ {
longlong val = 0; longlong val = 0;
for (uint i = 0; i < args->arg_count; i++) uint i;
for (i = 0; i < args->arg_count; i++)
{ {
if (args->args[i] == NULL) if (args->args[i] == NULL)
continue; continue;
switch (args->arg_type[i]) { switch (args->arg_type[i]) {
case STRING_RESULT: // Add string lengths case STRING_RESULT: /* Add string lengths */
val += args->lengths[i]; val += args->lengths[i];
break; break;
case INT_RESULT: // Add numbers case INT_RESULT: /* Add numbers */
val += *((longlong*) args->args[i]); val += *((longlong*) args->args[i]);
break; break;
case REAL_RESULT: // Add numers as longlong case REAL_RESULT: /* Add numers as longlong */
val += (longlong) *((double*) args->args[i]); val += (longlong) *((double*) args->args[i]);
break; break;
default: default:
...@@ -604,7 +610,9 @@ longlong myfunc_int(UDF_INIT *initid, UDF_ARGS *args, char *is_null, ...@@ -604,7 +610,9 @@ longlong myfunc_int(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
At least one of _init/_deinit is needed unless the server is started At least one of _init/_deinit is needed unless the server is started
with --allow_suspicious_udfs. with --allow_suspicious_udfs.
*/ */
my_bool myfunc_int_init(UDF_INIT *initid, UDF_ARGS *args, char *message) my_bool myfunc_int_init(UDF_INIT *initid __attribute__((unused)),
UDF_ARGS *args __attribute__((unused)),
char *message __attribute__((unused)))
{ {
return 0; return 0;
} }
...@@ -622,7 +630,7 @@ my_bool sequence_init(UDF_INIT *initid, UDF_ARGS *args, char *message) ...@@ -622,7 +630,7 @@ my_bool sequence_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
return 1; return 1;
} }
if (args->arg_count) if (args->arg_count)
args->arg_type[0]= INT_RESULT; // Force argument to int args->arg_type[0]= INT_RESULT; /* Force argument to int */
if (!(initid->ptr=(char*) malloc(sizeof(longlong)))) if (!(initid->ptr=(char*) malloc(sizeof(longlong))))
{ {
...@@ -646,8 +654,9 @@ void sequence_deinit(UDF_INIT *initid) ...@@ -646,8 +654,9 @@ void sequence_deinit(UDF_INIT *initid)
free(initid->ptr); free(initid->ptr);
} }
longlong sequence(UDF_INIT *initid, UDF_ARGS *args, char *is_null, longlong sequence(UDF_INIT *initid __attribute__((unused)), UDF_ARGS *args,
char *error) char *is_null __attribute__((unused)),
char *error __attribute__((unused)))
{ {
ulonglong val=0; ulonglong val=0;
if (args->arg_count) if (args->arg_count)
...@@ -670,7 +679,6 @@ longlong sequence(UDF_INIT *initid, UDF_ARGS *args, char *is_null, ...@@ -670,7 +679,6 @@ longlong sequence(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
#include <arpa/inet.h> #include <arpa/inet.h>
#include <netdb.h> #include <netdb.h>
extern "C" {
my_bool lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message); my_bool lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message);
void lookup_deinit(UDF_INIT *initid); void lookup_deinit(UDF_INIT *initid);
char *lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, char *lookup(UDF_INIT *initid, UDF_ARGS *args, char *result,
...@@ -679,7 +687,6 @@ my_bool reverse_lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message); ...@@ -679,7 +687,6 @@ my_bool reverse_lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message);
void reverse_lookup_deinit(UDF_INIT *initid); void reverse_lookup_deinit(UDF_INIT *initid);
char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result,
unsigned long *length, char *null_value, char *error); unsigned long *length, char *null_value, char *error);
}
/**************************************************************************** /****************************************************************************
...@@ -705,20 +712,26 @@ my_bool lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message) ...@@ -705,20 +712,26 @@ my_bool lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
return 0; return 0;
} }
void lookup_deinit(UDF_INIT *initid) void lookup_deinit(UDF_INIT *initid __attribute__((unused)))
{ {
#if !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_SOLARIS_STYLE_GETHOST) #if !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_SOLARIS_STYLE_GETHOST)
(void) pthread_mutex_destroy(&LOCK_hostname); (void) pthread_mutex_destroy(&LOCK_hostname);
#endif #endif
} }
char *lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, char *lookup(UDF_INIT *initid __attribute__((unused)), UDF_ARGS *args,
unsigned long *res_length, char *null_value, char *error) char *result, unsigned long *res_length, char *null_value,
char *error __attribute__((unused)))
{ {
uint length; uint length;
char name_buff[256];
struct hostent *hostent;
#if defined(HAVE_GETHOSTBYADDR_R) && defined(HAVE_SOLARIS_STYLE_GETHOST)
int tmp_errno; int tmp_errno;
char name_buff[256],hostname_buff[2048]; char hostname_buff[2048];
struct hostent tmp_hostent,*hostent; struct hostent tmp_hostent;
#endif
struct in_addr in;
if (!args->args[0] || !(length=args->lengths[0])) if (!args->args[0] || !(length=args->lengths[0]))
{ {
...@@ -746,7 +759,6 @@ char *lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, ...@@ -746,7 +759,6 @@ char *lookup(UDF_INIT *initid, UDF_ARGS *args, char *result,
} }
VOID(pthread_mutex_unlock(&LOCK_hostname)); VOID(pthread_mutex_unlock(&LOCK_hostname));
#endif #endif
struct in_addr in;
memcpy_fixed((char*) &in,(char*) *hostent->h_addr_list, sizeof(in.s_addr)); memcpy_fixed((char*) &in,(char*) *hostent->h_addr_list, sizeof(in.s_addr));
*res_length= (ulong) (strmov(result, inet_ntoa(in)) - result); *res_length= (ulong) (strmov(result, inet_ntoa(in)) - result);
return result; return result;
...@@ -780,18 +792,23 @@ my_bool reverse_lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message) ...@@ -780,18 +792,23 @@ my_bool reverse_lookup_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
return 0; return 0;
} }
void reverse_lookup_deinit(UDF_INIT *initid) void reverse_lookup_deinit(UDF_INIT *initid __attribute__((unused)))
{ {
#if !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_SOLARIS_STYLE_GETHOST) #if !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_SOLARIS_STYLE_GETHOST)
(void) pthread_mutex_destroy(&LOCK_hostname); (void) pthread_mutex_destroy(&LOCK_hostname);
#endif #endif
} }
char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, char *reverse_lookup(UDF_INIT *initid __attribute__((unused)), UDF_ARGS *args,
unsigned long *res_length, char *null_value, char *error) char *result, unsigned long *res_length,
char *null_value, char *error __attribute__((unused)))
{ {
#if defined(HAVE_GETHOSTBYADDR_R) && defined(HAVE_SOLARIS_STYLE_GETHOST)
char name_buff[256]; char name_buff[256];
struct hostent tmp_hostent; struct hostent tmp_hostent;
#endif
struct hostent *hp;
unsigned long taddr;
uint length; uint length;
if (args->arg_count == 4) if (args->arg_count == 4)
...@@ -808,8 +825,8 @@ char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, ...@@ -808,8 +825,8 @@ char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result,
(int) *((longlong*) args->args[3])); (int) *((longlong*) args->args[3]));
} }
else else
{ // string argument { /* string argument */
if (!args->args[0]) // Return NULL for NULL values if (!args->args[0]) /* Return NULL for NULL values */
{ {
*null_value=1; *null_value=1;
return 0; return 0;
...@@ -821,13 +838,12 @@ char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result, ...@@ -821,13 +838,12 @@ char *reverse_lookup(UDF_INIT *initid, UDF_ARGS *args, char *result,
result[length]=0; result[length]=0;
} }
unsigned long taddr = inet_addr(result); taddr = inet_addr(result);
if (taddr == (unsigned long) -1L) if (taddr == (unsigned long) -1L)
{ {
*null_value=1; *null_value=1;
return 0; return 0;
} }
struct hostent *hp;
#if defined(HAVE_GETHOSTBYADDR_R) && defined(HAVE_SOLARIS_STYLE_GETHOST) #if defined(HAVE_GETHOSTBYADDR_R) && defined(HAVE_SOLARIS_STYLE_GETHOST)
int tmp_errno; int tmp_errno;
if (!(hp=gethostbyaddr_r((char*) &taddr,sizeof(taddr), AF_INET, if (!(hp=gethostbyaddr_r((char*) &taddr,sizeof(taddr), AF_INET,
...@@ -902,11 +918,15 @@ avgcost_init( UDF_INIT* initid, UDF_ARGS* args, char* message ) ...@@ -902,11 +918,15 @@ avgcost_init( UDF_INIT* initid, UDF_ARGS* args, char* message )
/*args->arg_type[0] = REAL_RESULT; /*args->arg_type[0] = REAL_RESULT;
args->arg_type[1] = REAL_RESULT;*/ args->arg_type[1] = REAL_RESULT;*/
initid->maybe_null = 0; // The result may be null initid->maybe_null = 0; /* The result may be null */
initid->decimals = 4; // We want 4 decimals in the result initid->decimals = 4; /* We want 4 decimals in the result */
initid->max_length = 20; // 6 digits + . + 10 decimals initid->max_length = 20; /* 6 digits + . + 10 decimals */
data = new struct avgcost_data; if (!(data = (struct avgcost_data*) malloc(sizeof(struct avgcost_data))))
{
strmov(message,"Couldn't allocate memory");
return 1;
}
data->totalquantity = 0; data->totalquantity = 0;
data->totalprice = 0.0; data->totalprice = 0.0;
...@@ -918,7 +938,7 @@ avgcost_init( UDF_INIT* initid, UDF_ARGS* args, char* message ) ...@@ -918,7 +938,7 @@ avgcost_init( UDF_INIT* initid, UDF_ARGS* args, char* message )
void void
avgcost_deinit( UDF_INIT* initid ) avgcost_deinit( UDF_INIT* initid )
{ {
delete initid->ptr; free(initid->ptr);
} }
...@@ -933,7 +953,8 @@ avgcost_reset(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message) ...@@ -933,7 +953,8 @@ avgcost_reset(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message)
/* This is needed to get things to work in MySQL 4.1.1 and above */ /* This is needed to get things to work in MySQL 4.1.1 and above */
void void
avgcost_clear(UDF_INIT* initid, char* is_null, char* message) avgcost_clear(UDF_INIT* initid, char* is_null __attribute__((unused)),
char* message __attribute__((unused)))
{ {
struct avgcost_data* data = (struct avgcost_data*)initid->ptr; struct avgcost_data* data = (struct avgcost_data*)initid->ptr;
data->totalprice= 0.0; data->totalprice= 0.0;
...@@ -943,7 +964,9 @@ avgcost_clear(UDF_INIT* initid, char* is_null, char* message) ...@@ -943,7 +964,9 @@ avgcost_clear(UDF_INIT* initid, char* is_null, char* message)
void void
avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message) avgcost_add(UDF_INIT* initid, UDF_ARGS* args,
char* is_null __attribute__((unused)),
char* message __attribute__((unused)))
{ {
if (args->args[0] && args->args[1]) if (args->args[0] && args->args[1])
{ {
...@@ -963,7 +986,7 @@ avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message) ...@@ -963,7 +986,7 @@ avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message)
if ( ((quantity < 0) && (newquantity < 0)) if ( ((quantity < 0) && (newquantity < 0))
|| ((quantity > 0) && (newquantity > 0)) ) || ((quantity > 0) && (newquantity > 0)) )
{ {
data->totalprice = price * double(newquantity); data->totalprice = price * (double)newquantity;
} }
/* /*
** sub q if totalq > 0 ** sub q if totalq > 0
...@@ -971,15 +994,15 @@ avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message) ...@@ -971,15 +994,15 @@ avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message)
*/ */
else else
{ {
price = data->totalprice / double(data->totalquantity); price = data->totalprice / (double)data->totalquantity;
data->totalprice = price * double(newquantity); data->totalprice = price * (double)newquantity;
} }
data->totalquantity = newquantity; data->totalquantity = newquantity;
} }
else else
{ {
data->totalquantity += quantity; data->totalquantity += quantity;
data->totalprice += price * double(quantity); data->totalprice += price * (double)quantity;
} }
if (data->totalquantity == 0) if (data->totalquantity == 0)
...@@ -989,7 +1012,8 @@ avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message) ...@@ -989,7 +1012,8 @@ avgcost_add(UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* message)
double double
avgcost( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* error ) avgcost( UDF_INIT* initid, UDF_ARGS* args __attribute__((unused)),
char* is_null, char* error __attribute__((unused)))
{ {
struct avgcost_data* data = (struct avgcost_data*)initid->ptr; struct avgcost_data* data = (struct avgcost_data*)initid->ptr;
if (!data->count || !data->totalquantity) if (!data->count || !data->totalquantity)
...@@ -999,16 +1023,14 @@ avgcost( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* error ) ...@@ -999,16 +1023,14 @@ avgcost( UDF_INIT* initid, UDF_ARGS* args, char* is_null, char* error )
} }
*is_null = 0; *is_null = 0;
return data->totalprice/double(data->totalquantity); return data->totalprice/(double)data->totalquantity;
} }
extern "C" {
my_bool myfunc_argument_name_init(UDF_INIT *initid, UDF_ARGS *args, my_bool myfunc_argument_name_init(UDF_INIT *initid, UDF_ARGS *args,
char *message); char *message);
char *myfunc_argument_name(UDF_INIT *initid, UDF_ARGS *args, char *result, char *myfunc_argument_name(UDF_INIT *initid, UDF_ARGS *args, char *result,
unsigned long *length, char *null_value, unsigned long *length, char *null_value,
char *error); char *error);
}
my_bool myfunc_argument_name_init(UDF_INIT *initid, UDF_ARGS *args, my_bool myfunc_argument_name_init(UDF_INIT *initid, UDF_ARGS *args,
char *message) char *message)
...@@ -1024,16 +1046,17 @@ my_bool myfunc_argument_name_init(UDF_INIT *initid, UDF_ARGS *args, ...@@ -1024,16 +1046,17 @@ my_bool myfunc_argument_name_init(UDF_INIT *initid, UDF_ARGS *args,
return 0; return 0;
} }
char *myfunc_argument_name(UDF_INIT *initid, UDF_ARGS *args, char *result, char *myfunc_argument_name(UDF_INIT *initid __attribute__((unused)),
unsigned long *length, char *null_value, UDF_ARGS *args, char *result,
char *error) unsigned long *length, char *null_value,
char *error __attribute__((unused)))
{ {
if (!args->attributes[0]) if (!args->attributes[0])
{ {
null_value= 0; null_value= 0;
return 0; return 0;
} }
(*length)--; // space for ending \0 (for debugging purposes) (*length)--; /* space for ending \0 (for debugging purposes) */
if (*length > args->attribute_lengths[0]) if (*length > args->attribute_lengths[0])
*length= args->attribute_lengths[0]; *length= args->attribute_lengths[0];
memcpy(result, args->attributes[0], *length); memcpy(result, args->attributes[0], *length);
......
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