diff --git a/minigui_addons/webview.d b/minigui_addons/webview.d
new file mode 100644
index 0000000..26d706a
--- /dev/null
+++ b/minigui_addons/webview.d
@@ -0,0 +1,526 @@
+/++
+ A webview (based on [arsd.webview]) for minigui.
+
+ For now at least, to use this, you MUST have a CefApp in scope in main for the duration of your gui application.
+
+ History:
+ Added November 5, 2021. NOT YET STABLE.
++/
+module minigui_addons.webview;
+
+version(linux)
+ version=cef;
+version(Windows)
+ version=wv2;
+
+
+class StateChanged(alias field) : Event {
+ enum EventString = __traits(identifier, __traits(parent, field)) ~ "." ~ __traits(identifier, field) ~ ":change";
+ override bool cancelable() const { return false; }
+ this(Widget target, typeof(field) newValue) {
+ this.newValue = newValue;
+ super(EventString, target);
+ }
+
+ typeof(field) newValue;
+}
+
+void addWhenTriggered(Widget w, void delegate() dg) {
+ w.addEventListener("triggered", dg);
+}
+
+mixin template Observable(T, string name) {
+ private T backing;
+
+ mixin(q{
+ void } ~ name ~ q{_changed (void delegate(T) dg) {
+ this.addEventListener((StateChanged!this_thing ev) {
+ dg(ev.newValue);
+ });
+ }
+
+ @property T } ~ name ~ q{ () {
+ return backing;
+ }
+
+ @property void } ~ name ~ q{ (T t) {
+ backing = t;
+ auto event = new StateChanged!this_thing(this, t);
+ event.dispatch();
+ }
+ });
+
+ mixin("private alias this_thing = " ~ name ~ ";");
+}
+
+/+
+ SPA mode: put favicon on top level window, no other user controls at top level, links to different domains always open in new window.
++/
+
+// FIXME: look in /opt/cef for the dll and the locales
+
+import arsd.minigui;
+import arsd.webview;
+
+version(wv2)
+ alias WebViewWidget = WebViewWidget_WV2;
+else version(cef)
+ alias WebViewWidget = WebViewWidget_CEF;
+else static assert(0, "no webview available");
+
+class WebViewWidgetBase : NestedChildWindowWidget {
+ protected SimpleWindow containerWindow;
+
+ protected this(Widget parent) {
+ containerWindow = new SimpleWindow(640, 480, null, OpenGlOptions.no, Resizability.allowResizing, WindowTypes.nestedChild, WindowFlags.normal, getParentWindow(parent));
+
+ super(containerWindow, parent);
+ }
+
+ mixin Observable!(string, "title");
+ mixin Observable!(string, "url");
+ mixin Observable!(string, "status");
+ mixin Observable!(int, "loadingProgress");
+
+ abstract void refresh();
+ abstract void back();
+ abstract void forward();
+ abstract void stop();
+
+ abstract void navigate(string url);
+
+ // the url and line are for error reporting purposes
+ abstract void executeJavascript(string code, string url = null, int line = 0);
+
+ abstract void showDevTools();
+
+ // this is implemented as a do-nothing in the NestedChildWindowWidget base
+ // but you will almost certainly need to override it in implementations.
+ // abstract void registerMovementAdditionalWork();
+}
+
+
+version(wv2)
+class WebViewWidget_WV2 : WebViewWidgetBase {
+ private RC!ICoreWebView2 webview_window;
+ private RC!ICoreWebView2Environment webview_env;
+ private RC!ICoreWebView2Controller controller;
+
+ private bool initialized;
+
+ this(Widget parent) {
+ super(parent);
+ // that ctor sets containerWindow
+
+ Wv2App.useEnvironment((env) {
+ env.CreateCoreWebView2Controller(containerWindow.impl.hwnd,
+ callback!(ICoreWebView2CreateCoreWebView2ControllerCompletedHandler)(delegate(error, controller_raw) {
+ if(error || controller_raw is null)
+ return error;
+
+ // need to keep this beyond the callback or we're doomed.
+ controller = RC!ICoreWebView2Controller(controller_raw);
+
+ webview_window = controller.CoreWebView2;
+
+ RC!ICoreWebView2Settings Settings = webview_window.Settings;
+ Settings.IsScriptEnabled = TRUE;
+ Settings.AreDefaultScriptDialogsEnabled = TRUE;
+ Settings.IsWebMessageEnabled = TRUE;
+
+
+ auto ert = webview_window.add_NavigationStarting(
+ delegate (sender, args) {
+ wchar* t;
+ args.get_Uri(&t);
+ auto ot = t;
+
+ string s;
+
+ while(*t) {
+ s ~= *t;
+ t++;
+ }
+
+ this.url = s;
+
+ CoTaskMemFree(ot);
+
+ return S_OK;
+ });
+
+ RECT bounds;
+ GetClientRect(containerWindow.impl.hwnd, &bounds);
+ controller.Bounds = bounds;
+ error = webview_window.Navigate("http://arsdnet.net/test.html"w.ptr);
+ //error = webview_window.NavigateToString("
Hello"w.ptr);
+ //error = webview_window.Navigate("http://192.168.1.10/"w.ptr);
+
+ controller.IsVisible = true;
+
+ initialized = true;
+
+ return S_OK;
+ }));
+ });
+ }
+
+ override void registerMovementAdditionalWork() {
+ if(initialized) {
+ RECT bounds;
+ GetClientRect(containerWindow.impl.hwnd, &bounds);
+ controller.Bounds = bounds;
+
+ controller.NotifyParentWindowPositionChanged();
+ }
+ }
+
+ override void refresh() {
+ if(!initialized) return;
+ webview_window.Reload();
+ }
+ override void back() {
+ if(!initialized) return;
+ webview_window.GoBack();
+ }
+ override void forward() {
+ if(!initialized) return;
+ webview_window.GoForward();
+ }
+ override void stop() {
+ if(!initialized) return;
+ webview_window.Stop();
+ }
+
+ override void navigate(string url) {
+ if(!initialized) return;
+ import std.utf;
+ auto error = webview_window.Navigate(url.toUTF16z);
+ }
+
+ // the url and line are for error reporting purposes
+ override void executeJavascript(string code, string url = null, int line = 0) {
+ if(!initialized) return;
+ import std.utf;
+ webview_window.ExecuteScript(code.toUTF16z, null);
+ }
+
+ override void showDevTools() {
+ if(!initialized) return;
+ webview_window.OpenDevToolsWindow();
+ }
+}
+
+version(cef)
+class WebViewWidget_CEF : WebViewWidgetBase {
+ this(Widget parent) {
+ //semaphore = new Semaphore;
+ assert(CefApp.active);
+
+ super(parent);
+
+ flushGui();
+
+ mapping[containerWindow.nativeWindowHandle()] = this;
+
+ cef_window_info_t window_info;
+ window_info.parent_window = containerWindow.nativeWindowHandle;
+
+ cef_string_t cef_url = cef_string_t("http://arsdnet.net/test.html");
+
+ cef_browser_settings_t browser_settings;
+ browser_settings.size = cef_browser_settings_t.sizeof;
+
+ client = new MiniguiCefClient();
+
+ auto got = libcef.browser_host_create_browser(&window_info, client.passable, &cef_url, &browser_settings, null, null);
+
+ /+
+ containerWindow.closeQuery = delegate() {
+ browserHandle.get_host.close_browser(true);
+ //containerWindow.close();
+ };
+ +/
+
+ }
+
+ private MiniguiCefClient client;
+
+ /+
+ override void close() {
+ // FIXME: this should prolly be on the onclose event instead
+ mapping.remove[win.nativeWindowHandle()];
+ super.close();
+ }
+ +/
+
+ override void registerMovementAdditionalWork() {
+ if(browserWindow) {
+ static if(UsingSimpledisplayX11)
+ XResizeWindow(XDisplayConnection.get, browserWindow, width, height);
+ // FIXME: do for Windows too
+ }
+ }
+
+
+ private NativeWindowHandle browserWindow;
+ private RC!cef_browser_t browserHandle;
+
+ private static WebViewWidget[NativeWindowHandle] mapping;
+ private static WebViewWidget[NativeWindowHandle] browserMapping;
+
+ override void refresh() { if(browserHandle) browserHandle.reload(); }
+ override void back() { if(browserHandle) browserHandle.go_back(); }
+ override void forward() { if(browserHandle) browserHandle.go_forward(); }
+ override void stop() { if(browserHandle) browserHandle.stop_load(); }
+
+ override void navigate(string url) {
+ if(!browserHandle) return;
+ auto s = cef_string_t(url);
+ browserHandle.get_main_frame.load_url(&s);
+ }
+
+ // the url and line are for error reporting purposes
+ override void executeJavascript(string code, string url = null, int line = 0) {
+ if(!browserHandle) return;
+
+ auto c = cef_string_t(code);
+ auto u = cef_string_t(url);
+ browserHandle.get_main_frame.execute_java_script(&c, &u, line);
+ }
+
+ override void showDevTools() {
+ if(!browserHandle) return;
+ browserHandle.get_host.show_dev_tools(null /* window info */, client.passable, null /* settings */, null /* inspect element at coordinates */);
+ }
+
+ // FYI the cef browser host also allows things like custom spelling dictionaries and getting navigation entries.
+
+ // JS on init?
+ // JS bindings?
+ // user styles?
+ // navigate to string? (can just use a data uri maybe?)
+ // custom scheme handlers?
+
+ // navigation callbacks to prohibit certain things or move links to new window etc?
+}
+
+version(cef) {
+
+ //import core.sync.semaphore;
+ //__gshared Semaphore semaphore;
+
+ /+
+ Finds the WebViewWidget associated with the given browser, then runs the given code in the gui thread on it.
+ +/
+ void runOnWebView(RC!cef_browser_t browser, void delegate(WebViewWidget) dg) nothrow {
+ auto wh = cast(NativeWindowHandle) browser.get_host.get_window_handle;
+ runInGuiThreadAsync({
+ if(auto wvp = wh in WebViewWidget.browserMapping) {
+ dg(*wvp);
+ } else {
+ //writeln("not found ", wh, WebViewWidget.browserMapping);
+ }
+ });
+ }
+
+ class MiniguiCefLifeSpanHandler : CEF!cef_life_span_handler_t {
+ override int on_before_popup(RC!cef_browser_t, RC!cef_frame_t, const(cef_string_utf16_t)*, const(cef_string_utf16_t)*, cef_window_open_disposition_t, int, const(cef_popup_features_t)*, cef_window_info_t*, cef_client_t**, cef_browser_settings_t*, cef_dictionary_value_t**, int*) {
+ return 0;
+ }
+ override void on_after_created(RC!cef_browser_t browser) {
+ auto handle = cast(NativeWindowHandle) browser.get_host().get_window_handle();
+ auto ptr = browser.passable; // this adds to the refcount until it gets inside
+
+ // the only reliable key (at least as far as i can tell) is the window handle
+ // so gonna look that up and do the sync mapping that way.
+ runInGuiThreadAsync({
+ version(Windows) {
+ auto parent = GetParent(handle);
+ } else static if(UsingSimpledisplayX11) {
+ import arsd.simpledisplay : Window;
+ Window root;
+ Window parent;
+ uint c = 0;
+ auto display = XDisplayConnection.get;
+ Window* children;
+ XQueryTree(display, handle, &root, &parent, &children, &c);
+ XFree(children);
+ } else static assert(0);
+
+ if(auto wvp = parent in WebViewWidget.mapping) {
+ auto wv = *wvp;
+ wv.browserWindow = handle;
+ wv.browserHandle = RC!cef_browser_t(ptr);
+
+ wv.registerMovementAdditionalWork();
+
+ WebViewWidget.browserMapping[handle] = wv;
+ } else assert(0);
+ });
+ }
+ override int do_close(RC!cef_browser_t browser) {
+ return 0;
+ }
+ override void on_before_close(RC!cef_browser_t browser) {
+ /+
+ import std.stdio; debug writeln("notify");
+ try
+ semaphore.notify;
+ catch(Exception e) { assert(0); }
+ +/
+ }
+ }
+
+ class MiniguiLoadHandler : CEF!cef_load_handler_t {
+ override void on_loading_state_change(RC!(cef_browser_t) browser, int isLoading, int canGoBack, int canGoForward) {
+ /+
+ browser.runOnWebView((WebViewWidget wvw) {
+ wvw.parentWindow.win.title = wvw.browserHandle.get_main_frame.get_url.toGCAndFree;
+ });
+ +/
+ }
+ override void on_load_start(RC!(cef_browser_t), RC!(cef_frame_t), cef_transition_type_t) {
+ }
+ override void on_load_error(RC!(cef_browser_t), RC!(cef_frame_t), cef_errorcode_t, const(cef_string_utf16_t)*, const(cef_string_utf16_t)*) {
+ }
+ override void on_load_end(RC!(cef_browser_t), RC!(cef_frame_t), int) {
+ }
+ }
+
+ class MiniguiDialogHandler : CEF!cef_dialog_handler_t {
+
+ override int on_file_dialog(RC!(cef_browser_t) browser, cef_file_dialog_mode_t mode, const(cef_string_utf16_t)* title, const(cef_string_utf16_t)* default_file_path, cef_string_list_t accept_filters, int selected_accept_filter, RC!(cef_file_dialog_callback_t) callback) {
+ try {
+ auto ptr = callback.passable();
+ runInGuiThreadAsync({
+ getOpenFileName((string name) {
+ auto callback = RC!cef_file_dialog_callback_t(ptr);
+ auto list = libcef.string_list_alloc();
+ auto item = cef_string_t(name);
+ libcef.string_list_append(list, &item);
+ callback.cont(selected_accept_filter, list);
+ }, null, null, () {
+ auto callback = RC!cef_file_dialog_callback_t(ptr);
+ callback.cancel();
+ });
+ });
+ } catch(Exception e) {}
+
+ return 1;
+ }
+ }
+
+ class MiniguiDisplayHandler : CEF!cef_display_handler_t {
+ override void on_address_change(RC!(cef_browser_t) browser, RC!(cef_frame_t), const(cef_string_utf16_t)* address) {
+ auto url = address.toGC;
+ browser.runOnWebView((wv) {
+ wv.url = url;
+ });
+ }
+ override void on_title_change(RC!(cef_browser_t) browser, const(cef_string_utf16_t)* title) {
+ auto t = title.toGC;
+ browser.runOnWebView((wv) {
+ wv.title = t;
+ });
+ }
+ override void on_favicon_urlchange(RC!(cef_browser_t) browser, cef_string_list_t) {
+ }
+ override void on_fullscreen_mode_change(RC!(cef_browser_t) browser, int) {
+ }
+ override int on_tooltip(RC!(cef_browser_t) browser, cef_string_utf16_t*) {
+ return 0;
+ }
+ override void on_status_message(RC!(cef_browser_t) browser, const(cef_string_utf16_t)* msg) {
+ auto status = msg.toGC;
+ browser.runOnWebView((wv) {
+ wv.status = status;
+ });
+ }
+ override void on_loading_progress_change(RC!(cef_browser_t) browser, double progress) {
+ // progress is from 0.0 to 1.0
+ browser.runOnWebView((wv) {
+ wv.loadingProgress = cast(int) (progress * 100);
+ });
+ }
+ override int on_console_message(RC!(cef_browser_t), cef_log_severity_t, const(cef_string_utf16_t)*, const(cef_string_utf16_t)*, int) {
+ return 0; // 1 means to suppress it being automatically output
+ }
+ override int on_auto_resize(RC!(cef_browser_t), const(cef_size_t)*) {
+ return 0;
+ }
+ override int on_cursor_change(RC!(cef_browser_t), cef_cursor_handle_t, cef_cursor_type_t, const(cef_cursor_info_t)*) {
+ return 0;
+ }
+ }
+
+ class MiniguiCefClient : CEF!cef_client_t {
+ MiniguiCefLifeSpanHandler lsh;
+ MiniguiLoadHandler loadHandler;
+ MiniguiDialogHandler dialogHandler;
+ MiniguiDisplayHandler displayHandler;
+ this() {
+ lsh = new MiniguiCefLifeSpanHandler();
+ loadHandler = new MiniguiLoadHandler();
+ dialogHandler = new MiniguiDialogHandler();
+ displayHandler = new MiniguiDisplayHandler();
+ }
+
+ override cef_audio_handler_t* get_audio_handler() {
+ return null;
+ }
+ override cef_context_menu_handler_t* get_context_menu_handler() {
+ return null;
+ }
+ override cef_dialog_handler_t* get_dialog_handler() {
+ return dialogHandler.returnable;
+ }
+ override cef_display_handler_t* get_display_handler() {
+ return displayHandler.returnable;
+ }
+ override cef_download_handler_t* get_download_handler() {
+ return null;
+ }
+ override cef_drag_handler_t* get_drag_handler() {
+ return null;
+ }
+ override cef_find_handler_t* get_find_handler() {
+ return null;
+ }
+ override cef_focus_handler_t* get_focus_handler() {
+ return null;
+ }
+ override cef_jsdialog_handler_t* get_jsdialog_handler() {
+ // needed for alert etc.
+ return null;
+ }
+ override cef_keyboard_handler_t* get_keyboard_handler() {
+ // this can handle keyboard shortcuts etc
+ return null;
+ }
+ override cef_life_span_handler_t* get_life_span_handler() {
+ return lsh.returnable;
+ }
+ override cef_load_handler_t* get_load_handler() {
+ return loadHandler.returnable;
+ }
+ override cef_render_handler_t* get_render_handler() {
+ // this thing might work for an off-screen thing
+ // like to an image or to a video stream maybe
+ return null;
+ }
+ override cef_request_handler_t* get_request_handler() {
+ return null;
+ }
+ override int on_process_message_received(RC!cef_browser_t, RC!cef_frame_t, cef_process_id_t, RC!cef_process_message_t) {
+ return 0; // return 1 if you can actually handle the message
+ }
+ override cef_frame_handler_t* get_frame_handler() nothrow {
+ return null;
+ }
+ override cef_print_handler_t* get_print_handler() nothrow {
+ return null;
+ }
+
+ }
+}
diff --git a/webview.d b/webview.d
index 60e8136..6047a5d 100644
--- a/webview.d
+++ b/webview.d
@@ -1,111 +1,312 @@
/++
- A thin wrapper around common system webviews.
- Based on: https://github.com/zserge/webview
+ A web view wrapper. Uses CEF on Linux and WebView2 on Windows.
+
+ Microsoft WebView2 is fairly stable and is unlikely to break, but CEF
+ is not remotely stable and likely to break every release. You'll have
+ to get the same version as me to use this unless you want to generate
+ your own bindings (procedure found in the file comments). Details below.
+
+
+ I currently built against 95.7.17+g4208276+chromium-95.0.4638.69 and it
+ uses UTF-16 strings.
+
+ Then to install the cef put in the Resources in the RElease directory and
+ copy the locales to /opt/cef/Resources/Locales
+
+ You can download compatible builds from https://cef-builds.spotifycdn.com/index.html
+ just make sure to put in the version filter and check "all builds" to match it.
+
+ You do NOT actually need the cef to build the application, but it must be
+ on the user's machine to run it. It looks in /opt/cef/ on Linux.
+
+ Work in progress. DO NOT USE YET as I am prolly gonna break everything too.
+
+ On Windows, you need to distribute the WebView2Loader.dll with your exe. That
+ is found in the web view 2 sdk. Furthermore, users will have to install the runtime.
+
+ Please note; the Microsoft terms and conditions say they may be able to collect
+ information about your users if you use this on Windows.
+ see: https://developer.microsoft.com/en-us/microsoft-edge/webview2/
+
- Work in progress. DO NOT USE YET as I am prolly gonna break everything.
+/
module arsd.webview;
-// FIXME: I think dynamic loading cef might not be that bad; there's only a handful
-// of top level functions. will want to explore.
-
-// Please note; the Microsoft terms and conditions say they may be able to collect
-// information about your users if you use this on Windows.
-// see: https://developer.microsoft.com/en-us/microsoft-edge/webview2/
+// I might recover this gtk thing but i don't like gtk
+// dmdi webview -version=linux_gtk -version=Demo
+// the setup link for Microsoft:
// https://go.microsoft.com/fwlink/p/?LinkId=2124703
+version(Windows) {
+import arsd.simpledisplay;
+import arsd.com;
+import core.atomic;
+
+//import std.stdio;
+
+T callback(T)(typeof(&T.init.Invoke) dg) {
+ return new class T {
+ extern(Windows):
+
+ static if(is(typeof(T.init.Invoke) R == return))
+ static if(is(typeof(T.init.Invoke) P == __parameters))
+ override R Invoke(P _args_) {
+ return dg(_args_);
+ }
+
+ override HRESULT QueryInterface(const (IID)*riid, LPVOID *ppv) {
+ if (IID_IUnknown == *riid) {
+ *ppv = cast(void*) cast(IUnknown) this;
+ }
+ else if (T.iid == *riid) {
+ *ppv = cast(void*) cast(T) this;
+ }
+ else {
+ *ppv = null;
+ return E_NOINTERFACE;
+ }
+
+ AddRef();
+ return NOERROR;
+ }
+
+ shared LONG count = 0;
+ ULONG AddRef() {
+ return atomicOp!"+="(count, 1);
+ }
+ ULONG Release() {
+ return atomicOp!"-="(count, 1);
+ }
+ };
+}
+
+struct RC(T) {
+ private T object;
+ this(T t) {
+ object = t;
+ object.AddRef();
+ }
+ this(this) {
+ if(object is null) return;
+ object.AddRef();
+ }
+ ~this() {
+ if(object is null) return;
+ object.Release();
+ object = null;
+ }
+
+ void opAssign(T obj) {
+ obj.AddRef();
+ if(object)
+ object.Release();
+ this.object = obj;
+ }
+
+ T returnable() {
+ if(object is null) return null;
+ return object;
+ }
+
+ T passable() {
+ if(object is null) return null;
+ object.AddRef();
+ return object;
+ }
+
+ static foreach(memberName; __traits(derivedMembers, T)) {
+ mixin ForwardMethod!(memberName);
+ }
+}
+
+class ComException : Exception {
+ HRESULT errorCode;
+ this(HRESULT errorCode) {
+ import std.format;
+ super(format("HRESULT: 0x%08x", errorCode));
+ // FIXME: call FormatMessage
+ }
+}
+
+mixin template ForwardMethod(string methodName) {
+ static if(methodName.length > 4 && methodName[0 .. 4] == "put_") {
+ static if(is(typeof(__traits(getMember, T, memberName)) Params == function))
+ private alias Type = Params[0];
+ mixin(q{ @property void } ~ memberName[4 .. $] ~ q{(Type v) {
+ auto errorCode = __traits(getMember, object, memberName)(v);
+ if(errorCode)
+ throw new ComException(errorCode);
+ }
+ });
+ } else
+ static if(methodName.length > 4 && methodName[0 .. 4] == "get_") {
+ static if(is(typeof(__traits(getMember, T, memberName)) Params == function))
+ private alias Type = typeof(*(Params[0].init));
+ mixin(q{ @property Type } ~ memberName[4 .. $] ~ q{() {
+ Type response;
+ auto errorCode = __traits(getMember, object, memberName)(&response);
+ if(errorCode)
+ throw new ComException(errorCode);
+ return response;
+ }
+ });
+ } else
+ static if(methodName.length > 4 && methodName[0 .. 4] == "add_") {
+ static if(is(typeof(__traits(getMember, T, memberName)) Params == function))
+ alias Handler = Params[0];
+ alias HandlerDg = typeof(&Handler.init.Invoke);
+ mixin(q{ EventRegistrationToken } ~ memberName ~ q{ (HandlerDg handler) {
+ EventRegistrationToken token;
+ __traits(getMember, object, memberName)(callback!Handler(handler), &token);
+ return token;
+ }});
+ } else
+ static if(methodName.length > 7 && methodName[0 .. 4] == "remove_") {
+ mixin(q{ void } ~ memberName ~ q{ (EventRegistrationToken token) {
+ __traits(getMember, object, memberName)(token);
+ }});
+ } else {
+ // I could do the return value things by looking for these comments:
+ // /+[out]+/ but be warned it is possible or a thing to have multiple out params (only one such function in here though i think)
+ // /+[out, retval]+/
+ // a find/replace could make them a UDA or something.
+
+ static if(is(typeof(__traits(getMember, T, memberName)) Params == function))
+ static if(is(typeof(__traits(getMember, T, memberName)) Return == return))
+
+ mixin(q{ Return } ~ memberName ~ q{ (Params p) {
+ // FIXME: check the return value and throw
+ return __traits(getMember, object, memberName)(p);
+ }
+ });
+
+ }
+}
+
+struct Wv2App {
+ static bool active = false;
+
+ static HRESULT code;
+ static bool initialized = false;
+ static RC!ICoreWebView2Environment webview_env;
+
+ @disable this(this);
+
+ static void delegate(RC!ICoreWebView2Environment)[] pending;
+ this(void delegate(RC!ICoreWebView2Environment) withEnvironment) {
+ if(withEnvironment)
+ pending ~= withEnvironment;
+
+ import core.sys.windows.com;
+ CoInitializeEx(null, COINIT_APARTMENTTHREADED);
+
+ active = true;
+
+ auto lib = LoadLibraryW("WebView2Loader.dll"w.ptr);
+ typeof(&CreateCoreWebView2EnvironmentWithOptions) func;
+
+ if(lib is null)
+ throw new Exception("WebView2Loader.dll unable to load. The developer should bundle this with the application exe. It is found with the WebView2 SDK from nuget.");
+ func = cast(typeof(func)) GetProcAddress(lib, CreateCoreWebView2EnvironmentWithOptions.mangleof);
+ if(func is null)
+ throw new Exception("CreateCoreWebView2EnvironmentWithOptions failed from WebView2Loader...");
+
+ auto result = func(null, null, null,
+ callback!(ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler)(
+ delegate(error, env) {
+ initialized = true;
+ code = error;
+
+ if(error)
+ return error;
+
+ webview_env = env;
+
+ auto len = pending.length;
+ foreach(item; pending) {
+ item(webview_env);
+ }
+
+ pending = pending[len .. $];
+
+ return S_OK;
+ }
+ )
+ );
+
+ if(result != S_OK) {
+ if(MessageBox(null, "The WebView2 runtime is not installed. Would you like to install it now? This will open a browser to download a file. After it installs, you can try running this program again.", "Missing file", MB_YESNO) == IDYES) {
+ import std.process;
+ browse("https://go.microsoft.com/fwlink/p/?LinkId=2124703");
+ }
+ throw new ComException(result);
+ }
+ }
+
+ @disable this();
+
+ ~this() {
+ active = false;
+ }
+
+ static void useEnvironment(void delegate(RC!ICoreWebView2Environment) withEnvironment) {
+ assert(active);
+ assert(withEnvironment !is null);
+ if(initialized) {
+ if(code)
+ throw new ComException(code);
+ withEnvironment(webview_env);
+ } else
+ pending ~= withEnvironment;
+ }
+}
+}
+
+
+
+/+
+interface WebView {
+ void refresh();
+ void back();
+ void forward();
+ void stop();
+
+ void navigate(string url);
+
+ // the url and line are for error reporting purposes
+ void executeJavascript(string code, string url = null, int line = 0);
+
+ void showDevTools();
+
+ // these are get/set properties that you can subscribe to with some system
+
+ mixin Observable!(string, "title");
+ mixin Observable!(string, "url");
+ mixin Observable!(string, "status");
+ mixin Observable!(int, "loadingProgress");
+}
++/
+
+
+version(linux) {
+version(linux_gtk) {} else
+ version=cef;
+}
+
+
version(cef) {
import arsd.simpledisplay;
-pragma(lib, "cef");
-
-class MyCefClient : CEF!cef_client_t {
- MyCefLifeSpanHandler lsh;
- this() {
- lsh = new MyCefLifeSpanHandler();
- }
-
- override _cef_audio_handler_t* get_audio_handler() {
- return null;
- }
- override _cef_context_menu_handler_t* get_context_menu_handler() {
- return null;
- }
- override _cef_dialog_handler_t* get_dialog_handler() {
- return null;
- }
- override _cef_display_handler_t* get_display_handler() {
- return null;
- }
- override _cef_download_handler_t* get_download_handler() {
- return null;
- }
- override _cef_drag_handler_t* get_drag_handler() {
- return null;
- }
- override _cef_find_handler_t* get_find_handler() {
- return null;
- }
- override _cef_focus_handler_t* get_focus_handler() {
- return null;
- }
- override _cef_jsdialog_handler_t* get_jsdialog_handler() {
- return null;
- }
- override _cef_keyboard_handler_t* get_keyboard_handler() {
- return null;
- }
- override _cef_life_span_handler_t* get_life_span_handler() {
- return lsh.returnable;
- }
- override _cef_load_handler_t* get_load_handler() {
- return null;
- }
- override _cef_render_handler_t* get_render_handler() {
- return null;
- }
- override _cef_request_handler_t* get_request_handler() {
- return null;
- }
- override int on_process_message_received(RC!_cef_browser_t, RC!_cef_frame_t, cef_process_id_t, RC!_cef_process_message_t) {
- // FIXME: supposed to release references
- return 0; // return 1 if you can actually handle the message
- }
-}
-
-// FIXME: make a CefStruct thing that refcounts and just forwards automatically for the parameters.
-
-class MyCefLifeSpanHandler : CEF!cef_life_span_handler_t {
- override int on_before_popup(RC!_cef_browser_t, RC!_cef_frame_t, const(_cef_string_utf16_t)*, const(_cef_string_utf16_t)*, cef_window_open_disposition_t, int, const(_cef_popup_features_t)*, _cef_window_info_t*, _cef_client_t**, _cef_browser_settings_t*, _cef_dictionary_value_t**, int*) {
- // FIXME: supposed to release references
- return 0;
- }
- override void on_after_created(RC!_cef_browser_t browser) {
- /*
- auto frame = browser.get_main_frame();
- cef_string_t omg = cef_string_t("http://dpldocs.info"w);
- frame.load_url(frame, &omg);
- */
- }
- override int do_close(RC!_cef_browser_t browser) {
- return 0;
- }
- override void on_before_close(RC!_cef_browser_t browser) {
- }
-}
+//pragma(lib, "cef");
class BrowserProcessHandler : CEF!cef_browser_process_handler_t {
- override void get_cookieable_schemes(void*, int* includeDefaults) { *includeDefaults = 1; }
override void on_context_initialized() { }
- override _cef_print_handler_t* get_print_handler() {
- return null;
- }
- override void on_before_child_process_launch(RC!_cef_command_line_t) { }
+ override void on_before_child_process_launch(RC!cef_command_line_t) { }
override void on_schedule_message_pump_work(long delayMs) { }
- override _cef_client_t* get_default_client() { return null; }
+ override cef_client_t* get_default_client() { return null; }
}
@@ -114,38 +315,63 @@ int cefProcessHelper() {
import core.stdc.stdlib;
cef_main_args_t main_args;
- main_args.argc = Runtime.cArgs.argc;
- main_args.argv = Runtime.cArgs.argv;
+ version(linux) {
+ main_args.argc = Runtime.cArgs.argc;
+ main_args.argv = Runtime.cArgs.argv;
+ } else version(Windows) {
+ main_args.instance = GetModuleHandle(null);
+ }
- int code = cef_execute_process(&main_args, null, null);
- if(code >= 0)
- exit(code);
- return code;
+ if(libcef.loadDynamicLibrary()) {
+ int code = libcef.execute_process(&main_args, null, null);
+ if(code >= 0)
+ exit(code);
+ return code;
+ }
+ return -1;
}
shared static this() {
cefProcessHelper();
}
-struct CefApp {
+public struct CefApp {
+ static bool active() {
+ return count > 0;
+ }
+
+ private __gshared int count = 0;
+
@disable this(this);
@disable new();
this(void delegate(cef_settings_t* settings) setSettings) {
+
+ if(!libcef.loadDynamicLibrary())
+ throw new Exception("failed to load cef dll");
+
+ count++;
+
import core.runtime;
import core.stdc.stdlib;
cef_main_args_t main_args;
- main_args.argc = Runtime.cArgs.argc;
- main_args.argv = Runtime.cArgs.argv;
+ version(linux) {
+ main_args.argc = Runtime.cArgs.argc;
+ main_args.argv = Runtime.cArgs.argv;
+ } else version(Windows) {
+ main_args.instance = GetModuleHandle(null);
+ }
cef_settings_t settings;
settings.size = cef_settings_t.sizeof;
- settings.log_severity = cef_log_severity_t.LOGSEVERITY_DISABLE; // Show only warnings/errors
- //settings.log_severity = cef_log_severity_t.LOGSEVERITY_WARNING; // Show only warnings/errors
- //settings.external_message_pump = 1;
+ //settings.log_severity = cef_log_severity_t.LOGSEVERITY_DISABLE; // Show only warnings/errors
+ settings.log_severity = cef_log_severity_t.LOGSEVERITY_INFO; // Show only warnings/errors
settings.multi_threaded_message_loop = 1;
settings.no_sandbox = 1;
+ version(linux)
+ settings.locales_dir_path = cef_string_t("/opt/cef/Resources/locales");
+
if(setSettings !is null)
setSettings(&settings);
@@ -157,31 +383,35 @@ struct CefApp {
}
override void on_before_command_line_processing(const(cef_string_t)*, RC!cef_command_line_t) {}
- override _cef_resource_bundle_handler_t* get_resource_bundle_handler() {
+ override cef_resource_bundle_handler_t* get_resource_bundle_handler() {
return null;
}
- override _cef_browser_process_handler_t* get_browser_process_handler() {
+ override cef_browser_process_handler_t* get_browser_process_handler() {
return bph.returnable;
}
- override _cef_render_process_handler_t* get_render_process_handler() {
+ override cef_render_process_handler_t* get_render_process_handler() {
return null;
}
- override void on_register_custom_schemes(_cef_scheme_registrar_t*) {
+ override void on_register_custom_schemes(cef_scheme_registrar_t*) {
}
};
- if(!cef_initialize(&main_args, &settings, app.passable, null)) {
+ if(!libcef.initialize(&main_args, &settings, app.passable, null)) {
throw new Exception("cef_initialize failed");
}
}
~this() {
- cef_shutdown();
+ count--;
+ // this call hangs and idk why.
+ // FIXME
+ //libcef.shutdown();
}
}
+version(Demo)
void main() {
auto app = CefApp(null);
@@ -197,7 +427,7 @@ void main() {
*/
//window_info.parent_window = window.nativeWindowHandle;
- cef_string_t cef_url = cef_string_t("http://youtube.com/"w);
+ cef_string_t cef_url = cef_string_t("http://dpldocs.info/");//"http://youtube.com/"w);
//string url = "http://arsdnet.net/";
//cef_string_utf8_to_utf16(url.ptr, url.length, &cef_url);
@@ -207,10 +437,78 @@ void main() {
auto client = new MyCefClient();
- auto got = cef_browser_host_create_browser(&window_info, client.passable, &cef_url, &browser_settings, null, null); // or _sync
+ auto got = libcef.browser_host_create_browser(&window_info, client.passable, &cef_url, &browser_settings, null, null); // or _sync
window.eventLoop(0);
}
+
+
+/++
+ This gives access to the CEF functions. If you get a linker error for using an undefined function,
+ it is probably because you did NOT go through this when dynamically loading.
+
+ (...similarly, if you get a segfault, it is probably because you DID go through this when static binding.)
++/
+struct libcef {
+ static __gshared:
+
+ bool isLoaded;
+ bool loadAttempted;
+ void* libHandle;
+
+ /// Make sure you call this only from one thread, probably at process startup. It caches internally and returns true if the load was successful.
+ bool loadDynamicLibrary() {
+ if(loadAttempted)
+ return isLoaded;
+
+ loadAttempted = true;
+
+ version(linux) {
+ import core.sys.posix.dlfcn;
+ libHandle = dlopen("libcef.so", RTLD_NOW);
+
+ static void* loadsym(const char* name) {
+ return dlsym(libHandle, name);
+ }
+ } else version(Windows) {
+ import core.sys.windows.windows;
+ libHandle = LoadLibrary("libcef.dll");
+
+ static void* loadsym(const char* name) {
+ return GetProcAddress(libHandle, name);
+ }
+ }
+
+ //import std.stdio;
+ if(libHandle is null) {
+ //writeln("libhandlenull");
+ return false;
+ }
+ foreach(memberName; __traits(allMembers, libcef)[4 .. $]) { // cutting off everything until the actual static foreach below; this trims off isLoaded to loadDynamicLibrary
+ alias mem = __traits(getMember, libcef, memberName);
+ mem = cast(typeof(mem)) loadsym("cef_" ~ memberName);
+ if(mem is null) {
+ // writeln(memberName);
+ // throw new Exception("cef_" ~ memberName ~ " failed to load");
+ return false;
+ }
+ }
+
+ import core.stdc.string;
+ if(strcmp(libcef.api_hash(1), CEF_API_HASH_UNIVERSAL) != 0)
+ throw new Exception("libcef versions not matching bindings");
+
+ isLoaded = true;
+ return true;
+ }
+
+ static foreach(memberName; __traits(allMembers, arsd.webview))
+ static if(is(typeof(__traits(getMember, arsd.webview, memberName)) == function))
+ static if(memberName.length > 4 && memberName[0 .. 4] == "cef_") {
+ mixin(q{ typeof(&__traits(getMember, arsd.webview, memberName)) } ~ memberName[4 .. $] ~ ";"); // = &" ~ memberName ~ ";");
+ }
+}
+
}
version(linux_gtk)
@@ -362,7 +660,7 @@ private extern(C) {
alias msg_cb_t = void function(const char *msg);
}
-version(WEBVIEW_GTK) {
+version(linux_gtk) {
/* Original https://github.com/zserge/webview notice below:
@@ -746,7 +1044,7 @@ abstract class CEF(Base) {
}
}
- private static nothrow @nogc extern(C) {
+ private static nothrow @nogc extern(System) {
void c_add_ref(cef_base_ref_counted_t* self) {
return ((cast(Inner*) self).d_object).add_ref();
}
@@ -814,7 +1112,7 @@ private mixin template AbstractMethod(string name) {
// mixin(q{abstract nothrow Return } ~ name ~ q{(Params[1 .. $] p);});
mixin(q{
- private static nothrow extern(C)
+ private static nothrow extern(System)
Return c_}~name~q{(Params p) {
Base* self = p[0]; // a bit of a type check here...
auto dobj = (cast(Inner*) self).d_object; // ...before this cast.
@@ -894,6 +1192,9 @@ struct RC(Base) {
inner.base.release(&inner.base);
inner = null;
}
+ bool opCast(T:bool)() nothrow {
+ return inner !is null;
+ }
Base* getRawPointer() nothrow {
return inner;
@@ -902,6 +1203,7 @@ struct RC(Base) {
Base* passable() nothrow {
if(inner is null)
return inner;
+
inner.base.add_ref(&inner.base);
return inner;
}
@@ -913,7 +1215,6 @@ struct RC(Base) {
mixin(q{final ref @property } ~ memberName ~ q{() { return __traits(getMember, inner, memberName); }});
}
}
-
}
auto cefToD(T)(T t) {
@@ -924,26 +1225,70 @@ auto cefToD(T)(T t) {
}
}
-// bindings follow, first some hand-written ones for Linux, then some machine translated things.
+string toGC(const cef_string_utf16_t str) nothrow {
+ if(str.str is null)
+ return null;
+
+ string s;
+ s.reserve(str.length);
+
+ try
+ foreach(char ch; str.str[0 .. str.length])
+ s ~= ch;
+ catch(Exception e) {}
+ return s;
+}
+
+string toGC(const cef_string_utf16_t* str) nothrow {
+ if(str is null)
+ return null;
+ return toGC(*str);
+}
+
+string toGCAndFree(const cef_string_userfree_t str) nothrow {
+ if(str is null)
+ return null;
+
+ string s = toGC(str);
+ libcef.string_userfree_utf16_free(str);
+ //str = null;
+ return s;
+}
+
+// bindings follow, first some hand-written ones for Linux, then some machine translated things. More comments about the machine translation when it comes.
+
+version(linux)
struct cef_main_args_t {
int argc;
char** argv;
}
-alias _cef_main_args_t = cef_main_args_t;
+version(Windows)
+struct cef_main_args_t {
+ HINSTANCE instance;
+}
-extern(C)
+// 0 - CEF_VERSION_MAJOR
+// 1 - CEF_VERSION_MINOR
+// 2 - CEF_VERSION_PATCH
+// 3 - CEF_COMMIT_NUMBER
+// 4 - CHROME_VERSION_MAJOR
+// 5 - CHROME_VERSION_MINOR
+// 6 - CHROME_VERSION_BUILD
+// 7 - CHROME_VERSION_PATCH
+
+extern(C) nothrow
int cef_string_utf8_to_utf16(const char* src, size_t src_len, cef_string_utf16_t* output);
-struct _cef_string_utf8_t {
+struct cef_string_utf8_t {
char* str;
size_t length;
void* dtor;// void (*dtor)(char* str);
}
-alias cef_string_utf8_t = _cef_string_utf8_t;
-struct _cef_string_utf16_t {
+
+struct cef_string_utf16_t {
char16* str;
size_t length;
void* dtor; // voiod (*dtor)(char16* str);
@@ -952,12 +1297,18 @@ struct _cef_string_utf16_t {
this.str = cast(char16*) s.ptr;
this.length = s.length;
}
-}
-alias _cef_string_utf16_t cef_string_utf16_t;
+ this(string s) nothrow {
+ libcef.string_utf8_to_utf16(s.ptr, s.length, &this);
+ }
+}
alias cef_string_t = cef_string_utf16_t;
alias cef_window_handle_t = NativeWindowHandle;
+version(Windows)
+ alias cef_cursor_handle_t = HCURSOR;
+else
+ alias cef_cursor_handle_t = XID;
struct cef_time_t {
int year; // Four or five digit year "2007" (1601 to 30827 on
@@ -972,7 +1323,8 @@ struct cef_time_t {
int millisecond; // Milliseconds within the current second (0-999)
}
-struct _cef_window_info_t {
+version(linux)
+struct cef_window_info_t {
cef_string_t window_name;
uint x;
@@ -991,7 +1343,21 @@ struct _cef_window_info_t {
cef_window_handle_t window;
}
-alias cef_window_info_t = _cef_window_info_t;
+version(Windows)
+struct cef_window_info_t {
+ DWORD ex_style;
+ cef_string_t window_name;
+ DWORD style;
+ cef_rect_t bounds;
+ cef_window_handle_t parent_window;
+ HMENU menu;
+ int windowless_rendering_enabled;
+ int shared_texture_enabled;
+ int external_begin_frame_enabled;
+ cef_window_handle_t window;
+}
+
+
import core.stdc.config;
alias int16 = short;
@@ -1002,10 +1368,22 @@ alias char16 = wchar;
alias int64 = long;
alias uint64 = ulong;
-// FIXME
-alias cef_string_list_t = void*;
-alias cef_string_multimap_t = void*;
-alias cef_string_map_t = void*;
+// these are supposed to just be opaque pointers but i want some type safety. this same abi wise.......... RIGHT?
+struct cef_string_list_t { void* r; }
+struct cef_string_multimap_t { void* r; }
+struct cef_string_map_t { void* r; }
+
+
+extern(C) nothrow {
+ cef_string_list_t cef_string_list_alloc();
+ size_t cef_string_list_size(cef_string_list_t list);
+ int cef_string_list_value(cef_string_list_t list, size_t index, cef_string_t* value);
+ void cef_string_list_append(cef_string_list_t list, const cef_string_t* value);
+ void cef_string_list_clear(cef_string_list_t list);
+ void cef_string_list_free(cef_string_list_t list);
+ cef_string_list_t cef_string_list_copy(cef_string_list_t list);
+}
+
version(linux) {
import core.sys.posix.sys.types;
@@ -1017,20 +1395,32 @@ version(linux) {
alias OS_EVENT = void;
}
-nothrow @nogc extern(C) void cef_string_userfree_utf16_free(cef_string_userfree_utf16_t str);
-alias cef_string_userfree_t = const(wchar)*;
-alias cef_string_userfree_utf16_t = const(wchar)*;
+nothrow @nogc extern(C) void cef_string_userfree_utf16_free(const cef_string_userfree_utf16_t str);
+struct cef_string_userfree_utf16_t { cef_string_utf16_t* it; alias it this; }
+alias cef_string_userfree_t = cef_string_userfree_utf16_t;
-static assert(cef_app_t.sizeof == 80);
-static assert(cef_settings_t.sizeof == 440);
-static assert(cef_window_info_t.sizeof == 72);
-static assert(cef_string_t.sizeof == 24);
-static assert(cef_client_t.sizeof == 160);
+// **************
// cef/include/capi$ for i in *.h; do dstep -I../.. $i; done
+// also dstep include/cef_version.h
+// update the CEF_VERSION and the CEF_API_HASH_UNIVERSAL out of cef_version.h and cef_api_hash.h
// then concatenate the bodies of them and delete the translated macros and `struct .*;` stuff
+// then I added nothrow to all function pointers with a vim macro (`/function (e%a nothrow` then just hold in @ to do the @@ repeat macro command until it was done
+// then select all and global replace s/_cef/cef/g
+// then delete the pointless aliases find with `/alias \(.*\) = \1;` and delete with 2dd. macros can do the job or just simple global replace to nothing. blank lines don't matter.
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
+// and make sure version(linux) void cef_register_widevine_cdm ( if it is there.
+
+// and extern (C) is wrong on the callbacks, they should all be extern(System)
+// `/function (Oextern(System)`
+
+
+version=embedded_cef_bindings;
+
+// everything inside these brackets are the bindings you can replace if update needed
+
+version(embedded_cef_bindings) {
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
@@ -1061,48 +1451,43 @@ static assert(cef_client_t.sizeof == 160);
//
// ---------------------------------------------------------------------------
//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=00d5124d346e3f3cc3f53d67bcb766d1d798bf12$
+// This file was generated by the make_version_header.py tool.
//
extern (C):
+enum CEF_VERSION = "95.7.17+g4208276+chromium-95.0.4638.69";
+enum CEF_VERSION_MAJOR = 95;
+enum CEF_VERSION_MINOR = 7;
+enum CEF_VERSION_PATCH = 17;
+enum CEF_COMMIT_NUMBER = 2459;
+enum CEF_COMMIT_HASH = "4208276762b1f52ed444debd7caa84fc3332e6a9";
+enum COPYRIGHT_YEAR = 2021;
+
+enum CHROME_VERSION_MAJOR = 95;
+enum CHROME_VERSION_MINOR = 0;
+enum CHROME_VERSION_BUILD = 4638;
+enum CHROME_VERSION_PATCH = 69;
+
+
+
+// Returns CEF version information for the libcef library. The |entry|
+// parameter describes which version component will be returned:
+// 0 - CEF_VERSION_MAJOR
+// 1 - CEF_VERSION_MINOR
+// 2 - CEF_VERSION_PATCH
+// 3 - CEF_COMMIT_NUMBER
+// 4 - CHROME_VERSION_MAJOR
+// 5 - CHROME_VERSION_MINOR
+// 6 - CHROME_VERSION_BUILD
+// 7 - CHROME_VERSION_PATCH
///
-// Implement this structure to receive accessibility notification when
-// accessibility events have been registered. The functions of this structure
-// will be called on the UI thread.
-///
-struct _cef_accessibility_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
+int cef_version_info (int entry);
- ///
- // Called after renderer process sends accessibility tree changes to the
- // browser process.
- ///
- void function (
- _cef_accessibility_handler_t* self,
- _cef_value_t* value) nothrow on_accessibility_tree_change;
+// APSTUDIO_HIDDEN_SYMBOLS
- ///
- // Called after renderer process sends accessibility location changes to the
- // browser process.
- ///
- void function (
- _cef_accessibility_handler_t* self,
- _cef_value_t* value) nothrow on_accessibility_location_change;
-}
-
-alias cef_accessibility_handler_t = _cef_accessibility_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
+// CEF_INCLUDE_CEF_VERSION_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
@@ -1133,345 +1518,31 @@ alias cef_accessibility_handler_t = _cef_accessibility_handler_t;
//
// ---------------------------------------------------------------------------
//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=04cfae434fe901644c1c78f1c30c0921518cc666$
+// This file was generated by the make_api_hash_header.py tool.
//
extern (C):
-///
-// Implement this structure to provide handler implementations. Methods will be
-// called by the process and/or thread indicated.
-///
-struct _cef_app_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
+// The API hash is created by analyzing CEF header files for C API type
+// definitions. The hash value will change when header files are modified in a
+// way that may cause binary incompatibility with other builds. The universal
+// hash value will change if any platform is affected whereas the platform hash
+// values will change only if that particular platform is affected.
+enum CEF_API_HASH_UNIVERSAL = "21ac25aebdb49a8e8088c6fbee802b04fd07b501";
- ///
- // Provides an opportunity to view and/or modify command-line arguments before
- // processing by CEF and Chromium. The |process_type| value will be NULL for
- // the browser process. Do not keep a reference to the cef_command_line_t
- // object passed to this function. The CefSettings.command_line_args_disabled
- // value can be used to start with an NULL command-line object. Any values
- // specified in CefSettings that equate to command-line arguments will be set
- // before this function is called. Be cautious when using this function to
- // modify command-line arguments for non-browser processes as this may result
- // in undefined behavior including crashes.
- ///
- void function (
- _cef_app_t* self,
- const(cef_string_t)* process_type,
- _cef_command_line_t* command_line) nothrow on_before_command_line_processing;
-
- ///
- // Provides an opportunity to register custom schemes. Do not keep a reference
- // to the |registrar| object. This function is called on the main thread for
- // each process and the registered schemes should be the same across all
- // processes.
- ///
- void function (
- _cef_app_t* self,
- _cef_scheme_registrar_t* registrar) nothrow on_register_custom_schemes;
-
- ///
- // Return the handler for resource bundle events. If
- // CefSettings.pack_loading_disabled is true (1) a handler must be returned.
- // If no handler is returned resources will be loaded from pack files. This
- // function is called by the browser and render processes on multiple threads.
- ///
- _cef_resource_bundle_handler_t* function (
- _cef_app_t* self) nothrow get_resource_bundle_handler;
-
- ///
- // Return the handler for functionality specific to the browser process. This
- // function is called on multiple threads in the browser process.
- ///
- _cef_browser_process_handler_t* function (
- _cef_app_t* self) nothrow get_browser_process_handler;
-
- ///
- // Return the handler for functionality specific to the render process. This
- // function is called on the render process main thread.
- ///
- _cef_render_process_handler_t* function (
- _cef_app_t* self) nothrow get_render_process_handler;
-}
-
-alias cef_app_t = _cef_app_t;
+enum CEF_API_HASH_PLATFORM = "0b5227787444955a548b7544b2cdcda95a354506";
///
-// This function should be called from the application entry point function to
-// execute a secondary process. It can be used to run secondary processes from
-// the browser client executable (default behavior) or from a separate
-// executable specified by the CefSettings.browser_subprocess_path value. If
-// called for the browser process (identified by no "type" command-line value)
-// it will return immediately with a value of -1. If called for a recognized
-// secondary process it will block until the process should exit and then return
-// the process exit code. The |application| parameter may be NULL. The
-// |windows_sandbox_info| parameter is only used on Windows and may be NULL (see
-// cef_sandbox_win.h for details).
+// Returns CEF API hashes for the libcef library. The returned string is owned
+// by the library and should not be freed. The |entry| parameter describes which
+// hash value will be returned:
+// 0 - CEF_API_HASH_PLATFORM
+// 1 - CEF_API_HASH_UNIVERSAL
+// 2 - CEF_COMMIT_HASH (from cef_version.h)
///
-int cef_execute_process (
- const(_cef_main_args_t)* args,
- cef_app_t* application,
- void* windows_sandbox_info);
+const(char)* cef_api_hash (int entry);
-///
-// This function should be called on the main application thread to initialize
-// the CEF browser process. The |application| parameter may be NULL. A return
-// value of true (1) indicates that it succeeded and false (0) indicates that it
-// failed. The |windows_sandbox_info| parameter is only used on Windows and may
-// be NULL (see cef_sandbox_win.h for details).
-///
-int cef_initialize (
- const(_cef_main_args_t)* args,
- const(_cef_settings_t)* settings,
- cef_app_t* application,
- void* windows_sandbox_info);
-
-///
-// This function should be called on the main application thread to shut down
-// the CEF browser process before the application exits.
-///
-void cef_shutdown ();
-
-///
-// Perform a single iteration of CEF message loop processing. This function is
-// provided for cases where the CEF message loop must be integrated into an
-// existing application message loop. Use of this function is not recommended
-// for most users; use either the cef_run_message_loop() function or
-// CefSettings.multi_threaded_message_loop if possible. When using this function
-// care must be taken to balance performance against excessive CPU usage. It is
-// recommended to enable the CefSettings.external_message_pump option when using
-// this function so that
-// cef_browser_process_handler_t::on_schedule_message_pump_work() callbacks can
-// facilitate the scheduling process. This function should only be called on the
-// main application thread and only if cef_initialize() is called with a
-// CefSettings.multi_threaded_message_loop value of false (0). This function
-// will not block.
-///
-nothrow void cef_do_message_loop_work ();
-
-///
-// Run the CEF message loop. Use this function instead of an application-
-// provided message loop to get the best balance between performance and CPU
-// usage. This function should only be called on the main application thread and
-// only if cef_initialize() is called with a
-// CefSettings.multi_threaded_message_loop value of false (0). This function
-// will block until a quit message is received by the system.
-///
-void cef_run_message_loop ();
-
-///
-// Quit the CEF message loop that was started by calling cef_run_message_loop().
-// This function should only be called on the main application thread and only
-// if cef_run_message_loop() was used.
-///
-void cef_quit_message_loop ();
-
-///
-// Set to true (1) before calling Windows APIs like TrackPopupMenu that enter a
-// modal message loop. Set to false (0) after exiting the modal message loop.
-///
-void cef_set_osmodal_loop (int osModalLoop);
-
-///
-// Call during process startup to enable High-DPI support on Windows 7 or newer.
-// Older versions of Windows should be left DPI-unaware because they do not
-// support DirectWrite and GDI fonts are kerned very badly.
-///
-void cef_enable_highdpi_support ();
-
-// CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=430877d950508a545d0baa18c8c8c0d2d183fec4$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle audio events.
-///
-struct _cef_audio_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the UI thread to allow configuration of audio stream parameters.
- // Return true (1) to proceed with audio stream capture, or false (0) to
- // cancel it. All members of |params| can optionally be configured here, but
- // they are also pre-filled with some sensible defaults.
- ///
- int function (
- _cef_audio_handler_t* self,
- _cef_browser_t* browser,
- cef_audio_parameters_t* params) nothrow get_audio_parameters;
-
- ///
- // Called on a browser audio capture thread when the browser starts streaming
- // audio. OnAudioSteamStopped will always be called after
- // OnAudioStreamStarted; both functions may be called multiple times for the
- // same browser. |params| contains the audio parameters like sample rate and
- // channel layout. |channels| is the number of channels.
- ///
- void function (
- _cef_audio_handler_t* self,
- _cef_browser_t* browser,
- const(cef_audio_parameters_t)* params,
- int channels) nothrow on_audio_stream_started;
-
- ///
- // Called on the audio stream thread when a PCM packet is received for the
- // stream. |data| is an array representing the raw PCM data as a floating
- // point type, i.e. 4-byte value(s). |frames| is the number of frames in the
- // PCM packet. |pts| is the presentation timestamp (in milliseconds since the
- // Unix Epoch) and represents the time at which the decompressed packet should
- // be presented to the user. Based on |frames| and the |channel_layout| value
- // passed to OnAudioStreamStarted you can calculate the size of the |data|
- // array in bytes.
- ///
- void function (
- _cef_audio_handler_t* self,
- _cef_browser_t* browser,
- const(float*)* data,
- int frames,
- int64 pts) nothrow on_audio_stream_packet;
-
- ///
- // Called on the UI thread when the stream has stopped. OnAudioSteamStopped
- // will always be called after OnAudioStreamStarted; both functions may be
- // called multiple times for the same stream.
- ///
- void function (
- _cef_audio_handler_t* self,
- _cef_browser_t* browser) nothrow on_audio_stream_stopped;
-
- ///
- // Called on the UI or audio stream thread when an error occurred. During the
- // stream creation phase this callback will be called on the UI thread while
- // in the capturing phase it will be called on the audio stream thread. The
- // stream will be stopped immediately.
- ///
- void function (
- _cef_audio_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* message) nothrow on_audio_stream_error;
-}
-
-alias cef_audio_handler_t = _cef_audio_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_AUDIO_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=58be0e24b46373bbdad28031891396ea246f446c$
-//
-
-extern (C):
-
-///
-// Callback structure used for asynchronous continuation of authentication
-// requests.
-///
-struct _cef_auth_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Continue the authentication request.
- ///
- void function (
- _cef_auth_callback_t* self,
- const(cef_string_t)* username,
- const(cef_string_t)* password) nothrow cont;
-
- ///
- // Cancel the authentication request.
- ///
- void function (_cef_auth_callback_t* self) nothrow cancel;
-}
-
-alias cef_auth_callback_t = _cef_auth_callback_t;
-
-// CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_
+// CEF_INCLUDE_API_HASH_H_
// Copyright (c) 2014 Marshall A. Greenblatt. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
@@ -1504,13168 +1575,54 @@ alias cef_auth_callback_t = _cef_auth_callback_t;
extern (C):
///
-// All ref-counted framework structures must include this structure first.
+// Structure representing a point.
///
-struct _cef_base_ref_counted_t
+struct cef_point_t
{
- ///
- // Size of the data structure.
- ///
- size_t size;
-
- ///
- // Called to increment the reference count for the object. Should be called
- // for every new copy of a pointer to a given object.
- ///
- void function (_cef_base_ref_counted_t* self) nothrow add_ref;
-
- ///
- // Called to decrement the reference count for the object. If the reference
- // count falls to 0 the object should self-delete. Returns true (1) if the
- // resulting reference count is 0.
- ///
- int function (_cef_base_ref_counted_t* self) nothrow release;
-
- ///
- // Returns true (1) if the current reference count is 1.
- ///
- int function (_cef_base_ref_counted_t* self) nothrow has_one_ref;
-
- ///
- // Returns true (1) if the current reference count is at least 1.
- ///
- int function (_cef_base_ref_counted_t* self) nothrow has_at_least_one_ref;
-}
-
-alias cef_base_ref_counted_t = _cef_base_ref_counted_t;
-
-///
-// All scoped framework structures must include this structure first.
-///
-struct _cef_base_scoped_t
-{
- ///
- // Size of the data structure.
- ///
- size_t size;
-
- ///
- // Called to delete this object. May be NULL if the object is not owned.
- ///
- void function (_cef_base_scoped_t* self) del;
-}
-
-alias cef_base_scoped_t = _cef_base_scoped_t;
-
-// CEF_INCLUDE_CAPI_CEF_BASE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=965eb2e55afec0a4618a7acd9478b9c1215be29d$
-//
-
-import core.stdc.config;
-
-extern (C):
-
-///
-// Structure used to represent a browser window. When used in the browser
-// process the functions of this structure may be called on any thread unless
-// otherwise indicated in the comments. When used in the render process the
-// functions of this structure may only be called on the main thread.
-///
-struct _cef_browser_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the browser host object. This function can only be called in the
- // browser process.
- ///
- _cef_browser_host_t* function (_cef_browser_t* self) nothrow get_host;
-
- ///
- // Returns true (1) if the browser can navigate backwards.
- ///
- int function (_cef_browser_t* self) nothrow can_go_back;
-
- ///
- // Navigate backwards.
- ///
- void function (_cef_browser_t* self) nothrow go_back;
-
- ///
- // Returns true (1) if the browser can navigate forwards.
- ///
- int function (_cef_browser_t* self) nothrow can_go_forward;
-
- ///
- // Navigate forwards.
- ///
- void function (_cef_browser_t* self) nothrow go_forward;
-
- ///
- // Returns true (1) if the browser is currently loading.
- ///
- int function (_cef_browser_t* self) nothrow is_loading;
-
- ///
- // Reload the current page.
- ///
- void function (_cef_browser_t* self) nothrow reload;
-
- ///
- // Reload the current page ignoring any cached data.
- ///
- void function (_cef_browser_t* self) nothrow reload_ignore_cache;
-
- ///
- // Stop loading the page.
- ///
- void function (_cef_browser_t* self) nothrow stop_load;
-
- ///
- // Returns the globally unique identifier for this browser. This value is also
- // used as the tabId for extension APIs.
- ///
- int function (_cef_browser_t* self) nothrow get_identifier;
-
- ///
- // Returns true (1) if this object is pointing to the same handle as |that|
- // object.
- ///
- int function (_cef_browser_t* self, _cef_browser_t* that) nothrow is_same;
-
- ///
- // Returns true (1) if the window is a popup window.
- ///
- int function (_cef_browser_t* self) nothrow is_popup;
-
- ///
- // Returns true (1) if a document has been loaded in the browser.
- ///
- int function (_cef_browser_t* self) nothrow has_document;
-
- ///
- // Returns the main (top-level) frame for the browser window.
- ///
- _cef_frame_t* function (_cef_browser_t* self) nothrow get_main_frame;
-
- ///
- // Returns the focused frame for the browser window.
- ///
- _cef_frame_t* function (_cef_browser_t* self) nothrow get_focused_frame;
-
- ///
- // Returns the frame with the specified identifier, or NULL if not found.
- ///
- _cef_frame_t* function (
- _cef_browser_t* self,
- int64 identifier) nothrow get_frame_byident;
-
- ///
- // Returns the frame with the specified name, or NULL if not found.
- ///
- _cef_frame_t* function (
- _cef_browser_t* self,
- const(cef_string_t)* name) nothrow get_frame;
-
- ///
- // Returns the number of frames that currently exist.
- ///
- size_t function (_cef_browser_t* self) nothrow get_frame_count;
-
- ///
- // Returns the identifiers of all existing frames.
- ///
- void function (
- _cef_browser_t* self,
- size_t* identifiersCount,
- int64* identifiers) nothrow get_frame_identifiers;
-
- ///
- // Returns the names of all existing frames.
- ///
- void function (
- _cef_browser_t* self,
- cef_string_list_t names) nothrow get_frame_names;
-}
-
-alias cef_browser_t = _cef_browser_t;
-
-///
-// Callback structure for cef_browser_host_t::RunFileDialog. The functions of
-// this structure will be called on the browser process UI thread.
-///
-struct _cef_run_file_dialog_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called asynchronously after the file dialog is dismissed.
- // |selected_accept_filter| is the 0-based index of the value selected from
- // the accept filters array passed to cef_browser_host_t::RunFileDialog.
- // |file_paths| will be a single value or a list of values depending on the
- // dialog mode. If the selection was cancelled |file_paths| will be NULL.
- ///
- void function (
- _cef_run_file_dialog_callback_t* self,
- int selected_accept_filter,
- cef_string_list_t file_paths) nothrow on_file_dialog_dismissed;
-}
-
-alias cef_run_file_dialog_callback_t = _cef_run_file_dialog_callback_t;
-
-///
-// Callback structure for cef_browser_host_t::GetNavigationEntries. The
-// functions of this structure will be called on the browser process UI thread.
-///
-struct _cef_navigation_entry_visitor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed. Do not keep a reference to |entry| outside of
- // this callback. Return true (1) to continue visiting entries or false (0) to
- // stop. |current| is true (1) if this entry is the currently loaded
- // navigation entry. |index| is the 0-based index of this entry and |total| is
- // the total number of entries.
- ///
- int function (
- _cef_navigation_entry_visitor_t* self,
- _cef_navigation_entry_t* entry,
- int current,
- int index,
- int total) nothrow visit;
-}
-
-alias cef_navigation_entry_visitor_t = _cef_navigation_entry_visitor_t;
-
-///
-// Callback structure for cef_browser_host_t::PrintToPDF. The functions of this
-// structure will be called on the browser process UI thread.
-///
-struct _cef_pdf_print_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed when the PDF printing has completed. |path| is
- // the output path. |ok| will be true (1) if the printing completed
- // successfully or false (0) otherwise.
- ///
- void function (
- _cef_pdf_print_callback_t* self,
- const(cef_string_t)* path,
- int ok) nothrow on_pdf_print_finished;
-}
-
-alias cef_pdf_print_callback_t = _cef_pdf_print_callback_t;
-
-///
-// Callback structure for cef_browser_host_t::DownloadImage. The functions of
-// this structure will be called on the browser process UI thread.
-///
-struct _cef_download_image_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed when the image download has completed.
- // |image_url| is the URL that was downloaded and |http_status_code| is the
- // resulting HTTP status code. |image| is the resulting image, possibly at
- // multiple scale factors, or NULL if the download failed.
- ///
- void function (
- _cef_download_image_callback_t* self,
- const(cef_string_t)* image_url,
- int http_status_code,
- _cef_image_t* image) nothrow on_download_image_finished;
-}
-
-alias cef_download_image_callback_t = _cef_download_image_callback_t;
-
-///
-// Structure used to represent the browser process aspects of a browser window.
-// The functions of this structure can only be called in the browser process.
-// They may be called on any thread in that process unless otherwise indicated
-// in the comments.
-///
-struct _cef_browser_host_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the hosted browser object.
- ///
- _cef_browser_t* function (_cef_browser_host_t* self) nothrow get_browser;
-
- ///
- // Request that the browser close. The JavaScript 'onbeforeunload' event will
- // be fired. If |force_close| is false (0) the event handler, if any, will be
- // allowed to prompt the user and the user can optionally cancel the close. If
- // |force_close| is true (1) the prompt will not be displayed and the close
- // will proceed. Results in a call to cef_life_span_handler_t::do_close() if
- // the event handler allows the close or if |force_close| is true (1). See
- // cef_life_span_handler_t::do_close() documentation for additional usage
- // information.
- ///
- void function (_cef_browser_host_t* self, int force_close) nothrow close_browser;
-
- ///
- // Helper for closing a browser. Call this function from the top-level window
- // close handler. Internally this calls CloseBrowser(false (0)) if the close
- // has not yet been initiated. This function returns false (0) while the close
- // is pending and true (1) after the close has completed. See close_browser()
- // and cef_life_span_handler_t::do_close() documentation for additional usage
- // information. This function must be called on the browser process UI thread.
- ///
- int function (_cef_browser_host_t* self) nothrow try_close_browser;
-
- ///
- // Set whether the browser is focused.
- ///
- void function (_cef_browser_host_t* self, int focus) nothrow set_focus;
-
- ///
- // Retrieve the window handle for this browser. If this browser is wrapped in
- // a cef_browser_view_t this function should be called on the browser process
- // UI thread and it will return the handle for the top-level native window.
- ///
- c_ulong function (_cef_browser_host_t* self) nothrow get_window_handle;
-
- ///
- // Retrieve the window handle of the browser that opened this browser. Will
- // return NULL for non-popup windows or if this browser is wrapped in a
- // cef_browser_view_t. This function can be used in combination with custom
- // handling of modal windows.
- ///
- c_ulong function (_cef_browser_host_t* self) nothrow get_opener_window_handle;
-
- ///
- // Returns true (1) if this browser is wrapped in a cef_browser_view_t.
- ///
- int function (_cef_browser_host_t* self) nothrow has_view;
-
- ///
- // Returns the client for this browser.
- ///
- _cef_client_t* function (_cef_browser_host_t* self) nothrow get_client;
-
- ///
- // Returns the request context for this browser.
- ///
- _cef_request_context_t* function (
- _cef_browser_host_t* self) nothrow get_request_context;
-
- ///
- // Get the current zoom level. The default zoom level is 0.0. This function
- // can only be called on the UI thread.
- ///
- double function (_cef_browser_host_t* self) nothrow get_zoom_level;
-
- ///
- // Change the zoom level to the specified value. Specify 0.0 to reset the zoom
- // level. If called on the UI thread the change will be applied immediately.
- // Otherwise, the change will be applied asynchronously on the UI thread.
- ///
- void function (_cef_browser_host_t* self, double zoomLevel) nothrow set_zoom_level;
-
- ///
- // Call to run a file chooser dialog. Only a single file chooser dialog may be
- // pending at any given time. |mode| represents the type of dialog to display.
- // |title| to the title to be used for the dialog and may be NULL to show the
- // default title ("Open" or "Save" depending on the mode). |default_file_path|
- // is the path with optional directory and/or file name component that will be
- // initially selected in the dialog. |accept_filters| are used to restrict the
- // selectable file types and may any combination of (a) valid lower-cased MIME
- // types (e.g. "text/*" or "image/*"), (b) individual file extensions (e.g.
- // ".txt" or ".png"), or (c) combined description and file extension delimited
- // using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg").
- // |selected_accept_filter| is the 0-based index of the filter that will be
- // selected by default. |callback| will be executed after the dialog is
- // dismissed or immediately if another dialog is already pending. The dialog
- // will be initiated asynchronously on the UI thread.
- ///
- void function (
- _cef_browser_host_t* self,
- cef_file_dialog_mode_t mode,
- const(cef_string_t)* title,
- const(cef_string_t)* default_file_path,
- cef_string_list_t accept_filters,
- int selected_accept_filter,
- _cef_run_file_dialog_callback_t* callback) nothrow run_file_dialog;
-
- ///
- // Download the file at |url| using cef_download_handler_t.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* url) nothrow start_download;
-
- ///
- // Download |image_url| and execute |callback| on completion with the images
- // received from the renderer. If |is_favicon| is true (1) then cookies are
- // not sent and not accepted during download. Images with density independent
- // pixel (DIP) sizes larger than |max_image_size| are filtered out from the
- // image results. Versions of the image at different scale factors may be
- // downloaded up to the maximum scale factor supported by the system. If there
- // are no image results <= |max_image_size| then the smallest image is resized
- // to |max_image_size| and is the only result. A |max_image_size| of 0 means
- // unlimited. If |bypass_cache| is true (1) then |image_url| is requested from
- // the server even if it is present in the browser cache.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* image_url,
- int is_favicon,
- uint32 max_image_size,
- int bypass_cache,
- _cef_download_image_callback_t* callback) nothrow download_image;
-
- ///
- // Print the current browser contents.
- ///
- void function (_cef_browser_host_t* self) nothrow print;
-
- ///
- // Print the current browser contents to the PDF file specified by |path| and
- // execute |callback| on completion. The caller is responsible for deleting
- // |path| when done. For PDF printing to work on Linux you must implement the
- // cef_print_handler_t::GetPdfPaperSize function.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* path,
- const(_cef_pdf_print_settings_t)* settings,
- _cef_pdf_print_callback_t* callback) nothrow print_to_pdf;
-
- ///
- // Search for |searchText|. |identifier| must be a unique ID and these IDs
- // must strictly increase so that newer requests always have greater IDs than
- // older requests. If |identifier| is zero or less than the previous ID value
- // then it will be automatically assigned a new valid ID. |forward| indicates
- // whether to search forward or backward within the page. |matchCase|
- // indicates whether the search should be case-sensitive. |findNext| indicates
- // whether this is the first request or a follow-up. The cef_find_handler_t
- // instance, if any, returned via cef_client_t::GetFindHandler will be called
- // to report find results.
- ///
- void function (
- _cef_browser_host_t* self,
- int identifier,
- const(cef_string_t)* searchText,
- int forward,
- int matchCase,
- int findNext) nothrow find;
-
- ///
- // Cancel all searches that are currently going on.
- ///
- void function (_cef_browser_host_t* self, int clearSelection) nothrow stop_finding;
-
- ///
- // Open developer tools (DevTools) in its own browser. The DevTools browser
- // will remain associated with this browser. If the DevTools browser is
- // already open then it will be focused, in which case the |windowInfo|,
- // |client| and |settings| parameters will be ignored. If |inspect_element_at|
- // is non-NULL then the element at the specified (x,y) location will be
- // inspected. The |windowInfo| parameter will be ignored if this browser is
- // wrapped in a cef_browser_view_t.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_window_info_t)* windowInfo,
- _cef_client_t* client,
- const(_cef_browser_settings_t)* settings,
- const(cef_point_t)* inspect_element_at) nothrow show_dev_tools;
-
- ///
- // Explicitly close the associated DevTools browser, if any.
- ///
- void function (_cef_browser_host_t* self) nothrow close_dev_tools;
-
- ///
- // Returns true (1) if this browser currently has an associated DevTools
- // browser. Must be called on the browser process UI thread.
- ///
- int function (_cef_browser_host_t* self) nothrow has_dev_tools;
-
- ///
- // Send a function call message over the DevTools protocol. |message| must be
- // a UTF8-encoded JSON dictionary that contains "id" (int), "function"
- // (string) and "params" (dictionary, optional) values. See the DevTools
- // protocol documentation at https://chromedevtools.github.io/devtools-
- // protocol/ for details of supported functions and the expected "params"
- // dictionary contents. |message| will be copied if necessary. This function
- // will return true (1) if called on the UI thread and the message was
- // successfully submitted for validation, otherwise false (0). Validation will
- // be applied asynchronously and any messages that fail due to formatting
- // errors or missing parameters may be discarded without notification. Prefer
- // ExecuteDevToolsMethod if a more structured approach to message formatting
- // is desired.
- //
- // Every valid function call will result in an asynchronous function result or
- // error message that references the sent message "id". Event messages are
- // received while notifications are enabled (for example, between function
- // calls for "Page.enable" and "Page.disable"). All received messages will be
- // delivered to the observer(s) registered with AddDevToolsMessageObserver.
- // See cef_dev_tools_message_observer_t::OnDevToolsMessage documentation for
- // details of received message contents.
- //
- // Usage of the SendDevToolsMessage, ExecuteDevToolsMethod and
- // AddDevToolsMessageObserver functions does not require an active DevTools
- // front-end or remote-debugging session. Other active DevTools sessions will
- // continue to function independently. However, any modification of global
- // browser state by one session may not be reflected in the UI of other
- // sessions.
- //
- // Communication with the DevTools front-end (when displayed) can be logged
- // for development purposes by passing the `--devtools-protocol-log-
- // file=` command-line flag.
- ///
- int function (
- _cef_browser_host_t* self,
- const(void)* message,
- size_t message_size) nothrow send_dev_tools_message;
-
- ///
- // Execute a function call over the DevTools protocol. This is a more
- // structured version of SendDevToolsMessage. |message_id| is an incremental
- // number that uniquely identifies the message (pass 0 to have the next number
- // assigned automatically based on previous values). |function| is the
- // function name. |params| are the function parameters, which may be NULL. See
- // the DevTools protocol documentation (linked above) for details of supported
- // functions and the expected |params| dictionary contents. This function will
- // return the assigned message ID if called on the UI thread and the message
- // was successfully submitted for validation, otherwise 0. See the
- // SendDevToolsMessage documentation for additional usage information.
- ///
- int function (
- _cef_browser_host_t* self,
- int message_id,
- const(cef_string_t)* method,
- _cef_dictionary_value_t* params) nothrow execute_dev_tools_method;
-
- ///
- // Add an observer for DevTools protocol messages (function results and
- // events). The observer will remain registered until the returned
- // Registration object is destroyed. See the SendDevToolsMessage documentation
- // for additional usage information.
- ///
- _cef_registration_t* function (
- _cef_browser_host_t* self,
- _cef_dev_tools_message_observer_t* observer) nothrow add_dev_tools_message_observer;
-
- ///
- // Retrieve a snapshot of current navigation entries as values sent to the
- // specified visitor. If |current_only| is true (1) only the current
- // navigation entry will be sent, otherwise all navigation entries will be
- // sent.
- ///
- void function (
- _cef_browser_host_t* self,
- _cef_navigation_entry_visitor_t* visitor,
- int current_only) nothrow get_navigation_entries;
-
- ///
- // If a misspelled word is currently selected in an editable node calling this
- // function will replace it with the specified |word|.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* word) nothrow replace_misspelling;
-
- ///
- // Add the specified |word| to the spelling dictionary.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* word) nothrow add_word_to_dictionary;
-
- ///
- // Returns true (1) if window rendering is disabled.
- ///
- int function (_cef_browser_host_t* self) nothrow is_window_rendering_disabled;
-
- ///
- // Notify the browser that the widget has been resized. The browser will first
- // call cef_render_handler_t::GetViewRect to get the new size and then call
- // cef_render_handler_t::OnPaint asynchronously with the updated regions. This
- // function is only used when window rendering is disabled.
- ///
- void function (_cef_browser_host_t* self) nothrow was_resized;
-
- ///
- // Notify the browser that it has been hidden or shown. Layouting and
- // cef_render_handler_t::OnPaint notification will stop when the browser is
- // hidden. This function is only used when window rendering is disabled.
- ///
- void function (_cef_browser_host_t* self, int hidden) nothrow was_hidden;
-
- ///
- // Send a notification to the browser that the screen info has changed. The
- // browser will then call cef_render_handler_t::GetScreenInfo to update the
- // screen information with the new values. This simulates moving the webview
- // window from one display to another, or changing the properties of the
- // current display. This function is only used when window rendering is
- // disabled.
- ///
- void function (_cef_browser_host_t* self) nothrow notify_screen_info_changed;
-
- ///
- // Invalidate the view. The browser will call cef_render_handler_t::OnPaint
- // asynchronously. This function is only used when window rendering is
- // disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- cef_paint_element_type_t type) nothrow invalidate;
-
- ///
- // Issue a BeginFrame request to Chromium. Only valid when
- // cef_window_tInfo::external_begin_frame_enabled is set to true (1).
- ///
- void function (_cef_browser_host_t* self) nothrow send_external_begin_frame;
-
- ///
- // Send a key event to the browser.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_key_event_t)* event) nothrow send_key_event;
-
- ///
- // Send a mouse click event to the browser. The |x| and |y| coordinates are
- // relative to the upper-left corner of the view.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_mouse_event_t)* event,
- cef_mouse_button_type_t type,
- int mouseUp,
- int clickCount) nothrow send_mouse_click_event;
-
- ///
- // Send a mouse move event to the browser. The |x| and |y| coordinates are
- // relative to the upper-left corner of the view.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_mouse_event_t)* event,
- int mouseLeave) nothrow send_mouse_move_event;
-
- ///
- // Send a mouse wheel event to the browser. The |x| and |y| coordinates are
- // relative to the upper-left corner of the view. The |deltaX| and |deltaY|
- // values represent the movement delta in the X and Y directions respectively.
- // In order to scroll inside select popups with window rendering disabled
- // cef_render_handler_t::GetScreenPoint should be implemented properly.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_mouse_event_t)* event,
- int deltaX,
- int deltaY) nothrow send_mouse_wheel_event;
-
- ///
- // Send a touch event to the browser for a windowless browser.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_touch_event_t)* event) nothrow send_touch_event;
-
- ///
- // Send a focus event to the browser.
- ///
- void function (_cef_browser_host_t* self, int setFocus) nothrow send_focus_event;
-
- ///
- // Send a capture lost event to the browser.
- ///
- void function (_cef_browser_host_t* self) nothrow send_capture_lost_event;
-
- ///
- // Notify the browser that the window hosting it is about to be moved or
- // resized. This function is only used on Windows and Linux.
- ///
- void function (_cef_browser_host_t* self) nothrow notify_move_or_resize_started;
-
- ///
- // Returns the maximum rate in frames per second (fps) that
- // cef_render_handler_t:: OnPaint will be called for a windowless browser. The
- // actual fps may be lower if the browser cannot generate frames at the
- // requested rate. The minimum value is 1 and the maximum value is 60 (default
- // 30). This function can only be called on the UI thread.
- ///
- int function (_cef_browser_host_t* self) nothrow get_windowless_frame_rate;
-
- ///
- // Set the maximum rate in frames per second (fps) that cef_render_handler_t::
- // OnPaint will be called for a windowless browser. The actual fps may be
- // lower if the browser cannot generate frames at the requested rate. The
- // minimum value is 1 and the maximum value is 60 (default 30). Can also be
- // set at browser creation via cef_browser_tSettings.windowless_frame_rate.
- ///
- void function (
- _cef_browser_host_t* self,
- int frame_rate) nothrow set_windowless_frame_rate;
-
- ///
- // Begins a new composition or updates the existing composition. Blink has a
- // special node (a composition node) that allows the input function to change
- // text without affecting other DOM nodes. |text| is the optional text that
- // will be inserted into the composition node. |underlines| is an optional set
- // of ranges that will be underlined in the resulting text.
- // |replacement_range| is an optional range of the existing text that will be
- // replaced. |selection_range| is an optional range of the resulting text that
- // will be selected after insertion or replacement. The |replacement_range|
- // value is only used on OS X.
- //
- // This function may be called multiple times as the composition changes. When
- // the client is done making changes the composition should either be canceled
- // or completed. To cancel the composition call ImeCancelComposition. To
- // complete the composition call either ImeCommitText or
- // ImeFinishComposingText. Completion is usually signaled when:
- // A. The client receives a WM_IME_COMPOSITION message with a GCS_RESULTSTR
- // flag (on Windows), or;
- // B. The client receives a "commit" signal of GtkIMContext (on Linux), or;
- // C. insertText of NSTextInput is called (on Mac).
- //
- // This function is only used when window rendering is disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* text,
- size_t underlinesCount,
- const(cef_composition_underline_t)* underlines,
- const(cef_range_t)* replacement_range,
- const(cef_range_t)* selection_range) nothrow ime_set_composition;
-
- ///
- // Completes the existing composition by optionally inserting the specified
- // |text| into the composition node. |replacement_range| is an optional range
- // of the existing text that will be replaced. |relative_cursor_pos| is where
- // the cursor will be positioned relative to the current cursor position. See
- // comments on ImeSetComposition for usage. The |replacement_range| and
- // |relative_cursor_pos| values are only used on OS X. This function is only
- // used when window rendering is disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- const(cef_string_t)* text,
- const(cef_range_t)* replacement_range,
- int relative_cursor_pos) nothrow ime_commit_text;
-
- ///
- // Completes the existing composition by applying the current composition node
- // contents. If |keep_selection| is false (0) the current selection, if any,
- // will be discarded. See comments on ImeSetComposition for usage. This
- // function is only used when window rendering is disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- int keep_selection) nothrow ime_finish_composing_text;
-
- ///
- // Cancels the existing composition and discards the composition node contents
- // without applying them. See comments on ImeSetComposition for usage. This
- // function is only used when window rendering is disabled.
- ///
- void function (_cef_browser_host_t* self) nothrow ime_cancel_composition;
-
- ///
- // Call this function when the user drags the mouse into the web view (before
- // calling DragTargetDragOver/DragTargetLeave/DragTargetDrop). |drag_data|
- // should not contain file contents as this type of data is not allowed to be
- // dragged into the web view. File contents can be removed using
- // cef_drag_data_t::ResetFileContents (for example, if |drag_data| comes from
- // cef_render_handler_t::StartDragging). This function is only used when
- // window rendering is disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- _cef_drag_data_t* drag_data,
- const(_cef_mouse_event_t)* event,
- cef_drag_operations_mask_t allowed_ops) nothrow drag_target_drag_enter;
-
- ///
- // Call this function each time the mouse is moved across the web view during
- // a drag operation (after calling DragTargetDragEnter and before calling
- // DragTargetDragLeave/DragTargetDrop). This function is only used when window
- // rendering is disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_mouse_event_t)* event,
- cef_drag_operations_mask_t allowed_ops) nothrow drag_target_drag_over;
-
- ///
- // Call this function when the user drags the mouse out of the web view (after
- // calling DragTargetDragEnter). This function is only used when window
- // rendering is disabled.
- ///
- void function (_cef_browser_host_t* self) nothrow drag_target_drag_leave;
-
- ///
- // Call this function when the user completes the drag operation by dropping
- // the object onto the web view (after calling DragTargetDragEnter). The
- // object being dropped is |drag_data|, given as an argument to the previous
- // DragTargetDragEnter call. This function is only used when window rendering
- // is disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- const(_cef_mouse_event_t)* event) nothrow drag_target_drop;
-
- ///
- // Call this function when the drag operation started by a
- // cef_render_handler_t::StartDragging call has ended either in a drop or by
- // being cancelled. |x| and |y| are mouse coordinates relative to the upper-
- // left corner of the view. If the web view is both the drag source and the
- // drag target then all DragTarget* functions should be called before
- // DragSource* mthods. This function is only used when window rendering is
- // disabled.
- ///
- void function (
- _cef_browser_host_t* self,
- int x,
- int y,
- cef_drag_operations_mask_t op) nothrow drag_source_ended_at;
-
- ///
- // Call this function when the drag operation started by a
- // cef_render_handler_t::StartDragging call has completed. This function may
- // be called immediately without first calling DragSourceEndedAt to cancel a
- // drag operation. If the web view is both the drag source and the drag target
- // then all DragTarget* functions should be called before DragSource* mthods.
- // This function is only used when window rendering is disabled.
- ///
- void function (_cef_browser_host_t* self) nothrow drag_source_system_drag_ended;
-
- ///
- // Returns the current visible navigation entry for this browser. This
- // function can only be called on the UI thread.
- ///
- _cef_navigation_entry_t* function (
- _cef_browser_host_t* self) nothrow get_visible_navigation_entry;
-
- ///
- // Set accessibility state for all frames. |accessibility_state| may be
- // default, enabled or disabled. If |accessibility_state| is STATE_DEFAULT
- // then accessibility will be disabled by default and the state may be further
- // controlled with the "force-renderer-accessibility" and "disable-renderer-
- // accessibility" command-line switches. If |accessibility_state| is
- // STATE_ENABLED then accessibility will be enabled. If |accessibility_state|
- // is STATE_DISABLED then accessibility will be completely disabled.
- //
- // For windowed browsers accessibility will be enabled in Complete mode (which
- // corresponds to kAccessibilityModeComplete in Chromium). In this mode all
- // platform accessibility objects will be created and managed by Chromium's
- // internal implementation. The client needs only to detect the screen reader
- // and call this function appropriately. For example, on macOS the client can
- // handle the @"AXEnhancedUserStructure" accessibility attribute to detect
- // VoiceOver state changes and on Windows the client can handle WM_GETOBJECT
- // with OBJID_CLIENT to detect accessibility readers.
- //
- // For windowless browsers accessibility will be enabled in TreeOnly mode
- // (which corresponds to kAccessibilityModeWebContentsOnly in Chromium). In
- // this mode renderer accessibility is enabled, the full tree is computed, and
- // events are passed to CefAccessibiltyHandler, but platform accessibility
- // objects are not created. The client may implement platform accessibility
- // objects using CefAccessibiltyHandler callbacks if desired.
- ///
- void function (
- _cef_browser_host_t* self,
- cef_state_t accessibility_state) nothrow set_accessibility_state;
-
- ///
- // Enable notifications of auto resize via
- // cef_display_handler_t::OnAutoResize. Notifications are disabled by default.
- // |min_size| and |max_size| define the range of allowed sizes.
- ///
- void function (
- _cef_browser_host_t* self,
- int enabled,
- const(cef_size_t)* min_size,
- const(cef_size_t)* max_size) nothrow set_auto_resize_enabled;
-
- ///
- // Returns the extension hosted in this browser or NULL if no extension is
- // hosted. See cef_request_context_t::LoadExtension for details.
- ///
- _cef_extension_t* function (_cef_browser_host_t* self) nothrow get_extension;
-
- ///
- // Returns true (1) if this browser is hosting an extension background script.
- // Background hosts do not have a window and are not displayable. See
- // cef_request_context_t::LoadExtension for details.
- ///
- int function (_cef_browser_host_t* self) nothrow is_background_host;
-
- ///
- // Set whether the browser's audio is muted.
- ///
- void function (_cef_browser_host_t* self, int mute) nothrow set_audio_muted;
-
- ///
- // Returns true (1) if the browser's audio is muted. This function can only
- // be called on the UI thread.
- ///
- int function (_cef_browser_host_t* self) nothrow is_audio_muted;
-}
-
-alias cef_browser_host_t = _cef_browser_host_t;
-
-///
-// Create a new browser window using the window parameters specified by
-// |windowInfo|. All values will be copied internally and the actual window will
-// be created on the UI thread. If |request_context| is NULL the global request
-// context will be used. This function can be called on any browser process
-// thread and will not block. The optional |extra_info| parameter provides an
-// opportunity to specify extra information specific to the created browser that
-// will be passed to cef_render_process_handler_t::on_browser_created() in the
-// render process.
-///
-int cef_browser_host_create_browser (
- const(cef_window_info_t)* windowInfo,
- _cef_client_t* client,
- const(cef_string_t)* url,
- const(_cef_browser_settings_t)* settings,
- _cef_dictionary_value_t* extra_info,
- _cef_request_context_t* request_context);
-
-///
-// Create a new browser window using the window parameters specified by
-// |windowInfo|. If |request_context| is NULL the global request context will be
-// used. This function can only be called on the browser process UI thread. The
-// optional |extra_info| parameter provides an opportunity to specify extra
-// information specific to the created browser that will be passed to
-// cef_render_process_handler_t::on_browser_created() in the render process.
-///
-cef_browser_t* cef_browser_host_create_browser_sync (
- const(cef_window_info_t)* windowInfo,
- _cef_client_t* client,
- const(cef_string_t)* url,
- const(_cef_browser_settings_t)* settings,
- _cef_dictionary_value_t* extra_info,
- _cef_request_context_t* request_context);
-
-// CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=d56cbf83d6faefa9f716c7308bf7007dad98697d$
-//
-
-extern (C):
-
-///
-// Structure used to implement browser process callbacks. The functions of this
-// structure will be called on the browser process main thread unless otherwise
-// indicated.
-///
-struct _cef_browser_process_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the browser process UI thread to retrieve the list of schemes
- // that should support cookies. If |include_defaults| is true (1) the default
- // schemes ("http", "https", "ws" and "wss") will also be supported. Providing
- // an NULL |schemes| value and setting |include_defaults| to false (0) will
- // disable all loading and saving of cookies.
- //
- // This state will apply to the cef_cookie_manager_t associated with the
- // global cef_request_context_t. It will also be used as the initial state for
- // any new cef_request_context_ts created by the client. After creating a new
- // cef_request_context_t the cef_cookie_manager_t::SetSupportedSchemes
- // function may be called on the associated cef_cookie_manager_t to futher
- // override these values.
- ///
- void function (
- _cef_browser_process_handler_t* self,
- cef_string_list_t schemes,
- int* include_defaults) nothrow get_cookieable_schemes;
-
- ///
- // Called on the browser process UI thread immediately after the CEF context
- // has been initialized.
- ///
- void function (
- _cef_browser_process_handler_t* self) nothrow on_context_initialized;
-
- ///
- // Called before a child process is launched. Will be called on the browser
- // process UI thread when launching a render process and on the browser
- // process IO thread when launching a GPU or plugin process. Provides an
- // opportunity to modify the child process command line. Do not keep a
- // reference to |command_line| outside of this function.
- ///
- void function (
- _cef_browser_process_handler_t* self,
- _cef_command_line_t* command_line) nothrow on_before_child_process_launch;
-
- ///
- // Return the handler for printing on Linux. If a print handler is not
- // provided then printing will not be supported on the Linux platform.
- ///
- _cef_print_handler_t* function (
- _cef_browser_process_handler_t* self) nothrow get_print_handler;
-
- ///
- // Called from any thread when work has been scheduled for the browser process
- // main (UI) thread. This callback is used in combination with CefSettings.
- // external_message_pump and cef_do_message_loop_work() in cases where the CEF
- // message loop must be integrated into an existing application message loop
- // (see additional comments and warnings on CefDoMessageLoopWork). This
- // callback should schedule a cef_do_message_loop_work() call to happen on the
- // main (UI) thread. |delay_ms| is the requested delay in milliseconds. If
- // |delay_ms| is <= 0 then the call should happen reasonably soon. If
- // |delay_ms| is > 0 then the call should be scheduled to happen after the
- // specified delay and any currently pending scheduled call should be
- // cancelled.
- ///
- void function (
- _cef_browser_process_handler_t* self,
- int64 delay_ms) nothrow on_schedule_message_pump_work;
-
- ///
- // Return the default client for use with a newly created browser window. If
- // null is returned the browser will be unmanaged (no callbacks will be
- // executed for that browser) and application shutdown will be blocked until
- // the browser window is closed manually. This function is currently only used
- // with the chrome runtime.
- ///
- _cef_client_t* function (
- _cef_browser_process_handler_t* self) nothrow get_default_client;
-}
-
-alias cef_browser_process_handler_t = _cef_browser_process_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=5c540e617cf2782876defad365e85cd43932ffce$
-//
-
-extern (C):
-
-///
-// Generic callback structure used for asynchronous continuation.
-///
-struct _cef_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Continue processing.
- ///
- void function (_cef_callback_t* self) nothrow cont;
-
- ///
- // Cancel processing.
- ///
- void function (_cef_callback_t* self) nothrow cancel;
-}
-
-alias cef_callback_t = _cef_callback_t;
-
-///
-// Generic callback structure used for asynchronous completion.
-///
-struct _cef_completion_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called once the task is complete.
- ///
- void function (_cef_completion_callback_t* self) nothrow on_complete;
-}
-
-alias cef_completion_callback_t = _cef_completion_callback_t;
-
-// CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=8d4cb3e0bbf230804c93898daa4a8b2866a2c1ce$
-//
-
-extern (C):
-
-///
-// Implement this structure to provide handler implementations.
-///
-struct _cef_client_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Return the handler for audio rendering events.
- ///
- _cef_audio_handler_t* function (_cef_client_t* self) nothrow get_audio_handler;
-
- ///
- // Return the handler for context menus. If no handler is provided the default
- // implementation will be used.
- ///
- _cef_context_menu_handler_t* function (
- _cef_client_t* self) nothrow get_context_menu_handler;
-
- ///
- // Return the handler for dialogs. If no handler is provided the default
- // implementation will be used.
- ///
- _cef_dialog_handler_t* function (_cef_client_t* self) nothrow get_dialog_handler;
-
- ///
- // Return the handler for browser display state events.
- ///
- _cef_display_handler_t* function (_cef_client_t* self) nothrow get_display_handler;
-
- ///
- // Return the handler for download events. If no handler is returned downloads
- // will not be allowed.
- ///
- _cef_download_handler_t* function (
- _cef_client_t* self) nothrow get_download_handler;
-
- ///
- // Return the handler for drag events.
- ///
- _cef_drag_handler_t* function (_cef_client_t* self) nothrow get_drag_handler;
-
- ///
- // Return the handler for find result events.
- ///
- _cef_find_handler_t* function (_cef_client_t* self) nothrow get_find_handler;
-
- ///
- // Return the handler for focus events.
- ///
- _cef_focus_handler_t* function (_cef_client_t* self) nothrow get_focus_handler;
-
- ///
- // Return the handler for JavaScript dialogs. If no handler is provided the
- // default implementation will be used.
- ///
- _cef_jsdialog_handler_t* function (
- _cef_client_t* self) nothrow get_jsdialog_handler;
-
- ///
- // Return the handler for keyboard events.
- ///
- _cef_keyboard_handler_t* function (
- _cef_client_t* self) nothrow get_keyboard_handler;
-
- ///
- // Return the handler for browser life span events.
- ///
- _cef_life_span_handler_t* function (
- _cef_client_t* self) nothrow get_life_span_handler;
-
- ///
- // Return the handler for browser load status events.
- ///
- _cef_load_handler_t* function (_cef_client_t* self) nothrow get_load_handler;
-
- ///
- // Return the handler for off-screen rendering events.
- ///
- _cef_render_handler_t* function (_cef_client_t* self) nothrow get_render_handler;
-
- ///
- // Return the handler for browser request events.
- ///
- _cef_request_handler_t* function (_cef_client_t* self) nothrow get_request_handler;
-
- ///
- // Called when a new message is received from a different process. Return true
- // (1) if the message was handled or false (0) otherwise. Do not keep a
- // reference to or attempt to access the message outside of this callback.
- ///
- int function (
- _cef_client_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- cef_process_id_t source_process,
- _cef_process_message_t* message) nothrow on_process_message_received;
-}
-
-alias cef_client_t = _cef_client_t;
-
-// CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=72ba5fe0cc6fe8081ec7b2b556e9022d1c6e8c61$
-//
-
-extern (C):
-
-///
-// Structure used to create and/or parse command line arguments. Arguments with
-// '--', '-' and, on Windows, '/' prefixes are considered switches. Switches
-// will always precede any arguments without switch prefixes. Switches can
-// optionally have a value specified using the '=' delimiter (e.g.
-// "-switch=value"). An argument of "--" will terminate switch parsing with all
-// subsequent tokens, regardless of prefix, being interpreted as non-switch
-// arguments. Switch names are considered case-insensitive. This structure can
-// be used before cef_initialize() is called.
-///
-struct _cef_command_line_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. Do not call any other functions
- // if this function returns false (0).
- ///
- int function (_cef_command_line_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if the values of this object are read-only. Some APIs may
- // expose read-only objects.
- ///
- int function (_cef_command_line_t* self) nothrow is_read_only;
-
- ///
- // Returns a writable copy of this object.
- ///
- _cef_command_line_t* function (_cef_command_line_t* self) nothrow copy;
-
- ///
- // Initialize the command line with the specified |argc| and |argv| values.
- // The first argument must be the name of the program. This function is only
- // supported on non-Windows platforms.
- ///
- void function (
- _cef_command_line_t* self,
- int argc,
- const(char*)* argv) nothrow init_from_argv;
-
- ///
- // Initialize the command line with the string returned by calling
- // GetCommandLineW(). This function is only supported on Windows.
- ///
- void function (
- _cef_command_line_t* self,
- const(cef_string_t)* command_line) nothrow init_from_string;
-
- ///
- // Reset the command-line switches and arguments but leave the program
- // component unchanged.
- ///
- void function (_cef_command_line_t* self) nothrow reset;
-
- ///
- // Retrieve the original command line string as a vector of strings. The argv
- // array: { program, [(--|-|/)switch[=value]]*, [--], [argument]* }
- ///
- void function (_cef_command_line_t* self, cef_string_list_t argv) nothrow get_argv;
-
- ///
- // Constructs and returns the represented command line string. Use this
- // function cautiously because quoting behavior is unclear.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_command_line_t* self) nothrow get_command_line_string;
-
- ///
- // Get the program part of the command line string (the first item).
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_command_line_t* self) nothrow get_program;
-
- ///
- // Set the program part of the command line string (the first item).
- ///
- void function (
- _cef_command_line_t* self,
- const(cef_string_t)* program) nothrow set_program;
-
- ///
- // Returns true (1) if the command line has switches.
- ///
- int function (_cef_command_line_t* self) nothrow has_switches;
-
- ///
- // Returns true (1) if the command line contains the given switch.
- ///
- int function (
- _cef_command_line_t* self,
- const(cef_string_t)* name) nothrow has_switch;
-
- ///
- // Returns the value associated with the given switch. If the switch has no
- // value or isn't present this function returns the NULL string.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_command_line_t* self,
- const(cef_string_t)* name) nothrow get_switch_value;
-
- ///
- // Returns the map of switch names and values. If a switch has no value an
- // NULL string is returned.
- ///
- void function (
- _cef_command_line_t* self,
- cef_string_map_t switches) nothrow get_switches;
-
- ///
- // Add a switch to the end of the command line. If the switch has no value
- // pass an NULL value string.
- ///
- void function (
- _cef_command_line_t* self,
- const(cef_string_t)* name) nothrow append_switch;
-
- ///
- // Add a switch with the specified value to the end of the command line.
- ///
- void function (
- _cef_command_line_t* self,
- const(cef_string_t)* name,
- const(cef_string_t)* value) nothrow append_switch_with_value;
-
- ///
- // True if there are remaining command line arguments.
- ///
- int function (_cef_command_line_t* self) nothrow has_arguments;
-
- ///
- // Get the remaining command line arguments.
- ///
- void function (
- _cef_command_line_t* self,
- cef_string_list_t arguments) nothrow get_arguments;
-
- ///
- // Add an argument to the end of the command line.
- ///
- void function (
- _cef_command_line_t* self,
- const(cef_string_t)* argument) nothrow append_argument;
-
- ///
- // Insert a command before the current command. Common for debuggers, like
- // "valgrind" or "gdb --args".
- ///
- void function (
- _cef_command_line_t* self,
- const(cef_string_t)* wrapper) nothrow prepend_wrapper;
-}
-
-alias cef_command_line_t = _cef_command_line_t;
-
-///
-// Create a new cef_command_line_t instance.
-///
-cef_command_line_t* cef_command_line_create ();
-
-///
-// Returns the singleton global cef_command_line_t object. The returned object
-// will be read-only.
-///
-cef_command_line_t* cef_command_line_get_global ();
-
-// CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=fcb0328c54e5f629c24bfd232d75c31c372ab6ac$
-//
-
-extern (C):
-
-///
-// Callback structure used for continuation of custom context menu display.
-///
-struct _cef_run_context_menu_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Complete context menu display by selecting the specified |command_id| and
- // |event_flags|.
- ///
- void function (
- _cef_run_context_menu_callback_t* self,
- int command_id,
- cef_event_flags_t event_flags) nothrow cont;
-
- ///
- // Cancel context menu display.
- ///
- void function (_cef_run_context_menu_callback_t* self) nothrow cancel;
-}
-
-alias cef_run_context_menu_callback_t = _cef_run_context_menu_callback_t;
-
-///
-// Implement this structure to handle context menu events. The functions of this
-// structure will be called on the UI thread.
-///
-struct _cef_context_menu_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called before a context menu is displayed. |params| provides information
- // about the context menu state. |model| initially contains the default
- // context menu. The |model| can be cleared to show no context menu or
- // modified to show a custom menu. Do not keep references to |params| or
- // |model| outside of this callback.
- ///
- void function (
- _cef_context_menu_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_context_menu_params_t* params,
- _cef_menu_model_t* model) nothrow on_before_context_menu;
-
- ///
- // Called to allow custom display of the context menu. |params| provides
- // information about the context menu state. |model| contains the context menu
- // model resulting from OnBeforeContextMenu. For custom display return true
- // (1) and execute |callback| either synchronously or asynchronously with the
- // selected command ID. For default display return false (0). Do not keep
- // references to |params| or |model| outside of this callback.
- ///
- int function (
- _cef_context_menu_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_context_menu_params_t* params,
- _cef_menu_model_t* model,
- _cef_run_context_menu_callback_t* callback) nothrow run_context_menu;
-
- ///
- // Called to execute a command selected from the context menu. Return true (1)
- // if the command was handled or false (0) for the default implementation. See
- // cef_menu_id_t for the command ids that have default implementations. All
- // user-defined command ids should be between MENU_ID_USER_FIRST and
- // MENU_ID_USER_LAST. |params| will have the same values as what was passed to
- // on_before_context_menu(). Do not keep a reference to |params| outside of
- // this callback.
- ///
- int function (
- _cef_context_menu_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_context_menu_params_t* params,
- int command_id,
- cef_event_flags_t event_flags) nothrow on_context_menu_command;
-
- ///
- // Called when the context menu is dismissed irregardless of whether the menu
- // was NULL or a command was selected.
- ///
- void function (
- _cef_context_menu_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame) nothrow on_context_menu_dismissed;
-}
-
-alias cef_context_menu_handler_t = _cef_context_menu_handler_t;
-
-///
-// Provides information about the context menu state. The ethods of this
-// structure can only be accessed on browser process the UI thread.
-///
-struct _cef_context_menu_params_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the X coordinate of the mouse where the context menu was invoked.
- // Coords are relative to the associated RenderView's origin.
- ///
- int function (_cef_context_menu_params_t* self) nothrow get_xcoord;
-
- ///
- // Returns the Y coordinate of the mouse where the context menu was invoked.
- // Coords are relative to the associated RenderView's origin.
- ///
- int function (_cef_context_menu_params_t* self) nothrow get_ycoord;
-
- ///
- // Returns flags representing the type of node that the context menu was
- // invoked on.
- ///
- cef_context_menu_type_flags_t function (
- _cef_context_menu_params_t* self) nothrow get_type_flags;
-
- ///
- // Returns the URL of the link, if any, that encloses the node that the
- // context menu was invoked on.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_link_url;
-
- ///
- // Returns the link URL, if any, to be used ONLY for "copy link address". We
- // don't validate this field in the frontend process.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_unfiltered_link_url;
-
- ///
- // Returns the source URL, if any, for the element that the context menu was
- // invoked on. Example of elements with source URLs are img, audio, and video.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_source_url;
-
- ///
- // Returns true (1) if the context menu was invoked on an image which has non-
- // NULL contents.
- ///
- int function (_cef_context_menu_params_t* self) nothrow has_image_contents;
-
- ///
- // Returns the title text or the alt text if the context menu was invoked on
- // an image.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_title_text;
-
- ///
- // Returns the URL of the top level page that the context menu was invoked on.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_page_url;
-
- ///
- // Returns the URL of the subframe that the context menu was invoked on.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_frame_url;
-
- ///
- // Returns the character encoding of the subframe that the context menu was
- // invoked on.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_frame_charset;
-
- ///
- // Returns the type of context node that the context menu was invoked on.
- ///
- cef_context_menu_media_type_t function (
- _cef_context_menu_params_t* self) nothrow get_media_type;
-
- ///
- // Returns flags representing the actions supported by the media element, if
- // any, that the context menu was invoked on.
- ///
- cef_context_menu_media_state_flags_t function (
- _cef_context_menu_params_t* self) nothrow get_media_state_flags;
-
- ///
- // Returns the text of the selection, if any, that the context menu was
- // invoked on.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_selection_text;
-
- ///
- // Returns the text of the misspelled word, if any, that the context menu was
- // invoked on.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_context_menu_params_t* self) nothrow get_misspelled_word;
-
- ///
- // Returns true (1) if suggestions exist, false (0) otherwise. Fills in
- // |suggestions| from the spell check service for the misspelled word if there
- // is one.
- ///
- int function (
- _cef_context_menu_params_t* self,
- cef_string_list_t suggestions) nothrow get_dictionary_suggestions;
-
- ///
- // Returns true (1) if the context menu was invoked on an editable node.
- ///
- int function (_cef_context_menu_params_t* self) nothrow is_editable;
-
- ///
- // Returns true (1) if the context menu was invoked on an editable node where
- // spell-check is enabled.
- ///
- int function (_cef_context_menu_params_t* self) nothrow is_spell_check_enabled;
-
- ///
- // Returns flags representing the actions supported by the editable node, if
- // any, that the context menu was invoked on.
- ///
- cef_context_menu_edit_state_flags_t function (
- _cef_context_menu_params_t* self) nothrow get_edit_state_flags;
-
- ///
- // Returns true (1) if the context menu contains items specified by the
- // renderer process (for example, plugin placeholder or pepper plugin menu
- // items).
- ///
- int function (_cef_context_menu_params_t* self) nothrow is_custom_menu;
-
- ///
- // Returns true (1) if the context menu was invoked from a pepper plugin.
- ///
- int function (_cef_context_menu_params_t* self) nothrow is_pepper_menu;
-}
-
-alias cef_context_menu_params_t = _cef_context_menu_params_t;
-
-// CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=2f5721138da26a9d7cce300a635b58dae9f51a4a$
-//
-
-extern (C):
-
-///
-// Structure used for managing cookies. The functions of this structure may be
-// called on any thread unless otherwise indicated.
-///
-struct _cef_cookie_manager_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Set the schemes supported by this manager. If |include_defaults| is true
- // (1) the default schemes ("http", "https", "ws" and "wss") will also be
- // supported. Calling this function with an NULL |schemes| value and
- // |include_defaults| set to false (0) will disable all loading and saving of
- // cookies for this manager. If |callback| is non-NULL it will be executed
- // asnychronously on the UI thread after the change has been applied. Must be
- // called before any cookies are accessed.
- ///
- void function (
- _cef_cookie_manager_t* self,
- cef_string_list_t schemes,
- int include_defaults,
- _cef_completion_callback_t* callback) nothrow set_supported_schemes;
-
- ///
- // Visit all cookies on the UI thread. The returned cookies are ordered by
- // longest path, then by earliest creation date. Returns false (0) if cookies
- // cannot be accessed.
- ///
- int function (
- _cef_cookie_manager_t* self,
- _cef_cookie_visitor_t* visitor) nothrow visit_all_cookies;
-
- ///
- // Visit a subset of cookies on the UI thread. The results are filtered by the
- // given url scheme, host, domain and path. If |includeHttpOnly| is true (1)
- // HTTP-only cookies will also be included in the results. The returned
- // cookies are ordered by longest path, then by earliest creation date.
- // Returns false (0) if cookies cannot be accessed.
- ///
- int function (
- _cef_cookie_manager_t* self,
- const(cef_string_t)* url,
- int includeHttpOnly,
- _cef_cookie_visitor_t* visitor) nothrow visit_url_cookies;
-
- ///
- // Sets a cookie given a valid URL and explicit user-provided cookie
- // attributes. This function expects each attribute to be well-formed. It will
- // check for disallowed characters (e.g. the ';' character is disallowed
- // within the cookie value attribute) and fail without setting the cookie if
- // such characters are found. If |callback| is non-NULL it will be executed
- // asnychronously on the UI thread after the cookie has been set. Returns
- // false (0) if an invalid URL is specified or if cookies cannot be accessed.
- ///
- int function (
- _cef_cookie_manager_t* self,
- const(cef_string_t)* url,
- const(_cef_cookie_t)* cookie,
- _cef_set_cookie_callback_t* callback) nothrow set_cookie;
-
- ///
- // Delete all cookies that match the specified parameters. If both |url| and
- // |cookie_name| values are specified all host and domain cookies matching
- // both will be deleted. If only |url| is specified all host cookies (but not
- // domain cookies) irrespective of path will be deleted. If |url| is NULL all
- // cookies for all hosts and domains will be deleted. If |callback| is non-
- // NULL it will be executed asnychronously on the UI thread after the cookies
- // have been deleted. Returns false (0) if a non-NULL invalid URL is specified
- // or if cookies cannot be accessed. Cookies can alternately be deleted using
- // the Visit*Cookies() functions.
- ///
- int function (
- _cef_cookie_manager_t* self,
- const(cef_string_t)* url,
- const(cef_string_t)* cookie_name,
- _cef_delete_cookies_callback_t* callback) nothrow delete_cookies;
-
- ///
- // Flush the backing store (if any) to disk. If |callback| is non-NULL it will
- // be executed asnychronously on the UI thread after the flush is complete.
- // Returns false (0) if cookies cannot be accessed.
- ///
- int function (
- _cef_cookie_manager_t* self,
- _cef_completion_callback_t* callback) nothrow flush_store;
-}
-
-alias cef_cookie_manager_t = _cef_cookie_manager_t;
-
-///
-// Returns the global cookie manager. By default data will be stored at
-// CefSettings.cache_path if specified or in memory otherwise. If |callback| is
-// non-NULL it will be executed asnychronously on the UI thread after the
-// manager's storage has been initialized. Using this function is equivalent to
-// calling cef_request_context_t::cef_request_context_get_global_context()->GetD
-// efaultCookieManager().
-///
-cef_cookie_manager_t* cef_cookie_manager_get_global_manager (
- _cef_completion_callback_t* callback);
-
-///
-// Structure to implement for visiting cookie values. The functions of this
-// structure will always be called on the UI thread.
-///
-struct _cef_cookie_visitor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called once for each cookie. |count| is the 0-based
- // index for the current cookie. |total| is the total number of cookies. Set
- // |deleteCookie| to true (1) to delete the cookie currently being visited.
- // Return false (0) to stop visiting cookies. This function may never be
- // called if no cookies are found.
- ///
- int function (
- _cef_cookie_visitor_t* self,
- const(_cef_cookie_t)* cookie,
- int count,
- int total,
- int* deleteCookie) nothrow visit;
-}
-
-alias cef_cookie_visitor_t = _cef_cookie_visitor_t;
-
-///
-// Structure to implement to be notified of asynchronous completion via
-// cef_cookie_manager_t::set_cookie().
-///
-struct _cef_set_cookie_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called upon completion. |success| will be true (1) if
- // the cookie was set successfully.
- ///
- void function (_cef_set_cookie_callback_t* self, int success) nothrow on_complete;
-}
-
-alias cef_set_cookie_callback_t = _cef_set_cookie_callback_t;
-
-///
-// Structure to implement to be notified of asynchronous completion via
-// cef_cookie_manager_t::delete_cookies().
-///
-struct _cef_delete_cookies_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called upon completion. |num_deleted| will be the
- // number of cookies that were deleted.
- ///
- void function (
- _cef_delete_cookies_callback_t* self,
- int num_deleted) nothrow on_complete;
-}
-
-alias cef_delete_cookies_callback_t = _cef_delete_cookies_callback_t;
-
-// CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=2b24c7d99c59c669719b822f5ea19763d140b001$
-//
-
-extern (C):
-
-///
-// Crash reporting is configured using an INI-style config file named
-// "crash_reporter.cfg". On Windows and Linux this file must be placed next to
-// the main application executable. On macOS this file must be placed in the
-// top-level app bundle Resources directory (e.g.
-// ".app/Contents/Resources"). File contents are as follows:
-//
-// # Comments start with a hash character and must be on their own line.
-//
-// [Config]
-// ProductName=
-// ProductVersion=
-// AppName=
-// ExternalHandler=
-// BrowserCrashForwardingEnabled=
-// ServerURL=
-// RateLimitEnabled=
-// MaxUploadsPerDay=
-// MaxDatabaseSizeInMb=
-// MaxDatabaseAgeInDays=
-//
-// [CrashKeys]
-// my_key1=
-// my_key2=
-//
-// Config section:
-//
-// If "ProductName" and/or "ProductVersion" are set then the specified values
-// will be included in the crash dump metadata. On macOS if these values are set
-// to NULL then they will be retrieved from the Info.plist file using the
-// "CFBundleName" and "CFBundleShortVersionString" keys respectively.
-//
-// If "AppName" is set on Windows then crash report information (metrics,
-// database and dumps) will be stored locally on disk under the
-// "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. On other
-// platforms the CefSettings.user_data_path value will be used.
-//
-// If "ExternalHandler" is set on Windows then the specified exe will be
-// launched as the crashpad-handler instead of re-launching the main process
-// exe. The value can be an absolute path or a path relative to the main exe
-// directory. On Linux the CefSettings.browser_subprocess_path value will be
-// used. On macOS the existing subprocess app bundle will be used.
-//
-// If "BrowserCrashForwardingEnabled" is set to true (1) on macOS then browser
-// process crashes will be forwarded to the system crash reporter. This results
-// in the crash UI dialog being displayed to the user and crash reports being
-// logged under "~/Library/Logs/DiagnosticReports". Forwarding of crash reports
-// from non-browser processes and Debug builds is always disabled.
-//
-// If "ServerURL" is set then crashes will be uploaded as a multi-part POST
-// request to the specified URL. Otherwise, reports will only be stored locally
-// on disk.
-//
-// If "RateLimitEnabled" is set to true (1) then crash report uploads will be
-// rate limited as follows:
-// 1. If "MaxUploadsPerDay" is set to a positive value then at most the
-// specified number of crashes will be uploaded in each 24 hour period.
-// 2. If crash upload fails due to a network or server error then an
-// incremental backoff delay up to a maximum of 24 hours will be applied for
-// retries.
-// 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the
-// "MaxUploadsPerDay" value will be reduced to 1 until the client is
-// restarted. This helps to avoid an upload flood when the network or
-// server error is resolved.
-// Rate limiting is not supported on Linux.
-//
-// If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage
-// on disk will be limited to that size in megabytes. For example, on Windows
-// each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to
-// about 34 crash reports stored on disk. Not supported on Linux.
-//
-// If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older
-// than the specified age in days will be deleted. Not supported on Linux.
-//
-// CrashKeys section:
-//
-// A maximum of 26 crash keys of each size can be specified for use by the
-// application. Crash key values will be truncated based on the specified size
-// (small = 64 bytes, medium = 256 bytes, large = 1024 bytes). The value of
-// crash keys can be set from any thread or process using the
-// CefSetCrashKeyValue function. These key/value pairs will be sent to the crash
-// server along with the crash dump file.
-///
-int cef_crash_reporting_enabled ();
-
-///
-// Sets or clears a specific key-value pair from the crash metadata.
-///
-void cef_set_crash_key_value (
- const(cef_string_t)* key,
- const(cef_string_t)* value);
-
-// CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=86906c2e971fea7e479738f59bbf85d71ce31953$
-//
-
-extern (C):
-
-///
-// Callback structure for cef_browser_host_t::AddDevToolsMessageObserver. The
-// functions of this structure will be called on the browser process UI thread.
-///
-struct _cef_dev_tools_message_observer_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called on receipt of a DevTools protocol message.
- // |browser| is the originating browser instance. |message| is a UTF8-encoded
- // JSON dictionary representing either a function result or an event.
- // |message| is only valid for the scope of this callback and should be copied
- // if necessary. Return true (1) if the message was handled or false (0) if
- // the message should be further processed and passed to the
- // OnDevToolsMethodResult or OnDevToolsEvent functions as appropriate.
- //
- // Method result dictionaries include an "id" (int) value that identifies the
- // orginating function call sent from cef_browser_host_t::SendDevToolsMessage,
- // and optionally either a "result" (dictionary) or "error" (dictionary)
- // value. The "error" dictionary will contain "code" (int) and "message"
- // (string) values. Event dictionaries include a "function" (string) value and
- // optionally a "params" (dictionary) value. See the DevTools protocol
- // documentation at https://chromedevtools.github.io/devtools-protocol/ for
- // details of supported function calls and the expected "result" or "params"
- // dictionary contents. JSON dictionaries can be parsed using the CefParseJSON
- // function if desired, however be aware of performance considerations when
- // parsing large messages (some of which may exceed 1MB in size).
- ///
- int function (
- _cef_dev_tools_message_observer_t* self,
- _cef_browser_t* browser,
- const(void)* message,
- size_t message_size) nothrow on_dev_tools_message;
-
- ///
- // Method that will be called after attempted execution of a DevTools protocol
- // function. |browser| is the originating browser instance. |message_id| is
- // the "id" value that identifies the originating function call message. If
- // the function succeeded |success| will be true (1) and |result| will be the
- // UTF8-encoded JSON "result" dictionary value (which may be NULL). If the
- // function failed |success| will be false (0) and |result| will be the
- // UTF8-encoded JSON "error" dictionary value. |result| is only valid for the
- // scope of this callback and should be copied if necessary. See the
- // OnDevToolsMessage documentation for additional details on |result|
- // contents.
- ///
- void function (
- _cef_dev_tools_message_observer_t* self,
- _cef_browser_t* browser,
- int message_id,
- int success,
- const(void)* result,
- size_t result_size) nothrow on_dev_tools_method_result;
-
- ///
- // Method that will be called on receipt of a DevTools protocol event.
- // |browser| is the originating browser instance. |function| is the "function"
- // value. |params| is the UTF8-encoded JSON "params" dictionary value (which
- // may be NULL). |params| is only valid for the scope of this callback and
- // should be copied if necessary. See the OnDevToolsMessage documentation for
- // additional details on |params| contents.
- ///
- void function (
- _cef_dev_tools_message_observer_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* method,
- const(void)* params,
- size_t params_size) nothrow on_dev_tools_event;
-
- ///
- // Method that will be called when the DevTools agent has attached. |browser|
- // is the originating browser instance. This will generally occur in response
- // to the first message sent while the agent is detached.
- ///
- void function (
- _cef_dev_tools_message_observer_t* self,
- _cef_browser_t* browser) nothrow on_dev_tools_agent_attached;
-
- ///
- // Method that will be called when the DevTools agent has detached. |browser|
- // is the originating browser instance. Any function results that were pending
- // before the agent became detached will not be delivered, and any active
- // event subscriptions will be canceled.
- ///
- void function (
- _cef_dev_tools_message_observer_t* self,
- _cef_browser_t* browser) nothrow on_dev_tools_agent_detached;
-}
-
-alias cef_dev_tools_message_observer_t = _cef_dev_tools_message_observer_t;
-
-// CEF_INCLUDE_CAPI_CEF_DEVTOOLS_MESSAGE_OBSERVER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=3253c217564ae9a85a1e971298c32a35e4cad136$
-//
-
-extern (C):
-
-///
-// Callback structure for asynchronous continuation of file dialog requests.
-///
-struct _cef_file_dialog_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Continue the file selection. |selected_accept_filter| should be the 0-based
- // index of the value selected from the accept filters array passed to
- // cef_dialog_handler_t::OnFileDialog. |file_paths| should be a single value
- // or a list of values depending on the dialog mode. An NULL |file_paths|
- // value is treated the same as calling cancel().
- ///
- void function (
- _cef_file_dialog_callback_t* self,
- int selected_accept_filter,
- cef_string_list_t file_paths) nothrow cont;
-
- ///
- // Cancel the file selection.
- ///
- void function (_cef_file_dialog_callback_t* self) nothrow cancel;
-}
-
-alias cef_file_dialog_callback_t = _cef_file_dialog_callback_t;
-
-///
-// Implement this structure to handle dialog events. The functions of this
-// structure will be called on the browser process UI thread.
-///
-struct _cef_dialog_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called to run a file chooser dialog. |mode| represents the type of dialog
- // to display. |title| to the title to be used for the dialog and may be NULL
- // to show the default title ("Open" or "Save" depending on the mode).
- // |default_file_path| is the path with optional directory and/or file name
- // component that should be initially selected in the dialog. |accept_filters|
- // are used to restrict the selectable file types and may any combination of
- // (a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), (b)
- // individual file extensions (e.g. ".txt" or ".png"), or (c) combined
- // description and file extension delimited using "|" and ";" (e.g. "Image
- // Types|.png;.gif;.jpg"). |selected_accept_filter| is the 0-based index of
- // the filter that should be selected by default. To display a custom dialog
- // return true (1) and execute |callback| either inline or at a later time. To
- // display the default dialog return false (0).
- ///
- int function (
- _cef_dialog_handler_t* self,
- _cef_browser_t* browser,
- cef_file_dialog_mode_t mode,
- const(cef_string_t)* title,
- const(cef_string_t)* default_file_path,
- cef_string_list_t accept_filters,
- int selected_accept_filter,
- _cef_file_dialog_callback_t* callback) nothrow on_file_dialog;
-}
-
-alias cef_dialog_handler_t = _cef_dialog_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=eada7e92085d96497f4e69f3e8a7e8aa6746b175$
-//
-
-import core.stdc.config;
-
-extern (C):
-
-///
-// Implement this structure to handle events related to browser display state.
-// The functions of this structure will be called on the UI thread.
-///
-struct _cef_display_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called when a frame's address has changed.
- ///
- void function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- const(cef_string_t)* url) nothrow on_address_change;
-
- ///
- // Called when the page title changes.
- ///
- void function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* title) nothrow on_title_change;
-
- ///
- // Called when the page icon changes.
- ///
- void function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- cef_string_list_t icon_urls) nothrow on_favicon_urlchange;
-
- ///
- // Called when web content in the page has toggled fullscreen mode. If
- // |fullscreen| is true (1) the content will automatically be sized to fill
- // the browser content area. If |fullscreen| is false (0) the content will
- // automatically return to its original size and position. The client is
- // responsible for resizing the browser if desired.
- ///
- void function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- int fullscreen) nothrow on_fullscreen_mode_change;
-
- ///
- // Called when the browser is about to display a tooltip. |text| contains the
- // text that will be displayed in the tooltip. To handle the display of the
- // tooltip yourself return true (1). Otherwise, you can optionally modify
- // |text| and then return false (0) to allow the browser to display the
- // tooltip. When window rendering is disabled the application is responsible
- // for drawing tooltips and the return value is ignored.
- ///
- int function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- cef_string_t* text) nothrow on_tooltip;
-
- ///
- // Called when the browser receives a status message. |value| contains the
- // text that will be displayed in the status message.
- ///
- void function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* value) nothrow on_status_message;
-
- ///
- // Called to display a console message. Return true (1) to stop the message
- // from being output to the console.
- ///
- int function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- cef_log_severity_t level,
- const(cef_string_t)* message,
- const(cef_string_t)* source,
- int line) nothrow on_console_message;
-
- ///
- // Called when auto-resize is enabled via
- // cef_browser_host_t::SetAutoResizeEnabled and the contents have auto-
- // resized. |new_size| will be the desired size in view coordinates. Return
- // true (1) if the resize was handled or false (0) for default handling.
- ///
- int function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- const(cef_size_t)* new_size) nothrow on_auto_resize;
-
- ///
- // Called when the overall page loading progress has changed. |progress|
- // ranges from 0.0 to 1.0.
- ///
- void function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- double progress) nothrow on_loading_progress_change;
-
- ///
- // Called when the browser's cursor has changed. If |type| is CT_CUSTOM then
- // |custom_cursor_info| will be populated with the custom cursor information.
- // Return true (1) if the cursor change was handled or false (0) for default
- // handling.
- ///
- int function (
- _cef_display_handler_t* self,
- _cef_browser_t* browser,
- c_ulong cursor,
- cef_cursor_type_t type,
- const(_cef_cursor_info_t)* custom_cursor_info) nothrow on_cursor_change;
-}
-
-alias cef_display_handler_t = _cef_display_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=055c506e7950abba3ec1c12adbbb1a9989cf5ac5$
-//
-
-extern (C):
-
-///
-// Structure to implement for visiting the DOM. The functions of this structure
-// will be called on the render process main thread.
-///
-struct _cef_domvisitor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method executed for visiting the DOM. The document object passed to this
- // function represents a snapshot of the DOM at the time this function is
- // executed. DOM objects are only valid for the scope of this function. Do not
- // keep references to or attempt to access any DOM objects outside the scope
- // of this function.
- ///
- void function (
- _cef_domvisitor_t* self,
- _cef_domdocument_t* document) nothrow visit;
-}
-
-alias cef_domvisitor_t = _cef_domvisitor_t;
-
-///
-// Structure used to represent a DOM document. The functions of this structure
-// should only be called on the render process main thread thread.
-///
-struct _cef_domdocument_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the document type.
- ///
- cef_dom_document_type_t function (_cef_domdocument_t* self) nothrow get_type;
-
- ///
- // Returns the root document node.
- ///
- _cef_domnode_t* function (_cef_domdocument_t* self) nothrow get_document;
-
- ///
- // Returns the BODY node of an HTML document.
- ///
- _cef_domnode_t* function (_cef_domdocument_t* self) nothrow get_body;
-
- ///
- // Returns the HEAD node of an HTML document.
- ///
- _cef_domnode_t* function (_cef_domdocument_t* self) nothrow get_head;
-
- ///
- // Returns the title of an HTML document.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_domdocument_t* self) nothrow get_title;
-
- ///
- // Returns the document element with the specified ID value.
- ///
- _cef_domnode_t* function (
- _cef_domdocument_t* self,
- const(cef_string_t)* id) nothrow get_element_by_id;
-
- ///
- // Returns the node that currently has keyboard focus.
- ///
- _cef_domnode_t* function (_cef_domdocument_t* self) nothrow get_focused_node;
-
- ///
- // Returns true (1) if a portion of the document is selected.
- ///
- int function (_cef_domdocument_t* self) nothrow has_selection;
-
- ///
- // Returns the selection offset within the start node.
- ///
- int function (_cef_domdocument_t* self) nothrow get_selection_start_offset;
-
- ///
- // Returns the selection offset within the end node.
- ///
- int function (_cef_domdocument_t* self) nothrow get_selection_end_offset;
-
- ///
- // Returns the contents of this selection as markup.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_domdocument_t* self) nothrow get_selection_as_markup;
-
- ///
- // Returns the contents of this selection as text.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_domdocument_t* self) nothrow get_selection_as_text;
-
- ///
- // Returns the base URL for the document.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_domdocument_t* self) nothrow get_base_url;
-
- ///
- // Returns a complete URL based on the document base URL and the specified
- // partial URL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_domdocument_t* self,
- const(cef_string_t)* partialURL) nothrow get_complete_url;
-}
-
-alias cef_domdocument_t = _cef_domdocument_t;
-
-///
-// Structure used to represent a DOM node. The functions of this structure
-// should only be called on the render process main thread.
-///
-struct _cef_domnode_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the type for this node.
- ///
- cef_dom_node_type_t function (_cef_domnode_t* self) nothrow get_type;
-
- ///
- // Returns true (1) if this is a text node.
- ///
- int function (_cef_domnode_t* self) nothrow is_text;
-
- ///
- // Returns true (1) if this is an element node.
- ///
- int function (_cef_domnode_t* self) nothrow is_element;
-
- ///
- // Returns true (1) if this is an editable node.
- ///
- int function (_cef_domnode_t* self) nothrow is_editable;
-
- ///
- // Returns true (1) if this is a form control element node.
- ///
- int function (_cef_domnode_t* self) nothrow is_form_control_element;
-
- ///
- // Returns the type of this form control element node.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_domnode_t* self) nothrow get_form_control_element_type;
-
- ///
- // Returns true (1) if this object is pointing to the same handle as |that|
- // object.
- ///
- int function (_cef_domnode_t* self, _cef_domnode_t* that) nothrow is_same;
-
- ///
- // Returns the name of this node.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_domnode_t* self) nothrow get_name;
-
- ///
- // Returns the value of this node.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_domnode_t* self) nothrow get_value;
-
- ///
- // Set the value of this node. Returns true (1) on success.
- ///
- int function (_cef_domnode_t* self, const(cef_string_t)* value) nothrow set_value;
-
- ///
- // Returns the contents of this node as markup.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_domnode_t* self) nothrow get_as_markup;
-
- ///
- // Returns the document associated with this node.
- ///
- _cef_domdocument_t* function (_cef_domnode_t* self) nothrow get_document;
-
- ///
- // Returns the parent node.
- ///
- _cef_domnode_t* function (_cef_domnode_t* self) nothrow get_parent;
-
- ///
- // Returns the previous sibling node.
- ///
- _cef_domnode_t* function (_cef_domnode_t* self) nothrow get_previous_sibling;
-
- ///
- // Returns the next sibling node.
- ///
- _cef_domnode_t* function (_cef_domnode_t* self) nothrow get_next_sibling;
-
- ///
- // Returns true (1) if this node has child nodes.
- ///
- int function (_cef_domnode_t* self) nothrow has_children;
-
- ///
- // Return the first child node.
- ///
- _cef_domnode_t* function (_cef_domnode_t* self) nothrow get_first_child;
-
- ///
- // Returns the last child node.
- ///
- _cef_domnode_t* function (_cef_domnode_t* self) nothrow get_last_child;
-
- // The following functions are valid only for element nodes.
-
- ///
- // Returns the tag name of this element.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_domnode_t* self) nothrow get_element_tag_name;
-
- ///
- // Returns true (1) if this element has attributes.
- ///
- int function (_cef_domnode_t* self) nothrow has_element_attributes;
-
- ///
- // Returns true (1) if this element has an attribute named |attrName|.
- ///
- int function (
- _cef_domnode_t* self,
- const(cef_string_t)* attrName) nothrow has_element_attribute;
-
- ///
- // Returns the element attribute named |attrName|.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_domnode_t* self,
- const(cef_string_t)* attrName) nothrow get_element_attribute;
-
- ///
- // Returns a map of all element attributes.
- ///
- void function (
- _cef_domnode_t* self,
- cef_string_map_t attrMap) nothrow get_element_attributes;
-
- ///
- // Set the value for the element attribute named |attrName|. Returns true (1)
- // on success.
- ///
- int function (
- _cef_domnode_t* self,
- const(cef_string_t)* attrName,
- const(cef_string_t)* value) nothrow set_element_attribute;
-
- ///
- // Returns the inner text of the element.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_domnode_t* self) nothrow get_element_inner_text;
-
- ///
- // Returns the bounds of the element.
- ///
- cef_rect_t function (_cef_domnode_t* self) nothrow get_element_bounds;
-}
-
-alias cef_domnode_t = _cef_domnode_t;
-
-// CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=3399f17cc69d8fbd5c09f63f81680aa1f68454f0$
-//
-
-extern (C):
-
-///
-// Callback structure used to asynchronously continue a download.
-///
-struct _cef_before_download_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Call to continue the download. Set |download_path| to the full file path
- // for the download including the file name or leave blank to use the
- // suggested name and the default temp directory. Set |show_dialog| to true
- // (1) if you do wish to show the default "Save As" dialog.
- ///
- void function (
- _cef_before_download_callback_t* self,
- const(cef_string_t)* download_path,
- int show_dialog) nothrow cont;
-}
-
-alias cef_before_download_callback_t = _cef_before_download_callback_t;
-
-///
-// Callback structure used to asynchronously cancel a download.
-///
-struct _cef_download_item_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Call to cancel the download.
- ///
- void function (_cef_download_item_callback_t* self) nothrow cancel;
-
- ///
- // Call to pause the download.
- ///
- void function (_cef_download_item_callback_t* self) nothrow pause;
-
- ///
- // Call to resume the download.
- ///
- void function (_cef_download_item_callback_t* self) nothrow resume;
-}
-
-alias cef_download_item_callback_t = _cef_download_item_callback_t;
-
-///
-// Structure used to handle file downloads. The functions of this structure will
-// called on the browser process UI thread.
-///
-struct _cef_download_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called before a download begins. |suggested_name| is the suggested name for
- // the download file. By default the download will be canceled. Execute
- // |callback| either asynchronously or in this function to continue the
- // download if desired. Do not keep a reference to |download_item| outside of
- // this function.
- ///
- void function (
- _cef_download_handler_t* self,
- _cef_browser_t* browser,
- _cef_download_item_t* download_item,
- const(cef_string_t)* suggested_name,
- _cef_before_download_callback_t* callback) nothrow on_before_download;
-
- ///
- // Called when a download's status or progress information has been updated.
- // This may be called multiple times before and after on_before_download().
- // Execute |callback| either asynchronously or in this function to cancel the
- // download if desired. Do not keep a reference to |download_item| outside of
- // this function.
- ///
- void function (
- _cef_download_handler_t* self,
- _cef_browser_t* browser,
- _cef_download_item_t* download_item,
- _cef_download_item_callback_t* callback) nothrow on_download_updated;
-}
-
-alias cef_download_handler_t = _cef_download_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=d6366977af5e2a3a71b4f57042208ff7ed524c6c$
-//
-
-extern (C):
-
-///
-// Structure used to represent a download item.
-///
-struct _cef_download_item_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. Do not call any other functions
- // if this function returns false (0).
- ///
- int function (_cef_download_item_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if the download is in progress.
- ///
- int function (_cef_download_item_t* self) nothrow is_in_progress;
-
- ///
- // Returns true (1) if the download is complete.
- ///
- int function (_cef_download_item_t* self) nothrow is_complete;
-
- ///
- // Returns true (1) if the download has been canceled or interrupted.
- ///
- int function (_cef_download_item_t* self) nothrow is_canceled;
-
- ///
- // Returns a simple speed estimate in bytes/s.
- ///
- int64 function (_cef_download_item_t* self) nothrow get_current_speed;
-
- ///
- // Returns the rough percent complete or -1 if the receive total size is
- // unknown.
- ///
- int function (_cef_download_item_t* self) nothrow get_percent_complete;
-
- ///
- // Returns the total number of bytes.
- ///
- int64 function (_cef_download_item_t* self) nothrow get_total_bytes;
-
- ///
- // Returns the number of received bytes.
- ///
- int64 function (_cef_download_item_t* self) nothrow get_received_bytes;
-
- ///
- // Returns the time that the download started.
- ///
- cef_time_t function (_cef_download_item_t* self) nothrow get_start_time;
-
- ///
- // Returns the time that the download ended.
- ///
- cef_time_t function (_cef_download_item_t* self) nothrow get_end_time;
-
- ///
- // Returns the full path to the downloaded or downloading file.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_download_item_t* self) nothrow get_full_path;
-
- ///
- // Returns the unique identifier for this download.
- ///
- uint32 function (_cef_download_item_t* self) nothrow get_id;
-
- ///
- // Returns the URL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_download_item_t* self) nothrow get_url;
-
- ///
- // Returns the original URL before any redirections.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_download_item_t* self) nothrow get_original_url;
-
- ///
- // Returns the suggested file name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_download_item_t* self) nothrow get_suggested_file_name;
-
- ///
- // Returns the content disposition.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_download_item_t* self) nothrow get_content_disposition;
-
- ///
- // Returns the mime type.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_download_item_t* self) nothrow get_mime_type;
-}
-
-alias cef_download_item_t = _cef_download_item_t;
-
-// CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=6c8c654be3e69d872b3cfa6bdfb1adf615bff3ac$
-//
-
-extern (C):
-
-///
-// Structure used to represent drag data. The functions of this structure may be
-// called on any thread.
-///
-struct _cef_drag_data_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns a copy of the current object.
- ///
- _cef_drag_data_t* function (_cef_drag_data_t* self) nothrow clone;
-
- ///
- // Returns true (1) if this object is read-only.
- ///
- int function (_cef_drag_data_t* self) nothrow is_read_only;
-
- ///
- // Returns true (1) if the drag data is a link.
- ///
- int function (_cef_drag_data_t* self) nothrow is_link;
-
- ///
- // Returns true (1) if the drag data is a text or html fragment.
- ///
- int function (_cef_drag_data_t* self) nothrow is_fragment;
-
- ///
- // Returns true (1) if the drag data is a file.
- ///
- int function (_cef_drag_data_t* self) nothrow is_file;
-
- ///
- // Return the link URL that is being dragged.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_drag_data_t* self) nothrow get_link_url;
-
- ///
- // Return the title associated with the link being dragged.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_drag_data_t* self) nothrow get_link_title;
-
- ///
- // Return the metadata, if any, associated with the link being dragged.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_drag_data_t* self) nothrow get_link_metadata;
-
- ///
- // Return the plain text fragment that is being dragged.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_drag_data_t* self) nothrow get_fragment_text;
-
- ///
- // Return the text/html fragment that is being dragged.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_drag_data_t* self) nothrow get_fragment_html;
-
- ///
- // Return the base URL that the fragment came from. This value is used for
- // resolving relative URLs and may be NULL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_drag_data_t* self) nothrow get_fragment_base_url;
-
- ///
- // Return the name of the file being dragged out of the browser window.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_drag_data_t* self) nothrow get_file_name;
-
- ///
- // Write the contents of the file being dragged out of the web view into
- // |writer|. Returns the number of bytes sent to |writer|. If |writer| is NULL
- // this function will return the size of the file contents in bytes. Call
- // get_file_name() to get a suggested name for the file.
- ///
- size_t function (
- _cef_drag_data_t* self,
- _cef_stream_writer_t* writer) nothrow get_file_contents;
-
- ///
- // Retrieve the list of file names that are being dragged into the browser
- // window.
- ///
- int function (
- _cef_drag_data_t* self,
- cef_string_list_t names) nothrow get_file_names;
-
- ///
- // Set the link URL that is being dragged.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* url) nothrow set_link_url;
-
- ///
- // Set the title associated with the link being dragged.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* title) nothrow set_link_title;
-
- ///
- // Set the metadata associated with the link being dragged.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* data) nothrow set_link_metadata;
-
- ///
- // Set the plain text fragment that is being dragged.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* text) nothrow set_fragment_text;
-
- ///
- // Set the text/html fragment that is being dragged.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* html) nothrow set_fragment_html;
-
- ///
- // Set the base URL that the fragment came from.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* base_url) nothrow set_fragment_base_url;
-
- ///
- // Reset the file contents. You should do this before calling
- // cef_browser_host_t::DragTargetDragEnter as the web view does not allow us
- // to drag in this kind of data.
- ///
- void function (_cef_drag_data_t* self) nothrow reset_file_contents;
-
- ///
- // Add a file that is being dragged into the webview.
- ///
- void function (
- _cef_drag_data_t* self,
- const(cef_string_t)* path,
- const(cef_string_t)* display_name) nothrow add_file;
-
- ///
- // Get the image representation of drag data. May return NULL if no image
- // representation is available.
- ///
- _cef_image_t* function (_cef_drag_data_t* self) nothrow get_image;
-
- ///
- // Get the image hotspot (drag start location relative to image dimensions).
- ///
- cef_point_t function (_cef_drag_data_t* self) nothrow get_image_hotspot;
-
- ///
- // Returns true (1) if an image representation of drag data is available.
- ///
- int function (_cef_drag_data_t* self) nothrow has_image;
-}
-
-alias cef_drag_data_t = _cef_drag_data_t;
-
-///
-// Create a new cef_drag_data_t object.
-///
-cef_drag_data_t* cef_drag_data_create ();
-
-// CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=78022908355fbf836799545e67ce2e4663b85fdf$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to dragging. The functions
-// of this structure will be called on the UI thread.
-///
-struct _cef_drag_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called when an external drag event enters the browser window. |dragData|
- // contains the drag event data and |mask| represents the type of drag
- // operation. Return false (0) for default drag handling behavior or true (1)
- // to cancel the drag event.
- ///
- int function (
- _cef_drag_handler_t* self,
- _cef_browser_t* browser,
- _cef_drag_data_t* dragData,
- cef_drag_operations_mask_t mask) nothrow on_drag_enter;
-
- ///
- // Called whenever draggable regions for the browser window change. These can
- // be specified using the '-webkit-app-region: drag/no-drag' CSS-property. If
- // draggable regions are never defined in a document this function will also
- // never be called. If the last draggable region is removed from a document
- // this function will be called with an NULL vector.
- ///
- void function (
- _cef_drag_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- size_t regionsCount,
- const(cef_draggable_region_t)* regions) nothrow on_draggable_regions_changed;
-}
-
-alias cef_drag_handler_t = _cef_drag_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=b50087959cb679e4132f0fccfd23f01f76079018$
-//
-
-extern (C):
-
-///
-// Object representing an extension. Methods may be called on any thread unless
-// otherwise indicated.
-///
-struct _cef_extension_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the unique extension identifier. This is calculated based on the
- // extension public key, if available, or on the extension path. See
- // https://developer.chrome.com/extensions/manifest/key for details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_extension_t* self) nothrow get_identifier;
-
- ///
- // Returns the absolute path to the extension directory on disk. This value
- // will be prefixed with PK_DIR_RESOURCES if a relative path was passed to
- // cef_request_context_t::LoadExtension.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_extension_t* self) nothrow get_path;
-
- ///
- // Returns the extension manifest contents as a cef_dictionary_value_t object.
- // See https://developer.chrome.com/extensions/manifest for details.
- ///
- _cef_dictionary_value_t* function (_cef_extension_t* self) nothrow get_manifest;
-
- ///
- // Returns true (1) if this object is the same extension as |that| object.
- // Extensions are considered the same if identifier, path and loader context
- // match.
- ///
- int function (_cef_extension_t* self, _cef_extension_t* that) nothrow is_same;
-
- ///
- // Returns the handler for this extension. Will return NULL for internal
- // extensions or if no handler was passed to
- // cef_request_context_t::LoadExtension.
- ///
- _cef_extension_handler_t* function (_cef_extension_t* self) nothrow get_handler;
-
- ///
- // Returns the request context that loaded this extension. Will return NULL
- // for internal extensions or if the extension has been unloaded. See the
- // cef_request_context_t::LoadExtension documentation for more information
- // about loader contexts. Must be called on the browser process UI thread.
- ///
- _cef_request_context_t* function (
- _cef_extension_t* self) nothrow get_loader_context;
-
- ///
- // Returns true (1) if this extension is currently loaded. Must be called on
- // the browser process UI thread.
- ///
- int function (_cef_extension_t* self) nothrow is_loaded;
-
- ///
- // Unload this extension if it is not an internal extension and is currently
- // loaded. Will result in a call to
- // cef_extension_handler_t::OnExtensionUnloaded on success.
- ///
- void function (_cef_extension_t* self) nothrow unload;
-}
-
-alias cef_extension_t = _cef_extension_t;
-
-// CEF_INCLUDE_CAPI_CEF_EXTENSION_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=c930140791b9e7d4238110e24fe17b9566a34ec9$
-//
-
-extern (C):
-
-///
-// Creates a directory and all parent directories if they don't already exist.
-// Returns true (1) on successful creation or if the directory already exists.
-// The directory is only readable by the current user. Calling this function on
-// the browser process UI or IO threads is not allowed.
-///
-int cef_create_directory (const(cef_string_t)* full_path);
-
-///
-// Get the temporary directory provided by the system.
-//
-// WARNING: In general, you should use the temp directory variants below instead
-// of this function. Those variants will ensure that the proper permissions are
-// set so that other users on the system can't edit them while they're open
-// (which could lead to security issues).
-///
-int cef_get_temp_directory (cef_string_t* temp_dir);
-
-///
-// Creates a new directory. On Windows if |prefix| is provided the new directory
-// name is in the format of "prefixyyyy". Returns true (1) on success and sets
-// |new_temp_path| to the full path of the directory that was created. The
-// directory is only readable by the current user. Calling this function on the
-// browser process UI or IO threads is not allowed.
-///
-int cef_create_new_temp_directory (
- const(cef_string_t)* prefix,
- cef_string_t* new_temp_path);
-
-///
-// Creates a directory within another directory. Extra characters will be
-// appended to |prefix| to ensure that the new directory does not have the same
-// name as an existing directory. Returns true (1) on success and sets |new_dir|
-// to the full path of the directory that was created. The directory is only
-// readable by the current user. Calling this function on the browser process UI
-// or IO threads is not allowed.
-///
-int cef_create_temp_directory_in_directory (
- const(cef_string_t)* base_dir,
- const(cef_string_t)* prefix,
- cef_string_t* new_dir);
-
-///
-// Returns true (1) if the given path exists and is a directory. Calling this
-// function on the browser process UI or IO threads is not allowed.
-///
-int cef_directory_exists (const(cef_string_t)* path);
-
-///
-// Deletes the given path whether it's a file or a directory. If |path| is a
-// directory all contents will be deleted. If |recursive| is true (1) any sub-
-// directories and their contents will also be deleted (equivalent to executing
-// "rm -rf", so use with caution). On POSIX environments if |path| is a symbolic
-// link then only the symlink will be deleted. Returns true (1) on successful
-// deletion or if |path| does not exist. Calling this function on the browser
-// process UI or IO threads is not allowed.
-///
-int cef_delete_file (const(cef_string_t)* path, int recursive);
-
-///
-// Writes the contents of |src_dir| into a zip archive at |dest_file|. If
-// |include_hidden_files| is true (1) files starting with "." will be included.
-// Returns true (1) on success. Calling this function on the browser process UI
-// or IO threads is not allowed.
-///
-int cef_zip_directory (
- const(cef_string_t)* src_dir,
- const(cef_string_t)* dest_file,
- int include_hidden_files);
-
-///
-// Loads the existing "Certificate Revocation Lists" file that is managed by
-// Google Chrome. This file can generally be found in Chrome's User Data
-// directory (e.g. "C:\Users\[User]\AppData\Local\Google\Chrome\User Data\" on
-// Windows) and is updated periodically by Chrome's component updater service.
-// Must be called in the browser process after the context has been initialized.
-// See https://dev.chromium.org/Home/chromium-security/crlsets for background.
-///
-void cef_load_crlsets_file (const(cef_string_t)* path);
-
-// CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=2aa57426a91e10985a5e92830bc3bcd9287708d4$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to find results. The
-// functions of this structure will be called on the UI thread.
-///
-struct _cef_find_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called to report find results returned by cef_browser_host_t::find().
- // |identifer| is the identifier passed to find(), |count| is the number of
- // matches currently identified, |selectionRect| is the location of where the
- // match was found (in window coordinates), |activeMatchOrdinal| is the
- // current position in the search results, and |finalUpdate| is true (1) if
- // this is the last find notification.
- ///
- void function (
- _cef_find_handler_t* self,
- _cef_browser_t* browser,
- int identifier,
- int count,
- const(cef_rect_t)* selectionRect,
- int activeMatchOrdinal,
- int finalUpdate) nothrow on_find_result;
-}
-
-alias cef_find_handler_t = _cef_find_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=091dd994f37070e9d7c27d0e2f7411ea9cf068f5$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to focus. The functions of
-// this structure will be called on the UI thread.
-///
-struct _cef_focus_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called when the browser component is about to loose focus. For instance, if
- // focus was on the last HTML element and the user pressed the TAB key. |next|
- // will be true (1) if the browser is giving focus to the next component and
- // false (0) if the browser is giving focus to the previous component.
- ///
- void function (
- _cef_focus_handler_t* self,
- _cef_browser_t* browser,
- int next) nothrow on_take_focus;
-
- ///
- // Called when the browser component is requesting focus. |source| indicates
- // where the focus request is originating from. Return false (0) to allow the
- // focus to be set or true (1) to cancel setting the focus.
- ///
- int function (
- _cef_focus_handler_t* self,
- _cef_browser_t* browser,
- cef_focus_source_t source) nothrow on_set_focus;
-
- ///
- // Called when the browser component has received focus.
- ///
- void function (
- _cef_focus_handler_t* self,
- _cef_browser_t* browser) nothrow on_got_focus;
-}
-
-alias cef_focus_handler_t = _cef_focus_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=d8f114b44d02d96b5da0ec399c99091b9ceb6871$
-//
-
-extern (C):
-
-///
-// Structure used to represent a frame in the browser window. When used in the
-// browser process the functions of this structure may be called on any thread
-// unless otherwise indicated in the comments. When used in the render process
-// the functions of this structure may only be called on the main thread.
-///
-struct _cef_frame_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // True if this object is currently attached to a valid frame.
- ///
- int function (_cef_frame_t* self) nothrow is_valid;
-
- ///
- // Execute undo in this frame.
- ///
- void function (_cef_frame_t* self) nothrow undo;
-
- ///
- // Execute redo in this frame.
- ///
- void function (_cef_frame_t* self) nothrow redo;
-
- ///
- // Execute cut in this frame.
- ///
- void function (_cef_frame_t* self) nothrow cut;
-
- ///
- // Execute copy in this frame.
- ///
- void function (_cef_frame_t* self) nothrow copy;
-
- ///
- // Execute paste in this frame.
- ///
- void function (_cef_frame_t* self) nothrow paste;
-
- ///
- // Execute delete in this frame.
- ///
- void function (_cef_frame_t* self) nothrow del;
-
- ///
- // Execute select all in this frame.
- ///
- void function (_cef_frame_t* self) nothrow select_all;
-
- ///
- // Save this frame's HTML source to a temporary file and open it in the
- // default text viewing application. This function can only be called from the
- // browser process.
- ///
- void function (_cef_frame_t* self) nothrow view_source;
-
- ///
- // Retrieve this frame's HTML source as a string sent to the specified
- // visitor.
- ///
- void function (
- _cef_frame_t* self,
- _cef_string_visitor_t* visitor) nothrow get_source;
-
- ///
- // Retrieve this frame's display text as a string sent to the specified
- // visitor.
- ///
- void function (
- _cef_frame_t* self,
- _cef_string_visitor_t* visitor) nothrow get_text;
-
- ///
- // Load the request represented by the |request| object.
- //
- // WARNING: This function will fail with "bad IPC message" reason
- // INVALID_INITIATOR_ORIGIN (213) unless you first navigate to the request
- // origin using some other mechanism (LoadURL, link click, etc).
- ///
- void function (_cef_frame_t* self, _cef_request_t* request) nothrow load_request;
-
- ///
- // Load the specified |url|.
- ///
- void function (_cef_frame_t* self, const(cef_string_t)* url) nothrow load_url;
-
- ///
- // Execute a string of JavaScript code in this frame. The |script_url|
- // parameter is the URL where the script in question can be found, if any. The
- // renderer may request this URL to show the developer the source of the
- // error. The |start_line| parameter is the base line number to use for error
- // reporting.
- ///
- void function (
- _cef_frame_t* self,
- const(cef_string_t)* code,
- const(cef_string_t)* script_url,
- int start_line) nothrow execute_java_script;
-
- ///
- // Returns true (1) if this is the main (top-level) frame.
- ///
- int function (_cef_frame_t* self) nothrow is_main;
-
- ///
- // Returns true (1) if this is the focused frame.
- ///
- int function (_cef_frame_t* self) nothrow is_focused;
-
- ///
- // Returns the name for this frame. If the frame has an assigned name (for
- // example, set via the iframe "name" attribute) then that value will be
- // returned. Otherwise a unique name will be constructed based on the frame
- // parent hierarchy. The main (top-level) frame will always have an NULL name
- // value.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_frame_t* self) nothrow get_name;
-
- ///
- // Returns the globally unique identifier for this frame or < 0 if the
- // underlying frame does not yet exist.
- ///
- int64 function (_cef_frame_t* self) nothrow get_identifier;
-
- ///
- // Returns the parent of this frame or NULL if this is the main (top-level)
- // frame.
- ///
- _cef_frame_t* function (_cef_frame_t* self) nothrow get_parent;
-
- ///
- // Returns the URL currently loaded in this frame.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_frame_t* self) nothrow get_url;
-
- ///
- // Returns the browser that this frame belongs to.
- ///
- _cef_browser_t* function (_cef_frame_t* self) nothrow get_browser;
-
- ///
- // Get the V8 context associated with the frame. This function can only be
- // called from the render process.
- ///
- _cef_v8context_t* function (_cef_frame_t* self) nothrow get_v8context;
-
- ///
- // Visit the DOM document. This function can only be called from the render
- // process.
- ///
- void function (_cef_frame_t* self, _cef_domvisitor_t* visitor) nothrow visit_dom;
-
- ///
- // Create a new URL request that will be treated as originating from this
- // frame and the associated browser. This request may be intercepted by the
- // client via cef_resource_request_handler_t or cef_scheme_handler_factory_t.
- // Use cef_urlrequest_t::Create instead if you do not want the request to have
- // this association, in which case it may be handled differently (see
- // documentation on that function). Requests may originate from both the
- // browser process and the render process.
- //
- // For requests originating from the browser process:
- // - POST data may only contain a single element of type PDE_TYPE_FILE or
- // PDE_TYPE_BYTES.
- // For requests originating from the render process:
- // - POST data may only contain a single element of type PDE_TYPE_BYTES.
- // - If the response contains Content-Disposition or Mime-Type header values
- // that would not normally be rendered then the response may receive
- // special handling inside the browser (for example, via the file download
- // code path instead of the URL request code path).
- //
- // The |request| object will be marked as read-only after calling this
- // function.
- ///
- _cef_urlrequest_t* function (
- _cef_frame_t* self,
- _cef_request_t* request,
- _cef_urlrequest_client_t* client) nothrow create_urlrequest;
-
- ///
- // Send a message to the specified |target_process|. Message delivery is not
- // guaranteed in all cases (for example, if the browser is closing,
- // navigating, or if the target process crashes). Send an ACK message back
- // from the target process if confirmation is required.
- ///
- void function (
- _cef_frame_t* self,
- cef_process_id_t target_process,
- _cef_process_message_t* message) nothrow send_process_message;
-}
-
-alias cef_frame_t = _cef_frame_t;
-
-// CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=5afa8e95e6e7bddbd3c442e99b4c2843efb18c49$
-//
-
-extern (C):
-
-///
-// Container for a single image represented at different scale factors. All
-// image representations should be the same size in density independent pixel
-// (DIP) units. For example, if the image at scale factor 1.0 is 100x100 pixels
-// then the image at scale factor 2.0 should be 200x200 pixels -- both images
-// will display with a DIP size of 100x100 units. The functions of this
-// structure can be called on any browser process thread.
-///
-struct _cef_image_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this Image is NULL.
- ///
- int function (_cef_image_t* self) nothrow is_empty;
-
- ///
- // Returns true (1) if this Image and |that| Image share the same underlying
- // storage. Will also return true (1) if both images are NULL.
- ///
- int function (_cef_image_t* self, _cef_image_t* that) nothrow is_same;
-
- ///
- // Add a bitmap image representation for |scale_factor|. Only 32-bit RGBA/BGRA
- // formats are supported. |pixel_width| and |pixel_height| are the bitmap
- // representation size in pixel coordinates. |pixel_data| is the array of
- // pixel data and should be |pixel_width| x |pixel_height| x 4 bytes in size.
- // |color_type| and |alpha_type| values specify the pixel format.
- ///
- int function (
- _cef_image_t* self,
- float scale_factor,
- int pixel_width,
- int pixel_height,
- cef_color_type_t color_type,
- cef_alpha_type_t alpha_type,
- const(void)* pixel_data,
- size_t pixel_data_size) nothrow add_bitmap;
-
- ///
- // Add a PNG image representation for |scale_factor|. |png_data| is the image
- // data of size |png_data_size|. Any alpha transparency in the PNG data will
- // be maintained.
- ///
- int function (
- _cef_image_t* self,
- float scale_factor,
- const(void)* png_data,
- size_t png_data_size) nothrow add_png;
-
- ///
- // Create a JPEG image representation for |scale_factor|. |jpeg_data| is the
- // image data of size |jpeg_data_size|. The JPEG format does not support
- // transparency so the alpha byte will be set to 0xFF for all pixels.
- ///
- int function (
- _cef_image_t* self,
- float scale_factor,
- const(void)* jpeg_data,
- size_t jpeg_data_size) nothrow add_jpeg;
-
- ///
- // Returns the image width in density independent pixel (DIP) units.
- ///
- size_t function (_cef_image_t* self) nothrow get_width;
-
- ///
- // Returns the image height in density independent pixel (DIP) units.
- ///
- size_t function (_cef_image_t* self) nothrow get_height;
-
- ///
- // Returns true (1) if this image contains a representation for
- // |scale_factor|.
- ///
- int function (_cef_image_t* self, float scale_factor) nothrow has_representation;
-
- ///
- // Removes the representation for |scale_factor|. Returns true (1) on success.
- ///
- int function (
- _cef_image_t* self,
- float scale_factor) nothrow remove_representation;
-
- ///
- // Returns information for the representation that most closely matches
- // |scale_factor|. |actual_scale_factor| is the actual scale factor for the
- // representation. |pixel_width| and |pixel_height| are the representation
- // size in pixel coordinates. Returns true (1) on success.
- ///
- int function (
- _cef_image_t* self,
- float scale_factor,
- float* actual_scale_factor,
- int* pixel_width,
- int* pixel_height) nothrow get_representation_info;
-
- ///
- // Returns the bitmap representation that most closely matches |scale_factor|.
- // Only 32-bit RGBA/BGRA formats are supported. |color_type| and |alpha_type|
- // values specify the desired output pixel format. |pixel_width| and
- // |pixel_height| are the output representation size in pixel coordinates.
- // Returns a cef_binary_value_t containing the pixel data on success or NULL
- // on failure.
- ///
- _cef_binary_value_t* function (
- _cef_image_t* self,
- float scale_factor,
- cef_color_type_t color_type,
- cef_alpha_type_t alpha_type,
- int* pixel_width,
- int* pixel_height) nothrow get_as_bitmap;
-
- ///
- // Returns the PNG representation that most closely matches |scale_factor|. If
- // |with_transparency| is true (1) any alpha transparency in the image will be
- // represented in the resulting PNG data. |pixel_width| and |pixel_height| are
- // the output representation size in pixel coordinates. Returns a
- // cef_binary_value_t containing the PNG image data on success or NULL on
- // failure.
- ///
- _cef_binary_value_t* function (
- _cef_image_t* self,
- float scale_factor,
- int with_transparency,
- int* pixel_width,
- int* pixel_height) nothrow get_as_png;
-
- ///
- // Returns the JPEG representation that most closely matches |scale_factor|.
- // |quality| determines the compression level with 0 == lowest and 100 ==
- // highest. The JPEG format does not support alpha transparency and the alpha
- // channel, if any, will be discarded. |pixel_width| and |pixel_height| are
- // the output representation size in pixel coordinates. Returns a
- // cef_binary_value_t containing the JPEG image data on success or NULL on
- // failure.
- ///
- _cef_binary_value_t* function (
- _cef_image_t* self,
- float scale_factor,
- int quality,
- int* pixel_width,
- int* pixel_height) nothrow get_as_jpeg;
-}
-
-alias cef_image_t = _cef_image_t;
-
-///
-// Create a new cef_image_t. It will initially be NULL. Use the Add*() functions
-// to add representations at different scale factors.
-///
-cef_image_t* cef_image_create ();
-
-// CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=e68da1a5db612699b7b727edea2bb629f5d67103$
-//
-
-extern (C):
-
-///
-// Callback structure used for asynchronous continuation of JavaScript dialog
-// requests.
-///
-struct _cef_jsdialog_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Continue the JS dialog request. Set |success| to true (1) if the OK button
- // was pressed. The |user_input| value should be specified for prompt dialogs.
- ///
- void function (
- _cef_jsdialog_callback_t* self,
- int success,
- const(cef_string_t)* user_input) nothrow cont;
-}
-
-alias cef_jsdialog_callback_t = _cef_jsdialog_callback_t;
-
-///
-// Implement this structure to handle events related to JavaScript dialogs. The
-// functions of this structure will be called on the UI thread.
-///
-struct _cef_jsdialog_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called to run a JavaScript dialog. If |origin_url| is non-NULL it can be
- // passed to the CefFormatUrlForSecurityDisplay function to retrieve a secure
- // and user-friendly display string. The |default_prompt_text| value will be
- // specified for prompt dialogs only. Set |suppress_message| to true (1) and
- // return false (0) to suppress the message (suppressing messages is
- // preferable to immediately executing the callback as this is used to detect
- // presumably malicious behavior like spamming alert messages in
- // onbeforeunload). Set |suppress_message| to false (0) and return false (0)
- // to use the default implementation (the default implementation will show one
- // modal dialog at a time and suppress any additional dialog requests until
- // the displayed dialog is dismissed). Return true (1) if the application will
- // use a custom dialog or if the callback has been executed immediately.
- // Custom dialogs may be either modal or modeless. If a custom dialog is used
- // the application must execute |callback| once the custom dialog is
- // dismissed.
- ///
- int function (
- _cef_jsdialog_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* origin_url,
- cef_jsdialog_type_t dialog_type,
- const(cef_string_t)* message_text,
- const(cef_string_t)* default_prompt_text,
- _cef_jsdialog_callback_t* callback,
- int* suppress_message) nothrow on_jsdialog;
-
- ///
- // Called to run a dialog asking the user if they want to leave a page. Return
- // false (0) to use the default dialog implementation. Return true (1) if the
- // application will use a custom dialog or if the callback has been executed
- // immediately. Custom dialogs may be either modal or modeless. If a custom
- // dialog is used the application must execute |callback| once the custom
- // dialog is dismissed.
- ///
- int function (
- _cef_jsdialog_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* message_text,
- int is_reload,
- _cef_jsdialog_callback_t* callback) nothrow on_before_unload_dialog;
-
- ///
- // Called to cancel any pending dialogs and reset any saved dialog state. Will
- // be called due to events like page navigation irregardless of whether any
- // dialogs are currently pending.
- ///
- void function (
- _cef_jsdialog_handler_t* self,
- _cef_browser_t* browser) nothrow on_reset_dialog_state;
-
- ///
- // Called when the default implementation dialog is closed.
- ///
- void function (
- _cef_jsdialog_handler_t* self,
- _cef_browser_t* browser) nothrow on_dialog_closed;
-}
-
-alias cef_jsdialog_handler_t = _cef_jsdialog_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=70108de432674485dee079e541e0dacd6a437961$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to keyboard input. The
-// functions of this structure will be called on the UI thread.
-///
-struct _cef_keyboard_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called before a keyboard event is sent to the renderer. |event| contains
- // information about the keyboard event. |os_event| is the operating system
- // event message, if any. Return true (1) if the event was handled or false
- // (0) otherwise. If the event will be handled in on_key_event() as a keyboard
- // shortcut set |is_keyboard_shortcut| to true (1) and return false (0).
- ///
- int function (
- _cef_keyboard_handler_t* self,
- _cef_browser_t* browser,
- const(_cef_key_event_t)* event,
- OS_EVENT* os_event,
- int* is_keyboard_shortcut) nothrow on_pre_key_event;
-
- ///
- // Called after the renderer and JavaScript in the page has had a chance to
- // handle the event. |event| contains information about the keyboard event.
- // |os_event| is the operating system event message, if any. Return true (1)
- // if the keyboard event was handled or false (0) otherwise.
- ///
- int function (
- _cef_keyboard_handler_t* self,
- _cef_browser_t* browser,
- const(_cef_key_event_t)* event,
- OS_EVENT* os_event) nothrow on_key_event;
-}
-
-alias cef_keyboard_handler_t = _cef_keyboard_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=d6e91d55d41f729dca94ba5766f57849f29d0796$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to browser life span. The
-// functions of this structure will be called on the UI thread unless otherwise
-// indicated.
-///
-struct _cef_life_span_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the UI thread before a new popup browser is created. The
- // |browser| and |frame| values represent the source of the popup request. The
- // |target_url| and |target_frame_name| values indicate where the popup
- // browser should navigate and may be NULL if not specified with the request.
- // The |target_disposition| value indicates where the user intended to open
- // the popup (e.g. current tab, new tab, etc). The |user_gesture| value will
- // be true (1) if the popup was opened via explicit user gesture (e.g.
- // clicking a link) or false (0) if the popup opened automatically (e.g. via
- // the DomContentLoaded event). The |popupFeatures| structure contains
- // additional information about the requested popup window. To allow creation
- // of the popup browser optionally modify |windowInfo|, |client|, |settings|
- // and |no_javascript_access| and return false (0). To cancel creation of the
- // popup browser return true (1). The |client| and |settings| values will
- // default to the source browser's values. If the |no_javascript_access| value
- // is set to false (0) the new browser will not be scriptable and may not be
- // hosted in the same renderer process as the source browser. Any
- // modifications to |windowInfo| will be ignored if the parent browser is
- // wrapped in a cef_browser_view_t. Popup browser creation will be canceled if
- // the parent browser is destroyed before the popup browser creation completes
- // (indicated by a call to OnAfterCreated for the popup browser). The
- // |extra_info| parameter provides an opportunity to specify extra information
- // specific to the created popup browser that will be passed to
- // cef_render_process_handler_t::on_browser_created() in the render process.
- ///
- int function (
- _cef_life_span_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- const(cef_string_t)* target_url,
- const(cef_string_t)* target_frame_name,
- cef_window_open_disposition_t target_disposition,
- int user_gesture,
- const(_cef_popup_features_t)* popupFeatures,
- _cef_window_info_t* windowInfo,
- _cef_client_t** client,
- _cef_browser_settings_t* settings,
- _cef_dictionary_value_t** extra_info,
- int* no_javascript_access) nothrow on_before_popup;
-
- ///
- // Called after a new browser is created. This callback will be the first
- // notification that references |browser|.
- ///
- void function (
- _cef_life_span_handler_t* self,
- _cef_browser_t* browser) nothrow on_after_created;
-
- ///
- // Called when a browser has recieved a request to close. This may result
- // directly from a call to cef_browser_host_t::*close_browser() or indirectly
- // if the browser is parented to a top-level window created by CEF and the
- // user attempts to close that window (by clicking the 'X', for example). The
- // do_close() function will be called after the JavaScript 'onunload' event
- // has been fired.
- //
- // An application should handle top-level owner window close notifications by
- // calling cef_browser_host_t::try_close_browser() or
- // cef_browser_host_t::CloseBrowser(false (0)) instead of allowing the window
- // to close immediately (see the examples below). This gives CEF an
- // opportunity to process the 'onbeforeunload' event and optionally cancel the
- // close before do_close() is called.
- //
- // When windowed rendering is enabled CEF will internally create a window or
- // view to host the browser. In that case returning false (0) from do_close()
- // will send the standard close notification to the browser's top-level owner
- // window (e.g. WM_CLOSE on Windows, performClose: on OS X, "delete_event" on
- // Linux or cef_window_delegate_t::can_close() callback from Views). If the
- // browser's host window/view has already been destroyed (via view hierarchy
- // tear-down, for example) then do_close() will not be called for that browser
- // since is no longer possible to cancel the close.
- //
- // When windowed rendering is disabled returning false (0) from do_close()
- // will cause the browser object to be destroyed immediately.
- //
- // If the browser's top-level owner window requires a non-standard close
- // notification then send that notification from do_close() and return true
- // (1).
- //
- // The cef_life_span_handler_t::on_before_close() function will be called
- // after do_close() (if do_close() is called) and immediately before the
- // browser object is destroyed. The application should only exit after
- // on_before_close() has been called for all existing browsers.
- //
- // The below examples describe what should happen during window close when the
- // browser is parented to an application-provided top-level window.
- //
- // Example 1: Using cef_browser_host_t::try_close_browser(). This is
- // recommended for clients using standard close handling and windows created
- // on the browser process UI thread. 1. User clicks the window close button
- // which sends a close notification to
- // the application's top-level window.
- // 2. Application's top-level window receives the close notification and
- // calls TryCloseBrowser() (which internally calls CloseBrowser(false)).
- // TryCloseBrowser() returns false so the client cancels the window close.
- // 3. JavaScript 'onbeforeunload' handler executes and shows the close
- // confirmation dialog (which can be overridden via
- // CefJSDialogHandler::OnBeforeUnloadDialog()).
- // 4. User approves the close. 5. JavaScript 'onunload' handler executes. 6.
- // CEF sends a close notification to the application's top-level window
- // (because DoClose() returned false by default).
- // 7. Application's top-level window receives the close notification and
- // calls TryCloseBrowser(). TryCloseBrowser() returns true so the client
- // allows the window close.
- // 8. Application's top-level window is destroyed. 9. Application's
- // on_before_close() handler is called and the browser object
- // is destroyed.
- // 10. Application exits by calling cef_quit_message_loop() if no other
- // browsers
- // exist.
- //
- // Example 2: Using cef_browser_host_t::CloseBrowser(false (0)) and
- // implementing the do_close() callback. This is recommended for clients using
- // non-standard close handling or windows that were not created on the browser
- // process UI thread. 1. User clicks the window close button which sends a
- // close notification to
- // the application's top-level window.
- // 2. Application's top-level window receives the close notification and:
- // A. Calls CefBrowserHost::CloseBrowser(false).
- // B. Cancels the window close.
- // 3. JavaScript 'onbeforeunload' handler executes and shows the close
- // confirmation dialog (which can be overridden via
- // CefJSDialogHandler::OnBeforeUnloadDialog()).
- // 4. User approves the close. 5. JavaScript 'onunload' handler executes. 6.
- // Application's do_close() handler is called. Application will:
- // A. Set a flag to indicate that the next close attempt will be allowed.
- // B. Return false.
- // 7. CEF sends an close notification to the application's top-level window.
- // 8. Application's top-level window receives the close notification and
- // allows the window to close based on the flag from #6B.
- // 9. Application's top-level window is destroyed. 10. Application's
- // on_before_close() handler is called and the browser object
- // is destroyed.
- // 11. Application exits by calling cef_quit_message_loop() if no other
- // browsers
- // exist.
- ///
- int function (
- _cef_life_span_handler_t* self,
- _cef_browser_t* browser) nothrow do_close;
-
- ///
- // Called just before a browser is destroyed. Release all references to the
- // browser object and do not attempt to execute any functions on the browser
- // object (other than GetIdentifier or IsSame) after this callback returns.
- // This callback will be the last notification that references |browser| on
- // the UI thread. Any in-progress network requests associated with |browser|
- // will be aborted when the browser is destroyed, and
- // cef_resource_request_handler_t callbacks related to those requests may
- // still arrive on the IO thread after this function is called. See do_close()
- // documentation for additional usage information.
- ///
- void function (
- _cef_life_span_handler_t* self,
- _cef_browser_t* browser) nothrow on_before_close;
-}
-
-alias cef_life_span_handler_t = _cef_life_span_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=fa3cb1461b9d363c6c7d961f9e291c2fe736170e$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to browser load status. The
-// functions of this structure will be called on the browser process UI thread
-// or render process main thread (TID_RENDERER).
-///
-struct _cef_load_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called when the loading state has changed. This callback will be executed
- // twice -- once when loading is initiated either programmatically or by user
- // action, and once when loading is terminated due to completion, cancellation
- // of failure. It will be called before any calls to OnLoadStart and after all
- // calls to OnLoadError and/or OnLoadEnd.
- ///
- void function (
- _cef_load_handler_t* self,
- _cef_browser_t* browser,
- int isLoading,
- int canGoBack,
- int canGoForward) nothrow on_loading_state_change;
-
- ///
- // Called after a navigation has been committed and before the browser begins
- // loading contents in the frame. The |frame| value will never be NULL -- call
- // the is_main() function to check if this frame is the main frame.
- // |transition_type| provides information about the source of the navigation
- // and an accurate value is only available in the browser process. Multiple
- // frames may be loading at the same time. Sub-frames may start or continue
- // loading after the main frame load has ended. This function will not be
- // called for same page navigations (fragments, history state, etc.) or for
- // navigations that fail or are canceled before commit. For notification of
- // overall browser load status use OnLoadingStateChange instead.
- ///
- void function (
- _cef_load_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- cef_transition_type_t transition_type) nothrow on_load_start;
-
- ///
- // Called when the browser is done loading a frame. The |frame| value will
- // never be NULL -- call the is_main() function to check if this frame is the
- // main frame. Multiple frames may be loading at the same time. Sub-frames may
- // start or continue loading after the main frame load has ended. This
- // function will not be called for same page navigations (fragments, history
- // state, etc.) or for navigations that fail or are canceled before commit.
- // For notification of overall browser load status use OnLoadingStateChange
- // instead.
- ///
- void function (
- _cef_load_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- int httpStatusCode) nothrow on_load_end;
-
- ///
- // Called when a navigation fails or is canceled. This function may be called
- // by itself if before commit or in combination with OnLoadStart/OnLoadEnd if
- // after commit. |errorCode| is the error code number, |errorText| is the
- // error text and |failedUrl| is the URL that failed to load. See
- // net\base\net_error_list.h for complete descriptions of the error codes.
- ///
- void function (
- _cef_load_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- cef_errorcode_t errorCode,
- const(cef_string_t)* errorText,
- const(cef_string_t)* failedUrl) nothrow on_load_error;
-}
-
-alias cef_load_handler_t = _cef_load_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=4f4a0d76efaf87055ebf5e784f5d1b69fafdabc2$
-//
-
-extern (C):
-
-///
-// Supports discovery of and communication with media devices on the local
-// network via the Cast and DIAL protocols. The functions of this structure may
-// be called on any browser process thread unless otherwise indicated.
-///
-struct _cef_media_router_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Add an observer for MediaRouter events. The observer will remain registered
- // until the returned Registration object is destroyed.
- ///
- _cef_registration_t* function (
- _cef_media_router_t* self,
- _cef_media_observer_t* observer) nothrow add_observer;
-
- ///
- // Returns a MediaSource object for the specified media source URN. Supported
- // URN schemes include "cast:" and "dial:", and will be already known by the
- // client application (e.g. "cast:?clientId=").
- ///
- _cef_media_source_t* function (
- _cef_media_router_t* self,
- const(cef_string_t)* urn) nothrow get_source;
-
- ///
- // Trigger an asynchronous call to cef_media_observer_t::OnSinks on all
- // registered observers.
- ///
- void function (_cef_media_router_t* self) nothrow notify_current_sinks;
-
- ///
- // Create a new route between |source| and |sink|. Source and sink must be
- // valid, compatible (as reported by cef_media_sink_t::IsCompatibleWith), and
- // a route between them must not already exist. |callback| will be executed on
- // success or failure. If route creation succeeds it will also trigger an
- // asynchronous call to cef_media_observer_t::OnRoutes on all registered
- // observers.
- ///
- void function (
- _cef_media_router_t* self,
- _cef_media_source_t* source,
- _cef_media_sink_t* sink,
- _cef_media_route_create_callback_t* callback) nothrow create_route;
-
- ///
- // Trigger an asynchronous call to cef_media_observer_t::OnRoutes on all
- // registered observers.
- ///
- void function (_cef_media_router_t* self) nothrow notify_current_routes;
-}
-
-alias cef_media_router_t = _cef_media_router_t;
-
-///
-// Returns the MediaRouter object associated with the global request context.
-// Equivalent to calling cef_request_context_t::cef_request_context_get_global_c
-// ontext()->get_media_router().
-///
-cef_media_router_t* cef_media_router_get_global ();
-
-///
-// Implemented by the client to observe MediaRouter events and registered via
-// cef_media_router_t::AddObserver. The functions of this structure will be
-// called on the browser process UI thread.
-///
-struct _cef_media_observer_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // The list of available media sinks has changed or
- // cef_media_router_t::NotifyCurrentSinks was called.
- ///
- void function (
- _cef_media_observer_t* self,
- size_t sinksCount,
- _cef_media_sink_t** sinks) nothrow on_sinks;
-
- ///
- // The list of available media routes has changed or
- // cef_media_router_t::NotifyCurrentRoutes was called.
- ///
- void function (
- _cef_media_observer_t* self,
- size_t routesCount,
- _cef_media_route_t** routes) nothrow on_routes;
-
- ///
- // The connection state of |route| has changed.
- ///
- void function (
- _cef_media_observer_t* self,
- _cef_media_route_t* route,
- cef_media_route_connection_state_t state) nothrow on_route_state_changed;
-
- ///
- // A message was recieved over |route|. |message| is only valid for the scope
- // of this callback and should be copied if necessary.
- ///
- void function (
- _cef_media_observer_t* self,
- _cef_media_route_t* route,
- const(void)* message,
- size_t message_size) nothrow on_route_message_received;
-}
-
-alias cef_media_observer_t = _cef_media_observer_t;
-
-///
-// Represents the route between a media source and sink. Instances of this
-// object are created via cef_media_router_t::CreateRoute and retrieved via
-// cef_media_observer_t::OnRoutes. Contains the status and metadata of a routing
-// operation. The functions of this structure may be called on any browser
-// process thread unless otherwise indicated.
-///
-struct _cef_media_route_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the ID for this route.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_media_route_t* self) nothrow get_id;
-
- ///
- // Returns the source associated with this route.
- ///
- _cef_media_source_t* function (_cef_media_route_t* self) nothrow get_source;
-
- ///
- // Returns the sink associated with this route.
- ///
- _cef_media_sink_t* function (_cef_media_route_t* self) nothrow get_sink;
-
- ///
- // Send a message over this route. |message| will be copied if necessary.
- ///
- void function (
- _cef_media_route_t* self,
- const(void)* message,
- size_t message_size) nothrow send_route_message;
-
- ///
- // Terminate this route. Will result in an asynchronous call to
- // cef_media_observer_t::OnRoutes on all registered observers.
- ///
- void function (_cef_media_route_t* self) nothrow terminate;
-}
-
-alias cef_media_route_t = _cef_media_route_t;
-
-///
-// Callback structure for cef_media_router_t::CreateRoute. The functions of this
-// structure will be called on the browser process UI thread.
-///
-struct _cef_media_route_create_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed when the route creation has finished. |result|
- // will be CEF_MRCR_OK if the route creation succeeded. |error| will be a
- // description of the error if the route creation failed. |route| is the
- // resulting route, or NULL if the route creation failed.
- ///
- void function (
- _cef_media_route_create_callback_t* self,
- cef_media_route_create_result_t result,
- const(cef_string_t)* error,
- _cef_media_route_t* route) nothrow on_media_route_create_finished;
-}
-
-alias cef_media_route_create_callback_t = _cef_media_route_create_callback_t;
-
-///
-// Represents a sink to which media can be routed. Instances of this object are
-// retrieved via cef_media_observer_t::OnSinks. The functions of this structure
-// may be called on any browser process thread unless otherwise indicated.
-///
-struct _cef_media_sink_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the ID for this sink.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_media_sink_t* self) nothrow get_id;
-
- ///
- // Returns the name of this sink.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_media_sink_t* self) nothrow get_name;
-
- ///
- // Returns the description of this sink.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_media_sink_t* self) nothrow get_description;
-
- ///
- // Returns the icon type for this sink.
- ///
- cef_media_sink_icon_type_t function (
- _cef_media_sink_t* self) nothrow get_icon_type;
-
- ///
- // Asynchronously retrieves device info.
- ///
- void function (
- _cef_media_sink_t* self,
- _cef_media_sink_device_info_callback_t* callback) nothrow get_device_info;
-
- ///
- // Returns true (1) if this sink accepts content via Cast.
- ///
- int function (_cef_media_sink_t* self) nothrow is_cast_sink;
-
- ///
- // Returns true (1) if this sink accepts content via DIAL.
- ///
- int function (_cef_media_sink_t* self) nothrow is_dial_sink;
-
- ///
- // Returns true (1) if this sink is compatible with |source|.
- ///
- int function (
- _cef_media_sink_t* self,
- _cef_media_source_t* source) nothrow is_compatible_with;
-}
-
-alias cef_media_sink_t = _cef_media_sink_t;
-
-///
-// Callback structure for cef_media_sink_t::GetDeviceInfo. The functions of this
-// structure will be called on the browser process UI thread.
-///
-struct _cef_media_sink_device_info_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed asyncronously once device information has been
- // retrieved.
- ///
- void function (
- _cef_media_sink_device_info_callback_t* self,
- const(_cef_media_sink_device_info_t)* device_info) nothrow on_media_sink_device_info;
-}
-
-alias cef_media_sink_device_info_callback_t = _cef_media_sink_device_info_callback_t;
-
-///
-// Represents a source from which media can be routed. Instances of this object
-// are retrieved via cef_media_router_t::GetSource. The functions of this
-// structure may be called on any browser process thread unless otherwise
-// indicated.
-///
-struct _cef_media_source_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the ID (media source URN or URL) for this source.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_media_source_t* self) nothrow get_id;
-
- ///
- // Returns true (1) if this source outputs its content via Cast.
- ///
- int function (_cef_media_source_t* self) nothrow is_cast_source;
-
- ///
- // Returns true (1) if this source outputs its content via DIAL.
- ///
- int function (_cef_media_source_t* self) nothrow is_dial_source;
-}
-
-alias cef_media_source_t = _cef_media_source_t;
-
-// CEF_INCLUDE_CAPI_CEF_MEDIA_ROUTER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=cce24dba079162b10f359769eea176c4009b5ce5$
-//
-
-extern (C):
-
-///
-// Supports creation and modification of menus. See cef_menu_id_t for the
-// command ids that have default implementations. All user-defined command ids
-// should be between MENU_ID_USER_FIRST and MENU_ID_USER_LAST. The functions of
-// this structure can only be accessed on the browser process the UI thread.
-///
-struct _cef_menu_model_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this menu is a submenu.
- ///
- int function (_cef_menu_model_t* self) nothrow is_sub_menu;
-
- ///
- // Clears the menu. Returns true (1) on success.
- ///
- int function (_cef_menu_model_t* self) nothrow clear;
-
- ///
- // Returns the number of items in this menu.
- ///
- int function (_cef_menu_model_t* self) nothrow get_count;
-
- ///
- // Add a separator to the menu. Returns true (1) on success.
- ///
- int function (_cef_menu_model_t* self) nothrow add_separator;
-
- ///
- // Add an item to the menu. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- const(cef_string_t)* label) nothrow add_item;
-
- ///
- // Add a check item to the menu. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- const(cef_string_t)* label) nothrow add_check_item;
-
- ///
- // Add a radio item to the menu. Only a single item with the specified
- // |group_id| can be checked at a time. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- const(cef_string_t)* label,
- int group_id) nothrow add_radio_item;
-
- ///
- // Add a sub-menu to the menu. The new sub-menu is returned.
- ///
- _cef_menu_model_t* function (
- _cef_menu_model_t* self,
- int command_id,
- const(cef_string_t)* label) nothrow add_sub_menu;
-
- ///
- // Insert a separator in the menu at the specified |index|. Returns true (1)
- // on success.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow insert_separator_at;
-
- ///
- // Insert an item in the menu at the specified |index|. Returns true (1) on
- // success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int command_id,
- const(cef_string_t)* label) nothrow insert_item_at;
-
- ///
- // Insert a check item in the menu at the specified |index|. Returns true (1)
- // on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int command_id,
- const(cef_string_t)* label) nothrow insert_check_item_at;
-
- ///
- // Insert a radio item in the menu at the specified |index|. Only a single
- // item with the specified |group_id| can be checked at a time. Returns true
- // (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int command_id,
- const(cef_string_t)* label,
- int group_id) nothrow insert_radio_item_at;
-
- ///
- // Insert a sub-menu in the menu at the specified |index|. The new sub-menu is
- // returned.
- ///
- _cef_menu_model_t* function (
- _cef_menu_model_t* self,
- int index,
- int command_id,
- const(cef_string_t)* label) nothrow insert_sub_menu_at;
-
- ///
- // Removes the item with the specified |command_id|. Returns true (1) on
- // success.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow remove;
-
- ///
- // Removes the item at the specified |index|. Returns true (1) on success.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow remove_at;
-
- ///
- // Returns the index associated with the specified |command_id| or -1 if not
- // found due to the command id not existing in the menu.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow get_index_of;
-
- ///
- // Returns the command id at the specified |index| or -1 if not found due to
- // invalid range or the index being a separator.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow get_command_id_at;
-
- ///
- // Sets the command id at the specified |index|. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int command_id) nothrow set_command_id_at;
-
- ///
- // Returns the label for the specified |command_id| or NULL if not found.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_menu_model_t* self,
- int command_id) nothrow get_label;
-
- ///
- // Returns the label at the specified |index| or NULL if not found due to
- // invalid range or the index being a separator.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_menu_model_t* self,
- int index) nothrow get_label_at;
-
- ///
- // Sets the label for the specified |command_id|. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- const(cef_string_t)* label) nothrow set_label;
-
- ///
- // Set the label at the specified |index|. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- const(cef_string_t)* label) nothrow set_label_at;
-
- ///
- // Returns the item type for the specified |command_id|.
- ///
- cef_menu_item_type_t function (
- _cef_menu_model_t* self,
- int command_id) nothrow get_type;
-
- ///
- // Returns the item type at the specified |index|.
- ///
- cef_menu_item_type_t function (
- _cef_menu_model_t* self,
- int index) nothrow get_type_at;
-
- ///
- // Returns the group id for the specified |command_id| or -1 if invalid.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow get_group_id;
-
- ///
- // Returns the group id at the specified |index| or -1 if invalid.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow get_group_id_at;
-
- ///
- // Sets the group id for the specified |command_id|. Returns true (1) on
- // success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- int group_id) nothrow set_group_id;
-
- ///
- // Sets the group id at the specified |index|. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int group_id) nothrow set_group_id_at;
-
- ///
- // Returns the submenu for the specified |command_id| or NULL if invalid.
- ///
- _cef_menu_model_t* function (
- _cef_menu_model_t* self,
- int command_id) nothrow get_sub_menu;
-
- ///
- // Returns the submenu at the specified |index| or NULL if invalid.
- ///
- _cef_menu_model_t* function (
- _cef_menu_model_t* self,
- int index) nothrow get_sub_menu_at;
-
- ///
- // Returns true (1) if the specified |command_id| is visible.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow is_visible;
-
- ///
- // Returns true (1) if the specified |index| is visible.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow is_visible_at;
-
- ///
- // Change the visibility of the specified |command_id|. Returns true (1) on
- // success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- int visible) nothrow set_visible;
-
- ///
- // Change the visibility at the specified |index|. Returns true (1) on
- // success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int visible) nothrow set_visible_at;
-
- ///
- // Returns true (1) if the specified |command_id| is enabled.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow is_enabled;
-
- ///
- // Returns true (1) if the specified |index| is enabled.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow is_enabled_at;
-
- ///
- // Change the enabled status of the specified |command_id|. Returns true (1)
- // on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- int enabled) nothrow set_enabled;
-
- ///
- // Change the enabled status at the specified |index|. Returns true (1) on
- // success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int enabled) nothrow set_enabled_at;
-
- ///
- // Returns true (1) if the specified |command_id| is checked. Only applies to
- // check and radio items.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow is_checked;
-
- ///
- // Returns true (1) if the specified |index| is checked. Only applies to check
- // and radio items.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow is_checked_at;
-
- ///
- // Check the specified |command_id|. Only applies to check and radio items.
- // Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- int checked) nothrow set_checked;
-
- ///
- // Check the specified |index|. Only applies to check and radio items. Returns
- // true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int checked) nothrow set_checked_at;
-
- ///
- // Returns true (1) if the specified |command_id| has a keyboard accelerator
- // assigned.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow has_accelerator;
-
- ///
- // Returns true (1) if the specified |index| has a keyboard accelerator
- // assigned.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow has_accelerator_at;
-
- ///
- // Set the keyboard accelerator for the specified |command_id|. |key_code| can
- // be any virtual key or character value. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- int key_code,
- int shift_pressed,
- int ctrl_pressed,
- int alt_pressed) nothrow set_accelerator;
-
- ///
- // Set the keyboard accelerator at the specified |index|. |key_code| can be
- // any virtual key or character value. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int key_code,
- int shift_pressed,
- int ctrl_pressed,
- int alt_pressed) nothrow set_accelerator_at;
-
- ///
- // Remove the keyboard accelerator for the specified |command_id|. Returns
- // true (1) on success.
- ///
- int function (_cef_menu_model_t* self, int command_id) nothrow remove_accelerator;
-
- ///
- // Remove the keyboard accelerator at the specified |index|. Returns true (1)
- // on success.
- ///
- int function (_cef_menu_model_t* self, int index) nothrow remove_accelerator_at;
-
- ///
- // Retrieves the keyboard accelerator for the specified |command_id|. Returns
- // true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- int* key_code,
- int* shift_pressed,
- int* ctrl_pressed,
- int* alt_pressed) nothrow get_accelerator;
-
- ///
- // Retrieves the keyboard accelerator for the specified |index|. Returns true
- // (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- int* key_code,
- int* shift_pressed,
- int* ctrl_pressed,
- int* alt_pressed) nothrow get_accelerator_at;
-
- ///
- // Set the explicit color for |command_id| and |color_type| to |color|.
- // Specify a |color| value of 0 to remove the explicit color. If no explicit
- // color or default color is set for |color_type| then the system color will
- // be used. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- cef_menu_color_type_t color_type,
- cef_color_t color) nothrow set_color;
-
- ///
- // Set the explicit color for |command_id| and |index| to |color|. Specify a
- // |color| value of 0 to remove the explicit color. Specify an |index| value
- // of -1 to set the default color for items that do not have an explicit color
- // set. If no explicit color or default color is set for |color_type| then the
- // system color will be used. Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- cef_menu_color_type_t color_type,
- cef_color_t color) nothrow set_color_at;
-
- ///
- // Returns in |color| the color that was explicitly set for |command_id| and
- // |color_type|. If a color was not set then 0 will be returned in |color|.
- // Returns true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- cef_menu_color_type_t color_type,
- cef_color_t* color) nothrow get_color;
-
- ///
- // Returns in |color| the color that was explicitly set for |command_id| and
- // |color_type|. Specify an |index| value of -1 to return the default color in
- // |color|. If a color was not set then 0 will be returned in |color|. Returns
- // true (1) on success.
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- cef_menu_color_type_t color_type,
- cef_color_t* color) nothrow get_color_at;
-
- ///
- // Sets the font list for the specified |command_id|. If |font_list| is NULL
- // the system font will be used. Returns true (1) on success. The format is
- // ",[STYLES] ", where: - FONT_FAMILY_LIST is a comma-
- // separated list of font family names, - STYLES is an optional space-
- // separated list of style names (case-sensitive
- // "Bold" and "Italic" are supported), and
- // - SIZE is an integer font size in pixels with the suffix "px".
- //
- // Here are examples of valid font description strings: - "Arial, Helvetica,
- // Bold Italic 14px" - "Arial, 14px"
- ///
- int function (
- _cef_menu_model_t* self,
- int command_id,
- const(cef_string_t)* font_list) nothrow set_font_list;
-
- ///
- // Sets the font list for the specified |index|. Specify an |index| value of
- // -1 to set the default font. If |font_list| is NULL the system font will be
- // used. Returns true (1) on success. The format is
- // ",[STYLES] ", where: - FONT_FAMILY_LIST is a comma-
- // separated list of font family names, - STYLES is an optional space-
- // separated list of style names (case-sensitive
- // "Bold" and "Italic" are supported), and
- // - SIZE is an integer font size in pixels with the suffix "px".
- //
- // Here are examples of valid font description strings: - "Arial, Helvetica,
- // Bold Italic 14px" - "Arial, 14px"
- ///
- int function (
- _cef_menu_model_t* self,
- int index,
- const(cef_string_t)* font_list) nothrow set_font_list_at;
-}
-
-alias cef_menu_model_t = _cef_menu_model_t;
-
-///
-// Create a new MenuModel with the specified |delegate|.
-///
-cef_menu_model_t* cef_menu_model_create (_cef_menu_model_delegate_t* delegate_);
-
-// CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=071ec8a0e17d3b33acbf36c7ccc26d0995657cf3$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle menu model events. The functions of this
-// structure will be called on the browser process UI thread unless otherwise
-// indicated.
-///
-struct _cef_menu_model_delegate_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Perform the action associated with the specified |command_id| and optional
- // |event_flags|.
- ///
- void function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model,
- int command_id,
- cef_event_flags_t event_flags) nothrow execute_command;
-
- ///
- // Called when the user moves the mouse outside the menu and over the owning
- // window.
- ///
- void function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model,
- const(cef_point_t)* screen_point) nothrow mouse_outside_menu;
-
- ///
- // Called on unhandled open submenu keyboard commands. |is_rtl| will be true
- // (1) if the menu is displaying a right-to-left language.
- ///
- void function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model,
- int is_rtl) nothrow unhandled_open_submenu;
-
- ///
- // Called on unhandled close submenu keyboard commands. |is_rtl| will be true
- // (1) if the menu is displaying a right-to-left language.
- ///
- void function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model,
- int is_rtl) nothrow unhandled_close_submenu;
-
- ///
- // The menu is about to show.
- ///
- void function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model) nothrow menu_will_show;
-
- ///
- // The menu has closed.
- ///
- void function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model) nothrow menu_closed;
-
- ///
- // Optionally modify a menu item label. Return true (1) if |label| was
- // modified.
- ///
- int function (
- _cef_menu_model_delegate_t* self,
- _cef_menu_model_t* menu_model,
- cef_string_t* label) nothrow format_label;
-}
-
-alias cef_menu_model_delegate_t = _cef_menu_model_delegate_t;
-
-// CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=c6252024911652a4881d753aeeeb2615e6be3904$
-//
-
-extern (C):
-
-///
-// Structure used to represent an entry in navigation history.
-///
-struct _cef_navigation_entry_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. Do not call any other functions
- // if this function returns false (0).
- ///
- int function (_cef_navigation_entry_t* self) nothrow is_valid;
-
- ///
- // Returns the actual URL of the page. For some pages this may be data: URL or
- // similar. Use get_display_url() to return a display-friendly version.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_navigation_entry_t* self) nothrow get_url;
-
- ///
- // Returns a display-friendly version of the URL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_navigation_entry_t* self) nothrow get_display_url;
-
- ///
- // Returns the original URL that was entered by the user before any redirects.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_navigation_entry_t* self) nothrow get_original_url;
-
- ///
- // Returns the title set by the page. This value may be NULL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_navigation_entry_t* self) nothrow get_title;
-
- ///
- // Returns the transition type which indicates what the user did to move to
- // this page from the previous page.
- ///
- cef_transition_type_t function (
- _cef_navigation_entry_t* self) nothrow get_transition_type;
-
- ///
- // Returns true (1) if this navigation includes post data.
- ///
- int function (_cef_navigation_entry_t* self) nothrow has_post_data;
-
- ///
- // Returns the time for the last known successful navigation completion. A
- // navigation may be completed more than once if the page is reloaded. May be
- // 0 if the navigation has not yet completed.
- ///
- cef_time_t function (_cef_navigation_entry_t* self) nothrow get_completion_time;
-
- ///
- // Returns the HTTP status code for the last known successful navigation
- // response. May be 0 if the response has not yet been received or if the
- // navigation has not yet completed.
- ///
- int function (_cef_navigation_entry_t* self) nothrow get_http_status_code;
-
- ///
- // Returns the SSL information for this navigation entry.
- ///
- _cef_sslstatus_t* function (_cef_navigation_entry_t* self) nothrow get_sslstatus;
-}
-
-alias cef_navigation_entry_t = _cef_navigation_entry_t;
-
-// CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=8a26e2f8273298dcf44d6fbf32fd565f6aaa912c$
-//
-
-extern (C):
-
-///
-// Add an entry to the cross-origin access whitelist.
-//
-// The same-origin policy restricts how scripts hosted from different origins
-// (scheme + domain + port) can communicate. By default, scripts can only access
-// resources with the same origin. Scripts hosted on the HTTP and HTTPS schemes
-// (but no other schemes) can use the "Access-Control-Allow-Origin" header to
-// allow cross-origin requests. For example, https://source.example.com can make
-// XMLHttpRequest requests on http://target.example.com if the
-// http://target.example.com request returns an "Access-Control-Allow-Origin:
-// https://source.example.com" response header.
-//
-// Scripts in separate frames or iframes and hosted from the same protocol and
-// domain suffix can execute cross-origin JavaScript if both pages set the
-// document.domain value to the same domain suffix. For example,
-// scheme://foo.example.com and scheme://bar.example.com can communicate using
-// JavaScript if both domains set document.domain="example.com".
-//
-// This function is used to allow access to origins that would otherwise violate
-// the same-origin policy. Scripts hosted underneath the fully qualified
-// |source_origin| URL (like http://www.example.com) will be allowed access to
-// all resources hosted on the specified |target_protocol| and |target_domain|.
-// If |target_domain| is non-NULL and |allow_target_subdomains| if false (0)
-// only exact domain matches will be allowed. If |target_domain| contains a top-
-// level domain component (like "example.com") and |allow_target_subdomains| is
-// true (1) sub-domain matches will be allowed. If |target_domain| is NULL and
-// |allow_target_subdomains| if true (1) all domains and IP addresses will be
-// allowed.
-//
-// This function cannot be used to bypass the restrictions on local or display
-// isolated schemes. See the comments on CefRegisterCustomScheme for more
-// information.
-//
-// This function may be called on any thread. Returns false (0) if
-// |source_origin| is invalid or the whitelist cannot be accessed.
-///
-int cef_add_cross_origin_whitelist_entry (
- const(cef_string_t)* source_origin,
- const(cef_string_t)* target_protocol,
- const(cef_string_t)* target_domain,
- int allow_target_subdomains);
-
-///
-// Remove an entry from the cross-origin access whitelist. Returns false (0) if
-// |source_origin| is invalid or the whitelist cannot be accessed.
-///
-int cef_remove_cross_origin_whitelist_entry (
- const(cef_string_t)* source_origin,
- const(cef_string_t)* target_protocol,
- const(cef_string_t)* target_domain,
- int allow_target_subdomains);
-
-///
-// Remove all entries from the cross-origin access whitelist. Returns false (0)
-// if the whitelist cannot be accessed.
-///
-int cef_clear_cross_origin_whitelist ();
-
-// CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=19337a70a13352e70452be7fcc25ef2de4b1ae4c$
-//
-
-extern (C):
-
-///
-// Parse the specified |url| into its component parts. Returns false (0) if the
-// URL is NULL or invalid.
-///
-int cef_parse_url (const(cef_string_t)* url, _cef_urlparts_t* parts);
-
-///
-// Creates a URL from the specified |parts|, which must contain a non-NULL spec
-// or a non-NULL host and path (at a minimum), but not both. Returns false (0)
-// if |parts| isn't initialized as described.
-///
-int cef_create_url (const(_cef_urlparts_t)* parts, cef_string_t* url);
-
-///
-// This is a convenience function for formatting a URL in a concise and human-
-// friendly way to help users make security-related decisions (or in other
-// circumstances when people need to distinguish sites, origins, or otherwise-
-// simplified URLs from each other). Internationalized domain names (IDN) may be
-// presented in Unicode if the conversion is considered safe. The returned value
-// will (a) omit the path for standard schemes, excepting file and filesystem,
-// and (b) omit the port if it is the default for the scheme. Do not use this
-// for URLs which will be parsed or sent to other applications.
-///
-// The resulting string must be freed by calling cef_string_userfree_free().
-cef_string_userfree_t cef_format_url_for_security_display (
- const(cef_string_t)* origin_url);
-
-///
-// Returns the mime type for the specified file extension or an NULL string if
-// unknown.
-///
-// The resulting string must be freed by calling cef_string_userfree_free().
-cef_string_userfree_t cef_get_mime_type (const(cef_string_t)* extension);
-
-///
-// Get the extensions associated with the given mime type. This should be passed
-// in lower case. There could be multiple extensions for a given mime type, like
-// "html,htm" for "text/html", or "txt,text,html,..." for "text/*". Any existing
-// elements in the provided vector will not be erased.
-///
-void cef_get_extensions_for_mime_type (
- const(cef_string_t)* mime_type,
- cef_string_list_t extensions);
-
-///
-// Encodes |data| as a base64 string.
-///
-// The resulting string must be freed by calling cef_string_userfree_free().
-cef_string_userfree_t cef_base64encode (const(void)* data, size_t data_size);
-
-///
-// Decodes the base64 encoded string |data|. The returned value will be NULL if
-// the decoding fails.
-///
-_cef_binary_value_t* cef_base64decode (const(cef_string_t)* data);
-
-///
-// Escapes characters in |text| which are unsuitable for use as a query
-// parameter value. Everything except alphanumerics and -_.!~*'() will be
-// converted to "%XX". If |use_plus| is true (1) spaces will change to "+". The
-// result is basically the same as encodeURIComponent in Javacript.
-///
-// The resulting string must be freed by calling cef_string_userfree_free().
-cef_string_userfree_t cef_uriencode (const(cef_string_t)* text, int use_plus);
-
-///
-// Unescapes |text| and returns the result. Unescaping consists of looking for
-// the exact pattern "%XX" where each X is a hex digit and converting to the
-// character with the numerical value of those digits (e.g. "i%20=%203%3b"
-// unescapes to "i = 3;"). If |convert_to_utf8| is true (1) this function will
-// attempt to interpret the initial decoded result as UTF-8. If the result is
-// convertable into UTF-8 it will be returned as converted. Otherwise the
-// initial decoded result will be returned. The |unescape_rule| parameter
-// supports further customization the decoding process.
-///
-// The resulting string must be freed by calling cef_string_userfree_free().
-cef_string_userfree_t cef_uridecode (
- const(cef_string_t)* text,
- int convert_to_utf8,
- cef_uri_unescape_rule_t unescape_rule);
-
-///
-// Parses the specified |json_string| and returns a dictionary or list
-// representation. If JSON parsing fails this function returns NULL.
-///
-_cef_value_t* cef_parse_json (
- const(cef_string_t)* json_string,
- cef_json_parser_options_t options);
-
-///
-// Parses the specified UTF8-encoded |json| buffer of size |json_size| and
-// returns a dictionary or list representation. If JSON parsing fails this
-// function returns NULL.
-///
-_cef_value_t* cef_parse_json_buffer (
- const(void)* json,
- size_t json_size,
- cef_json_parser_options_t options);
-
-///
-// Parses the specified |json_string| and returns a dictionary or list
-// representation. If JSON parsing fails this function returns NULL and
-// populates |error_msg_out| with a formatted error message.
-///
-_cef_value_t* cef_parse_jsonand_return_error (
- const(cef_string_t)* json_string,
- cef_json_parser_options_t options,
- cef_string_t* error_msg_out);
-
-///
-// Generates a JSON string from the specified root |node| which should be a
-// dictionary or list value. Returns an NULL string on failure. This function
-// requires exclusive access to |node| including any underlying data.
-///
-// The resulting string must be freed by calling cef_string_userfree_free().
-cef_string_userfree_t cef_write_json (
- _cef_value_t* node,
- cef_json_writer_options_t options);
-
-// CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=1b218a91d7f3ba0e68f0c3be21a0df91e515d28a$
-//
-
-extern (C):
-
-///
-// Retrieve the path associated with the specified |key|. Returns true (1) on
-// success. Can be called on any thread in the browser process.
-///
-int cef_get_path (cef_path_key_t key, cef_string_t* path);
-
-// CEF_INCLUDE_CAPI_CEF_PATH_UTIL_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=b8d7be1399d3426a3f872b12bc1438e041a16308$
-//
-
-extern (C):
-
-///
-// Callback structure for asynchronous continuation of print dialog requests.
-///
-struct _cef_print_dialog_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Continue printing with the specified |settings|.
- ///
- void function (
- _cef_print_dialog_callback_t* self,
- _cef_print_settings_t* settings) nothrow cont;
-
- ///
- // Cancel the printing.
- ///
- void function (_cef_print_dialog_callback_t* self) nothrow cancel;
-}
-
-alias cef_print_dialog_callback_t = _cef_print_dialog_callback_t;
-
-///
-// Callback structure for asynchronous continuation of print job requests.
-///
-struct _cef_print_job_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Indicate completion of the print job.
- ///
- void function (_cef_print_job_callback_t* self) nothrow cont;
-}
-
-alias cef_print_job_callback_t = _cef_print_job_callback_t;
-
-///
-// Implement this structure to handle printing on Linux. Each browser will have
-// only one print job in progress at a time. The functions of this structure
-// will be called on the browser process UI thread.
-///
-struct _cef_print_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called when printing has started for the specified |browser|. This function
- // will be called before the other OnPrint*() functions and irrespective of
- // how printing was initiated (e.g. cef_browser_host_t::print(), JavaScript
- // window.print() or PDF extension print button).
- ///
- void function (
- _cef_print_handler_t* self,
- _cef_browser_t* browser) nothrow on_print_start;
-
- ///
- // Synchronize |settings| with client state. If |get_defaults| is true (1)
- // then populate |settings| with the default print settings. Do not keep a
- // reference to |settings| outside of this callback.
- ///
- void function (
- _cef_print_handler_t* self,
- _cef_browser_t* browser,
- _cef_print_settings_t* settings,
- int get_defaults) nothrow on_print_settings;
-
- ///
- // Show the print dialog. Execute |callback| once the dialog is dismissed.
- // Return true (1) if the dialog will be displayed or false (0) to cancel the
- // printing immediately.
- ///
- int function (
- _cef_print_handler_t* self,
- _cef_browser_t* browser,
- int has_selection,
- _cef_print_dialog_callback_t* callback) nothrow on_print_dialog;
-
- ///
- // Send the print job to the printer. Execute |callback| once the job is
- // completed. Return true (1) if the job will proceed or false (0) to cancel
- // the job immediately.
- ///
- int function (
- _cef_print_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* document_name,
- const(cef_string_t)* pdf_file_path,
- _cef_print_job_callback_t* callback) nothrow on_print_job;
-
- ///
- // Reset client state related to printing.
- ///
- void function (
- _cef_print_handler_t* self,
- _cef_browser_t* browser) nothrow on_print_reset;
-
- ///
- // Return the PDF paper size in device units. Used in combination with
- // cef_browser_host_t::print_to_pdf().
- ///
- cef_size_t function (
- _cef_print_handler_t* self,
- int device_units_per_inch) nothrow get_pdf_paper_size;
-}
-
-alias cef_print_handler_t = _cef_print_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_PRINT_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=8f7d7993691e07f4a8a42d63522c751cfba3c168$
-//
-
-extern (C):
-
-///
-// Structure representing print settings.
-///
-struct _cef_print_settings_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. Do not call any other functions
- // if this function returns false (0).
- ///
- int function (_cef_print_settings_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if the values of this object are read-only. Some APIs may
- // expose read-only objects.
- ///
- int function (_cef_print_settings_t* self) nothrow is_read_only;
-
- ///
- // Set the page orientation.
- ///
- void function (_cef_print_settings_t* self, int landscape) nothrow set_orientation;
-
- ///
- // Returns true (1) if the orientation is landscape.
- ///
- int function (_cef_print_settings_t* self) nothrow is_landscape;
-
- ///
- // Set the printer printable area in device units. Some platforms already
- // provide flipped area. Set |landscape_needs_flip| to false (0) on those
- // platforms to avoid double flipping.
- ///
- void function (
- _cef_print_settings_t* self,
- const(cef_size_t)* physical_size_device_units,
- const(cef_rect_t)* printable_area_device_units,
- int landscape_needs_flip) nothrow set_printer_printable_area;
-
- ///
- // Set the device name.
- ///
- void function (
- _cef_print_settings_t* self,
- const(cef_string_t)* name) nothrow set_device_name;
-
- ///
- // Get the device name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_print_settings_t* self) nothrow get_device_name;
-
- ///
- // Set the DPI (dots per inch).
- ///
- void function (_cef_print_settings_t* self, int dpi) nothrow set_dpi;
-
- ///
- // Get the DPI (dots per inch).
- ///
- int function (_cef_print_settings_t* self) nothrow get_dpi;
-
- ///
- // Set the page ranges.
- ///
- void function (
- _cef_print_settings_t* self,
- size_t rangesCount,
- const(cef_range_t)* ranges) nothrow set_page_ranges;
-
- ///
- // Returns the number of page ranges that currently exist.
- ///
- size_t function (_cef_print_settings_t* self) nothrow get_page_ranges_count;
-
- ///
- // Retrieve the page ranges.
- ///
- void function (
- _cef_print_settings_t* self,
- size_t* rangesCount,
- cef_range_t* ranges) nothrow get_page_ranges;
-
- ///
- // Set whether only the selection will be printed.
- ///
- void function (
- _cef_print_settings_t* self,
- int selection_only) nothrow set_selection_only;
-
- ///
- // Returns true (1) if only the selection will be printed.
- ///
- int function (_cef_print_settings_t* self) nothrow is_selection_only;
-
- ///
- // Set whether pages will be collated.
- ///
- void function (_cef_print_settings_t* self, int collate) nothrow set_collate;
-
- ///
- // Returns true (1) if pages will be collated.
- ///
- int function (_cef_print_settings_t* self) nothrow will_collate;
-
- ///
- // Set the color model.
- ///
- void function (
- _cef_print_settings_t* self,
- cef_color_model_t model) nothrow set_color_model;
-
- ///
- // Get the color model.
- ///
- cef_color_model_t function (_cef_print_settings_t* self) nothrow get_color_model;
-
- ///
- // Set the number of copies.
- ///
- void function (_cef_print_settings_t* self, int copies) nothrow set_copies;
-
- ///
- // Get the number of copies.
- ///
- int function (_cef_print_settings_t* self) nothrow get_copies;
-
- ///
- // Set the duplex mode.
- ///
- void function (
- _cef_print_settings_t* self,
- cef_duplex_mode_t mode) nothrow set_duplex_mode;
-
- ///
- // Get the duplex mode.
- ///
- cef_duplex_mode_t function (_cef_print_settings_t* self) nothrow get_duplex_mode;
-}
-
-alias cef_print_settings_t = _cef_print_settings_t;
-
-///
-// Create a new cef_print_settings_t object.
-///
-cef_print_settings_t* cef_print_settings_create ();
-
-// CEF_INCLUDE_CAPI_CEF_PRINT_SETTINGS_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=79ec6d99ea47e1cf9b2cca0433704f205e14d3bd$
-//
-
-extern (C):
-
-///
-// Structure representing a message. Can be used on any process and thread.
-///
-struct _cef_process_message_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. Do not call any other functions
- // if this function returns false (0).
- ///
- int function (_cef_process_message_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if the values of this object are read-only. Some APIs may
- // expose read-only objects.
- ///
- int function (_cef_process_message_t* self) nothrow is_read_only;
-
- ///
- // Returns a writable copy of this object.
- ///
- _cef_process_message_t* function (_cef_process_message_t* self) nothrow copy;
-
- ///
- // Returns the message name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_process_message_t* self) nothrow get_name;
-
- ///
- // Returns the list of arguments.
- ///
- _cef_list_value_t* function (
- _cef_process_message_t* self) nothrow get_argument_list;
-}
-
-alias cef_process_message_t = _cef_process_message_t;
-
-///
-// Create a new cef_process_message_t object with the specified name.
-///
-cef_process_message_t* cef_process_message_create (const(cef_string_t)* name);
-
-// CEF_INCLUDE_CAPI_CEF_PROCESS_MESSAGE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=75b16fd9d592c1d22b94d740e1deb61efe3afb97$
-//
-
-extern (C):
-
-///
-// Launches the process specified via |command_line|. Returns true (1) upon
-// success. Must be called on the browser process TID_PROCESS_LAUNCHER thread.
-//
-// Unix-specific notes: - All file descriptors open in the parent process will
-// be closed in the
-// child process except for stdin, stdout, and stderr.
-// - If the first argument on the command line does not contain a slash,
-// PATH will be searched. (See man execvp.)
-///
-int cef_launch_process (_cef_command_line_t* command_line);
-
-// CEF_INCLUDE_CAPI_CEF_PROCESS_UTIL_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=029e237cf80f94a25453bac5a9b1e0765bb56f37$
-//
-
-extern (C):
-
-///
-// Generic callback structure used for managing the lifespan of a registration.
-///
-struct _cef_registration_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-}
-
-alias cef_registration_t = _cef_registration_t;
-
-// CEF_INCLUDE_CAPI_CEF_REGISTRATION_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=f9806cd79f33b6a762fff25edd4189ae42bc8fd2$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events when window rendering is disabled.
-// The functions of this structure will be called on the UI thread.
-///
-struct _cef_render_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Return the handler for accessibility notifications. If no handler is
- // provided the default implementation will be used.
- ///
- _cef_accessibility_handler_t* function (
- _cef_render_handler_t* self) nothrow get_accessibility_handler;
-
- ///
- // Called to retrieve the root window rectangle in screen coordinates. Return
- // true (1) if the rectangle was provided. If this function returns false (0)
- // the rectangle from GetViewRect will be used.
- ///
- int function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- cef_rect_t* rect) nothrow get_root_screen_rect;
-
- ///
- // Called to retrieve the view rectangle which is relative to screen
- // coordinates. This function must always provide a non-NULL rectangle.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- cef_rect_t* rect) nothrow get_view_rect;
-
- ///
- // Called to retrieve the translation from view coordinates to actual screen
- // coordinates. Return true (1) if the screen coordinates were provided.
- ///
- int function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- int viewX,
- int viewY,
- int* screenX,
- int* screenY) nothrow get_screen_point;
-
- ///
- // Called to allow the client to fill in the CefScreenInfo object with
- // appropriate values. Return true (1) if the |screen_info| structure has been
- // modified.
- //
- // If the screen info rectangle is left NULL the rectangle from GetViewRect
- // will be used. If the rectangle is still NULL or invalid popups may not be
- // drawn correctly.
- ///
- int function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- _cef_screen_info_t* screen_info) nothrow get_screen_info;
-
- ///
- // Called when the browser wants to show or hide the popup widget. The popup
- // should be shown if |show| is true (1) and hidden if |show| is false (0).
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- int show) nothrow on_popup_show;
-
- ///
- // Called when the browser wants to move or resize the popup widget. |rect|
- // contains the new location and size in view coordinates.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- const(cef_rect_t)* rect) nothrow on_popup_size;
-
- ///
- // Called when an element should be painted. Pixel values passed to this
- // function are scaled relative to view coordinates based on the value of
- // CefScreenInfo.device_scale_factor returned from GetScreenInfo. |type|
- // indicates whether the element is the view or the popup widget. |buffer|
- // contains the pixel data for the whole image. |dirtyRects| contains the set
- // of rectangles in pixel coordinates that need to be repainted. |buffer| will
- // be |width|*|height|*4 bytes in size and represents a BGRA image with an
- // upper-left origin. This function is only called when
- // cef_window_tInfo::shared_texture_enabled is set to false (0).
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- cef_paint_element_type_t type,
- size_t dirtyRectsCount,
- const(cef_rect_t)* dirtyRects,
- const(void)* buffer,
- int width,
- int height) nothrow on_paint;
-
- ///
- // Called when an element has been rendered to the shared texture handle.
- // |type| indicates whether the element is the view or the popup widget.
- // |dirtyRects| contains the set of rectangles in pixel coordinates that need
- // to be repainted. |shared_handle| is the handle for a D3D11 Texture2D that
- // can be accessed via ID3D11Device using the OpenSharedResource function.
- // This function is only called when cef_window_tInfo::shared_texture_enabled
- // is set to true (1), and is currently only supported on Windows.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- cef_paint_element_type_t type,
- size_t dirtyRectsCount,
- const(cef_rect_t)* dirtyRects,
- void* shared_handle) nothrow on_accelerated_paint;
-
- ///
- // Called when the user starts dragging content in the web view. Contextual
- // information about the dragged content is supplied by |drag_data|. (|x|,
- // |y|) is the drag start location in screen coordinates. OS APIs that run a
- // system message loop may be used within the StartDragging call.
- //
- // Return false (0) to abort the drag operation. Don't call any of
- // cef_browser_host_t::DragSource*Ended* functions after returning false (0).
- //
- // Return true (1) to handle the drag operation. Call
- // cef_browser_host_t::DragSourceEndedAt and DragSourceSystemDragEnded either
- // synchronously or asynchronously to inform the web view that the drag
- // operation has ended.
- ///
- int function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- _cef_drag_data_t* drag_data,
- cef_drag_operations_mask_t allowed_ops,
- int x,
- int y) nothrow start_dragging;
-
- ///
- // Called when the web view wants to update the mouse cursor during a drag &
- // drop operation. |operation| describes the allowed operation (none, move,
- // copy, link).
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- cef_drag_operations_mask_t operation) nothrow update_drag_cursor;
-
- ///
- // Called when the scroll offset has changed.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- double x,
- double y) nothrow on_scroll_offset_changed;
-
- ///
- // Called when the IME composition range has changed. |selected_range| is the
- // range of characters that have been selected. |character_bounds| is the
- // bounds of each character in view coordinates.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- const(cef_range_t)* selected_range,
- size_t character_boundsCount,
- const(cef_rect_t)* character_bounds) nothrow on_ime_composition_range_changed;
-
- ///
- // Called when text selection has changed for the specified |browser|.
- // |selected_text| is the currently selected text and |selected_range| is the
- // character range.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* selected_text,
- const(cef_range_t)* selected_range) nothrow on_text_selection_changed;
-
- ///
- // Called when an on-screen keyboard should be shown or hidden for the
- // specified |browser|. |input_mode| specifies what kind of keyboard should be
- // opened. If |input_mode| is CEF_TEXT_INPUT_MODE_NONE, any existing keyboard
- // for this browser should be hidden.
- ///
- void function (
- _cef_render_handler_t* self,
- _cef_browser_t* browser,
- cef_text_input_mode_t input_mode) nothrow on_virtual_keyboard_requested;
-}
-
-alias cef_render_handler_t = _cef_render_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_RENDER_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=8419eb3eba9dd372b019bd367d4f195433b21c9b$
-//
-
-extern (C):
-
-///
-// Structure used to implement render process callbacks. The functions of this
-// structure will be called on the render process main thread (TID_RENDERER)
-// unless otherwise indicated.
-///
-struct _cef_render_process_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called after WebKit has been initialized.
- ///
- void function (_cef_render_process_handler_t* self) nothrow on_web_kit_initialized;
-
- ///
- // Called after a browser has been created. When browsing cross-origin a new
- // browser will be created before the old browser with the same identifier is
- // destroyed. |extra_info| is a read-only value originating from
- // cef_browser_host_t::cef_browser_host_create_browser(),
- // cef_browser_host_t::cef_browser_host_create_browser_sync(),
- // cef_life_span_handler_t::on_before_popup() or
- // cef_browser_view_t::cef_browser_view_create().
- ///
- void function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser,
- _cef_dictionary_value_t* extra_info) nothrow on_browser_created;
-
- ///
- // Called before a browser is destroyed.
- ///
- void function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser) nothrow on_browser_destroyed;
-
- ///
- // Return the handler for browser load status events.
- ///
- _cef_load_handler_t* function (
- _cef_render_process_handler_t* self) nothrow get_load_handler;
-
- ///
- // Called immediately after the V8 context for a frame has been created. To
- // retrieve the JavaScript 'window' object use the
- // cef_v8context_t::get_global() function. V8 handles can only be accessed
- // from the thread on which they are created. A task runner for posting tasks
- // on the associated thread can be retrieved via the
- // cef_v8context_t::get_task_runner() function.
- ///
- void function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_v8context_t* context) nothrow on_context_created;
-
- ///
- // Called immediately before the V8 context for a frame is released. No
- // references to the context should be kept after this function is called.
- ///
- void function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_v8context_t* context) nothrow on_context_released;
-
- ///
- // Called for global uncaught exceptions in a frame. Execution of this
- // callback is disabled by default. To enable set
- // CefSettings.uncaught_exception_stack_size > 0.
- ///
- void function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_v8context_t* context,
- _cef_v8exception_t* exception,
- _cef_v8stack_trace_t* stackTrace) nothrow on_uncaught_exception;
-
- ///
- // Called when a new node in the the browser gets focus. The |node| value may
- // be NULL if no specific node has gained focus. The node object passed to
- // this function represents a snapshot of the DOM at the time this function is
- // executed. DOM objects are only valid for the scope of this function. Do not
- // keep references to or attempt to access any DOM objects outside the scope
- // of this function.
- ///
- void function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_domnode_t* node) nothrow on_focused_node_changed;
-
- ///
- // Called when a new message is received from a different process. Return true
- // (1) if the message was handled or false (0) otherwise. Do not keep a
- // reference to or attempt to access the message outside of this callback.
- ///
- int function (
- _cef_render_process_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- cef_process_id_t source_process,
- _cef_process_message_t* message) nothrow on_process_message_received;
-}
-
-alias cef_render_process_handler_t = _cef_render_process_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_RENDER_PROCESS_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=3efd81a4bfdfca579a77f14bd37b8192122ebda4$
-//
-
-extern (C):
-
-///
-// Callback structure used for asynchronous continuation of url requests.
-///
-struct _cef_request_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Continue the url request. If |allow| is true (1) the request will be
- // continued. Otherwise, the request will be canceled.
- ///
- void function (_cef_request_callback_t* self, int allow) nothrow cont;
-
- ///
- // Cancel the url request.
- ///
- void function (_cef_request_callback_t* self) nothrow cancel;
-}
-
-alias cef_request_callback_t = _cef_request_callback_t;
-
-// CEF_INCLUDE_CAPI_CEF_REQUEST_CALLBACK_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=b3725b8fa4118936caacda69504dc597f3620d82$
-//
-
-extern (C):
-
-///
-// Structure used to represent a web request. The functions of this structure
-// may be called on any thread.
-///
-struct _cef_request_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is read-only.
- ///
- int function (_cef_request_t* self) nothrow is_read_only;
-
- ///
- // Get the fully qualified URL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_request_t* self) nothrow get_url;
-
- ///
- // Set the fully qualified URL.
- ///
- void function (_cef_request_t* self, const(cef_string_t)* url) nothrow set_url;
-
- ///
- // Get the request function type. The value will default to POST if post data
- // is provided and GET otherwise.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_request_t* self) nothrow get_method;
-
- ///
- // Set the request function type.
- ///
- void function (
- _cef_request_t* self,
- const(cef_string_t)* method) nothrow set_method;
-
- ///
- // Set the referrer URL and policy. If non-NULL the referrer URL must be fully
- // qualified with an HTTP or HTTPS scheme component. Any username, password or
- // ref component will be removed.
- ///
- void function (
- _cef_request_t* self,
- const(cef_string_t)* referrer_url,
- cef_referrer_policy_t policy) nothrow set_referrer;
-
- ///
- // Get the referrer URL.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_request_t* self) nothrow get_referrer_url;
-
- ///
- // Get the referrer policy.
- ///
- cef_referrer_policy_t function (_cef_request_t* self) nothrow get_referrer_policy;
-
- ///
- // Get the post data.
- ///
- _cef_post_data_t* function (_cef_request_t* self) nothrow get_post_data;
-
- ///
- // Set the post data.
- ///
- void function (
- _cef_request_t* self,
- _cef_post_data_t* postData) nothrow set_post_data;
-
- ///
- // Get the header values. Will not include the Referer value if any.
- ///
- void function (
- _cef_request_t* self,
- cef_string_multimap_t headerMap) nothrow get_header_map;
-
- ///
- // Set the header values. If a Referer value exists in the header map it will
- // be removed and ignored.
- ///
- void function (
- _cef_request_t* self,
- cef_string_multimap_t headerMap) nothrow set_header_map;
-
- ///
- // Returns the first header value for |name| or an NULL string if not found.
- // Will not return the Referer value if any. Use GetHeaderMap instead if
- // |name| might have multiple values.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_request_t* self,
- const(cef_string_t)* name) nothrow get_header_by_name;
-
- ///
- // Set the header |name| to |value|. If |overwrite| is true (1) any existing
- // values will be replaced with the new value. If |overwrite| is false (0) any
- // existing values will not be overwritten. The Referer value cannot be set
- // using this function.
- ///
- void function (
- _cef_request_t* self,
- const(cef_string_t)* name,
- const(cef_string_t)* value,
- int overwrite) nothrow set_header_by_name;
-
- ///
- // Set all values at one time.
- ///
- void function (
- _cef_request_t* self,
- const(cef_string_t)* url,
- const(cef_string_t)* method,
- _cef_post_data_t* postData,
- cef_string_multimap_t headerMap) nothrow set;
-
- ///
- // Get the flags used in combination with cef_urlrequest_t. See
- // cef_urlrequest_flags_t for supported values.
- ///
- int function (_cef_request_t* self) nothrow get_flags;
-
- ///
- // Set the flags used in combination with cef_urlrequest_t. See
- // cef_urlrequest_flags_t for supported values.
- ///
- void function (_cef_request_t* self, int flags) nothrow set_flags;
-
- ///
- // Get the URL to the first party for cookies used in combination with
- // cef_urlrequest_t.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_request_t* self) nothrow get_first_party_for_cookies;
-
- ///
- // Set the URL to the first party for cookies used in combination with
- // cef_urlrequest_t.
- ///
- void function (
- _cef_request_t* self,
- const(cef_string_t)* url) nothrow set_first_party_for_cookies;
-
- ///
- // Get the resource type for this request. Only available in the browser
- // process.
- ///
- cef_resource_type_t function (_cef_request_t* self) nothrow get_resource_type;
-
- ///
- // Get the transition type for this request. Only available in the browser
- // process and only applies to requests that represent a main frame or sub-
- // frame navigation.
- ///
- cef_transition_type_t function (_cef_request_t* self) nothrow get_transition_type;
-
- ///
- // Returns the globally unique identifier for this request or 0 if not
- // specified. Can be used by cef_resource_request_handler_t implementations in
- // the browser process to track a single request across multiple callbacks.
- ///
- uint64 function (_cef_request_t* self) nothrow get_identifier;
-}
-
-alias cef_request_t = _cef_request_t;
-
-///
-// Create a new cef_request_t object.
-///
-cef_request_t* cef_request_create ();
-
-///
-// Structure used to represent post data for a web request. The functions of
-// this structure may be called on any thread.
-///
-struct _cef_post_data_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is read-only.
- ///
- int function (_cef_post_data_t* self) nothrow is_read_only;
-
- ///
- // Returns true (1) if the underlying POST data includes elements that are not
- // represented by this cef_post_data_t object (for example, multi-part file
- // upload data). Modifying cef_post_data_t objects with excluded elements may
- // result in the request failing.
- ///
- int function (_cef_post_data_t* self) nothrow has_excluded_elements;
-
- ///
- // Returns the number of existing post data elements.
- ///
- size_t function (_cef_post_data_t* self) nothrow get_element_count;
-
- ///
- // Retrieve the post data elements.
- ///
- void function (
- _cef_post_data_t* self,
- size_t* elementsCount,
- _cef_post_data_element_t** elements) nothrow get_elements;
-
- ///
- // Remove the specified post data element. Returns true (1) if the removal
- // succeeds.
- ///
- int function (
- _cef_post_data_t* self,
- _cef_post_data_element_t* element) nothrow remove_element;
-
- ///
- // Add the specified post data element. Returns true (1) if the add succeeds.
- ///
- int function (
- _cef_post_data_t* self,
- _cef_post_data_element_t* element) nothrow add_element;
-
- ///
- // Remove all existing post data elements.
- ///
- void function (_cef_post_data_t* self) nothrow remove_elements;
-}
-
-alias cef_post_data_t = _cef_post_data_t;
-
-///
-// Create a new cef_post_data_t object.
-///
-cef_post_data_t* cef_post_data_create ();
-
-///
-// Structure used to represent a single element in the request post data. The
-// functions of this structure may be called on any thread.
-///
-struct _cef_post_data_element_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is read-only.
- ///
- int function (_cef_post_data_element_t* self) nothrow is_read_only;
-
- ///
- // Remove all contents from the post data element.
- ///
- void function (_cef_post_data_element_t* self) nothrow set_to_empty;
-
- ///
- // The post data element will represent a file.
- ///
- void function (
- _cef_post_data_element_t* self,
- const(cef_string_t)* fileName) nothrow set_to_file;
-
- ///
- // The post data element will represent bytes. The bytes passed in will be
- // copied.
- ///
- void function (
- _cef_post_data_element_t* self,
- size_t size,
- const(void)* bytes) nothrow set_to_bytes;
-
- ///
- // Return the type of this post data element.
- ///
- cef_postdataelement_type_t function (
- _cef_post_data_element_t* self) nothrow get_type;
-
- ///
- // Return the file name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_post_data_element_t* self) nothrow get_file;
-
- ///
- // Return the number of bytes.
- ///
- size_t function (_cef_post_data_element_t* self) nothrow get_bytes_count;
-
- ///
- // Read up to |size| bytes into |bytes| and return the number of bytes
- // actually read.
- ///
- size_t function (
- _cef_post_data_element_t* self,
- size_t size,
- void* bytes) nothrow get_bytes;
-}
-
-alias cef_post_data_element_t = _cef_post_data_element_t;
-
-///
-// Create a new cef_post_data_element_t object.
-///
-cef_post_data_element_t* cef_post_data_element_create ();
-
-// CEF_INCLUDE_CAPI_CEF_REQUEST_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=e758d8c53334b91bce818cc6e9f84915778d7827$
-//
-
-extern (C):
-
-///
-// Implement this structure to provide handler implementations. The handler
-// instance will not be released until all objects related to the context have
-// been destroyed.
-///
-struct _cef_request_context_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the browser process UI thread immediately after the request
- // context has been initialized.
- ///
- void function (
- _cef_request_context_handler_t* self,
- _cef_request_context_t* request_context) nothrow on_request_context_initialized;
-
- ///
- // Called on multiple browser process threads before a plugin instance is
- // loaded. |mime_type| is the mime type of the plugin that will be loaded.
- // |plugin_url| is the content URL that the plugin will load and may be NULL.
- // |is_main_frame| will be true (1) if the plugin is being loaded in the main
- // (top-level) frame, |top_origin_url| is the URL for the top-level frame that
- // contains the plugin when loading a specific plugin instance or NULL when
- // building the initial list of enabled plugins for 'navigator.plugins'
- // JavaScript state. |plugin_info| includes additional information about the
- // plugin that will be loaded. |plugin_policy| is the recommended policy.
- // Modify |plugin_policy| and return true (1) to change the policy. Return
- // false (0) to use the recommended policy. The default plugin policy can be
- // set at runtime using the `--plugin-policy=[allow|detect|block]` command-
- // line flag. Decisions to mark a plugin as disabled by setting
- // |plugin_policy| to PLUGIN_POLICY_DISABLED may be cached when
- // |top_origin_url| is NULL. To purge the plugin list cache and potentially
- // trigger new calls to this function call
- // cef_request_context_t::PurgePluginListCache.
- ///
- int function (
- _cef_request_context_handler_t* self,
- const(cef_string_t)* mime_type,
- const(cef_string_t)* plugin_url,
- int is_main_frame,
- const(cef_string_t)* top_origin_url,
- _cef_web_plugin_info_t* plugin_info,
- cef_plugin_policy_t* plugin_policy) nothrow on_before_plugin_load;
-
- ///
- // Called on the browser process IO thread before a resource request is
- // initiated. The |browser| and |frame| values represent the source of the
- // request, and may be NULL for requests originating from service workers or
- // cef_urlrequest_t. |request| represents the request contents and cannot be
- // modified in this callback. |is_navigation| will be true (1) if the resource
- // request is a navigation. |is_download| will be true (1) if the resource
- // request is a download. |request_initiator| is the origin (scheme + domain)
- // of the page that initiated the request. Set |disable_default_handling| to
- // true (1) to disable default handling of the request, in which case it will
- // need to be handled via cef_resource_request_handler_t::GetResourceHandler
- // or it will be canceled. To allow the resource load to proceed with default
- // handling return NULL. To specify a handler for the resource return a
- // cef_resource_request_handler_t object. This function will not be called if
- // the client associated with |browser| returns a non-NULL value from
- // cef_request_handler_t::GetResourceRequestHandler for the same request
- // (identified by cef_request_t::GetIdentifier).
- ///
- _cef_resource_request_handler_t* function (
- _cef_request_context_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- int is_navigation,
- int is_download,
- const(cef_string_t)* request_initiator,
- int* disable_default_handling) nothrow get_resource_request_handler;
-}
-
-alias cef_request_context_handler_t = _cef_request_context_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=0167eb1abe614bd6391d273a8085fa3e53e7c217$
-//
-
-extern (C):
-
-///
-// Callback structure used to select a client certificate for authentication.
-///
-struct _cef_select_client_certificate_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Chooses the specified certificate for client certificate authentication.
- // NULL value means that no client certificate should be used.
- ///
- void function (
- _cef_select_client_certificate_callback_t* self,
- _cef_x509certificate_t* cert) nothrow select;
-}
-
-alias cef_select_client_certificate_callback_t = _cef_select_client_certificate_callback_t;
-
-///
-// Implement this structure to handle events related to browser requests. The
-// functions of this structure will be called on the thread indicated.
-///
-struct _cef_request_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the UI thread before browser navigation. Return true (1) to
- // cancel the navigation or false (0) to allow the navigation to proceed. The
- // |request| object cannot be modified in this callback.
- // cef_load_handler_t::OnLoadingStateChange will be called twice in all cases.
- // If the navigation is allowed cef_load_handler_t::OnLoadStart and
- // cef_load_handler_t::OnLoadEnd will be called. If the navigation is canceled
- // cef_load_handler_t::OnLoadError will be called with an |errorCode| value of
- // ERR_ABORTED. The |user_gesture| value will be true (1) if the browser
- // navigated via explicit user gesture (e.g. clicking a link) or false (0) if
- // it navigated automatically (e.g. via the DomContentLoaded event).
- ///
- int function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- int user_gesture,
- int is_redirect) nothrow on_before_browse;
-
- ///
- // Called on the UI thread before OnBeforeBrowse in certain limited cases
- // where navigating a new or different browser might be desirable. This
- // includes user-initiated navigation that might open in a special way (e.g.
- // links clicked via middle-click or ctrl + left-click) and certain types of
- // cross-origin navigation initiated from the renderer process (e.g.
- // navigating the top-level frame to/from a file URL). The |browser| and
- // |frame| values represent the source of the navigation. The
- // |target_disposition| value indicates where the user intended to navigate
- // the browser based on standard Chromium behaviors (e.g. current tab, new
- // tab, etc). The |user_gesture| value will be true (1) if the browser
- // navigated via explicit user gesture (e.g. clicking a link) or false (0) if
- // it navigated automatically (e.g. via the DomContentLoaded event). Return
- // true (1) to cancel the navigation or false (0) to allow the navigation to
- // proceed in the source browser's top-level frame.
- ///
- int function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- const(cef_string_t)* target_url,
- cef_window_open_disposition_t target_disposition,
- int user_gesture) nothrow on_open_urlfrom_tab;
-
- ///
- // Called on the browser process IO thread before a resource request is
- // initiated. The |browser| and |frame| values represent the source of the
- // request. |request| represents the request contents and cannot be modified
- // in this callback. |is_navigation| will be true (1) if the resource request
- // is a navigation. |is_download| will be true (1) if the resource request is
- // a download. |request_initiator| is the origin (scheme + domain) of the page
- // that initiated the request. Set |disable_default_handling| to true (1) to
- // disable default handling of the request, in which case it will need to be
- // handled via cef_resource_request_handler_t::GetResourceHandler or it will
- // be canceled. To allow the resource load to proceed with default handling
- // return NULL. To specify a handler for the resource return a
- // cef_resource_request_handler_t object. If this callback returns NULL the
- // same function will be called on the associated
- // cef_request_context_handler_t, if any.
- ///
- _cef_resource_request_handler_t* function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- int is_navigation,
- int is_download,
- const(cef_string_t)* request_initiator,
- int* disable_default_handling) nothrow get_resource_request_handler;
-
- ///
- // Called on the IO thread when the browser needs credentials from the user.
- // |origin_url| is the origin making this authentication request. |isProxy|
- // indicates whether the host is a proxy server. |host| contains the hostname
- // and |port| contains the port number. |realm| is the realm of the challenge
- // and may be NULL. |scheme| is the authentication scheme used, such as
- // "basic" or "digest", and will be NULL if the source of the request is an
- // FTP server. Return true (1) to continue the request and call
- // cef_auth_callback_t::cont() either in this function or at a later time when
- // the authentication information is available. Return false (0) to cancel the
- // request immediately.
- ///
- int function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* origin_url,
- int isProxy,
- const(cef_string_t)* host,
- int port,
- const(cef_string_t)* realm,
- const(cef_string_t)* scheme,
- _cef_auth_callback_t* callback) nothrow get_auth_credentials;
-
- ///
- // Called on the IO thread when JavaScript requests a specific storage quota
- // size via the webkitStorageInfo.requestQuota function. |origin_url| is the
- // origin of the page making the request. |new_size| is the requested quota
- // size in bytes. Return true (1) to continue the request and call
- // cef_request_callback_t::cont() either in this function or at a later time
- // to grant or deny the request. Return false (0) to cancel the request
- // immediately.
- ///
- int function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* origin_url,
- int64 new_size,
- _cef_request_callback_t* callback) nothrow on_quota_request;
-
- ///
- // Called on the UI thread to handle requests for URLs with an invalid SSL
- // certificate. Return true (1) and call cef_request_callback_t::cont() either
- // in this function or at a later time to continue or cancel the request.
- // Return false (0) to cancel the request immediately. If
- // CefSettings.ignore_certificate_errors is set all invalid certificates will
- // be accepted without calling this function.
- ///
- int function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- cef_errorcode_t cert_error,
- const(cef_string_t)* request_url,
- _cef_sslinfo_t* ssl_info,
- _cef_request_callback_t* callback) nothrow on_certificate_error;
-
- ///
- // Called on the UI thread when a client certificate is being requested for
- // authentication. Return false (0) to use the default behavior and
- // automatically select the first certificate available. Return true (1) and
- // call cef_select_client_certificate_callback_t::Select either in this
- // function or at a later time to select a certificate. Do not call Select or
- // call it with NULL to continue without using any certificate. |isProxy|
- // indicates whether the host is an HTTPS proxy or the origin server. |host|
- // and |port| contains the hostname and port of the SSL server. |certificates|
- // is the list of certificates to choose from; this list has already been
- // pruned by Chromium so that it only contains certificates from issuers that
- // the server trusts.
- ///
- int function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- int isProxy,
- const(cef_string_t)* host,
- int port,
- size_t certificatesCount,
- _cef_x509certificate_t** certificates,
- _cef_select_client_certificate_callback_t* callback) nothrow on_select_client_certificate;
-
- ///
- // Called on the browser process UI thread when a plugin has crashed.
- // |plugin_path| is the path of the plugin that crashed.
- ///
- void function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- const(cef_string_t)* plugin_path) nothrow on_plugin_crashed;
-
- ///
- // Called on the browser process UI thread when the render view associated
- // with |browser| is ready to receive/handle IPC messages in the render
- // process.
- ///
- void function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser) nothrow on_render_view_ready;
-
- ///
- // Called on the browser process UI thread when the render process terminates
- // unexpectedly. |status| indicates how the process terminated.
- ///
- void function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser,
- cef_termination_status_t status) nothrow on_render_process_terminated;
-
- ///
- // Called on the browser process UI thread when the window.document object of
- // the main frame has been created.
- ///
- void function (
- _cef_request_handler_t* self,
- _cef_browser_t* browser) nothrow on_document_available_in_main_frame;
-}
-
-alias cef_request_handler_t = _cef_request_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_REQUEST_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=b0e2b63b467c6d4e990405d948908da3546ea1c7$
-//
-
-extern (C):
-
-///
-// Structure used for retrieving resources from the resource bundle (*.pak)
-// files loaded by CEF during startup or via the cef_resource_bundle_handler_t
-// returned from cef_app_t::GetResourceBundleHandler. See CefSettings for
-// additional options related to resource bundle loading. The functions of this
-// structure may be called on any thread unless otherwise indicated.
-///
-struct _cef_resource_bundle_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the localized string for the specified |string_id| or an NULL
- // string if the value is not found. Include cef_pack_strings.h for a listing
- // of valid string ID values.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_resource_bundle_t* self,
- int string_id) nothrow get_localized_string;
-
- ///
- // Returns a cef_binary_value_t containing the decompressed contents of the
- // specified scale independent |resource_id| or NULL if not found. Include
- // cef_pack_resources.h for a listing of valid resource ID values.
- ///
- _cef_binary_value_t* function (
- _cef_resource_bundle_t* self,
- int resource_id) nothrow get_data_resource;
-
- ///
- // Returns a cef_binary_value_t containing the decompressed contents of the
- // specified |resource_id| nearest the scale factor |scale_factor| or NULL if
- // not found. Use a |scale_factor| value of SCALE_FACTOR_NONE for scale
- // independent resources or call GetDataResource instead.Include
- // cef_pack_resources.h for a listing of valid resource ID values.
- ///
- _cef_binary_value_t* function (
- _cef_resource_bundle_t* self,
- int resource_id,
- cef_scale_factor_t scale_factor) nothrow get_data_resource_for_scale;
-}
-
-alias cef_resource_bundle_t = _cef_resource_bundle_t;
-
-///
-// Returns the global resource bundle instance.
-///
-cef_resource_bundle_t* cef_resource_bundle_get_global ();
-
-// CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=fd90a707c59a8c04b1b1bfc6129a90e27934f501$
-//
-
-extern (C):
-
-///
-// Structure used to implement a custom resource bundle structure. See
-// CefSettings for additional options related to resource bundle loading. The
-// functions of this structure may be called on multiple threads.
-///
-struct _cef_resource_bundle_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called to retrieve a localized translation for the specified |string_id|.
- // To provide the translation set |string| to the translation string and
- // return true (1). To use the default translation return false (0). Include
- // cef_pack_strings.h for a listing of valid string ID values.
- ///
- int function (
- _cef_resource_bundle_handler_t* self,
- int string_id,
- cef_string_t* string) nothrow get_localized_string;
-
- ///
- // Called to retrieve data for the specified scale independent |resource_id|.
- // To provide the resource data set |data| and |data_size| to the data pointer
- // and size respectively and return true (1). To use the default resource data
- // return false (0). The resource data will not be copied and must remain
- // resident in memory. Include cef_pack_resources.h for a listing of valid
- // resource ID values.
- ///
- int function (
- _cef_resource_bundle_handler_t* self,
- int resource_id,
- void** data,
- size_t* data_size) nothrow get_data_resource;
-
- ///
- // Called to retrieve data for the specified |resource_id| nearest the scale
- // factor |scale_factor|. To provide the resource data set |data| and
- // |data_size| to the data pointer and size respectively and return true (1).
- // To use the default resource data return false (0). The resource data will
- // not be copied and must remain resident in memory. Include
- // cef_pack_resources.h for a listing of valid resource ID values.
- ///
- int function (
- _cef_resource_bundle_handler_t* self,
- int resource_id,
- cef_scale_factor_t scale_factor,
- void** data,
- size_t* data_size) nothrow get_data_resource_for_scale;
-}
-
-alias cef_resource_bundle_handler_t = _cef_resource_bundle_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=5241e3dd5d3fa0b17dd6d6ea2f30734a32150c88$
-//
-
-extern (C):
-
-///
-// Callback for asynchronous continuation of cef_resource_handler_t::skip().
-///
-struct _cef_resource_skip_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Callback for asynchronous continuation of skip(). If |bytes_skipped| > 0
- // then either skip() will be called again until the requested number of bytes
- // have been skipped or the request will proceed. If |bytes_skipped| <= 0 the
- // request will fail with ERR_REQUEST_RANGE_NOT_SATISFIABLE.
- ///
- void function (
- _cef_resource_skip_callback_t* self,
- int64 bytes_skipped) nothrow cont;
-}
-
-alias cef_resource_skip_callback_t = _cef_resource_skip_callback_t;
-
-///
-// Callback for asynchronous continuation of cef_resource_handler_t::read().
-///
-struct _cef_resource_read_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Callback for asynchronous continuation of read(). If |bytes_read| == 0 the
- // response will be considered complete. If |bytes_read| > 0 then read() will
- // be called again until the request is complete (based on either the result
- // or the expected content length). If |bytes_read| < 0 then the request will
- // fail and the |bytes_read| value will be treated as the error code.
- ///
- void function (_cef_resource_read_callback_t* self, int bytes_read) nothrow cont;
-}
-
-alias cef_resource_read_callback_t = _cef_resource_read_callback_t;
-
-///
-// Structure used to implement a custom request handler structure. The functions
-// of this structure will be called on the IO thread unless otherwise indicated.
-///
-struct _cef_resource_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Open the response stream. To handle the request immediately set
- // |handle_request| to true (1) and return true (1). To decide at a later time
- // set |handle_request| to false (0), return true (1), and execute |callback|
- // to continue or cancel the request. To cancel the request immediately set
- // |handle_request| to true (1) and return false (0). This function will be
- // called in sequence but not from a dedicated thread. For backwards
- // compatibility set |handle_request| to false (0) and return false (0) and
- // the ProcessRequest function will be called.
- ///
- int function (
- _cef_resource_handler_t* self,
- _cef_request_t* request,
- int* handle_request,
- _cef_callback_t* callback) nothrow open;
-
- ///
- // Begin processing the request. To handle the request return true (1) and
- // call cef_callback_t::cont() once the response header information is
- // available (cef_callback_t::cont() can also be called from inside this
- // function if header information is available immediately). To cancel the
- // request return false (0).
- //
- // WARNING: This function is deprecated. Use Open instead.
- ///
- int function (
- _cef_resource_handler_t* self,
- _cef_request_t* request,
- _cef_callback_t* callback) nothrow process_request;
-
- ///
- // Retrieve response header information. If the response length is not known
- // set |response_length| to -1 and read_response() will be called until it
- // returns false (0). If the response length is known set |response_length| to
- // a positive value and read_response() will be called until it returns false
- // (0) or the specified number of bytes have been read. Use the |response|
- // object to set the mime type, http status code and other optional header
- // values. To redirect the request to a new URL set |redirectUrl| to the new
- // URL. |redirectUrl| can be either a relative or fully qualified URL. It is
- // also possible to set |response| to a redirect http status code and pass the
- // new URL via a Location header. Likewise with |redirectUrl| it is valid to
- // set a relative or fully qualified URL as the Location header value. If an
- // error occured while setting up the request you can call set_error() on
- // |response| to indicate the error condition.
- ///
- void function (
- _cef_resource_handler_t* self,
- _cef_response_t* response,
- int64* response_length,
- cef_string_t* redirectUrl) nothrow get_response_headers;
-
- ///
- // Skip response data when requested by a Range header. Skip over and discard
- // |bytes_to_skip| bytes of response data. If data is available immediately
- // set |bytes_skipped| to the number of bytes skipped and return true (1). To
- // read the data at a later time set |bytes_skipped| to 0, return true (1) and
- // execute |callback| when the data is available. To indicate failure set
- // |bytes_skipped| to < 0 (e.g. -2 for ERR_FAILED) and return false (0). This
- // function will be called in sequence but not from a dedicated thread.
- ///
- int function (
- _cef_resource_handler_t* self,
- int64 bytes_to_skip,
- int64* bytes_skipped,
- _cef_resource_skip_callback_t* callback) nothrow skip;
-
- ///
- // Read response data. If data is available immediately copy up to
- // |bytes_to_read| bytes into |data_out|, set |bytes_read| to the number of
- // bytes copied, and return true (1). To read the data at a later time keep a
- // pointer to |data_out|, set |bytes_read| to 0, return true (1) and execute
- // |callback| when the data is available (|data_out| will remain valid until
- // the callback is executed). To indicate response completion set |bytes_read|
- // to 0 and return false (0). To indicate failure set |bytes_read| to < 0
- // (e.g. -2 for ERR_FAILED) and return false (0). This function will be called
- // in sequence but not from a dedicated thread. For backwards compatibility
- // set |bytes_read| to -1 and return false (0) and the ReadResponse function
- // will be called.
- ///
- int function (
- _cef_resource_handler_t* self,
- void* data_out,
- int bytes_to_read,
- int* bytes_read,
- _cef_resource_read_callback_t* callback) nothrow read;
-
- ///
- // Read response data. If data is available immediately copy up to
- // |bytes_to_read| bytes into |data_out|, set |bytes_read| to the number of
- // bytes copied, and return true (1). To read the data at a later time set
- // |bytes_read| to 0, return true (1) and call cef_callback_t::cont() when the
- // data is available. To indicate response completion return false (0).
- //
- // WARNING: This function is deprecated. Use Skip and Read instead.
- ///
- int function (
- _cef_resource_handler_t* self,
- void* data_out,
- int bytes_to_read,
- int* bytes_read,
- _cef_callback_t* callback) nothrow read_response;
-
- ///
- // Request processing has been canceled.
- ///
- void function (_cef_resource_handler_t* self) nothrow cancel;
-}
-
-alias cef_resource_handler_t = _cef_resource_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_RESOURCE_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=afc96f188710bd336d09ce479a650aaa3a55357a$
-//
-
-extern (C):
-
-///
-// Implement this structure to handle events related to browser requests. The
-// functions of this structure will be called on the IO thread unless otherwise
-// indicated.
-///
-struct _cef_resource_request_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the IO thread before a resource request is loaded. The |browser|
- // and |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. To
- // optionally filter cookies for the request return a
- // cef_cookie_access_filter_t object. The |request| object cannot not be
- // modified in this callback.
- ///
- _cef_cookie_access_filter_t* function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request) nothrow get_cookie_access_filter;
-
- ///
- // Called on the IO thread before a resource request is loaded. The |browser|
- // and |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. To redirect
- // or change the resource load optionally modify |request|. Modification of
- // the request URL will be treated as a redirect. Return RV_CONTINUE to
- // continue the request immediately. Return RV_CONTINUE_ASYNC and call
- // cef_request_callback_t:: cont() at a later time to continue or cancel the
- // request asynchronously. Return RV_CANCEL to cancel the request immediately.
- //
- ///
- cef_return_value_t function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- _cef_request_callback_t* callback) nothrow on_before_resource_load;
-
- ///
- // Called on the IO thread before a resource is loaded. The |browser| and
- // |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. To allow the
- // resource to load using the default network loader return NULL. To specify a
- // handler for the resource return a cef_resource_handler_t object. The
- // |request| object cannot not be modified in this callback.
- ///
- _cef_resource_handler_t* function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request) nothrow get_resource_handler;
-
- ///
- // Called on the IO thread when a resource load is redirected. The |browser|
- // and |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. The
- // |request| parameter will contain the old URL and other request-related
- // information. The |response| parameter will contain the response that
- // resulted in the redirect. The |new_url| parameter will contain the new URL
- // and can be changed if desired. The |request| and |response| objects cannot
- // be modified in this callback.
- ///
- void function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- _cef_response_t* response,
- cef_string_t* new_url) nothrow on_resource_redirect;
-
- ///
- // Called on the IO thread when a resource response is received. The |browser|
- // and |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. To allow the
- // resource load to proceed without modification return false (0). To redirect
- // or retry the resource load optionally modify |request| and return true (1).
- // Modification of the request URL will be treated as a redirect. Requests
- // handled using the default network loader cannot be redirected in this
- // callback. The |response| object cannot be modified in this callback.
- //
- // WARNING: Redirecting using this function is deprecated. Use
- // OnBeforeResourceLoad or GetResourceHandler to perform redirects.
- ///
- int function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- _cef_response_t* response) nothrow on_resource_response;
-
- ///
- // Called on the IO thread to optionally filter resource response content. The
- // |browser| and |frame| values represent the source of the request, and may
- // be NULL for requests originating from service workers or cef_urlrequest_t.
- // |request| and |response| represent the request and response respectively
- // and cannot be modified in this callback.
- ///
- _cef_response_filter_t* function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- _cef_response_t* response) nothrow get_resource_response_filter;
-
- ///
- // Called on the IO thread when a resource load has completed. The |browser|
- // and |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. |request|
- // and |response| represent the request and response respectively and cannot
- // be modified in this callback. |status| indicates the load completion
- // status. |received_content_length| is the number of response bytes actually
- // read. This function will be called for all requests, including requests
- // that are aborted due to CEF shutdown or destruction of the associated
- // browser. In cases where the associated browser is destroyed this callback
- // may arrive after the cef_life_span_handler_t::OnBeforeClose callback for
- // that browser. The cef_frame_t::IsValid function can be used to test for
- // this situation, and care should be taken not to call |browser| or |frame|
- // functions that modify state (like LoadURL, SendProcessMessage, etc.) if the
- // frame is invalid.
- ///
- void function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- _cef_response_t* response,
- cef_urlrequest_status_t status,
- int64 received_content_length) nothrow on_resource_load_complete;
-
- ///
- // Called on the IO thread to handle requests for URLs with an unknown
- // protocol component. The |browser| and |frame| values represent the source
- // of the request, and may be NULL for requests originating from service
- // workers or cef_urlrequest_t. |request| cannot be modified in this callback.
- // Set |allow_os_execution| to true (1) to attempt execution via the
- // registered OS protocol handler, if any. SECURITY WARNING: YOU SHOULD USE
- // THIS METHOD TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR OTHER URL
- // ANALYSIS BEFORE ALLOWING OS EXECUTION.
- ///
- void function (
- _cef_resource_request_handler_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- int* allow_os_execution) nothrow on_protocol_execution;
-}
-
-alias cef_resource_request_handler_t = _cef_resource_request_handler_t;
-
-///
-// Implement this structure to filter cookies that may be sent or received from
-// resource requests. The functions of this structure will be called on the IO
-// thread unless otherwise indicated.
-///
-struct _cef_cookie_access_filter_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called on the IO thread before a resource request is sent. The |browser|
- // and |frame| values represent the source of the request, and may be NULL for
- // requests originating from service workers or cef_urlrequest_t. |request|
- // cannot be modified in this callback. Return true (1) if the specified
- // cookie can be sent with the request or false (0) otherwise.
- ///
- int function (
- _cef_cookie_access_filter_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- const(_cef_cookie_t)* cookie) nothrow can_send_cookie;
-
- ///
- // Called on the IO thread after a resource response is received. The
- // |browser| and |frame| values represent the source of the request, and may
- // be NULL for requests originating from service workers or cef_urlrequest_t.
- // |request| cannot be modified in this callback. Return true (1) if the
- // specified cookie returned with the response can be saved or false (0)
- // otherwise.
- ///
- int function (
- _cef_cookie_access_filter_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- _cef_request_t* request,
- _cef_response_t* response,
- const(_cef_cookie_t)* cookie) nothrow can_save_cookie;
-}
-
-alias cef_cookie_access_filter_t = _cef_cookie_access_filter_t;
-
-// CEF_INCLUDE_CAPI_CEF_RESOURCE_REQUEST_HANDLER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=2bccae35945ecea55c4c79bba840b44a691f1aa3$
-//
-
-extern (C):
-
-///
-// Structure used to represent a web response. The functions of this structure
-// may be called on any thread.
-///
-struct _cef_response_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is read-only.
- ///
- int function (_cef_response_t* self) nothrow is_read_only;
-
- ///
- // Get the response error code. Returns ERR_NONE if there was no error.
- ///
- cef_errorcode_t function (_cef_response_t* self) nothrow get_error;
-
- ///
- // Set the response error code. This can be used by custom scheme handlers to
- // return errors during initial request processing.
- ///
- void function (_cef_response_t* self, cef_errorcode_t error) nothrow set_error;
-
- ///
- // Get the response status code.
- ///
- int function (_cef_response_t* self) nothrow get_status;
-
- ///
- // Set the response status code.
- ///
- void function (_cef_response_t* self, int status) nothrow set_status;
-
- ///
- // Get the response status text.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_response_t* self) nothrow get_status_text;
-
- ///
- // Set the response status text.
- ///
- void function (
- _cef_response_t* self,
- const(cef_string_t)* statusText) nothrow set_status_text;
-
- ///
- // Get the response mime type.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_response_t* self) nothrow get_mime_type;
-
- ///
- // Set the response mime type.
- ///
- void function (
- _cef_response_t* self,
- const(cef_string_t)* mimeType) nothrow set_mime_type;
-
- ///
- // Get the response charset.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_response_t* self) nothrow get_charset;
-
- ///
- // Set the response charset.
- ///
- void function (
- _cef_response_t* self,
- const(cef_string_t)* charset) nothrow set_charset;
-
- ///
- // Get the value for the specified response header field.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_response_t* self,
- const(cef_string_t)* name) nothrow get_header_by_name;
-
- ///
- // Set the header |name| to |value|. If |overwrite| is true (1) any existing
- // values will be replaced with the new value. If |overwrite| is false (0) any
- // existing values will not be overwritten.
- ///
- void function (
- _cef_response_t* self,
- const(cef_string_t)* name,
- const(cef_string_t)* value,
- int overwrite) nothrow set_header_by_name;
-
- ///
- // Get all response header fields.
- ///
- void function (
- _cef_response_t* self,
- cef_string_multimap_t headerMap) nothrow get_header_map;
-
- ///
- // Set all response header fields.
- ///
- void function (
- _cef_response_t* self,
- cef_string_multimap_t headerMap) nothrow set_header_map;
-
- ///
- // Get the resolved URL after redirects or changed as a result of HSTS.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_response_t* self) nothrow get_url;
-
- ///
- // Set the resolved URL after redirects or changed as a result of HSTS.
- ///
- void function (_cef_response_t* self, const(cef_string_t)* url) nothrow set_url;
-}
-
-alias cef_response_t = _cef_response_t;
-
-///
-// Create a new cef_response_t object.
-///
-cef_response_t* cef_response_create ();
-
-// CEF_INCLUDE_CAPI_CEF_RESPONSE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=5b2602702a13a71ac012808eecb09bb8b9494551$
-//
-
-extern (C):
-
-///
-// Implement this structure to filter resource response content. The functions
-// of this structure will be called on the browser process IO thread.
-///
-struct _cef_response_filter_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Initialize the response filter. Will only be called a single time. The
- // filter will not be installed if this function returns false (0).
- ///
- int function (_cef_response_filter_t* self) nothrow init_filter;
-
- ///
- // Called to filter a chunk of data. Expected usage is as follows:
- //
- // A. Read input data from |data_in| and set |data_in_read| to the number of
- // bytes that were read up to a maximum of |data_in_size|. |data_in| will
- // be NULL if |data_in_size| is zero.
- // B. Write filtered output data to |data_out| and set |data_out_written| to
- // the number of bytes that were written up to a maximum of
- // |data_out_size|. If no output data was written then all data must be
- // read from |data_in| (user must set |data_in_read| = |data_in_size|).
- // C. Return RESPONSE_FILTER_DONE if all output data was written or
- // RESPONSE_FILTER_NEED_MORE_DATA if output data is still pending.
- //
- // This function will be called repeatedly until the input buffer has been
- // fully read (user sets |data_in_read| = |data_in_size|) and there is no more
- // input data to filter (the resource response is complete). This function may
- // then be called an additional time with an NULL input buffer if the user
- // filled the output buffer (set |data_out_written| = |data_out_size|) and
- // returned RESPONSE_FILTER_NEED_MORE_DATA to indicate that output data is
- // still pending.
- //
- // Calls to this function will stop when one of the following conditions is
- // met:
- //
- // A. There is no more input data to filter (the resource response is
- // complete) and the user sets |data_out_written| = 0 or returns
- // RESPONSE_FILTER_DONE to indicate that all data has been written, or;
- // B. The user returns RESPONSE_FILTER_ERROR to indicate an error.
- //
- // Do not keep a reference to the buffers passed to this function.
- ///
- cef_response_filter_status_t function (
- _cef_response_filter_t* self,
- void* data_in,
- size_t data_in_size,
- size_t* data_in_read,
- void* data_out,
- size_t data_out_size,
- size_t* data_out_written) nothrow filter;
-}
-
-alias cef_response_filter_t = _cef_response_filter_t;
-
-// CEF_INCLUDE_CAPI_CEF_RESPONSE_FILTER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=d93b4ad0b71ffe0a05326b39c3ed0bdb26a73fac$
-//
-
-extern (C):
-
-///
-// Structure that manages custom scheme registrations.
-///
-struct _cef_scheme_registrar_t
-{
- ///
- // Base structure.
- ///
- cef_base_scoped_t base;
-
- ///
- // Register a custom scheme. This function should not be called for the built-
- // in HTTP, HTTPS, FILE, FTP, ABOUT and DATA schemes.
- //
- // See cef_scheme_options_t for possible values for |options|.
- //
- // This function may be called on any thread. It should only be called once
- // per unique |scheme_name| value. If |scheme_name| is already registered or
- // if an error occurs this function will return false (0).
- ///
- int function (
- _cef_scheme_registrar_t* self,
- const(cef_string_t)* scheme_name,
- int options) nothrow add_custom_scheme;
-}
-
-alias cef_scheme_registrar_t = _cef_scheme_registrar_t;
-
-///
-// Structure that creates cef_resource_handler_t instances for handling scheme
-// requests. The functions of this structure will always be called on the IO
-// thread.
-///
-struct _cef_scheme_handler_factory_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Return a new resource handler instance to handle the request or an NULL
- // reference to allow default handling of the request. |browser| and |frame|
- // will be the browser window and frame respectively that originated the
- // request or NULL if the request did not originate from a browser window (for
- // example, if the request came from cef_urlrequest_t). The |request| object
- // passed to this function cannot be modified.
- ///
- _cef_resource_handler_t* function (
- _cef_scheme_handler_factory_t* self,
- _cef_browser_t* browser,
- _cef_frame_t* frame,
- const(cef_string_t)* scheme_name,
- _cef_request_t* request) nothrow create;
-}
-
-alias cef_scheme_handler_factory_t = _cef_scheme_handler_factory_t;
-
-///
-// Register a scheme handler factory with the global request context. An NULL
-// |domain_name| value for a standard scheme will cause the factory to match all
-// domain names. The |domain_name| value will be ignored for non-standard
-// schemes. If |scheme_name| is a built-in scheme and no handler is returned by
-// |factory| then the built-in scheme handler factory will be called. If
-// |scheme_name| is a custom scheme then you must also implement the
-// cef_app_t::on_register_custom_schemes() function in all processes. This
-// function may be called multiple times to change or remove the factory that
-// matches the specified |scheme_name| and optional |domain_name|. Returns false
-// (0) if an error occurs. This function may be called on any thread in the
-// browser process. Using this function is equivalent to calling cef_request_con
-// text_t::cef_request_context_get_global_context()->register_scheme_handler_fac
-// tory().
-///
-int cef_register_scheme_handler_factory (
- const(cef_string_t)* scheme_name,
- const(cef_string_t)* domain_name,
- cef_scheme_handler_factory_t* factory);
-
-///
-// Clear all scheme handler factories registered with the global request
-// context. Returns false (0) on error. This function may be called on any
-// thread in the browser process. Using this function is equivalent to calling c
-// ef_request_context_t::cef_request_context_get_global_context()->clear_scheme_
-// handler_factories().
-///
-int cef_clear_scheme_handler_factories ();
-
-// CEF_INCLUDE_CAPI_CEF_SCHEME_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=ffd489adc301ed88e1f30f8f38cec1730411a4b5$
-//
-
-extern (C):
-
-///
-// Structure representing a server that supports HTTP and WebSocket requests.
-// Server capacity is limited and is intended to handle only a small number of
-// simultaneous connections (e.g. for communicating between applications on
-// localhost). The functions of this structure are safe to call from any thread
-// in the brower process unless otherwise indicated.
-///
-struct _cef_server_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the task runner for the dedicated server thread.
- ///
- _cef_task_runner_t* function (_cef_server_t* self) nothrow get_task_runner;
-
- ///
- // Stop the server and shut down the dedicated server thread. See
- // cef_server_handler_t::OnServerCreated documentation for a description of
- // server lifespan.
- ///
- void function (_cef_server_t* self) nothrow shutdown;
-
- ///
- // Returns true (1) if the server is currently running and accepting incoming
- // connections. See cef_server_handler_t::OnServerCreated documentation for a
- // description of server lifespan. This function must be called on the
- // dedicated server thread.
- ///
- int function (_cef_server_t* self) nothrow is_running;
-
- ///
- // Returns the server address including the port number.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_server_t* self) nothrow get_address;
-
- ///
- // Returns true (1) if the server currently has a connection. This function
- // must be called on the dedicated server thread.
- ///
- int function (_cef_server_t* self) nothrow has_connection;
-
- ///
- // Returns true (1) if |connection_id| represents a valid connection. This
- // function must be called on the dedicated server thread.
- ///
- int function (_cef_server_t* self, int connection_id) nothrow is_valid_connection;
-
- ///
- // Send an HTTP 200 "OK" response to the connection identified by
- // |connection_id|. |content_type| is the response content type (e.g.
- // "text/html"), |data| is the response content, and |data_size| is the size
- // of |data| in bytes. The contents of |data| will be copied. The connection
- // will be closed automatically after the response is sent.
- ///
- void function (
- _cef_server_t* self,
- int connection_id,
- const(cef_string_t)* content_type,
- const(void)* data,
- size_t data_size) nothrow send_http200response;
-
- ///
- // Send an HTTP 404 "Not Found" response to the connection identified by
- // |connection_id|. The connection will be closed automatically after the
- // response is sent.
- ///
- void function (
- _cef_server_t* self,
- int connection_id) nothrow send_http404response;
-
- ///
- // Send an HTTP 500 "Internal Server Error" response to the connection
- // identified by |connection_id|. |error_message| is the associated error
- // message. The connection will be closed automatically after the response is
- // sent.
- ///
- void function (
- _cef_server_t* self,
- int connection_id,
- const(cef_string_t)* error_message) nothrow send_http500response;
-
- ///
- // Send a custom HTTP response to the connection identified by
- // |connection_id|. |response_code| is the HTTP response code sent in the
- // status line (e.g. 200), |content_type| is the response content type sent as
- // the "Content-Type" header (e.g. "text/html"), |content_length| is the
- // expected content length, and |extra_headers| is the map of extra response
- // headers. If |content_length| is >= 0 then the "Content-Length" header will
- // be sent. If |content_length| is 0 then no content is expected and the
- // connection will be closed automatically after the response is sent. If
- // |content_length| is < 0 then no "Content-Length" header will be sent and
- // the client will continue reading until the connection is closed. Use the
- // SendRawData function to send the content, if applicable, and call
- // CloseConnection after all content has been sent.
- ///
- void function (
- _cef_server_t* self,
- int connection_id,
- int response_code,
- const(cef_string_t)* content_type,
- int64 content_length,
- cef_string_multimap_t extra_headers) nothrow send_http_response;
-
- ///
- // Send raw data directly to the connection identified by |connection_id|.
- // |data| is the raw data and |data_size| is the size of |data| in bytes. The
- // contents of |data| will be copied. No validation of |data| is performed
- // internally so the client should be careful to send the amount indicated by
- // the "Content-Length" header, if specified. See SendHttpResponse
- // documentation for intended usage.
- ///
- void function (
- _cef_server_t* self,
- int connection_id,
- const(void)* data,
- size_t data_size) nothrow send_raw_data;
-
- ///
- // Close the connection identified by |connection_id|. See SendHttpResponse
- // documentation for intended usage.
- ///
- void function (_cef_server_t* self, int connection_id) nothrow close_connection;
-
- ///
- // Send a WebSocket message to the connection identified by |connection_id|.
- // |data| is the response content and |data_size| is the size of |data| in
- // bytes. The contents of |data| will be copied. See
- // cef_server_handler_t::OnWebSocketRequest documentation for intended usage.
- ///
- void function (
- _cef_server_t* self,
- int connection_id,
- const(void)* data,
- size_t data_size) nothrow send_web_socket_message;
-}
-
-alias cef_server_t = _cef_server_t;
-
-///
-// Create a new server that binds to |address| and |port|. |address| must be a
-// valid IPv4 or IPv6 address (e.g. 127.0.0.1 or ::1) and |port| must be a port
-// number outside of the reserved range (e.g. between 1025 and 65535 on most
-// platforms). |backlog| is the maximum number of pending connections. A new
-// thread will be created for each CreateServer call (the "dedicated server
-// thread"). It is therefore recommended to use a different cef_server_handler_t
-// instance for each CreateServer call to avoid thread safety issues in the
-// cef_server_handler_t implementation. The
-// cef_server_handler_t::OnServerCreated function will be called on the
-// dedicated server thread to report success or failure. See
-// cef_server_handler_t::OnServerCreated documentation for a description of
-// server lifespan.
-///
-void cef_server_create (
- const(cef_string_t)* address,
- uint16 port,
- int backlog,
- _cef_server_handler_t* handler);
-
-///
-// Implement this structure to handle HTTP server requests. A new thread will be
-// created for each cef_server_t::CreateServer call (the "dedicated server
-// thread"), and the functions of this structure will be called on that thread.
-// It is therefore recommended to use a different cef_server_handler_t instance
-// for each cef_server_t::CreateServer call to avoid thread safety issues in the
-// cef_server_handler_t implementation.
-///
-struct _cef_server_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called when |server| is created. If the server was started successfully
- // then cef_server_t::IsRunning will return true (1). The server will continue
- // running until cef_server_t::Shutdown is called, after which time
- // OnServerDestroyed will be called. If the server failed to start then
- // OnServerDestroyed will be called immediately after this function returns.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server) nothrow on_server_created;
-
- ///
- // Called when |server| is destroyed. The server thread will be stopped after
- // this function returns. The client should release any references to |server|
- // when this function is called. See OnServerCreated documentation for a
- // description of server lifespan.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server) nothrow on_server_destroyed;
-
- ///
- // Called when a client connects to |server|. |connection_id| uniquely
- // identifies the connection. Each call to this function will have a matching
- // call to OnClientDisconnected.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server,
- int connection_id) nothrow on_client_connected;
-
- ///
- // Called when a client disconnects from |server|. |connection_id| uniquely
- // identifies the connection. The client should release any data associated
- // with |connection_id| when this function is called and |connection_id|
- // should no longer be passed to cef_server_t functions. Disconnects can
- // originate from either the client or the server. For example, the server
- // will disconnect automatically after a cef_server_t::SendHttpXXXResponse
- // function is called.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server,
- int connection_id) nothrow on_client_disconnected;
-
- ///
- // Called when |server| receives an HTTP request. |connection_id| uniquely
- // identifies the connection, |client_address| is the requesting IPv4 or IPv6
- // client address including port number, and |request| contains the request
- // contents (URL, function, headers and optional POST data). Call cef_server_t
- // functions either synchronously or asynchronusly to send a response.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server,
- int connection_id,
- const(cef_string_t)* client_address,
- _cef_request_t* request) nothrow on_http_request;
-
- ///
- // Called when |server| receives a WebSocket request. |connection_id| uniquely
- // identifies the connection, |client_address| is the requesting IPv4 or IPv6
- // client address including port number, and |request| contains the request
- // contents (URL, function, headers and optional POST data). Execute
- // |callback| either synchronously or asynchronously to accept or decline the
- // WebSocket connection. If the request is accepted then OnWebSocketConnected
- // will be called after the WebSocket has connected and incoming messages will
- // be delivered to the OnWebSocketMessage callback. If the request is declined
- // then the client will be disconnected and OnClientDisconnected will be
- // called. Call the cef_server_t::SendWebSocketMessage function after
- // receiving the OnWebSocketConnected callback to respond with WebSocket
- // messages.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server,
- int connection_id,
- const(cef_string_t)* client_address,
- _cef_request_t* request,
- _cef_callback_t* callback) nothrow on_web_socket_request;
-
- ///
- // Called after the client has accepted the WebSocket connection for |server|
- // and |connection_id| via the OnWebSocketRequest callback. See
- // OnWebSocketRequest documentation for intended usage.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server,
- int connection_id) nothrow on_web_socket_connected;
-
- ///
- // Called when |server| receives an WebSocket message. |connection_id|
- // uniquely identifies the connection, |data| is the message content and
- // |data_size| is the size of |data| in bytes. Do not keep a reference to
- // |data| outside of this function. See OnWebSocketRequest documentation for
- // intended usage.
- ///
- void function (
- _cef_server_handler_t* self,
- _cef_server_t* server,
- int connection_id,
- const(void)* data,
- size_t data_size) nothrow on_web_socket_message;
-}
-
-alias cef_server_handler_t = _cef_server_handler_t;
-
-// CEF_INCLUDE_CAPI_CEF_SERVER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=badaadcff4641fea876fb626b8ffe5a6f34a376c$
-//
-
-extern (C):
-
-///
-// Structure representing SSL information.
-///
-struct _cef_sslinfo_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns a bitmask containing any and all problems verifying the server
- // certificate.
- ///
- cef_cert_status_t function (_cef_sslinfo_t* self) nothrow get_cert_status;
-
- ///
- // Returns the X.509 certificate.
- ///
- _cef_x509certificate_t* function (
- _cef_sslinfo_t* self) nothrow get_x509certificate;
-}
-
-alias cef_sslinfo_t = _cef_sslinfo_t;
-
-///
-// Returns true (1) if the certificate status represents an error.
-///
-int cef_is_cert_status_error (cef_cert_status_t status);
-
-// CEF_INCLUDE_CAPI_CEF_SSL_INFO_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=3755121a7b89de52a67885ac1c6d12de23f4b657$
-//
-
-extern (C):
-
-///
-// Structure representing the SSL information for a navigation entry.
-///
-struct _cef_sslstatus_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if the status is related to a secure SSL/TLS connection.
- ///
- int function (_cef_sslstatus_t* self) nothrow is_secure_connection;
-
- ///
- // Returns a bitmask containing any and all problems verifying the server
- // certificate.
- ///
- cef_cert_status_t function (_cef_sslstatus_t* self) nothrow get_cert_status;
-
- ///
- // Returns the SSL version used for the SSL connection.
- ///
- cef_ssl_version_t function (_cef_sslstatus_t* self) nothrow get_sslversion;
-
- ///
- // Returns a bitmask containing the page security content status.
- ///
- cef_ssl_content_status_t function (
- _cef_sslstatus_t* self) nothrow get_content_status;
-
- ///
- // Returns the X.509 certificate.
- ///
- _cef_x509certificate_t* function (
- _cef_sslstatus_t* self) nothrow get_x509certificate;
-}
-
-alias cef_sslstatus_t = _cef_sslstatus_t;
-
-// CEF_INCLUDE_CAPI_CEF_SSL_STATUS_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=bd5bbcdc385f83512bf64304e180f1a05b765c16$
-//
-
-extern (C):
-
-///
-// Structure the client can implement to provide a custom stream reader. The
-// functions of this structure may be called on any thread.
-///
-struct _cef_read_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Read raw binary data.
- ///
- size_t function (
- _cef_read_handler_t* self,
- void* ptr,
- size_t size,
- size_t n) nothrow read;
-
- ///
- // Seek to the specified offset position. |whence| may be any one of SEEK_CUR,
- // SEEK_END or SEEK_SET. Return zero on success and non-zero on failure.
- ///
- int function (_cef_read_handler_t* self, int64 offset, int whence) nothrow seek;
-
- ///
- // Return the current offset position.
- ///
- int64 function (_cef_read_handler_t* self) nothrow tell;
-
- ///
- // Return non-zero if at end of file.
- ///
- int function (_cef_read_handler_t* self) nothrow eof;
-
- ///
- // Return true (1) if this handler performs work like accessing the file
- // system which may block. Used as a hint for determining the thread to access
- // the handler from.
- ///
- int function (_cef_read_handler_t* self) nothrow may_block;
-}
-
-alias cef_read_handler_t = _cef_read_handler_t;
-
-///
-// Structure used to read data from a stream. The functions of this structure
-// may be called on any thread.
-///
-struct _cef_stream_reader_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Read raw binary data.
- ///
- size_t function (
- _cef_stream_reader_t* self,
- void* ptr,
- size_t size,
- size_t n) nothrow read;
-
- ///
- // Seek to the specified offset position. |whence| may be any one of SEEK_CUR,
- // SEEK_END or SEEK_SET. Returns zero on success and non-zero on failure.
- ///
- int function (_cef_stream_reader_t* self, int64 offset, int whence) nothrow seek;
-
- ///
- // Return the current offset position.
- ///
- int64 function (_cef_stream_reader_t* self) nothrow tell;
-
- ///
- // Return non-zero if at end of file.
- ///
- int function (_cef_stream_reader_t* self) nothrow eof;
-
- ///
- // Returns true (1) if this reader performs work like accessing the file
- // system which may block. Used as a hint for determining the thread to access
- // the reader from.
- ///
- int function (_cef_stream_reader_t* self) nothrow may_block;
-}
-
-alias cef_stream_reader_t = _cef_stream_reader_t;
-
-///
-// Create a new cef_stream_reader_t object from a file.
-///
-cef_stream_reader_t* cef_stream_reader_create_for_file (
- const(cef_string_t)* fileName);
-
-///
-// Create a new cef_stream_reader_t object from data.
-///
-cef_stream_reader_t* cef_stream_reader_create_for_data (
- void* data,
- size_t size);
-
-///
-// Create a new cef_stream_reader_t object from a custom handler.
-///
-cef_stream_reader_t* cef_stream_reader_create_for_handler (
- cef_read_handler_t* handler);
-
-///
-// Structure the client can implement to provide a custom stream writer. The
-// functions of this structure may be called on any thread.
-///
-struct _cef_write_handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Write raw binary data.
- ///
- size_t function (
- _cef_write_handler_t* self,
- const(void)* ptr,
- size_t size,
- size_t n) nothrow write;
-
- ///
- // Seek to the specified offset position. |whence| may be any one of SEEK_CUR,
- // SEEK_END or SEEK_SET. Return zero on success and non-zero on failure.
- ///
- int function (_cef_write_handler_t* self, int64 offset, int whence) nothrow seek;
-
- ///
- // Return the current offset position.
- ///
- int64 function (_cef_write_handler_t* self) nothrow tell;
-
- ///
- // Flush the stream.
- ///
- int function (_cef_write_handler_t* self) nothrow flush;
-
- ///
- // Return true (1) if this handler performs work like accessing the file
- // system which may block. Used as a hint for determining the thread to access
- // the handler from.
- ///
- int function (_cef_write_handler_t* self) nothrow may_block;
-}
-
-alias cef_write_handler_t = _cef_write_handler_t;
-
-///
-// Structure used to write data to a stream. The functions of this structure may
-// be called on any thread.
-///
-struct _cef_stream_writer_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Write raw binary data.
- ///
- size_t function (
- _cef_stream_writer_t* self,
- const(void)* ptr,
- size_t size,
- size_t n) nothrow write;
-
- ///
- // Seek to the specified offset position. |whence| may be any one of SEEK_CUR,
- // SEEK_END or SEEK_SET. Returns zero on success and non-zero on failure.
- ///
- int function (_cef_stream_writer_t* self, int64 offset, int whence) nothrow seek;
-
- ///
- // Return the current offset position.
- ///
- int64 function (_cef_stream_writer_t* self) nothrow tell;
-
- ///
- // Flush the stream.
- ///
- int function (_cef_stream_writer_t* self) nothrow flush;
-
- ///
- // Returns true (1) if this writer performs work like accessing the file
- // system which may block. Used as a hint for determining the thread to access
- // the writer from.
- ///
- int function (_cef_stream_writer_t* self) nothrow may_block;
-}
-
-alias cef_stream_writer_t = _cef_stream_writer_t;
-
-///
-// Create a new cef_stream_writer_t object for a file.
-///
-cef_stream_writer_t* cef_stream_writer_create_for_file (
- const(cef_string_t)* fileName);
-
-///
-// Create a new cef_stream_writer_t object for a custom handler.
-///
-cef_stream_writer_t* cef_stream_writer_create_for_handler (
- cef_write_handler_t* handler);
-
-// CEF_INCLUDE_CAPI_CEF_STREAM_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=bba3a9719860f9a81c63cbb052a4c501416b2ada$
-//
-
-extern (C):
-
-///
-// Implement this structure to receive string values asynchronously.
-///
-struct _cef_string_visitor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed.
- ///
- void function (
- _cef_string_visitor_t* self,
- const(cef_string_t)* string) nothrow visit;
-}
-
-alias cef_string_visitor_t = _cef_string_visitor_t;
-
-// CEF_INCLUDE_CAPI_CEF_STRING_VISITOR_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=025daa5db3bf16029953da7703e3e5968bd97fe2$
-//
-
-extern (C):
-
-///
-// Implement this structure for asynchronous task execution. If the task is
-// posted successfully and if the associated message loop is still running then
-// the execute() function will be called on the target thread. If the task fails
-// to post then the task object may be destroyed on the source thread instead of
-// the target thread. For this reason be cautious when performing work in the
-// task object destructor.
-///
-struct _cef_task_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be executed on the target thread.
- ///
- void function (_cef_task_t* self) nothrow execute;
-}
-
-alias cef_task_t = _cef_task_t;
-
-///
-// Structure that asynchronously executes tasks on the associated thread. It is
-// safe to call the functions of this structure on any thread.
-//
-// CEF maintains multiple internal threads that are used for handling different
-// types of tasks in different processes. The cef_thread_id_t definitions in
-// cef_types.h list the common CEF threads. Task runners are also available for
-// other CEF threads as appropriate (for example, V8 WebWorker threads).
-///
-struct _cef_task_runner_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is pointing to the same task runner as
- // |that| object.
- ///
- int function (_cef_task_runner_t* self, _cef_task_runner_t* that) nothrow is_same;
-
- ///
- // Returns true (1) if this task runner belongs to the current thread.
- ///
- int function (_cef_task_runner_t* self) nothrow belongs_to_current_thread;
-
- ///
- // Returns true (1) if this task runner is for the specified CEF thread.
- ///
- int function (
- _cef_task_runner_t* self,
- cef_thread_id_t threadId) nothrow belongs_to_thread;
-
- ///
- // Post a task for execution on the thread associated with this task runner.
- // Execution will occur asynchronously.
- ///
- int function (_cef_task_runner_t* self, _cef_task_t* task) nothrow post_task;
-
- ///
- // Post a task for delayed execution on the thread associated with this task
- // runner. Execution will occur asynchronously. Delayed tasks are not
- // supported on V8 WebWorker threads and will be executed without the
- // specified delay.
- ///
- int function (
- _cef_task_runner_t* self,
- _cef_task_t* task,
- int64 delay_ms) nothrow post_delayed_task;
-}
-
-alias cef_task_runner_t = _cef_task_runner_t;
-
-///
-// 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.
-///
-cef_task_runner_t* cef_task_runner_get_for_current_thread ();
-
-///
-// Returns the task runner for the specified CEF thread.
-///
-cef_task_runner_t* cef_task_runner_get_for_thread (cef_thread_id_t threadId);
-
-///
-// Returns true (1) if called on the specified thread. Equivalent to using
-// cef_task_runner_t::GetForThread(threadId)->belongs_to_current_thread().
-///
-int cef_currently_on (cef_thread_id_t threadId);
-
-///
-// Post a task for execution on the specified thread. Equivalent to using
-// cef_task_runner_t::GetForThread(threadId)->PostTask(task).
-///
-int cef_post_task (cef_thread_id_t threadId, cef_task_t* task);
-
-///
-// Post a task for delayed execution on the specified thread. Equivalent to
-// using cef_task_runner_t::GetForThread(threadId)->PostDelayedTask(task,
-// delay_ms).
-///
-int cef_post_delayed_task (
- cef_thread_id_t threadId,
- cef_task_t* task,
- int64 delay_ms);
-
-// CEF_INCLUDE_CAPI_CEF_TASK_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=d443c0990241554b548bc946f46f35582445e818$
-//
-
-extern (C):
-
-///
-// A simple thread abstraction that establishes a message loop on a new thread.
-// The consumer uses cef_task_runner_t to execute code on the thread's message
-// loop. The thread is terminated when the cef_thread_t object is destroyed or
-// stop() is called. All pending tasks queued on the thread's message loop will
-// run to completion before the thread is terminated. cef_thread_create() can be
-// called on any valid CEF thread in either the browser or render process. This
-// structure should only be used for tasks that require a dedicated thread. In
-// most cases you can post tasks to an existing CEF thread instead of creating a
-// new one; see cef_task.h for details.
-///
-struct _cef_thread_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the cef_task_runner_t that will execute code on this thread's
- // message loop. This function is safe to call from any thread.
- ///
- _cef_task_runner_t* function (_cef_thread_t* self) nothrow get_task_runner;
-
- ///
- // Returns the platform thread ID. It will return the same value after stop()
- // is called. This function is safe to call from any thread.
- ///
- cef_platform_thread_id_t function (
- _cef_thread_t* self) nothrow get_platform_thread_id;
-
- ///
- // Stop and join the thread. This function must be called from the same thread
- // that called cef_thread_create(). Do not call this function if
- // cef_thread_create() was called with a |stoppable| value of false (0).
- ///
- void function (_cef_thread_t* self) nothrow stop;
-
- ///
- // Returns true (1) if the thread is currently running. This function must be
- // called from the same thread that called cef_thread_create().
- ///
- int function (_cef_thread_t* self) nothrow is_running;
-}
-
-alias cef_thread_t = _cef_thread_t;
-
-///
-// Create and start a new thread. This function does not block waiting for the
-// thread to run initialization. |display_name| is the name that will be used to
-// identify the thread. |priority| is the thread execution priority.
-// |message_loop_type| indicates the set of asynchronous events that the thread
-// can process. If |stoppable| is true (1) the thread will stopped and joined on
-// destruction or when stop() is called; otherwise, the thread cannot be stopped
-// and will be leaked on shutdown. On Windows the |com_init_mode| value
-// specifies how COM will be initialized for the thread. If |com_init_mode| is
-// set to COM_INIT_MODE_STA then |message_loop_type| must be set to ML_TYPE_UI.
-///
-cef_thread_t* cef_thread_create (
- const(cef_string_t)* display_name,
- cef_thread_priority_t priority,
- cef_message_loop_type_t message_loop_type,
- int stoppable,
- cef_com_init_mode_t com_init_mode);
-
-// CEF_INCLUDE_CAPI_CEF_THREAD_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=b1b96b7cb636afbd201b88bc1544afc58099c0b6$
-//
-
-extern (C):
-
-///
-// Implement this structure to receive notification when tracing has completed.
-// The functions of this structure will be called on the browser process UI
-// thread.
-///
-struct _cef_end_tracing_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called after all processes have sent their trace data. |tracing_file| is
- // the path at which tracing data was written. The client is responsible for
- // deleting |tracing_file|.
- ///
- void function (
- _cef_end_tracing_callback_t* self,
- const(cef_string_t)* tracing_file) nothrow on_end_tracing_complete;
-}
-
-alias cef_end_tracing_callback_t = _cef_end_tracing_callback_t;
-
-///
-// Start tracing events on all processes. Tracing is initialized asynchronously
-// and |callback| will be executed on the UI thread after initialization is
-// complete.
-//
-// If CefBeginTracing was called previously, or if a CefEndTracingAsync call is
-// pending, CefBeginTracing will fail and return false (0).
-//
-// |categories| is a comma-delimited list of category wildcards. A category can
-// have an optional '-' prefix to make it an excluded category. Having both
-// included and excluded categories in the same list is not supported.
-//
-// Example: "test_MyTest*" Example: "test_MyTest*,test_OtherStuff" Example:
-// "-excluded_category1,-excluded_category2"
-//
-// This function must be called on the browser process UI thread.
-///
-int cef_begin_tracing (
- const(cef_string_t)* categories,
- _cef_completion_callback_t* callback);
-
-///
-// Stop tracing events on all processes.
-//
-// This function will fail and return false (0) if a previous call to
-// CefEndTracingAsync is already pending or if CefBeginTracing was not called.
-//
-// |tracing_file| is the path at which tracing data will be written and
-// |callback| is the callback that will be executed once all processes have sent
-// their trace data. If |tracing_file| is NULL a new temporary file path will be
-// used. If |callback| is NULL no trace data will be written.
-//
-// This function must be called on the browser process UI thread.
-///
-int cef_end_tracing (
- const(cef_string_t)* tracing_file,
- cef_end_tracing_callback_t* callback);
-
-///
-// Returns the current system trace time or, if none is defined, the current
-// high-res time. Can be used by clients to synchronize with the time
-// information in trace events.
-///
-int64 cef_now_from_system_trace_time ();
-
-// CEF_INCLUDE_CAPI_CEF_TRACE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=75f4f7a9ff628a6ae699a697722caa5d49546784$
-//
-
-extern (C):
-
-///
-// Structure used to make a URL request. URL requests are not associated with a
-// browser instance so no cef_client_t callbacks will be executed. URL requests
-// can be created on any valid CEF thread in either the browser or render
-// process. Once created the functions of the URL request object must be
-// accessed on the same thread that created it.
-///
-struct _cef_urlrequest_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the request object used to create this URL request. The returned
- // object is read-only and should not be modified.
- ///
- _cef_request_t* function (_cef_urlrequest_t* self) nothrow get_request;
-
- ///
- // Returns the client.
- ///
- _cef_urlrequest_client_t* function (_cef_urlrequest_t* self) nothrow get_client;
-
- ///
- // Returns the request status.
- ///
- cef_urlrequest_status_t function (
- _cef_urlrequest_t* self) nothrow get_request_status;
-
- ///
- // Returns the request error if status is UR_CANCELED or UR_FAILED, or 0
- // otherwise.
- ///
- cef_errorcode_t function (_cef_urlrequest_t* self) nothrow get_request_error;
-
- ///
- // Returns the response, or NULL if no response information is available.
- // Response information will only be available after the upload has completed.
- // The returned object is read-only and should not be modified.
- ///
- _cef_response_t* function (_cef_urlrequest_t* self) nothrow get_response;
-
- ///
- // Returns true (1) if the response body was served from the cache. This
- // includes responses for which revalidation was required.
- ///
- int function (_cef_urlrequest_t* self) nothrow response_was_cached;
-
- ///
- // Cancel the request.
- ///
- void function (_cef_urlrequest_t* self) nothrow cancel;
-}
-
-alias cef_urlrequest_t = _cef_urlrequest_t;
-
-///
-// Create a new URL request that is not associated with a specific browser or
-// frame. Use cef_frame_t::CreateURLRequest instead if you want the request to
-// have this association, in which case it may be handled differently (see
-// documentation on that function). A request created with this function may
-// only originate from the browser process, and will behave as follows:
-// - It may be intercepted by the client via CefResourceRequestHandler or
-// CefSchemeHandlerFactory.
-// - POST data may only contain only a single element of type PDE_TYPE_FILE
-// or PDE_TYPE_BYTES.
-// - If |request_context| is empty the global request context will be used.
-//
-// The |request| object will be marked as read-only after calling this function.
-///
-cef_urlrequest_t* cef_urlrequest_create (
- _cef_request_t* request,
- _cef_urlrequest_client_t* client,
- _cef_request_context_t* request_context);
-
-///
-// Structure that should be implemented by the cef_urlrequest_t client. The
-// functions of this structure will be called on the same thread that created
-// the request unless otherwise documented.
-///
-struct _cef_urlrequest_client_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Notifies the client that the request has completed. Use the
- // cef_urlrequest_t::GetRequestStatus function to determine if the request was
- // successful or not.
- ///
- void function (
- _cef_urlrequest_client_t* self,
- _cef_urlrequest_t* request) nothrow on_request_complete;
-
- ///
- // Notifies the client of upload progress. |current| denotes the number of
- // bytes sent so far and |total| is the total size of uploading data (or -1 if
- // chunked upload is enabled). This function will only be called if the
- // UR_FLAG_REPORT_UPLOAD_PROGRESS flag is set on the request.
- ///
- void function (
- _cef_urlrequest_client_t* self,
- _cef_urlrequest_t* request,
- int64 current,
- int64 total) nothrow on_upload_progress;
-
- ///
- // Notifies the client of download progress. |current| denotes the number of
- // bytes received up to the call and |total| is the expected total size of the
- // response (or -1 if not determined).
- ///
- void function (
- _cef_urlrequest_client_t* self,
- _cef_urlrequest_t* request,
- int64 current,
- int64 total) nothrow on_download_progress;
-
- ///
- // Called when some part of the response is read. |data| contains the current
- // bytes received since the last call. This function will not be called if the
- // UR_FLAG_NO_DOWNLOAD_DATA flag is set on the request.
- ///
- void function (
- _cef_urlrequest_client_t* self,
- _cef_urlrequest_t* request,
- const(void)* data,
- size_t data_length) nothrow on_download_data;
-
- ///
- // Called on the IO thread when the browser needs credentials from the user.
- // |isProxy| indicates whether the host is a proxy server. |host| contains the
- // hostname and |port| contains the port number. Return true (1) to continue
- // the request and call cef_auth_callback_t::cont() when the authentication
- // information is available. If the request has an associated browser/frame
- // then returning false (0) will result in a call to GetAuthCredentials on the
- // cef_request_handler_t associated with that browser, if any. Otherwise,
- // returning false (0) will cancel the request immediately. This function will
- // only be called for requests initiated from the browser process.
- ///
- int function (
- _cef_urlrequest_client_t* self,
- int isProxy,
- const(cef_string_t)* host,
- int port,
- const(cef_string_t)* realm,
- const(cef_string_t)* scheme,
- _cef_auth_callback_t* callback) nothrow get_auth_credentials;
-}
-
-alias cef_urlrequest_client_t = _cef_urlrequest_client_t;
-
-// CEF_INCLUDE_CAPI_CEF_URLREQUEST_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=3bb8f9801a153172981120926c7a5629e08d7131$
-//
-
-extern (C):
-
-///
-// Structure representing a V8 context handle. V8 handles can only be accessed
-// from the thread on which they are created. Valid threads for creating a V8
-// handle include the render process main thread (TID_RENDERER) and WebWorker
-// threads. A task runner for posting tasks on the associated thread can be
-// retrieved via the cef_v8context_t::get_task_runner() function.
-///
-struct _cef_v8context_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the task runner associated with this context. V8 handles can only
- // be accessed from the thread on which they are created. This function can be
- // called on any render process thread.
- ///
- _cef_task_runner_t* function (_cef_v8context_t* self) nothrow get_task_runner;
-
- ///
- // Returns true (1) if the underlying handle is valid and it can be accessed
- // on the current thread. Do not call any other functions if this function
- // returns false (0).
- ///
- int function (_cef_v8context_t* self) nothrow is_valid;
-
- ///
- // Returns the browser for this context. This function will return an NULL
- // reference for WebWorker contexts.
- ///
- _cef_browser_t* function (_cef_v8context_t* self) nothrow get_browser;
-
- ///
- // Returns the frame for this context. This function will return an NULL
- // reference for WebWorker contexts.
- ///
- _cef_frame_t* function (_cef_v8context_t* self) nothrow get_frame;
-
- ///
- // Returns the global object for this context. The context must be entered
- // before calling this function.
- ///
- _cef_v8value_t* function (_cef_v8context_t* self) nothrow get_global;
-
- ///
- // Enter this context. A context must be explicitly entered before creating a
- // V8 Object, Array, Function or Date asynchronously. exit() must be called
- // the same number of times as enter() before releasing this context. V8
- // objects belong to the context in which they are created. Returns true (1)
- // if the scope was entered successfully.
- ///
- int function (_cef_v8context_t* self) nothrow enter;
-
- ///
- // Exit this context. Call this function only after calling enter(). Returns
- // true (1) if the scope was exited successfully.
- ///
- int function (_cef_v8context_t* self) nothrow exit;
-
- ///
- // Returns true (1) if this object is pointing to the same handle as |that|
- // object.
- ///
- int function (_cef_v8context_t* self, _cef_v8context_t* that) nothrow is_same;
-
- ///
- // Execute a string of JavaScript code in this V8 context. The |script_url|
- // parameter is the URL where the script in question can be found, if any. The
- // |start_line| parameter is the base line number to use for error reporting.
- // On success |retval| will be set to the return value, if any, and the
- // function will return true (1). On failure |exception| will be set to the
- // exception, if any, and the function will return false (0).
- ///
- int function (
- _cef_v8context_t* self,
- const(cef_string_t)* code,
- const(cef_string_t)* script_url,
- int start_line,
- _cef_v8value_t** retval,
- _cef_v8exception_t** exception) nothrow eval;
-}
-
-alias cef_v8context_t = _cef_v8context_t;
-
-///
-// Returns the current (top) context object in the V8 context stack.
-///
-cef_v8context_t* cef_v8context_get_current_context ();
-
-///
-// Returns the entered (bottom) context object in the V8 context stack.
-///
-cef_v8context_t* cef_v8context_get_entered_context ();
-
-///
-// Returns true (1) if V8 is currently inside a context.
-///
-int cef_v8context_in_context ();
-
-///
-// Structure that should be implemented to handle V8 function calls. The
-// functions of this structure will be called on the thread associated with the
-// V8 function.
-///
-struct _cef_v8handler_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Handle execution of the function identified by |name|. |object| is the
- // receiver ('this' object) of the function. |arguments| is the list of
- // arguments passed to the function. If execution succeeds set |retval| to the
- // function return value. If execution fails set |exception| to the exception
- // that will be thrown. Return true (1) if execution was handled.
- ///
- int function (
- _cef_v8handler_t* self,
- const(cef_string_t)* name,
- _cef_v8value_t* object,
- size_t argumentsCount,
- _cef_v8value_t** arguments,
- _cef_v8value_t** retval,
- cef_string_t* exception) nothrow execute;
-}
-
-alias cef_v8handler_t = _cef_v8handler_t;
-
-///
-// Structure that should be implemented to handle V8 accessor calls. Accessor
-// identifiers are registered by calling cef_v8value_t::set_value(). The
-// functions of this structure will be called on the thread associated with the
-// V8 accessor.
-///
-struct _cef_v8accessor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Handle retrieval the accessor value identified by |name|. |object| is the
- // receiver ('this' object) of the accessor. If retrieval succeeds set
- // |retval| to the return value. If retrieval fails set |exception| to the
- // exception that will be thrown. Return true (1) if accessor retrieval was
- // handled.
- ///
- int function (
- _cef_v8accessor_t* self,
- const(cef_string_t)* name,
- _cef_v8value_t* object,
- _cef_v8value_t** retval,
- cef_string_t* exception) nothrow get;
-
- ///
- // Handle assignment of the accessor value identified by |name|. |object| is
- // the receiver ('this' object) of the accessor. |value| is the new value
- // being assigned to the accessor. If assignment fails set |exception| to the
- // exception that will be thrown. Return true (1) if accessor assignment was
- // handled.
- ///
- int function (
- _cef_v8accessor_t* self,
- const(cef_string_t)* name,
- _cef_v8value_t* object,
- _cef_v8value_t* value,
- cef_string_t* exception) nothrow set;
-}
-
-alias cef_v8accessor_t = _cef_v8accessor_t;
-
-///
-// Structure that should be implemented to handle V8 interceptor calls. The
-// functions of this structure will be called on the thread associated with the
-// V8 interceptor. Interceptor's named property handlers (with first argument of
-// type CefString) are called when object is indexed by string. Indexed property
-// handlers (with first argument of type int) are called when object is indexed
-// by integer.
-///
-struct _cef_v8interceptor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Handle retrieval of the interceptor value identified by |name|. |object| is
- // the receiver ('this' object) of the interceptor. If retrieval succeeds, set
- // |retval| to the return value. If the requested value does not exist, don't
- // set either |retval| or |exception|. If retrieval fails, set |exception| to
- // the exception that will be thrown. If the property has an associated
- // accessor, it will be called only if you don't set |retval|. Return true (1)
- // if interceptor retrieval was handled, false (0) otherwise.
- ///
- int function (
- _cef_v8interceptor_t* self,
- const(cef_string_t)* name,
- _cef_v8value_t* object,
- _cef_v8value_t** retval,
- cef_string_t* exception) nothrow get_byname;
-
- ///
- // Handle retrieval of the interceptor value identified by |index|. |object|
- // is the receiver ('this' object) of the interceptor. If retrieval succeeds,
- // set |retval| to the return value. If the requested value does not exist,
- // don't set either |retval| or |exception|. If retrieval fails, set
- // |exception| to the exception that will be thrown. Return true (1) if
- // interceptor retrieval was handled, false (0) otherwise.
- ///
- int function (
- _cef_v8interceptor_t* self,
- int index,
- _cef_v8value_t* object,
- _cef_v8value_t** retval,
- cef_string_t* exception) nothrow get_byindex;
-
- ///
- // Handle assignment of the interceptor value identified by |name|. |object|
- // is the receiver ('this' object) of the interceptor. |value| is the new
- // value being assigned to the interceptor. If assignment fails, set
- // |exception| to the exception that will be thrown. This setter will always
- // be called, even when the property has an associated accessor. Return true
- // (1) if interceptor assignment was handled, false (0) otherwise.
- ///
- int function (
- _cef_v8interceptor_t* self,
- const(cef_string_t)* name,
- _cef_v8value_t* object,
- _cef_v8value_t* value,
- cef_string_t* exception) nothrow set_byname;
-
- ///
- // Handle assignment of the interceptor value identified by |index|. |object|
- // is the receiver ('this' object) of the interceptor. |value| is the new
- // value being assigned to the interceptor. If assignment fails, set
- // |exception| to the exception that will be thrown. Return true (1) if
- // interceptor assignment was handled, false (0) otherwise.
- ///
- int function (
- _cef_v8interceptor_t* self,
- int index,
- _cef_v8value_t* object,
- _cef_v8value_t* value,
- cef_string_t* exception) nothrow set_byindex;
-}
-
-alias cef_v8interceptor_t = _cef_v8interceptor_t;
-
-///
-// Structure representing a V8 exception. The functions of this structure may be
-// called on any render process thread.
-///
-struct _cef_v8exception_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the exception message.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_v8exception_t* self) nothrow get_message;
-
- ///
- // Returns the line of source code that the exception occurred within.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_v8exception_t* self) nothrow get_source_line;
-
- ///
- // Returns the resource name for the script from where the function causing
- // the error originates.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_v8exception_t* self) nothrow get_script_resource_name;
-
- ///
- // Returns the 1-based number of the line where the error occurred or 0 if the
- // line number is unknown.
- ///
- int function (_cef_v8exception_t* self) nothrow get_line_number;
-
- ///
- // Returns the index within the script of the first character where the error
- // occurred.
- ///
- int function (_cef_v8exception_t* self) nothrow get_start_position;
-
- ///
- // Returns the index within the script of the last character where the error
- // occurred.
- ///
- int function (_cef_v8exception_t* self) nothrow get_end_position;
-
- ///
- // Returns the index within the line of the first character where the error
- // occurred.
- ///
- int function (_cef_v8exception_t* self) nothrow get_start_column;
-
- ///
- // Returns the index within the line of the last character where the error
- // occurred.
- ///
- int function (_cef_v8exception_t* self) nothrow get_end_column;
-}
-
-alias cef_v8exception_t = _cef_v8exception_t;
-
-///
-// Callback structure that is passed to cef_v8value_t::CreateArrayBuffer.
-///
-struct _cef_v8array_buffer_release_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Called to release |buffer| when the ArrayBuffer JS object is garbage
- // collected. |buffer| is the value that was passed to CreateArrayBuffer along
- // with this object.
- ///
- void function (
- _cef_v8array_buffer_release_callback_t* self,
- void* buffer) nothrow release_buffer;
-}
-
-alias cef_v8array_buffer_release_callback_t = _cef_v8array_buffer_release_callback_t;
-
-///
-// Structure representing a V8 value handle. V8 handles can only be accessed
-// from the thread on which they are created. Valid threads for creating a V8
-// handle include the render process main thread (TID_RENDERER) and WebWorker
-// threads. A task runner for posting tasks on the associated thread can be
-// retrieved via the cef_v8context_t::get_task_runner() function.
-///
-struct _cef_v8value_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if the underlying handle is valid and it can be accessed
- // on the current thread. Do not call any other functions if this function
- // returns false (0).
- ///
- int function (_cef_v8value_t* self) nothrow is_valid;
-
- ///
- // True if the value type is undefined.
- ///
- int function (_cef_v8value_t* self) nothrow is_undefined;
-
- ///
- // True if the value type is null.
- ///
- int function (_cef_v8value_t* self) nothrow is_null;
-
- ///
- // True if the value type is bool.
- ///
- int function (_cef_v8value_t* self) nothrow is_bool;
-
- ///
- // True if the value type is int.
- ///
- int function (_cef_v8value_t* self) nothrow is_int;
-
- ///
- // True if the value type is unsigned int.
- ///
- int function (_cef_v8value_t* self) nothrow is_uint;
-
- ///
- // True if the value type is double.
- ///
- int function (_cef_v8value_t* self) nothrow is_double;
-
- ///
- // True if the value type is Date.
- ///
- int function (_cef_v8value_t* self) nothrow is_date;
-
- ///
- // True if the value type is string.
- ///
- int function (_cef_v8value_t* self) nothrow is_string;
-
- ///
- // True if the value type is object.
- ///
- int function (_cef_v8value_t* self) nothrow is_object;
-
- ///
- // True if the value type is array.
- ///
- int function (_cef_v8value_t* self) nothrow is_array;
-
- ///
- // True if the value type is an ArrayBuffer.
- ///
- int function (_cef_v8value_t* self) nothrow is_array_buffer;
-
- ///
- // True if the value type is function.
- ///
- int function (_cef_v8value_t* self) nothrow is_function;
-
- ///
- // Returns true (1) if this object is pointing to the same handle as |that|
- // object.
- ///
- int function (_cef_v8value_t* self, _cef_v8value_t* that) nothrow is_same;
-
- ///
- // Return a bool value.
- ///
- int function (_cef_v8value_t* self) nothrow get_bool_value;
-
- ///
- // Return an int value.
- ///
- int32 function (_cef_v8value_t* self) nothrow get_int_value;
-
- ///
- // Return an unsigned int value.
- ///
- uint32 function (_cef_v8value_t* self) nothrow get_uint_value;
-
- ///
- // Return a double value.
- ///
- double function (_cef_v8value_t* self) nothrow get_double_value;
-
- ///
- // Return a Date value.
- ///
- cef_time_t function (_cef_v8value_t* self) nothrow get_date_value;
-
- ///
- // Return a string value.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_v8value_t* self) nothrow get_string_value;
-
- // OBJECT METHODS - These functions are only available on objects. Arrays and
- // functions are also objects. String- and integer-based keys can be used
- // interchangably with the framework converting between them as necessary.
-
- ///
- // Returns true (1) if this is a user created object.
- ///
- int function (_cef_v8value_t* self) nothrow is_user_created;
-
- ///
- // Returns true (1) if the last function call resulted in an exception. This
- // attribute exists only in the scope of the current CEF value object.
- ///
- int function (_cef_v8value_t* self) nothrow has_exception;
-
- ///
- // Returns the exception resulting from the last function call. This attribute
- // exists only in the scope of the current CEF value object.
- ///
- _cef_v8exception_t* function (_cef_v8value_t* self) nothrow get_exception;
-
- ///
- // Clears the last exception and returns true (1) on success.
- ///
- int function (_cef_v8value_t* self) nothrow clear_exception;
-
- ///
- // Returns true (1) if this object will re-throw future exceptions. This
- // attribute exists only in the scope of the current CEF value object.
- ///
- int function (_cef_v8value_t* self) nothrow will_rethrow_exceptions;
-
- ///
- // Set whether this object will re-throw future exceptions. By default
- // exceptions are not re-thrown. If a exception is re-thrown the current
- // context should not be accessed again until after the exception has been
- // caught and not re-thrown. Returns true (1) on success. This attribute
- // exists only in the scope of the current CEF value object.
- ///
- int function (_cef_v8value_t* self, int rethrow) nothrow set_rethrow_exceptions;
-
- ///
- // Returns true (1) if the object has a value with the specified identifier.
- ///
- int function (
- _cef_v8value_t* self,
- const(cef_string_t)* key) nothrow has_value_bykey;
-
- ///
- // Returns true (1) if the object has a value with the specified identifier.
- ///
- int function (_cef_v8value_t* self, int index) nothrow has_value_byindex;
-
- ///
- // Deletes the value with the specified identifier and returns true (1) on
- // success. Returns false (0) if this function is called incorrectly or an
- // exception is thrown. For read-only and don't-delete values this function
- // will return true (1) even though deletion failed.
- ///
- int function (
- _cef_v8value_t* self,
- const(cef_string_t)* key) nothrow delete_value_bykey;
-
- ///
- // Deletes the value with the specified identifier and returns true (1) on
- // success. Returns false (0) if this function is called incorrectly, deletion
- // fails or an exception is thrown. For read-only and don't-delete values this
- // function will return true (1) even though deletion failed.
- ///
- int function (_cef_v8value_t* self, int index) nothrow delete_value_byindex;
-
- ///
- // Returns the value with the specified identifier on success. Returns NULL if
- // this function is called incorrectly or an exception is thrown.
- ///
- _cef_v8value_t* function (
- _cef_v8value_t* self,
- const(cef_string_t)* key) nothrow get_value_bykey;
-
- ///
- // Returns the value with the specified identifier on success. Returns NULL if
- // this function is called incorrectly or an exception is thrown.
- ///
- _cef_v8value_t* function (
- _cef_v8value_t* self,
- int index) nothrow get_value_byindex;
-
- ///
- // Associates a value with the specified identifier and returns true (1) on
- // success. Returns false (0) if this function is called incorrectly or an
- // exception is thrown. For read-only values this function will return true
- // (1) even though assignment failed.
- ///
- int function (
- _cef_v8value_t* self,
- const(cef_string_t)* key,
- _cef_v8value_t* value,
- cef_v8_propertyattribute_t attribute) nothrow set_value_bykey;
-
- ///
- // Associates a value with the specified identifier and returns true (1) on
- // success. Returns false (0) if this function is called incorrectly or an
- // exception is thrown. For read-only values this function will return true
- // (1) even though assignment failed.
- ///
- int function (
- _cef_v8value_t* self,
- int index,
- _cef_v8value_t* value) nothrow set_value_byindex;
-
- ///
- // Registers an identifier and returns true (1) on success. Access to the
- // identifier will be forwarded to the cef_v8accessor_t instance passed to
- // cef_v8value_t::cef_v8value_create_object(). Returns false (0) if this
- // function is called incorrectly or an exception is thrown. For read-only
- // values this function will return true (1) even though assignment failed.
- ///
- int function (
- _cef_v8value_t* self,
- const(cef_string_t)* key,
- cef_v8_accesscontrol_t settings,
- cef_v8_propertyattribute_t attribute) nothrow set_value_byaccessor;
-
- ///
- // Read the keys for the object's values into the specified vector. Integer-
- // based keys will also be returned as strings.
- ///
- int function (_cef_v8value_t* self, cef_string_list_t keys) nothrow get_keys;
-
- ///
- // Sets the user data for this object and returns true (1) on success. Returns
- // false (0) if this function is called incorrectly. This function can only be
- // called on user created objects.
- ///
- int function (
- _cef_v8value_t* self,
- _cef_base_ref_counted_t* user_data) nothrow set_user_data;
-
- ///
- // Returns the user data, if any, assigned to this object.
- ///
- _cef_base_ref_counted_t* function (_cef_v8value_t* self) nothrow get_user_data;
-
- ///
- // Returns the amount of externally allocated memory registered for the
- // object.
- ///
- int function (_cef_v8value_t* self) nothrow get_externally_allocated_memory;
-
- ///
- // Adjusts the amount of registered external memory for the object. Used to
- // give V8 an indication of the amount of externally allocated memory that is
- // kept alive by JavaScript objects. V8 uses this information to decide when
- // to perform global garbage collection. Each cef_v8value_t tracks the amount
- // of external memory associated with it and automatically decreases the
- // global total by the appropriate amount on its destruction.
- // |change_in_bytes| specifies the number of bytes to adjust by. This function
- // returns the number of bytes associated with the object after the
- // adjustment. This function can only be called on user created objects.
- ///
- int function (
- _cef_v8value_t* self,
- int change_in_bytes) nothrow adjust_externally_allocated_memory;
-
- // ARRAY METHODS - These functions are only available on arrays.
-
- ///
- // Returns the number of elements in the array.
- ///
- int function (_cef_v8value_t* self) nothrow get_array_length;
-
- // ARRAY BUFFER METHODS - These functions are only available on ArrayBuffers.
-
- ///
- // Returns the ReleaseCallback object associated with the ArrayBuffer or NULL
- // if the ArrayBuffer was not created with CreateArrayBuffer.
- ///
- _cef_v8array_buffer_release_callback_t* function (
- _cef_v8value_t* self) nothrow get_array_buffer_release_callback;
-
- ///
- // Prevent the ArrayBuffer from using it's memory block by setting the length
- // to zero. This operation cannot be undone. If the ArrayBuffer was created
- // with CreateArrayBuffer then
- // cef_v8array_buffer_release_callback_t::ReleaseBuffer will be called to
- // release the underlying buffer.
- ///
- int function (_cef_v8value_t* self) nothrow neuter_array_buffer;
-
- // FUNCTION METHODS - These functions are only available on functions.
-
- ///
- // Returns the function name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_v8value_t* self) nothrow get_function_name;
-
- ///
- // Returns the function handler or NULL if not a CEF-created function.
- ///
- _cef_v8handler_t* function (_cef_v8value_t* self) nothrow get_function_handler;
-
- ///
- // Execute the function using the current V8 context. This function should
- // only be called from within the scope of a cef_v8handler_t or
- // cef_v8accessor_t callback, or in combination with calling enter() and
- // exit() on a stored cef_v8context_t reference. |object| is the receiver
- // ('this' object) of the function. If |object| is NULL the current context's
- // global object will be used. |arguments| is the list of arguments that will
- // be passed to the function. Returns the function return value on success.
- // Returns NULL if this function is called incorrectly or an exception is
- // thrown.
- ///
- _cef_v8value_t* function (
- _cef_v8value_t* self,
- _cef_v8value_t* object,
- size_t argumentsCount,
- _cef_v8value_t** arguments) nothrow execute_function;
-
- ///
- // Execute the function using the specified V8 context. |object| is the
- // receiver ('this' object) of the function. If |object| is NULL the specified
- // context's global object will be used. |arguments| is the list of arguments
- // that will be passed to the function. Returns the function return value on
- // success. Returns NULL if this function is called incorrectly or an
- // exception is thrown.
- ///
- _cef_v8value_t* function (
- _cef_v8value_t* self,
- _cef_v8context_t* context,
- _cef_v8value_t* object,
- size_t argumentsCount,
- _cef_v8value_t** arguments) nothrow execute_function_with_context;
-}
-
-alias cef_v8value_t = _cef_v8value_t;
-
-///
-// Create a new cef_v8value_t object of type undefined.
-///
-cef_v8value_t* cef_v8value_create_undefined ();
-
-///
-// Create a new cef_v8value_t object of type null.
-///
-cef_v8value_t* cef_v8value_create_null ();
-
-///
-// Create a new cef_v8value_t object of type bool.
-///
-cef_v8value_t* cef_v8value_create_bool (int value);
-
-///
-// Create a new cef_v8value_t object of type int.
-///
-cef_v8value_t* cef_v8value_create_int (int32 value);
-
-///
-// Create a new cef_v8value_t object of type unsigned int.
-///
-cef_v8value_t* cef_v8value_create_uint (uint32 value);
-
-///
-// Create a new cef_v8value_t object of type double.
-///
-cef_v8value_t* cef_v8value_create_double (double value);
-
-///
-// Create a new cef_v8value_t object of type Date. This function should only be
-// called from within the scope of a cef_render_process_handler_t,
-// cef_v8handler_t or cef_v8accessor_t callback, or in combination with calling
-// enter() and exit() on a stored cef_v8context_t reference.
-///
-cef_v8value_t* cef_v8value_create_date (const(cef_time_t)* date);
-
-///
-// Create a new cef_v8value_t object of type string.
-///
-cef_v8value_t* cef_v8value_create_string (const(cef_string_t)* value);
-
-///
-// Create a new cef_v8value_t object of type object with optional accessor
-// and/or interceptor. This function should only be called from within the scope
-// of a cef_render_process_handler_t, cef_v8handler_t or cef_v8accessor_t
-// callback, or in combination with calling enter() and exit() on a stored
-// cef_v8context_t reference.
-///
-cef_v8value_t* cef_v8value_create_object (
- cef_v8accessor_t* accessor,
- cef_v8interceptor_t* interceptor);
-
-///
-// Create a new cef_v8value_t object of type array with the specified |length|.
-// If |length| is negative the returned array will have length 0. This function
-// should only be called from within the scope of a
-// cef_render_process_handler_t, cef_v8handler_t or cef_v8accessor_t callback,
-// or in combination with calling enter() and exit() on a stored cef_v8context_t
-// reference.
-///
-cef_v8value_t* cef_v8value_create_array (int length);
-
-///
-// Create a new cef_v8value_t object of type ArrayBuffer which wraps the
-// provided |buffer| of size |length| bytes. The ArrayBuffer is externalized,
-// meaning that it does not own |buffer|. The caller is responsible for freeing
-// |buffer| when requested via a call to cef_v8array_buffer_release_callback_t::
-// ReleaseBuffer. This function should only be called from within the scope of a
-// cef_render_process_handler_t, cef_v8handler_t or cef_v8accessor_t callback,
-// or in combination with calling enter() and exit() on a stored cef_v8context_t
-// reference.
-///
-cef_v8value_t* cef_v8value_create_array_buffer (
- void* buffer,
- size_t length,
- cef_v8array_buffer_release_callback_t* release_callback);
-
-///
-// Create a new cef_v8value_t object of type function. This function should only
-// be called from within the scope of a cef_render_process_handler_t,
-// cef_v8handler_t or cef_v8accessor_t callback, or in combination with calling
-// enter() and exit() on a stored cef_v8context_t reference.
-///
-cef_v8value_t* cef_v8value_create_function (
- const(cef_string_t)* name,
- cef_v8handler_t* handler) nothrow;
-
-///
-// Structure representing a V8 stack trace handle. V8 handles can only be
-// accessed from the thread on which they are created. Valid threads for
-// creating a V8 handle include the render process main thread (TID_RENDERER)
-// and WebWorker threads. A task runner for posting tasks on the associated
-// thread can be retrieved via the cef_v8context_t::get_task_runner() function.
-///
-struct _cef_v8stack_trace_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if the underlying handle is valid and it can be accessed
- // on the current thread. Do not call any other functions if this function
- // returns false (0).
- ///
- int function (_cef_v8stack_trace_t* self) nothrow is_valid;
-
- ///
- // Returns the number of stack frames.
- ///
- int function (_cef_v8stack_trace_t* self) nothrow get_frame_count;
-
- ///
- // Returns the stack frame at the specified 0-based index.
- ///
- _cef_v8stack_frame_t* function (
- _cef_v8stack_trace_t* self,
- int index) nothrow get_frame;
-}
-
-alias cef_v8stack_trace_t = _cef_v8stack_trace_t;
-
-///
-// Returns the stack trace for the currently active context. |frame_limit| is
-// the maximum number of frames that will be captured.
-///
-cef_v8stack_trace_t* cef_v8stack_trace_get_current (int frame_limit);
-
-///
-// Structure representing a V8 stack frame handle. V8 handles can only be
-// accessed from the thread on which they are created. Valid threads for
-// creating a V8 handle include the render process main thread (TID_RENDERER)
-// and WebWorker threads. A task runner for posting tasks on the associated
-// thread can be retrieved via the cef_v8context_t::get_task_runner() function.
-///
-struct _cef_v8stack_frame_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if the underlying handle is valid and it can be accessed
- // on the current thread. Do not call any other functions if this function
- // returns false (0).
- ///
- int function (_cef_v8stack_frame_t* self) nothrow is_valid;
-
- ///
- // Returns the name of the resource script that contains the function.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_v8stack_frame_t* self) nothrow get_script_name;
-
- ///
- // Returns the name of the resource script that contains the function or the
- // sourceURL value if the script name is undefined and its source ends with a
- // "//@ sourceURL=..." string.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_v8stack_frame_t* self) nothrow get_script_name_or_source_url;
-
- ///
- // Returns the name of the function.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_v8stack_frame_t* self) nothrow get_function_name;
-
- ///
- // Returns the 1-based line number for the function call or 0 if unknown.
- ///
- int function (_cef_v8stack_frame_t* self) nothrow get_line_number;
-
- ///
- // Returns the 1-based column offset on the line for the function call or 0 if
- // unknown.
- ///
- int function (_cef_v8stack_frame_t* self) nothrow get_column;
-
- ///
- // Returns true (1) if the function was compiled using eval().
- ///
- int function (_cef_v8stack_frame_t* self) nothrow is_eval;
-
- ///
- // Returns true (1) if the function was called as a constructor via "new".
- ///
- int function (_cef_v8stack_frame_t* self) nothrow is_constructor;
-}
-
-alias cef_v8stack_frame_t = _cef_v8stack_frame_t;
-
-///
-// Register a new V8 extension with the specified JavaScript extension code and
-// handler. Functions implemented by the handler are prototyped using the
-// keyword 'native'. The calling of a native function is restricted to the scope
-// in which the prototype of the native function is defined. This function may
-// only be called on the render process main thread.
-//
-// Example JavaScript extension code:
-// // create the 'example' global object if it doesn't already exist.
-// if (!example)
-// example = {};
-// // create the 'example.test' global object if it doesn't already exist.
-// if (!example.test)
-// example.test = {};
-// (function() {
-// // Define the function 'example.test.myfunction'.
-// example.test.myfunction = function() {
-// // Call CefV8Handler::Execute() with the function name 'MyFunction'
-// // and no arguments.
-// native function MyFunction();
-// return MyFunction();
-// };
-// // Define the getter function for parameter 'example.test.myparam'.
-// example.test.__defineGetter__('myparam', function() {
-// // Call CefV8Handler::Execute() with the function name 'GetMyParam'
-// // and no arguments.
-// native function GetMyParam();
-// return GetMyParam();
-// });
-// // Define the setter function for parameter 'example.test.myparam'.
-// example.test.__defineSetter__('myparam', function(b) {
-// // Call CefV8Handler::Execute() with the function name 'SetMyParam'
-// // and a single argument.
-// native function SetMyParam();
-// if(b) SetMyParam(b);
-// });
-//
-// // Extension definitions can also contain normal JavaScript variables
-// // and functions.
-// var myint = 0;
-// example.test.increment = function() {
-// myint += 1;
-// return myint;
-// };
-// })();
-//
Example usage in the page:
-// // Call the function.
-// example.test.myfunction();
-// // Set the parameter.
-// example.test.myparam = value;
-// // Get the parameter.
-// value = example.test.myparam;
-// // Call another function.
-// example.test.increment();
-//
-///
-int cef_register_extension (
- const(cef_string_t)* extension_name,
- const(cef_string_t)* javascript_code,
- cef_v8handler_t* handler);
-
-// CEF_INCLUDE_CAPI_CEF_V8_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=22f935968cd7f2549def42f5d84694311bde125e$
-//
-
-extern (C):
-
-///
-// Structure that wraps other data value types. Complex types (binary,
-// dictionary and list) will be referenced but not owned by this object. Can be
-// used on any process and thread.
-///
-struct _cef_value_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if the underlying data is valid. This will always be true
- // (1) for simple types. For complex types (binary, dictionary and list) the
- // underlying data may become invalid if owned by another object (e.g. list or
- // dictionary) and that other object is then modified or destroyed. This value
- // object can be re-used by calling Set*() even if the underlying data is
- // invalid.
- ///
- int function (_cef_value_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if the underlying data is owned by another object.
- ///
- int function (_cef_value_t* self) nothrow is_owned;
-
- ///
- // Returns true (1) if the underlying data is read-only. Some APIs may expose
- // read-only objects.
- ///
- int function (_cef_value_t* self) nothrow is_read_only;
-
- ///
- // Returns true (1) if this object and |that| object have the same underlying
- // data. If true (1) modifications to this object will also affect |that|
- // object and vice-versa.
- ///
- int function (_cef_value_t* self, _cef_value_t* that) nothrow is_same;
-
- ///
- // Returns true (1) if this object and |that| object have an equivalent
- // underlying value but are not necessarily the same object.
- ///
- int function (_cef_value_t* self, _cef_value_t* that) nothrow is_equal;
-
- ///
- // Returns a copy of this object. The underlying data will also be copied.
- ///
- _cef_value_t* function (_cef_value_t* self) nothrow copy;
-
- ///
- // Returns the underlying value type.
- ///
- cef_value_type_t function (_cef_value_t* self) nothrow get_type;
-
- ///
- // Returns the underlying value as type bool.
- ///
- int function (_cef_value_t* self) nothrow get_bool;
-
- ///
- // Returns the underlying value as type int.
- ///
- int function (_cef_value_t* self) nothrow get_int;
-
- ///
- // Returns the underlying value as type double.
- ///
- double function (_cef_value_t* self) nothrow get_double;
-
- ///
- // Returns the underlying value as type string.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_value_t* self) nothrow get_string;
-
- ///
- // Returns the underlying value as type binary. The returned reference may
- // become invalid if the value is owned by another object or if ownership is
- // transferred to another object in the future. To maintain a reference to the
- // value after assigning ownership to a dictionary or list pass this object to
- // the set_value() function instead of passing the returned reference to
- // set_binary().
- ///
- _cef_binary_value_t* function (_cef_value_t* self) nothrow get_binary;
-
- ///
- // Returns the underlying value as type dictionary. The returned reference may
- // become invalid if the value is owned by another object or if ownership is
- // transferred to another object in the future. To maintain a reference to the
- // value after assigning ownership to a dictionary or list pass this object to
- // the set_value() function instead of passing the returned reference to
- // set_dictionary().
- ///
- _cef_dictionary_value_t* function (_cef_value_t* self) nothrow get_dictionary;
-
- ///
- // Returns the underlying value as type list. The returned reference may
- // become invalid if the value is owned by another object or if ownership is
- // transferred to another object in the future. To maintain a reference to the
- // value after assigning ownership to a dictionary or list pass this object to
- // the set_value() function instead of passing the returned reference to
- // set_list().
- ///
- _cef_list_value_t* function (_cef_value_t* self) nothrow get_list;
-
- ///
- // Sets the underlying value as type null. Returns true (1) if the value was
- // set successfully.
- ///
- int function (_cef_value_t* self) nothrow set_null;
-
- ///
- // Sets the underlying value as type bool. Returns true (1) if the value was
- // set successfully.
- ///
- int function (_cef_value_t* self, int value) nothrow set_bool;
-
- ///
- // Sets the underlying value as type int. Returns true (1) if the value was
- // set successfully.
- ///
- int function (_cef_value_t* self, int value) nothrow set_int;
-
- ///
- // Sets the underlying value as type double. Returns true (1) if the value was
- // set successfully.
- ///
- int function (_cef_value_t* self, double value) nothrow set_double;
-
- ///
- // Sets the underlying value as type string. Returns true (1) if the value was
- // set successfully.
- ///
- int function (_cef_value_t* self, const(cef_string_t)* value) nothrow set_string;
-
- ///
- // Sets the underlying value as type binary. Returns true (1) if the value was
- // set successfully. This object keeps a reference to |value| and ownership of
- // the underlying data remains unchanged.
- ///
- int function (_cef_value_t* self, _cef_binary_value_t* value) nothrow set_binary;
-
- ///
- // Sets the underlying value as type dict. Returns true (1) if the value was
- // set successfully. This object keeps a reference to |value| and ownership of
- // the underlying data remains unchanged.
- ///
- int function (
- _cef_value_t* self,
- _cef_dictionary_value_t* value) nothrow set_dictionary;
-
- ///
- // Sets the underlying value as type list. Returns true (1) if the value was
- // set successfully. This object keeps a reference to |value| and ownership of
- // the underlying data remains unchanged.
- ///
- int function (_cef_value_t* self, _cef_list_value_t* value) nothrow set_list;
-}
-
-alias cef_value_t = _cef_value_t;
-
-///
-// Creates a new object.
-///
-cef_value_t* cef_value_create ();
-
-///
-// Structure representing a binary value. Can be used on any process and thread.
-///
-struct _cef_binary_value_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. This object may become invalid if
- // the underlying data is owned by another object (e.g. list or dictionary)
- // and that other object is then modified or destroyed. Do not call any other
- // functions if this function returns false (0).
- ///
- int function (_cef_binary_value_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if this object is currently owned by another object.
- ///
- int function (_cef_binary_value_t* self) nothrow is_owned;
-
- ///
- // Returns true (1) if this object and |that| object have the same underlying
- // data.
- ///
- int function (
- _cef_binary_value_t* self,
- _cef_binary_value_t* that) nothrow is_same;
-
- ///
- // Returns true (1) if this object and |that| object have an equivalent
- // underlying value but are not necessarily the same object.
- ///
- int function (
- _cef_binary_value_t* self,
- _cef_binary_value_t* that) nothrow is_equal;
-
- ///
- // Returns a copy of this object. The data in this object will also be copied.
- ///
- _cef_binary_value_t* function (_cef_binary_value_t* self) nothrow copy;
-
- ///
- // Returns the data size.
- ///
- size_t function (_cef_binary_value_t* self) nothrow get_size;
-
- ///
- // Read up to |buffer_size| number of bytes into |buffer|. Reading begins at
- // the specified byte |data_offset|. Returns the number of bytes read.
- ///
- size_t function (
- _cef_binary_value_t* self,
- void* buffer,
- size_t buffer_size,
- size_t data_offset) nothrow get_data;
-}
-
-alias cef_binary_value_t = _cef_binary_value_t;
-
-///
-// Creates a new object that is not owned by any other object. The specified
-// |data| will be copied.
-///
-cef_binary_value_t* cef_binary_value_create (
- const(void)* data,
- size_t data_size);
-
-///
-// Structure representing a dictionary value. Can be used on any process and
-// thread.
-///
-struct _cef_dictionary_value_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. This object may become invalid if
- // the underlying data is owned by another object (e.g. list or dictionary)
- // and that other object is then modified or destroyed. Do not call any other
- // functions if this function returns false (0).
- ///
- int function (_cef_dictionary_value_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if this object is currently owned by another object.
- ///
- int function (_cef_dictionary_value_t* self) nothrow is_owned;
-
- ///
- // Returns true (1) if the values of this object are read-only. Some APIs may
- // expose read-only objects.
- ///
- int function (_cef_dictionary_value_t* self) nothrow is_read_only;
-
- ///
- // Returns true (1) if this object and |that| object have the same underlying
- // data. If true (1) modifications to this object will also affect |that|
- // object and vice-versa.
- ///
- int function (
- _cef_dictionary_value_t* self,
- _cef_dictionary_value_t* that) nothrow is_same;
-
- ///
- // Returns true (1) if this object and |that| object have an equivalent
- // underlying value but are not necessarily the same object.
- ///
- int function (
- _cef_dictionary_value_t* self,
- _cef_dictionary_value_t* that) nothrow is_equal;
-
- ///
- // Returns a writable copy of this object. If |exclude_NULL_children| is true
- // (1) any NULL dictionaries or lists will be excluded from the copy.
- ///
- _cef_dictionary_value_t* function (
- _cef_dictionary_value_t* self,
- int exclude_empty_children) nothrow copy;
-
- ///
- // Returns the number of values.
- ///
- size_t function (_cef_dictionary_value_t* self) nothrow get_size;
-
- ///
- // Removes all values. Returns true (1) on success.
- ///
- int function (_cef_dictionary_value_t* self) nothrow clear;
-
- ///
- // Returns true (1) if the current dictionary has a value for the given key.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow has_key;
-
- ///
- // Reads all keys for this dictionary into the specified vector.
- ///
- int function (
- _cef_dictionary_value_t* self,
- cef_string_list_t keys) nothrow get_keys;
-
- ///
- // Removes the value at the specified key. Returns true (1) is the value was
- // removed successfully.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow remove;
-
- ///
- // Returns the value type for the specified key.
- ///
- cef_value_type_t function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_type;
-
- ///
- // Returns the value at the specified key. For simple types the returned value
- // will copy existing data and modifications to the value will not modify this
- // object. For complex types (binary, dictionary and list) the returned value
- // will reference existing data and modifications to the value will modify
- // this object.
- ///
- _cef_value_t* function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_value;
-
- ///
- // Returns the value at the specified key as type bool.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_bool;
-
- ///
- // Returns the value at the specified key as type int.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_int;
-
- ///
- // Returns the value at the specified key as type double.
- ///
- double function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_double;
-
- ///
- // Returns the value at the specified key as type string.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_string;
-
- ///
- // Returns the value at the specified key as type binary. The returned value
- // will reference existing data.
- ///
- _cef_binary_value_t* function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_binary;
-
- ///
- // Returns the value at the specified key as type dictionary. The returned
- // value will reference existing data and modifications to the value will
- // modify this object.
- ///
- _cef_dictionary_value_t* function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_dictionary;
-
- ///
- // Returns the value at the specified key as type list. The returned value
- // will reference existing data and modifications to the value will modify
- // this object.
- ///
- _cef_list_value_t* function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow get_list;
-
- ///
- // Sets the value at the specified key. Returns true (1) if the value was set
- // successfully. If |value| represents simple data then the underlying data
- // will be copied and modifications to |value| will not modify this object. If
- // |value| represents complex data (binary, dictionary or list) then the
- // underlying data will be referenced and modifications to |value| will modify
- // this object.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- _cef_value_t* value) nothrow set_value;
-
- ///
- // Sets the value at the specified key as type null. Returns true (1) if the
- // value was set successfully.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key) nothrow set_null;
-
- ///
- // Sets the value at the specified key as type bool. Returns true (1) if the
- // value was set successfully.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- int value) nothrow set_bool;
-
- ///
- // Sets the value at the specified key as type int. Returns true (1) if the
- // value was set successfully.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- int value) nothrow set_int;
-
- ///
- // Sets the value at the specified key as type double. Returns true (1) if the
- // value was set successfully.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- double value) nothrow set_double;
-
- ///
- // Sets the value at the specified key as type string. Returns true (1) if the
- // value was set successfully.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- const(cef_string_t)* value) nothrow set_string;
-
- ///
- // Sets the value at the specified key as type binary. Returns true (1) if the
- // value was set successfully. If |value| is currently owned by another object
- // then the value will be copied and the |value| reference will not change.
- // Otherwise, ownership will be transferred to this object and the |value|
- // reference will be invalidated.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- _cef_binary_value_t* value) nothrow set_binary;
-
- ///
- // Sets the value at the specified key as type dict. Returns true (1) if the
- // value was set successfully. If |value| is currently owned by another object
- // then the value will be copied and the |value| reference will not change.
- // Otherwise, ownership will be transferred to this object and the |value|
- // reference will be invalidated.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- _cef_dictionary_value_t* value) nothrow set_dictionary;
-
- ///
- // Sets the value at the specified key as type list. Returns true (1) if the
- // value was set successfully. If |value| is currently owned by another object
- // then the value will be copied and the |value| reference will not change.
- // Otherwise, ownership will be transferred to this object and the |value|
- // reference will be invalidated.
- ///
- int function (
- _cef_dictionary_value_t* self,
- const(cef_string_t)* key,
- _cef_list_value_t* value) nothrow set_list;
-}
-
-alias cef_dictionary_value_t = _cef_dictionary_value_t;
-
-///
-// Creates a new object that is not owned by any other object.
-///
-cef_dictionary_value_t* cef_dictionary_value_create ();
-
-///
-// Structure representing a list value. Can be used on any process and thread.
-///
-struct _cef_list_value_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns true (1) if this object is valid. This object may become invalid if
- // the underlying data is owned by another object (e.g. list or dictionary)
- // and that other object is then modified or destroyed. Do not call any other
- // functions if this function returns false (0).
- ///
- int function (_cef_list_value_t* self) nothrow is_valid;
-
- ///
- // Returns true (1) if this object is currently owned by another object.
- ///
- int function (_cef_list_value_t* self) nothrow is_owned;
-
- ///
- // Returns true (1) if the values of this object are read-only. Some APIs may
- // expose read-only objects.
- ///
- int function (_cef_list_value_t* self) nothrow is_read_only;
-
- ///
- // Returns true (1) if this object and |that| object have the same underlying
- // data. If true (1) modifications to this object will also affect |that|
- // object and vice-versa.
- ///
- int function (_cef_list_value_t* self, _cef_list_value_t* that) nothrow is_same;
-
- ///
- // Returns true (1) if this object and |that| object have an equivalent
- // underlying value but are not necessarily the same object.
- ///
- int function (_cef_list_value_t* self, _cef_list_value_t* that) nothrow is_equal;
-
- ///
- // Returns a writable copy of this object.
- ///
- _cef_list_value_t* function (_cef_list_value_t* self) nothrow copy;
-
- ///
- // Sets the number of values. If the number of values is expanded all new
- // value slots will default to type null. Returns true (1) on success.
- ///
- int function (_cef_list_value_t* self, size_t size) nothrow set_size;
-
- ///
- // Returns the number of values.
- ///
- size_t function (_cef_list_value_t* self) nothrow get_size;
-
- ///
- // Removes all values. Returns true (1) on success.
- ///
- int function (_cef_list_value_t* self) nothrow clear;
-
- ///
- // Removes the value at the specified index.
- ///
- int function (_cef_list_value_t* self, size_t index) nothrow remove;
-
- ///
- // Returns the value type at the specified index.
- ///
- cef_value_type_t function (_cef_list_value_t* self, size_t index) nothrow get_type;
-
- ///
- // Returns the value at the specified index. For simple types the returned
- // value will copy existing data and modifications to the value will not
- // modify this object. For complex types (binary, dictionary and list) the
- // returned value will reference existing data and modifications to the value
- // will modify this object.
- ///
- _cef_value_t* function (_cef_list_value_t* self, size_t index) nothrow get_value;
-
- ///
- // Returns the value at the specified index as type bool.
- ///
- int function (_cef_list_value_t* self, size_t index) nothrow get_bool;
-
- ///
- // Returns the value at the specified index as type int.
- ///
- int function (_cef_list_value_t* self, size_t index) nothrow get_int;
-
- ///
- // Returns the value at the specified index as type double.
- ///
- double function (_cef_list_value_t* self, size_t index) nothrow get_double;
-
- ///
- // Returns the value at the specified index as type string.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_list_value_t* self,
- size_t index) nothrow get_string;
-
- ///
- // Returns the value at the specified index as type binary. The returned value
- // will reference existing data.
- ///
- _cef_binary_value_t* function (
- _cef_list_value_t* self,
- size_t index) nothrow get_binary;
-
- ///
- // Returns the value at the specified index as type dictionary. The returned
- // value will reference existing data and modifications to the value will
- // modify this object.
- ///
- _cef_dictionary_value_t* function (
- _cef_list_value_t* self,
- size_t index) nothrow get_dictionary;
-
- ///
- // Returns the value at the specified index as type list. The returned value
- // will reference existing data and modifications to the value will modify
- // this object.
- ///
- _cef_list_value_t* function (
- _cef_list_value_t* self,
- size_t index) nothrow get_list;
-
- ///
- // Sets the value at the specified index. Returns true (1) if the value was
- // set successfully. If |value| represents simple data then the underlying
- // data will be copied and modifications to |value| will not modify this
- // object. If |value| represents complex data (binary, dictionary or list)
- // then the underlying data will be referenced and modifications to |value|
- // will modify this object.
- ///
- int function (
- _cef_list_value_t* self,
- size_t index,
- _cef_value_t* value) nothrow set_value;
-
- ///
- // Sets the value at the specified index as type null. Returns true (1) if the
- // value was set successfully.
- ///
- int function (_cef_list_value_t* self, size_t index) nothrow set_null;
-
- ///
- // Sets the value at the specified index as type bool. Returns true (1) if the
- // value was set successfully.
- ///
- int function (_cef_list_value_t* self, size_t index, int value) nothrow set_bool;
-
- ///
- // Sets the value at the specified index as type int. Returns true (1) if the
- // value was set successfully.
- ///
- int function (_cef_list_value_t* self, size_t index, int value) nothrow set_int;
-
- ///
- // Sets the value at the specified index as type double. Returns true (1) if
- // the value was set successfully.
- ///
- int function (
- _cef_list_value_t* self,
- size_t index,
- double value) nothrow set_double;
-
- ///
- // Sets the value at the specified index as type string. Returns true (1) if
- // the value was set successfully.
- ///
- int function (
- _cef_list_value_t* self,
- size_t index,
- const(cef_string_t)* value) nothrow set_string;
-
- ///
- // Sets the value at the specified index as type binary. Returns true (1) if
- // the value was set successfully. If |value| is currently owned by another
- // object then the value will be copied and the |value| reference will not
- // change. Otherwise, ownership will be transferred to this object and the
- // |value| reference will be invalidated.
- ///
- int function (
- _cef_list_value_t* self,
- size_t index,
- _cef_binary_value_t* value) nothrow set_binary;
-
- ///
- // Sets the value at the specified index as type dict. Returns true (1) if the
- // value was set successfully. If |value| is currently owned by another object
- // then the value will be copied and the |value| reference will not change.
- // Otherwise, ownership will be transferred to this object and the |value|
- // reference will be invalidated.
- ///
- int function (
- _cef_list_value_t* self,
- size_t index,
- _cef_dictionary_value_t* value) nothrow set_dictionary;
-
- ///
- // Sets the value at the specified index as type list. Returns true (1) if the
- // value was set successfully. If |value| is currently owned by another object
- // then the value will be copied and the |value| reference will not change.
- // Otherwise, ownership will be transferred to this object and the |value|
- // reference will be invalidated.
- ///
- int function (
- _cef_list_value_t* self,
- size_t index,
- _cef_list_value_t* value) nothrow set_list;
-}
-
-alias cef_list_value_t = _cef_list_value_t;
-
-///
-// Creates a new object that is not owned by any other object.
-///
-cef_list_value_t* cef_list_value_create ();
-
-// CEF_INCLUDE_CAPI_CEF_VALUES_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=aedfa5758cbf37dff244c065d55d273231470877$
-//
-
-extern (C):
-
-///
-// WaitableEvent is a thread synchronization tool that allows one thread to wait
-// for another thread to finish some work. This is equivalent to using a
-// Lock+ConditionVariable to protect a simple boolean value. However, using
-// WaitableEvent in conjunction with a Lock to wait for a more complex state
-// change (e.g., for an item to be added to a queue) is not recommended. In that
-// case consider using a ConditionVariable instead of a WaitableEvent. It is
-// safe to create and/or signal a WaitableEvent from any thread. Blocking on a
-// WaitableEvent by calling the *wait() functions is not allowed on the browser
-// process UI or IO threads.
-///
-struct _cef_waitable_event_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Put the event in the un-signaled state.
- ///
- void function (_cef_waitable_event_t* self) nothrow reset;
-
- ///
- // Put the event in the signaled state. This causes any thread blocked on Wait
- // to be woken up.
- ///
- void function (_cef_waitable_event_t* self) nothrow signal;
-
- ///
- // Returns true (1) if the event is in the signaled state, else false (0). If
- // the event was created with |automatic_reset| set to true (1) then calling
- // this function will also cause a reset.
- ///
- int function (_cef_waitable_event_t* self) nothrow is_signaled;
-
- ///
- // Wait indefinitely for the event to be signaled. This function will not
- // return until after the call to signal() has completed. This function cannot
- // be called on the browser process UI or IO threads.
- ///
- void function (_cef_waitable_event_t* self) nothrow wait;
-
- ///
- // Wait up to |max_ms| milliseconds for the event to be signaled. Returns true
- // (1) if the event was signaled. A return value of false (0) does not
- // necessarily mean that |max_ms| was exceeded. This function will not return
- // until after the call to signal() has completed. This function cannot be
- // called on the browser process UI or IO threads.
- ///
- int function (_cef_waitable_event_t* self, int64 max_ms) nothrow timed_wait;
-}
-
-alias cef_waitable_event_t = _cef_waitable_event_t;
-
-///
-// Create a new waitable event. If |automatic_reset| is true (1) then the event
-// state is automatically reset to un-signaled after a single waiting thread has
-// been released; otherwise, the state remains signaled until reset() is called
-// manually. If |initially_signaled| is true (1) then the event will start in
-// the signaled state.
-///
-cef_waitable_event_t* cef_waitable_event_create (
- int automatic_reset,
- int initially_signaled);
-
-// CEF_INCLUDE_CAPI_CEF_WAITABLE_EVENT_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=f1b2b6203d45fdf76d72ea1e79fcef0bb2a26138$
-//
-
-extern (C):
-
-///
-// Information about a specific web plugin.
-///
-struct _cef_web_plugin_info_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the plugin name (i.e. Flash).
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_web_plugin_info_t* self) nothrow get_name;
-
- ///
- // Returns the plugin file path (DLL/bundle/library).
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_web_plugin_info_t* self) nothrow get_path;
-
- ///
- // Returns the version of the plugin (may be OS-specific).
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_web_plugin_info_t* self) nothrow get_version;
-
- ///
- // Returns a description of the plugin from the version information.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_web_plugin_info_t* self) nothrow get_description;
-}
-
-alias cef_web_plugin_info_t = _cef_web_plugin_info_t;
-
-///
-// Structure to implement for visiting web plugin information. The functions of
-// this structure will be called on the browser process UI thread.
-///
-struct _cef_web_plugin_info_visitor_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called once for each plugin. |count| is the 0-based
- // index for the current plugin. |total| is the total number of plugins.
- // Return false (0) to stop visiting plugins. This function may never be
- // called if no plugins are found.
- ///
- int function (
- _cef_web_plugin_info_visitor_t* self,
- _cef_web_plugin_info_t* info,
- int count,
- int total) nothrow visit;
-}
-
-alias cef_web_plugin_info_visitor_t = _cef_web_plugin_info_visitor_t;
-
-///
-// Structure to implement for receiving unstable plugin information. The
-// functions of this structure will be called on the browser process IO thread.
-///
-struct _cef_web_plugin_unstable_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called for the requested plugin. |unstable| will be
- // true (1) if the plugin has reached the crash count threshold of 3 times in
- // 120 seconds.
- ///
- void function (
- _cef_web_plugin_unstable_callback_t* self,
- const(cef_string_t)* path,
- int unstable) nothrow is_unstable;
-}
-
-alias cef_web_plugin_unstable_callback_t = _cef_web_plugin_unstable_callback_t;
-
-///
-// Implement this structure to receive notification when CDM registration is
-// complete. The functions of this structure will be called on the browser
-// process UI thread.
-///
-struct _cef_register_cdm_callback_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Method that will be called when CDM registration is complete. |result| will
- // be CEF_CDM_REGISTRATION_ERROR_NONE if registration completed successfully.
- // Otherwise, |result| and |error_message| will contain additional information
- // about why registration failed.
- ///
- void function (
- _cef_register_cdm_callback_t* self,
- cef_cdm_registration_error_t result,
- const(cef_string_t)* error_message) nothrow on_cdm_registration_complete;
+ int x;
+ int y;
}
-alias cef_register_cdm_callback_t = _cef_register_cdm_callback_t;
-
-///
-// Visit web plugin information. Can be called on any thread in the browser
-// process.
-///
-void cef_visit_web_plugin_info (cef_web_plugin_info_visitor_t* visitor);
-
-///
-// Cause the plugin list to refresh the next time it is accessed regardless of
-// whether it has already been loaded. Can be called on any thread in the
-// browser process.
-///
-void cef_refresh_web_plugins ();
-
-///
-// Unregister an internal plugin. This may be undone the next time
-// cef_refresh_web_plugins() is called. Can be called on any thread in the
-// browser process.
-///
-void cef_unregister_internal_web_plugin (const(cef_string_t)* path);
-
-///
-// Register a plugin crash. Can be called on any thread in the browser process
-// but will be executed on the IO thread.
-///
-void cef_register_web_plugin_crash (const(cef_string_t)* path);
-
-///
-// Query if a plugin is unstable. Can be called on any thread in the browser
-// process.
-///
-void cef_is_web_plugin_unstable (
- const(cef_string_t)* path,
- cef_web_plugin_unstable_callback_t* callback);
-
-///
-// Register the Widevine CDM plugin.
-//
-// The client application is responsible for downloading an appropriate
-// platform-specific CDM binary distribution from Google, extracting the
-// contents, and building the required directory structure on the local machine.
-// The cef_browser_host_t::StartDownload function and CefZipArchive structure
-// can be used to implement this functionality in CEF. Contact Google via
-// https://www.widevine.com/contact.html for details on CDM download.
-//
-// |path| is a directory that must contain the following files:
-// 1. manifest.json file from the CDM binary distribution (see below).
-// 2. widevinecdm file from the CDM binary distribution (e.g.
-// widevinecdm.dll on on Windows, libwidevinecdm.dylib on OS X,
-// libwidevinecdm.so on Linux).
-//
-// If any of these files are missing or if the manifest file has incorrect
-// contents the registration will fail and |callback| will receive a |result|
-// value of CEF_CDM_REGISTRATION_ERROR_INCORRECT_CONTENTS.
-//
-// The manifest.json file must contain the following keys:
-// A. "os": Supported OS (e.g. "mac", "win" or "linux").
-// B. "arch": Supported architecture (e.g. "ia32" or "x64").
-// C. "x-cdm-module-versions": Module API version (e.g. "4").
-// D. "x-cdm-interface-versions": Interface API version (e.g. "8").
-// E. "x-cdm-host-versions": Host API version (e.g. "8").
-// F. "version": CDM version (e.g. "1.4.8.903").
-// G. "x-cdm-codecs": List of supported codecs (e.g. "vp8,vp9.0,avc1").
-//
-// A through E are used to verify compatibility with the current Chromium
-// version. If the CDM is not compatible the registration will fail and
-// |callback| will receive a |result| value of
-// CEF_CDM_REGISTRATION_ERROR_INCOMPATIBLE.
-//
-// |callback| will be executed asynchronously once registration is complete.
-//
-// On Linux this function must be called before cef_initialize() and the
-// registration cannot be changed during runtime. If registration is not
-// supported at the time that cef_register_widevine_cdm() is called then
-// |callback| will receive a |result| value of
-// CEF_CDM_REGISTRATION_ERROR_NOT_SUPPORTED.
-///
-void cef_register_widevine_cdm (
- const(cef_string_t)* path,
- cef_register_cdm_callback_t* callback);
-
-// CEF_INCLUDE_CAPI_CEF_WEB_PLUGIN_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=2d04c2cc1791b90ddb9333fe830ad07042e9df2d$
-//
-
-extern (C):
-
-///
-// Structure representing the issuer or subject field of an X.509 certificate.
-///
-struct _cef_x509cert_principal_t
-{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns a name that can be used to represent the issuer. It tries in this
- // order: Common Name (CN), Organization Name (O) and Organizational Unit Name
- // (OU) and returns the first non-NULL one found.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_x509cert_principal_t* self) nothrow get_display_name;
-
- ///
- // Returns the common name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_x509cert_principal_t* self) nothrow get_common_name;
-
- ///
- // Returns the locality name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_x509cert_principal_t* self) nothrow get_locality_name;
-
- ///
- // Returns the state or province name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_x509cert_principal_t* self) nothrow get_state_or_province_name;
-
- ///
- // Returns the country name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_x509cert_principal_t* self) nothrow get_country_name;
-
- ///
- // Retrieve the list of street addresses.
- ///
- void function (
- _cef_x509cert_principal_t* self,
- cef_string_list_t addresses) nothrow get_street_addresses;
-
- ///
- // Retrieve the list of organization names.
- ///
- void function (
- _cef_x509cert_principal_t* self,
- cef_string_list_t names) nothrow get_organization_names;
- ///
- // Retrieve the list of organization unit names.
- ///
- void function (
- _cef_x509cert_principal_t* self,
- cef_string_list_t names) nothrow get_organization_unit_names;
-
- ///
- // Retrieve the list of domain components.
- ///
- void function (
- _cef_x509cert_principal_t* self,
- cef_string_list_t components) nothrow get_domain_components;
-}
-
-alias cef_x509cert_principal_t = _cef_x509cert_principal_t;
///
-// Structure representing a X.509 certificate.
+// Structure representing a rectangle.
///
-struct _cef_x509certificate_t
+struct cef_rect_t
{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Returns the subject of the X.509 certificate. For HTTPS server certificates
- // this represents the web server. The common name of the subject should
- // match the host name of the web server.
- ///
- _cef_x509cert_principal_t* function (
- _cef_x509certificate_t* self) nothrow get_subject;
-
- ///
- // Returns the issuer of the X.509 certificate.
- ///
- _cef_x509cert_principal_t* function (
- _cef_x509certificate_t* self) nothrow get_issuer;
-
- ///
- // Returns the DER encoded serial number for the X.509 certificate. The value
- // possibly includes a leading 00 byte.
- ///
- _cef_binary_value_t* function (
- _cef_x509certificate_t* self) nothrow get_serial_number;
-
- ///
- // Returns the date before which the X.509 certificate is invalid.
- // CefTime.GetTimeT() will return 0 if no date was specified.
- ///
- cef_time_t function (_cef_x509certificate_t* self) nothrow get_valid_start;
-
- ///
- // Returns the date after which the X.509 certificate is invalid.
- // CefTime.GetTimeT() will return 0 if no date was specified.
- ///
- cef_time_t function (_cef_x509certificate_t* self) nothrow get_valid_expiry;
-
- ///
- // Returns the DER encoded data for the X.509 certificate.
- ///
- _cef_binary_value_t* function (
- _cef_x509certificate_t* self) nothrow get_derencoded;
-
- ///
- // Returns the PEM encoded data for the X.509 certificate.
- ///
- _cef_binary_value_t* function (
- _cef_x509certificate_t* self) nothrow get_pemencoded;
-
- ///
- // Returns the number of certificates in the issuer chain. If 0, the
- // certificate is self-signed.
- ///
- size_t function (_cef_x509certificate_t* self) nothrow get_issuer_chain_size;
-
- ///
- // Returns the DER encoded data for the certificate issuer chain. If we failed
- // to encode a certificate in the chain it is still present in the array but
- // is an NULL string.
- ///
- void function (
- _cef_x509certificate_t* self,
- size_t* chainCount,
- _cef_binary_value_t** chain) nothrow get_derencoded_issuer_chain;
-
- ///
- // Returns the PEM encoded data for the certificate issuer chain. If we failed
- // to encode a certificate in the chain it is still present in the array but
- // is an NULL string.
- ///
- void function (
- _cef_x509certificate_t* self,
- size_t* chainCount,
- _cef_binary_value_t** chain) nothrow get_pemencoded_issuer_chain;
+ int x;
+ int y;
+ int width;
+ int height;
}
-alias cef_x509certificate_t = _cef_x509certificate_t;
-
-// CEF_INCLUDE_CAPI_CEF_X509_CERTIFICATE_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=64f6b6477ec81b1d64517cf0af2e3b2121ff39bd$
-//
-extern (C):
///
-// Structure that supports the reading of XML data via the libxml streaming API.
-// The functions of this structure should only be called on the thread that
-// creates the object.
+// Structure representing a size.
///
-struct _cef_xml_reader_t
+struct cef_size_t
{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Moves the cursor to the next node in the document. This function must be
- // called at least once to set the current cursor position. Returns true (1)
- // if the cursor position was set successfully.
- ///
- int function (_cef_xml_reader_t* self) nothrow move_to_next_node;
-
- ///
- // Close the document. This should be called directly to ensure that cleanup
- // occurs on the correct thread.
- ///
- int function (_cef_xml_reader_t* self) nothrow close;
-
- ///
- // Returns true (1) if an error has been reported by the XML parser.
- ///
- int function (_cef_xml_reader_t* self) nothrow has_error;
-
- ///
- // Returns the error string.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_error;
-
- // The below functions retrieve data for the node at the current cursor
- // position.
-
- ///
- // Returns the node type.
- ///
- cef_xml_node_type_t function (_cef_xml_reader_t* self) nothrow get_type;
-
- ///
- // Returns the node depth. Depth starts at 0 for the root node.
- ///
- int function (_cef_xml_reader_t* self) nothrow get_depth;
-
- ///
- // Returns the local name. See http://www.w3.org/TR/REC-xml-names/#NT-
- // LocalPart for additional details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_local_name;
-
- ///
- // Returns the namespace prefix. See http://www.w3.org/TR/REC-xml-names/ for
- // additional details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_prefix;
-
- ///
- // Returns the qualified name, equal to (Prefix:)LocalName. See
- // http://www.w3.org/TR/REC-xml-names/#ns-qualnames for additional details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_xml_reader_t* self) nothrow get_qualified_name;
-
- ///
- // Returns the URI defining the namespace associated with the node. See
- // http://www.w3.org/TR/REC-xml-names/ for additional details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_namespace_uri;
-
- ///
- // Returns the base URI of the node. See http://www.w3.org/TR/xmlbase/ for
- // additional details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_base_uri;
-
- ///
- // Returns the xml:lang scope within which the node resides. See
- // http://www.w3.org/TR/REC-xml/#sec-lang-tag for additional details.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_xml_lang;
-
- ///
- // Returns true (1) if the node represents an NULL element. is considered
- // NULL but is not.
- ///
- int function (_cef_xml_reader_t* self) nothrow is_empty_element;
-
- ///
- // Returns true (1) if the node has a text value.
- ///
- int function (_cef_xml_reader_t* self) nothrow has_value;
-
- ///
- // Returns the text value.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_value;
-
- ///
- // Returns true (1) if the node has attributes.
- ///
- int function (_cef_xml_reader_t* self) nothrow has_attributes;
-
- ///
- // Returns the number of attributes.
- ///
- size_t function (_cef_xml_reader_t* self) nothrow get_attribute_count;
-
- ///
- // Returns the value of the attribute at the specified 0-based index.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_xml_reader_t* self,
- int index) nothrow get_attribute_byindex;
-
- ///
- // Returns the value of the attribute with the specified qualified name.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_xml_reader_t* self,
- const(cef_string_t)* qualifiedName) nothrow get_attribute_byqname;
-
- ///
- // Returns the value of the attribute with the specified local name and
- // namespace URI.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (
- _cef_xml_reader_t* self,
- const(cef_string_t)* localName,
- const(cef_string_t)* namespaceURI) nothrow get_attribute_bylname;
-
- ///
- // Returns an XML representation of the current node's children.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_inner_xml;
-
- ///
- // Returns an XML representation of the current node including its children.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_xml_reader_t* self) nothrow get_outer_xml;
-
- ///
- // Returns the line number for the current node.
- ///
- int function (_cef_xml_reader_t* self) nothrow get_line_number;
-
- // Attribute nodes are not traversed by default. The below functions can be
- // used to move the cursor to an attribute node. move_to_carrying_element()
- // can be called afterwards to return the cursor to the carrying element. The
- // depth of an attribute node will be 1 + the depth of the carrying element.
-
- ///
- // Moves the cursor to the attribute at the specified 0-based index. Returns
- // true (1) if the cursor position was set successfully.
- ///
- int function (
- _cef_xml_reader_t* self,
- int index) nothrow move_to_attribute_byindex;
-
- ///
- // Moves the cursor to the attribute with the specified qualified name.
- // Returns true (1) if the cursor position was set successfully.
- ///
- int function (
- _cef_xml_reader_t* self,
- const(cef_string_t)* qualifiedName) nothrow move_to_attribute_byqname;
-
- ///
- // Moves the cursor to the attribute with the specified local name and
- // namespace URI. Returns true (1) if the cursor position was set
- // successfully.
- ///
- int function (
- _cef_xml_reader_t* self,
- const(cef_string_t)* localName,
- const(cef_string_t)* namespaceURI) nothrow move_to_attribute_bylname;
-
- ///
- // Moves the cursor to the first attribute in the current element. Returns
- // true (1) if the cursor position was set successfully.
- ///
- int function (_cef_xml_reader_t* self) nothrow move_to_first_attribute;
-
- ///
- // Moves the cursor to the next attribute in the current element. Returns true
- // (1) if the cursor position was set successfully.
- ///
- int function (_cef_xml_reader_t* self) nothrow move_to_next_attribute;
-
- ///
- // Moves the cursor back to the carrying element. Returns true (1) if the
- // cursor position was set successfully.
- ///
- int function (_cef_xml_reader_t* self) nothrow move_to_carrying_element;
+ int width;
+ int height;
}
-alias cef_xml_reader_t = _cef_xml_reader_t;
-
-///
-// Create a new cef_xml_reader_t object. The returned object's functions can
-// only be called from the thread that created the object.
-///
-cef_xml_reader_t* cef_xml_reader_create (
- _cef_stream_reader_t* stream,
- cef_xml_encoding_type_t encodingType,
- const(cef_string_t)* URI);
-
-// CEF_INCLUDE_CAPI_CEF_XML_READER_CAPI_H_
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the name Chromium Embedded
-// Framework nor the names of its contributors may be used to endorse
-// or promote products derived from this software without specific prior
-// written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// ---------------------------------------------------------------------------
-//
-// This file was generated by the CEF translator tool and should not edited
-// by hand. See the translator.README.txt file in the tools directory for
-// more information.
-//
-// $hash=f8b7ec1654c7d62153e2670b52ed18eb4c9c58d5$
-//
-extern (C):
///
-// Structure that supports the reading of zip archives via the zlib unzip API.
-// The functions of this structure should only be called on the thread that
-// creates the object.
+// Structure representing insets.
///
-struct _cef_zip_reader_t
+struct cef_insets_t
{
- ///
- // Base structure.
- ///
- cef_base_ref_counted_t base;
-
- ///
- // Moves the cursor to the first file in the archive. Returns true (1) if the
- // cursor position was set successfully.
- ///
- int function (_cef_zip_reader_t* self) nothrow move_to_first_file;
-
- ///
- // Moves the cursor to the next file in the archive. Returns true (1) if the
- // cursor position was set successfully.
- ///
- int function (_cef_zip_reader_t* self) nothrow move_to_next_file;
-
- ///
- // Moves the cursor to the specified file in the archive. If |caseSensitive|
- // is true (1) then the search will be case sensitive. Returns true (1) if the
- // cursor position was set successfully.
- ///
- int function (
- _cef_zip_reader_t* self,
- const(cef_string_t)* fileName,
- int caseSensitive) nothrow move_to_file;
-
- ///
- // Closes the archive. This should be called directly to ensure that cleanup
- // occurs on the correct thread.
- ///
- int function (_cef_zip_reader_t* self) nothrow close;
-
- // The below functions act on the file at the current cursor position.
-
- ///
- // Returns the name of the file.
- ///
- // The resulting string must be freed by calling cef_string_userfree_free().
- cef_string_userfree_t function (_cef_zip_reader_t* self) nothrow get_file_name;
-
- ///
- // Returns the uncompressed size of the file.
- ///
- int64 function (_cef_zip_reader_t* self) nothrow get_file_size;
-
- ///
- // Returns the last modified timestamp for the file.
- ///
- cef_time_t function (_cef_zip_reader_t* self) nothrow get_file_last_modified;
-
- ///
- // Opens the file for reading of uncompressed data. A read password may
- // optionally be specified.
- ///
- int function (
- _cef_zip_reader_t* self,
- const(cef_string_t)* password) nothrow open_file;
-
- ///
- // Closes the file.
- ///
- int function (_cef_zip_reader_t* self) nothrow close_file;
-
- ///
- // Read uncompressed file contents into the specified buffer. Returns < 0 if
- // an error occurred, 0 if at the end of file, or the number of bytes read.
- ///
- int function (
- _cef_zip_reader_t* self,
- void* buffer,
- size_t bufferSize) nothrow read_file;
-
- ///
- // Returns the current offset in the uncompressed file contents.
- ///
- int64 function (_cef_zip_reader_t* self) nothrow tell;
-
- ///
- // Returns true (1) if at end of the file contents.
- ///
- int function (_cef_zip_reader_t* self) nothrow eof;
+ int top;
+ int left;
+ int bottom;
+ int right;
}
-alias cef_zip_reader_t = _cef_zip_reader_t;
-///
-// Create a new cef_zip_reader_t object. The returned object's functions can
-// only be called from the thread that created the object.
-///
-cef_zip_reader_t* cef_zip_reader_create (_cef_stream_reader_t* stream);
-// CEF_INCLUDE_CAPI_CEF_ZIP_READER_CAPI_H_
+// CEF_INCLUDE_INTERNAL_CEF_TYPES_GEOMETRY_H_
// Copyright (c) 2014 Marshall A. Greenblatt. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
@@ -14705,6 +1662,30 @@ extern (C):
// in a known order. Equivalent to the SkColor type.
alias cef_color_t = uint;
+// Return the alpha byte from a cef_color_t value.
+
+
+// Return the red byte from a cef_color_t value.
+
+
+// Return the green byte from a cef_color_t value.
+
+
+// Return the blue byte from a cef_color_t value.
+
+
+// Return an cef_color_t value with the specified byte component values.
+
+
+// Return an int64 value with the specified low and high int32 component values.
+
+
+// Return the low int32 value from an int64 value.
+
+
+// Return the high int32 value from an int64 value.
+
+
///
// Log severity levels.
///
@@ -14778,7 +1759,7 @@ enum cef_state_t
// values. Many of these and other settings can also configured using command-
// line switches.
///
-struct _cef_settings_t
+struct cef_settings_t
{
///
// Size of this structure.
@@ -14870,7 +1851,9 @@ struct _cef_settings_t
// in-memory caches are used for storage and no data is persisted to disk.
// HTML5 databases such as localStorage will only persist across sessions if a
// cache path is specified. Can be overridden for individual CefRequestContext
- // instances via the CefRequestContextSettings.cache_path value.
+ // instances via the CefRequestContextSettings.cache_path value. When using
+ // the Chrome runtime the "default" profile will be used if |cache_path| and
+ // |root_cache_path| have the same value.
///
cef_string_t cache_path;
@@ -14886,13 +1869,14 @@ struct _cef_settings_t
cef_string_t root_cache_path;
///
- // The location where user data such as spell checking dictionary files will
- // be stored on disk. If this value is empty then the default
- // platform-specific user data directory will be used ("~/.cef_user_data"
- // directory on Linux, "~/Library/Application Support/CEF/User Data" directory
- // on Mac OS X, "Local Settings\Application Data\CEF\User Data" directory
- // under the user profile directory on Windows). If this value is non-empty
- // then it must be an absolute path.
+ // The location where user data such as the Widevine CDM module and spell
+ // checking dictionary files will be stored on disk. If this value is empty
+ // then the default platform-specific user data directory will be used
+ // ("~/.config/cef_user_data" directory on Linux, "~/Library/Application
+ // Support/CEF/User Data" directory on MacOS, "AppData\Local\CEF\User Data"
+ // directory under the user profile directory on Windows). If this value is
+ // non-empty then it must be an absolute path. When using the Chrome runtime
+ // this value will be ignored in favor of the |root_cache_path| value.
///
cef_string_t user_data_path;
@@ -14929,9 +1913,9 @@ struct _cef_settings_t
// Value that will be inserted as the product portion of the default
// User-Agent string. If empty the Chromium product version will be used. If
// |userAgent| is specified this value will be ignored. Also configurable
- // using the "product-version" command-line switch.
+ // using the "user-agent-product" command-line switch.
///
- cef_string_t product_version;
+ cef_string_t user_agent_product;
///
// The locale string that will be passed to WebKit. If empty the default
@@ -14945,7 +1929,7 @@ struct _cef_settings_t
///
// The directory and file name to use for the debug log. If empty a default
// log file name and location will be used. On Windows and Linux a "debug.log"
- // file will be written in the main executable directory. On Mac OS X a
+ // file will be written in the main executable directory. On MacOS a
// "~/Library/Logs/_debug.log" file will be written where
// is the name of the main app executable. Also configurable using the
// "log-file" command-line switch.
@@ -14970,10 +1954,10 @@ struct _cef_settings_t
///
// The fully qualified path for the resources directory. If this value is
- // empty the cef.pak and/or devtools_resources.pak files must be located in
- // the module directory on Windows/Linux or the app bundle Resources directory
- // on Mac OS X. If this value is non-empty then it must be an absolute path.
- // Also configurable using the "resources-dir-path" command-line switch.
+ // empty the *.pak files must be located in the module directory on
+ // Windows/Linux or the app bundle Resources directory on MacOS. If this
+ // value is non-empty then it must be an absolute path. Also configurable
+ // using the "resources-dir-path" command-line switch.
///
cef_string_t resources_dir_path;
@@ -14981,9 +1965,9 @@ struct _cef_settings_t
// The fully qualified path for the locales directory. If this value is empty
// the locales directory must be located in the module directory. If this
// value is non-empty then it must be an absolute path. This value is ignored
- // on Mac OS X where pack files are always loaded from the app bundle
- // Resources directory. Also configurable using the "locales-dir-path"
- // command-line switch.
+ // on MacOS where pack files are always loaded from the app bundle Resources
+ // directory. Also configurable using the "locales-dir-path" command-line
+ // switch.
///
cef_string_t locales_dir_path;
@@ -15014,17 +1998,6 @@ struct _cef_settings_t
///
int uncaught_exception_stack_size;
- ///
- // Set to true (1) to ignore errors related to invalid SSL certificates.
- // Enabling this setting can lead to potential security vulnerabilities like
- // "man in the middle" attacks. Applications that load content from the
- // internet should not enable this setting. Also configurable using the
- // "ignore-certificate-errors" command-line switch. Can be overridden for
- // individual CefRequestContext instances via the
- // CefRequestContextSettings.ignore_certificate_errors value.
- ///
- int ignore_certificate_errors;
-
///
// Background color used for the browser before a document is loaded and when
// no document color is specified. The alpha component must be either fully
@@ -15047,6 +2020,20 @@ struct _cef_settings_t
///
cef_string_t accept_language_list;
+ ///
+ // Comma delimited list of schemes supported by the associated
+ // CefCookieManager. If |cookieable_schemes_exclude_defaults| is false (0) the
+ // default schemes ("http", "https", "ws" and "wss") will also be supported.
+ // Specifying a |cookieable_schemes_list| value and setting
+ // |cookieable_schemes_exclude_defaults| to true (1) will disable all loading
+ // and saving of cookies for this manager. Can be overridden
+ // for individual CefRequestContext instances via the
+ // CefRequestContextSettings.cookieable_schemes_list and
+ // CefRequestContextSettings.cookieable_schemes_exclude_defaults values.
+ ///
+ cef_string_t cookieable_schemes_list;
+ int cookieable_schemes_exclude_defaults;
+
///
// GUID string used for identifying the application. This is passed to the
// system AV function for scanning downloaded files. By default, the GUID
@@ -15056,13 +2043,13 @@ struct _cef_settings_t
cef_string_t application_client_id_for_file_scanning;
}
-alias cef_settings_t = _cef_settings_t;
+
///
// Request context initialization settings. Specify NULL or 0 to get the
// recommended default values.
///
-struct _cef_request_context_settings_t
+struct cef_request_context_settings_t
{
///
// Size of this structure.
@@ -15099,16 +2086,6 @@ struct _cef_request_context_settings_t
///
int persist_user_preferences;
- ///
- // Set to true (1) to ignore errors related to invalid SSL certificates.
- // Enabling this setting can lead to potential security vulnerabilities like
- // "man in the middle" attacks. Applications that load content from the
- // internet should not enable this setting. Can be set globally using the
- // CefSettings.ignore_certificate_errors value. This value will be ignored if
- // |cache_path| matches the CefSettings.cache_path value.
- ///
- int ignore_certificate_errors;
-
///
// Comma delimited ordered list of language codes without any whitespace that
// will be used in the "Accept-Language" HTTP header. Can be set globally
@@ -15118,9 +2095,21 @@ struct _cef_request_context_settings_t
// ignored if |cache_path| matches the CefSettings.cache_path value.
///
cef_string_t accept_language_list;
+
+ ///
+ // Comma delimited list of schemes supported by the associated
+ // CefCookieManager. If |cookieable_schemes_exclude_defaults| is false (0) the
+ // default schemes ("http", "https", "ws" and "wss") will also be supported.
+ // Specifying a |cookieable_schemes_list| value and setting
+ // |cookieable_schemes_exclude_defaults| to true (1) will disable all loading
+ // and saving of cookies for this manager. These values will be ignored if
+ // |cache_path| matches the CefSettings.cache_path value.
+ ///
+ cef_string_t cookieable_schemes_list;
+ int cookieable_schemes_exclude_defaults;
}
-alias cef_request_context_settings_t = _cef_request_context_settings_t;
+
///
// Browser initialization settings. Specify NULL or 0 to get the recommended
@@ -15128,7 +2117,7 @@ alias cef_request_context_settings_t = _cef_request_context_settings_t;
// tested. Many of these and other settings can also configured using command-
// line switches.
///
-struct _cef_browser_settings_t
+struct cef_browser_settings_t
{
///
// Size of this structure.
@@ -15207,26 +2196,6 @@ struct _cef_browser_settings_t
///
cef_state_t plugins;
- ///
- // Controls whether file URLs will have access to all URLs. Also configurable
- // using the "allow-universal-access-from-files" command-line switch.
- ///
- cef_state_t universal_access_from_file_urls;
-
- ///
- // Controls whether file URLs will have access to other file URLs. Also
- // configurable using the "allow-access-from-files" command-line switch.
- ///
- cef_state_t file_access_from_file_urls;
-
- ///
- // Controls whether web security restrictions (same-origin policy) will be
- // enforced. Disabling this setting is not recommend as it will allow risky
- // security behavior such as cross-site scripting (XSS). Also configurable
- // using the "disable-web-security" command-line switch.
- ///
- cef_state_t web_security;
-
///
// Controls whether image URLs will be loaded from the network. A cached image
// will still be rendered if requested. Also configurable using the
@@ -15265,12 +2234,6 @@ struct _cef_browser_settings_t
///
cef_state_t databases;
- ///
- // Controls whether the application cache can be used. Also configurable using
- // the "disable-application-cache" command-line switch.
- ///
- cef_state_t application_cache;
-
///
// Controls whether WebGL can be used. Note that WebGL requires hardware
// support and may not work on all systems even when enabled. Also
@@ -15293,13 +2256,13 @@ struct _cef_browser_settings_t
///
// Comma delimited ordered list of language codes without any whitespace that
// will be used in the "Accept-Language" HTTP header. May be set globally
- // using the CefBrowserSettings.accept_language_list value. If both values are
+ // using the CefSettings.accept_language_list value. If both values are
// empty then "en-US,en" will be used.
///
cef_string_t accept_language_list;
}
-alias cef_browser_settings_t = _cef_browser_settings_t;
+
///
// Return value types.
@@ -15325,7 +2288,7 @@ enum cef_return_value_t
///
// URL component parts.
///
-struct _cef_urlparts_t
+struct cef_urlparts_t
{
///
// The complete URL specification.
@@ -15382,7 +2345,7 @@ struct _cef_urlparts_t
cef_string_t fragment;
}
-alias cef_urlparts_t = _cef_urlparts_t;
+
///
// Cookie priority values.
@@ -15408,7 +2371,7 @@ enum cef_cookie_same_site_t
///
// Cookie information.
///
-struct _cef_cookie_t
+struct cef_cookie_t
{
///
// The cookie name.
@@ -15472,7 +2435,7 @@ struct _cef_cookie_t
cef_cookie_priority_t priority;
}
-alias cef_cookie_t = _cef_cookie_t;
+
///
// Process termination status values.
@@ -15544,7 +2507,7 @@ enum cef_path_key_t
///
// "Application Data" directory under the user profile directory on Windows
- // and "~/Library/Application Support" directory on Mac OS X.
+ // and "~/Library/Application Support" directory on MacOS.
///
PK_USER_DATA = 7,
@@ -15601,7 +2564,6 @@ enum cef_errorcode_t
ERR_CLEARTEXT_NOT_PERMITTED = -29,
ERR_BLOCKED_BY_CSP = -30,
ERR_H2_OR_QUIC_REQUIRED = -31,
- ERR_INSECURE_PRIVATE_NETWORK_REQUEST = -32,
ERR_CONNECTION_CLOSED = -100,
ERR_CONNECTION_RESET = -101,
ERR_CONNECTION_REFUSED = -102,
@@ -15759,91 +2721,89 @@ enum cef_errorcode_t
ERR_CACHE_OPERATION_NOT_SUPPORTED = -403,
ERR_CACHE_OPEN_FAILURE = -404,
ERR_CACHE_CREATE_FAILURE = -405,
- ERR_CACHE_RACE = -406,
///
// Supported certificate status code values. See net\cert\cert_status_flags.h
+ ERR_CACHE_RACE = -406,
// for more information. CERT_STATUS_NONE is new in CEF because we use an
// enum while cert_status_flags.h uses a typedef and static const variables.
- ERR_CACHE_CHECKSUM_READ_FAILURE = -407,
///
+ ERR_CACHE_CHECKSUM_READ_FAILURE = -407,
// 1 << 3 is reserved for ERR_CERT_CONTAINS_ERRORS (not useful with WinHTTP).
ERR_CACHE_CHECKSUM_MISMATCH = -408,
- ERR_CACHE_LOCK_TIMEOUT = -409,
// 1 << 9 was used for CERT_STATUS_NOT_IN_DNS
- ERR_CACHE_AUTH_FAILURE_AFTER_READ = -410,
+ ERR_CACHE_LOCK_TIMEOUT = -409,
// 1 << 12 was used for CERT_STATUS_WEAK_DH_KEY
+ ERR_CACHE_AUTH_FAILURE_AFTER_READ = -410,
// Bits 16 to 31 are for non-error statuses.
- ERR_CACHE_ENTRY_NOT_SUITABLE = -411,
// Bit 18 was CERT_STATUS_IS_DNSSEC
+ ERR_CACHE_ENTRY_NOT_SUITABLE = -411,
ERR_CACHE_DOOM_FAILURE = -412,
- ERR_CACHE_OPEN_OR_CREATE_FAILURE = -413,
///
// The manner in which a link click should be opened. These constants match
- ERR_INSECURE_RESPONSE = -501,
// their equivalents in Chromium's window_open_disposition.h and should not be
+ ERR_CACHE_OPEN_OR_CREATE_FAILURE = -413,
// renumbered.
///
+ ERR_INSECURE_RESPONSE = -501,
ERR_NO_PRIVATE_KEY_FOR_CERT = -502,
- ERR_ADD_USER_CERT_FAILED = -503,
///
- ERR_INVALID_SIGNED_EXCHANGE = -504,
// "Verb" of a drag-and-drop operation as negotiated between the source and
+ ERR_ADD_USER_CERT_FAILED = -503,
// destination. These constants match their equivalents in WebCore's
- ERR_INVALID_WEB_BUNDLE = -505,
+ ERR_INVALID_SIGNED_EXCHANGE = -504,
// DragActions.h and should not be renumbered.
///
+ ERR_INVALID_WEB_BUNDLE = -505,
ERR_TRUST_TOKEN_OPERATION_FAILED = -506,
///
// Input mode of a virtual keyboard. These constants match their equivalents
- ERR_TRUST_TOKEN_OPERATION_CACHE_HIT = -507,
// in Chromium's text_input_mode.h and should not be renumbered.
// See https://html.spec.whatwg.org/#input-modalities:-the-inputmode-attribute
///
- ERR_FTP_FAILED = -601,
- ERR_FTP_SERVICE_UNAVAILABLE = -602,
- ERR_FTP_TRANSFER_ABORTED = -603,
+ ERR_TRUST_TOKEN_OPERATION_SUCCESS_WITHOUT_SENDING_REQUEST = -507,
///
// V8 access control values.
+ ERR_FTP_FAILED = -601,
///
- ERR_FTP_FILE_BUSY = -604,
+ ERR_FTP_SERVICE_UNAVAILABLE = -602,
///
// V8 property attribute values.
- ERR_FTP_SYNTAX_ERROR = -605,
+ ERR_FTP_TRANSFER_ABORTED = -603,
///
// Writeable, Enumerable,
- ERR_FTP_COMMAND_NOT_SUPPORTED = -606,
// Configurable
+ ERR_FTP_FILE_BUSY = -604,
// Not writeable
- ERR_FTP_BAD_COMMAND_SEQUENCE = -607,
// Not enumerable
+ ERR_FTP_SYNTAX_ERROR = -605,
// Not configurable
- ERR_PKCS12_IMPORT_BAD_PASSWORD = -701,
///
// Post data elements may represent either bytes or files.
- ERR_PKCS12_IMPORT_FAILED = -702,
+ ERR_FTP_COMMAND_NOT_SUPPORTED = -606,
///
- ERR_IMPORT_CA_CERT_NOT_CA = -703,
///
+ ERR_FTP_BAD_COMMAND_SEQUENCE = -607,
// Resource type for a request.
///
///
// Top level page.
///
+ ERR_PKCS12_IMPORT_BAD_PASSWORD = -701,
///
// Frame or iframe.
@@ -15851,7 +2811,7 @@ enum cef_errorcode_t
///
// CSS stylesheet.
- ERR_IMPORT_CERT_ALREADY_EXISTS = -704,
+ ERR_PKCS12_IMPORT_FAILED = -702,
///
///
@@ -15859,8 +2819,8 @@ enum cef_errorcode_t
///
///
+ ERR_IMPORT_CA_CERT_NOT_CA = -703,
// Image (jpg/gif/png/etc).
- ERR_IMPORT_CA_CERT_FAILED = -705,
///
///
@@ -15869,15 +2829,14 @@ enum cef_errorcode_t
///
// Some other subresource. This is the default type if the actual type is
- ERR_IMPORT_SERVER_CERT_FAILED = -706,
// unknown.
///
- ERR_PKCS12_IMPORT_INVALID_MAC = -707,
///
+ ERR_IMPORT_CERT_ALREADY_EXISTS = -704,
// Object (or embed) tag for a plugin, or a resource that a plugin requested.
- ERR_PKCS12_IMPORT_INVALID_FILE = -708,
///
+ ERR_IMPORT_CA_CERT_FAILED = -705,
///
// Media resource.
@@ -15885,13 +2844,13 @@ enum cef_errorcode_t
///
// Main resource of a dedicated worker.
- ERR_PKCS12_IMPORT_UNSUPPORTED = -709,
+ ERR_IMPORT_SERVER_CERT_FAILED = -706,
///
///
// Main resource of a shared worker.
- ERR_KEY_GENERATION_FAILED = -710,
///
+ ERR_PKCS12_IMPORT_INVALID_MAC = -707,
///
// Explicitly requested prefetch.
@@ -15900,7 +2859,7 @@ enum cef_errorcode_t
///
// Favicon.
///
- ERR_PRIVATE_KEY_EXPORT_FAILED = -712,
+ ERR_PKCS12_IMPORT_INVALID_FILE = -708,
///
// XMLHttpRequest.
@@ -15909,30 +2868,41 @@ enum cef_errorcode_t
///
// A request for a
///
- ERR_SELF_SIGNED_CERT_GENERATION_FAILED = -713,
+ ERR_PKCS12_IMPORT_UNSUPPORTED = -709,
///
// Main resource of a service worker.
///
+ ERR_KEY_GENERATION_FAILED = -710,
///
// A report of Content Security Policy violations.
- ERR_CERT_DATABASE_CHANGED = -714,
///
///
// A resource that a plugin requested.
+ ERR_PRIVATE_KEY_EXPORT_FAILED = -712,
+ ///
+
+ ///
+ // A main-frame service worker navigation preload request.
+ ERR_SELF_SIGNED_CERT_GENERATION_FAILED = -713,
+ ///
+
+ ///
+ // A sub-frame service worker navigation preload request.
+ ERR_CERT_DATABASE_CHANGED = -714,
///
///
- ERR_DNS_MALFORMED_RESPONSE = -800,
// Transition type for a request. Made up of one source value and 0 or more
- ERR_DNS_SERVER_REQUIRES_TCP = -801,
// qualifiers.
+ ERR_DNS_MALFORMED_RESPONSE = -800,
///
///
// Source is a link click or the JavaScript window.open function. This is
+ ERR_DNS_SERVER_REQUIRES_TCP = -801,
// also the default value for requests like sub-resource loads that are not
// navigations.
///
@@ -15944,25 +2914,35 @@ enum cef_errorcode_t
///
// Source is a subframe navigation. This is any content that is automatically
- ERR_DNS_SERVER_FAILED = -802,
// loaded in a non-toplevel frame. For example, if a page consists of several
- ERR_DNS_TIMED_OUT = -803,
+ ERR_DNS_SERVER_FAILED = -802,
// frames containing ads, those ad URLs will have this transition type.
+ ERR_DNS_TIMED_OUT = -803,
// The user may not even realize the content in these pages is a separate
// frame, so may not care about the URL.
///
///
// Source is a subframe navigation explicitly requested by the user that will
- ERR_DNS_CACHE_MISS = -804,
// generate new navigation entries in the back/forward list. These are
- ERR_DNS_SEARCH_EMPTY = -805,
+ ERR_DNS_CACHE_MISS = -804,
// probably more important than frames that were automatically loaded in
- ERR_DNS_SORT_ERROR = -806,
+ ERR_DNS_SEARCH_EMPTY = -805,
// the background because the user probably cares about the fact that this
+ ERR_DNS_SORT_ERROR = -806,
// link was loaded.
///
- ERR_DNS_SECURE_RESOLVER_HOSTNAME_RESOLUTION_FAILED = -808
+
+ ///
+ // Source is a form submission by the user. NOTE: In some situations
+ // submitting a form does not result in this transition type. This can happen
+ ERR_DNS_SECURE_RESOLVER_HOSTNAME_RESOLUTION_FAILED = -808,
+ // if the form uses a script to submit the contents.
+ ///
+
+ ///
+ // Source is a "reload" of the page via the Reload function or by re-visiting
+ ERR_DNS_NAME_HTTPS_ONLY = -809
}
enum cef_cert_status_t
@@ -16069,7 +3049,9 @@ enum cef_resource_type_t
RT_PING = 14,
RT_SERVICE_WORKER = 15,
RT_CSP_REPORT = 16,
- RT_PLUGIN_RESOURCE = 17
+ RT_PLUGIN_RESOURCE = 17,
+ RT_NAVIGATION_PRELOAD_MAIN_FRAME = 19,
+ RT_NAVIGATION_PRELOAD_SUB_FRAME = 20
}
enum cef_transition_type_t
@@ -16078,16 +3060,7 @@ enum cef_transition_type_t
TT_EXPLICIT = 1,
TT_AUTO_SUBFRAME = 3,
TT_MANUAL_SUBFRAME = 4,
-
- ///
- // Source is a form submission by the user. NOTE: In some situations
- // submitting a form does not result in this transition type. This can happen
- // if the form uses a script to submit the contents.
- ///
TT_FORM_SUBMIT = 7,
-
- ///
- // Source is a "reload" of the page via the Reload function or by re-visiting
// the same URL. NOTE: This is distinct from the concept of whether a
// particular load uses "reload semantics" (i.e. bypasses cached data).
///
@@ -16246,69 +3219,9 @@ enum cef_urlrequest_status_t
UR_FAILED = 4
}
-///
-// Structure representing a point.
-///
-struct _cef_point_t
-{
- int x;
- int y;
-}
-
-alias cef_point_t = _cef_point_t;
-
-///
-// Structure representing a rectangle.
-///
-struct _cef_rect_t
-{
- int x;
- int y;
- int width;
- int height;
-}
-
-alias cef_rect_t = _cef_rect_t;
-
-///
-// Structure representing a size.
-///
-struct _cef_size_t
-{
- int width;
- int height;
-}
-
-alias cef_size_t = _cef_size_t;
-
-///
-// Structure representing a range.
-///
-struct _cef_range_t
-{
- int from;
- int to;
-}
-
-alias cef_range_t = _cef_range_t;
-
-///
-// Structure representing insets.
-///
-struct _cef_insets_t
-{
- int top;
- int left;
- int bottom;
- int right;
-}
-
-alias cef_insets_t = _cef_insets_t;
-
-///
// Structure representing a draggable region.
///
-struct _cef_draggable_region_t
+struct cef_draggable_region_t
{
///
// Bounds of the region.
@@ -16321,7 +3234,7 @@ struct _cef_draggable_region_t
int draggable;
}
-alias cef_draggable_region_t = _cef_draggable_region_t;
+
///
// Existing process IDs.
@@ -16362,7 +3275,6 @@ enum cef_thread_id_t
// CefShutdown() are guaranteed to run.
///
TID_FILE_BACKGROUND = 1,
- TID_FILE = TID_FILE_BACKGROUND,
///
// Used for blocking tasks (e.g. file system access) that affect UI or
@@ -16512,7 +3424,7 @@ enum cef_jsdialog_type_t
// passed as a parameter to CefRenderHandler::GetScreenInfo and should be filled
// in by the client.
///
-struct _cef_screen_info_t
+struct cef_screen_info_t
{
///
// Device scale factor. Specifies the ratio between physical and logical
@@ -16564,7 +3476,7 @@ struct _cef_screen_info_t
cef_rect_t available_rect;
}
-alias cef_screen_info_t = _cef_screen_info_t;
+
///
// Supported menu IDs. Non-English translations can be provided for the
@@ -16604,7 +3516,7 @@ enum cef_menu_id_t
MENU_ID_ADD_TO_DICTIONARY = 206,
// Custom menu items originating from the renderer process. For example,
- // plugin placeholder menu items or Flash menu items.
+ // plugin placeholder menu items.
MENU_ID_CUSTOM_FIRST = 220,
MENU_ID_CUSTOM_LAST = 250,
@@ -16628,7 +3540,7 @@ enum cef_mouse_button_type_t
///
// Structure representing mouse event information.
///
-struct _cef_mouse_event_t
+struct cef_mouse_event_t
{
///
// X coordinate relative to the left side of the view.
@@ -16647,7 +3559,7 @@ struct _cef_mouse_event_t
uint32 modifiers;
}
-alias cef_mouse_event_t = _cef_mouse_event_t;
+
///
// Touch points states types.
@@ -16675,7 +3587,7 @@ enum cef_pointer_type_t
///
// Structure representing touch event information.
///
-struct _cef_touch_event_t
+struct cef_touch_event_t
{
///
// Id of a touch point. Must be unique per touch, can be any number except -1.
@@ -16735,7 +3647,7 @@ struct _cef_touch_event_t
cef_pointer_type_t pointer_type;
}
-alias cef_touch_event_t = _cef_touch_event_t;
+
///
// Paint element types.
@@ -16765,7 +3677,8 @@ enum cef_event_flags_t
EVENTFLAG_IS_KEY_PAD = 1 << 9,
EVENTFLAG_IS_LEFT = 1 << 10,
EVENTFLAG_IS_RIGHT = 1 << 11,
- EVENTFLAG_ALTGR_DOWN = 1 << 12
+ EVENTFLAG_ALTGR_DOWN = 1 << 12,
+ EVENTFLAG_IS_REPEAT = 1 << 13
}
///
@@ -16914,7 +3827,7 @@ enum cef_key_event_type_t
///
// Structure representing keyboard event information.
///
-struct _cef_key_event_t
+struct cef_key_event_t
{
///
// The type of keyboard event.
@@ -16965,7 +3878,7 @@ struct _cef_key_event_t
int focus_on_editable_field;
}
-alias cef_key_event_t = _cef_key_event_t;
+
///
// Focus sources.
@@ -17031,7 +3944,7 @@ enum cef_xml_node_type_t
///
// Popup window features.
///
-struct _cef_popup_features_t
+struct cef_popup_features_t
{
int x;
int xSet;
@@ -17048,7 +3961,7 @@ struct _cef_popup_features_t
int scrollbarsVisible;
}
-alias cef_popup_features_t = _cef_popup_features_t;
+
///
// DOM document types.
@@ -17261,7 +4174,7 @@ enum cef_cursor_type_t
// |size.width|*|size.height|*4 bytes in size and represents a BGRA image with
// an upper-left origin.
///
-struct _cef_cursor_info_t
+struct cef_cursor_info_t
{
cef_point_t hotspot;
float image_scale_factor;
@@ -17269,7 +4182,7 @@ struct _cef_cursor_info_t
cef_size_t size;
}
-alias cef_cursor_info_t = _cef_cursor_info_t;
+
///
// URI unescape rules passed to CefURIDecode().
@@ -17402,7 +4315,7 @@ enum cef_pdf_print_margin_type_t
///
// Structure representing PDF print settings.
///
-struct _cef_pdf_print_settings_t
+struct cef_pdf_print_settings_t
{
///
// Page title to display in the header. Only used if |header_footer_enabled|
@@ -17467,7 +4380,7 @@ struct _cef_pdf_print_settings_t
int backgrounds_enabled;
}
-alias cef_pdf_print_settings_t = _cef_pdf_print_settings_t;
+
///
// Supported UI scale factors for the platform. SCALE_FACTOR_NONE is used for
@@ -17700,7 +4613,7 @@ enum cef_cross_axis_alignment_t
///
// Settings used when initializing a CefBoxLayout.
///
-struct _cef_box_layout_settings_t
+struct cef_box_layout_settings_t
{
///
// If true (1) the layout will be horizontal, otherwise the layout will be
@@ -17755,7 +4668,7 @@ struct _cef_box_layout_settings_t
int default_flex;
}
-alias cef_box_layout_settings_t = _cef_box_layout_settings_t;
+
///
// Specifies the button display state.
@@ -17923,31 +4836,16 @@ enum cef_scheme_options_t
}
///
-// Error codes for CDM registration. See cef_web_plugin.h for details.
+// Structure representing a range.
///
-enum cef_cdm_registration_error_t
+struct cef_range_t
{
- ///
- // No error. Registration completed successfully.
- ///
- CEF_CDM_REGISTRATION_ERROR_NONE = 0,
-
- ///
- // Required files or manifest contents are missing.
- ///
- CEF_CDM_REGISTRATION_ERROR_INCORRECT_CONTENTS = 1,
-
- ///
- // The CDM is incompatible with the current Chromium version.
- ///
- CEF_CDM_REGISTRATION_ERROR_INCOMPATIBLE = 2,
-
- ///
- // CDM registration is not supported at this time.
- ///
- CEF_CDM_REGISTRATION_ERROR_NOT_SUPPORTED = 3
+ int from;
+ int to;
}
+
+
///
// Composition underline style.
///
@@ -17964,7 +4862,7 @@ enum cef_composition_underline_style_t
// wrapper around Blink's WebCompositionUnderline class and should be kept in
// sync with that.
///
-struct _cef_composition_underline_t
+struct cef_composition_underline_t
{
///
// Underline character range.
@@ -17992,7 +4890,7 @@ struct _cef_composition_underline_t
cef_composition_underline_style_t style;
}
-alias cef_composition_underline_t = _cef_composition_underline_t;
+
///
// Enumerates the various representations of the ordering of audio channels.
@@ -18109,7 +5007,7 @@ enum cef_channel_layout_t
///
// Structure representing the audio parameters for setting up the audio handler.
///
-struct _cef_audio_parameters_t
+struct cef_audio_parameters_t
{
///
// Layout of the audio channels
@@ -18127,7 +5025,7 @@ struct _cef_audio_parameters_t
int frames_per_buffer;
}
-alias cef_audio_parameters_t = _cef_audio_parameters_t;
+
///
// Result codes for CefMediaRouter::CreateRoute. Should be kept in sync with
@@ -18144,8 +5042,9 @@ enum cef_media_route_create_result_t
CEF_MRCR_NO_SUPPORTED_PROVIDER = 7,
CEF_MRCR_CANCELLED = 8,
CEF_MRCR_ROUTE_ALREADY_EXISTS = 9,
+ CEF_MRCR_ROUTE_ALREADY_TERMINATED = 11,
- CEF_MRCR_TOTAL_COUNT = 11 // The total number of values.
+ CEF_MRCR_TOTAL_COUNT = 12 // The total number of values.
}
///
@@ -18181,14 +5080,14 @@ enum cef_media_sink_icon_type_t
///
// Device information for a MediaSink object.
///
-struct _cef_media_sink_device_info_t
+struct cef_media_sink_device_info_t
{
cef_string_t ip_address;
int port;
cef_string_t model_name;
}
-alias cef_media_sink_device_info_t = _cef_media_sink_device_info_t;
+
///
// Represents commands available to TextField.
@@ -18203,9 +5102,41 @@ enum cef_text_field_commands_t
CEF_TFC_SELECT_ALL = 6
}
-// CEF_INCLUDE_INTERNAL_CEF_TYPES_H_
+///
+// Supported Chrome toolbar types.
+///
+enum cef_chrome_toolbar_type_t
+{
+ CEF_CTT_NONE = 1,
+ CEF_CTT_NORMAL = 2,
+ CEF_CTT_LOCATION = 3
+}
-// Copyright (c) 2020 Marshall A. Greenblatt. All rights reserved.
+///
+// Docking modes supported by CefWindow::AddOverlay.
+///
+enum cef_docking_mode_t
+{
+ CEF_DOCKING_MODE_TOP_LEFT = 1,
+ CEF_DOCKING_MODE_TOP_RIGHT = 2,
+ CEF_DOCKING_MODE_BOTTOM_LEFT = 3,
+ CEF_DOCKING_MODE_BOTTOM_RIGHT = 4,
+ CEF_DOCKING_MODE_CUSTOM = 5
+}
+
+///
+// Show states supported by CefWindowDelegate::GetInitialShowState.
+///
+enum cef_show_state_t
+{
+ CEF_SHOW_STATE_NORMAL = 1,
+ CEF_SHOW_STATE_MINIMIZED = 2,
+ CEF_SHOW_STATE_MAXIMIZED = 3,
+ CEF_SHOW_STATE_FULLSCREEN = 4
+}
+
+// CEF_INCLUDE_INTERNAL_CEF_TYPES_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
@@ -18240,15 +5171,8550 @@ enum cef_text_field_commands_t
// by hand. See the translator.README.txt file in the tools directory for
// more information.
//
-// $hash=7ce0953f069204a4dd2037c4a05ac9454c5e66a6$
+// $hash=c487e5fd787b1be8224a8981839e0cfdd0ed74f3$
//
extern (C):
+///
+// Implement this structure to receive accessibility notification when
+// accessibility events have been registered. The functions of this structure
+// will be called on the UI thread.
+///
+struct cef_accessibility_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called after renderer process sends accessibility tree changes to the
+ // browser process.
+ ///
+ extern(System) void function (
+ cef_accessibility_handler_t* self,
+ cef_value_t* value) nothrow on_accessibility_tree_change;
+
+ ///
+ // Called after renderer process sends accessibility location changes to the
+ // browser process.
+ ///
+ extern(System) void function (
+ cef_accessibility_handler_t* self,
+ cef_value_t* value) nothrow on_accessibility_location_change;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=a4b63e6e7942e3a3961b4f7141a963980178ae6f$
+//
+
+extern (C):
+
+///
+// Implement this structure to provide handler implementations. Methods will be
+// called by the process and/or thread indicated.
+///
+struct cef_app_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Provides an opportunity to view and/or modify command-line arguments before
+ // processing by CEF and Chromium. The |process_type| value will be NULL for
+ // the browser process. Do not keep a reference to the cef_command_line_t
+ // object passed to this function. The CefSettings.command_line_args_disabled
+ // value can be used to start with an NULL command-line object. Any values
+ // specified in CefSettings that equate to command-line arguments will be set
+ // before this function is called. Be cautious when using this function to
+ // modify command-line arguments for non-browser processes as this may result
+ // in undefined behavior including crashes.
+ ///
+ extern(System) void function (
+ cef_app_t* self,
+ const(cef_string_t)* process_type,
+ cef_command_line_t* command_line) nothrow on_before_command_line_processing;
+
+ ///
+ // Provides an opportunity to register custom schemes. Do not keep a reference
+ // to the |registrar| object. This function is called on the main thread for
+ // each process and the registered schemes should be the same across all
+ // processes.
+ ///
+ extern(System) void function (
+ cef_app_t* self,
+ cef_scheme_registrar_t* registrar) nothrow on_register_custom_schemes;
+
+ ///
+ // Return the handler for resource bundle events. If
+ // CefSettings.pack_loading_disabled is true (1) a handler must be returned.
+ // If no handler is returned resources will be loaded from pack files. This
+ // function is called by the browser and render processes on multiple threads.
+ ///
+ extern(System) cef_resource_bundle_handler_t* function (
+ cef_app_t* self) nothrow get_resource_bundle_handler;
+
+ ///
+ // Return the handler for functionality specific to the browser process. This
+ // function is called on multiple threads in the browser process.
+ ///
+ extern(System) cef_browser_process_handler_t* function (
+ cef_app_t* self) nothrow get_browser_process_handler;
+
+ ///
+ // Return the handler for functionality specific to the render process. This
+ // function is called on the render process main thread.
+ ///
+ extern(System) cef_render_process_handler_t* function (
+ cef_app_t* self) nothrow get_render_process_handler;
+}
+
+
+
+///
+// This function should be called from the application entry point function to
+// execute a secondary process. It can be used to run secondary processes from
+// the browser client executable (default behavior) or from a separate
+// executable specified by the CefSettings.browser_subprocess_path value. If
+// called for the browser process (identified by no "type" command-line value)
+// it will return immediately with a value of -1. If called for a recognized
+// secondary process it will block until the process should exit and then return
+// the process exit code. The |application| parameter may be NULL. The
+// |windows_sandbox_info| parameter is only used on Windows and may be NULL (see
+// cef_sandbox_win.h for details).
+///
+int cef_execute_process (
+ const(cef_main_args_t)* args,
+ cef_app_t* application,
+ void* windows_sandbox_info);
+
+///
+// This function should be called on the main application thread to initialize
+// the CEF browser process. The |application| parameter may be NULL. A return
+// value of true (1) indicates that it succeeded and false (0) indicates that it
+// failed. The |windows_sandbox_info| parameter is only used on Windows and may
+// be NULL (see cef_sandbox_win.h for details).
+///
+int cef_initialize (
+ const(cef_main_args_t)* args,
+ const(cef_settings_t)* settings,
+ cef_app_t* application,
+ void* windows_sandbox_info);
+
+///
+// This function should be called on the main application thread to shut down
+// the CEF browser process before the application exits.
+///
+void cef_shutdown ();
+
+///
+// Perform a single iteration of CEF message loop processing. This function is
+// provided for cases where the CEF message loop must be integrated into an
+// existing application message loop. Use of this function is not recommended
+// for most users; use either the cef_run_message_loop() function or
+// CefSettings.multi_threaded_message_loop if possible. When using this function
+// care must be taken to balance performance against excessive CPU usage. It is
+// recommended to enable the CefSettings.external_message_pump option when using
+// this function so that
+// cef_browser_process_handler_t::on_schedule_message_pump_work() callbacks can
+// facilitate the scheduling process. This function should only be called on the
+// main application thread and only if cef_initialize() is called with a
+// CefSettings.multi_threaded_message_loop value of false (0). This function
+// will not block.
+///
+void cef_do_message_loop_work ();
+
+///
+// Run the CEF message loop. Use this function instead of an application-
+// provided message loop to get the best balance between performance and CPU
+// usage. This function should only be called on the main application thread and
+// only if cef_initialize() is called with a
+// CefSettings.multi_threaded_message_loop value of false (0). This function
+// will block until a quit message is received by the system.
+///
+void cef_run_message_loop ();
+
+///
+// Quit the CEF message loop that was started by calling cef_run_message_loop().
+// This function should only be called on the main application thread and only
+// if cef_run_message_loop() was used.
+///
+void cef_quit_message_loop ();
+
+///
+// Set to true (1) before calling Windows APIs like TrackPopupMenu that enter a
+// modal message loop. Set to false (0) after exiting the modal message loop.
+///
+void cef_set_osmodal_loop (int osModalLoop);
+
+///
+// Call during process startup to enable High-DPI support on Windows 7 or newer.
+// Older versions of Windows should be left DPI-unaware because they do not
+// support DirectWrite and GDI fonts are kerned very badly.
+///
+void cef_enable_highdpi_support ();
+
+// CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=7a483ed552ecca4f1aaa03800d366beca1ea2dee$
+//
+
+extern (C):
+
+///
+// Implement this structure to handle audio events.
+///
+struct cef_audio_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called on the UI thread to allow configuration of audio stream parameters.
+ // Return true (1) to proceed with audio stream capture, or false (0) to
+ // cancel it. All members of |params| can optionally be configured here, but
+ // they are also pre-filled with some sensible defaults.
+ ///
+ extern(System) int function (
+ cef_audio_handler_t* self,
+ cef_browser_t* browser,
+ cef_audio_parameters_t* params) nothrow get_audio_parameters;
+
+ ///
+ // Called on a browser audio capture thread when the browser starts streaming
+ // audio. OnAudioSteamStopped will always be called after
+ // OnAudioStreamStarted; both functions may be called multiple times for the
+ // same browser. |params| contains the audio parameters like sample rate and
+ // channel layout. |channels| is the number of channels.
+ ///
+ extern(System) void function (
+ cef_audio_handler_t* self,
+ cef_browser_t* browser,
+ const(cef_audio_parameters_t)* params,
+ int channels) nothrow on_audio_stream_started;
+
+ ///
+ // Called on the audio stream thread when a PCM packet is received for the
+ // stream. |data| is an array representing the raw PCM data as a floating
+ // point type, i.e. 4-byte value(s). |frames| is the number of frames in the
+ // PCM packet. |pts| is the presentation timestamp (in milliseconds since the
+ // Unix Epoch) and represents the time at which the decompressed packet should
+ // be presented to the user. Based on |frames| and the |channel_layout| value
+ // passed to OnAudioStreamStarted you can calculate the size of the |data|
+ // array in bytes.
+ ///
+ extern(System) void function (
+ cef_audio_handler_t* self,
+ cef_browser_t* browser,
+ const(float*)* data,
+ int frames,
+ int64 pts) nothrow on_audio_stream_packet;
+
+ ///
+ // Called on the UI thread when the stream has stopped. OnAudioSteamStopped
+ // will always be called after OnAudioStreamStarted; both functions may be
+ // called multiple times for the same stream.
+ ///
+ extern(System) void function (
+ cef_audio_handler_t* self,
+ cef_browser_t* browser) nothrow on_audio_stream_stopped;
+
+ ///
+ // Called on the UI or audio stream thread when an error occurred. During the
+ // stream creation phase this callback will be called on the UI thread while
+ // in the capturing phase it will be called on the audio stream thread. The
+ // stream will be stopped immediately.
+ ///
+ extern(System) void function (
+ cef_audio_handler_t* self,
+ cef_browser_t* browser,
+ const(cef_string_t)* message) nothrow on_audio_stream_error;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_AUDIO_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=2b9508a328ed0218e2c576af455f8d76e5978545$
+//
+
+extern (C):
+
+///
+// Callback structure used for asynchronous continuation of authentication
+// requests.
+///
+struct cef_auth_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Continue the authentication request.
+ ///
+ extern(System) void function (
+ cef_auth_callback_t* self,
+ const(cef_string_t)* username,
+ const(cef_string_t)* password) nothrow cont;
+
+ ///
+ // Cancel the authentication request.
+ ///
+ extern(System) void function (cef_auth_callback_t* self) nothrow cancel;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_
+// Copyright (c) 2014 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+extern (C):
+
+///
+// All ref-counted framework structures must include this structure first.
+///
+struct cef_base_ref_counted_t
+{
+ ///
+ // Size of the data structure.
+ ///
+ size_t size;
+
+ ///
+ // Called to increment the reference count for the object. Should be called
+ // for every new copy of a pointer to a given object.
+ ///
+ extern(System) void function (cef_base_ref_counted_t* self) nothrow add_ref;
+
+ ///
+ // Called to decrement the reference count for the object. If the reference
+ // count falls to 0 the object should self-delete. Returns true (1) if the
+ // resulting reference count is 0.
+ ///
+ extern(System) int function (cef_base_ref_counted_t* self) nothrow release;
+
+ ///
+ // Returns true (1) if the current reference count is 1.
+ ///
+ extern(System) int function (cef_base_ref_counted_t* self) nothrow has_one_ref;
+
+ ///
+ // Returns true (1) if the current reference count is at least 1.
+ ///
+ extern(System) int function (cef_base_ref_counted_t* self) nothrow has_at_least_one_ref;
+}
+
+
+
+///
+// All scoped framework structures must include this structure first.
+///
+struct cef_base_scoped_t
+{
+ ///
+ // Size of the data structure.
+ ///
+ size_t size;
+
+ ///
+ // Called to delete this object. May be NULL if the object is not owned.
+ ///
+ extern(System) void function (cef_base_scoped_t* self) nothrow del;
+}
+
+
+
+// Check that the structure |s|, which is defined with a size_t member at the
+// top, is large enough to contain the specified member |f|.
+
+
+
+
+// CEF_INCLUDE_CAPI_CEF_BASE_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=b83b96e2b90124bba8084e2df7f66cc6749df872$
+//
+
+import core.stdc.config;
+
+extern (C):
+
+
+
+///
+// Structure used to represent a browser. When used in the browser process the
+// functions of this structure may be called on any thread unless otherwise
+// indicated in the comments. When used in the render process the functions of
+// this structure may only be called on the main thread.
+///
+struct cef_browser_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // True if this object is currently valid. This will return false (0) after
+ // cef_life_span_handler_t::OnBeforeClose is called.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow is_valid;
+
+ ///
+ // Returns the browser host object. This function can only be called in the
+ // browser process.
+ ///
+ extern(System) cef_browser_host_t* function (cef_browser_t* self) nothrow get_host;
+
+ ///
+ // Returns true (1) if the browser can navigate backwards.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow can_go_back;
+
+ ///
+ // Navigate backwards.
+ ///
+ extern(System) void function (cef_browser_t* self) nothrow go_back;
+
+ ///
+ // Returns true (1) if the browser can navigate forwards.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow can_go_forward;
+
+ ///
+ // Navigate forwards.
+ ///
+ extern(System) void function (cef_browser_t* self) nothrow go_forward;
+
+ ///
+ // Returns true (1) if the browser is currently loading.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow is_loading;
+
+ ///
+ // Reload the current page.
+ ///
+ extern(System) void function (cef_browser_t* self) nothrow reload;
+
+ ///
+ // Reload the current page ignoring any cached data.
+ ///
+ extern(System) void function (cef_browser_t* self) nothrow reload_ignore_cache;
+
+ ///
+ // Stop loading the page.
+ ///
+ extern(System) void function (cef_browser_t* self) nothrow stop_load;
+
+ ///
+ // Returns the globally unique identifier for this browser. This value is also
+ // used as the tabId for extension APIs.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow get_identifier;
+
+ ///
+ // Returns true (1) if this object is pointing to the same handle as |that|
+ // object.
+ ///
+ extern(System) int function (cef_browser_t* self, cef_browser_t* that) nothrow is_same;
+
+ ///
+ // Returns true (1) if the browser is a popup.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow is_popup;
+
+ ///
+ // Returns true (1) if a document has been loaded in the browser.
+ ///
+ extern(System) int function (cef_browser_t* self) nothrow has_document;
+
+ ///
+ // Returns the main (top-level) frame for the browser. In the browser process
+ // this will return a valid object until after
+ // cef_life_span_handler_t::OnBeforeClose is called. In the renderer process
+ // this will return NULL if the main frame is hosted in a different renderer
+ // process (e.g. for cross-origin sub-frames). The main frame object will
+ // change during cross-origin navigation or re-navigation after renderer
+ // process termination (due to crashes, etc).
+ ///
+ extern(System) cef_frame_t* function (cef_browser_t* self) nothrow get_main_frame;
+
+ ///
+ // Returns the focused frame for the browser.
+ ///
+ extern(System) cef_frame_t* function (cef_browser_t* self) nothrow get_focused_frame;
+
+ ///
+ // Returns the frame with the specified identifier, or NULL if not found.
+ ///
+ extern(System) cef_frame_t* function (
+ cef_browser_t* self,
+ int64 identifier) nothrow get_frame_byident;
+
+ ///
+ // Returns the frame with the specified name, or NULL if not found.
+ ///
+ extern(System) cef_frame_t* function (
+ cef_browser_t* self,
+ const(cef_string_t)* name) nothrow get_frame;
+
+ ///
+ // Returns the number of frames that currently exist.
+ ///
+ extern(System) size_t function (cef_browser_t* self) nothrow get_frame_count;
+
+ ///
+ // Returns the identifiers of all existing frames.
+ ///
+ extern(System) void function (
+ cef_browser_t* self,
+ size_t* identifiersCount,
+ int64* identifiers) nothrow get_frame_identifiers;
+
+ ///
+ // Returns the names of all existing frames.
+ ///
+ extern(System) void function (
+ cef_browser_t* self,
+ cef_string_list_t names) nothrow get_frame_names;
+}
+
+
+
+///
+// Callback structure for cef_browser_host_t::RunFileDialog. The functions of
+// this structure will be called on the browser process UI thread.
+///
+struct cef_run_file_dialog_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called asynchronously after the file dialog is dismissed.
+ // |selected_accept_filter| is the 0-based index of the value selected from
+ // the accept filters array passed to cef_browser_host_t::RunFileDialog.
+ // |file_paths| will be a single value or a list of values depending on the
+ // dialog mode. If the selection was cancelled |file_paths| will be NULL.
+ ///
+ extern(System) void function (
+ cef_run_file_dialog_callback_t* self,
+ int selected_accept_filter,
+ cef_string_list_t file_paths) nothrow on_file_dialog_dismissed;
+}
+
+
+
+///
+// Callback structure for cef_browser_host_t::GetNavigationEntries. The
+// functions of this structure will be called on the browser process UI thread.
+///
+struct cef_navigation_entry_visitor_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be executed. Do not keep a reference to |entry| outside of
+ // this callback. Return true (1) to continue visiting entries or false (0) to
+ // stop. |current| is true (1) if this entry is the currently loaded
+ // navigation entry. |index| is the 0-based index of this entry and |total| is
+ // the total number of entries.
+ ///
+ extern(System) int function (
+ cef_navigation_entry_visitor_t* self,
+ cef_navigation_entry_t* entry,
+ int current,
+ int index,
+ int total) nothrow visit;
+}
+
+
+
+///
+// Callback structure for cef_browser_host_t::PrintToPDF. The functions of this
+// structure will be called on the browser process UI thread.
+///
+struct cef_pdf_print_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be executed when the PDF printing has completed. |path| is
+ // the output path. |ok| will be true (1) if the printing completed
+ // successfully or false (0) otherwise.
+ ///
+ extern(System) void function (
+ cef_pdf_print_callback_t* self,
+ const(cef_string_t)* path,
+ int ok) nothrow on_pdf_print_finished;
+}
+
+
+
+///
+// Callback structure for cef_browser_host_t::DownloadImage. The functions of
+// this structure will be called on the browser process UI thread.
+///
+struct cef_download_image_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be executed when the image download has completed.
+ // |image_url| is the URL that was downloaded and |http_status_code| is the
+ // resulting HTTP status code. |image| is the resulting image, possibly at
+ // multiple scale factors, or NULL if the download failed.
+ ///
+ extern(System) void function (
+ cef_download_image_callback_t* self,
+ const(cef_string_t)* image_url,
+ int http_status_code,
+ cef_image_t* image) nothrow on_download_image_finished;
+}
+
+
+
+///
+// Structure used to represent the browser process aspects of a browser. The
+// functions of this structure can only be called in the browser process. They
+// may be called on any thread in that process unless otherwise indicated in the
+// comments.
+///
+struct cef_browser_host_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns the hosted browser object.
+ ///
+ extern(System) cef_browser_t* function (cef_browser_host_t* self) nothrow get_browser;
+
+ ///
+ // Request that the browser close. The JavaScript 'onbeforeunload' event will
+ // be fired. If |force_close| is false (0) the event handler, if any, will be
+ // allowed to prompt the user and the user can optionally cancel the close. If
+ // |force_close| is true (1) the prompt will not be displayed and the close
+ // will proceed. Results in a call to cef_life_span_handler_t::do_close() if
+ // the event handler allows the close or if |force_close| is true (1). See
+ // cef_life_span_handler_t::do_close() documentation for additional usage
+ // information.
+ ///
+ extern(System) void function (cef_browser_host_t* self, int force_close) nothrow close_browser;
+
+ ///
+ // Helper for closing a browser. Call this function from the top-level window
+ // close handler (if any). Internally this calls CloseBrowser(false (0)) if
+ // the close has not yet been initiated. This function returns false (0) while
+ // the close is pending and true (1) after the close has completed. See
+ // close_browser() and cef_life_span_handler_t::do_close() documentation for
+ // additional usage information. This function must be called on the browser
+ // process UI thread.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow try_close_browser;
+
+ ///
+ // Set whether the browser is focused.
+ ///
+ extern(System) void function (cef_browser_host_t* self, int focus) nothrow set_focus;
+
+ ///
+ // Retrieve the window handle (if any) for this browser. If this browser is
+ // wrapped in a cef_browser_view_t this function should be called on the
+ // browser process UI thread and it will return the handle for the top-level
+ // native window.
+ ///
+ extern(System) c_ulong function (cef_browser_host_t* self) nothrow get_window_handle;
+
+ ///
+ // Retrieve the window handle (if any) of the browser that opened this
+ // browser. Will return NULL for non-popup browsers or if this browser is
+ // wrapped in a cef_browser_view_t. This function can be used in combination
+ // with custom handling of modal windows.
+ ///
+ extern(System) c_ulong function (cef_browser_host_t* self) nothrow get_opener_window_handle;
+
+ ///
+ // Returns true (1) if this browser is wrapped in a cef_browser_view_t.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow has_view;
+
+ ///
+ // Returns the client for this browser.
+ ///
+ extern(System) cef_client_t* function (cef_browser_host_t* self) nothrow get_client;
+
+ ///
+ // Returns the request context for this browser.
+ ///
+ extern(System) cef_request_context_t* function (
+ cef_browser_host_t* self) nothrow get_request_context;
+
+ ///
+ // Get the current zoom level. The default zoom level is 0.0. This function
+ // can only be called on the UI thread.
+ ///
+ extern(System) double function (cef_browser_host_t* self) nothrow get_zoom_level;
+
+ ///
+ // Change the zoom level to the specified value. Specify 0.0 to reset the zoom
+ // level. If called on the UI thread the change will be applied immediately.
+ // Otherwise, the change will be applied asynchronously on the UI thread.
+ ///
+ extern(System) void function (cef_browser_host_t* self, double zoomLevel) nothrow set_zoom_level;
+
+ ///
+ // Call to run a file chooser dialog. Only a single file chooser dialog may be
+ // pending at any given time. |mode| represents the type of dialog to display.
+ // |title| to the title to be used for the dialog and may be NULL to show the
+ // default title ("Open" or "Save" depending on the mode). |default_file_path|
+ // is the path with optional directory and/or file name component that will be
+ // initially selected in the dialog. |accept_filters| are used to restrict the
+ // selectable file types and may any combination of (a) valid lower-cased MIME
+ // types (e.g. "text/*" or "image/*"), (b) individual file extensions (e.g.
+ // ".txt" or ".png"), or (c) combined description and file extension delimited
+ // using "|" and ";" (e.g. "Image Types|.png;.gif;.jpg").
+ // |selected_accept_filter| is the 0-based index of the filter that will be
+ // selected by default. |callback| will be executed after the dialog is
+ // dismissed or immediately if another dialog is already pending. The dialog
+ // will be initiated asynchronously on the UI thread.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ cef_file_dialog_mode_t mode,
+ const(cef_string_t)* title,
+ const(cef_string_t)* default_file_path,
+ cef_string_list_t accept_filters,
+ int selected_accept_filter,
+ cef_run_file_dialog_callback_t* callback) nothrow run_file_dialog;
+
+ ///
+ // Download the file at |url| using cef_download_handler_t.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* url) nothrow start_download;
+
+ ///
+ // Download |image_url| and execute |callback| on completion with the images
+ // received from the renderer. If |is_favicon| is true (1) then cookies are
+ // not sent and not accepted during download. Images with density independent
+ // pixel (DIP) sizes larger than |max_image_size| are filtered out from the
+ // image results. Versions of the image at different scale factors may be
+ // downloaded up to the maximum scale factor supported by the system. If there
+ // are no image results <= |max_image_size| then the smallest image is resized
+ // to |max_image_size| and is the only result. A |max_image_size| of 0 means
+ // unlimited. If |bypass_cache| is true (1) then |image_url| is requested from
+ // the server even if it is present in the browser cache.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* image_url,
+ int is_favicon,
+ uint32 max_image_size,
+ int bypass_cache,
+ cef_download_image_callback_t* callback) nothrow download_image;
+
+ ///
+ // Print the current browser contents.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow print;
+
+ ///
+ // Print the current browser contents to the PDF file specified by |path| and
+ // execute |callback| on completion. The caller is responsible for deleting
+ // |path| when done. For PDF printing to work on Linux you must implement the
+ // cef_print_handler_t::GetPdfPaperSize function.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* path,
+ const(cef_pdf_print_settings_t)* settings,
+ cef_pdf_print_callback_t* callback) nothrow print_to_pdf;
+
+ ///
+ // Search for |searchText|. |identifier| must be a unique ID and these IDs
+ // must strictly increase so that newer requests always have greater IDs than
+ // older requests. If |identifier| is zero or less than the previous ID value
+ // then it will be automatically assigned a new valid ID. |forward| indicates
+ // whether to search forward or backward within the page. |matchCase|
+ // indicates whether the search should be case-sensitive. |findNext| indicates
+ // whether this is the first request or a follow-up. The cef_find_handler_t
+ // instance, if any, returned via cef_client_t::GetFindHandler will be called
+ // to report find results.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ int identifier,
+ const(cef_string_t)* searchText,
+ int forward,
+ int matchCase,
+ int findNext) nothrow find;
+
+ ///
+ // Cancel all searches that are currently going on.
+ ///
+ extern(System) void function (cef_browser_host_t* self, int clearSelection) nothrow stop_finding;
+
+ ///
+ // Open developer tools (DevTools) in its own browser. The DevTools browser
+ // will remain associated with this browser. If the DevTools browser is
+ // already open then it will be focused, in which case the |windowInfo|,
+ // |client| and |settings| parameters will be ignored. If |inspect_element_at|
+ // is non-NULL then the element at the specified (x,y) location will be
+ // inspected. The |windowInfo| parameter will be ignored if this browser is
+ // wrapped in a cef_browser_view_t.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_window_info_t)* windowInfo,
+ cef_client_t* client,
+ const(cef_browser_settings_t)* settings,
+ const(cef_point_t)* inspect_element_at) nothrow show_dev_tools;
+
+ ///
+ // Explicitly close the associated DevTools browser, if any.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow close_dev_tools;
+
+ ///
+ // Returns true (1) if this browser currently has an associated DevTools
+ // browser. Must be called on the browser process UI thread.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow has_dev_tools;
+
+ ///
+ // Send a function call message over the DevTools protocol. |message| must be
+ // a UTF8-encoded JSON dictionary that contains "id" (int), "function"
+ // (string) and "params" (dictionary, optional) values. See the DevTools
+ // protocol documentation at https://chromedevtools.github.io/devtools-
+ // protocol/ for details of supported functions and the expected "params"
+ // dictionary contents. |message| will be copied if necessary. This function
+ // will return true (1) if called on the UI thread and the message was
+ // successfully submitted for validation, otherwise false (0). Validation will
+ // be applied asynchronously and any messages that fail due to formatting
+ // errors or missing parameters may be discarded without notification. Prefer
+ // ExecuteDevToolsMethod if a more structured approach to message formatting
+ // is desired.
+ //
+ // Every valid function call will result in an asynchronous function result or
+ // error message that references the sent message "id". Event messages are
+ // received while notifications are enabled (for example, between function
+ // calls for "Page.enable" and "Page.disable"). All received messages will be
+ // delivered to the observer(s) registered with AddDevToolsMessageObserver.
+ // See cef_dev_tools_message_observer_t::OnDevToolsMessage documentation for
+ // details of received message contents.
+ //
+ // Usage of the SendDevToolsMessage, ExecuteDevToolsMethod and
+ // AddDevToolsMessageObserver functions does not require an active DevTools
+ // front-end or remote-debugging session. Other active DevTools sessions will
+ // continue to function independently. However, any modification of global
+ // browser state by one session may not be reflected in the UI of other
+ // sessions.
+ //
+ // Communication with the DevTools front-end (when displayed) can be logged
+ // for development purposes by passing the `--devtools-protocol-log-
+ // file=` command-line flag.
+ ///
+ extern(System) int function (
+ cef_browser_host_t* self,
+ const(void)* message,
+ size_t message_size) nothrow send_dev_tools_message;
+
+ ///
+ // Execute a function call over the DevTools protocol. This is a more
+ // structured version of SendDevToolsMessage. |message_id| is an incremental
+ // number that uniquely identifies the message (pass 0 to have the next number
+ // assigned automatically based on previous values). |function| is the
+ // function name. |params| are the function parameters, which may be NULL. See
+ // the DevTools protocol documentation (linked above) for details of supported
+ // functions and the expected |params| dictionary contents. This function will
+ // return the assigned message ID if called on the UI thread and the message
+ // was successfully submitted for validation, otherwise 0. See the
+ // SendDevToolsMessage documentation for additional usage information.
+ ///
+ extern(System) int function (
+ cef_browser_host_t* self,
+ int message_id,
+ const(cef_string_t)* method,
+ cef_dictionary_value_t* params) nothrow execute_dev_tools_method;
+
+ ///
+ // Add an observer for DevTools protocol messages (function results and
+ // events). The observer will remain registered until the returned
+ // Registration object is destroyed. See the SendDevToolsMessage documentation
+ // for additional usage information.
+ ///
+ extern(System) cef_registration_t* function (
+ cef_browser_host_t* self,
+ cef_dev_tools_message_observer_t* observer) nothrow add_dev_tools_message_observer;
+
+ ///
+ // Retrieve a snapshot of current navigation entries as values sent to the
+ // specified visitor. If |current_only| is true (1) only the current
+ // navigation entry will be sent, otherwise all navigation entries will be
+ // sent.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ cef_navigation_entry_visitor_t* visitor,
+ int current_only) nothrow get_navigation_entries;
+
+ ///
+ // If a misspelled word is currently selected in an editable node calling this
+ // function will replace it with the specified |word|.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* word) nothrow replace_misspelling;
+
+ ///
+ // Add the specified |word| to the spelling dictionary.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* word) nothrow add_word_to_dictionary;
+
+ ///
+ // Returns true (1) if window rendering is disabled.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow is_window_rendering_disabled;
+
+ ///
+ // Notify the browser that the widget has been resized. The browser will first
+ // call cef_render_handler_t::GetViewRect to get the new size and then call
+ // cef_render_handler_t::OnPaint asynchronously with the updated regions. This
+ // function is only used when window rendering is disabled.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow was_resized;
+
+ ///
+ // Notify the browser that it has been hidden or shown. Layouting and
+ // cef_render_handler_t::OnPaint notification will stop when the browser is
+ // hidden. This function is only used when window rendering is disabled.
+ ///
+ extern(System) void function (cef_browser_host_t* self, int hidden) nothrow was_hidden;
+
+ ///
+ // Send a notification to the browser that the screen info has changed. The
+ // browser will then call cef_render_handler_t::GetScreenInfo to update the
+ // screen information with the new values. This simulates moving the webview
+ // window from one display to another, or changing the properties of the
+ // current display. This function is only used when window rendering is
+ // disabled.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow notify_screen_info_changed;
+
+ ///
+ // Invalidate the view. The browser will call cef_render_handler_t::OnPaint
+ // asynchronously. This function is only used when window rendering is
+ // disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ cef_paint_element_type_t type) nothrow invalidate;
+
+ ///
+ // Issue a BeginFrame request to Chromium. Only valid when
+ // cef_window_tInfo::external_begin_frame_enabled is set to true (1).
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow send_external_begin_frame;
+
+ ///
+ // Send a key event to the browser.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_key_event_t)* event) nothrow send_key_event;
+
+ ///
+ // Send a mouse click event to the browser. The |x| and |y| coordinates are
+ // relative to the upper-left corner of the view.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_mouse_event_t)* event,
+ cef_mouse_button_type_t type,
+ int mouseUp,
+ int clickCount) nothrow send_mouse_click_event;
+
+ ///
+ // Send a mouse move event to the browser. The |x| and |y| coordinates are
+ // relative to the upper-left corner of the view.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_mouse_event_t)* event,
+ int mouseLeave) nothrow send_mouse_move_event;
+
+ ///
+ // Send a mouse wheel event to the browser. The |x| and |y| coordinates are
+ // relative to the upper-left corner of the view. The |deltaX| and |deltaY|
+ // values represent the movement delta in the X and Y directions respectively.
+ // In order to scroll inside select popups with window rendering disabled
+ // cef_render_handler_t::GetScreenPoint should be implemented properly.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_mouse_event_t)* event,
+ int deltaX,
+ int deltaY) nothrow send_mouse_wheel_event;
+
+ ///
+ // Send a touch event to the browser for a windowless browser.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_touch_event_t)* event) nothrow send_touch_event;
+
+ ///
+ // Send a capture lost event to the browser.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow send_capture_lost_event;
+
+ ///
+ // Notify the browser that the window hosting it is about to be moved or
+ // resized. This function is only used on Windows and Linux.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow notify_move_or_resize_started;
+
+ ///
+ // Returns the maximum rate in frames per second (fps) that
+ // cef_render_handler_t:: OnPaint will be called for a windowless browser. The
+ // actual fps may be lower if the browser cannot generate frames at the
+ // requested rate. The minimum value is 1 and the maximum value is 60 (default
+ // 30). This function can only be called on the UI thread.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow get_windowless_frame_rate;
+
+ ///
+ // Set the maximum rate in frames per second (fps) that cef_render_handler_t::
+ // OnPaint will be called for a windowless browser. The actual fps may be
+ // lower if the browser cannot generate frames at the requested rate. The
+ // minimum value is 1 and the maximum value is 60 (default 30). Can also be
+ // set at browser creation via cef_browser_tSettings.windowless_frame_rate.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ int frame_rate) nothrow set_windowless_frame_rate;
+
+ ///
+ // Begins a new composition or updates the existing composition. Blink has a
+ // special node (a composition node) that allows the input function to change
+ // text without affecting other DOM nodes. |text| is the optional text that
+ // will be inserted into the composition node. |underlines| is an optional set
+ // of ranges that will be underlined in the resulting text.
+ // |replacement_range| is an optional range of the existing text that will be
+ // replaced. |selection_range| is an optional range of the resulting text that
+ // will be selected after insertion or replacement. The |replacement_range|
+ // value is only used on OS X.
+ //
+ // This function may be called multiple times as the composition changes. When
+ // the client is done making changes the composition should either be canceled
+ // or completed. To cancel the composition call ImeCancelComposition. To
+ // complete the composition call either ImeCommitText or
+ // ImeFinishComposingText. Completion is usually signaled when:
+ // A. The client receives a WM_IME_COMPOSITION message with a GCS_RESULTSTR
+ // flag (on Windows), or;
+ // B. The client receives a "commit" signal of GtkIMContext (on Linux), or;
+ // C. insertText of NSTextInput is called (on Mac).
+ //
+ // This function is only used when window rendering is disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* text,
+ size_t underlinesCount,
+ const(cef_composition_underline_t)* underlines,
+ const(cef_range_t)* replacement_range,
+ const(cef_range_t)* selection_range) nothrow ime_set_composition;
+
+ ///
+ // Completes the existing composition by optionally inserting the specified
+ // |text| into the composition node. |replacement_range| is an optional range
+ // of the existing text that will be replaced. |relative_cursor_pos| is where
+ // the cursor will be positioned relative to the current cursor position. See
+ // comments on ImeSetComposition for usage. The |replacement_range| and
+ // |relative_cursor_pos| values are only used on OS X. This function is only
+ // used when window rendering is disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_string_t)* text,
+ const(cef_range_t)* replacement_range,
+ int relative_cursor_pos) nothrow ime_commit_text;
+
+ ///
+ // Completes the existing composition by applying the current composition node
+ // contents. If |keep_selection| is false (0) the current selection, if any,
+ // will be discarded. See comments on ImeSetComposition for usage. This
+ // function is only used when window rendering is disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ int keep_selection) nothrow ime_finish_composing_text;
+
+ ///
+ // Cancels the existing composition and discards the composition node contents
+ // without applying them. See comments on ImeSetComposition for usage. This
+ // function is only used when window rendering is disabled.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow ime_cancel_composition;
+
+ ///
+ // Call this function when the user drags the mouse into the web view (before
+ // calling DragTargetDragOver/DragTargetLeave/DragTargetDrop). |drag_data|
+ // should not contain file contents as this type of data is not allowed to be
+ // dragged into the web view. File contents can be removed using
+ // cef_drag_data_t::ResetFileContents (for example, if |drag_data| comes from
+ // cef_render_handler_t::StartDragging). This function is only used when
+ // window rendering is disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ cef_drag_data_t* drag_data,
+ const(cef_mouse_event_t)* event,
+ cef_drag_operations_mask_t allowed_ops) nothrow drag_target_drag_enter;
+
+ ///
+ // Call this function each time the mouse is moved across the web view during
+ // a drag operation (after calling DragTargetDragEnter and before calling
+ // DragTargetDragLeave/DragTargetDrop). This function is only used when window
+ // rendering is disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_mouse_event_t)* event,
+ cef_drag_operations_mask_t allowed_ops) nothrow drag_target_drag_over;
+
+ ///
+ // Call this function when the user drags the mouse out of the web view (after
+ // calling DragTargetDragEnter). This function is only used when window
+ // rendering is disabled.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow drag_target_drag_leave;
+
+ ///
+ // Call this function when the user completes the drag operation by dropping
+ // the object onto the web view (after calling DragTargetDragEnter). The
+ // object being dropped is |drag_data|, given as an argument to the previous
+ // DragTargetDragEnter call. This function is only used when window rendering
+ // is disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ const(cef_mouse_event_t)* event) nothrow drag_target_drop;
+
+ ///
+ // Call this function when the drag operation started by a
+ // cef_render_handler_t::StartDragging call has ended either in a drop or by
+ // being cancelled. |x| and |y| are mouse coordinates relative to the upper-
+ // left corner of the view. If the web view is both the drag source and the
+ // drag target then all DragTarget* functions should be called before
+ // DragSource* mthods. This function is only used when window rendering is
+ // disabled.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ int x,
+ int y,
+ cef_drag_operations_mask_t op) nothrow drag_source_ended_at;
+
+ ///
+ // Call this function when the drag operation started by a
+ // cef_render_handler_t::StartDragging call has completed. This function may
+ // be called immediately without first calling DragSourceEndedAt to cancel a
+ // drag operation. If the web view is both the drag source and the drag target
+ // then all DragTarget* functions should be called before DragSource* mthods.
+ // This function is only used when window rendering is disabled.
+ ///
+ extern(System) void function (cef_browser_host_t* self) nothrow drag_source_system_drag_ended;
+
+ ///
+ // Returns the current visible navigation entry for this browser. This
+ // function can only be called on the UI thread.
+ ///
+ extern(System) cef_navigation_entry_t* function (
+ cef_browser_host_t* self) nothrow get_visible_navigation_entry;
+
+ ///
+ // Set accessibility state for all frames. |accessibility_state| may be
+ // default, enabled or disabled. If |accessibility_state| is STATE_DEFAULT
+ // then accessibility will be disabled by default and the state may be further
+ // controlled with the "force-renderer-accessibility" and "disable-renderer-
+ // accessibility" command-line switches. If |accessibility_state| is
+ // STATE_ENABLED then accessibility will be enabled. If |accessibility_state|
+ // is STATE_DISABLED then accessibility will be completely disabled.
+ //
+ // For windowed browsers accessibility will be enabled in Complete mode (which
+ // corresponds to kAccessibilityModeComplete in Chromium). In this mode all
+ // platform accessibility objects will be created and managed by Chromium's
+ // internal implementation. The client needs only to detect the screen reader
+ // and call this function appropriately. For example, on macOS the client can
+ // handle the @"AXEnhancedUserStructure" accessibility attribute to detect
+ // VoiceOver state changes and on Windows the client can handle WM_GETOBJECT
+ // with OBJID_CLIENT to detect accessibility readers.
+ //
+ // For windowless browsers accessibility will be enabled in TreeOnly mode
+ // (which corresponds to kAccessibilityModeWebContentsOnly in Chromium). In
+ // this mode renderer accessibility is enabled, the full tree is computed, and
+ // events are passed to CefAccessibiltyHandler, but platform accessibility
+ // objects are not created. The client may implement platform accessibility
+ // objects using CefAccessibiltyHandler callbacks if desired.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ cef_state_t accessibility_state) nothrow set_accessibility_state;
+
+ ///
+ // Enable notifications of auto resize via
+ // cef_display_handler_t::OnAutoResize. Notifications are disabled by default.
+ // |min_size| and |max_size| define the range of allowed sizes.
+ ///
+ extern(System) void function (
+ cef_browser_host_t* self,
+ int enabled,
+ const(cef_size_t)* min_size,
+ const(cef_size_t)* max_size) nothrow set_auto_resize_enabled;
+
+ ///
+ // Returns the extension hosted in this browser or NULL if no extension is
+ // hosted. See cef_request_context_t::LoadExtension for details.
+ ///
+ extern(System) cef_extension_t* function (cef_browser_host_t* self) nothrow get_extension;
+
+ ///
+ // Returns true (1) if this browser is hosting an extension background script.
+ // Background hosts do not have a window and are not displayable. See
+ // cef_request_context_t::LoadExtension for details.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow is_background_host;
+
+ ///
+ // Set whether the browser's audio is muted.
+ ///
+ extern(System) void function (cef_browser_host_t* self, int mute) nothrow set_audio_muted;
+
+ ///
+ // Returns true (1) if the browser's audio is muted. This function can only
+ // be called on the UI thread.
+ ///
+ extern(System) int function (cef_browser_host_t* self) nothrow is_audio_muted;
+}
+
+
+
+///
+// Create a new browser using the window parameters specified by |windowInfo|.
+// All values will be copied internally and the actual window (if any) will be
+// created on the UI thread. If |request_context| is NULL the global request
+// context will be used. This function can be called on any browser process
+// thread and will not block. The optional |extra_info| parameter provides an
+// opportunity to specify extra information specific to the created browser that
+// will be passed to cef_render_process_handler_t::on_browser_created() in the
+// render process.
+///
+int cef_browser_host_create_browser (
+ const(cef_window_info_t)* windowInfo,
+ cef_client_t* client,
+ const(cef_string_t)* url,
+ const(cef_browser_settings_t)* settings,
+ cef_dictionary_value_t* extra_info,
+ cef_request_context_t* request_context);
+
+///
+// Create a new browser using the window parameters specified by |windowInfo|.
+// If |request_context| is NULL the global request context will be used. This
+// function can only be called on the browser process UI thread. The optional
+// |extra_info| parameter provides an opportunity to specify extra information
+// specific to the created browser that will be passed to
+// cef_render_process_handler_t::on_browser_created() in the render process.
+///
+cef_browser_t* cef_browser_host_create_browser_sync (
+ const(cef_window_info_t)* windowInfo,
+ cef_client_t* client,
+ const(cef_string_t)* url,
+ const(cef_browser_settings_t)* settings,
+ cef_dictionary_value_t* extra_info,
+ cef_request_context_t* request_context);
+
+// CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=ade537f836add7fe0b5fd94ceba26d678abb3e43$
+//
+
+extern (C):
+
+///
+// Structure used to implement browser process callbacks. The functions of this
+// structure will be called on the browser process main thread unless otherwise
+// indicated.
+///
+struct cef_browser_process_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called on the browser process UI thread immediately after the CEF context
+ // has been initialized.
+ ///
+ extern(System) void function (
+ cef_browser_process_handler_t* self) nothrow on_context_initialized;
+
+ ///
+ // Called before a child process is launched. Will be called on the browser
+ // process UI thread when launching a render process and on the browser
+ // process IO thread when launching a GPU or plugin process. Provides an
+ // opportunity to modify the child process command line. Do not keep a
+ // reference to |command_line| outside of this function.
+ ///
+ extern(System) void function (
+ cef_browser_process_handler_t* self,
+ cef_command_line_t* command_line) nothrow on_before_child_process_launch;
+
+ ///
+ // Called from any thread when work has been scheduled for the browser process
+ // main (UI) thread. This callback is used in combination with CefSettings.
+ // external_message_pump and cef_do_message_loop_work() in cases where the CEF
+ // message loop must be integrated into an existing application message loop
+ // (see additional comments and warnings on CefDoMessageLoopWork). This
+ // callback should schedule a cef_do_message_loop_work() call to happen on the
+ // main (UI) thread. |delay_ms| is the requested delay in milliseconds. If
+ // |delay_ms| is <= 0 then the call should happen reasonably soon. If
+ // |delay_ms| is > 0 then the call should be scheduled to happen after the
+ // specified delay and any currently pending scheduled call should be
+ // cancelled.
+ ///
+ extern(System) void function (
+ cef_browser_process_handler_t* self,
+ int64 delay_ms) nothrow on_schedule_message_pump_work;
+
+ ///
+ // Return the default client for use with a newly created browser window. If
+ // null is returned the browser will be unmanaged (no callbacks will be
+ // executed for that browser) and application shutdown will be blocked until
+ // the browser window is closed manually. This function is currently only used
+ // with the chrome runtime.
+ ///
+ extern(System) cef_client_t* function (
+ cef_browser_process_handler_t* self) nothrow get_default_client;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=cd8c183355a6808abd763ecc0396b5da6c15b3f9$
+//
+
+extern (C):
+
+///
+// Generic callback structure used for asynchronous continuation.
+///
+struct cef_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Continue processing.
+ ///
+ extern(System) void function (cef_callback_t* self) nothrow cont;
+
+ ///
+ // Cancel processing.
+ ///
+ extern(System) void function (cef_callback_t* self) nothrow cancel;
+}
+
+
+
+///
+// Generic callback structure used for asynchronous completion.
+///
+struct cef_completion_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be called once the task is complete.
+ ///
+ extern(System) void function (cef_completion_callback_t* self) nothrow on_complete;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=845a1d1dda63a06f4ae33ed39acfd2599b46a885$
+//
+
+extern (C):
+
+///
+// Implement this structure to provide handler implementations.
+///
+struct cef_client_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Return the handler for audio rendering events.
+ ///
+ extern(System) cef_audio_handler_t* function (cef_client_t* self) nothrow get_audio_handler;
+
+ ///
+ // Return the handler for context menus. If no handler is provided the default
+ // implementation will be used.
+ ///
+ extern(System) cef_context_menu_handler_t* function (
+ cef_client_t* self) nothrow get_context_menu_handler;
+
+ ///
+ // Return the handler for dialogs. If no handler is provided the default
+ // implementation will be used.
+ ///
+ extern(System) cef_dialog_handler_t* function (cef_client_t* self) nothrow get_dialog_handler;
+
+ ///
+ // Return the handler for browser display state events.
+ ///
+ extern(System) cef_display_handler_t* function (cef_client_t* self) nothrow get_display_handler;
+
+ ///
+ // Return the handler for download events. If no handler is returned downloads
+ // will not be allowed.
+ ///
+ extern(System) cef_download_handler_t* function (
+ cef_client_t* self) nothrow get_download_handler;
+
+ ///
+ // Return the handler for drag events.
+ ///
+ extern(System) cef_drag_handler_t* function (cef_client_t* self) nothrow get_drag_handler;
+
+ ///
+ // Return the handler for find result events.
+ ///
+ extern(System) cef_find_handler_t* function (cef_client_t* self) nothrow get_find_handler;
+
+ ///
+ // Return the handler for focus events.
+ ///
+ extern(System) cef_focus_handler_t* function (cef_client_t* self) nothrow get_focus_handler;
+
+ ///
+ // Return the handler for events related to cef_frame_t lifespan. This
+ // function will be called once during cef_browser_t creation and the result
+ // will be cached for performance reasons.
+ ///
+ extern(System) cef_frame_handler_t* function (cef_client_t* self) nothrow get_frame_handler;
+
+ ///
+ // Return the handler for JavaScript dialogs. If no handler is provided the
+ // default implementation will be used.
+ ///
+ extern(System) cef_jsdialog_handler_t* function (
+ cef_client_t* self) nothrow get_jsdialog_handler;
+
+ ///
+ // Return the handler for keyboard events.
+ ///
+ extern(System) cef_keyboard_handler_t* function (
+ cef_client_t* self) nothrow get_keyboard_handler;
+
+ ///
+ // Return the handler for browser life span events.
+ ///
+ extern(System) cef_life_span_handler_t* function (
+ cef_client_t* self) nothrow get_life_span_handler;
+
+ ///
+ // Return the handler for browser load status events.
+ ///
+ extern(System) cef_load_handler_t* function (cef_client_t* self) nothrow get_load_handler;
+
+ ///
+ // Return the handler for printing on Linux. If a print handler is not
+ // provided then printing will not be supported on the Linux platform.
+ ///
+ extern(System) cef_print_handler_t* function (cef_client_t* self) nothrow get_print_handler;
+
+ ///
+ // Return the handler for off-screen rendering events.
+ ///
+ extern(System) cef_render_handler_t* function (cef_client_t* self) nothrow get_render_handler;
+
+ ///
+ // Return the handler for browser request events.
+ ///
+ extern(System) cef_request_handler_t* function (cef_client_t* self) nothrow get_request_handler;
+
+ ///
+ // Called when a new message is received from a different process. Return true
+ // (1) if the message was handled or false (0) otherwise. It is safe to keep
+ // a reference to |message| outside of this callback.
+ ///
+ extern(System) int function (
+ cef_client_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame,
+ cef_process_id_t source_process,
+ cef_process_message_t* message) nothrow on_process_message_received;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=3ecebd6b30bb8fb837e062eacd021c1a1ff3620a$
+//
+
+extern (C):
+
+///
+// Structure used to create and/or parse command line arguments. Arguments with
+// '--', '-' and, on Windows, '/' prefixes are considered switches. Switches
+// will always precede any arguments without switch prefixes. Switches can
+// optionally have a value specified using the '=' delimiter (e.g.
+// "-switch=value"). An argument of "--" will terminate switch parsing with all
+// subsequent tokens, regardless of prefix, being interpreted as non-switch
+// arguments. Switch names should be lowercase ASCII and will be converted to
+// such if necessary. Switch values will retain the original case and UTF8
+// encoding. This structure can be used before cef_initialize() is called.
+///
+struct cef_command_line_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns true (1) if this object is valid. Do not call any other functions
+ // if this function returns false (0).
+ ///
+ extern(System) int function (cef_command_line_t* self) nothrow is_valid;
+
+ ///
+ // Returns true (1) if the values of this object are read-only. Some APIs may
+ // expose read-only objects.
+ ///
+ extern(System) int function (cef_command_line_t* self) nothrow is_read_only;
+
+ ///
+ // Returns a writable copy of this object.
+ ///
+ extern(System) cef_command_line_t* function (cef_command_line_t* self) nothrow copy;
+
+ ///
+ // Initialize the command line with the specified |argc| and |argv| values.
+ // The first argument must be the name of the program. This function is only
+ // supported on non-Windows platforms.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ int argc,
+ const(char*)* argv) nothrow init_from_argv;
+
+ ///
+ // Initialize the command line with the string returned by calling
+ // GetCommandLineW(). This function is only supported on Windows.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ const(cef_string_t)* command_line) nothrow init_from_string;
+
+ ///
+ // Reset the command-line switches and arguments but leave the program
+ // component unchanged.
+ ///
+ extern(System) void function (cef_command_line_t* self) nothrow reset;
+
+ ///
+ // Retrieve the original command line string as a vector of strings. The argv
+ // array: { program, [(--|-|/)switch[=value]]*, [--], [argument]* }
+ ///
+ extern(System) void function (cef_command_line_t* self, cef_string_list_t argv) nothrow get_argv;
+
+ ///
+ // Constructs and returns the represented command line string. Use this
+ // function cautiously because quoting behavior is unclear.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_command_line_t* self) nothrow get_command_line_string;
+
+ ///
+ // Get the program part of the command line string (the first item).
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_command_line_t* self) nothrow get_program;
+
+ ///
+ // Set the program part of the command line string (the first item).
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ const(cef_string_t)* program) nothrow set_program;
+
+ ///
+ // Returns true (1) if the command line has switches.
+ ///
+ extern(System) int function (cef_command_line_t* self) nothrow has_switches;
+
+ ///
+ // Returns true (1) if the command line contains the given switch.
+ ///
+ extern(System) int function (
+ cef_command_line_t* self,
+ const(cef_string_t)* name) nothrow has_switch;
+
+ ///
+ // Returns the value associated with the given switch. If the switch has no
+ // value or isn't present this function returns the NULL string.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_command_line_t* self,
+ const(cef_string_t)* name) nothrow get_switch_value;
+
+ ///
+ // Returns the map of switch names and values. If a switch has no value an
+ // NULL string is returned.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ cef_string_map_t switches) nothrow get_switches;
+
+ ///
+ // Add a switch to the end of the command line. If the switch has no value
+ // pass an NULL value string.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ const(cef_string_t)* name) nothrow append_switch;
+
+ ///
+ // Add a switch with the specified value to the end of the command line.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ const(cef_string_t)* name,
+ const(cef_string_t)* value) nothrow append_switch_with_value;
+
+ ///
+ // True if there are remaining command line arguments.
+ ///
+ extern(System) int function (cef_command_line_t* self) nothrow has_arguments;
+
+ ///
+ // Get the remaining command line arguments.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ cef_string_list_t arguments) nothrow get_arguments;
+
+ ///
+ // Add an argument to the end of the command line.
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ const(cef_string_t)* argument) nothrow append_argument;
+
+ ///
+ // Insert a command before the current command. Common for debuggers, like
+ // "valgrind" or "gdb --args".
+ ///
+ extern(System) void function (
+ cef_command_line_t* self,
+ const(cef_string_t)* wrapper) nothrow prepend_wrapper;
+}
+
+
+
+///
+// Create a new cef_command_line_t instance.
+///
+cef_command_line_t* cef_command_line_create ();
+
+///
+// Returns the singleton global cef_command_line_t object. The returned object
+// will be read-only.
+///
+cef_command_line_t* cef_command_line_get_global ();
+
+// CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=175779df75a1405fcc5c337a09e6322c556698ba$
+//
+
+extern (C):
+
+///
+// Callback structure used for continuation of custom context menu display.
+///
+struct cef_run_context_menu_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Complete context menu display by selecting the specified |command_id| and
+ // |event_flags|.
+ ///
+ extern(System) void function (
+ cef_run_context_menu_callback_t* self,
+ int command_id,
+ cef_event_flags_t event_flags) nothrow cont;
+
+ ///
+ // Cancel context menu display.
+ ///
+ extern(System) void function (cef_run_context_menu_callback_t* self) nothrow cancel;
+}
+
+
+
+///
+// Implement this structure to handle context menu events. The functions of this
+// structure will be called on the UI thread.
+///
+struct cef_context_menu_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called before a context menu is displayed. |params| provides information
+ // about the context menu state. |model| initially contains the default
+ // context menu. The |model| can be cleared to show no context menu or
+ // modified to show a custom menu. Do not keep references to |params| or
+ // |model| outside of this callback.
+ ///
+ extern(System) void function (
+ cef_context_menu_handler_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame,
+ cef_context_menu_params_t* params,
+ cef_menu_model_t* model) nothrow on_before_context_menu;
+
+ ///
+ // Called to allow custom display of the context menu. |params| provides
+ // information about the context menu state. |model| contains the context menu
+ // model resulting from OnBeforeContextMenu. For custom display return true
+ // (1) and execute |callback| either synchronously or asynchronously with the
+ // selected command ID. For default display return false (0). Do not keep
+ // references to |params| or |model| outside of this callback.
+ ///
+ extern(System) int function (
+ cef_context_menu_handler_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame,
+ cef_context_menu_params_t* params,
+ cef_menu_model_t* model,
+ cef_run_context_menu_callback_t* callback) nothrow run_context_menu;
+
+ ///
+ // Called to execute a command selected from the context menu. Return true (1)
+ // if the command was handled or false (0) for the default implementation. See
+ // cef_menu_id_t for the command ids that have default implementations. All
+ // user-defined command ids should be between MENU_ID_USER_FIRST and
+ // MENU_ID_USER_LAST. |params| will have the same values as what was passed to
+ // on_before_context_menu(). Do not keep a reference to |params| outside of
+ // this callback.
+ ///
+ extern(System) int function (
+ cef_context_menu_handler_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame,
+ cef_context_menu_params_t* params,
+ int command_id,
+ cef_event_flags_t event_flags) nothrow on_context_menu_command;
+
+ ///
+ // Called when the context menu is dismissed irregardless of whether the menu
+ // was NULL or a command was selected.
+ ///
+ extern(System) void function (
+ cef_context_menu_handler_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame) nothrow on_context_menu_dismissed;
+}
+
+
+
+///
+// Provides information about the context menu state. The ethods of this
+// structure can only be accessed on browser process the UI thread.
+///
+struct cef_context_menu_params_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns the X coordinate of the mouse where the context menu was invoked.
+ // Coords are relative to the associated RenderView's origin.
+ ///
+ extern(System) int function (cef_context_menu_params_t* self) nothrow get_xcoord;
+
+ ///
+ // Returns the Y coordinate of the mouse where the context menu was invoked.
+ // Coords are relative to the associated RenderView's origin.
+ ///
+ extern(System) int function (cef_context_menu_params_t* self) nothrow get_ycoord;
+
+ ///
+ // Returns flags representing the type of node that the context menu was
+ // invoked on.
+ ///
+ extern(System) cef_context_menu_type_flags_t function (
+ cef_context_menu_params_t* self) nothrow get_type_flags;
+
+ ///
+ // Returns the URL of the link, if any, that encloses the node that the
+ // context menu was invoked on.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_link_url;
+
+ ///
+ // Returns the link URL, if any, to be used ONLY for "copy link address". We
+ // don't validate this field in the frontend process.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_unfiltered_link_url;
+
+ ///
+ // Returns the source URL, if any, for the element that the context menu was
+ // invoked on. Example of elements with source URLs are img, audio, and video.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_source_url;
+
+ ///
+ // Returns true (1) if the context menu was invoked on an image which has non-
+ // NULL contents.
+ ///
+ extern(System) int function (cef_context_menu_params_t* self) nothrow has_image_contents;
+
+ ///
+ // Returns the title text or the alt text if the context menu was invoked on
+ // an image.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_title_text;
+
+ ///
+ // Returns the URL of the top level page that the context menu was invoked on.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_page_url;
+
+ ///
+ // Returns the URL of the subframe that the context menu was invoked on.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_frame_url;
+
+ ///
+ // Returns the character encoding of the subframe that the context menu was
+ // invoked on.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_frame_charset;
+
+ ///
+ // Returns the type of context node that the context menu was invoked on.
+ ///
+ extern(System) cef_context_menu_media_type_t function (
+ cef_context_menu_params_t* self) nothrow get_media_type;
+
+ ///
+ // Returns flags representing the actions supported by the media element, if
+ // any, that the context menu was invoked on.
+ ///
+ extern(System) cef_context_menu_media_state_flags_t function (
+ cef_context_menu_params_t* self) nothrow get_media_state_flags;
+
+ ///
+ // Returns the text of the selection, if any, that the context menu was
+ // invoked on.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_selection_text;
+
+ ///
+ // Returns the text of the misspelled word, if any, that the context menu was
+ // invoked on.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_context_menu_params_t* self) nothrow get_misspelled_word;
+
+ ///
+ // Returns true (1) if suggestions exist, false (0) otherwise. Fills in
+ // |suggestions| from the spell check service for the misspelled word if there
+ // is one.
+ ///
+ extern(System) int function (
+ cef_context_menu_params_t* self,
+ cef_string_list_t suggestions) nothrow get_dictionary_suggestions;
+
+ ///
+ // Returns true (1) if the context menu was invoked on an editable node.
+ ///
+ extern(System) int function (cef_context_menu_params_t* self) nothrow is_editable;
+
+ ///
+ // Returns true (1) if the context menu was invoked on an editable node where
+ // spell-check is enabled.
+ ///
+ extern(System) int function (cef_context_menu_params_t* self) nothrow is_spell_check_enabled;
+
+ ///
+ // Returns flags representing the actions supported by the editable node, if
+ // any, that the context menu was invoked on.
+ ///
+ extern(System) cef_context_menu_edit_state_flags_t function (
+ cef_context_menu_params_t* self) nothrow get_edit_state_flags;
+
+ ///
+ // Returns true (1) if the context menu contains items specified by the
+ // renderer process (for example, plugin placeholder or pepper plugin menu
+ // items).
+ ///
+ extern(System) int function (cef_context_menu_params_t* self) nothrow is_custom_menu;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=b19ef1c8a781f8d59276357609fe64370bb8a107$
+//
+
+extern (C):
+
+///
+// Structure used for managing cookies. The functions of this structure may be
+// called on any thread unless otherwise indicated.
+///
+struct cef_cookie_manager_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Visit all cookies on the UI thread. The returned cookies are ordered by
+ // longest path, then by earliest creation date. Returns false (0) if cookies
+ // cannot be accessed.
+ ///
+ extern(System) int function (
+ cef_cookie_manager_t* self,
+ cef_cookie_visitor_t* visitor) nothrow visit_all_cookies;
+
+ ///
+ // Visit a subset of cookies on the UI thread. The results are filtered by the
+ // given url scheme, host, domain and path. If |includeHttpOnly| is true (1)
+ // HTTP-only cookies will also be included in the results. The returned
+ // cookies are ordered by longest path, then by earliest creation date.
+ // Returns false (0) if cookies cannot be accessed.
+ ///
+ extern(System) int function (
+ cef_cookie_manager_t* self,
+ const(cef_string_t)* url,
+ int includeHttpOnly,
+ cef_cookie_visitor_t* visitor) nothrow visit_url_cookies;
+
+ ///
+ // Sets a cookie given a valid URL and explicit user-provided cookie
+ // attributes. This function expects each attribute to be well-formed. It will
+ // check for disallowed characters (e.g. the ';' character is disallowed
+ // within the cookie value attribute) and fail without setting the cookie if
+ // such characters are found. If |callback| is non-NULL it will be executed
+ // asnychronously on the UI thread after the cookie has been set. Returns
+ // false (0) if an invalid URL is specified or if cookies cannot be accessed.
+ ///
+ extern(System) int function (
+ cef_cookie_manager_t* self,
+ const(cef_string_t)* url,
+ const(cef_cookie_t)* cookie,
+ cef_set_cookie_callback_t* callback) nothrow set_cookie;
+
+ ///
+ // Delete all cookies that match the specified parameters. If both |url| and
+ // |cookie_name| values are specified all host and domain cookies matching
+ // both will be deleted. If only |url| is specified all host cookies (but not
+ // domain cookies) irrespective of path will be deleted. If |url| is NULL all
+ // cookies for all hosts and domains will be deleted. If |callback| is non-
+ // NULL it will be executed asnychronously on the UI thread after the cookies
+ // have been deleted. Returns false (0) if a non-NULL invalid URL is specified
+ // or if cookies cannot be accessed. Cookies can alternately be deleted using
+ // the Visit*Cookies() functions.
+ ///
+ extern(System) int function (
+ cef_cookie_manager_t* self,
+ const(cef_string_t)* url,
+ const(cef_string_t)* cookie_name,
+ cef_delete_cookies_callback_t* callback) nothrow delete_cookies;
+
+ ///
+ // Flush the backing store (if any) to disk. If |callback| is non-NULL it will
+ // be executed asnychronously on the UI thread after the flush is complete.
+ // Returns false (0) if cookies cannot be accessed.
+ ///
+ extern(System) int function (
+ cef_cookie_manager_t* self,
+ cef_completion_callback_t* callback) nothrow flush_store;
+}
+
+
+
+///
+// Returns the global cookie manager. By default data will be stored at
+// CefSettings.cache_path if specified or in memory otherwise. If |callback| is
+// non-NULL it will be executed asnychronously on the UI thread after the
+// manager's storage has been initialized. Using this function is equivalent to
+// calling cef_request_context_t::cef_request_context_get_global_context()->GetD
+// efaultCookieManager().
+///
+cef_cookie_manager_t* cef_cookie_manager_get_global_manager (
+ cef_completion_callback_t* callback);
+
+///
+// Structure to implement for visiting cookie values. The functions of this
+// structure will always be called on the UI thread.
+///
+struct cef_cookie_visitor_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be called once for each cookie. |count| is the 0-based
+ // index for the current cookie. |total| is the total number of cookies. Set
+ // |deleteCookie| to true (1) to delete the cookie currently being visited.
+ // Return false (0) to stop visiting cookies. This function may never be
+ // called if no cookies are found.
+ ///
+ extern(System) int function (
+ cef_cookie_visitor_t* self,
+ const(cef_cookie_t)* cookie,
+ int count,
+ int total,
+ int* deleteCookie) nothrow visit;
+}
+
+
+
+///
+// Structure to implement to be notified of asynchronous completion via
+// cef_cookie_manager_t::set_cookie().
+///
+struct cef_set_cookie_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be called upon completion. |success| will be true (1) if
+ // the cookie was set successfully.
+ ///
+ extern(System) void function (cef_set_cookie_callback_t* self, int success) nothrow on_complete;
+}
+
+
+
+///
+// Structure to implement to be notified of asynchronous completion via
+// cef_cookie_manager_t::delete_cookies().
+///
+struct cef_delete_cookies_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be called upon completion. |num_deleted| will be the
+ // number of cookies that were deleted.
+ ///
+ extern(System) void function (
+ cef_delete_cookies_callback_t* self,
+ int num_deleted) nothrow on_complete;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=5e19231e3476eef376c2742e8d375bee7bd4ea2d$
+//
+
+extern (C):
+
+///
+// Crash reporting is configured using an INI-style config file named
+// "crash_reporter.cfg". On Windows and Linux this file must be placed next to
+// the main application executable. On macOS this file must be placed in the
+// top-level app bundle Resources directory (e.g.
+// ".app/Contents/Resources"). File contents are as follows:
+//
+// # Comments start with a hash character and must be on their own line.
+//
+// [Config]
+// ProductName=
+// ProductVersion=
+// AppName=
+// ExternalHandler=
+// BrowserCrashForwardingEnabled=
+// ServerURL=
+// RateLimitEnabled=
+// MaxUploadsPerDay=
+// MaxDatabaseSizeInMb=
+// MaxDatabaseAgeInDays=
+//
+// [CrashKeys]
+// my_key1=
+// my_key2=
+//
+// Config section:
+//
+// If "ProductName" and/or "ProductVersion" are set then the specified values
+// will be included in the crash dump metadata. On macOS if these values are set
+// to NULL then they will be retrieved from the Info.plist file using the
+// "CFBundleName" and "CFBundleShortVersionString" keys respectively.
+//
+// If "AppName" is set on Windows then crash report information (metrics,
+// database and dumps) will be stored locally on disk under the
+// "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. On other
+// platforms the CefSettings.user_data_path value will be used.
+//
+// If "ExternalHandler" is set on Windows then the specified exe will be
+// launched as the crashpad-handler instead of re-launching the main process
+// exe. The value can be an absolute path or a path relative to the main exe
+// directory. On Linux the CefSettings.browser_subprocess_path value will be
+// used. On macOS the existing subprocess app bundle will be used.
+//
+// If "BrowserCrashForwardingEnabled" is set to true (1) on macOS then browser
+// process crashes will be forwarded to the system crash reporter. This results
+// in the crash UI dialog being displayed to the user and crash reports being
+// logged under "~/Library/Logs/DiagnosticReports". Forwarding of crash reports
+// from non-browser processes and Debug builds is always disabled.
+//
+// If "ServerURL" is set then crashes will be uploaded as a multi-part POST
+// request to the specified URL. Otherwise, reports will only be stored locally
+// on disk.
+//
+// If "RateLimitEnabled" is set to true (1) then crash report uploads will be
+// rate limited as follows:
+// 1. If "MaxUploadsPerDay" is set to a positive value then at most the
+// specified number of crashes will be uploaded in each 24 hour period.
+// 2. If crash upload fails due to a network or server error then an
+// incremental backoff delay up to a maximum of 24 hours will be applied for
+// retries.
+// 3. If a backoff delay is applied and "MaxUploadsPerDay" is > 1 then the
+// "MaxUploadsPerDay" value will be reduced to 1 until the client is
+// restarted. This helps to avoid an upload flood when the network or
+// server error is resolved.
+// Rate limiting is not supported on Linux.
+//
+// If "MaxDatabaseSizeInMb" is set to a positive value then crash report storage
+// on disk will be limited to that size in megabytes. For example, on Windows
+// each dump is about 600KB so a "MaxDatabaseSizeInMb" value of 20 equates to
+// about 34 crash reports stored on disk. Not supported on Linux.
+//
+// If "MaxDatabaseAgeInDays" is set to a positive value then crash reports older
+// than the specified age in days will be deleted. Not supported on Linux.
+//
+// CrashKeys section:
+//
+// A maximum of 26 crash keys of each size can be specified for use by the
+// application. Crash key values will be truncated based on the specified size
+// (small = 64 bytes, medium = 256 bytes, large = 1024 bytes). The value of
+// crash keys can be set from any thread or process using the
+// CefSetCrashKeyValue function. These key/value pairs will be sent to the crash
+// server along with the crash dump file.
+///
+int cef_crash_reporting_enabled ();
+
+///
+// Sets or clears a specific key-value pair from the crash metadata.
+///
+void cef_set_crash_key_value (
+ const(cef_string_t)* key,
+ const(cef_string_t)* value);
+
+// CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=1a256c04042ebd4867f39e1c31def558871b2bab$
+//
+
+extern (C):
+
+
+
+///
+// Callback structure for cef_browser_host_t::AddDevToolsMessageObserver. The
+// functions of this structure will be called on the browser process UI thread.
+///
+struct cef_dev_tools_message_observer_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method that will be called on receipt of a DevTools protocol message.
+ // |browser| is the originating browser instance. |message| is a UTF8-encoded
+ // JSON dictionary representing either a function result or an event.
+ // |message| is only valid for the scope of this callback and should be copied
+ // if necessary. Return true (1) if the message was handled or false (0) if
+ // the message should be further processed and passed to the
+ // OnDevToolsMethodResult or OnDevToolsEvent functions as appropriate.
+ //
+ // Method result dictionaries include an "id" (int) value that identifies the
+ // orginating function call sent from cef_browser_host_t::SendDevToolsMessage,
+ // and optionally either a "result" (dictionary) or "error" (dictionary)
+ // value. The "error" dictionary will contain "code" (int) and "message"
+ // (string) values. Event dictionaries include a "function" (string) value and
+ // optionally a "params" (dictionary) value. See the DevTools protocol
+ // documentation at https://chromedevtools.github.io/devtools-protocol/ for
+ // details of supported function calls and the expected "result" or "params"
+ // dictionary contents. JSON dictionaries can be parsed using the CefParseJSON
+ // function if desired, however be aware of performance considerations when
+ // parsing large messages (some of which may exceed 1MB in size).
+ ///
+ extern(System) int function (
+ cef_dev_tools_message_observer_t* self,
+ cef_browser_t* browser,
+ const(void)* message,
+ size_t message_size) nothrow on_dev_tools_message;
+
+ ///
+ // Method that will be called after attempted execution of a DevTools protocol
+ // function. |browser| is the originating browser instance. |message_id| is
+ // the "id" value that identifies the originating function call message. If
+ // the function succeeded |success| will be true (1) and |result| will be the
+ // UTF8-encoded JSON "result" dictionary value (which may be NULL). If the
+ // function failed |success| will be false (0) and |result| will be the
+ // UTF8-encoded JSON "error" dictionary value. |result| is only valid for the
+ // scope of this callback and should be copied if necessary. See the
+ // OnDevToolsMessage documentation for additional details on |result|
+ // contents.
+ ///
+ extern(System) void function (
+ cef_dev_tools_message_observer_t* self,
+ cef_browser_t* browser,
+ int message_id,
+ int success,
+ const(void)* result,
+ size_t result_size) nothrow on_dev_tools_method_result;
+
+ ///
+ // Method that will be called on receipt of a DevTools protocol event.
+ // |browser| is the originating browser instance. |function| is the "function"
+ // value. |params| is the UTF8-encoded JSON "params" dictionary value (which
+ // may be NULL). |params| is only valid for the scope of this callback and
+ // should be copied if necessary. See the OnDevToolsMessage documentation for
+ // additional details on |params| contents.
+ ///
+ extern(System) void function (
+ cef_dev_tools_message_observer_t* self,
+ cef_browser_t* browser,
+ const(cef_string_t)* method,
+ const(void)* params,
+ size_t params_size) nothrow on_dev_tools_event;
+
+ ///
+ // Method that will be called when the DevTools agent has attached. |browser|
+ // is the originating browser instance. This will generally occur in response
+ // to the first message sent while the agent is detached.
+ ///
+ extern(System) void function (
+ cef_dev_tools_message_observer_t* self,
+ cef_browser_t* browser) nothrow on_dev_tools_agent_attached;
+
+ ///
+ // Method that will be called when the DevTools agent has detached. |browser|
+ // is the originating browser instance. Any function results that were pending
+ // before the agent became detached will not be delivered, and any active
+ // event subscriptions will be canceled.
+ ///
+ extern(System) void function (
+ cef_dev_tools_message_observer_t* self,
+ cef_browser_t* browser) nothrow on_dev_tools_agent_detached;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DEVTOOLS_MESSAGE_OBSERVER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=5ae5556e4085faf8cf17ee757f5eeac9197f75c0$
+//
+
+extern (C):
+
+///
+// Callback structure for asynchronous continuation of file dialog requests.
+///
+struct cef_file_dialog_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Continue the file selection. |selected_accept_filter| should be the 0-based
+ // index of the value selected from the accept filters array passed to
+ // cef_dialog_handler_t::OnFileDialog. |file_paths| should be a single value
+ // or a list of values depending on the dialog mode. An NULL |file_paths|
+ // value is treated the same as calling cancel().
+ ///
+ extern(System) void function (
+ cef_file_dialog_callback_t* self,
+ int selected_accept_filter,
+ cef_string_list_t file_paths) nothrow cont;
+
+ ///
+ // Cancel the file selection.
+ ///
+ extern(System) void function (cef_file_dialog_callback_t* self) nothrow cancel;
+}
+
+
+
+///
+// Implement this structure to handle dialog events. The functions of this
+// structure will be called on the browser process UI thread.
+///
+struct cef_dialog_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called to run a file chooser dialog. |mode| represents the type of dialog
+ // to display. |title| to the title to be used for the dialog and may be NULL
+ // to show the default title ("Open" or "Save" depending on the mode).
+ // |default_file_path| is the path with optional directory and/or file name
+ // component that should be initially selected in the dialog. |accept_filters|
+ // are used to restrict the selectable file types and may any combination of
+ // (a) valid lower-cased MIME types (e.g. "text/*" or "image/*"), (b)
+ // individual file extensions (e.g. ".txt" or ".png"), or (c) combined
+ // description and file extension delimited using "|" and ";" (e.g. "Image
+ // Types|.png;.gif;.jpg"). |selected_accept_filter| is the 0-based index of
+ // the filter that should be selected by default. To display a custom dialog
+ // return true (1) and execute |callback| either inline or at a later time. To
+ // display the default dialog return false (0).
+ ///
+ extern(System) int function (
+ cef_dialog_handler_t* self,
+ cef_browser_t* browser,
+ cef_file_dialog_mode_t mode,
+ const(cef_string_t)* title,
+ const(cef_string_t)* default_file_path,
+ cef_string_list_t accept_filters,
+ int selected_accept_filter,
+ cef_file_dialog_callback_t* callback) nothrow on_file_dialog;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=067fd169a30bec1ad8eeacc5ab1ac750cf59640e$
+//
+
+import core.stdc.config;
+
+extern (C):
+
+///
+// Implement this structure to handle events related to browser display state.
+// The functions of this structure will be called on the UI thread.
+///
+struct cef_display_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called when a frame's address has changed.
+ ///
+ extern(System) void function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame,
+ const(cef_string_t)* url) nothrow on_address_change;
+
+ ///
+ // Called when the page title changes.
+ ///
+ extern(System) void function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ const(cef_string_t)* title) nothrow on_title_change;
+
+ ///
+ // Called when the page icon changes.
+ ///
+ extern(System) void function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ cef_string_list_t icon_urls) nothrow on_favicon_urlchange;
+
+ ///
+ // Called when web content in the page has toggled fullscreen mode. If
+ // |fullscreen| is true (1) the content will automatically be sized to fill
+ // the browser content area. If |fullscreen| is false (0) the content will
+ // automatically return to its original size and position. The client is
+ // responsible for resizing the browser if desired.
+ ///
+ extern(System) void function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ int fullscreen) nothrow on_fullscreen_mode_change;
+
+ ///
+ // Called when the browser is about to display a tooltip. |text| contains the
+ // text that will be displayed in the tooltip. To handle the display of the
+ // tooltip yourself return true (1). Otherwise, you can optionally modify
+ // |text| and then return false (0) to allow the browser to display the
+ // tooltip. When window rendering is disabled the application is responsible
+ // for drawing tooltips and the return value is ignored.
+ ///
+ extern(System) int function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ cef_string_t* text) nothrow on_tooltip;
+
+ ///
+ // Called when the browser receives a status message. |value| contains the
+ // text that will be displayed in the status message.
+ ///
+ extern(System) void function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ const(cef_string_t)* value) nothrow on_status_message;
+
+ ///
+ // Called to display a console message. Return true (1) to stop the message
+ // from being output to the console.
+ ///
+ extern(System) int function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ cef_log_severity_t level,
+ const(cef_string_t)* message,
+ const(cef_string_t)* source,
+ int line) nothrow on_console_message;
+
+ ///
+ // Called when auto-resize is enabled via
+ // cef_browser_host_t::SetAutoResizeEnabled and the contents have auto-
+ // resized. |new_size| will be the desired size in view coordinates. Return
+ // true (1) if the resize was handled or false (0) for default handling.
+ ///
+ extern(System) int function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ const(cef_size_t)* new_size) nothrow on_auto_resize;
+
+ ///
+ // Called when the overall page loading progress has changed. |progress|
+ // ranges from 0.0 to 1.0.
+ ///
+ extern(System) void function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ double progress) nothrow on_loading_progress_change;
+
+ ///
+ // Called when the browser's cursor has changed. If |type| is CT_CUSTOM then
+ // |custom_cursor_info| will be populated with the custom cursor information.
+ // Return true (1) if the cursor change was handled or false (0) for default
+ // handling.
+ ///
+ extern(System) int function (
+ cef_display_handler_t* self,
+ cef_browser_t* browser,
+ c_ulong cursor,
+ cef_cursor_type_t type,
+ const(cef_cursor_info_t)* custom_cursor_info) nothrow on_cursor_change;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=0517dc6c42fdde9fecfc4549fab1ea12b614e143$
+//
+
+extern (C):
+
+///
+// Structure to implement for visiting the DOM. The functions of this structure
+// will be called on the render process main thread.
+///
+struct cef_domvisitor_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Method executed for visiting the DOM. The document object passed to this
+ // function represents a snapshot of the DOM at the time this function is
+ // executed. DOM objects are only valid for the scope of this function. Do not
+ // keep references to or attempt to access any DOM objects outside the scope
+ // of this function.
+ ///
+ extern(System) void function (
+ cef_domvisitor_t* self,
+ cef_domdocument_t* document) nothrow visit;
+}
+
+
+
+///
+// Structure used to represent a DOM document. The functions of this structure
+// should only be called on the render process main thread thread.
+///
+struct cef_domdocument_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns the document type.
+ ///
+ extern(System) cef_dom_document_type_t function (cef_domdocument_t* self) nothrow get_type;
+
+ ///
+ // Returns the root document node.
+ ///
+ extern(System) cef_domnode_t* function (cef_domdocument_t* self) nothrow get_document;
+
+ ///
+ // Returns the BODY node of an HTML document.
+ ///
+ extern(System) cef_domnode_t* function (cef_domdocument_t* self) nothrow get_body;
+
+ ///
+ // Returns the HEAD node of an HTML document.
+ ///
+ extern(System) cef_domnode_t* function (cef_domdocument_t* self) nothrow get_head;
+
+ ///
+ // Returns the title of an HTML document.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_domdocument_t* self) nothrow get_title;
+
+ ///
+ // Returns the document element with the specified ID value.
+ ///
+ extern(System) cef_domnode_t* function (
+ cef_domdocument_t* self,
+ const(cef_string_t)* id) nothrow get_element_by_id;
+
+ ///
+ // Returns the node that currently has keyboard focus.
+ ///
+ extern(System) cef_domnode_t* function (cef_domdocument_t* self) nothrow get_focused_node;
+
+ ///
+ // Returns true (1) if a portion of the document is selected.
+ ///
+ extern(System) int function (cef_domdocument_t* self) nothrow has_selection;
+
+ ///
+ // Returns the selection offset within the start node.
+ ///
+ extern(System) int function (cef_domdocument_t* self) nothrow get_selection_start_offset;
+
+ ///
+ // Returns the selection offset within the end node.
+ ///
+ extern(System) int function (cef_domdocument_t* self) nothrow get_selection_end_offset;
+
+ ///
+ // Returns the contents of this selection as markup.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_domdocument_t* self) nothrow get_selection_as_markup;
+
+ ///
+ // Returns the contents of this selection as text.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_domdocument_t* self) nothrow get_selection_as_text;
+
+ ///
+ // Returns the base URL for the document.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_domdocument_t* self) nothrow get_base_url;
+
+ ///
+ // Returns a complete URL based on the document base URL and the specified
+ // partial URL.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_domdocument_t* self,
+ const(cef_string_t)* partialURL) nothrow get_complete_url;
+}
+
+
+
+///
+// Structure used to represent a DOM node. The functions of this structure
+// should only be called on the render process main thread.
+///
+struct cef_domnode_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns the type for this node.
+ ///
+ extern(System) cef_dom_node_type_t function (cef_domnode_t* self) nothrow get_type;
+
+ ///
+ // Returns true (1) if this is a text node.
+ ///
+ extern(System) int function (cef_domnode_t* self) nothrow is_text;
+
+ ///
+ // Returns true (1) if this is an element node.
+ ///
+ extern(System) int function (cef_domnode_t* self) nothrow is_element;
+
+ ///
+ // Returns true (1) if this is an editable node.
+ ///
+ extern(System) int function (cef_domnode_t* self) nothrow is_editable;
+
+ ///
+ // Returns true (1) if this is a form control element node.
+ ///
+ extern(System) int function (cef_domnode_t* self) nothrow is_form_control_element;
+
+ ///
+ // Returns the type of this form control element node.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_domnode_t* self) nothrow get_form_control_element_type;
+
+ ///
+ // Returns true (1) if this object is pointing to the same handle as |that|
+ // object.
+ ///
+ extern(System) int function (cef_domnode_t* self, cef_domnode_t* that) nothrow is_same;
+
+ ///
+ // Returns the name of this node.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_domnode_t* self) nothrow get_name;
+
+ ///
+ // Returns the value of this node.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_domnode_t* self) nothrow get_value;
+
+ ///
+ // Set the value of this node. Returns true (1) on success.
+ ///
+ extern(System) int function (cef_domnode_t* self, const(cef_string_t)* value) nothrow set_value;
+
+ ///
+ // Returns the contents of this node as markup.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_domnode_t* self) nothrow get_as_markup;
+
+ ///
+ // Returns the document associated with this node.
+ ///
+ extern(System) cef_domdocument_t* function (cef_domnode_t* self) nothrow get_document;
+
+ ///
+ // Returns the parent node.
+ ///
+ extern(System) cef_domnode_t* function (cef_domnode_t* self) nothrow get_parent;
+
+ ///
+ // Returns the previous sibling node.
+ ///
+ extern(System) cef_domnode_t* function (cef_domnode_t* self) nothrow get_previous_sibling;
+
+ ///
+ // Returns the next sibling node.
+ ///
+ extern(System) cef_domnode_t* function (cef_domnode_t* self) nothrow get_next_sibling;
+
+ ///
+ // Returns true (1) if this node has child nodes.
+ ///
+ extern(System) int function (cef_domnode_t* self) nothrow has_children;
+
+ ///
+ // Return the first child node.
+ ///
+ extern(System) cef_domnode_t* function (cef_domnode_t* self) nothrow get_first_child;
+
+ ///
+ // Returns the last child node.
+ ///
+ extern(System) cef_domnode_t* function (cef_domnode_t* self) nothrow get_last_child;
+
+ // The following functions are valid only for element nodes.
+
+ ///
+ // Returns the tag name of this element.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_domnode_t* self) nothrow get_element_tag_name;
+
+ ///
+ // Returns true (1) if this element has attributes.
+ ///
+ extern(System) int function (cef_domnode_t* self) nothrow has_element_attributes;
+
+ ///
+ // Returns true (1) if this element has an attribute named |attrName|.
+ ///
+ extern(System) int function (
+ cef_domnode_t* self,
+ const(cef_string_t)* attrName) nothrow has_element_attribute;
+
+ ///
+ // Returns the element attribute named |attrName|.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_domnode_t* self,
+ const(cef_string_t)* attrName) nothrow get_element_attribute;
+
+ ///
+ // Returns a map of all element attributes.
+ ///
+ extern(System) void function (
+ cef_domnode_t* self,
+ cef_string_map_t attrMap) nothrow get_element_attributes;
+
+ ///
+ // Set the value for the element attribute named |attrName|. Returns true (1)
+ // on success.
+ ///
+ extern(System) int function (
+ cef_domnode_t* self,
+ const(cef_string_t)* attrName,
+ const(cef_string_t)* value) nothrow set_element_attribute;
+
+ ///
+ // Returns the inner text of the element.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_domnode_t* self) nothrow get_element_inner_text;
+
+ ///
+ // Returns the bounds of the element.
+ ///
+ extern(System) cef_rect_t function (cef_domnode_t* self) nothrow get_element_bounds;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=f0ceb73b289072a01c45c6e7abf339a4ec924d29$
+//
+
+extern (C):
+
+///
+// Callback structure used to asynchronously continue a download.
+///
+struct cef_before_download_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Call to continue the download. Set |download_path| to the full file path
+ // for the download including the file name or leave blank to use the
+ // suggested name and the default temp directory. Set |show_dialog| to true
+ // (1) if you do wish to show the default "Save As" dialog.
+ ///
+ extern(System) void function (
+ cef_before_download_callback_t* self,
+ const(cef_string_t)* download_path,
+ int show_dialog) nothrow cont;
+}
+
+
+
+///
+// Callback structure used to asynchronously cancel a download.
+///
+struct cef_download_item_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Call to cancel the download.
+ ///
+ extern(System) void function (cef_download_item_callback_t* self) nothrow cancel;
+
+ ///
+ // Call to pause the download.
+ ///
+ extern(System) void function (cef_download_item_callback_t* self) nothrow pause;
+
+ ///
+ // Call to resume the download.
+ ///
+ extern(System) void function (cef_download_item_callback_t* self) nothrow resume;
+}
+
+
+
+///
+// Structure used to handle file downloads. The functions of this structure will
+// called on the browser process UI thread.
+///
+struct cef_download_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called before a download begins. |suggested_name| is the suggested name for
+ // the download file. By default the download will be canceled. Execute
+ // |callback| either asynchronously or in this function to continue the
+ // download if desired. Do not keep a reference to |download_item| outside of
+ // this function.
+ ///
+ extern(System) void function (
+ cef_download_handler_t* self,
+ cef_browser_t* browser,
+ cef_download_item_t* download_item,
+ const(cef_string_t)* suggested_name,
+ cef_before_download_callback_t* callback) nothrow on_before_download;
+
+ ///
+ // Called when a download's status or progress information has been updated.
+ // This may be called multiple times before and after on_before_download().
+ // Execute |callback| either asynchronously or in this function to cancel the
+ // download if desired. Do not keep a reference to |download_item| outside of
+ // this function.
+ ///
+ extern(System) void function (
+ cef_download_handler_t* self,
+ cef_browser_t* browser,
+ cef_download_item_t* download_item,
+ cef_download_item_callback_t* callback) nothrow on_download_updated;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=d84044bb582b029af5fa46c75f35b3da948dffd2$
+//
+
+extern (C):
+
+///
+// Structure used to represent a download item.
+///
+struct cef_download_item_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns true (1) if this object is valid. Do not call any other functions
+ // if this function returns false (0).
+ ///
+ extern(System) int function (cef_download_item_t* self) nothrow is_valid;
+
+ ///
+ // Returns true (1) if the download is in progress.
+ ///
+ extern(System) int function (cef_download_item_t* self) nothrow is_in_progress;
+
+ ///
+ // Returns true (1) if the download is complete.
+ ///
+ extern(System) int function (cef_download_item_t* self) nothrow is_complete;
+
+ ///
+ // Returns true (1) if the download has been canceled or interrupted.
+ ///
+ extern(System) int function (cef_download_item_t* self) nothrow is_canceled;
+
+ ///
+ // Returns a simple speed estimate in bytes/s.
+ ///
+ extern(System) int64 function (cef_download_item_t* self) nothrow get_current_speed;
+
+ ///
+ // Returns the rough percent complete or -1 if the receive total size is
+ // unknown.
+ ///
+ extern(System) int function (cef_download_item_t* self) nothrow get_percent_complete;
+
+ ///
+ // Returns the total number of bytes.
+ ///
+ extern(System) int64 function (cef_download_item_t* self) nothrow get_total_bytes;
+
+ ///
+ // Returns the number of received bytes.
+ ///
+ extern(System) int64 function (cef_download_item_t* self) nothrow get_received_bytes;
+
+ ///
+ // Returns the time that the download started.
+ ///
+ extern(System) cef_time_t function (cef_download_item_t* self) nothrow get_start_time;
+
+ ///
+ // Returns the time that the download ended.
+ ///
+ extern(System) cef_time_t function (cef_download_item_t* self) nothrow get_end_time;
+
+ ///
+ // Returns the full path to the downloaded or downloading file.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_download_item_t* self) nothrow get_full_path;
+
+ ///
+ // Returns the unique identifier for this download.
+ ///
+ extern(System) uint32 function (cef_download_item_t* self) nothrow get_id;
+
+ ///
+ // Returns the URL.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_download_item_t* self) nothrow get_url;
+
+ ///
+ // Returns the original URL before any redirections.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_download_item_t* self) nothrow get_original_url;
+
+ ///
+ // Returns the suggested file name.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_download_item_t* self) nothrow get_suggested_file_name;
+
+ ///
+ // Returns the content disposition.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_download_item_t* self) nothrow get_content_disposition;
+
+ ///
+ // Returns the mime type.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_download_item_t* self) nothrow get_mime_type;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=9663321e2be1d000ac54e195c81f210ae40773d1$
+//
+
+extern (C):
+
+///
+// Structure used to represent drag data. The functions of this structure may be
+// called on any thread.
+///
+struct cef_drag_data_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns a copy of the current object.
+ ///
+ extern(System) cef_drag_data_t* function (cef_drag_data_t* self) nothrow clone;
+
+ ///
+ // Returns true (1) if this object is read-only.
+ ///
+ extern(System) int function (cef_drag_data_t* self) nothrow is_read_only;
+
+ ///
+ // Returns true (1) if the drag data is a link.
+ ///
+ extern(System) int function (cef_drag_data_t* self) nothrow is_link;
+
+ ///
+ // Returns true (1) if the drag data is a text or html fragment.
+ ///
+ extern(System) int function (cef_drag_data_t* self) nothrow is_fragment;
+
+ ///
+ // Returns true (1) if the drag data is a file.
+ ///
+ extern(System) int function (cef_drag_data_t* self) nothrow is_file;
+
+ ///
+ // Return the link URL that is being dragged.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_drag_data_t* self) nothrow get_link_url;
+
+ ///
+ // Return the title associated with the link being dragged.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_drag_data_t* self) nothrow get_link_title;
+
+ ///
+ // Return the metadata, if any, associated with the link being dragged.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_drag_data_t* self) nothrow get_link_metadata;
+
+ ///
+ // Return the plain text fragment that is being dragged.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_drag_data_t* self) nothrow get_fragment_text;
+
+ ///
+ // Return the text/html fragment that is being dragged.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_drag_data_t* self) nothrow get_fragment_html;
+
+ ///
+ // Return the base URL that the fragment came from. This value is used for
+ // resolving relative URLs and may be NULL.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (
+ cef_drag_data_t* self) nothrow get_fragment_base_url;
+
+ ///
+ // Return the name of the file being dragged out of the browser window.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_drag_data_t* self) nothrow get_file_name;
+
+ ///
+ // Write the contents of the file being dragged out of the web view into
+ // |writer|. Returns the number of bytes sent to |writer|. If |writer| is NULL
+ // this function will return the size of the file contents in bytes. Call
+ // get_file_name() to get a suggested name for the file.
+ ///
+ extern(System) size_t function (
+ cef_drag_data_t* self,
+ cef_stream_writer_t* writer) nothrow get_file_contents;
+
+ ///
+ // Retrieve the list of file names that are being dragged into the browser
+ // window.
+ ///
+ extern(System) int function (
+ cef_drag_data_t* self,
+ cef_string_list_t names) nothrow get_file_names;
+
+ ///
+ // Set the link URL that is being dragged.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* url) nothrow set_link_url;
+
+ ///
+ // Set the title associated with the link being dragged.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* title) nothrow set_link_title;
+
+ ///
+ // Set the metadata associated with the link being dragged.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* data) nothrow set_link_metadata;
+
+ ///
+ // Set the plain text fragment that is being dragged.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* text) nothrow set_fragment_text;
+
+ ///
+ // Set the text/html fragment that is being dragged.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* html) nothrow set_fragment_html;
+
+ ///
+ // Set the base URL that the fragment came from.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* base_url) nothrow set_fragment_base_url;
+
+ ///
+ // Reset the file contents. You should do this before calling
+ // cef_browser_host_t::DragTargetDragEnter as the web view does not allow us
+ // to drag in this kind of data.
+ ///
+ extern(System) void function (cef_drag_data_t* self) nothrow reset_file_contents;
+
+ ///
+ // Add a file that is being dragged into the webview.
+ ///
+ extern(System) void function (
+ cef_drag_data_t* self,
+ const(cef_string_t)* path,
+ const(cef_string_t)* display_name) nothrow add_file;
+
+ ///
+ // Get the image representation of drag data. May return NULL if no image
+ // representation is available.
+ ///
+ extern(System) cef_image_t* function (cef_drag_data_t* self) nothrow get_image;
+
+ ///
+ // Get the image hotspot (drag start location relative to image dimensions).
+ ///
+ extern(System) cef_point_t function (cef_drag_data_t* self) nothrow get_image_hotspot;
+
+ ///
+ // Returns true (1) if an image representation of drag data is available.
+ ///
+ extern(System) int function (cef_drag_data_t* self) nothrow has_image;
+}
+
+
+
+///
+// Create a new cef_drag_data_t object.
+///
+cef_drag_data_t* cef_drag_data_create ();
+
+// CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=1cc1f134e68406ae3b05f7e181e12f27262772f0$
+//
+
+extern (C):
+
+///
+// Implement this structure to handle events related to dragging. The functions
+// of this structure will be called on the UI thread.
+///
+struct cef_drag_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called when an external drag event enters the browser window. |dragData|
+ // contains the drag event data and |mask| represents the type of drag
+ // operation. Return false (0) for default drag handling behavior or true (1)
+ // to cancel the drag event.
+ ///
+ extern(System) int function (
+ cef_drag_handler_t* self,
+ cef_browser_t* browser,
+ cef_drag_data_t* dragData,
+ cef_drag_operations_mask_t mask) nothrow on_drag_enter;
+
+ ///
+ // Called whenever draggable regions for the browser window change. These can
+ // be specified using the '-webkit-app-region: drag/no-drag' CSS-property. If
+ // draggable regions are never defined in a document this function will also
+ // never be called. If the last draggable region is removed from a document
+ // this function will be called with an NULL vector.
+ ///
+ extern(System) void function (
+ cef_drag_handler_t* self,
+ cef_browser_t* browser,
+ cef_frame_t* frame,
+ size_t regionsCount,
+ const(cef_draggable_region_t)* regions) nothrow on_draggable_regions_changed;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=5d5251098be1477705de2a21502dec2d8338ce00$
+//
+
+extern (C):
+
+
+
+
+///
+// Object representing an extension. Methods may be called on any thread unless
+// otherwise indicated.
+///
+struct cef_extension_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Returns the unique extension identifier. This is calculated based on the
+ // extension public key, if available, or on the extension path. See
+ // https://developer.chrome.com/extensions/manifest/key for details.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_extension_t* self) nothrow get_identifier;
+
+ ///
+ // Returns the absolute path to the extension directory on disk. This value
+ // will be prefixed with PK_DIR_RESOURCES if a relative path was passed to
+ // cef_request_context_t::LoadExtension.
+ ///
+ // The resulting string must be freed by calling cef_string_userfree_free().
+ extern(System) cef_string_userfree_t function (cef_extension_t* self) nothrow get_path;
+
+ ///
+ // Returns the extension manifest contents as a cef_dictionary_value_t object.
+ // See https://developer.chrome.com/extensions/manifest for details.
+ ///
+ extern(System) cef_dictionary_value_t* function (cef_extension_t* self) nothrow get_manifest;
+
+ ///
+ // Returns true (1) if this object is the same extension as |that| object.
+ // Extensions are considered the same if identifier, path and loader context
+ // match.
+ ///
+ extern(System) int function (cef_extension_t* self, cef_extension_t* that) nothrow is_same;
+
+ ///
+ // Returns the handler for this extension. Will return NULL for internal
+ // extensions or if no handler was passed to
+ // cef_request_context_t::LoadExtension.
+ ///
+ extern(System) cef_extension_handler_t* function (cef_extension_t* self) nothrow get_handler;
+
+ ///
+ // Returns the request context that loaded this extension. Will return NULL
+ // for internal extensions or if the extension has been unloaded. See the
+ // cef_request_context_t::LoadExtension documentation for more information
+ // about loader contexts. Must be called on the browser process UI thread.
+ ///
+ extern(System) cef_request_context_t* function (
+ cef_extension_t* self) nothrow get_loader_context;
+
+ ///
+ // Returns true (1) if this extension is currently loaded. Must be called on
+ // the browser process UI thread.
+ ///
+ extern(System) int function (cef_extension_t* self) nothrow is_loaded;
+
+ ///
+ // Unload this extension if it is not an internal extension and is currently
+ // loaded. Will result in a call to
+ // cef_extension_handler_t::OnExtensionUnloaded on success.
+ ///
+ extern(System) void function (cef_extension_t* self) nothrow unload;
+}
+
+
+
+// CEF_INCLUDE_CAPI_CEF_EXTENSION_CAPI_H_
+// Copyright (c) 2021 Marshall A. Greenblatt. All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the name Chromium Embedded
+// Framework nor the names of its contributors may be used to endorse
+// or promote products derived from this software without specific prior
+// written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+// ---------------------------------------------------------------------------
+//
+// This file was generated by the CEF translator tool and should not edited
+// by hand. See the translator.README.txt file in the tools directory for
+// more information.
+//
+// $hash=c952241dabb9d99109ebb64acba0124e43150628$
+//
+
+extern (C):
+
+
+
+///
+// Callback structure used for asynchronous continuation of
+// cef_extension_handler_t::GetExtensionResource.
+///
+struct cef_get_extension_resource_callback_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Continue the request. Read the resource contents from |stream|.
+ ///
+ extern(System) void function (
+ cef_get_extension_resource_callback_t* self,
+ cef_stream_reader_t* stream) nothrow cont;
+
+ ///
+ // Cancel the request.
+ ///
+ extern(System) void function (cef_get_extension_resource_callback_t* self) nothrow cancel;
+}
+
+
+
+///
+// Implement this structure to handle events related to browser extensions. The
+// functions of this structure will be called on the UI thread. See
+// cef_request_context_t::LoadExtension for information about extension loading.
+///
+struct cef_extension_handler_t
+{
+ ///
+ // Base structure.
+ ///
+ cef_base_ref_counted_t base;
+
+ ///
+ // Called if the cef_request_context_t::LoadExtension request fails. |result|
+ // will be the error code.
+ ///
+ extern(System) void function (
+ cef_extension_handler_t* self,
+ cef_errorcode_t result) nothrow on_extension_load_failed;
+
+ ///
+ // Called if the cef_request_context_t::LoadExtension request succeeds.
+ // |extension| is the loaded extension.
+ ///
+ extern(System) void function (
+ cef_extension_handler_t* self,
+ cef_extension_t* extension) nothrow on_extension_loaded;
+
+ ///
+ // Called after the cef_extension_t::Unload request has completed.
+ ///
+ extern(System) void function (
+ cef_extension_handler_t* self,
+ cef_extension_t* extension) nothrow on_extension_unloaded;
+
+ ///
+ // Called when an extension needs a browser to host a background script
+ // specified via the "background" manifest key. The browser will have no
+ // visible window and cannot be displayed. |extension| is the extension that
+ // is loading the background script. |url| is an internally generated
+ // reference to an HTML page that will be used to load the background script
+ // via a