PDA

Ver la Versión Completa : Problema FirdBird y UDF


Abel Garcia
03-12-2004, 16:30:13
;)
Hola A todos Tengo una pregunta para todos ustedes, hace poco encontre un ejemplo muy sencillo de una UDF para interbase es una DLL desarrollada en c++ Builder 6.0, me interesa pasar esa DLL a FireBird pero en la cabecera de del DLL
tiene lo siguiente:

#include <windows.h>
#include <string.h>
#include "IB_UTIL.H"

__declspec(dllexport) char const * __cdecl CatStr(char * s1, char * s2)
{
char *s3 = (char *) ib_util_malloc(256);
.
.
.
La cabecera "IB_UTIL.H" se encuentra en el directorio de Interbase osea
en :

C:\Archivos de programa\Borland\InterBase\SDK\INCLUDE

Tambien se inlcuye en el proyecto de la DLL la libreria:

C:\Archivos de programa\Borland\InterBase\SDK\LIB\IB_UTIL.LIB


Mi Pregunta es Si yo quiero usar esta libreria en FireBird Funcionaria ?

O tengo que recompilar esta DLL con nuevas librerias y cabeceras para FirdBird?

Si este furera el caso les agradeceria que me indicaran cuales Librerias son para que funcione adecuadamente en FireBird, a proposito la version de Interbase que uso es la 6.5.

De antemanto muchas gracias por su atencion, y les deseo a todos ustedes unas felices fiestas de fin de Año.

Sinaloense
03-12-2004, 19:14:57
En teoría, Debiera funcionar.

Sinaloense
03-12-2004, 19:28:49
Te pongo una UDF hecha en Pascal por mi hace unos meses, espero te sirva como ejemploo:


library aam;

{ Important note about DLL memory management: ShareMem must be the
first unit in your library's USES clause AND your project's (select
Project-View Source) USES clause if your DLL exports any procedures or
functions that pass strings as parameters or function results. This
applies to all strings passed to and from your DLL--even those that
are nested in records and classes. ShareMem is the interface unit to
the BORLNDMM.DLL shared memory manager, which must be deployed along
with your DLL. To avoid using BORLNDMM.DLL, pass string information
using PChar or ShortString parameters. }

uses
SysUtils, ib_util,
Classes;

function ftstr(v:real):string;stdcall
begin
result:=FormatFloat('#,##0.00',v);
end;

function ceros(var n:integer;var s:integer): PChar;stdcall;
var
i: Integer;
sz:string;
begin
sz:=IntToStr(n);
For i:=0 to s-(Length(sz)) do
sz:='0'+sz;
i := 0;
result := pchar(sz);
end;


function DoubleToStr(var n:Double;var al:integer): PChar;stdcall;
var
i,j,k: Integer;
sz,temp:string;
begin
i := 0;
temp:='';
sz:=trim(FormatFloat('$#,##0.00',n));
j:=13-length(sz);
for k:=j downto 1 do
temp:=temp+' ';
temp:=temp+sz;
if al=1 then
result := pchar(temp)
else
result := pchar(sz);
end;

exports ceros,DoubleToStr;


{$R *.res}

begin
end.




-----------------------------------------------------------------------


Y se anexa a Firebird de la sig. forma:



DECLARE EXTERNAL FUNCTION CEROS
INTEGER,
INTEGER
RETURNS CSTRING(10)
ENTRY_POINT 'ceros' MODULE_NAME 'aam'




-------------------------------------------------------------


Y se usa:


Select ceros(mi_campo_numerico,1) from mi_tabla



Y debe regresar:
10.2 convierte a $10.20