Hi Dax und Apollonius,
@Dax: Habs jetzt so gelöst wie Apollonius gesagt hat, aber ich werd mir diese Float-Befehle auch mal angucken.. Kann ja nichts schaden was dazuzulernen
@Apollonius: Danke, es funktioniert, aaber (
) es taucht ein ganz seltsamer effekt auf:
Delphi-Quellcode:
// Diese Funktion rufe ich auf f = 2.1
procedure TForm1.Test3(f: Extended);
begin
ShowMessage(FloatToStrF(f,ffNumber,5,2));
end;
Zitat:
---------------------------
Project1
---------------------------
2,10
---------------------------
OK
---------------------------
Und das ist die verkürzte Darstellung -.-
PS: Ich poste nochmal grad wie das ganze aufgerufen wird:
Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
begin
Form1.ExecuteScriptMethod('
Test3',[2.1]);
end;
procedure TForm1.ExecuteScriptMethod(Method:
String;
Params:
array of Const);
var proc: Pointer;
i, off: Integer;
max: Integer;
p1,p2: Integer;
begin
proc := MethodAddress(Method);
max := Length(Params);
for i:= 2
to max-1
do
begin
off := i*8;
// stack-parameter pushen (floats noch nicht eingebaut!)
asm
mov edx, [Params]
add edx, off
mov edx, [edx]
push edx
end;
end;
// 1 - 3. Parameter übergeben (wobei 1. Parameter = Self)
p1 := Params[0].VType;
p2 := Params[1].VType;
asm
mov eax, max
and eax, eax
jz @Self
// Kein Parameter
sub eax,1
jz @Param1
// 1 Parameter, sonst 2 Parameter
@Param2:
mov ecx, [Params];
add ecx, 8
mov ecx, [ecx]
@Param1:
mov edx, [Params]
mov edx, [edx]
mov eax, p1
// wenn Params[0].VType = vtExtended (3)
sub eax, 3
jnz @Self
// dann float pushen
push word ptr [edx+$08]
push [edx+$04]
push [edx]
@Self:
mov eax,self
// self übergeben
call proc
// methode aufrufen
end;
end;
PS: Bitte nicht meine Methode optimieren... Es funktioniert so weit und dadrüber bin ich froh.. nachher hab ich zwar tollen Code, aber der ist dann nicht von mir sondern von sonst jemandem und das mag ich nicht
Gruß
Neutral General