Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   ¿Como modifico un componente libre? (https://www.clubdelphi.com/foros/showthread.php?t=82868)

red_dragon 20-04-2013 23:29:21

¿Como modifico un componente libre?
 
Bueno el componente en cuestion es ArtFormula, lo encuentran en artsoft . nm . ru / works . html sirve como evaluador de expresiones en tiempo de ejecucion, descargado de la pagina no tiene soporte para llamar datos de una tabla o base de datos, sin embargo el autor de este componente proporciona codigo para que esta funcionalidad se incluya en el componente, lo malo es que intente agregar a los archivos pas que viene con el componente y no le encuentro solucion. El codigo adicional en cuestion es este:

El autor dice que hay que crear un nuevo modulo para acceder a los datos de Firebird. Por ejem para un tsqltable seria asi.

FBTables : array of TSQLTable;

function mytable(var Calc : TFormulaCalc):TCalcItem;
begin
setN(result,trunc(Calc.topn));
end;

function mytableopen(var Calc : TFormulaCalc):TCalcItem;
var i,p : integer;
begin
p := -1;
for i := 0 to high(FBTables) do
begin
if FBTables[i] = nil then
begin
p := i;
break;
end;
end;
if p = -1 then
begin
p := high(FBTables)+1;
setlength(FBTables,p+1);
end;
FBTables[p] := TSQLTable.Create(Self);
< ... initialization of FBTables[p] ... >
setN(result,p);
end;


function mytableclose(var Calc : TFormulaCalc):TCalcItem;
var current:integer;
begin
current := trunc(Calc.TopN);
FBTables[current].close;
Freeandnil(Files[current]);
setN(result,0);
end;

function mytablenext(var Calc : TFormulaCalc):TCalcItem;
var current:integer;
begin
current := trunc(Calc.TopN);
FBTables[current].next;
if FBTables[current].eof then setN(result,0)
else setN(result,1);
end;

function mytablefield(var Calc : TFormulaCalc):TCalcItem;
var current:integer;
begin
current := trunc(Calc.ItemN(1));
SetS(result,FBTables[current].fieldbyname(Calc.topS).asstring);
end;



module := Formula.AddUserFunction('table',1,mytable,true);
Formula.AddModuleFunction(module,'open',1,mytableopen);
Formula.AddModuleFunction(module,'close',0,mytableclose);
Formula.AddModuleFunction(module,'next',0,mytablenext);
Formula.AddModuleFunction(module,'field',1,mytablefield);


Despues en el programa ya iria esto:


$mytable := table.open('table_name');
$n := 1;
while $n=1 do
if table($mytable).field('field')="AFECTED" then B3=50 else B3=0 endd;
$n := table($mytable).next;
wend;

table($mytable).close;

Alguna idea de como deben ir y en que archivos para que la funcionalidad de sacar datos de Tsqltable o Tsqlquery se adicione con estos codigos a ese componente, desde ya gracias por vuestra respuesta.

Casimiro Noteví 21-04-2013 00:20:47

Bienvenido a clubdelphi, ¿ya leiste nuestra guía de estilo?, gracias por tu colaboración :)


Recuerda poner los tags al código fuente, ejemplo:



Gracias :)


La franja horaria es GMT +2. Ahora son las 16:26:42.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi