You've already forked CEF4Delphi
mirror of
https://github.com/salvadordf/CEF4Delphi.git
synced 2025-11-23 21:34:53 +02:00
Partial fix for issue #291
- Create the CefApp handlers only when they are needed in SingleProcess mode. - Added several "RemoveReferences" procedures to disable events when the application is shutting down in the CefApp handlers.
This commit is contained in:
@@ -70,6 +70,8 @@ type
|
||||
procedure OnFocusedNodeChanged(const browser: ICefBrowser; const frame: ICefFrame; const node: ICefDomNode); virtual; abstract;
|
||||
function OnProcessMessageReceived(const browser: ICefBrowser; const frame: ICefFrame; sourceProcess: TCefProcessId; const aMessage: ICefProcessMessage): Boolean; virtual;
|
||||
|
||||
procedure RemoveReferences; virtual; abstract;
|
||||
|
||||
public
|
||||
constructor Create; virtual;
|
||||
end;
|
||||
@@ -89,6 +91,8 @@ type
|
||||
procedure OnFocusedNodeChanged(const browser: ICefBrowser; const frame: ICefFrame; const node: ICefDomNode); override;
|
||||
function OnProcessMessageReceived(const browser: ICefBrowser; const frame: ICefFrame; sourceProcess: TCefProcessId; const aMessage : ICefProcessMessage): Boolean; override;
|
||||
|
||||
procedure RemoveReferences; override;
|
||||
|
||||
public
|
||||
constructor Create(const aCefApp : TCefApplicationCore); reintroduce;
|
||||
destructor Destroy; override;
|
||||
@@ -110,7 +114,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnWebKitInitialized;
|
||||
end;
|
||||
|
||||
@@ -122,7 +127,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnBrowserCreated(TCefBrowserRef.UnWrap(browser),
|
||||
TCefDictionaryValueRef.UnWrap(extra_info));
|
||||
end;
|
||||
@@ -134,7 +140,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnBrowserDestroyed(TCefBrowserRef.UnWrap(browser));
|
||||
end;
|
||||
|
||||
@@ -145,7 +152,8 @@ begin
|
||||
Result := nil;
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
Result := CefGetData(TCefRenderProcessHandlerOwn(TempObject).GetLoadHandler);
|
||||
end;
|
||||
|
||||
@@ -158,7 +166,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnContextCreated(TCefBrowserRef.UnWrap(browser),
|
||||
TCefFrameRef.UnWrap(frame),
|
||||
TCefv8ContextRef.UnWrap(context));
|
||||
@@ -173,7 +182,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnContextReleased(TCefBrowserRef.UnWrap(browser),
|
||||
TCefFrameRef.UnWrap(frame),
|
||||
TCefv8ContextRef.UnWrap(context));
|
||||
@@ -190,7 +200,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnUncaughtException(TCefBrowserRef.UnWrap(browser),
|
||||
TCefFrameRef.UnWrap(frame),
|
||||
TCefv8ContextRef.UnWrap(context),
|
||||
@@ -207,7 +218,8 @@ var
|
||||
begin
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
TCefRenderProcessHandlerOwn(TempObject).OnFocusedNodeChanged(TCefBrowserRef.UnWrap(browser),
|
||||
TCefFrameRef.UnWrap(frame),
|
||||
TCefDomNodeRef.UnWrap(node));
|
||||
@@ -224,7 +236,8 @@ begin
|
||||
Result := Ord(False);
|
||||
TempObject := CefGetObject(self);
|
||||
|
||||
if (TempObject <> nil) and (TempObject is TCefRenderProcessHandlerOwn) then
|
||||
if (TempObject <> nil) and
|
||||
(TempObject is TCefRenderProcessHandlerOwn) then
|
||||
Result := Ord(TCefRenderProcessHandlerOwn(TempObject).OnProcessMessageReceived(TCefBrowserRef.UnWrap(browser),
|
||||
TCefFrameRef.UnWrap(frame),
|
||||
source_process,
|
||||
@@ -274,22 +287,30 @@ constructor TCefCustomRenderProcessHandler.Create(const aCefApp : TCefApplicatio
|
||||
begin
|
||||
inherited Create;
|
||||
|
||||
RemoveReferences;
|
||||
|
||||
FCefApp := aCefApp;
|
||||
|
||||
if (FCefApp <> nil) and FCefApp.MustCreateLoadHandler then
|
||||
FLoadHandler := TCustomRenderLoadHandler.Create(FCefApp)
|
||||
else
|
||||
FLoadHandler := nil;
|
||||
FLoadHandler := TCustomRenderLoadHandler.Create(FCefApp);
|
||||
end;
|
||||
|
||||
destructor TCefCustomRenderProcessHandler.Destroy;
|
||||
begin
|
||||
FCefApp := nil;
|
||||
FLoadHandler := nil;
|
||||
RemoveReferences;
|
||||
|
||||
inherited Destroy;
|
||||
end;
|
||||
|
||||
procedure TCefCustomRenderProcessHandler.RemoveReferences;
|
||||
begin
|
||||
if (FLoadHandler <> nil) then
|
||||
FLoadHandler.RemoveReferences;
|
||||
|
||||
FCefApp := nil;
|
||||
FLoadHandler := nil;
|
||||
end;
|
||||
|
||||
procedure TCefCustomRenderProcessHandler.OnWebKitInitialized;
|
||||
begin
|
||||
try
|
||||
@@ -378,10 +399,10 @@ begin
|
||||
end;
|
||||
end;
|
||||
|
||||
function TCefCustomRenderProcessHandler.OnProcessMessageReceived(const browser : ICefBrowser;
|
||||
const frame : ICefFrame;
|
||||
sourceProcess : TCefProcessId;
|
||||
const aMessage : ICefProcessMessage): Boolean;
|
||||
function TCefCustomRenderProcessHandler.OnProcessMessageReceived(const browser : ICefBrowser;
|
||||
const frame : ICefFrame;
|
||||
sourceProcess : TCefProcessId;
|
||||
const aMessage : ICefProcessMessage): Boolean;
|
||||
begin
|
||||
Result := inherited OnProcessMessageReceived(browser, frame, sourceProcess, aMessage);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user