git-svn-id: https://192.168.0.254/svn/Componentes.Terceros.FastReport@13 475b051d-3a53-6940-addd-820bf0cfe0d7
102 lines
2.5 KiB
ObjectPascal
102 lines
2.5 KiB
ObjectPascal
|
|
{******************************************}
|
|
{ }
|
|
{ FastReport v4.0 }
|
|
{ IBX components RTTI }
|
|
{ }
|
|
{ Copyright (c) 1998-2006 }
|
|
{ by Alexander Tzyganenko, }
|
|
{ Fast Reports Inc. }
|
|
{ }
|
|
{******************************************}
|
|
|
|
unit frxIBXRTTI;
|
|
|
|
interface
|
|
|
|
{$I frx.inc}
|
|
|
|
implementation
|
|
|
|
uses
|
|
Windows, Classes, fs_iinterpreter, frxIBXComponents, fs_iibxrtti
|
|
{$IFDEF Delphi6}
|
|
, Variants
|
|
{$ENDIF};
|
|
|
|
|
|
type
|
|
TFunctions = class(TfsRTTIModule)
|
|
private
|
|
function CallMethod(Instance: TObject; ClassType: TClass;
|
|
const MethodName: String; Caller: TfsMethodHelper): Variant;
|
|
function GetProp(Instance: TObject; ClassType: TClass;
|
|
const PropName: String): Variant;
|
|
public
|
|
constructor Create(AScript: TfsScript); override;
|
|
end;
|
|
|
|
|
|
{ TFunctions }
|
|
|
|
constructor TFunctions.Create(AScript: TfsScript);
|
|
begin
|
|
inherited Create(AScript);
|
|
with AScript do
|
|
begin
|
|
with AddClass(TfrxIBXDatabase, 'TfrxCustomDatabase') do
|
|
AddProperty('Database', 'TIBDatabase', GetProp, nil);
|
|
with AddClass(TfrxIBXTable, 'TfrxCustomTable') do
|
|
AddProperty('Table', 'TIBTable', GetProp, nil);
|
|
with AddClass(TfrxIBXQuery, 'TfrxCustomQuery') do
|
|
begin
|
|
AddMethod('procedure ExecSQL', CallMethod);
|
|
AddProperty('Query', 'TIBQuery', GetProp, nil);
|
|
end;
|
|
end;
|
|
end;
|
|
|
|
function TFunctions.CallMethod(Instance: TObject; ClassType: TClass;
|
|
const MethodName: String; Caller: TfsMethodHelper): Variant;
|
|
begin
|
|
Result := 0;
|
|
|
|
if ClassType = TfrxIBXQuery then
|
|
begin
|
|
if MethodName = 'EXECSQL' then
|
|
TfrxIBXQuery(Instance).Query.ExecSQL
|
|
end
|
|
end;
|
|
|
|
function TFunctions.GetProp(Instance: TObject; ClassType: TClass;
|
|
const PropName: String): Variant;
|
|
begin
|
|
Result := 0;
|
|
|
|
if ClassType = TfrxIBXDatabase then
|
|
begin
|
|
if PropName = 'DATABASE' then
|
|
Result := Integer(TfrxIBXDatabase(Instance).Database)
|
|
end
|
|
else if ClassType = TfrxIBXTable then
|
|
begin
|
|
if PropName = 'TABLE' then
|
|
Result := Integer(TfrxIBXTable(Instance).Table)
|
|
end
|
|
else if ClassType = TfrxIBXQuery then
|
|
begin
|
|
if PropName = 'QUERY' then
|
|
Result := Integer(TfrxIBXQuery(Instance).Query)
|
|
end
|
|
end;
|
|
|
|
|
|
initialization
|
|
fsRTTIModules.Add(TFunctions);
|
|
|
|
finalization
|
|
if fsRTTIModules <> nil then
|
|
fsRTTIModules.Remove(TFunctions);
|
|
|
|
end.
|