Skip to content

⚡ Zig binding & wrapper for a tiny cross-platform webview library to build modern cross-platform GUIs.

License

Notifications You must be signed in to change notification settings

tocha699/webview-zig

 
 

Repository files navigation

webview-zig

Zig binding for a tiny cross-platform webview library to build modern cross-platform GUIs.

Requirements

Usage

zig fetch --save https://github.com/thechampagne/webview-zig/archive/refs/heads/main.tar.gz

build.zig.zon:

.{
    .dependencies = .{
        .webview = .{
            .url = "https://github.com/thechampagne/webview-zig/archive/refs/heads/main.tar.gz" ,
          //.hash = "12208586373679a455aa8ef874112c93c1613196f60137878d90ce9d2ae8fb9cd511",
        },
    },
}

build.zig:

const webview = b.dependency("webview", .{
    .target = target,
    .optimize = optimize,
});
exe.root_module.addImport("webview", webview.module("webview"));
exe.linkLibrary(webview.artifact("webviewStatic")); // or "webviewShared" for shared library
// exe.linkSystemLibrary("webview"); to link with installed prebuilt library without building

API

const WebView = struct {

    const WebViewVersionInfo = struct {
        version: struct {
            major: c_uint,
            minor: c_uint,
            patch: c_uint,
        },
        version_number: [32]c_char,
        pre_release: [48]c_char,
        build_metadata: [48]c_char,
    };

    const DispatchCallback = *const fn (WebView, ?*anyopaque) void;

    const BindCallback = *const fn ([:0]const u8, [:0]const u8, ?*anyopaque) void;

    const WindowSizeHint = enum(c_uint) {
        None,
        Min,
        Max,
        Fixed
    };

    const NativeHandle = enum(c_uint) {
        ui_window,
        ui_widget,
        browser_controller
    };

    const WebViewError = error {
        MissingDependency,
        Canceled,
        InvalidState,
        InvalidArgument,
        Unspecified,
        Duplicate,
        NotFound,
    };

    fn CallbackContext(func: [DispatchCallback|BindCallback]) type {
        return struct {
            fn init(data: ?*anyopaque) @This();
        };
    }

    fn create(debug: bool, window: ?*anyopaque) WebView;

    fn run(self: WebView) WebViewError!void;

    fn terminate(self: WebView) WebViewError!void;
    
    fn dispatch(self: WebView, ctx: *const CallbackContext) WebViewError!void;
    
    fn getWindow(self: WebView) ?*anyopaque;

    fn getNativeHandle(self: WebView, kind: NativeHandle) ?*anyopaque;
    
    fn setTitle(self: WebView, title: [:0]const u8) WebViewError!void;
    
    fn setSize(self: WebView, width: i32, height: i32, hint: WindowSizeHint) WebViewError!void;
    
    fn navigate(self: WebView, url: [:0]const u8) WebViewError!void;
    
    fn setHtml(self: WebView, html: [:0]const u8) WebViewError!void;
    
    fn init(self: WebView, js: [:0]const u8) WebViewError!void;
    
    fn eval(self: WebView, js: [:0]const u8) WebViewError!void;
    
    fn bind(self: WebView, name: [:0]const u8, ctx: *const CallbackContext) WebViewError!void;
    
    fn unbind(self: WebView, name: [:0]const u8) WebViewError!void;
    
    fn ret(self: WebView ,seq: [:0]const u8, status: i32, result: [:0]const u8) WebViewError!void;
    
    fn version() *const WebViewVersionInfo;

    fn destroy(self: WebView) WebViewError!void;
}

References

License

This repo is released under the MIT License.

Third party code:

About

⚡ Zig binding & wrapper for a tiny cross-platform webview library to build modern cross-platform GUIs.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Zig 100.0%