8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-23 22:43:04 +01:00

Update the ancient example IUDF "test" to use reference with nulls instead of value that can't be declared in DSQL and has compatibility problems

This commit is contained in:
robocop 2004-08-27 04:56:22 +00:00
parent 4ce7a139e5
commit 8638418d36

View File

@ -42,7 +42,7 @@ struct FN {
// FPTR_INT FUNCTIONS_entrypoint(char*, char*);
static int test(long, char*);
static int test(const long*, char*);
static DSC* ni(DSC*, DSC*);
static SLONG* byteLen(const dsc*);
@ -100,7 +100,7 @@ FPTR_INT FUNCTIONS_entrypoint(const char* module, const char* entrypoint)
}
static int test(long n, char *result)
static int test(const long* n, char *result)
{
/**************************************
*
@ -113,17 +113,20 @@ static int test(long n, char *result)
*
* QLI:
* define function test module_name "test_module" entry_point "test_function"
* long by value,
* long by reference //by value, CVC: BY VALUE is deprecated for input params
* char [20] by reference return_argument;
* ISQL:
* declare external function test
* int by value, -> There's no way to do that, DSQL doesn't support input params by value.
* int null, // CVC: with NULL signaling
* char(20) returns parameter 2
* entry_point 'test_function' module_name 'test_module';
*
**************************************/
sprintf(result, "%ld is a number", n);
if (n)
sprintf(result, "%ld is a number", *n);
else
sprintf(result, "is NULL");
const char* const end = result + 20;
while (*result)