2017-01-27 16:37:51 +01:00
|
|
|
unit uCEFTaskRunner;
|
|
|
|
|
2018-05-12 14:50:54 +02:00
|
|
|
{$IFDEF FPC}
|
|
|
|
{$MODE OBJFPC}{$H+}
|
|
|
|
{$ENDIF}
|
|
|
|
|
2017-02-05 20:56:46 +01:00
|
|
|
{$I cef.inc}
|
|
|
|
|
2022-02-19 18:56:41 +01:00
|
|
|
{$IFNDEF TARGET_64BITS}{$ALIGN ON}{$ENDIF}
|
|
|
|
{$MINENUMSIZE 4}
|
|
|
|
|
2017-01-27 16:37:51 +01:00
|
|
|
interface
|
|
|
|
|
|
|
|
uses
|
2017-03-16 19:09:42 +01:00
|
|
|
uCEFBaseRefCounted, uCEFInterfaces, uCEFTypes;
|
2017-01-27 16:37:51 +01:00
|
|
|
|
|
|
|
type
|
2017-03-16 19:09:42 +01:00
|
|
|
TCefTaskRunnerRef = class(TCefBaseRefCountedRef, ICefTaskRunner)
|
2023-11-16 16:58:47 +01:00
|
|
|
protected
|
|
|
|
function IsSame(const that: ICefTaskRunner): Boolean;
|
|
|
|
function BelongsToCurrentThread: Boolean;
|
|
|
|
function BelongsToThread(threadId: TCefThreadId): Boolean;
|
|
|
|
function PostTask(const task: ICefTask): Boolean;
|
|
|
|
function PostDelayedTask(const task: ICefTask; delayMs: Int64): Boolean;
|
|
|
|
public
|
|
|
|
/// <summary>
|
|
|
|
/// Returns a ICefTaskRunner instance using a PCefTaskRunner data pointer.
|
|
|
|
/// </summary>
|
|
|
|
class function UnWrap(data: Pointer): ICefTaskRunner;
|
|
|
|
/// <summary>
|
|
|
|
/// Returns the task runner for the current thread. Only CEF threads will have
|
|
|
|
/// task runners. An NULL reference will be returned if this function is called
|
|
|
|
/// on an invalid thread.
|
|
|
|
/// </summary>
|
|
|
|
class function GetForCurrentThread: ICefTaskRunner;
|
|
|
|
/// <summary>
|
|
|
|
/// Returns the task runner for the specified CEF thread.
|
|
|
|
/// </summary>
|
|
|
|
class function GetForThread(threadId: TCefThreadId): ICefTaskRunner;
|
2017-01-27 16:37:51 +01:00
|
|
|
end;
|
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
uses
|
|
|
|
uCEFMiscFunctions, uCEFLibFunctions;
|
|
|
|
|
|
|
|
|
|
|
|
function TCefTaskRunnerRef.BelongsToCurrentThread: Boolean;
|
|
|
|
begin
|
2018-05-12 14:50:54 +02:00
|
|
|
Result := PCefTaskRunner(FData)^.belongs_to_current_thread(PCefTaskRunner(FData)) <> 0;
|
2017-01-27 16:37:51 +01:00
|
|
|
end;
|
|
|
|
|
|
|
|
function TCefTaskRunnerRef.BelongsToThread(threadId: TCefThreadId): Boolean;
|
|
|
|
begin
|
2018-05-12 14:50:54 +02:00
|
|
|
Result := PCefTaskRunner(FData)^.belongs_to_thread(PCefTaskRunner(FData), threadId) <> 0;
|
2017-01-27 16:37:51 +01:00
|
|
|
end;
|
|
|
|
|
|
|
|
class function TCefTaskRunnerRef.GetForCurrentThread: ICefTaskRunner;
|
|
|
|
begin
|
|
|
|
Result := UnWrap(cef_task_runner_get_for_current_thread());
|
|
|
|
end;
|
|
|
|
|
|
|
|
class function TCefTaskRunnerRef.GetForThread(threadId: TCefThreadId): ICefTaskRunner;
|
|
|
|
begin
|
|
|
|
Result := UnWrap(cef_task_runner_get_for_thread(threadId));
|
|
|
|
end;
|
|
|
|
|
|
|
|
function TCefTaskRunnerRef.IsSame(const that: ICefTaskRunner): Boolean;
|
|
|
|
begin
|
2018-05-12 14:50:54 +02:00
|
|
|
Result := PCefTaskRunner(FData)^.is_same(PCefTaskRunner(FData), CefGetData(that)) <> 0;
|
2017-01-27 16:37:51 +01:00
|
|
|
end;
|
|
|
|
|
2018-03-29 20:02:04 +02:00
|
|
|
function TCefTaskRunnerRef.PostDelayedTask(const task: ICefTask; delayMs: Int64): Boolean;
|
2017-01-27 16:37:51 +01:00
|
|
|
begin
|
2018-05-12 14:50:54 +02:00
|
|
|
Result := PCefTaskRunner(FData)^.post_delayed_task(PCefTaskRunner(FData), CefGetData(task), delayMs) <> 0;
|
2017-01-27 16:37:51 +01:00
|
|
|
end;
|
|
|
|
|
|
|
|
function TCefTaskRunnerRef.PostTask(const task: ICefTask): Boolean;
|
|
|
|
begin
|
2018-05-12 14:50:54 +02:00
|
|
|
Result := PCefTaskRunner(FData)^.post_task(PCefTaskRunner(FData), CefGetData(task)) <> 0;
|
2017-01-27 16:37:51 +01:00
|
|
|
end;
|
|
|
|
|
|
|
|
class function TCefTaskRunnerRef.UnWrap(data: Pointer): ICefTaskRunner;
|
|
|
|
begin
|
2018-03-29 20:02:04 +02:00
|
|
|
if (data <> nil) then
|
|
|
|
Result := Create(data) as ICefTaskRunner
|
|
|
|
else
|
2017-01-27 16:37:51 +01:00
|
|
|
Result := nil;
|
|
|
|
end;
|
|
|
|
|
|
|
|
end.
|