unit uCEFTaskRunner; {$IFDEF FPC} {$MODE OBJFPC}{$H+} {$ENDIF} {$I cef.inc} {$IFNDEF TARGET_64BITS}{$ALIGN ON}{$ENDIF} {$MINENUMSIZE 4} interface uses uCEFBaseRefCounted, uCEFInterfaces, uCEFTypes; type TCefTaskRunnerRef = class(TCefBaseRefCountedRef, ICefTaskRunner) 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 /// /// Returns a ICefTaskRunner instance using a PCefTaskRunner data pointer. /// class function UnWrap(data: Pointer): ICefTaskRunner; /// /// 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. /// class function GetForCurrentThread: ICefTaskRunner; /// /// Returns the task runner for the specified CEF thread. /// class function GetForThread(threadId: TCefThreadId): ICefTaskRunner; end; implementation uses uCEFMiscFunctions, uCEFLibFunctions; function TCefTaskRunnerRef.BelongsToCurrentThread: Boolean; begin Result := PCefTaskRunner(FData)^.belongs_to_current_thread(PCefTaskRunner(FData)) <> 0; end; function TCefTaskRunnerRef.BelongsToThread(threadId: TCefThreadId): Boolean; begin Result := PCefTaskRunner(FData)^.belongs_to_thread(PCefTaskRunner(FData), threadId) <> 0; 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 Result := PCefTaskRunner(FData)^.is_same(PCefTaskRunner(FData), CefGetData(that)) <> 0; end; function TCefTaskRunnerRef.PostDelayedTask(const task: ICefTask; delayMs: Int64): Boolean; begin Result := PCefTaskRunner(FData)^.post_delayed_task(PCefTaskRunner(FData), CefGetData(task), delayMs) <> 0; end; function TCefTaskRunnerRef.PostTask(const task: ICefTask): Boolean; begin Result := PCefTaskRunner(FData)^.post_task(PCefTaskRunner(FData), CefGetData(task)) <> 0; end; class function TCefTaskRunnerRef.UnWrap(data: Pointer): ICefTaskRunner; begin if (data <> nil) then Result := Create(data) as ICefTaskRunner else Result := nil; end; end.