WIP
This commit is contained in:
parent
25db2003ae
commit
c6a8712150
@ -106,6 +106,61 @@ FB_UDR_BEGIN_FUNCTION(MFK_flagged)
|
|||||||
FB_UDR_END_FUNCTION
|
FB_UDR_END_FUNCTION
|
||||||
|
|
||||||
|
|
||||||
|
/*** DDL
|
||||||
|
create function Blob_Save (
|
||||||
|
afilename varchar(8191),
|
||||||
|
ablobcallback BLOB
|
||||||
|
) returns bigint
|
||||||
|
external name 'my_first_udr_kit!MFK_Blob_Save'
|
||||||
|
engine udr;
|
||||||
|
***/
|
||||||
|
FB_UDR_BEGIN_FUNCTION(MFK_Blob_Save)
|
||||||
|
|
||||||
|
FB_UDR_MESSAGE(InMessage,
|
||||||
|
(FB_VARCHAR, afilename)
|
||||||
|
(FB_BLOB, ablobcallback)
|
||||||
|
);
|
||||||
|
|
||||||
|
FB_UDR_MESSAGE(OutMessage,
|
||||||
|
(FB_BIGINT, result)
|
||||||
|
);
|
||||||
|
|
||||||
|
FB_UDR_EXECUTE_FUNCTION
|
||||||
|
{
|
||||||
|
// // Test Input
|
||||||
|
// if (!s || !b || !b->blob_handle) {
|
||||||
|
// return NULL;
|
||||||
|
// }
|
||||||
|
// // open for write & as a binary...
|
||||||
|
// FILE* file_ = fopen(s, "wb");
|
||||||
|
// if (file_ == NULL) {
|
||||||
|
// ISC_INT64* res = MALLOC(sizeof(ISC_INT64));
|
||||||
|
// *res = -2;
|
||||||
|
// return res;
|
||||||
|
// }
|
||||||
|
// // allocate buffer size to equal with max segment size
|
||||||
|
// ISC_UCHAR* buffer = malloc(b->blob_max_segment);
|
||||||
|
// if (!buffer) {
|
||||||
|
// ISC_INT64* res = MALLOC(sizeof(ISC_INT64));
|
||||||
|
// *res = -1;
|
||||||
|
// return res;
|
||||||
|
// }
|
||||||
|
// /* see BLOBCALLBACK in ibase.h */
|
||||||
|
// ISC_INT64* res = MALLOC(sizeof(ISC_INT64));
|
||||||
|
// *res = 0;
|
||||||
|
// ISC_USHORT len;
|
||||||
|
// while (b->blob_get_segment(b->blob_handle, buffer, b->blob_max_segment, &len)) {
|
||||||
|
// *res += fwrite(buffer, 1, len, file_); // write buffer into given file.. (size as per 1 Byte for an element)
|
||||||
|
// }
|
||||||
|
// free(buffer);
|
||||||
|
// fclose(file_);
|
||||||
|
// return res;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FB_UDR_END_FUNCTION
|
||||||
|
|
||||||
|
|
||||||
/*** DDL
|
/*** DDL
|
||||||
create function BillDate (
|
create function BillDate (
|
||||||
@ -115,18 +170,18 @@ FB_UDR_END_FUNCTION
|
|||||||
external name 'my_first_udr_kit!MFK_BillDate'
|
external name 'my_first_udr_kit!MFK_BillDate'
|
||||||
engine udr;
|
engine udr;
|
||||||
***/
|
***/
|
||||||
FB_UDR_BEGIN_FUNCTION(MFK_BillDate)
|
// FB_UDR_BEGIN_FUNCTION(MFK_BillDate)
|
||||||
|
//
|
||||||
FB_UDR_MESSAGE(InMessage,
|
// FB_UDR_MESSAGE(InMessage,
|
||||||
(FB_INTEGER, d)
|
// (FB_INTEGER, d)
|
||||||
(FB_INTEGER, date)
|
// (FB_INTEGER, date)
|
||||||
);
|
// );
|
||||||
FB_UDR_MESSAGE(OutMessage,
|
// FB_UDR_MESSAGE(OutMessage,
|
||||||
(FB_DATE, result)
|
// (FB_DATE, result)
|
||||||
);
|
// );
|
||||||
|
//
|
||||||
|
//
|
||||||
FB_UDR_END_FUNCTION
|
// FB_UDR_END_FUNCTION
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user