rtl: cache IObjectInstance as string

This commit is contained in:
mattias 2019-01-07 16:05:29 +00:00
parent 2ed1cff471
commit 6244b933ac

View File

@ -306,6 +306,20 @@ function StrictInequal(const A: JSValue; const B): boolean; assembler;
implementation
type
{ TJSObj - simple access to JS Object }
TJSObj = class external name 'Object'
private
function GetProperties(Name: String): JSValue; external name '[]';
procedure SetProperties(Name: String; const AValue: JSValue); external name '[]';
public
//constructor new;
//function hasOwnProperty(prop: String): boolean;
property Properties[Name: String]: JSValue read GetProperties write SetProperties; default;
end;
// function parseInt(s: String; Radix: NativeInt): NativeInt; external name 'parseInt'; // may result NaN
function isNaN(i: JSValue): boolean; external name 'isNaN'; // may result NaN
@ -399,13 +413,10 @@ asm
end;
function Pos(const Search, InString: String; StartAt : Integer): Integer; assembler; overload;
asm
return InString.indexOf(Search,StartAt-1)+1;
end;
procedure Insert(const Insertion: String; var Target: String; Index: Integer);
var
t: String;
@ -582,7 +593,6 @@ begin
end;
function upcase(c : char) : char; assembler;
asm
return c.toUpperCase();
end;
@ -731,6 +741,7 @@ begin
asm
var i = iid.$intf;
if (i){
// iid is the private TGuid of an interface
i = rtl.getIntfG(this,i.$guid,2);
if (i){
obj.set(i);
@ -748,7 +759,9 @@ end;
function TObject.GetInterfaceByStr(const iidstr: String; out obj): boolean;
begin
if (iidstr = IObjectInstance) then
if not TJSObj(IObjectInstance)['$str'] then
TJSObj(IObjectInstance)['$str']:=GUIDToString(IObjectInstance);
if iidstr = TJSObj(IObjectInstance)['$str'] then
begin
obj:=Self;
exit(true);