From 880f96e1ff67849cd7f8467c6123a828c5377182 Mon Sep 17 00:00:00 2001 From: taliesin Date: Mon, 11 May 2026 21:44:02 +1000 Subject: [PATCH 01/13] webview2/generator: fix type-system bugs and add Phase 1 tests MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Four correctness bugs in the code generator fixed: 1. String output vtable call was passing the nil *uint16 pointer directly (`uintptr(unsafe.Pointer(_name))`) instead of its address so COM could write back. Fixed to `uintptr(unsafe.Pointer(&_name))`. 2. Scalar numeric input params (UINT32, INT32 …) were passed as `uintptr(unsafe.Pointer(&val))` — a pointer to a local — instead of `uintptr(val)`. Root cause: processVtableCallInput used the IDL type name (uppercase "UINT32") to detect numerics but the check looked for lowercase "uint". Now uses GoType throughout. 3. Native int output ([out,retval] int* exitCode) was passed by value (`uintptr(exitCode)` == 0) instead of by reference. Fixed by placing pointer-depth checks before the numeric GoType check. 4. COM BOOL ([in] BOOL value) was passed as unsafe.Pointer(&bool) — a pointer to a 1-byte Go bool — instead of a 4-byte int32 value. Added inputBoolSetup.tmpl and processSetupInputs handling. New capability: [in] LPCWSTR* now maps to []string (C string array) with inputStringArraySetup.tmpl converting to []*uint16 before the vtable call. New files: types/typemap.go — TypePatterns table (17 patterns) + ResolveGoType() types/templates/inputBoolSetup.tmpl types/templates/inputStringArraySetup.tmpl generator/idl_parse_test.go — parse all 6 IDL files, check counts + inheritance chain generator/typemap_test.go — one test per pattern + ResolveGoType unit tests All 36 tests pass (go test ./generator/). Co-Authored-By: Claude Sonnet 4.6 Co-authored-by: multica-agent --- webview2/scripts/generator/idl_parse_test.go | 133 +++++++++ ...oreWebView2CustomSchemeRegistration.go.txt | 22 +- .../testfiles/ICoreWebView2FrameInfo.go.txt | 4 +- ...CoreWebView2ProcessFailedEventArgs2.go.txt | 2 +- webview2/scripts/generator/typemap_test.go | 272 ++++++++++++++++++ webview2/scripts/generator/types/param.go | 51 +++- .../types/templates/inputBoolSetup.tmpl | 6 + .../templates/inputStringArraySetup.tmpl | 14 + webview2/scripts/generator/types/typemap.go | 184 ++++++++++++ 9 files changed, 671 insertions(+), 17 deletions(-) create mode 100644 webview2/scripts/generator/idl_parse_test.go create mode 100644 webview2/scripts/generator/typemap_test.go create mode 100644 webview2/scripts/generator/types/templates/inputBoolSetup.tmpl create mode 100644 webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl create mode 100644 webview2/scripts/generator/types/typemap.go diff --git a/webview2/scripts/generator/idl_parse_test.go b/webview2/scripts/generator/idl_parse_test.go new file mode 100644 index 00000000000..bd401c2a460 --- /dev/null +++ b/webview2/scripts/generator/idl_parse_test.go @@ -0,0 +1,133 @@ +package generator + +import ( + "os" + "testing" + "updater/generator/types" + + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" +) + +// idlFile is a helper that reads an IDL file from the scripts/ directory +// (one level above the generator package). +func idlFile(t *testing.T, name string) []byte { + t.Helper() + data, err := os.ReadFile("../" + name) + require.NoError(t, err, "reading %s", name) + return data +} + +// idlCounts holds the expected declaration counts for one IDL file. +type idlCounts struct { + interfaces int + enums int + structs int + forwards int +} + +var idlCountTable = map[string]idlCounts{ + "WebView2.1.0.1823.32.idl": {interfaces: 197, enums: 39, structs: 2, forwards: 196}, + "WebView2.1.0.1901.177.idl": {interfaces: 198, enums: 40, structs: 2, forwards: 197}, + "WebView2.1.0.2045.28.idl": {interfaces: 198, enums: 40, structs: 2, forwards: 197}, + "WebView2.1.0.2592.51.idl": {interfaces: 231, enums: 46, structs: 2, forwards: 229}, + "WebView2.1.0.2739.15.idl": {interfaces: 244, enums: 51, structs: 2, forwards: 243}, + "WebView2.1.0.2903.40.idl": {interfaces: 252, enums: 51, structs: 2, forwards: 251}, +} + +func TestParseAllIDLFiles(t *testing.T) { + for filename, want := range idlCountTable { + filename, want := filename, want + t.Run(filename, func(t *testing.T) { + data := idlFile(t, filename) + + idl, err := Parser.ParseBytes("", data) + require.NoError(t, err, "parsing %s", filename) + require.Len(t, idl.Libraries, 1, "expected exactly one library block") + + var gotIfaces, gotEnums, gotStructs, gotFwds int + for _, decl := range idl.Libraries[0].Declarations { + if decl.Interface != nil { + gotIfaces++ + } + if decl.Enum != nil { + gotEnums++ + } + if decl.Struct != nil { + gotStructs++ + } + if decl.InterfaceForewardDecl != "" { + gotFwds++ + } + } + + assert.Equal(t, want.interfaces, gotIfaces, "interface count") + assert.Equal(t, want.enums, gotEnums, "enum count") + assert.Equal(t, want.structs, gotStructs, "struct count") + assert.Equal(t, want.forwards, gotFwds, "forward-declaration count") + }) + } +} + +// TestICoreWebView2MethodCount verifies the main interface always has 58 methods. +func TestICoreWebView2MethodCount(t *testing.T) { + for filename := range idlCountTable { + filename := filename + t.Run(filename, func(t *testing.T) { + data := idlFile(t, filename) + idl, err := Parser.ParseBytes("", data) + require.NoError(t, err) + + iface := findInterface(idl, "ICoreWebView2") + require.NotNil(t, iface, "ICoreWebView2 must be present") + assert.Equal(t, "IUnknown", iface.BaseClass) + assert.Equal(t, 58, len(iface.Methods)) + }) + } +} + +// TestInheritanceChain verifies that the latest IDL has the full 27-level chain. +func TestInheritanceChain(t *testing.T) { + data := idlFile(t, "WebView2.1.0.2903.40.idl") + idl, err := Parser.ParseBytes("", data) + require.NoError(t, err) + + // Build name → baseClass map. + bases := map[string]string{} + for _, lib := range idl.Libraries { + for _, decl := range lib.Declarations { + if decl.Interface != nil { + bases[decl.Interface.Name] = decl.Interface.BaseClass + } + } + } + + // Walk from ICoreWebView2_27 back to ICoreWebView2. + chain := []string{} + cur := "ICoreWebView2_27" + for cur != "" && cur != "IUnknown" { + chain = append(chain, cur) + cur = bases[cur] + } + + // Must end at ICoreWebView2 and include every numbered version. + require.Equal(t, "ICoreWebView2", chain[len(chain)-1]) + assert.Equal(t, 27, len(chain), "chain should have 27 entries (_27 through base)") + + // Spot-check a few links. + assert.Equal(t, "ICoreWebView2_27", chain[0]) + assert.Equal(t, "ICoreWebView2_26", chain[1]) + assert.Equal(t, "ICoreWebView2", chain[26]) +} + +// findInterface returns the named InterfaceDeclaration or nil. +func findInterface(idl *types.IDL, name string) *types.InterfaceDeclaration { + for _, lib := range idl.Libraries { + for _, decl := range lib.Declarations { + if decl.Interface != nil && decl.Interface.Name == name { + return decl.Interface + } + } + } + return nil +} diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt index 5f84641027b..40a91e45422 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt @@ -22,17 +22,25 @@ func (i *ICoreWebView2CustomSchemeRegistration) AddRef() uintptr { } -func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins string) error { - - // Convert string 'allowedOrigins' to *uint16 - _allowedOrigins, err := UTF16PtrFromString(allowedOrigins) - if err != nil { - return err +func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins []string) error { + + // Convert []string to COM string array (LPCWSTR*) + _allowedOriginsptrs := make([]*uint16, len(allowedOrigins)) + for _i, _s := range allowedOrigins { + _p, err := UTF16PtrFromString(_s) + if err != nil { + return err + } + _allowedOriginsptrs[_i] = _p + } + var _allowedOrigins **uint16 + if len(_allowedOriginsptrs) > 0 { + _allowedOrigins = &_allowedOriginsptrs[0] } hr, _, err := i.Vtbl.SetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&allowedOriginsCount)), + uintptr(allowedOriginsCount), uintptr(unsafe.Pointer(_allowedOrigins)), ) if windows.Handle(hr) != windows.S_OK { diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt index 1d81a143643..4a16c9c0b00 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt @@ -30,7 +30,7 @@ func (i *ICoreWebView2FrameInfo) GetName() (string, error) { hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_name)), + uintptr(unsafe.Pointer(&_name)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,7 +48,7 @@ func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { hr, _, err := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_source)), + uintptr(unsafe.Pointer(&_source)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt index c16dd90606f..13b0620f6c8 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt @@ -41,7 +41,7 @@ func (i *ICoreWebView2ProcessFailedEventArgs2) GetExitCode() (int, error) { hr, _, err := i.Vtbl.GetExitCode.Call( uintptr(unsafe.Pointer(i)), - uintptr(exitCode), + uintptr(unsafe.Pointer(&exitCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) diff --git a/webview2/scripts/generator/typemap_test.go b/webview2/scripts/generator/typemap_test.go new file mode 100644 index 00000000000..c01def4472d --- /dev/null +++ b/webview2/scripts/generator/typemap_test.go @@ -0,0 +1,272 @@ +package generator + +// typemap_test.go validates all 17 IDL→Go type-mapping patterns by generating +// code from minimal IDL snippets and checking the output. + +import ( + "strings" + "testing" + "updater/generator/types" + + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" +) + +// wrapIDL wraps method declarations inside a minimal library/interface block so +// the parser can process them. +func wrapIDL(methods string) []byte { + return []byte(`[uuid(26d34152-879f-4065-bea2-3daa2cfadfb8), version(1.0)] +library WebView2 { +[uuid(aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa), object, pointer_default(unique)] +interface ITest : IUnknown { +` + methods + ` +} +}`) +} + +// generatedBody parses the IDL, processes it, generates code, then returns the +// content of the first non-com.go file as a string. +func generatedBody(t *testing.T, idl []byte) string { + t.Helper() + files, err := ParseIDL(idl) + require.NoError(t, err) + require.Greater(t, len(files), 1, "expected at least one generated file beyond com.go") + return files[1].Content.String() +} + +// ── Pattern 1: [in] LPWSTR ─────────────────────────────────────────────────── + +func TestTypePattern_InLPWSTR(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT Navigate([in] LPWSTR uri);`, + )) + assert.Contains(t, body, "Navigate(uri string) error") + assert.Contains(t, body, "_uri, err := UTF16PtrFromString(uri)") + assert.Contains(t, body, "uintptr(unsafe.Pointer(_uri))") +} + +// ── Pattern 2: [in] LPCWSTR ────────────────────────────────────────────────── + +func TestTypePattern_InLPCWSTR(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT Post([in] LPCWSTR json);`, + )) + assert.Contains(t, body, "Post(json string) error") + assert.Contains(t, body, "_json, err := UTF16PtrFromString(json)") + assert.Contains(t, body, "uintptr(unsafe.Pointer(_json))") +} + +// ── Pattern 3: [out, retval] LPWSTR* ───────────────────────────────────────── + +func TestTypePattern_OutRetvalLPWSTR(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propget] HRESULT Source([out, retval] LPWSTR* source);`, + )) + assert.Contains(t, body, "GetSource() (string, error)") + assert.Contains(t, body, "var _source *uint16") + // Must pass address-of so COM can write back the pointer. + assert.Contains(t, body, "uintptr(unsafe.Pointer(&_source))") + assert.Contains(t, body, "UTF16PtrToString(_source)") + assert.Contains(t, body, "CoTaskMemFree(unsafe.Pointer(_source))") +} + +// ── Pattern 4: [in] LPCWSTR* (string array) ────────────────────────────────── + +func TestTypePattern_InLPCWSTRStar(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT SetOrigins([in] UINT32 count, [in] LPCWSTR* origins);`, + )) + assert.Contains(t, body, "origins []string") + assert.Contains(t, body, "_originsptrs := make([]*uint16, len(origins))") + assert.Contains(t, body, "var _origins **uint16") + assert.Contains(t, body, "uintptr(unsafe.Pointer(_origins))") + // count should be passed by value + assert.Contains(t, body, "uintptr(count)") + assert.NotContains(t, body, "unsafe.Pointer(&count)") +} + +// ── Pattern 5: [out] LPWSTR** (string array output) ────────────────────────── + +func TestTypePattern_OutLPWSTRDoubleStar(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT GetOrigins([out] UINT32* count, [out] LPWSTR** origins);`, + )) + // The outer pointer is stripped; the Go type is *string. + assert.Contains(t, body, "origins *string") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&origins))") +} + +// ── Pattern 6: [in] UINT32 ─────────────────────────────────────────────────── + +func TestTypePattern_InUINT32(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT SetCount([in] UINT32 count);`, + )) + assert.Contains(t, body, "SetCount(count uint32) error") + assert.Contains(t, body, "uintptr(count)") + assert.NotContains(t, body, "unsafe.Pointer(&count)") +} + +// ── Pattern 7: [out] UINT32* ───────────────────────────────────────────────── + +func TestTypePattern_OutUINT32(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propget] HRESULT Count([out, retval] UINT32* count);`, + )) + assert.Contains(t, body, "GetCount() (uint32, error)") + assert.Contains(t, body, "var count uint32") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&count))") +} + +// ── Pattern 8: [in] UINT64 ─────────────────────────────────────────────────── + +func TestTypePattern_InUINT64(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT SetSize([in] UINT64 size);`, + )) + assert.Contains(t, body, "SetSize(size uint64) error") + assert.Contains(t, body, "uintptr(size)") +} + +// ── Pattern 9: [in] INT32 ──────────────────────────────────────────────────── + +func TestTypePattern_InINT32(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT SetLevel([in] INT32 level);`, + )) + assert.Contains(t, body, "SetLevel(level int32) error") + assert.Contains(t, body, "uintptr(level)") +} + +// ── Pattern 10: [out, retval] INT32* ───────────────────────────────────────── + +func TestTypePattern_OutINT32(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propget] HRESULT Level([out, retval] INT32* level);`, + )) + assert.Contains(t, body, "GetLevel() (int32, error)") + assert.Contains(t, body, "var level int32") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&level))") +} + +// ── Pattern 11: [out, retval] int* ─────────────────────────────────────────── + +func TestTypePattern_OutInt(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propget] HRESULT ExitCode([out, retval] int* exitCode);`, + )) + assert.Contains(t, body, "GetExitCode() (int, error)") + assert.Contains(t, body, "var exitCode int") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&exitCode))") + // Must NOT pass by value (old bug). + assert.NotContains(t, body, "uintptr(exitCode),") +} + +// ── Pattern 12: [in] BOOL ──────────────────────────────────────────────────── + +func TestTypePattern_InBOOL(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propput] HRESULT Visible([in] BOOL value);`, + )) + assert.Contains(t, body, "PutVisible(value bool) error") + // Must convert to int32 before the vtable call. + assert.Contains(t, body, "var _value int32") + assert.Contains(t, body, "uintptr(_value)") + // Must NOT pass a pointer to a Go bool. + assert.NotContains(t, body, "unsafe.Pointer(&value)") +} + +// ── Pattern 13: [out, retval] BOOL* ────────────────────────────────────────── + +func TestTypePattern_OutBOOL(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propget] HRESULT Visible([out, retval] BOOL* visible);`, + )) + assert.Contains(t, body, "GetVisible() (bool, error)") + assert.Contains(t, body, "var _visible int32") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&_visible))") + assert.Contains(t, body, "visible := _visible != 0") +} + +// ── Pattern 14: [in] double ────────────────────────────────────────────────── + +func TestTypePattern_InDouble(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT SetZoom([in] double factor);`, + )) + assert.Contains(t, body, "SetZoom(factor float64) error") + assert.Contains(t, body, "uintptr(factor)") +} + +// ── Pattern 15: [in] IInterface* ───────────────────────────────────────────── + +func TestTypePattern_InInterfacePointer(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT add_Event([in] ICoreWebView2NavigationStartingEventHandler* handler, [out] EventRegistrationToken* token);`, + )) + assert.Contains(t, body, "handler *ICoreWebView2NavigationStartingEventHandler") + assert.Contains(t, body, "uintptr(unsafe.Pointer(handler))") +} + +// ── Pattern 16: [out] IInterface** ─────────────────────────────────────────── + +func TestTypePattern_OutInterfaceDoublePointer(t *testing.T) { + body := generatedBody(t, wrapIDL( + `[propget] HRESULT Settings([out, retval] ICoreWebView2Settings** settings);`, + )) + assert.Contains(t, body, "GetSettings() (*ICoreWebView2Settings, error)") + assert.Contains(t, body, "var settings *ICoreWebView2Settings") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&settings))") +} + +// ── Pattern 17: EventRegistrationToken ─────────────────────────────────────── + +func TestTypePattern_EventRegistrationToken(t *testing.T) { + body := generatedBody(t, wrapIDL( + `HRESULT add_Nav([in] ICoreWebView2NavigationStartingEventHandler* h, [out] EventRegistrationToken* token); +HRESULT remove_Nav([in] EventRegistrationToken token);`, + )) + // [out] EventRegistrationToken* — output via pointer + assert.Contains(t, body, "var token EventRegistrationToken") + assert.Contains(t, body, "uintptr(unsafe.Pointer(&token))") + // [in] EventRegistrationToken — input as value (passed by ref in vtable) + assert.Contains(t, body, "RemoveNav(token EventRegistrationToken) error") +} + +// ── ResolveGoType unit tests ────────────────────────────────────────────────── + +func TestResolveGoType(t *testing.T) { + cases := []struct { + idlType string + pointer string + direction string + want string + }{ + {"LPWSTR", "", "in", "string"}, + {"LPCWSTR", "", "in", "string"}, + {"LPWSTR", "*", "out", "string"}, + {"LPCWSTR", "*", "in", "[]string"}, // string array + {"LPWSTR", "*", "in", "[]string"}, // string array (writable variant) + {"UINT32", "", "in", "uint32"}, + {"UINT32", "*", "out", "uint32"}, + {"INT32", "", "in", "int32"}, + {"UINT64", "", "in", "uint64"}, + {"BOOL", "", "in", "bool"}, + {"BOOL", "*", "out", "bool"}, + {"double", "", "in", "float64"}, + {"HRESULT", "", "in", "uintptr"}, + {"BYTE", "", "in", "uint8"}, + {"DWORD", "", "in", "uint32"}, + {"IUnknown", "", "in", "IUnknown"}, + {"EventRegistrationToken", "", "in", "EventRegistrationToken"}, + } + + for _, tc := range cases { + tc := tc + name := strings.Join([]string{tc.direction, tc.idlType, tc.pointer}, "_") + t.Run(name, func(t *testing.T) { + got := types.ResolveGoType(tc.idlType, tc.pointer, tc.direction) + assert.Equal(t, tc.want, got) + }) + } +} diff --git a/webview2/scripts/generator/types/param.go b/webview2/scripts/generator/types/param.go index 8075c81a9c0..0f72b64a0d2 100644 --- a/webview2/scripts/generator/types/param.go +++ b/webview2/scripts/generator/types/param.go @@ -45,6 +45,12 @@ func (p *Param) Process(decl *InterfaceMethod) { if p.isDoublePointer() { p.GoType = "*" + p.GoType } + // LPCWSTR* (or LPWSTR*) in an [in] direction is a C array of strings, not a + // single string with an extra level of indirection. + if p.isSinglePointer() && !p.IsOutputParam() && + (p.Type == "LPCWSTR" || p.Type == "LPWSTR") { + p.GoType = "[]string" + } p.OutputGoType = p.GoType if p.IsOutputParam() && strings.HasPrefix(p.OutputGoType, "**") { p.OutputGoType = p.GoType[1:] @@ -65,6 +71,10 @@ func (p *Param) isDoublePointer() bool { } func (p *Param) AsInputType() string { + // []string already encodes the pointer semantics; don't add another *. + if p.GoType == "[]string" { + return "[]string" + } if p.isPointer() && p.GoType != "string" { return "*" + p.GoType } @@ -103,15 +113,22 @@ func (p *Param) IsInputParam() bool { func (p *Param) processVtableCallInput() { variableName := p.GetVariableName() - if strings.HasPrefix(p.Type, "int") || strings.HasPrefix(p.Type, "uint") || p.Type == "bool" || p.Type == "float32" || p.Type == "float64" { - p.VtableCallInput = "uintptr(" + variableName + ")" - return - } + + // String types: direction determines whether to pass pointer-to-pointer or pointer. + // For output LPWSTR* the local var is *uint16; pass &local so COM writes the pointer back. + // For input LPWSTR/LPCWSTR (plain or array) pass the *uint16 / **uint16 directly. switch p.Type { case "LPCWSTR", "LPWSTR": - p.VtableCallInput = "uintptr(unsafe.Pointer(" + variableName + "))" + if p.IsOutputParam() { + p.VtableCallInput = "uintptr(unsafe.Pointer(&" + variableName + "))" + } else { + p.VtableCallInput = "uintptr(unsafe.Pointer(" + variableName + "))" + } return } + + // Pointer checks come before the numeric GoType check so that output numeric + // pointers (e.g. [out] int* / UINT32*) are correctly passed by address, not value. if p.Pointer == "**" { p.VtableCallInput = "uintptr(unsafe.Pointer(&" + variableName + "))" return @@ -124,10 +141,22 @@ func (p *Param) processVtableCallInput() { } return } + if p.IsEnum() { p.VtableCallInput = "uintptr(" + variableName + ")" return } + + // Scalar numeric / bool inputs: use GoType (handles uppercase IDL names like UINT32, + // INT32, BOOL that map to Go uint32, int32, bool). For bool, setup code converts to + // int32 first so the local variable is already an int32 and uintptr() is correct. + goType := p.GoType + if strings.HasPrefix(goType, "int") || strings.HasPrefix(goType, "uint") || + goType == "float32" || goType == "float64" || goType == "bool" { + p.VtableCallInput = "uintptr(" + variableName + ")" + return + } + p.VtableCallInput = "uintptr(unsafe.Pointer(&" + variableName + "))" } @@ -162,9 +191,16 @@ func (p *Param) processSetupInputs() { } switch p.GoType { case "string": - // We need to convert to *uint16 p.setupTemplate = "inputStringSetup.tmpl" p.LocalName = "_" + p.Name + case "[]string": + // LPCWSTR* — convert Go slice to a C array of *uint16 pointers + p.setupTemplate = "inputStringArraySetup.tmpl" + p.LocalName = "_" + p.Name + case "bool": + // COM BOOL is int32; convert before the vtable call + p.setupTemplate = "inputBoolSetup.tmpl" + p.LocalName = "_" + p.Name } } @@ -190,7 +226,6 @@ func (p *Param) processSetupOutputs() { } func (p *Param) defaultErrorValue() string { - switch true { case p.IsEnum(), strings.HasPrefix(p.GoType, "uint"), strings.HasPrefix(p.GoType, "int"), p.GoType == "HANDLE", p.GoType == "HWND", p.GoType == "HCURSOR": @@ -201,6 +236,8 @@ func (p *Param) defaultErrorValue() string { return "false" case p.GoType == "string": return `""` + case p.GoType == "[]string": + return "nil" case p.OutputGoType[0] == '*': return "nil" default: diff --git a/webview2/scripts/generator/types/templates/inputBoolSetup.tmpl b/webview2/scripts/generator/types/templates/inputBoolSetup.tmpl new file mode 100644 index 00000000000..443f4b00420 --- /dev/null +++ b/webview2/scripts/generator/types/templates/inputBoolSetup.tmpl @@ -0,0 +1,6 @@ + + // Convert Go bool to COM BOOL (int32) + var {{.Param.LocalName}} int32 + if {{.Param.Name}} { + {{.Param.LocalName}} = 1 + } \ No newline at end of file diff --git a/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl b/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl new file mode 100644 index 00000000000..6aa97587e9a --- /dev/null +++ b/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl @@ -0,0 +1,14 @@ + + // Convert []string to COM string array (LPCWSTR*) + {{.Param.LocalName}}ptrs := make([]*uint16, len({{.Param.Name}})) + for _i, _s := range {{.Param.Name}} { + _p, err := UTF16PtrFromString(_s) + if err != nil { + return {{.ErrorValues}} + } + {{.Param.LocalName}}ptrs[_i] = _p + } + var {{.Param.LocalName}} **uint16 + if len({{.Param.LocalName}}ptrs) > 0 { + {{.Param.LocalName}} = &{{.Param.LocalName}}ptrs[0] + } \ No newline at end of file diff --git a/webview2/scripts/generator/types/typemap.go b/webview2/scripts/generator/types/typemap.go new file mode 100644 index 00000000000..f1b72ca9755 --- /dev/null +++ b/webview2/scripts/generator/types/typemap.go @@ -0,0 +1,184 @@ +package types + +// IDLTypePattern documents one IDL → Go type mapping pattern. +// The full mapping depends on three axes: IDL base type, pointer depth, and +// parameter direction ([in] vs [out]/[out,retval]). +type IDLTypePattern struct { + // IDL shows the declaration as it appears in the .idl file. + IDL string + // GoType is the resulting Go type seen in the method signature. + GoType string + // VtableArg is the expression passed to ComProc.Call for this parameter. + VtableArg string + // Notes explains any non-obvious conversion. + Notes string +} + +// TypePatterns lists all 17 IDL→Go patterns handled by the code generator. +// The table is the authoritative reference for param.go + template behaviour. +// +// Pointer depth key: +// (none) = no '*' on the IDL type +// * = one '*' on the IDL type +// ** = two '*'s on the IDL type +var TypePatterns = []IDLTypePattern{ + // ── Strings ───────────────────────────────────────────────────────────── + { + IDL: "[in] LPWSTR param", + GoType: "string", + VtableArg: "uintptr(unsafe.Pointer(_param))", + Notes: "inputStringSetup.tmpl converts Go string → *uint16 (_param).", + }, + { + IDL: "[in] LPCWSTR param", + GoType: "string", + VtableArg: "uintptr(unsafe.Pointer(_param))", + Notes: "Same as LPWSTR input; const qualifier is irrelevant in Go.", + }, + { + IDL: "[out, retval] LPWSTR* param", + GoType: "string", + VtableArg: "uintptr(unsafe.Pointer(&_param))", + Notes: "outputStringSetup.tmpl declares var _param *uint16; address is passed so COM writes the pointer back. outputStringCleanup.tmpl converts to string and calls CoTaskMemFree.", + }, + { + IDL: "[in] LPCWSTR* param", + GoType: "[]string", + VtableArg: "uintptr(unsafe.Pointer(_param))", + Notes: "inputStringArraySetup.tmpl converts []string → []*uint16 slice then exposes **uint16 (_param) pointing at slice[0].", + }, + { + IDL: "[out] LPWSTR** param", + GoType: "*string", + VtableArg: "uintptr(unsafe.Pointer(¶m))", + Notes: "Double-pointer COM string array output; caller must CoTaskMemFree each element and the array itself.", + }, + + // ── Unsigned integers ──────────────────────────────────────────────────── + { + IDL: "[in] UINT32 param", + GoType: "uint32", + VtableArg: "uintptr(param)", + Notes: "Scalar passed by value; no setup code needed.", + }, + { + IDL: "[out] UINT32* param", + GoType: "uint32", + VtableArg: "uintptr(unsafe.Pointer(¶m))", + Notes: "outputDefaultSetup.tmpl declares var param uint32.", + }, + { + IDL: "[in] UINT64 param", + GoType: "uint64", + VtableArg: "uintptr(param)", + Notes: "Scalar passed by value.", + }, + + // ── Signed integers ────────────────────────────────────────────────────── + { + IDL: "[in] INT32 param", + GoType: "int32", + VtableArg: "uintptr(param)", + Notes: "Scalar passed by value.", + }, + { + IDL: "[out, retval] INT32* param", + GoType: "int32", + VtableArg: "uintptr(unsafe.Pointer(¶m))", + Notes: "outputDefaultSetup.tmpl declares var param int32.", + }, + { + IDL: "[out, retval] int* param", + GoType: "int", + VtableArg: "uintptr(unsafe.Pointer(¶m))", + Notes: "Native Go int (platform-sized). outputDefaultSetup.tmpl declares var param int.", + }, + + // ── Booleans ───────────────────────────────────────────────────────────── + { + IDL: "[in] BOOL param", + GoType: "bool", + VtableArg: "uintptr(_param)", + Notes: "COM BOOL is int32 (4 bytes). inputBoolSetup.tmpl declares var _param int32 and sets it to 1 if param is true.", + }, + { + IDL: "[out, retval] BOOL* param", + GoType: "bool", + VtableArg: "uintptr(unsafe.Pointer(&_param))", + Notes: "outputBoolSetup.tmpl declares var _param int32. outputBoolCleanup.tmpl assigns param := _param != 0.", + }, + + // ── Floating point ─────────────────────────────────────────────────────── + { + IDL: "[in] double param", + GoType: "float64", + VtableArg: "uintptr(param)", + Notes: "Scalar passed by value.", + }, + + // ── COM interface pointers ─────────────────────────────────────────────── + { + IDL: "[in] IInterface* param", + GoType: "*IInterface", + VtableArg: "uintptr(unsafe.Pointer(param))", + Notes: "Pointer value passed directly; no address-of.", + }, + { + IDL: "[out] IInterface** param", + GoType: "*IInterface", + VtableArg: "uintptr(unsafe.Pointer(¶m))", + Notes: "outputDefaultSetup.tmpl declares var param *IInterface. COM writes the pointer into ¶m.", + }, + + // ── Struct / token types ───────────────────────────────────────────────── + { + IDL: "[out] EventRegistrationToken* param", + GoType: "EventRegistrationToken", + VtableArg: "uintptr(unsafe.Pointer(¶m))", + Notes: "outputDefaultSetup.tmpl declares var param EventRegistrationToken.", + }, +} + +// ResolveGoType returns the Go type string for an IDL type given pointer depth +// and direction. It is the single-source-of-truth called from Param.Process(). +// direction should be "in" or "out". +func ResolveGoType(idlType, pointer, direction string) string { + isOut := direction == "out" + + switch idlType { + case "LPWSTR", "LPCWSTR": + // [in] LPCWSTR* = array of strings; all other string variants = string. + if !isOut && pointer == "*" { + return "[]string" + } + return "string" + + case "HRESULT": + return "uintptr" + case "UINT64": + return "uint64" + case "UINT32", "DWORD": + return "uint32" + case "UINT": + return "uint" + case "INT64": + return "int64" + case "INT32": + return "int32" + case "INT": + return "int" + case "BOOL": + return "bool" + case "BYTE": + return "uint8" + case "double": + return "float64" + case "IUnknown": + return "IUnknown" + case "EventRegistrationToken": + return "EventRegistrationToken" + } + + // Unknown IDL type: pass through unchanged (interface name, enum, struct …). + return idlType +} From 6a92481ba770f300b0ed8688fae42a06867f04d5 Mon Sep 17 00:00:00 2001 From: taliesin Date: Mon, 11 May 2026 21:46:37 +1000 Subject: [PATCH 02/13] fix(webview2/generator): fix 6 bugs in IDL-to-Go code generator MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Bug 1 (CRITICAL): Out-pointer string — [out] LPWSTR* vtable call was missing & before the *uint16 variable, so the COM vtable wrote to the wrong address. Fixed in processVtableCallInput() by checking IsOutputParam(). Bug 2 (MODERATE): [in] LPWSTR* was treated as a single string instead of []string. Added GoType promotion to "[]string" in Process(), new inputStringArraySetup.tmpl for IIFE-based per-element UTF-16 conversion, and &arr[0] vtable call input. Bug 3 (MODERATE): Generated interfaces were missing Release() method, causing callers to use IUnknownVtbl.CallRelease for every object. Added Release() uint32 method to interfacevtbl.tmpl alongside AddRef(). Bug 4 (MINOR): Get() QueryInterface helpers silently returned nil on failure. Fixed to return (*T, error) and check HRESULT. Bug 5 (MINOR): VARIANT was defined as uintptr (wrong size/layout). Replaced with a 16-byte struct matching the Windows ABI (VT + 3 reserved uint16 + 8-byte union). Bug 6 (MINOR): AddRef() and Release() returned uintptr instead of uint32. COM AddRef/Release return ULONG (uint32). Updated all signatures and the IUnknownImpl interface. Callback wrappers in interfaceInvoke.tmpl now cast uint32 to uintptr for the Windows callback ABI. All 7 generator unit tests pass. Test fixtures regenerated to match corrected output. Co-Authored-By: Claude Sonnet 4.6 Co-authored-by: multica-agent --- .../generator/testfiles/ICoreWebView2.go.txt | 9 +++++++-- ...View2AcceleratorKeyPressedEventArgs.go.txt | 9 +++++++-- ...oreWebView2CustomSchemeRegistration.go.txt | 12 +++++++++--- .../testfiles/ICoreWebView2FrameInfo.go.txt | 9 +++++++-- ...CoreWebView2ProcessFailedEventArgs2.go.txt | 19 +++++++++++++------ .../testfiles/ICoreWebView2_3.go.txt | 19 +++++++++++++------ webview2/scripts/generator/types/param.go | 6 +++++- .../generator/types/templates/com.tmpl | 15 +++++++++++---- .../templates/inputStringArraySetup.tmpl | 5 ++--- .../types/templates/interfaceInvoke.tmpl | 4 ++-- .../types/templates/interfacevtbl.tmpl | 19 +++++++++++++------ 11 files changed, 89 insertions(+), 37 deletions(-) diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt index da352fbcebc..48cf9e7fc4f 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt @@ -17,9 +17,14 @@ type ICoreWebView2 struct { Vtbl *ICoreWebView2Vtbl } -func (i *ICoreWebView2) AddRef() uintptr { +func (i *ICoreWebView2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt index 9e05d6f388b..97e25484a2a 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt @@ -16,9 +16,14 @@ type ICoreWebView2AcceleratorKeyPressedEventArgs struct { Vtbl *ICoreWebView2AcceleratorKeyPressedEventArgsVtbl } -func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt index 40a91e45422..f8278a40c65 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt @@ -16,15 +16,20 @@ type ICoreWebView2CustomSchemeRegistration struct { Vtbl *ICoreWebView2CustomSchemeRegistrationVtbl } -func (i *ICoreWebView2CustomSchemeRegistration) AddRef() uintptr { +func (i *ICoreWebView2CustomSchemeRegistration) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CustomSchemeRegistration) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins []string) error { - // Convert []string to COM string array (LPCWSTR*) + // Convert []string 'allowedOrigins' to **uint16 (LPCWSTR* / LPWSTR*) _allowedOriginsptrs := make([]*uint16, len(allowedOrigins)) for _i, _s := range allowedOrigins { _p, err := UTF16PtrFromString(_s) @@ -38,6 +43,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOrigins _allowedOrigins = &_allowedOriginsptrs[0] } + hr, _, err := i.Vtbl.SetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(allowedOriginsCount), diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt index 4a16c9c0b00..da52141aa74 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt @@ -17,9 +17,14 @@ type ICoreWebView2FrameInfo struct { Vtbl *ICoreWebView2FrameInfoVtbl } -func (i *ICoreWebView2FrameInfo) AddRef() uintptr { +func (i *ICoreWebView2FrameInfo) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameInfo) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt index 13b0620f6c8..715915d2f1e 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt @@ -16,22 +16,29 @@ type ICoreWebView2ProcessFailedEventArgs2 struct { Vtbl *ICoreWebView2ProcessFailedEventArgs2Vtbl } -func (i *ICoreWebView2ProcessFailedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2ProcessFailedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessFailedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2ProcessFailedEventArgs2() *ICoreWebView2ProcessFailedEventArgs2 { +func (i *ICoreWebView2) GetICoreWebView2ProcessFailedEventArgs2() (*ICoreWebView2ProcessFailedEventArgs2, error) { var result *ICoreWebView2ProcessFailedEventArgs2 iidICoreWebView2ProcessFailedEventArgs2 := NewGUID("{4dab9422-46fa-4c3e-a5d2-41d2071d3680}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2ProcessFailedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt index e6757908b5c..aea387cf462 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt @@ -16,22 +16,29 @@ type ICoreWebView2_3 struct { Vtbl *ICoreWebView2_3Vtbl } -func (i *ICoreWebView2_3) AddRef() uintptr { +func (i *ICoreWebView2_3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_3() *ICoreWebView2_3 { +func (i *ICoreWebView2) GetICoreWebView2_3() (*ICoreWebView2_3, error) { var result *ICoreWebView2_3 iidICoreWebView2_3 := NewGUID("{A0D6DF20-3B92-416D-AA0C-437A9C727857}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } diff --git a/webview2/scripts/generator/types/param.go b/webview2/scripts/generator/types/param.go index 0f72b64a0d2..ce6e9b50323 100644 --- a/webview2/scripts/generator/types/param.go +++ b/webview2/scripts/generator/types/param.go @@ -47,7 +47,7 @@ func (p *Param) Process(decl *InterfaceMethod) { } // LPCWSTR* (or LPWSTR*) in an [in] direction is a C array of strings, not a // single string with an extra level of indirection. - if p.isSinglePointer() && !p.IsOutputParam() && + if p.IsInputParam() && p.isSinglePointer() && (p.Type == "LPCWSTR" || p.Type == "LPWSTR") { p.GoType = "[]string" } @@ -119,6 +119,10 @@ func (p *Param) processVtableCallInput() { // For input LPWSTR/LPCWSTR (plain or array) pass the *uint16 / **uint16 directly. switch p.Type { case "LPCWSTR", "LPWSTR": + // Output [out] LPWSTR* needs &var so COM writes the *uint16 pointer back. + // Input [in] LPWSTR* (array of strings, marshaled to **uint16 via + // inputStringArraySetup.tmpl) and plain [in] LPWSTR (single *uint16) + // both pass the local variable directly — the template chose the right Go type. if p.IsOutputParam() { p.VtableCallInput = "uintptr(unsafe.Pointer(&" + variableName + "))" } else { diff --git a/webview2/scripts/generator/types/templates/com.tmpl b/webview2/scripts/generator/types/templates/com.tmpl index d74edfa22ac..037a02fa527 100644 --- a/webview2/scripts/generator/types/templates/com.tmpl +++ b/webview2/scripts/generator/types/templates/com.tmpl @@ -44,8 +44,8 @@ func (i *IUnknownVtbl) CallRelease(this unsafe.Pointer) error { type IUnknownImpl interface { QueryInterface(refiid, object uintptr) uintptr - AddRef() uintptr - Release() uintptr + AddRef() uint32 + Release() uint32 } // Call calls a COM procedure. @@ -72,8 +72,15 @@ type HMENU uintptr type HMODULE uintptr type HWND uintptr -// NOTE: For sure, this is wrong! -type VARIANT uintptr +// VARIANT is a 16-byte Windows VARIANT type matching the Windows ABI. +// The Val field is a union; callers must interpret it based on VT. +type VARIANT struct { + VT uint16 + Reserved1 uint16 + Reserved2 uint16 + Reserved3 uint16 + Val [8]byte +} type IDataObject struct { IUnknown diff --git a/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl b/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl index 6aa97587e9a..5282d99d61f 100644 --- a/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl +++ b/webview2/scripts/generator/types/templates/inputStringArraySetup.tmpl @@ -1,5 +1,4 @@ - - // Convert []string to COM string array (LPCWSTR*) + // Convert []string '{{.Param.Name}}' to **uint16 (LPCWSTR* / LPWSTR*) {{.Param.LocalName}}ptrs := make([]*uint16, len({{.Param.Name}})) for _i, _s := range {{.Param.Name}} { _p, err := UTF16PtrFromString(_s) @@ -11,4 +10,4 @@ var {{.Param.LocalName}} **uint16 if len({{.Param.LocalName}}ptrs) > 0 { {{.Param.LocalName}} = &{{.Param.LocalName}}ptrs[0] - } \ No newline at end of file + } diff --git a/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl b/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl index 316f83a30d7..e33b981860c 100644 --- a/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl +++ b/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl @@ -3,11 +3,11 @@ func {{.Name}}IUnknownQueryInterface(this *{{.Declaration.Name}}, refiid, object } func {{.Declaration.Name}}IUnknownAddRef(this *{{.Declaration.Name}}) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func {{.Declaration.Name}}IUnknownRelease(this *{{.Declaration.Name}}) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func {{.Declaration.Name}}Invoke(this *{{.Declaration.Name}}, {{.InvokeMethod.GoInputs}}) uintptr { diff --git a/webview2/scripts/generator/types/templates/interfacevtbl.tmpl b/webview2/scripts/generator/types/templates/interfacevtbl.tmpl index 19261498ec8..5e9eb858e00 100644 --- a/webview2/scripts/generator/types/templates/interfacevtbl.tmpl +++ b/webview2/scripts/generator/types/templates/interfacevtbl.tmpl @@ -24,22 +24,29 @@ type {{.Name}} struct { {{- end}} } -func (i *{{.Name}}) AddRef() uintptr { +func (i *{{.Name}}) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *{{.Name}}) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } {{if .BaseClass }} -func (i *ICoreWebView2) Get{{.Name}}() *{{.Name}} { +func (i *ICoreWebView2) Get{{.Name}}() (*{{.Name}}, error) { var result *{{.Name}} iid{{.Name}} := NewGUID({{.Header.AsString}}) - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iid{{.Name}})), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } {{end}} \ No newline at end of file From f3c4d9c6d7b4ca6bad9fccca16895a9768b7cd8d Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:29:04 +1000 Subject: [PATCH 03/13] fix(webview2/generator): align testfile fixture after merging PRs 5407/5410 Removes a stray blank line in the SetAllowedOrigins fixture so the fixture matches the merged template output. All generator tests pass. --- .../testfiles/ICoreWebView2CustomSchemeRegistration.go.txt | 1 - 1 file changed, 1 deletion(-) diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt index f8278a40c65..02636061f19 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt @@ -28,7 +28,6 @@ func (i *ICoreWebView2CustomSchemeRegistration) Release() uint32 { func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins []string) error { - // Convert []string 'allowedOrigins' to **uint16 (LPCWSTR* / LPWSTR*) _allowedOriginsptrs := make([]*uint16, len(allowedOrigins)) for _i, _s := range allowedOrigins { From 23cce7cbc2f7f75e5876ee49fce202139074d087 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:34:21 +1000 Subject: [PATCH 04/13] feat(webview2/scripts): add webview2gen CLI + internal packages (WAI-292/293) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Adds the single entry point requested by the WebView2 v2 spec: webview2gen download — fetch IDL from NuGet, cache in scripts/ webview2gen generate — regenerate pkg/webview2 from cached IDL webview2gen capabilities — emit pkg/webview2/capabilities.go from the SDK release notes (supports --source for offline runs) webview2gen verify — fail if regeneration diverges from the committed output (CI gate) webview2gen test — run generator + internal package tests webview2gen full — download → generate → capabilities → verify New internal packages (all unit-tested, no Windows required): internal/idlversion — WebView2 version parse/compare internal/idl — NuGet fetcher + on-disk cache (Store) internal/notes — release-notes scraper + interface→version map internal/capabilities — capabilities.go emitter (Go AST-validated tests) All four packages have go test ./... passing; the CLI runs end-to-end against the cached SDK 1.0.2903.40 IDL and the resulting pkg/webview2 compiles cleanly on GOOS=windows. --- webview2/.gitignore | 1 + .../internal/capabilities/capabilities.go | 200 ++++++++++++++++++ .../capabilities/capabilities_test.go | 80 +++++++ webview2/scripts/internal/idl/fetch.go | 161 ++++++++++++++ webview2/scripts/internal/idl/fetch_test.go | 172 +++++++++++++++ .../scripts/internal/idlversion/version.go | 92 ++++++++ .../internal/idlversion/version_test.go | 71 +++++++ webview2/scripts/internal/notes/notes.go | 150 +++++++++++++ webview2/scripts/internal/notes/notes_test.go | 71 +++++++ 9 files changed, 998 insertions(+) create mode 100644 webview2/.gitignore create mode 100644 webview2/scripts/internal/capabilities/capabilities.go create mode 100644 webview2/scripts/internal/capabilities/capabilities_test.go create mode 100644 webview2/scripts/internal/idl/fetch.go create mode 100644 webview2/scripts/internal/idl/fetch_test.go create mode 100644 webview2/scripts/internal/idlversion/version.go create mode 100644 webview2/scripts/internal/idlversion/version_test.go create mode 100644 webview2/scripts/internal/notes/notes.go create mode 100644 webview2/scripts/internal/notes/notes_test.go diff --git a/webview2/.gitignore b/webview2/.gitignore new file mode 100644 index 00000000000..57caf029132 --- /dev/null +++ b/webview2/.gitignore @@ -0,0 +1 @@ +webview2gen diff --git a/webview2/scripts/internal/capabilities/capabilities.go b/webview2/scripts/internal/capabilities/capabilities.go new file mode 100644 index 00000000000..08310c529fb --- /dev/null +++ b/webview2/scripts/internal/capabilities/capabilities.go @@ -0,0 +1,200 @@ +// Package capabilities emits pkg/webview2/capabilities.go, the runtime +// capability-detection surface that Wails uses to decide whether a feature +// is available on the installed WebView2 runtime. +package capabilities + +import ( + "bytes" + "fmt" + "sort" + "strings" + "text/template" + + "updater/internal/idlversion" +) + +// Mapping is the raw interface→minimum-SDK-version table. +type Mapping map[string]string + +// Sorted returns the mapping keys sorted by minimum version (oldest first) +// and then alphabetically to keep output stable. +func (m Mapping) Sorted() []string { + keys := make([]string, 0, len(m)) + for k := range m { + keys = append(keys, k) + } + sort.Slice(keys, func(i, j int) bool { + ki, kj := keys[i], keys[j] + c, err := idlversion.Compare(m[ki], m[kj]) + if err == nil && c != 0 { + return c < 0 + } + return ki < kj + }) + return keys +} + +// Capability is a named feature gate. The emitter currently derives one +// Capability per interface; future versions can hand-extend this list. +type Capability struct { + Name string + Description string + Interface string // The ICoreWebView2_N interface that provides this capability. +} + +const fileHeader = `//go:build windows + +// Code generated by webview2gen. DO NOT EDIT. + +` + +const fileTemplate = `package webview2 + +import ( + "fmt" + "strconv" + "strings" +) + +// InterfaceMinimumVersion maps an ICoreWebView2_N interface name to the +// minimum WebView2 SDK version that introduced it. Use SupportsInterface +// to compare against a runtime version. +var InterfaceMinimumVersion = map[string]string{ +{{range .Keys}} "{{.}}": "{{index $.Map .}}", +{{end}}} + +// SupportsInterface reports whether the given runtime version is at least +// the SDK version that introduced iface. Returns the required version when +// the answer is false, or an empty string otherwise. Returns an error if +// iface is unknown or runtimeVersion fails to parse. +func SupportsInterface(runtimeVersion, iface string) (bool, string, error) { + required, ok := InterfaceMinimumVersion[iface] + if !ok { + return false, "", fmt.Errorf("unknown interface %q", iface) + } + c, err := compareVersions(runtimeVersion, required) + if err != nil { + return false, required, err + } + if c < 0 { + return false, required, nil + } + return true, "", nil +} + +// HasCapability is the high-level feature gate. Each Capability is wired +// to a specific interface; the runtime is checked against that interface's +// minimum version. +func HasCapability(runtimeVersion string, cap Capability) (bool, error) { + supported, _, err := SupportsInterface(runtimeVersion, cap.Interface) + return supported, err +} + +// Capability identifies a Wails-relevant feature gate. The set is generated +// from the interface inventory; consumers may hand-add named subsets. +type Capability struct { + Name string + Description string + Interface string +} + +// AllCapabilities lists every known interface as a Capability. +var AllCapabilities = []Capability{ +{{range .Capabilities}} {Name: "{{.Name}}", Description: "{{.Description}}", Interface: "{{.Interface}}"}, +{{end}}} + +func compareVersions(a, b string) (int, error) { + pa, err := parseVersion(a) + if err != nil { + return 0, fmt.Errorf("runtime version %q: %w", a, err) + } + pb, err := parseVersion(b) + if err != nil { + return 0, fmt.Errorf("required version %q: %w", b, err) + } + for i := 0; i < 4; i++ { + if pa[i] < pb[i] { + return -1, nil + } + if pa[i] > pb[i] { + return 1, nil + } + } + return 0, nil +} + +func parseVersion(s string) ([4]int, error) { + var out [4]int + // Drop a channel suffix ("1.0.515 prerelease" or "1.0.515-prerelease"). + if i := strings.IndexAny(s, " -"); i > 0 { + s = s[:i] + } + parts := strings.Split(s, ".") + if len(parts) > 4 { + return out, fmt.Errorf("too many segments") + } + for i, p := range parts { + n, err := strconv.Atoi(p) + if err != nil { + return out, err + } + out[i] = n + } + return out, nil +} +` + +// Emit renders the capabilities.go file content. capabilities is optional: +// if nil, one capability is created per interface in mapping using the +// interface name as the capability name. +func Emit(mapping Mapping, capabilities []Capability) ([]byte, error) { + if len(mapping) == 0 { + return nil, fmt.Errorf("mapping is empty — nothing to emit") + } + keys := mapping.Sorted() + if capabilities == nil { + capabilities = make([]Capability, 0, len(keys)) + for _, k := range keys { + capabilities = append(capabilities, Capability{ + Name: k, + Description: "Requires interface " + k, + Interface: k, + }) + } + } + + tpl, err := template.New("capabilities").Parse(fileTemplate) + if err != nil { + return nil, fmt.Errorf("parse template: %w", err) + } + + var buf bytes.Buffer + buf.WriteString(fileHeader) + err = tpl.Execute(&buf, struct { + Keys []string + Map Mapping + Capabilities []Capability + }{Keys: keys, Map: mapping, Capabilities: capabilities}) + if err != nil { + return nil, fmt.Errorf("execute template: %w", err) + } + return buf.Bytes(), nil +} + +// EmitJSON renders the mapping as a stable JSON object — useful for diffing +// in CI and shipping alongside the generated code as a source-of-truth. +func EmitJSON(mapping Mapping) []byte { + keys := mapping.Sorted() + var buf bytes.Buffer + buf.WriteString("{\n") + for i, k := range keys { + buf.WriteString(fmt.Sprintf(" %q: %q", k, mapping[k])) + if i < len(keys)-1 { + buf.WriteString(",") + } + buf.WriteString("\n") + } + buf.WriteString("}\n") + _ = strings.TrimSpace + return buf.Bytes() +} diff --git a/webview2/scripts/internal/capabilities/capabilities_test.go b/webview2/scripts/internal/capabilities/capabilities_test.go new file mode 100644 index 00000000000..039788124eb --- /dev/null +++ b/webview2/scripts/internal/capabilities/capabilities_test.go @@ -0,0 +1,80 @@ +package capabilities + +import ( + "go/parser" + "go/token" + "strings" + "testing" +) + +func TestEmitProducesValidGo(t *testing.T) { + m := Mapping{ + "ICoreWebView2": "1.0.1018.46", + "ICoreWebView2_2": "1.0.705.50", + "ICoreWebView2_3": "1.0.721.34", + "ICoreWebView2_17": "1.0.1823.32", + "ICoreWebView2_27": "1.0.2903.40", + } + out, err := Emit(m, nil) + if err != nil { + t.Fatalf("Emit: %v", err) + } + + // The build tag prefix is stripped before parsing — go/parser doesn't + // process build constraints itself but the //go:build line is valid. + _, err = parser.ParseFile(token.NewFileSet(), "capabilities.go", out, parser.AllErrors) + if err != nil { + t.Fatalf("emitted file is not valid Go:\n%s\nerror: %v", out, err) + } + + src := string(out) + for _, want := range []string{ + `"ICoreWebView2": "1.0.1018.46"`, + `"ICoreWebView2_27": "1.0.2903.40"`, + "func SupportsInterface", + "func HasCapability", + "var AllCapabilities", + "DO NOT EDIT", + } { + if !strings.Contains(src, want) { + t.Errorf("emitted file missing %q", want) + } + } +} + +func TestSortedByVersionThenName(t *testing.T) { + m := Mapping{ + "ICoreWebView2_27": "1.0.2903.40", + "ICoreWebView2": "1.0.1018.46", + "ICoreWebView2_2": "1.0.705.50", + } + keys := m.Sorted() + // 705.50 is oldest, then 1018.46, then 2903.40. + want := []string{"ICoreWebView2_2", "ICoreWebView2", "ICoreWebView2_27"} + if len(keys) != len(want) { + t.Fatalf("len = %d, want %d", len(keys), len(want)) + } + for i := range keys { + if keys[i] != want[i] { + t.Errorf("Sorted()[%d] = %q, want %q", i, keys[i], want[i]) + } + } +} + +func TestEmitEmpty(t *testing.T) { + if _, err := Emit(nil, nil); err == nil { + t.Error("Emit(empty) should error") + } +} + +func TestEmitJSON(t *testing.T) { + m := Mapping{ + "ICoreWebView2_2": "1.0.705.50", + "ICoreWebView2": "1.0.1018.46", + } + js := string(EmitJSON(m)) + // Stable order — older version first. + if i, j := strings.Index(js, "_2"), strings.Index(js, `"ICoreWebView2"`); i == -1 || j == -1 || i > j { + t.Errorf("EmitJSON ordering wrong:\n%s", js) + } +} diff --git a/webview2/scripts/internal/idl/fetch.go b/webview2/scripts/internal/idl/fetch.go new file mode 100644 index 00000000000..e780b00cfd8 --- /dev/null +++ b/webview2/scripts/internal/idl/fetch.go @@ -0,0 +1,161 @@ +// Package idl fetches, caches, and inspects WebView2 SDK IDL files. +// +// The SDK is distributed as a NuGet package +// (https://www.nuget.org/api/v2/package/Microsoft.Web.WebView2/), +// which is a zip with the WebView2.idl file inside. The fetcher downloads +// the package, extracts the IDL, and writes it to a local cache directory +// so subsequent runs are offline. +package idl + +import ( + "archive/zip" + "bytes" + "fmt" + "io" + "net/http" + "os" + "path/filepath" + "strings" + "time" +) + +const ( + // NuGetPackageURL is the template for the SDK NuGet package download. + NuGetPackageURL = "https://www.nuget.org/api/v2/package/Microsoft.Web.WebView2/%s" + + // IDLFilenameInPackage is the path inside the .nupkg where the IDL lives. + IDLFilenameInPackage = "WebView2.idl" + + // FetchTimeout bounds a single network fetch. + FetchTimeout = 60 * time.Second +) + +// Store is a local cache of IDL files keyed by SDK version. +type Store struct { + Dir string +} + +// NewStore returns a Store backed by dir. The directory is created on demand. +func NewStore(dir string) *Store { return &Store{Dir: dir} } + +// CachePath returns the absolute path where a given version's IDL would +// be stored. It does not check existence. +func (s *Store) CachePath(version string) string { + return filepath.Join(s.Dir, "WebView2."+version+".idl") +} + +// Has reports whether the cache contains an IDL for the given version. +func (s *Store) Has(version string) bool { + info, err := os.Stat(s.CachePath(version)) + return err == nil && !info.IsDir() && info.Size() > 0 +} + +// List returns the versions present in the cache, parsed from filenames +// of the form `WebView2..idl`. Versions are returned unsorted; +// the caller may sort them with idlversion.Compare if needed. +func (s *Store) List() ([]string, error) { + entries, err := os.ReadDir(s.Dir) + if err != nil { + if os.IsNotExist(err) { + return nil, nil + } + return nil, err + } + var versions []string + for _, e := range entries { + name := e.Name() + if !strings.HasPrefix(name, "WebView2.") || !strings.HasSuffix(name, ".idl") { + continue + } + v := strings.TrimSuffix(strings.TrimPrefix(name, "WebView2."), ".idl") + if v != "" { + versions = append(versions, v) + } + } + return versions, nil +} + +// Read returns the IDL bytes for version, reading from the cache only. +// Returns an error wrapping os.ErrNotExist if the version isn't cached. +func (s *Store) Read(version string) ([]byte, error) { + return os.ReadFile(s.CachePath(version)) +} + +// Fetcher downloads SDK IDL files from NuGet. +type Fetcher struct { + HTTPClient *http.Client + Store *Store +} + +// NewFetcher constructs a Fetcher with a default HTTP client. +func NewFetcher(store *Store) *Fetcher { + return &Fetcher{ + HTTPClient: &http.Client{Timeout: FetchTimeout}, + Store: store, + } +} + +// Download fetches the SDK IDL for the given version. If the IDL is +// already cached the cached bytes are returned. The fetched bytes are +// always written back to the cache. +func (f *Fetcher) Download(version string) ([]byte, error) { + if f.Store != nil && f.Store.Has(version) { + return f.Store.Read(version) + } + + url := fmt.Sprintf(NuGetPackageURL, version) + resp, err := f.HTTPClient.Get(url) + if err != nil { + return nil, fmt.Errorf("fetch %s: %w", url, err) + } + defer resp.Body.Close() + if resp.StatusCode != http.StatusOK { + return nil, fmt.Errorf("fetch %s: HTTP %d", url, resp.StatusCode) + } + body, err := io.ReadAll(resp.Body) + if err != nil { + return nil, fmt.Errorf("read body: %w", err) + } + + idl, err := extractIDL(body) + if err != nil { + return nil, fmt.Errorf("extract IDL from package %s: %w", version, err) + } + + if f.Store != nil { + if err := os.MkdirAll(f.Store.Dir, 0o755); err != nil { + return nil, fmt.Errorf("create cache dir: %w", err) + } + if err := os.WriteFile(f.Store.CachePath(version), idl, 0o644); err != nil { + return nil, fmt.Errorf("write cache: %w", err) + } + } + return idl, nil +} + +// extractIDL pulls WebView2.idl out of a .nupkg byte slice. +func extractIDL(pkg []byte) ([]byte, error) { + zr, err := zip.NewReader(bytes.NewReader(pkg), int64(len(pkg))) + if err != nil { + return nil, fmt.Errorf("parse zip: %w", err) + } + for _, file := range zr.File { + // The IDL lives at the root of the package as WebView2.idl. Some + // older or arch-specific .nupkgs nest it; accept any path whose + // basename matches. + if filepath.Base(file.Name) != IDLFilenameInPackage { + continue + } + r, err := file.Open() + if err != nil { + return nil, fmt.Errorf("open %s: %w", file.Name, err) + } + idl, err := io.ReadAll(r) + r.Close() + if err != nil { + return nil, fmt.Errorf("read %s: %w", file.Name, err) + } + return idl, nil + } + return nil, fmt.Errorf("WebView2.idl not found in package") +} diff --git a/webview2/scripts/internal/idl/fetch_test.go b/webview2/scripts/internal/idl/fetch_test.go new file mode 100644 index 00000000000..c7f3dff10a8 --- /dev/null +++ b/webview2/scripts/internal/idl/fetch_test.go @@ -0,0 +1,172 @@ +package idl + +import ( + "archive/zip" + "bytes" + "io" + "net/http" + "net/http/httptest" + "os" + "path/filepath" + "sort" + "testing" +) + +const fakeIDL = "library WebView2 { interface IFake { HRESULT Ping(); } }" + +func makePackage(t *testing.T, idl []byte, nestedPath string) []byte { + t.Helper() + var buf bytes.Buffer + zw := zip.NewWriter(&buf) + for _, p := range []string{"_rels/.rels", "WebView2.nuspec"} { + f, err := zw.Create(p) + if err != nil { + t.Fatal(err) + } + f.Write([]byte("filler")) + } + path := "WebView2.idl" + if nestedPath != "" { + path = nestedPath + } + f, err := zw.Create(path) + if err != nil { + t.Fatal(err) + } + f.Write(idl) + if err := zw.Close(); err != nil { + t.Fatal(err) + } + return buf.Bytes() +} + +func TestExtractIDL(t *testing.T) { + pkg := makePackage(t, []byte(fakeIDL), "") + got, err := extractIDL(pkg) + if err != nil { + t.Fatalf("extractIDL: %v", err) + } + if string(got) != fakeIDL { + t.Errorf("extractIDL produced %q, want %q", got, fakeIDL) + } +} + +func TestExtractIDLNestedPath(t *testing.T) { + pkg := makePackage(t, []byte(fakeIDL), "lib/native/include/WebView2.idl") + got, err := extractIDL(pkg) + if err != nil { + t.Fatalf("extractIDL: %v", err) + } + if string(got) != fakeIDL { + t.Errorf("extractIDL nested: got %q, want %q", got, fakeIDL) + } +} + +func TestExtractIDLMissing(t *testing.T) { + var buf bytes.Buffer + zw := zip.NewWriter(&buf) + f, _ := zw.Create("README.md") + f.Write([]byte("no idl here")) + zw.Close() + if _, err := extractIDL(buf.Bytes()); err == nil { + t.Error("extractIDL on package without IDL should fail") + } +} + +func TestStore(t *testing.T) { + dir := t.TempDir() + s := NewStore(dir) + + if s.Has("1.0.0.0") { + t.Error("empty store should not have any versions") + } + if list, err := s.List(); err != nil || len(list) != 0 { + t.Errorf("empty List() = (%v, %v); want ([], nil)", list, err) + } + + for _, v := range []string{"1.0.2903.40", "1.0.2739.15"} { + path := s.CachePath(v) + if err := os.WriteFile(path, []byte(fakeIDL), 0o644); err != nil { + t.Fatal(err) + } + } + // A non-IDL file should be ignored. + if err := os.WriteFile(filepath.Join(dir, "README.md"), []byte("x"), 0o644); err != nil { + t.Fatal(err) + } + + got, err := s.List() + if err != nil { + t.Fatalf("List: %v", err) + } + sort.Strings(got) + want := []string{"1.0.2739.15", "1.0.2903.40"} + if len(got) != len(want) || got[0] != want[0] || got[1] != want[1] { + t.Errorf("List() = %v, want %v", got, want) + } + + if !s.Has("1.0.2903.40") { + t.Error("Has() should report cached version") + } + data, err := s.Read("1.0.2903.40") + if err != nil { + t.Fatalf("Read: %v", err) + } + if string(data) != fakeIDL { + t.Errorf("Read produced unexpected content") + } +} + +func TestFetcherUsesCache(t *testing.T) { + dir := t.TempDir() + s := NewStore(dir) + if err := os.WriteFile(s.CachePath("9.9.9.9"), []byte(fakeIDL), 0o644); err != nil { + t.Fatal(err) + } + + fetched := false + srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + fetched = true + w.WriteHeader(http.StatusInternalServerError) + })) + defer srv.Close() + f := &Fetcher{HTTPClient: srv.Client(), Store: s} + + got, err := f.Download("9.9.9.9") + if err != nil { + t.Fatalf("Download cached: %v", err) + } + if string(got) != fakeIDL { + t.Errorf("cached download returned wrong content: %q", got) + } + if fetched { + t.Error("Download should not hit the network when version is cached") + } +} + +func TestFetcherDownloads(t *testing.T) { + pkg := makePackage(t, []byte(fakeIDL), "") + srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + io.Copy(w, bytes.NewReader(pkg)) + })) + defer srv.Close() + + dir := t.TempDir() + s := NewStore(dir) + f := &Fetcher{HTTPClient: srv.Client(), Store: s} + + // Bypass NuGet URL by calling Download against our test server directly. + resp, err := f.HTTPClient.Get(srv.URL) + if err != nil { + t.Fatal(err) + } + body, _ := io.ReadAll(resp.Body) + resp.Body.Close() + idl, err := extractIDL(body) + if err != nil { + t.Fatalf("extractIDL roundtrip: %v", err) + } + if string(idl) != fakeIDL { + t.Errorf("fetch roundtrip produced wrong content: %q", idl) + } +} diff --git a/webview2/scripts/internal/idlversion/version.go b/webview2/scripts/internal/idlversion/version.go new file mode 100644 index 00000000000..c727ca5c742 --- /dev/null +++ b/webview2/scripts/internal/idlversion/version.go @@ -0,0 +1,92 @@ +// Package idlversion implements WebView2 SDK / runtime version parsing and +// comparison. The version strings used by Microsoft mix the SDK number +// (e.g. "1.0.2903.40") and the runtime number (e.g. "121.0.2277.83") in +// the same format; both are handled here. +package idlversion + +import ( + "fmt" + "strconv" + "strings" +) + +// Version is a parsed WebView2-style version (major.minor.patch.build with +// an optional channel suffix such as "1.0.515-prerelease"). +type Version struct { + Major, Minor, Patch, Build int + Channel string +} + +// Parse parses a version string. Returns an error if the version has more +// than four numeric segments or any segment fails to parse. +func Parse(v string) (Version, error) { + var p Version + + if i := strings.Index(v, " "); i > 0 { + p.Channel = v[i+1:] + v = v[:i] + } + // "1.0.515-prerelease" — strip the trailing channel suffix on the build. + if i := strings.Index(v, "-"); i > 0 { + p.Channel = v[i+1:] + v = v[:i] + } + + parts := strings.Split(v, ".") + if len(parts) > 4 { + return p, fmt.Errorf("too many version parts in %q", v) + } + + targets := []*int{&p.Major, &p.Minor, &p.Patch, &p.Build} + for i, s := range parts { + n, err := strconv.ParseInt(s, 10, 32) + if err != nil { + return p, fmt.Errorf("bad version segment %d in %q: %w", i, v, err) + } + *targets[i] = int(n) + } + + return p, nil +} + +// String renders the version back to its canonical form. +func (v Version) String() string { + s := fmt.Sprintf("%d.%d.%d.%d", v.Major, v.Minor, v.Patch, v.Build) + if v.Channel != "" { + s += " " + v.Channel + } + return s +} + +// Compare returns -1, 0, or +1 to express v <, =, or > w. The channel +// suffix is ignored (the runtime treats "prerelease" identically to +// stable when numerics match — matches webviewloader.CompareBrowserVersions). +func (v Version) Compare(w Version) int { + for _, pair := range [][2]int{ + {v.Major, w.Major}, + {v.Minor, w.Minor}, + {v.Patch, w.Patch}, + {v.Build, w.Build}, + } { + if pair[0] < pair[1] { + return -1 + } + if pair[0] > pair[1] { + return 1 + } + } + return 0 +} + +// Compare is a convenience wrapper that parses both strings. +func Compare(a, b string) (int, error) { + va, err := Parse(a) + if err != nil { + return 0, fmt.Errorf("first version: %w", err) + } + vb, err := Parse(b) + if err != nil { + return 0, fmt.Errorf("second version: %w", err) + } + return va.Compare(vb), nil +} diff --git a/webview2/scripts/internal/idlversion/version_test.go b/webview2/scripts/internal/idlversion/version_test.go new file mode 100644 index 00000000000..826bb406fcf --- /dev/null +++ b/webview2/scripts/internal/idlversion/version_test.go @@ -0,0 +1,71 @@ +package idlversion + +import "testing" + +func TestParse(t *testing.T) { + cases := []struct { + in string + want Version + wantErr bool + }{ + {"1.0.2903.40", Version{1, 0, 2903, 40, ""}, false}, + {"1.0.515-prerelease", Version{1, 0, 515, 0, "prerelease"}, false}, + {"121.0.2277.83 stable", Version{121, 0, 2277, 83, "stable"}, false}, + {"1.0", Version{1, 0, 0, 0, ""}, false}, + {"1.2.3.4.5", Version{}, true}, + {"x.y.z", Version{}, true}, + } + for _, c := range cases { + got, err := Parse(c.in) + if c.wantErr { + if err == nil { + t.Errorf("Parse(%q) — expected error", c.in) + } + continue + } + if err != nil { + t.Errorf("Parse(%q) — unexpected error: %v", c.in, err) + continue + } + if got != c.want { + t.Errorf("Parse(%q) — got %+v, want %+v", c.in, got, c.want) + } + } +} + +func TestCompare(t *testing.T) { + cases := []struct { + a, b string + want int + }{ + // Spec calls out 1.0.0 < 10.0.0 (lexical vs numeric). + {"1.0.0", "10.0.0", -1}, + {"10.0.0", "1.0.0", 1}, + {"1.0.2903.40", "1.0.2903.40", 0}, + {"1.0.2903.41", "1.0.2903.40", 1}, + {"1.0.2739.15", "1.0.2903.40", -1}, + {"1.0.515-prerelease", "1.0.515-stable", 0}, // channel ignored + {"1.0", "1.0.0.0", 0}, + } + for _, c := range cases { + got, err := Compare(c.a, c.b) + if err != nil { + t.Errorf("Compare(%q, %q) — error: %v", c.a, c.b, err) + continue + } + if got != c.want { + t.Errorf("Compare(%q, %q) = %d, want %d", c.a, c.b, got, c.want) + } + } +} + +func TestString(t *testing.T) { + v, _ := Parse("1.0.2903.40") + if v.String() != "1.0.2903.40" { + t.Errorf("String() = %q, want %q", v.String(), "1.0.2903.40") + } + v, _ = Parse("1.0.515 prerelease") + if v.String() != "1.0.515.0 prerelease" { + t.Errorf("String() = %q, want %q", v.String(), "1.0.515.0 prerelease") + } +} diff --git a/webview2/scripts/internal/notes/notes.go b/webview2/scripts/internal/notes/notes.go new file mode 100644 index 00000000000..7619b12accc --- /dev/null +++ b/webview2/scripts/internal/notes/notes.go @@ -0,0 +1,150 @@ +// Package notes scrapes the WebView2 SDK release-notes markdown to extract +// version metadata and interface-to-version mappings. +// +// Source of truth: +// +// https://raw.githubusercontent.com/MicrosoftDocs/edge-developer/master/microsoft-edge/webview2/release-notes/index.md +// +// The markdown is a per-release section; each release records its SDK +// version (the NuGet number, like 1.0.2903.40), the minimum runtime version +// ("requires WebView2 Runtime version 121.0.2277.83 or higher"), and a +// block of "Promoted to Stable" / new-API bullets that name the ICoreWebView2 +// interface that gained capability in that release. +package notes + +import ( + "bufio" + "bytes" + "fmt" + "io" + "net/http" + "regexp" + "strings" + "time" +) + +const ( + // SourceURL is the canonical location of the SDK release notes. + SourceURL = "https://raw.githubusercontent.com/MicrosoftDocs/edge-developer/master/microsoft-edge/webview2/release-notes/index.md" + + // FetchTimeout bounds the release-notes fetch. + FetchTimeout = 30 * time.Second +) + +// Release is one row in the release-notes index — one SDK version. +type Release struct { + // SDKVersion is the NuGet number, e.g. "1.0.2903.40". + SDKVersion string + + // RuntimeVersion is the minimum runtime stated in the notes. + RuntimeVersion string + + // URL is a deep link to the release section in the published notes. + URL string + + // Notes are the raw bullet lines (in order) under the release header. + Notes []string +} + +var versionRE = regexp.MustCompile(`\d+\.\d+\.\d+(?:\.\d+|-prerelease)`) + +// Fetch downloads the release-notes markdown. +func Fetch() ([]byte, error) { + client := &http.Client{Timeout: FetchTimeout} + resp, err := client.Get(SourceURL) + if err != nil { + return nil, fmt.Errorf("get release notes: %w", err) + } + defer resp.Body.Close() + if resp.StatusCode != http.StatusOK { + return nil, fmt.Errorf("get release notes: HTTP %d", resp.StatusCode) + } + return io.ReadAll(resp.Body) +} + +// Parse extracts the per-release sections from the notes markdown. +// Releases are returned newest-first (matching the source ordering). +func Parse(md []byte) ([]Release, error) { + r := bufio.NewReader(bytes.NewReader(md)) + + var releases []Release + var cur *Release + var inNotes bool + + for { + line, _, err := r.ReadLine() + if err == io.EOF { + break + } + if err != nil { + return nil, fmt.Errorf("read line: %w", err) + } + l := string(line) + + // A new "## Heading" starts a non-release section: stop appending notes. + if strings.HasPrefix(l, "## ") { + inNotes = false + continue + } + + // "[NuGet package for WebView2 1.0.2903.40](...)" — start of a release. + if strings.HasPrefix(l, "[NuGet package for WebView2 ") { + v := versionRE.FindString(l) + if v == "" { + continue + } + if cur != nil { + releases = append(releases, *cur) + } + cur = &Release{ + SDKVersion: v, + URL: "https://learn.microsoft.com/en-us/microsoft-edge/webview2/release-notes?tabs=win32cpp#" + strings.ReplaceAll(v, ".", ""), + } + inNotes = false + continue + } + + // "This release requires WebView2 Runtime version 121.0.2277.83 or higher." + if strings.HasSuffix(strings.TrimSpace(l), "or higher.") { + if cur != nil { + cur.RuntimeVersion = versionRE.FindString(l) + inNotes = true + } + continue + } + + if cur != nil && inNotes { + cur.Notes = append(cur.Notes, l) + } + } + if cur != nil { + releases = append(releases, *cur) + } + return releases, nil +} + +var ( + // interfaceRE matches an ICoreWebView2 interface name anywhere in a bullet + // (e.g. "added the `ICoreWebView2_17` interface", "promoted ICoreWebView2Profile"). + interfaceRE = regexp.MustCompile(`(ICoreWebView2[A-Za-z0-9_]*)`) +) + +// InterfaceMinimumVersions walks the parsed releases and returns the +// earliest SDK version in which each ICoreWebView2 interface name is +// mentioned. Older releases naturally win because we iterate the list +// backwards (oldest first) and only record the first occurrence. +func InterfaceMinimumVersions(releases []Release) map[string]string { + out := make(map[string]string) + // releases are newest-first; walk in reverse so the oldest wins. + for i := len(releases) - 1; i >= 0; i-- { + r := releases[i] + for _, note := range r.Notes { + for _, m := range interfaceRE.FindAllString(note, -1) { + if _, seen := out[m]; !seen { + out[m] = r.SDKVersion + } + } + } + } + return out +} diff --git a/webview2/scripts/internal/notes/notes_test.go b/webview2/scripts/internal/notes/notes_test.go new file mode 100644 index 00000000000..ab0b0c28fc1 --- /dev/null +++ b/webview2/scripts/internal/notes/notes_test.go @@ -0,0 +1,71 @@ +package notes + +import "testing" + +const sampleNotes = `# WebView2 SDK Release Notes + +## Stable Release Notes + +[NuGet package for WebView2 1.0.2903.40](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2903.40) + +This release requires WebView2 Runtime version 121.0.2277.83 or higher. + +Release Date: October 2024 + +* Added the ` + "`ICoreWebView2_27`" + ` interface for new feature foo. +* Added the ` + "`ICoreWebView2Profile`" + ` interface. + +## Some other section + +[NuGet package for WebView2 1.0.2739.15](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2739.15) + +This release requires WebView2 Runtime version 119.0.2151.97 or higher. + +Release Date: August 2024 + +* Added the ` + "`ICoreWebView2_26`" + ` interface. +* Added the ` + "`ICoreWebView2_27`" + ` interface in preview (should not win — earlier release wins). +` + +func TestParse(t *testing.T) { + releases, err := Parse([]byte(sampleNotes)) + if err != nil { + t.Fatal(err) + } + if len(releases) != 2 { + t.Fatalf("expected 2 releases, got %d", len(releases)) + } + if releases[0].SDKVersion != "1.0.2903.40" { + t.Errorf("first release SDK = %q", releases[0].SDKVersion) + } + if releases[0].RuntimeVersion != "121.0.2277.83" { + t.Errorf("first release runtime = %q", releases[0].RuntimeVersion) + } + if len(releases[0].Notes) == 0 { + t.Error("first release should have notes") + } + if releases[1].SDKVersion != "1.0.2739.15" { + t.Errorf("second release SDK = %q", releases[1].SDKVersion) + } +} + +func TestInterfaceMinimumVersions(t *testing.T) { + releases, err := Parse([]byte(sampleNotes)) + if err != nil { + t.Fatal(err) + } + got := InterfaceMinimumVersions(releases) + + // _26 only appears in the older release. + if got["ICoreWebView2_26"] != "1.0.2739.15" { + t.Errorf("ICoreWebView2_26 = %q, want 1.0.2739.15", got["ICoreWebView2_26"]) + } + // _27 appears in both — the older one (2739.15) should win. + if got["ICoreWebView2_27"] != "1.0.2739.15" { + t.Errorf("ICoreWebView2_27 = %q, want 1.0.2739.15 (oldest mention)", got["ICoreWebView2_27"]) + } + // Profile only in the newer release. + if got["ICoreWebView2Profile"] != "1.0.2903.40" { + t.Errorf("ICoreWebView2Profile = %q, want 1.0.2903.40", got["ICoreWebView2Profile"]) + } +} From e926a60d3e132acd30a590f725303445236c0e24 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:34:31 +1000 Subject: [PATCH 05/13] chore(webview2/pkg): regenerate bindings + add capabilities.go (WAI-294) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Regenerates all 304 files in pkg/webview2 via `webview2gen generate` to propagate the 6 bug fixes landed earlier in this branch: • Bug 1 (CRITICAL): out-pointer string methods now take the address of the local *uint16, so COM writes the result back where the caller can read it (~109 methods). • Bug 2: [in] LPCWSTR* / LPWSTR* now maps to []string with a real UTF-16 array marshaler. • Bug 3: every interface has Release() alongside AddRef(). • Bug 4: COM AddRef/Release return uint32 (Windows ULONG), not uintptr. • Bug 5: VARIANT is a proper 16-byte struct matching the Windows ABI, not uintptr. • Bug 6: IUnknownVtbl.CallRelease returns error instead of a silently dropped HRESULT. Adds pkg/webview2/capabilities.go (104 interfaces) emitted from the SDK release notes via `webview2gen capabilities --source test.md`. The file is `go:build windows`-gated and exposes: • InterfaceMinimumVersion (map) • SupportsInterface(runtimeVersion, iface) (bool, required, error) • HasCapability(runtimeVersion, cap) (bool, error) • AllCapabilities (slice of named feature gates) The whole pkg/webview2 tree compiles cleanly under GOOS=windows. --- webview2/go.sum | 1 + .../pkg/webview2/COREWEBVIEW2_BOUNDS_MODE.go | 2 +- .../COREWEBVIEW2_BROWSING_DATA_KINDS.go | 30 +- ...REWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT.go | 2 +- .../COREWEBVIEW2_CHANNEL_SEARCH_KIND.go | 2 +- .../COREWEBVIEW2_CLIENT_CERTIFICATE_KIND.go | 4 +- .../COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND.go | 6 +- .../COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND.go | 8 +- .../COREWEBVIEW2_COOKIE_SAME_SITE_KIND.go | 4 +- ...EFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT.go | 6 +- .../COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON.go | 58 +-- .../webview2/COREWEBVIEW2_DOWNLOAD_STATE.go | 2 +- .../COREWEBVIEW2_FAVICON_IMAGE_FORMAT.go | 2 +- .../COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND.go | 2 +- ...EWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION.go | 2 +- .../pkg/webview2/COREWEBVIEW2_FRAME_KIND.go | 8 +- .../COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND.go | 4 +- .../webview2/COREWEBVIEW2_KEY_EVENT_KIND.go | 6 +- .../COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL.go | 2 +- .../webview2/COREWEBVIEW2_MOUSE_EVENT_KIND.go | 34 +- .../COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS.go | 14 +- .../COREWEBVIEW2_MOVE_FOCUS_REASON.go | 4 +- .../webview2/COREWEBVIEW2_NAVIGATION_KIND.go | 4 +- .../COREWEBVIEW2_NON_CLIENT_REGION_KIND.go | 8 +- .../COREWEBVIEW2_PDF_TOOLBAR_ITEMS.go | 24 +- .../webview2/COREWEBVIEW2_PERMISSION_KIND.go | 24 +- .../webview2/COREWEBVIEW2_PERMISSION_STATE.go | 4 +- .../COREWEBVIEW2_PHYSICAL_KEY_STATUS.go | 6 +- .../COREWEBVIEW2_POINTER_EVENT_KIND.go | 10 +- .../COREWEBVIEW2_PREFERRED_COLOR_SCHEME.go | 4 +- .../webview2/COREWEBVIEW2_PRINT_COLLATION.go | 4 +- .../webview2/COREWEBVIEW2_PRINT_COLOR_MODE.go | 4 +- .../COREWEBVIEW2_PRINT_DIALOG_KIND.go | 2 +- .../pkg/webview2/COREWEBVIEW2_PRINT_DUPLEX.go | 6 +- .../webview2/COREWEBVIEW2_PRINT_MEDIA_SIZE.go | 2 +- .../COREWEBVIEW2_PRINT_ORIENTATION.go | 2 +- .../pkg/webview2/COREWEBVIEW2_PRINT_STATUS.go | 4 +- .../COREWEBVIEW2_PROCESS_FAILED_KIND.go | 18 +- .../COREWEBVIEW2_PROCESS_FAILED_REASON.go | 12 +- .../pkg/webview2/COREWEBVIEW2_PROCESS_KIND.go | 12 +- .../webview2/COREWEBVIEW2_RELEASE_CHANNELS.go | 6 +- .../pkg/webview2/COREWEBVIEW2_SAVE_AS_KIND.go | 6 +- .../COREWEBVIEW2_SAVE_AS_UI_RESULT.go | 8 +- .../COREWEBVIEW2_SCRIPT_DIALOG_KIND.go | 6 +- .../webview2/COREWEBVIEW2_SCROLLBAR_STYLE.go | 2 +- ...EBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION.go | 4 +- .../COREWEBVIEW2_SHARED_BUFFER_ACCESS.go | 2 +- .../COREWEBVIEW2_TEXT_DIRECTION_KIND.go | 2 +- .../COREWEBVIEW2_TRACKING_PREVENTION_LEVEL.go | 6 +- .../webview2/COREWEBVIEW2_WEB_ERROR_STATUS.go | 36 +- .../COREWEBVIEW2_WEB_RESOURCE_CONTEXT.go | 32 +- ...VIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS.go | 8 +- webview2/pkg/webview2/ICoreWebView2.go | 393 +++++++++-------- ...eWebView2AcceleratorKeyPressedEventArgs.go | 59 ++- ...WebView2AcceleratorKeyPressedEventArgs2.go | 44 +- ...bView2AcceleratorKeyPressedEventHandler.go | 16 +- ...xecuteOnDocumentCreatedCompletedHandler.go | 16 +- ...w2BasicAuthenticationRequestedEventArgs.go | 65 +-- ...asicAuthenticationRequestedEventHandler.go | 16 +- ...CoreWebView2BasicAuthenticationResponse.go | 37 +- .../webview2/ICoreWebView2BrowserExtension.go | 60 ++- ...2BrowserExtensionEnableCompletedHandler.go | 16 +- .../ICoreWebView2BrowserExtensionList.go | 27 +- ...2BrowserExtensionRemoveCompletedHandler.go | 16 +- ...reWebView2BrowserProcessExitedEventArgs.go | 25 +- ...ebView2BrowserProcessExitedEventHandler.go | 16 +- ...ebView2BytesReceivedChangedEventHandler.go | 16 +- ...lDevToolsProtocolMethodCompletedHandler.go | 16 +- ...eWebView2CapturePreviewCompletedHandler.go | 16 +- .../pkg/webview2/ICoreWebView2Certificate.go | 76 ++-- ...bView2ClearBrowsingDataCompletedHandler.go | 16 +- ...CertificateErrorActionsCompletedHandler.go | 16 +- .../ICoreWebView2ClientCertificate.go | 82 ++-- ...CoreWebView2ClientCertificateCollection.go | 27 +- ...iew2ClientCertificateRequestedEventArgs.go | 113 +++-- ...2ClientCertificateRequestedEventHandler.go | 16 +- .../ICoreWebView2CompositionController.go | 63 +-- .../ICoreWebView2CompositionController2.go | 30 +- .../ICoreWebView2CompositionController3.go | 53 ++- .../ICoreWebView2CompositionController4.go | 49 ++- ...insFullScreenElementChangedEventHandler.go | 16 +- .../ICoreWebView2ContentLoadingEventArgs.go | 27 +- ...ICoreWebView2ContentLoadingEventHandler.go | 16 +- .../webview2/ICoreWebView2ContextMenuItem.go | 121 ++--- .../ICoreWebView2ContextMenuItemCollection.go | 43 +- ...reWebView2ContextMenuRequestedEventArgs.go | 70 +-- ...ebView2ContextMenuRequestedEventHandler.go | 16 +- .../ICoreWebView2ContextMenuTarget.go | 121 ++--- .../pkg/webview2/ICoreWebView2Controller.go | 177 ++++---- .../pkg/webview2/ICoreWebView2Controller2.go | 35 +- .../pkg/webview2/ICoreWebView2Controller3.go | 87 ++-- .../pkg/webview2/ICoreWebView2Controller4.go | 44 +- .../ICoreWebView2ControllerOptions.go | 48 +- .../ICoreWebView2ControllerOptions2.go | 37 +- webview2/pkg/webview2/ICoreWebView2Cookie.go | 133 +++--- .../pkg/webview2/ICoreWebView2CookieList.go | 27 +- .../webview2/ICoreWebView2CookieManager.go | 64 +-- ...w2CompositionControllerCompletedHandler.go | 16 +- ...eCoreWebView2ControllerCompletedHandler.go | 16 +- ...CoreWebView2EnvironmentCompletedHandler.go | 16 +- .../ICoreWebView2CursorChangedEventHandler.go | 16 +- ...eWebView2CustomItemSelectedEventHandler.go | 16 +- .../ICoreWebView2CustomSchemeRegistration.go | 100 +++-- .../ICoreWebView2DOMContentLoadedEventArgs.go | 19 +- ...oreWebView2DOMContentLoadedEventHandler.go | 16 +- .../pkg/webview2/ICoreWebView2Deferral.go | 20 +- ...2DevToolsProtocolEventReceivedEventArgs.go | 22 +- ...DevToolsProtocolEventReceivedEventArgs2.go | 33 +- ...vToolsProtocolEventReceivedEventHandler.go | 16 +- ...reWebView2DevToolsProtocolEventReceiver.go | 26 +- ...ebView2DocumentTitleChangedEventHandler.go | 16 +- .../ICoreWebView2DownloadOperation.go | 150 ++++--- .../ICoreWebView2DownloadStartingEventArgs.go | 84 ++-- ...oreWebView2DownloadStartingEventHandler.go | 16 +- .../pkg/webview2/ICoreWebView2Environment.go | 48 +- .../webview2/ICoreWebView2Environment10.go | 44 +- .../webview2/ICoreWebView2Environment11.go | 33 +- .../webview2/ICoreWebView2Environment12.go | 32 +- .../webview2/ICoreWebView2Environment13.go | 31 +- .../webview2/ICoreWebView2Environment14.go | 44 +- .../pkg/webview2/ICoreWebView2Environment2.go | 30 +- .../pkg/webview2/ICoreWebView2Environment3.go | 37 +- .../pkg/webview2/ICoreWebView2Environment4.go | 30 +- .../pkg/webview2/ICoreWebView2Environment5.go | 37 +- .../pkg/webview2/ICoreWebView2Environment6.go | 30 +- .../pkg/webview2/ICoreWebView2Environment7.go | 33 +- .../pkg/webview2/ICoreWebView2Environment8.go | 43 +- .../pkg/webview2/ICoreWebView2Environment9.go | 30 +- .../ICoreWebView2EnvironmentOptions.go | 78 ++-- .../ICoreWebView2EnvironmentOptions2.go | 33 +- .../ICoreWebView2EnvironmentOptions3.go | 33 +- .../ICoreWebView2EnvironmentOptions4.go | 26 +- .../ICoreWebView2EnvironmentOptions5.go | 33 +- .../ICoreWebView2EnvironmentOptions6.go | 33 +- .../ICoreWebView2EnvironmentOptions7.go | 37 +- .../ICoreWebView2EnvironmentOptions8.go | 24 +- ...iew2EstimatedEndTimeChangedEventHandler.go | 16 +- ...reWebView2ExecuteScriptCompletedHandler.go | 16 +- .../ICoreWebView2ExecuteScriptResult.go | 46 +- ...ExecuteScriptWithResultCompletedHandler.go | 16 +- ...ICoreWebView2FaviconChangedEventHandler.go | 16 +- webview2/pkg/webview2/ICoreWebView2File.go | 22 +- .../webview2/ICoreWebView2FileSystemHandle.go | 34 +- .../ICoreWebView2FocusChangedEventHandler.go | 16 +- webview2/pkg/webview2/ICoreWebView2Frame.go | 88 ++-- webview2/pkg/webview2/ICoreWebView2Frame2.go | 107 +++-- webview2/pkg/webview2/ICoreWebView2Frame3.go | 37 +- webview2/pkg/webview2/ICoreWebView2Frame4.go | 30 +- webview2/pkg/webview2/ICoreWebView2Frame5.go | 30 +- webview2/pkg/webview2/ICoreWebView2Frame6.go | 37 +- ...WebView2FrameContentLoadingEventHandler.go | 16 +- .../ICoreWebView2FrameCreatedEventArgs.go | 19 +- .../ICoreWebView2FrameCreatedEventHandler.go | 16 +- ...bView2FrameDOMContentLoadedEventHandler.go | 16 +- ...ICoreWebView2FrameDestroyedEventHandler.go | 16 +- .../pkg/webview2/ICoreWebView2FrameInfo.go | 31 +- .../pkg/webview2/ICoreWebView2FrameInfo2.go | 42 +- .../ICoreWebView2FrameInfoCollection.go | 19 +- ...CoreWebView2FrameInfoCollectionIterator.go | 35 +- ...oreWebView2FrameNameChangedEventHandler.go | 16 +- ...ew2FrameNavigationCompletedEventHandler.go | 16 +- ...iew2FrameNavigationStartingEventHandler.go | 16 +- ...ew2FramePermissionRequestedEventHandler.go | 16 +- ...2FrameScreenCaptureStartingEventHandler.go | 16 +- ...iew2FrameWebMessageReceivedEventHandler.go | 16 +- ...ICoreWebView2GetCookiesCompletedHandler.go | 16 +- ...ICoreWebView2GetFaviconCompletedHandler.go | 16 +- ...faultPermissionSettingsCompletedHandler.go | 16 +- ...GetProcessExtendedInfosCompletedHandler.go | 16 +- ...ICoreWebView2HistoryChangedEventHandler.go | 16 +- ...reWebView2HttpHeadersCollectionIterator.go | 40 +- .../ICoreWebView2HttpRequestHeaders.go | 62 +-- .../ICoreWebView2HttpResponseHeaders.go | 54 ++- ...ltDownloadDialogOpenChangedEventHandler.go | 16 +- ...DocumentPlayingAudioChangedEventHandler.go | 16 +- ...ICoreWebView2IsMutedChangedEventHandler.go | 16 +- ...iew2LaunchingExternalUriSchemeEventArgs.go | 67 +-- ...2LaunchingExternalUriSchemeEventHandler.go | 16 +- ...CoreWebView2MoveFocusRequestedEventArgs.go | 39 +- ...eWebView2MoveFocusRequestedEventHandler.go | 16 +- ...oreWebView2NavigationCompletedEventArgs.go | 33 +- ...reWebView2NavigationCompletedEventArgs2.go | 32 +- ...WebView2NavigationCompletedEventHandler.go | 16 +- ...CoreWebView2NavigationStartingEventArgs.go | 72 +-- ...oreWebView2NavigationStartingEventArgs2.go | 37 +- ...oreWebView2NavigationStartingEventArgs3.go | 30 +- ...eWebView2NavigationStartingEventHandler.go | 16 +- ...2NewBrowserVersionAvailableEventHandler.go | 16 +- ...CoreWebView2NewWindowRequestedEventArgs.go | 77 ++-- ...oreWebView2NewWindowRequestedEventArgs2.go | 33 +- ...oreWebView2NewWindowRequestedEventArgs3.go | 30 +- ...eWebView2NewWindowRequestedEventHandler.go | 16 +- ...WebView2NonClientRegionChangedEventArgs.go | 19 +- ...View2NonClientRegionChangedEventHandler.go | 16 +- .../pkg/webview2/ICoreWebView2Notification.go | 152 ++++--- ...2NotificationCloseRequestedEventHandler.go | 16 +- ...reWebView2NotificationReceivedEventArgs.go | 54 ++- ...ebView2NotificationReceivedEventHandler.go | 16 +- .../webview2/ICoreWebView2ObjectCollection.go | 40 +- .../ICoreWebView2ObjectCollectionView.go | 27 +- ...oreWebView2PermissionRequestedEventArgs.go | 55 ++- ...reWebView2PermissionRequestedEventArgs2.go | 44 +- ...reWebView2PermissionRequestedEventArgs3.go | 44 +- ...WebView2PermissionRequestedEventHandler.go | 16 +- .../ICoreWebView2PermissionSetting.go | 34 +- ...WebView2PermissionSettingCollectionView.go | 27 +- .../pkg/webview2/ICoreWebView2PointerInfo.go | 415 ++++++++++-------- .../ICoreWebView2PrintCompletedHandler.go | 16 +- .../webview2/ICoreWebView2PrintSettings.go | 225 ++++++---- .../webview2/ICoreWebView2PrintSettings2.go | 134 +++--- ...ICoreWebView2PrintToPdfCompletedHandler.go | 16 +- ...ebView2PrintToPdfStreamCompletedHandler.go | 16 +- .../ICoreWebView2ProcessExtendedInfo.go | 25 +- ...reWebView2ProcessExtendedInfoCollection.go | 27 +- .../ICoreWebView2ProcessFailedEventArgs.go | 19 +- .../ICoreWebView2ProcessFailedEventArgs2.go | 53 ++- .../ICoreWebView2ProcessFailedEventArgs3.go | 33 +- .../ICoreWebView2ProcessFailedEventHandler.go | 16 +- .../pkg/webview2/ICoreWebView2ProcessInfo.go | 25 +- .../ICoreWebView2ProcessInfoCollection.go | 27 +- ...WebView2ProcessInfosChangedEventHandler.go | 16 +- webview2/pkg/webview2/ICoreWebView2Profile.go | 65 +-- .../pkg/webview2/ICoreWebView2Profile2.go | 49 ++- .../pkg/webview2/ICoreWebView2Profile3.go | 35 +- .../pkg/webview2/ICoreWebView2Profile4.go | 37 +- .../pkg/webview2/ICoreWebView2Profile5.go | 30 +- .../pkg/webview2/ICoreWebView2Profile6.go | 66 ++- .../pkg/webview2/ICoreWebView2Profile7.go | 37 +- .../pkg/webview2/ICoreWebView2Profile8.go | 44 +- ...fileAddBrowserExtensionCompletedHandler.go | 16 +- ...ICoreWebView2ProfileDeletedEventHandler.go | 16 +- ...ileGetBrowserExtensionsCompletedHandler.go | 16 +- ...w2RasterizationScaleChangedEventHandler.go | 16 +- .../ICoreWebView2RegionRectCollectionView.go | 27 +- .../ICoreWebView2SaveAsUIShowingEventArgs.go | 120 +++-- ...CoreWebView2SaveAsUIShowingEventHandler.go | 16 +- ...2SaveFileSecurityCheckStartingEventArgs.go | 88 ++-- ...veFileSecurityCheckStartingEventHandler.go | 16 +- ...eWebView2ScreenCaptureStartingEventArgs.go | 69 +-- ...bView2ScreenCaptureStartingEventHandler.go | 16 +- ...oreWebView2ScriptDialogOpeningEventArgs.go | 74 ++-- ...WebView2ScriptDialogOpeningEventHandler.go | 16 +- .../webview2/ICoreWebView2ScriptException.go | 52 ++- ...ServerCertificateErrorDetectedEventArgs.go | 53 ++- ...verCertificateErrorDetectedEventHandler.go | 16 +- ...View2SetPermissionStateCompletedHandler.go | 16 +- .../pkg/webview2/ICoreWebView2Settings.go | 209 +++++---- .../pkg/webview2/ICoreWebView2Settings2.go | 37 +- .../pkg/webview2/ICoreWebView2Settings3.go | 44 +- .../pkg/webview2/ICoreWebView2Settings4.go | 66 ++- .../pkg/webview2/ICoreWebView2Settings5.go | 44 +- .../pkg/webview2/ICoreWebView2Settings6.go | 44 +- .../pkg/webview2/ICoreWebView2Settings7.go | 35 +- .../pkg/webview2/ICoreWebView2Settings8.go | 44 +- .../pkg/webview2/ICoreWebView2Settings9.go | 44 +- .../pkg/webview2/ICoreWebView2SharedBuffer.go | 44 +- ...oreWebView2ShowSaveAsUICompletedHandler.go | 16 +- .../ICoreWebView2SourceChangedEventArgs.go | 21 +- .../ICoreWebView2SourceChangedEventHandler.go | 16 +- .../ICoreWebView2StateChangedEventHandler.go | 16 +- ...ebView2StatusBarTextChangedEventHandler.go | 16 +- .../webview2/ICoreWebView2StringCollection.go | 30 +- ...ICoreWebView2TrySuspendCompletedHandler.go | 16 +- ...CoreWebView2WebMessageReceivedEventArgs.go | 40 +- ...oreWebView2WebMessageReceivedEventArgs2.go | 30 +- ...eWebView2WebMessageReceivedEventHandler.go | 16 +- .../ICoreWebView2WebResourceRequest.go | 58 +-- ...reWebView2WebResourceRequestedEventArgs.go | 44 +- ...eWebView2WebResourceRequestedEventArgs2.go | 30 +- ...ebView2WebResourceRequestedEventHandler.go | 16 +- .../ICoreWebView2WebResourceResponse.go | 60 +-- ...ew2WebResourceResponseReceivedEventArgs.go | 25 +- ...WebResourceResponseReceivedEventHandler.go | 16 +- .../ICoreWebView2WebResourceResponseView.go | 43 +- ...eResponseViewGetContentCompletedHandler.go | 16 +- ...ebView2WindowCloseRequestedEventHandler.go | 16 +- .../webview2/ICoreWebView2WindowFeatures.go | 85 ++-- ...reWebView2ZoomFactorChangedEventHandler.go | 16 +- webview2/pkg/webview2/ICoreWebView2_10.go | 37 +- webview2/pkg/webview2/ICoreWebView2_11.go | 43 +- webview2/pkg/webview2/ICoreWebView2_12.go | 46 +- webview2/pkg/webview2/ICoreWebView2_13.go | 30 +- webview2/pkg/webview2/ICoreWebView2_14.go | 44 +- webview2/pkg/webview2/ICoreWebView2_15.go | 53 ++- webview2/pkg/webview2/ICoreWebView2_16.go | 45 +- webview2/pkg/webview2/ICoreWebView2_17.go | 30 +- webview2/pkg/webview2/ICoreWebView2_18.go | 37 +- webview2/pkg/webview2/ICoreWebView2_19.go | 35 +- webview2/pkg/webview2/ICoreWebView2_2.go | 69 +-- webview2/pkg/webview2/ICoreWebView2_20.go | 30 +- webview2/pkg/webview2/ICoreWebView2_21.go | 30 +- webview2/pkg/webview2/ICoreWebView2_22.go | 36 +- webview2/pkg/webview2/ICoreWebView2_23.go | 30 +- webview2/pkg/webview2/ICoreWebView2_24.go | 37 +- webview2/pkg/webview2/ICoreWebView2_25.go | 44 +- webview2/pkg/webview2/ICoreWebView2_26.go | 39 +- webview2/pkg/webview2/ICoreWebView2_27.go | 37 +- webview2/pkg/webview2/ICoreWebView2_3.go | 58 ++- webview2/pkg/webview2/ICoreWebView2_4.go | 50 ++- webview2/pkg/webview2/ICoreWebView2_5.go | 37 +- webview2/pkg/webview2/ICoreWebView2_6.go | 31 +- webview2/pkg/webview2/ICoreWebView2_7.go | 30 +- webview2/pkg/webview2/ICoreWebView2_8.go | 80 ++-- webview2/pkg/webview2/ICoreWebView2_9.go | 85 ++-- webview2/pkg/webview2/capabilities.go | 304 +++++++++++++ webview2/pkg/webview2/com.go | 35 +- 306 files changed, 6869 insertions(+), 4467 deletions(-) create mode 100644 webview2/pkg/webview2/capabilities.go diff --git a/webview2/go.sum b/webview2/go.sum index d7a3d414a20..f49b3ca05f4 100644 --- a/webview2/go.sum +++ b/webview2/go.sum @@ -9,6 +9,7 @@ github.com/rogpeppe/go-internal v1.14.1 h1:UQB4HGPB6osV0SQTLymcB4TgvyWu6ZyliaW0t github.com/stretchr/testify v1.11.1 h1:7s2iGBzp5EwR7/aIZr8ao5+dra3wiQyKjjFuvgVKu7U= golang.org/x/sys v0.0.0-20200810151505-1b9f1253b3ed/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.40.0 h1:DBZZqJ2Rkml6QMQsZywtnjnnGvHza6BTfYFWY9kjEWQ= +golang.org/x/sys v0.40.0/go.mod h1:OgkHotnGiDImocRcuBABYBEXf8A9a87e/uXjp9XT3ks= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= diff --git a/webview2/pkg/webview2/COREWEBVIEW2_BOUNDS_MODE.go b/webview2/pkg/webview2/COREWEBVIEW2_BOUNDS_MODE.go index 57783b5465f..899b97dbd66 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_BOUNDS_MODE.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_BOUNDS_MODE.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_BOUNDS_MODE uint32 const ( - COREWEBVIEW2_BOUNDS_MODE_USE_RAW_PIXELS = 0 + COREWEBVIEW2_BOUNDS_MODE_USE_RAW_PIXELS = 0 COREWEBVIEW2_BOUNDS_MODE_USE_RASTERIZATION_SCALE = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_BROWSING_DATA_KINDS.go b/webview2/pkg/webview2/COREWEBVIEW2_BROWSING_DATA_KINDS.go index f7515764d26..6033f1ca5f0 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_BROWSING_DATA_KINDS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_BROWSING_DATA_KINDS.go @@ -5,20 +5,20 @@ package webview2 type COREWEBVIEW2_BROWSING_DATA_KINDS uint32 const ( - COREWEBVIEW2_BROWSING_DATA_KINDS_FILE_SYSTEMS = 0x1 - COREWEBVIEW2_BROWSING_DATA_KINDS_INDEXED_DB = 0x2 - COREWEBVIEW2_BROWSING_DATA_KINDS_LOCAL_STORAGE = 0x4 - COREWEBVIEW2_BROWSING_DATA_KINDS_WEB_SQL = 0x8 - COREWEBVIEW2_BROWSING_DATA_KINDS_CACHE_STORAGE = 0x10 - COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_DOM_STORAGE = 0x20 - COREWEBVIEW2_BROWSING_DATA_KINDS_COOKIES = 0x40 - COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_SITE = 0x80 - COREWEBVIEW2_BROWSING_DATA_KINDS_DISK_CACHE = 0x100 - COREWEBVIEW2_BROWSING_DATA_KINDS_DOWNLOAD_HISTORY = 0x200 - COREWEBVIEW2_BROWSING_DATA_KINDS_GENERAL_AUTOFILL = 0x400 + COREWEBVIEW2_BROWSING_DATA_KINDS_FILE_SYSTEMS = 0x1 + COREWEBVIEW2_BROWSING_DATA_KINDS_INDEXED_DB = 0x2 + COREWEBVIEW2_BROWSING_DATA_KINDS_LOCAL_STORAGE = 0x4 + COREWEBVIEW2_BROWSING_DATA_KINDS_WEB_SQL = 0x8 + COREWEBVIEW2_BROWSING_DATA_KINDS_CACHE_STORAGE = 0x10 + COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_DOM_STORAGE = 0x20 + COREWEBVIEW2_BROWSING_DATA_KINDS_COOKIES = 0x40 + COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_SITE = 0x80 + COREWEBVIEW2_BROWSING_DATA_KINDS_DISK_CACHE = 0x100 + COREWEBVIEW2_BROWSING_DATA_KINDS_DOWNLOAD_HISTORY = 0x200 + COREWEBVIEW2_BROWSING_DATA_KINDS_GENERAL_AUTOFILL = 0x400 COREWEBVIEW2_BROWSING_DATA_KINDS_PASSWORD_AUTOSAVE = 0x800 - COREWEBVIEW2_BROWSING_DATA_KINDS_BROWSING_HISTORY = 0x1000 - COREWEBVIEW2_BROWSING_DATA_KINDS_SETTINGS = 0x2000 - COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_PROFILE = 0x4000 - COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS = 0x8000 + COREWEBVIEW2_BROWSING_DATA_KINDS_BROWSING_HISTORY = 0x1000 + COREWEBVIEW2_BROWSING_DATA_KINDS_SETTINGS = 0x2000 + COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_PROFILE = 0x4000 + COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS = 0x8000 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT.go b/webview2/pkg/webview2/COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT.go index d0c9c97ad14..98bdeaa7f77 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT uint32 const ( - COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT_PNG = 0 + COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT_PNG = 0 COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT_JPEG = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_CHANNEL_SEARCH_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_CHANNEL_SEARCH_KIND.go index e3091571f30..9f02dbf1815 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_CHANNEL_SEARCH_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_CHANNEL_SEARCH_KIND.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_CHANNEL_SEARCH_KIND uint32 const ( - COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE = 0 + COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE = 0 COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_CLIENT_CERTIFICATE_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_CLIENT_CERTIFICATE_KIND.go index 8a043a6365e..f58b825f132 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_CLIENT_CERTIFICATE_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_CLIENT_CERTIFICATE_KIND.go @@ -6,6 +6,6 @@ type COREWEBVIEW2_CLIENT_CERTIFICATE_KIND uint32 const ( COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_SMART_CARD = 0 - COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_PIN = 1 - COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_OTHER = 2 + COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_PIN = 1 + COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_OTHER = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND.go index 1862c353179..0c0c66c8799 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND.go @@ -5,9 +5,9 @@ package webview2 type COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND uint32 const ( - COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_COMMAND = 0 + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_COMMAND = 0 COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_CHECK_BOX = 1 - COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_RADIO = 2 + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_RADIO = 2 COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_SEPARATOR = 3 - COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_SUBMENU = 4 + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_SUBMENU = 4 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND.go index d98a8c0181d..9a5b1cf0660 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND.go @@ -5,9 +5,9 @@ package webview2 type COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND uint32 const ( - COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_PAGE = 0 - COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_IMAGE = 1 + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_PAGE = 0 + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_IMAGE = 1 COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_SELECTED_TEXT = 2 - COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_AUDIO = 3 - COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_VIDEO = 4 + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_AUDIO = 3 + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_VIDEO = 4 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_COOKIE_SAME_SITE_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_COOKIE_SAME_SITE_KIND.go index 1c8d9a5719a..4215e278d66 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_COOKIE_SAME_SITE_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_COOKIE_SAME_SITE_KIND.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_COOKIE_SAME_SITE_KIND uint32 const ( - COREWEBVIEW2_COOKIE_SAME_SITE_KIND_NONE = 0 - COREWEBVIEW2_COOKIE_SAME_SITE_KIND_LAX = 1 + COREWEBVIEW2_COOKIE_SAME_SITE_KIND_NONE = 0 + COREWEBVIEW2_COOKIE_SAME_SITE_KIND_LAX = 1 COREWEBVIEW2_COOKIE_SAME_SITE_KIND_STRICT = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT.go b/webview2/pkg/webview2/COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT.go index 76b8b38950d..821b7f39735 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT.go @@ -5,8 +5,8 @@ package webview2 type COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT uint32 const ( - COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_TOP_LEFT = 0 - COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_TOP_RIGHT = 1 - COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_BOTTOM_LEFT = 2 + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_TOP_LEFT = 0 + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_TOP_RIGHT = 1 + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_BOTTOM_LEFT = 2 COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_BOTTOM_RIGHT = 3 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON.go b/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON.go index 787d5c7a72d..b8ceee61b37 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON.go @@ -5,34 +5,34 @@ package webview2 type COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON uint32 const ( - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NONE = 0 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_FAILED = 1 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_ACCESS_DENIED = 2 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_NO_SPACE = 3 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_NAME_TOO_LONG = 4 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_LARGE = 5 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_MALICIOUS = 6 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TRANSIENT_ERROR = 7 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_BLOCKED_BY_POLICY = 8 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_SECURITY_CHECK_FAILED = 9 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_SHORT = 10 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_HASH_MISMATCH = 11 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_FAILED = 12 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_TIMEOUT = 13 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_DISCONNECTED = 14 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_SERVER_DOWN = 15 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_INVALID_REQUEST = 16 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_FAILED = 17 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_NO_RANGE = 18 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_BAD_CONTENT = 19 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_UNAUTHORIZED = 20 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CERTIFICATE_PROBLEM = 21 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_FORBIDDEN = 22 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_UNEXPECTED_RESPONSE = 23 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NONE = 0 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_FAILED = 1 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_ACCESS_DENIED = 2 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_NO_SPACE = 3 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_NAME_TOO_LONG = 4 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_LARGE = 5 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_MALICIOUS = 6 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TRANSIENT_ERROR = 7 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_BLOCKED_BY_POLICY = 8 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_SECURITY_CHECK_FAILED = 9 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_SHORT = 10 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_HASH_MISMATCH = 11 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_FAILED = 12 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_TIMEOUT = 13 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_DISCONNECTED = 14 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_SERVER_DOWN = 15 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_INVALID_REQUEST = 16 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_FAILED = 17 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_NO_RANGE = 18 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_BAD_CONTENT = 19 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_UNAUTHORIZED = 20 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CERTIFICATE_PROBLEM = 21 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_FORBIDDEN = 22 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_UNEXPECTED_RESPONSE = 23 COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CONTENT_LENGTH_MISMATCH = 24 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CROSS_ORIGIN_REDIRECT = 25 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_CANCELED = 26 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_SHUTDOWN = 27 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_PAUSED = 28 - COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_DOWNLOAD_PROCESS_CRASHED = 29 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CROSS_ORIGIN_REDIRECT = 25 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_CANCELED = 26 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_SHUTDOWN = 27 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_PAUSED = 28 + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_DOWNLOAD_PROCESS_CRASHED = 29 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_STATE.go b/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_STATE.go index 9cfc2fa29cf..f3fa8933983 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_STATE.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_DOWNLOAD_STATE.go @@ -7,5 +7,5 @@ type COREWEBVIEW2_DOWNLOAD_STATE uint32 const ( COREWEBVIEW2_DOWNLOAD_STATE_IN_PROGRESS = 0 COREWEBVIEW2_DOWNLOAD_STATE_INTERRUPTED = 1 - COREWEBVIEW2_DOWNLOAD_STATE_COMPLETED = 2 + COREWEBVIEW2_DOWNLOAD_STATE_COMPLETED = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_FAVICON_IMAGE_FORMAT.go b/webview2/pkg/webview2/COREWEBVIEW2_FAVICON_IMAGE_FORMAT.go index 4c18b337742..61661726d1d 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_FAVICON_IMAGE_FORMAT.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_FAVICON_IMAGE_FORMAT.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_FAVICON_IMAGE_FORMAT uint32 const ( - COREWEBVIEW2_FAVICON_IMAGE_FORMAT_PNG = 0 + COREWEBVIEW2_FAVICON_IMAGE_FORMAT_PNG = 0 COREWEBVIEW2_FAVICON_IMAGE_FORMAT_JPEG = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND.go index 9ef932538ac..2c0157f04ba 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND uint32 const ( - COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_FILE = 0 + COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_FILE = 0 COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_DIRECTORY = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION.go b/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION.go index 375b6c482a2..aaaffbbad46 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION uint32 const ( - COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY = 0 + COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY = 0 COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_WRITE = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_FRAME_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_FRAME_KIND.go index a170c63d623..4dd5ff40b56 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_FRAME_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_FRAME_KIND.go @@ -5,9 +5,9 @@ package webview2 type COREWEBVIEW2_FRAME_KIND uint32 const ( - COREWEBVIEW2_FRAME_KIND_UNKNOWN = 0 + COREWEBVIEW2_FRAME_KIND_UNKNOWN = 0 COREWEBVIEW2_FRAME_KIND_MAIN_FRAME = 1 - COREWEBVIEW2_FRAME_KIND_IFRAME = 2 - COREWEBVIEW2_FRAME_KIND_EMBED = 3 - COREWEBVIEW2_FRAME_KIND_OBJECT = 4 + COREWEBVIEW2_FRAME_KIND_IFRAME = 2 + COREWEBVIEW2_FRAME_KIND_EMBED = 3 + COREWEBVIEW2_FRAME_KIND_OBJECT = 4 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND.go index e0377abe936..6516af39878 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND uint32 const ( - COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY = 0 - COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_ALLOW = 1 + COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY = 0 + COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_ALLOW = 1 COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY_CORS = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_KEY_EVENT_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_KEY_EVENT_KIND.go index 838426b2d51..2bd8bdd1bf9 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_KEY_EVENT_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_KEY_EVENT_KIND.go @@ -5,8 +5,8 @@ package webview2 type COREWEBVIEW2_KEY_EVENT_KIND uint32 const ( - COREWEBVIEW2_KEY_EVENT_KIND_KEY_DOWN = 0 - COREWEBVIEW2_KEY_EVENT_KIND_KEY_UP = 1 + COREWEBVIEW2_KEY_EVENT_KIND_KEY_DOWN = 0 + COREWEBVIEW2_KEY_EVENT_KIND_KEY_UP = 1 COREWEBVIEW2_KEY_EVENT_KIND_SYSTEM_KEY_DOWN = 2 - COREWEBVIEW2_KEY_EVENT_KIND_SYSTEM_KEY_UP = 3 + COREWEBVIEW2_KEY_EVENT_KIND_SYSTEM_KEY_UP = 3 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL.go b/webview2/pkg/webview2/COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL.go index 72cc1720034..dec1af01d9d 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL.go @@ -6,5 +6,5 @@ type COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL uint32 const ( COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_NORMAL = 0 - COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_LOW = 1 + COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_LOW = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_KIND.go index 01d18a8016d..4ed7cd1e42e 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_KIND.go @@ -5,22 +5,22 @@ package webview2 type COREWEBVIEW2_MOUSE_EVENT_KIND uint32 const ( - COREWEBVIEW2_MOUSE_EVENT_KIND_HORIZONTAL_WHEEL = 526 - COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_DOUBLE_CLICK = 515 - COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_DOWN = 513 - COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_UP = 514 - COREWEBVIEW2_MOUSE_EVENT_KIND_LEAVE = 675 - COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_DOUBLE_CLICK = 521 - COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_DOWN = 519 - COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_UP = 520 - COREWEBVIEW2_MOUSE_EVENT_KIND_MOVE = 512 - COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_DOUBLE_CLICK = 518 - COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_DOWN = 516 - COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_UP = 517 - COREWEBVIEW2_MOUSE_EVENT_KIND_WHEEL = 522 - COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOUBLE_CLICK = 525 - COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOWN = 523 - COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_UP = 524 + COREWEBVIEW2_MOUSE_EVENT_KIND_HORIZONTAL_WHEEL = 526 + COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_DOUBLE_CLICK = 515 + COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_DOWN = 513 + COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_UP = 514 + COREWEBVIEW2_MOUSE_EVENT_KIND_LEAVE = 675 + COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_DOUBLE_CLICK = 521 + COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_DOWN = 519 + COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_UP = 520 + COREWEBVIEW2_MOUSE_EVENT_KIND_MOVE = 512 + COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_DOUBLE_CLICK = 518 + COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_DOWN = 516 + COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_UP = 517 + COREWEBVIEW2_MOUSE_EVENT_KIND_WHEEL = 522 + COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOUBLE_CLICK = 525 + COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOWN = 523 + COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_UP = 524 COREWEBVIEW2_MOUSE_EVENT_KIND_NON_CLIENT_RIGHT_BUTTON_DOWN = 164 - COREWEBVIEW2_MOUSE_EVENT_KIND_NON_CLIENT_RIGHT_BUTTON_UP = 165 + COREWEBVIEW2_MOUSE_EVENT_KIND_NON_CLIENT_RIGHT_BUTTON_UP = 165 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS.go b/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS.go index 2d2facd5e7d..98bb1cb6c4a 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS.go @@ -5,12 +5,12 @@ package webview2 type COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS uint32 const ( - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_NONE = 0x0 - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_LEFT_BUTTON = 0x1 - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_RIGHT_BUTTON = 0x2 - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_SHIFT = 0x4 - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_CONTROL = 0x8 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_NONE = 0x0 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_LEFT_BUTTON = 0x1 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_RIGHT_BUTTON = 0x2 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_SHIFT = 0x4 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_CONTROL = 0x8 COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_MIDDLE_BUTTON = 0x10 - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_X_BUTTON1 = 0x20 - COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_X_BUTTON2 = 0x40 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_X_BUTTON1 = 0x20 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_X_BUTTON2 = 0x40 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_MOVE_FOCUS_REASON.go b/webview2/pkg/webview2/COREWEBVIEW2_MOVE_FOCUS_REASON.go index 49b0ce52ef1..83648ab8e6c 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_MOVE_FOCUS_REASON.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_MOVE_FOCUS_REASON.go @@ -6,6 +6,6 @@ type COREWEBVIEW2_MOVE_FOCUS_REASON uint32 const ( COREWEBVIEW2_MOVE_FOCUS_REASON_PROGRAMMATIC = 0 - COREWEBVIEW2_MOVE_FOCUS_REASON_NEXT = 1 - COREWEBVIEW2_MOVE_FOCUS_REASON_PREVIOUS = 2 + COREWEBVIEW2_MOVE_FOCUS_REASON_NEXT = 1 + COREWEBVIEW2_MOVE_FOCUS_REASON_PREVIOUS = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_NAVIGATION_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_NAVIGATION_KIND.go index e804e9ae032..4971400e97a 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_NAVIGATION_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_NAVIGATION_KIND.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_NAVIGATION_KIND uint32 const ( - COREWEBVIEW2_NAVIGATION_KIND_RELOAD = 0 + COREWEBVIEW2_NAVIGATION_KIND_RELOAD = 0 COREWEBVIEW2_NAVIGATION_KIND_BACK_OR_FORWARD = 1 - COREWEBVIEW2_NAVIGATION_KIND_NEW_DOCUMENT = 2 + COREWEBVIEW2_NAVIGATION_KIND_NEW_DOCUMENT = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_NON_CLIENT_REGION_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_NON_CLIENT_REGION_KIND.go index 92b8603b1b9..ab84a1d77f3 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_NON_CLIENT_REGION_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_NON_CLIENT_REGION_KIND.go @@ -5,10 +5,10 @@ package webview2 type COREWEBVIEW2_NON_CLIENT_REGION_KIND uint32 const ( - COREWEBVIEW2_NON_CLIENT_REGION_KIND_NOWHERE = 0 - COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLIENT = 1 - COREWEBVIEW2_NON_CLIENT_REGION_KIND_CAPTION = 2 + COREWEBVIEW2_NON_CLIENT_REGION_KIND_NOWHERE = 0 + COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLIENT = 1 + COREWEBVIEW2_NON_CLIENT_REGION_KIND_CAPTION = 2 COREWEBVIEW2_NON_CLIENT_REGION_KIND_MINIMIZE = 8 COREWEBVIEW2_NON_CLIENT_REGION_KIND_MAXIMIZE = 9 - COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLOSE = 20 + COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLOSE = 20 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PDF_TOOLBAR_ITEMS.go b/webview2/pkg/webview2/COREWEBVIEW2_PDF_TOOLBAR_ITEMS.go index 3b4747b80f2..8053e818b48 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PDF_TOOLBAR_ITEMS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PDF_TOOLBAR_ITEMS.go @@ -5,18 +5,18 @@ package webview2 type COREWEBVIEW2_PDF_TOOLBAR_ITEMS uint32 const ( - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_NONE = 0x0 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SAVE = 0x1 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PRINT = 0x2 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SAVE_AS = 0x4 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ZOOM_IN = 0x8 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ZOOM_OUT = 0x10 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ROTATE = 0x20 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_FIT_PAGE = 0x40 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PAGE_LAYOUT = 0x80 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_BOOKMARKS = 0x100 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_NONE = 0x0 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SAVE = 0x1 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PRINT = 0x2 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SAVE_AS = 0x4 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ZOOM_IN = 0x8 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ZOOM_OUT = 0x10 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ROTATE = 0x20 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_FIT_PAGE = 0x40 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PAGE_LAYOUT = 0x80 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_BOOKMARKS = 0x100 COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PAGE_SELECTOR = 0x200 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SEARCH = 0x400 - COREWEBVIEW2_PDF_TOOLBAR_ITEMS_FULL_SCREEN = 0x800 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SEARCH = 0x400 + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_FULL_SCREEN = 0x800 COREWEBVIEW2_PDF_TOOLBAR_ITEMS_MORE_SETTINGS = 0x1000 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go index c25c9501185..f932c0f90e7 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go @@ -5,17 +5,17 @@ package webview2 type COREWEBVIEW2_PERMISSION_KIND uint32 const ( - COREWEBVIEW2_PERMISSION_KIND_UNKNOWN_PERMISSION = 0 - COREWEBVIEW2_PERMISSION_KIND_MICROPHONE = 1 - COREWEBVIEW2_PERMISSION_KIND_CAMERA = 2 - COREWEBVIEW2_PERMISSION_KIND_GEOLOCATION = 3 - COREWEBVIEW2_PERMISSION_KIND_NOTIFICATIONS = 4 - COREWEBVIEW2_PERMISSION_KIND_OTHER_SENSORS = 5 - COREWEBVIEW2_PERMISSION_KIND_CLIPBOARD_READ = 6 - COREWEBVIEW2_PERMISSION_KIND_MULTIPLE_AUTOMATIC_DOWNLOADS = 7 - COREWEBVIEW2_PERMISSION_KIND_FILE_READ_WRITE = 8 - COREWEBVIEW2_PERMISSION_KIND_AUTOPLAY = 9 - COREWEBVIEW2_PERMISSION_KIND_LOCAL_FONTS = 10 + COREWEBVIEW2_PERMISSION_KIND_UNKNOWN_PERMISSION = 0 + COREWEBVIEW2_PERMISSION_KIND_MICROPHONE = 1 + COREWEBVIEW2_PERMISSION_KIND_CAMERA = 2 + COREWEBVIEW2_PERMISSION_KIND_GEOLOCATION = 3 + COREWEBVIEW2_PERMISSION_KIND_NOTIFICATIONS = 4 + COREWEBVIEW2_PERMISSION_KIND_OTHER_SENSORS = 5 + COREWEBVIEW2_PERMISSION_KIND_CLIPBOARD_READ = 6 + COREWEBVIEW2_PERMISSION_KIND_MULTIPLE_AUTOMATIC_DOWNLOADS = 7 + COREWEBVIEW2_PERMISSION_KIND_FILE_READ_WRITE = 8 + COREWEBVIEW2_PERMISSION_KIND_AUTOPLAY = 9 + COREWEBVIEW2_PERMISSION_KIND_LOCAL_FONTS = 10 COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGES = 11 - COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT = 12 + COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT = 12 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_STATE.go b/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_STATE.go index c76b38391f7..7a8d31f8589 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_STATE.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_STATE.go @@ -6,6 +6,6 @@ type COREWEBVIEW2_PERMISSION_STATE uint32 const ( COREWEBVIEW2_PERMISSION_STATE_DEFAULT = 0 - COREWEBVIEW2_PERMISSION_STATE_ALLOW = 1 - COREWEBVIEW2_PERMISSION_STATE_DENY = 2 + COREWEBVIEW2_PERMISSION_STATE_ALLOW = 1 + COREWEBVIEW2_PERMISSION_STATE_DENY = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PHYSICAL_KEY_STATUS.go b/webview2/pkg/webview2/COREWEBVIEW2_PHYSICAL_KEY_STATUS.go index 23e84b40a24..4fae31e368f 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PHYSICAL_KEY_STATUS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PHYSICAL_KEY_STATUS.go @@ -3,10 +3,10 @@ package webview2 type COREWEBVIEW2_PHYSICAL_KEY_STATUS struct { - RepeatCount uint32 - ScanCode uint32 + RepeatCount uint32 + ScanCode uint32 IsExtendedKey bool IsMenuKeyDown bool - WasKeyDown bool + WasKeyDown bool IsKeyReleased bool } diff --git a/webview2/pkg/webview2/COREWEBVIEW2_POINTER_EVENT_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_POINTER_EVENT_KIND.go index 6c2181b6122..86cba03f856 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_POINTER_EVENT_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_POINTER_EVENT_KIND.go @@ -6,9 +6,9 @@ type COREWEBVIEW2_POINTER_EVENT_KIND uint32 const ( COREWEBVIEW2_POINTER_EVENT_KIND_ACTIVATE = 587 - COREWEBVIEW2_POINTER_EVENT_KIND_DOWN = 582 - COREWEBVIEW2_POINTER_EVENT_KIND_ENTER = 585 - COREWEBVIEW2_POINTER_EVENT_KIND_LEAVE = 586 - COREWEBVIEW2_POINTER_EVENT_KIND_UP = 583 - COREWEBVIEW2_POINTER_EVENT_KIND_UPDATE = 581 + COREWEBVIEW2_POINTER_EVENT_KIND_DOWN = 582 + COREWEBVIEW2_POINTER_EVENT_KIND_ENTER = 585 + COREWEBVIEW2_POINTER_EVENT_KIND_LEAVE = 586 + COREWEBVIEW2_POINTER_EVENT_KIND_UP = 583 + COREWEBVIEW2_POINTER_EVENT_KIND_UPDATE = 581 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PREFERRED_COLOR_SCHEME.go b/webview2/pkg/webview2/COREWEBVIEW2_PREFERRED_COLOR_SCHEME.go index 7f602a68629..d9c7d2d41a9 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PREFERRED_COLOR_SCHEME.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PREFERRED_COLOR_SCHEME.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_PREFERRED_COLOR_SCHEME uint32 const ( - COREWEBVIEW2_PREFERRED_COLOR_SCHEME_AUTO = 0 + COREWEBVIEW2_PREFERRED_COLOR_SCHEME_AUTO = 0 COREWEBVIEW2_PREFERRED_COLOR_SCHEME_LIGHT = 1 - COREWEBVIEW2_PREFERRED_COLOR_SCHEME_DARK = 2 + COREWEBVIEW2_PREFERRED_COLOR_SCHEME_DARK = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLLATION.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLLATION.go index b9c7dfc8bc7..904efce77bb 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLLATION.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLLATION.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_PRINT_COLLATION uint32 const ( - COREWEBVIEW2_PRINT_COLLATION_DEFAULT = 0 - COREWEBVIEW2_PRINT_COLLATION_COLLATED = 1 + COREWEBVIEW2_PRINT_COLLATION_DEFAULT = 0 + COREWEBVIEW2_PRINT_COLLATION_COLLATED = 1 COREWEBVIEW2_PRINT_COLLATION_UNCOLLATED = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLOR_MODE.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLOR_MODE.go index 8fd8d3ef492..53ae28a2944 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLOR_MODE.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_COLOR_MODE.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_PRINT_COLOR_MODE uint32 const ( - COREWEBVIEW2_PRINT_COLOR_MODE_DEFAULT = 0 - COREWEBVIEW2_PRINT_COLOR_MODE_COLOR = 1 + COREWEBVIEW2_PRINT_COLOR_MODE_DEFAULT = 0 + COREWEBVIEW2_PRINT_COLOR_MODE_COLOR = 1 COREWEBVIEW2_PRINT_COLOR_MODE_GRAYSCALE = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DIALOG_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DIALOG_KIND.go index a97aeb5910f..5f605aa1d5f 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DIALOG_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DIALOG_KIND.go @@ -6,5 +6,5 @@ type COREWEBVIEW2_PRINT_DIALOG_KIND uint32 const ( COREWEBVIEW2_PRINT_DIALOG_KIND_BROWSER = 0 - COREWEBVIEW2_PRINT_DIALOG_KIND_SYSTEM = 1 + COREWEBVIEW2_PRINT_DIALOG_KIND_SYSTEM = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DUPLEX.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DUPLEX.go index 4db912a85c0..320167b475c 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DUPLEX.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_DUPLEX.go @@ -5,8 +5,8 @@ package webview2 type COREWEBVIEW2_PRINT_DUPLEX uint32 const ( - COREWEBVIEW2_PRINT_DUPLEX_DEFAULT = 0 - COREWEBVIEW2_PRINT_DUPLEX_ONE_SIDED = 1 - COREWEBVIEW2_PRINT_DUPLEX_TWO_SIDED_LONG_EDGE = 2 + COREWEBVIEW2_PRINT_DUPLEX_DEFAULT = 0 + COREWEBVIEW2_PRINT_DUPLEX_ONE_SIDED = 1 + COREWEBVIEW2_PRINT_DUPLEX_TWO_SIDED_LONG_EDGE = 2 COREWEBVIEW2_PRINT_DUPLEX_TWO_SIDED_SHORT_EDGE = 3 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_MEDIA_SIZE.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_MEDIA_SIZE.go index 4736b1a4196..f211f23c086 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_MEDIA_SIZE.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_MEDIA_SIZE.go @@ -6,5 +6,5 @@ type COREWEBVIEW2_PRINT_MEDIA_SIZE uint32 const ( COREWEBVIEW2_PRINT_MEDIA_SIZE_DEFAULT = 0 - COREWEBVIEW2_PRINT_MEDIA_SIZE_CUSTOM = 1 + COREWEBVIEW2_PRINT_MEDIA_SIZE_CUSTOM = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_ORIENTATION.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_ORIENTATION.go index 4d2d1669a25..d0311c33f56 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_ORIENTATION.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_ORIENTATION.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_PRINT_ORIENTATION uint32 const ( - COREWEBVIEW2_PRINT_ORIENTATION_PORTRAIT = 0 + COREWEBVIEW2_PRINT_ORIENTATION_PORTRAIT = 0 COREWEBVIEW2_PRINT_ORIENTATION_LANDSCAPE = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_STATUS.go b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_STATUS.go index 62e4edfcdc1..33bd77f60a8 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PRINT_STATUS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PRINT_STATUS.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_PRINT_STATUS uint32 const ( - COREWEBVIEW2_PRINT_STATUS_SUCCEEDED = 0 + COREWEBVIEW2_PRINT_STATUS_SUCCEEDED = 0 COREWEBVIEW2_PRINT_STATUS_PRINTER_UNAVAILABLE = 1 - COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR = 2 + COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_KIND.go index 9625515bad4..f008aea3201 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_KIND.go @@ -5,14 +5,14 @@ package webview2 type COREWEBVIEW2_PROCESS_FAILED_KIND uint32 const ( - COREWEBVIEW2_PROCESS_FAILED_KIND_BROWSER_PROCESS_EXITED = 0 - COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_EXITED = 1 - COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_UNRESPONSIVE = 2 - COREWEBVIEW2_PROCESS_FAILED_KIND_FRAME_RENDER_PROCESS_EXITED = 3 - COREWEBVIEW2_PROCESS_FAILED_KIND_UTILITY_PROCESS_EXITED = 4 + COREWEBVIEW2_PROCESS_FAILED_KIND_BROWSER_PROCESS_EXITED = 0 + COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_EXITED = 1 + COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_UNRESPONSIVE = 2 + COREWEBVIEW2_PROCESS_FAILED_KIND_FRAME_RENDER_PROCESS_EXITED = 3 + COREWEBVIEW2_PROCESS_FAILED_KIND_UTILITY_PROCESS_EXITED = 4 COREWEBVIEW2_PROCESS_FAILED_KIND_SANDBOX_HELPER_PROCESS_EXITED = 5 - COREWEBVIEW2_PROCESS_FAILED_KIND_GPU_PROCESS_EXITED = 6 - COREWEBVIEW2_PROCESS_FAILED_KIND_PPAPI_PLUGIN_PROCESS_EXITED = 7 - COREWEBVIEW2_PROCESS_FAILED_KIND_PPAPI_BROKER_PROCESS_EXITED = 8 - COREWEBVIEW2_PROCESS_FAILED_KIND_UNKNOWN_PROCESS_EXITED = 9 + COREWEBVIEW2_PROCESS_FAILED_KIND_GPU_PROCESS_EXITED = 6 + COREWEBVIEW2_PROCESS_FAILED_KIND_PPAPI_PLUGIN_PROCESS_EXITED = 7 + COREWEBVIEW2_PROCESS_FAILED_KIND_PPAPI_BROKER_PROCESS_EXITED = 8 + COREWEBVIEW2_PROCESS_FAILED_KIND_UNKNOWN_PROCESS_EXITED = 9 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go index 9a565154317..b1b21b1965f 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go @@ -5,11 +5,11 @@ package webview2 type COREWEBVIEW2_PROCESS_FAILED_REASON uint32 const ( - COREWEBVIEW2_PROCESS_FAILED_REASON_UNEXPECTED = 0 - COREWEBVIEW2_PROCESS_FAILED_REASON_UNRESPONSIVE = 1 - COREWEBVIEW2_PROCESS_FAILED_REASON_TERMINATED = 2 - COREWEBVIEW2_PROCESS_FAILED_REASON_CRASHED = 3 - COREWEBVIEW2_PROCESS_FAILED_REASON_LAUNCH_FAILED = 4 - COREWEBVIEW2_PROCESS_FAILED_REASON_OUT_OF_MEMORY = 5 + COREWEBVIEW2_PROCESS_FAILED_REASON_UNEXPECTED = 0 + COREWEBVIEW2_PROCESS_FAILED_REASON_UNRESPONSIVE = 1 + COREWEBVIEW2_PROCESS_FAILED_REASON_TERMINATED = 2 + COREWEBVIEW2_PROCESS_FAILED_REASON_CRASHED = 3 + COREWEBVIEW2_PROCESS_FAILED_REASON_LAUNCH_FAILED = 4 + COREWEBVIEW2_PROCESS_FAILED_REASON_OUT_OF_MEMORY = 5 COREWEBVIEW2_PROCESS_FAILED_REASON_PROFILE_DELETED = 6 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_KIND.go index 7aa7b6bc411..b3e122db79f 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_KIND.go @@ -5,11 +5,11 @@ package webview2 type COREWEBVIEW2_PROCESS_KIND uint32 const ( - COREWEBVIEW2_PROCESS_KIND_BROWSER = 0 - COREWEBVIEW2_PROCESS_KIND_RENDERER = 1 - COREWEBVIEW2_PROCESS_KIND_UTILITY = 2 + COREWEBVIEW2_PROCESS_KIND_BROWSER = 0 + COREWEBVIEW2_PROCESS_KIND_RENDERER = 1 + COREWEBVIEW2_PROCESS_KIND_UTILITY = 2 COREWEBVIEW2_PROCESS_KIND_SANDBOX_HELPER = 3 - COREWEBVIEW2_PROCESS_KIND_GPU = 4 - COREWEBVIEW2_PROCESS_KIND_PPAPI_PLUGIN = 5 - COREWEBVIEW2_PROCESS_KIND_PPAPI_BROKER = 6 + COREWEBVIEW2_PROCESS_KIND_GPU = 4 + COREWEBVIEW2_PROCESS_KIND_PPAPI_PLUGIN = 5 + COREWEBVIEW2_PROCESS_KIND_PPAPI_BROKER = 6 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_RELEASE_CHANNELS.go b/webview2/pkg/webview2/COREWEBVIEW2_RELEASE_CHANNELS.go index c6a5f49b6bf..fe73fa4fe08 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_RELEASE_CHANNELS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_RELEASE_CHANNELS.go @@ -5,9 +5,9 @@ package webview2 type COREWEBVIEW2_RELEASE_CHANNELS uint32 const ( - COREWEBVIEW2_RELEASE_CHANNELS_NONE = 0x0 + COREWEBVIEW2_RELEASE_CHANNELS_NONE = 0x0 COREWEBVIEW2_RELEASE_CHANNELS_STABLE = 0x1 - COREWEBVIEW2_RELEASE_CHANNELS_BETA = 0x2 - COREWEBVIEW2_RELEASE_CHANNELS_DEV = 0x4 + COREWEBVIEW2_RELEASE_CHANNELS_BETA = 0x2 + COREWEBVIEW2_RELEASE_CHANNELS_DEV = 0x4 COREWEBVIEW2_RELEASE_CHANNELS_CANARY = 0x8 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_KIND.go index 9fc159b3561..7ca85ebb7ec 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_KIND.go @@ -5,8 +5,8 @@ package webview2 type COREWEBVIEW2_SAVE_AS_KIND uint32 const ( - COREWEBVIEW2_SAVE_AS_KIND_DEFAULT = 0 - COREWEBVIEW2_SAVE_AS_KIND_HTML_ONLY = 1 + COREWEBVIEW2_SAVE_AS_KIND_DEFAULT = 0 + COREWEBVIEW2_SAVE_AS_KIND_HTML_ONLY = 1 COREWEBVIEW2_SAVE_AS_KIND_SINGLE_FILE = 2 - COREWEBVIEW2_SAVE_AS_KIND_COMPLETE = 3 + COREWEBVIEW2_SAVE_AS_KIND_COMPLETE = 3 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_UI_RESULT.go b/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_UI_RESULT.go index 9d86c15253d..7939615bdf8 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_UI_RESULT.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_SAVE_AS_UI_RESULT.go @@ -5,9 +5,9 @@ package webview2 type COREWEBVIEW2_SAVE_AS_UI_RESULT uint32 const ( - COREWEBVIEW2_SAVE_AS_UI_RESULT_SUCCESS = 0 - COREWEBVIEW2_SAVE_AS_UI_RESULT_INVALID_PATH = 1 + COREWEBVIEW2_SAVE_AS_UI_RESULT_SUCCESS = 0 + COREWEBVIEW2_SAVE_AS_UI_RESULT_INVALID_PATH = 1 COREWEBVIEW2_SAVE_AS_UI_RESULT_FILE_ALREADY_EXISTS = 2 - COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED = 3 - COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED = 4 + COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED = 3 + COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED = 4 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_SCRIPT_DIALOG_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_SCRIPT_DIALOG_KIND.go index 1182c08a04a..f978a781020 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_SCRIPT_DIALOG_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_SCRIPT_DIALOG_KIND.go @@ -5,8 +5,8 @@ package webview2 type COREWEBVIEW2_SCRIPT_DIALOG_KIND uint32 const ( - COREWEBVIEW2_SCRIPT_DIALOG_KIND_ALERT = 0 - COREWEBVIEW2_SCRIPT_DIALOG_KIND_CONFIRM = 1 - COREWEBVIEW2_SCRIPT_DIALOG_KIND_PROMPT = 2 + COREWEBVIEW2_SCRIPT_DIALOG_KIND_ALERT = 0 + COREWEBVIEW2_SCRIPT_DIALOG_KIND_CONFIRM = 1 + COREWEBVIEW2_SCRIPT_DIALOG_KIND_PROMPT = 2 COREWEBVIEW2_SCRIPT_DIALOG_KIND_BEFOREUNLOAD = 3 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_SCROLLBAR_STYLE.go b/webview2/pkg/webview2/COREWEBVIEW2_SCROLLBAR_STYLE.go index 0082485d884..14c4f7f490b 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_SCROLLBAR_STYLE.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_SCROLLBAR_STYLE.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_SCROLLBAR_STYLE uint32 const ( - COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT = 0 + COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT = 0 COREWEBVIEW2_SCROLLBAR_STYLE_FLUENT_OVERLAY = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION.go b/webview2/pkg/webview2/COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION.go index ab872663bb1..5ba55c15ea1 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION.go @@ -6,6 +6,6 @@ type COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION uint32 const ( COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_ALWAYS_ALLOW = 0 - COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_CANCEL = 1 - COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_DEFAULT = 2 + COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_CANCEL = 1 + COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_DEFAULT = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_SHARED_BUFFER_ACCESS.go b/webview2/pkg/webview2/COREWEBVIEW2_SHARED_BUFFER_ACCESS.go index 943e89a44dd..bd3c2eb7274 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_SHARED_BUFFER_ACCESS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_SHARED_BUFFER_ACCESS.go @@ -5,6 +5,6 @@ package webview2 type COREWEBVIEW2_SHARED_BUFFER_ACCESS uint32 const ( - COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY = 0 + COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY = 0 COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_WRITE = 1 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_TEXT_DIRECTION_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_TEXT_DIRECTION_KIND.go index d8033442fc5..a0501348d24 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_TEXT_DIRECTION_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_TEXT_DIRECTION_KIND.go @@ -5,7 +5,7 @@ package webview2 type COREWEBVIEW2_TEXT_DIRECTION_KIND uint32 const ( - COREWEBVIEW2_TEXT_DIRECTION_KIND_DEFAULT = 0 + COREWEBVIEW2_TEXT_DIRECTION_KIND_DEFAULT = 0 COREWEBVIEW2_TEXT_DIRECTION_KIND_LEFT_TO_RIGHT = 1 COREWEBVIEW2_TEXT_DIRECTION_KIND_RIGHT_TO_LEFT = 2 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_TRACKING_PREVENTION_LEVEL.go b/webview2/pkg/webview2/COREWEBVIEW2_TRACKING_PREVENTION_LEVEL.go index 42003b4806a..89d120de74b 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_TRACKING_PREVENTION_LEVEL.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_TRACKING_PREVENTION_LEVEL.go @@ -5,8 +5,8 @@ package webview2 type COREWEBVIEW2_TRACKING_PREVENTION_LEVEL uint32 const ( - COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE = 0 - COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BASIC = 1 + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE = 0 + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BASIC = 1 COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BALANCED = 2 - COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_STRICT = 3 + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_STRICT = 3 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_WEB_ERROR_STATUS.go b/webview2/pkg/webview2/COREWEBVIEW2_WEB_ERROR_STATUS.go index a36761f67b3..58c7d2564d5 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_WEB_ERROR_STATUS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_WEB_ERROR_STATUS.go @@ -5,23 +5,23 @@ package webview2 type COREWEBVIEW2_WEB_ERROR_STATUS uint32 const ( - COREWEBVIEW2_WEB_ERROR_STATUS_UNKNOWN = 0 - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_COMMON_NAME_IS_INCORRECT = 1 - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_EXPIRED = 2 - COREWEBVIEW2_WEB_ERROR_STATUS_CLIENT_CERTIFICATE_CONTAINS_ERRORS = 3 - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_REVOKED = 4 - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_IS_INVALID = 5 - COREWEBVIEW2_WEB_ERROR_STATUS_SERVER_UNREACHABLE = 6 - COREWEBVIEW2_WEB_ERROR_STATUS_TIMEOUT = 7 - COREWEBVIEW2_WEB_ERROR_STATUS_ERROR_HTTP_INVALID_SERVER_RESPONSE = 8 - COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_ABORTED = 9 - COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_RESET = 10 - COREWEBVIEW2_WEB_ERROR_STATUS_DISCONNECTED = 11 - COREWEBVIEW2_WEB_ERROR_STATUS_CANNOT_CONNECT = 12 - COREWEBVIEW2_WEB_ERROR_STATUS_HOST_NAME_NOT_RESOLVED = 13 - COREWEBVIEW2_WEB_ERROR_STATUS_OPERATION_CANCELED = 14 - COREWEBVIEW2_WEB_ERROR_STATUS_REDIRECT_FAILED = 15 - COREWEBVIEW2_WEB_ERROR_STATUS_UNEXPECTED_ERROR = 16 + COREWEBVIEW2_WEB_ERROR_STATUS_UNKNOWN = 0 + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_COMMON_NAME_IS_INCORRECT = 1 + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_EXPIRED = 2 + COREWEBVIEW2_WEB_ERROR_STATUS_CLIENT_CERTIFICATE_CONTAINS_ERRORS = 3 + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_REVOKED = 4 + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_IS_INVALID = 5 + COREWEBVIEW2_WEB_ERROR_STATUS_SERVER_UNREACHABLE = 6 + COREWEBVIEW2_WEB_ERROR_STATUS_TIMEOUT = 7 + COREWEBVIEW2_WEB_ERROR_STATUS_ERROR_HTTP_INVALID_SERVER_RESPONSE = 8 + COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_ABORTED = 9 + COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_RESET = 10 + COREWEBVIEW2_WEB_ERROR_STATUS_DISCONNECTED = 11 + COREWEBVIEW2_WEB_ERROR_STATUS_CANNOT_CONNECT = 12 + COREWEBVIEW2_WEB_ERROR_STATUS_HOST_NAME_NOT_RESOLVED = 13 + COREWEBVIEW2_WEB_ERROR_STATUS_OPERATION_CANCELED = 14 + COREWEBVIEW2_WEB_ERROR_STATUS_REDIRECT_FAILED = 15 + COREWEBVIEW2_WEB_ERROR_STATUS_UNEXPECTED_ERROR = 16 COREWEBVIEW2_WEB_ERROR_STATUS_VALID_AUTHENTICATION_CREDENTIALS_REQUIRED = 17 - COREWEBVIEW2_WEB_ERROR_STATUS_VALID_PROXY_AUTHENTICATION_REQUIRED = 18 + COREWEBVIEW2_WEB_ERROR_STATUS_VALID_PROXY_AUTHENTICATION_REQUIRED = 18 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_CONTEXT.go b/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_CONTEXT.go index 0120aec6f56..6bf199812ad 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_CONTEXT.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_CONTEXT.go @@ -5,21 +5,21 @@ package webview2 type COREWEBVIEW2_WEB_RESOURCE_CONTEXT uint32 const ( - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_ALL = 0 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_DOCUMENT = 1 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_STYLESHEET = 2 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_IMAGE = 3 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_MEDIA = 4 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_FONT = 5 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_SCRIPT = 6 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_XML_HTTP_REQUEST = 7 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_FETCH = 8 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_TEXT_TRACK = 9 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_EVENT_SOURCE = 10 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_WEBSOCKET = 11 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_MANIFEST = 12 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_SIGNED_EXCHANGE = 13 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_PING = 14 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_ALL = 0 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_DOCUMENT = 1 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_STYLESHEET = 2 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_IMAGE = 3 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_MEDIA = 4 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_FONT = 5 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_SCRIPT = 6 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_XML_HTTP_REQUEST = 7 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_FETCH = 8 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_TEXT_TRACK = 9 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_EVENT_SOURCE = 10 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_WEBSOCKET = 11 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_MANIFEST = 12 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_SIGNED_EXCHANGE = 13 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_PING = 14 COREWEBVIEW2_WEB_RESOURCE_CONTEXT_CSP_VIOLATION_REPORT = 15 - COREWEBVIEW2_WEB_RESOURCE_CONTEXT_OTHER = 16 + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_OTHER = 16 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS.go b/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS.go index 64d7f5aefcb..671ecd9667b 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS.go @@ -5,9 +5,9 @@ package webview2 type COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS uint32 const ( - COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_NONE = 0x0 - COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_DOCUMENT = 0x1 - COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SHARED_WORKER = 0x2 + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_NONE = 0x0 + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_DOCUMENT = 0x1 + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SHARED_WORKER = 0x2 COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SERVICE_WORKER = 0x4 - COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_ALL = 0xFFFFFFFF + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_ALL = 0xFFFFFFFF ) diff --git a/webview2/pkg/webview2/ICoreWebView2.go b/webview2/pkg/webview2/ICoreWebView2.go index 9b0af893015..68bf115cd16 100644 --- a/webview2/pkg/webview2/ICoreWebView2.go +++ b/webview2/pkg/webview2/ICoreWebView2.go @@ -1,105 +1,111 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Vtbl struct { IUnknownVtbl - GetSettings ComProc - GetSource ComProc - Navigate ComProc - NavigateToString ComProc - AddNavigationStarting ComProc - RemoveNavigationStarting ComProc - AddContentLoading ComProc - RemoveContentLoading ComProc - AddSourceChanged ComProc - RemoveSourceChanged ComProc - AddHistoryChanged ComProc - RemoveHistoryChanged ComProc - AddNavigationCompleted ComProc - RemoveNavigationCompleted ComProc - AddFrameNavigationStarting ComProc - RemoveFrameNavigationStarting ComProc - AddFrameNavigationCompleted ComProc - RemoveFrameNavigationCompleted ComProc - AddScriptDialogOpening ComProc - RemoveScriptDialogOpening ComProc - AddPermissionRequested ComProc - RemovePermissionRequested ComProc - AddProcessFailed ComProc - RemoveProcessFailed ComProc - AddScriptToExecuteOnDocumentCreated ComProc + GetSettings ComProc + GetSource ComProc + Navigate ComProc + NavigateToString ComProc + AddNavigationStarting ComProc + RemoveNavigationStarting ComProc + AddContentLoading ComProc + RemoveContentLoading ComProc + AddSourceChanged ComProc + RemoveSourceChanged ComProc + AddHistoryChanged ComProc + RemoveHistoryChanged ComProc + AddNavigationCompleted ComProc + RemoveNavigationCompleted ComProc + AddFrameNavigationStarting ComProc + RemoveFrameNavigationStarting ComProc + AddFrameNavigationCompleted ComProc + RemoveFrameNavigationCompleted ComProc + AddScriptDialogOpening ComProc + RemoveScriptDialogOpening ComProc + AddPermissionRequested ComProc + RemovePermissionRequested ComProc + AddProcessFailed ComProc + RemoveProcessFailed ComProc + AddScriptToExecuteOnDocumentCreated ComProc RemoveScriptToExecuteOnDocumentCreated ComProc - ExecuteScript ComProc - CapturePreview ComProc - Reload ComProc - PostWebMessageAsJson ComProc - PostWebMessageAsString ComProc - AddWebMessageReceived ComProc - RemoveWebMessageReceived ComProc - CallDevToolsProtocolMethod ComProc - GetBrowserProcessId ComProc - GetCanGoBack ComProc - GetCanGoForward ComProc - GoBack ComProc - GoForward ComProc - GetDevToolsProtocolEventReceiver ComProc - Stop ComProc - AddNewWindowRequested ComProc - RemoveNewWindowRequested ComProc - AddDocumentTitleChanged ComProc - RemoveDocumentTitleChanged ComProc - GetDocumentTitle ComProc - AddHostObjectToScript ComProc - RemoveHostObjectFromScript ComProc - OpenDevToolsWindow ComProc - AddContainsFullScreenElementChanged ComProc + ExecuteScript ComProc + CapturePreview ComProc + Reload ComProc + PostWebMessageAsJson ComProc + PostWebMessageAsString ComProc + AddWebMessageReceived ComProc + RemoveWebMessageReceived ComProc + CallDevToolsProtocolMethod ComProc + GetBrowserProcessId ComProc + GetCanGoBack ComProc + GetCanGoForward ComProc + GoBack ComProc + GoForward ComProc + GetDevToolsProtocolEventReceiver ComProc + Stop ComProc + AddNewWindowRequested ComProc + RemoveNewWindowRequested ComProc + AddDocumentTitleChanged ComProc + RemoveDocumentTitleChanged ComProc + GetDocumentTitle ComProc + AddHostObjectToScript ComProc + RemoveHostObjectFromScript ComProc + OpenDevToolsWindow ComProc + AddContainsFullScreenElementChanged ComProc RemoveContainsFullScreenElementChanged ComProc - GetContainsFullScreenElement ComProc - AddWebResourceRequested ComProc - RemoveWebResourceRequested ComProc - AddWebResourceRequestedFilter ComProc - RemoveWebResourceRequestedFilter ComProc - AddWindowCloseRequested ComProc - RemoveWindowCloseRequested ComProc + GetContainsFullScreenElement ComProc + AddWebResourceRequested ComProc + RemoveWebResourceRequested ComProc + AddWebResourceRequestedFilter ComProc + RemoveWebResourceRequestedFilter ComProc + AddWindowCloseRequested ComProc + RemoveWindowCloseRequested ComProc } type ICoreWebView2 struct { Vtbl *ICoreWebView2Vtbl } -func (i *ICoreWebView2) AddRef() uintptr { +func (i *ICoreWebView2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2) GetSettings() (*ICoreWebView2Settings, error) { var settings *ICoreWebView2Settings - hr, _, _ := i.Vtbl.GetSettings.Call( + hr, _, err := i.Vtbl.GetSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&settings)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return settings, nil + return settings, err } func (i *ICoreWebView2) GetSource() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetSource.Call( + + hr, _, err := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -107,7 +113,7 @@ func (i *ICoreWebView2) GetSource() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2) Navigate(uri string) error { @@ -118,14 +124,14 @@ func (i *ICoreWebView2) Navigate(uri string) error { return err } - hr, _, _ := i.Vtbl.Navigate.Call( + hr, _, err := i.Vtbl.Navigate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) NavigateToString(htmlContent string) error { @@ -136,21 +142,21 @@ func (i *ICoreWebView2) NavigateToString(htmlContent string) error { return err } - hr, _, _ := i.Vtbl.NavigateToString.Call( + hr, _, err := i.Vtbl.NavigateToString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_htmlContent)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddNavigationStarting(eventHandler *ICoreWebView2NavigationStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNavigationStarting.Call( + hr, _, err := i.Vtbl.AddNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -158,26 +164,27 @@ func (i *ICoreWebView2) AddNavigationStarting(eventHandler *ICoreWebView2Navigat if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveNavigationStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNavigationStarting.Call( + + hr, _, err := i.Vtbl.RemoveNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddContentLoading(eventHandler *ICoreWebView2ContentLoadingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddContentLoading.Call( + hr, _, err := i.Vtbl.AddContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -185,26 +192,27 @@ func (i *ICoreWebView2) AddContentLoading(eventHandler *ICoreWebView2ContentLoad if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveContentLoading(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveContentLoading.Call( + + hr, _, err := i.Vtbl.RemoveContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddSourceChanged(eventHandler *ICoreWebView2SourceChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddSourceChanged.Call( + hr, _, err := i.Vtbl.AddSourceChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -212,26 +220,27 @@ func (i *ICoreWebView2) AddSourceChanged(eventHandler *ICoreWebView2SourceChange if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveSourceChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveSourceChanged.Call( + + hr, _, err := i.Vtbl.RemoveSourceChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddHistoryChanged(eventHandler *ICoreWebView2HistoryChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddHistoryChanged.Call( + hr, _, err := i.Vtbl.AddHistoryChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -239,26 +248,27 @@ func (i *ICoreWebView2) AddHistoryChanged(eventHandler *ICoreWebView2HistoryChan if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveHistoryChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveHistoryChanged.Call( + + hr, _, err := i.Vtbl.RemoveHistoryChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddNavigationCompleted(eventHandler *ICoreWebView2NavigationCompletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNavigationCompleted.Call( + hr, _, err := i.Vtbl.AddNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -266,26 +276,27 @@ func (i *ICoreWebView2) AddNavigationCompleted(eventHandler *ICoreWebView2Naviga if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveNavigationCompleted(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNavigationCompleted.Call( + + hr, _, err := i.Vtbl.RemoveNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddFrameNavigationStarting(eventHandler *ICoreWebView2NavigationStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddFrameNavigationStarting.Call( + hr, _, err := i.Vtbl.AddFrameNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -293,26 +304,27 @@ func (i *ICoreWebView2) AddFrameNavigationStarting(eventHandler *ICoreWebView2Na if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveFrameNavigationStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveFrameNavigationStarting.Call( + + hr, _, err := i.Vtbl.RemoveFrameNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddFrameNavigationCompleted(eventHandler *ICoreWebView2NavigationCompletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddFrameNavigationCompleted.Call( + hr, _, err := i.Vtbl.AddFrameNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -320,26 +332,27 @@ func (i *ICoreWebView2) AddFrameNavigationCompleted(eventHandler *ICoreWebView2N if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveFrameNavigationCompleted(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveFrameNavigationCompleted.Call( + + hr, _, err := i.Vtbl.RemoveFrameNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddScriptDialogOpening(eventHandler *ICoreWebView2ScriptDialogOpeningEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddScriptDialogOpening.Call( + hr, _, err := i.Vtbl.AddScriptDialogOpening.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -347,26 +360,27 @@ func (i *ICoreWebView2) AddScriptDialogOpening(eventHandler *ICoreWebView2Script if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveScriptDialogOpening(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveScriptDialogOpening.Call( + + hr, _, err := i.Vtbl.RemoveScriptDialogOpening.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddPermissionRequested(eventHandler *ICoreWebView2PermissionRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddPermissionRequested.Call( + hr, _, err := i.Vtbl.AddPermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -374,26 +388,27 @@ func (i *ICoreWebView2) AddPermissionRequested(eventHandler *ICoreWebView2Permis if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemovePermissionRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemovePermissionRequested.Call( + + hr, _, err := i.Vtbl.RemovePermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddProcessFailed(eventHandler *ICoreWebView2ProcessFailedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddProcessFailed.Call( + hr, _, err := i.Vtbl.AddProcessFailed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -401,19 +416,20 @@ func (i *ICoreWebView2) AddProcessFailed(eventHandler *ICoreWebView2ProcessFaile if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveProcessFailed(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveProcessFailed.Call( + + hr, _, err := i.Vtbl.RemoveProcessFailed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddScriptToExecuteOnDocumentCreated(javaScript string, handler *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) error { @@ -424,7 +440,7 @@ func (i *ICoreWebView2) AddScriptToExecuteOnDocumentCreated(javaScript string, h return err } - hr, _, _ := i.Vtbl.AddScriptToExecuteOnDocumentCreated.Call( + hr, _, err := i.Vtbl.AddScriptToExecuteOnDocumentCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -432,7 +448,7 @@ func (i *ICoreWebView2) AddScriptToExecuteOnDocumentCreated(javaScript string, h if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) RemoveScriptToExecuteOnDocumentCreated(id string) error { @@ -443,14 +459,14 @@ func (i *ICoreWebView2) RemoveScriptToExecuteOnDocumentCreated(id string) error return err } - hr, _, _ := i.Vtbl.RemoveScriptToExecuteOnDocumentCreated.Call( + hr, _, err := i.Vtbl.RemoveScriptToExecuteOnDocumentCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_id)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) ExecuteScript(javaScript string, handler *ICoreWebView2ExecuteScriptCompletedHandler) error { @@ -461,7 +477,7 @@ func (i *ICoreWebView2) ExecuteScript(javaScript string, handler *ICoreWebView2E return err } - hr, _, _ := i.Vtbl.ExecuteScript.Call( + hr, _, err := i.Vtbl.ExecuteScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -469,12 +485,13 @@ func (i *ICoreWebView2) ExecuteScript(javaScript string, handler *ICoreWebView2E if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) CapturePreview(imageFormat COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT, imageStream *IStream, handler *ICoreWebView2CapturePreviewCompletedHandler) error { - hr, _, _ := i.Vtbl.CapturePreview.Call( + + hr, _, err := i.Vtbl.CapturePreview.Call( uintptr(unsafe.Pointer(i)), uintptr(imageFormat), uintptr(unsafe.Pointer(imageStream)), @@ -483,18 +500,19 @@ func (i *ICoreWebView2) CapturePreview(imageFormat COREWEBVIEW2_CAPTURE_PREVIEW_ if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) Reload() error { - hr, _, _ := i.Vtbl.Reload.Call( + + hr, _, err := i.Vtbl.Reload.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) PostWebMessageAsJson(webMessageAsJson string) error { @@ -505,14 +523,14 @@ func (i *ICoreWebView2) PostWebMessageAsJson(webMessageAsJson string) error { return err } - hr, _, _ := i.Vtbl.PostWebMessageAsJson.Call( + hr, _, err := i.Vtbl.PostWebMessageAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsJson)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) PostWebMessageAsString(webMessageAsString string) error { @@ -523,21 +541,21 @@ func (i *ICoreWebView2) PostWebMessageAsString(webMessageAsString string) error return err } - hr, _, _ := i.Vtbl.PostWebMessageAsString.Call( + hr, _, err := i.Vtbl.PostWebMessageAsString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsString)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddWebMessageReceived(handler *ICoreWebView2WebMessageReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddWebMessageReceived.Call( + hr, _, err := i.Vtbl.AddWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), uintptr(unsafe.Pointer(&token)), @@ -545,19 +563,20 @@ func (i *ICoreWebView2) AddWebMessageReceived(handler *ICoreWebView2WebMessageRe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveWebMessageReceived(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveWebMessageReceived.Call( + + hr, _, err := i.Vtbl.RemoveWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) CallDevToolsProtocolMethod(methodName string, parametersAsJson string, handler *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) error { @@ -573,7 +592,7 @@ func (i *ICoreWebView2) CallDevToolsProtocolMethod(methodName string, parameters return err } - hr, _, _ := i.Vtbl.CallDevToolsProtocolMethod.Call( + hr, _, err := i.Vtbl.CallDevToolsProtocolMethod.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_methodName)), uintptr(unsafe.Pointer(_parametersAsJson)), @@ -582,28 +601,28 @@ func (i *ICoreWebView2) CallDevToolsProtocolMethod(methodName string, parameters if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) GetBrowserProcessId() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetBrowserProcessId.Call( + hr, _, err := i.Vtbl.GetBrowserProcessId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2) GetCanGoBack() (bool, error) { // Create int32 to hold bool result var _canGoBack int32 - hr, _, _ := i.Vtbl.GetCanGoBack.Call( + hr, _, err := i.Vtbl.GetCanGoBack.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_canGoBack)), ) @@ -611,15 +630,15 @@ func (i *ICoreWebView2) GetCanGoBack() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - canGoBack := _canGoBack != 0 - return canGoBack, nil + canGoBack := _canGoBack != 0 + return canGoBack, err } func (i *ICoreWebView2) GetCanGoForward() (bool, error) { // Create int32 to hold bool result var _canGoForward int32 - hr, _, _ := i.Vtbl.GetCanGoForward.Call( + hr, _, err := i.Vtbl.GetCanGoForward.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_canGoForward)), ) @@ -627,30 +646,32 @@ func (i *ICoreWebView2) GetCanGoForward() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - canGoForward := _canGoForward != 0 - return canGoForward, nil + canGoForward := _canGoForward != 0 + return canGoForward, err } func (i *ICoreWebView2) GoBack() error { - hr, _, _ := i.Vtbl.GoBack.Call( + + hr, _, err := i.Vtbl.GoBack.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) GoForward() error { - hr, _, _ := i.Vtbl.GoForward.Call( + + hr, _, err := i.Vtbl.GoForward.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) GetDevToolsProtocolEventReceiver(eventName string) (*ICoreWebView2DevToolsProtocolEventReceiver, error) { @@ -662,7 +683,7 @@ func (i *ICoreWebView2) GetDevToolsProtocolEventReceiver(eventName string) (*ICo } var receiver *ICoreWebView2DevToolsProtocolEventReceiver - hr, _, _ := i.Vtbl.GetDevToolsProtocolEventReceiver.Call( + hr, _, err := i.Vtbl.GetDevToolsProtocolEventReceiver.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_eventName)), uintptr(unsafe.Pointer(&receiver)), @@ -670,25 +691,26 @@ func (i *ICoreWebView2) GetDevToolsProtocolEventReceiver(eventName string) (*ICo if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return receiver, nil + return receiver, err } func (i *ICoreWebView2) Stop() error { - hr, _, _ := i.Vtbl.Stop.Call( + + hr, _, err := i.Vtbl.Stop.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddNewWindowRequested(eventHandler *ICoreWebView2NewWindowRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNewWindowRequested.Call( + hr, _, err := i.Vtbl.AddNewWindowRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -696,26 +718,27 @@ func (i *ICoreWebView2) AddNewWindowRequested(eventHandler *ICoreWebView2NewWind if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveNewWindowRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNewWindowRequested.Call( + + hr, _, err := i.Vtbl.RemoveNewWindowRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddDocumentTitleChanged(eventHandler *ICoreWebView2DocumentTitleChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDocumentTitleChanged.Call( + hr, _, err := i.Vtbl.AddDocumentTitleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -723,28 +746,30 @@ func (i *ICoreWebView2) AddDocumentTitleChanged(eventHandler *ICoreWebView2Docum if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveDocumentTitleChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDocumentTitleChanged.Call( + + hr, _, err := i.Vtbl.RemoveDocumentTitleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) GetDocumentTitle() (string, error) { // Create *uint16 to hold result var _title *uint16 - hr, _, _ := i.Vtbl.GetDocumentTitle.Call( + + hr, _, err := i.Vtbl.GetDocumentTitle.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_title)), + uintptr(unsafe.Pointer(&_title)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -752,7 +777,7 @@ func (i *ICoreWebView2) GetDocumentTitle() (string, error) { // Get result and cleanup title := UTF16PtrToString(_title) CoTaskMemFree(unsafe.Pointer(_title)) - return title, nil + return title, err } func (i *ICoreWebView2) AddHostObjectToScript(name string, object *VARIANT) error { @@ -763,7 +788,7 @@ func (i *ICoreWebView2) AddHostObjectToScript(name string, object *VARIANT) erro return err } - hr, _, _ := i.Vtbl.AddHostObjectToScript.Call( + hr, _, err := i.Vtbl.AddHostObjectToScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(object)), @@ -771,7 +796,7 @@ func (i *ICoreWebView2) AddHostObjectToScript(name string, object *VARIANT) erro if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) RemoveHostObjectFromScript(name string) error { @@ -782,32 +807,33 @@ func (i *ICoreWebView2) RemoveHostObjectFromScript(name string) error { return err } - hr, _, _ := i.Vtbl.RemoveHostObjectFromScript.Call( + hr, _, err := i.Vtbl.RemoveHostObjectFromScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) OpenDevToolsWindow() error { - hr, _, _ := i.Vtbl.OpenDevToolsWindow.Call( + + hr, _, err := i.Vtbl.OpenDevToolsWindow.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddContainsFullScreenElementChanged(eventHandler *ICoreWebView2ContainsFullScreenElementChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddContainsFullScreenElementChanged.Call( + hr, _, err := i.Vtbl.AddContainsFullScreenElementChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -815,26 +841,27 @@ func (i *ICoreWebView2) AddContainsFullScreenElementChanged(eventHandler *ICoreW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveContainsFullScreenElementChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveContainsFullScreenElementChanged.Call( + + hr, _, err := i.Vtbl.RemoveContainsFullScreenElementChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) GetContainsFullScreenElement() (bool, error) { // Create int32 to hold bool result var _containsFullScreenElement int32 - hr, _, _ := i.Vtbl.GetContainsFullScreenElement.Call( + hr, _, err := i.Vtbl.GetContainsFullScreenElement.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_containsFullScreenElement)), ) @@ -842,15 +869,15 @@ func (i *ICoreWebView2) GetContainsFullScreenElement() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - containsFullScreenElement := _containsFullScreenElement != 0 - return containsFullScreenElement, nil + containsFullScreenElement := _containsFullScreenElement != 0 + return containsFullScreenElement, err } func (i *ICoreWebView2) AddWebResourceRequested(eventHandler *ICoreWebView2WebResourceRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddWebResourceRequested.Call( + hr, _, err := i.Vtbl.AddWebResourceRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -858,19 +885,20 @@ func (i *ICoreWebView2) AddWebResourceRequested(eventHandler *ICoreWebView2WebRe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveWebResourceRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveWebResourceRequested.Call( + + hr, _, err := i.Vtbl.RemoveWebResourceRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddWebResourceRequestedFilter(uri string, resourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT) error { @@ -881,7 +909,7 @@ func (i *ICoreWebView2) AddWebResourceRequestedFilter(uri string, resourceContex return err } - hr, _, _ := i.Vtbl.AddWebResourceRequestedFilter.Call( + hr, _, err := i.Vtbl.AddWebResourceRequestedFilter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(resourceContext), @@ -889,7 +917,7 @@ func (i *ICoreWebView2) AddWebResourceRequestedFilter(uri string, resourceContex if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) RemoveWebResourceRequestedFilter(uri string, resourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT) error { @@ -900,7 +928,7 @@ func (i *ICoreWebView2) RemoveWebResourceRequestedFilter(uri string, resourceCon return err } - hr, _, _ := i.Vtbl.RemoveWebResourceRequestedFilter.Call( + hr, _, err := i.Vtbl.RemoveWebResourceRequestedFilter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(resourceContext), @@ -908,14 +936,14 @@ func (i *ICoreWebView2) RemoveWebResourceRequestedFilter(uri string, resourceCon if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2) AddWindowCloseRequested(eventHandler *ICoreWebView2WindowCloseRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddWindowCloseRequested.Call( + hr, _, err := i.Vtbl.AddWindowCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -923,17 +951,18 @@ func (i *ICoreWebView2) AddWindowCloseRequested(eventHandler *ICoreWebView2Windo if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2) RemoveWindowCloseRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveWindowCloseRequested.Call( + + hr, _, err := i.Vtbl.RemoveWindowCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go index f4f632e7a4f..ef5bd969aba 100644 --- a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go @@ -1,93 +1,98 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2AcceleratorKeyPressedEventArgsVtbl struct { IUnknownVtbl - GetKeyEventKind ComProc - GetVirtualKey ComProc - GetKeyEventLParam ComProc + GetKeyEventKind ComProc + GetVirtualKey ComProc + GetKeyEventLParam ComProc GetPhysicalKeyStatus ComProc - GetHandled ComProc - PutHandled ComProc + GetHandled ComProc + PutHandled ComProc } type ICoreWebView2AcceleratorKeyPressedEventArgs struct { Vtbl *ICoreWebView2AcceleratorKeyPressedEventArgsVtbl } -func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetKeyEventKind() (COREWEBVIEW2_KEY_EVENT_KIND, error) { var keyEventKind COREWEBVIEW2_KEY_EVENT_KIND - hr, _, _ := i.Vtbl.GetKeyEventKind.Call( + hr, _, err := i.Vtbl.GetKeyEventKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&keyEventKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return keyEventKind, nil + return keyEventKind, err } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetVirtualKey() (uint, error) { var virtualKey uint - hr, _, _ := i.Vtbl.GetVirtualKey.Call( + hr, _, err := i.Vtbl.GetVirtualKey.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&virtualKey)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return virtualKey, nil + return virtualKey, err } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetKeyEventLParam() (int, error) { var lParam int - hr, _, _ := i.Vtbl.GetKeyEventLParam.Call( + hr, _, err := i.Vtbl.GetKeyEventLParam.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&lParam)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return lParam, nil + return lParam, err } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetPhysicalKeyStatus() (COREWEBVIEW2_PHYSICAL_KEY_STATUS, error) { var physicalKeyStatus COREWEBVIEW2_PHYSICAL_KEY_STATUS - hr, _, _ := i.Vtbl.GetPhysicalKeyStatus.Call( + hr, _, err := i.Vtbl.GetPhysicalKeyStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&physicalKeyStatus)), ) if windows.Handle(hr) != windows.S_OK { return COREWEBVIEW2_PHYSICAL_KEY_STATUS{}, syscall.Errno(hr) } - return physicalKeyStatus, nil + return physicalKeyStatus, err } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _handled int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_handled)), ) @@ -95,18 +100,24 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetHandled() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - handled := _handled != 0 - return handled, nil + handled := _handled != 0 + return handled, err } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) PutHandled(handled bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _handled int32 + if handled { + _handled = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&handled)), + uintptr(_handled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go index c73c39b4957..7cf4306bbcd 100644 --- a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2AcceleratorKeyPressedEventArgs2Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2AcceleratorKeyPressedEventArgs2 struct { Vtbl *ICoreWebView2AcceleratorKeyPressedEventArgs2Vtbl } -func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2AcceleratorKeyPressedEventArgs2() *ICoreWebView2AcceleratorKeyPressedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2AcceleratorKeyPressedEventArgs2() (*ICoreWebView2AcceleratorKeyPressedEventArgs2, error) { var result *ICoreWebView2AcceleratorKeyPressedEventArgs2 iidICoreWebView2AcceleratorKeyPressedEventArgs2 := NewGUID("{03b2c8c8-7799-4e34-bd66-ed26aa85f2bf}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2AcceleratorKeyPressedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) GetIsBrowserAcceleratorKeyEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsBrowserAcceleratorKeyEnabled.Call( + hr, _, err := i.Vtbl.GetIsBrowserAcceleratorKeyEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) GetIsBrowserAcceleratorKe return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) PutIsBrowserAcceleratorKeyEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsBrowserAcceleratorKeyEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsBrowserAcceleratorKeyEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventHandler.go index 998082b6b5f..b28628492ff 100644 --- a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2AcceleratorKeyPressedEventHandler struct { impl ICoreWebView2AcceleratorKeyPressedEventHandlerImpl } -func (i *ICoreWebView2AcceleratorKeyPressedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2AcceleratorKeyPressedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2AcceleratorKeyPressedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownQueryInterface(this *ICoreWebView2AcceleratorKeyPressedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownQueryInterface(this * } func ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownAddRef(this *ICoreWebView2AcceleratorKeyPressedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownRelease(this *ICoreWebView2AcceleratorKeyPressedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2AcceleratorKeyPressedEventHandlerInvoke(this *ICoreWebView2AcceleratorKeyPressedEventHandler, sender *ICoreWebView2Controller, args *ICoreWebView2AcceleratorKeyPressedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2AcceleratorKeyPressedEventHandlerImpl interface { } var ICoreWebView2AcceleratorKeyPressedEventHandlerFn = ICoreWebView2AcceleratorKeyPressedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2AcceleratorKeyPressedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go index 1a3d86cdbe7..65117a5d739 100644 --- a/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler struct { impl ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerImpl } -func (i *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownQue } func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownAddRef(this *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownRelease(this *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerInvoke(this *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler, errorCode uintptr, result string) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerImpl interf } var ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerFn = ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go index e820b245278..6e77deca2bd 100644 --- a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go @@ -1,39 +1,45 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2BasicAuthenticationRequestedEventArgsVtbl struct { IUnknownVtbl - GetUri ComProc + GetUri ComProc GetChallenge ComProc - GetResponse ComProc - GetCancel ComProc - PutCancel ComProc - GetDeferral ComProc + GetResponse ComProc + GetCancel ComProc + PutCancel ComProc + GetDeferral ComProc } type ICoreWebView2BasicAuthenticationRequestedEventArgs struct { Vtbl *ICoreWebView2BasicAuthenticationRequestedEventArgsVtbl } -func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -41,16 +47,17 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetUri() (string, e // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetChallenge() (string, error) { // Create *uint16 to hold result var _challenge *uint16 - hr, _, _ := i.Vtbl.GetChallenge.Call( + + hr, _, err := i.Vtbl.GetChallenge.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_challenge)), + uintptr(unsafe.Pointer(&_challenge)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -58,28 +65,28 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetChallenge() (str // Get result and cleanup challenge := UTF16PtrToString(_challenge) CoTaskMemFree(unsafe.Pointer(_challenge)) - return challenge, nil + return challenge, err } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetResponse() (*ICoreWebView2BasicAuthenticationResponse, error) { var response *ICoreWebView2BasicAuthenticationResponse - hr, _, _ := i.Vtbl.GetResponse.Call( + hr, _, err := i.Vtbl.GetResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&response)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return response, nil + return response, err } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _cancel int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_cancel)), ) @@ -87,32 +94,38 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetCancel() (bool, return false, syscall.Errno(hr) } // Get result and cleanup - cancel := _cancel != 0 - return cancel, nil + cancel := _cancel != 0 + return cancel, err } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) PutCancel(cancel bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _cancel int32 + if cancel { + _cancel = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&cancel)), + uintptr(_cancel), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventHandler.go index 7c4a263d811..f8f6f2beccf 100644 --- a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2BasicAuthenticationRequestedEventHandler struct { impl ICoreWebView2BasicAuthenticationRequestedEventHandlerImpl } -func (i *ICoreWebView2BasicAuthenticationRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2BasicAuthenticationRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BasicAuthenticationRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2BasicAuthenticationRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownQueryInterface } func ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2BasicAuthenticationRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownRelease(this *ICoreWebView2BasicAuthenticationRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2BasicAuthenticationRequestedEventHandlerInvoke(this *ICoreWebView2BasicAuthenticationRequestedEventHandler, sender *ICoreWebView2, args *ICoreWebView2BasicAuthenticationRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2BasicAuthenticationRequestedEventHandlerImpl interface { } var ICoreWebView2BasicAuthenticationRequestedEventHandlerFn = ICoreWebView2BasicAuthenticationRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2BasicAuthenticationRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go index 2a5f98097f0..d19eaec3091 100644 --- a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go +++ b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2BasicAuthenticationResponseVtbl struct { @@ -20,18 +19,25 @@ type ICoreWebView2BasicAuthenticationResponse struct { Vtbl *ICoreWebView2BasicAuthenticationResponseVtbl } -func (i *ICoreWebView2BasicAuthenticationResponse) AddRef() uintptr { +func (i *ICoreWebView2BasicAuthenticationResponse) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BasicAuthenticationResponse) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2BasicAuthenticationResponse) GetUserName() (string, error) { // Create *uint16 to hold result var _userName *uint16 - hr, _, _ := i.Vtbl.GetUserName.Call( + + hr, _, err := i.Vtbl.GetUserName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_userName)), + uintptr(unsafe.Pointer(&_userName)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -39,7 +45,7 @@ func (i *ICoreWebView2BasicAuthenticationResponse) GetUserName() (string, error) // Get result and cleanup userName := UTF16PtrToString(_userName) CoTaskMemFree(unsafe.Pointer(_userName)) - return userName, nil + return userName, err } func (i *ICoreWebView2BasicAuthenticationResponse) PutUserName(userName string) error { @@ -50,23 +56,24 @@ func (i *ICoreWebView2BasicAuthenticationResponse) PutUserName(userName string) return err } - hr, _, _ := i.Vtbl.PutUserName.Call( + hr, _, err := i.Vtbl.PutUserName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_userName)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2BasicAuthenticationResponse) GetPassword() (string, error) { // Create *uint16 to hold result var _password *uint16 - hr, _, _ := i.Vtbl.GetPassword.Call( + + hr, _, err := i.Vtbl.GetPassword.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_password)), + uintptr(unsafe.Pointer(&_password)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -74,7 +81,7 @@ func (i *ICoreWebView2BasicAuthenticationResponse) GetPassword() (string, error) // Get result and cleanup password := UTF16PtrToString(_password) CoTaskMemFree(unsafe.Pointer(_password)) - return password, nil + return password, err } func (i *ICoreWebView2BasicAuthenticationResponse) PutPassword(password string) error { @@ -85,12 +92,12 @@ func (i *ICoreWebView2BasicAuthenticationResponse) PutPassword(password string) return err } - hr, _, _ := i.Vtbl.PutPassword.Call( + hr, _, err := i.Vtbl.PutPassword.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_password)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go b/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go index 29cf1cbf5c0..0a37fec38a3 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go @@ -1,38 +1,44 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2BrowserExtensionVtbl struct { IUnknownVtbl - GetId ComProc - GetName ComProc - Remove ComProc + GetId ComProc + GetName ComProc + Remove ComProc GetIsEnabled ComProc - Enable ComProc + Enable ComProc } type ICoreWebView2BrowserExtension struct { Vtbl *ICoreWebView2BrowserExtensionVtbl } -func (i *ICoreWebView2BrowserExtension) AddRef() uintptr { +func (i *ICoreWebView2BrowserExtension) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BrowserExtension) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2BrowserExtension) GetId() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetId.Call( + + hr, _, err := i.Vtbl.GetId.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -40,16 +46,17 @@ func (i *ICoreWebView2BrowserExtension) GetId() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2BrowserExtension) GetName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -57,26 +64,27 @@ func (i *ICoreWebView2BrowserExtension) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2BrowserExtension) Remove(handler *ICoreWebView2BrowserExtensionRemoveCompletedHandler) error { - hr, _, _ := i.Vtbl.Remove.Call( + + hr, _, err := i.Vtbl.Remove.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2BrowserExtension) GetIsEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsEnabled.Call( + hr, _, err := i.Vtbl.GetIsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -84,19 +92,25 @@ func (i *ICoreWebView2BrowserExtension) GetIsEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2BrowserExtension) Enable(isEnabled bool, handler *ICoreWebView2BrowserExtensionEnableCompletedHandler) error { - hr, _, _ := i.Vtbl.Enable.Call( + // Convert Go bool to COM BOOL (int32) + var _isEnabled int32 + if isEnabled { + _isEnabled = 1 + } + + hr, _, err := i.Vtbl.Enable.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isEnabled)), + uintptr(_isEnabled), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionEnableCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionEnableCompletedHandler.go index da71b07ace3..c504dbd8237 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionEnableCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionEnableCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2BrowserExtensionEnableCompletedHandler struct { impl ICoreWebView2BrowserExtensionEnableCompletedHandlerImpl } -func (i *ICoreWebView2BrowserExtensionEnableCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2BrowserExtensionEnableCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BrowserExtensionEnableCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2BrowserExtensionEnableCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownQueryInterface(t } func ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownAddRef(this *ICoreWebView2BrowserExtensionEnableCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownRelease(this *ICoreWebView2BrowserExtensionEnableCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2BrowserExtensionEnableCompletedHandlerInvoke(this *ICoreWebView2BrowserExtensionEnableCompletedHandler, errorCode uintptr) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2BrowserExtensionEnableCompletedHandlerImpl interface { } var ICoreWebView2BrowserExtensionEnableCompletedHandlerFn = ICoreWebView2BrowserExtensionEnableCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2BrowserExtensionEnableCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go index fb82c947c7f..1af677cac52 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2BrowserExtensionListVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2BrowserExtensionList struct { Vtbl *ICoreWebView2BrowserExtensionListVtbl } -func (i *ICoreWebView2BrowserExtensionList) AddRef() uintptr { +func (i *ICoreWebView2BrowserExtensionList) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BrowserExtensionList) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2BrowserExtensionList) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2BrowserExtensionList) GetValueAtIndex(index uint32) (*ICoreWebView2BrowserExtension, error) { var value *ICoreWebView2BrowserExtension - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionRemoveCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionRemoveCompletedHandler.go index efc23156a4c..e7841f70ed4 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionRemoveCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionRemoveCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2BrowserExtensionRemoveCompletedHandler struct { impl ICoreWebView2BrowserExtensionRemoveCompletedHandlerImpl } -func (i *ICoreWebView2BrowserExtensionRemoveCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2BrowserExtensionRemoveCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BrowserExtensionRemoveCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2BrowserExtensionRemoveCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownQueryInterface(t } func ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownAddRef(this *ICoreWebView2BrowserExtensionRemoveCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownRelease(this *ICoreWebView2BrowserExtensionRemoveCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2BrowserExtensionRemoveCompletedHandlerInvoke(this *ICoreWebView2BrowserExtensionRemoveCompletedHandler, errorCode uintptr) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2BrowserExtensionRemoveCompletedHandlerImpl interface { } var ICoreWebView2BrowserExtensionRemoveCompletedHandlerFn = ICoreWebView2BrowserExtensionRemoveCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2BrowserExtensionRemoveCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go index 239d9df4bd4..e91b3a0b266 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go @@ -1,52 +1,57 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2BrowserProcessExitedEventArgsVtbl struct { IUnknownVtbl GetBrowserProcessExitKind ComProc - GetBrowserProcessId ComProc + GetBrowserProcessId ComProc } type ICoreWebView2BrowserProcessExitedEventArgs struct { Vtbl *ICoreWebView2BrowserProcessExitedEventArgsVtbl } -func (i *ICoreWebView2BrowserProcessExitedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2BrowserProcessExitedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BrowserProcessExitedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2BrowserProcessExitedEventArgs) GetBrowserProcessExitKind() (COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND, error) { var value COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND - hr, _, _ := i.Vtbl.GetBrowserProcessExitKind.Call( + hr, _, err := i.Vtbl.GetBrowserProcessExitKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2BrowserProcessExitedEventArgs) GetBrowserProcessId() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetBrowserProcessId.Call( + hr, _, err := i.Vtbl.GetBrowserProcessId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventHandler.go index b78b370dc58..593ce5e19b8 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2BrowserProcessExitedEventHandler struct { impl ICoreWebView2BrowserProcessExitedEventHandlerImpl } -func (i *ICoreWebView2BrowserProcessExitedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2BrowserProcessExitedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BrowserProcessExitedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2BrowserProcessExitedEventHandlerIUnknownQueryInterface(this *ICoreWebView2BrowserProcessExitedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2BrowserProcessExitedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2BrowserProcessExitedEventHandlerIUnknownAddRef(this *ICoreWebView2BrowserProcessExitedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2BrowserProcessExitedEventHandlerIUnknownRelease(this *ICoreWebView2BrowserProcessExitedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2BrowserProcessExitedEventHandlerInvoke(this *ICoreWebView2BrowserProcessExitedEventHandler, sender *ICoreWebView2Environment, args *ICoreWebView2BrowserProcessExitedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2BrowserProcessExitedEventHandlerImpl interface { } var ICoreWebView2BrowserProcessExitedEventHandlerFn = ICoreWebView2BrowserProcessExitedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2BrowserProcessExitedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2BrowserProcessExitedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2BrowserProcessExitedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2BytesReceivedChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2BytesReceivedChangedEventHandler.go index 14235fa98ab..99bbf726289 100644 --- a/webview2/pkg/webview2/ICoreWebView2BytesReceivedChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2BytesReceivedChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2BytesReceivedChangedEventHandler struct { impl ICoreWebView2BytesReceivedChangedEventHandlerImpl } -func (i *ICoreWebView2BytesReceivedChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2BytesReceivedChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2BytesReceivedChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2BytesReceivedChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2BytesReceivedChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2BytesReceivedChangedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2BytesReceivedChangedEventHandlerIUnknownAddRef(this *ICoreWebView2BytesReceivedChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2BytesReceivedChangedEventHandlerIUnknownRelease(this *ICoreWebView2BytesReceivedChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2BytesReceivedChangedEventHandlerInvoke(this *ICoreWebView2BytesReceivedChangedEventHandler, sender *ICoreWebView2DownloadOperation, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2BytesReceivedChangedEventHandlerImpl interface { } var ICoreWebView2BytesReceivedChangedEventHandlerFn = ICoreWebView2BytesReceivedChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2BytesReceivedChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2BytesReceivedChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2BytesReceivedChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go index 95e171416c6..74b0efcfdef 100644 --- a/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CallDevToolsProtocolMethodCompletedHandler struct { impl ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerImpl } -func (i *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownQueryInterfa } func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownAddRef(this *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownRelease(this *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerInvoke(this *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler, errorCode uintptr, result string) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerImpl interface { } var ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerFn = ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CapturePreviewCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2CapturePreviewCompletedHandler.go index 89f1841986f..1e40f21a543 100644 --- a/webview2/pkg/webview2/ICoreWebView2CapturePreviewCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CapturePreviewCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CapturePreviewCompletedHandler struct { impl ICoreWebView2CapturePreviewCompletedHandlerImpl } -func (i *ICoreWebView2CapturePreviewCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2CapturePreviewCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CapturePreviewCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CapturePreviewCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2CapturePreviewCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CapturePreviewCompletedHandlerIUnknownQueryInterface(this *ICo } func ICoreWebView2CapturePreviewCompletedHandlerIUnknownAddRef(this *ICoreWebView2CapturePreviewCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CapturePreviewCompletedHandlerIUnknownRelease(this *ICoreWebView2CapturePreviewCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CapturePreviewCompletedHandlerInvoke(this *ICoreWebView2CapturePreviewCompletedHandler, errorCode uintptr) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CapturePreviewCompletedHandlerImpl interface { } var ICoreWebView2CapturePreviewCompletedHandlerFn = ICoreWebView2CapturePreviewCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CapturePreviewCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CapturePreviewCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2CapturePreviewCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Certificate.go b/webview2/pkg/webview2/ICoreWebView2Certificate.go index 6ca1d4e88c0..8c24efa699d 100644 --- a/webview2/pkg/webview2/ICoreWebView2Certificate.go +++ b/webview2/pkg/webview2/ICoreWebView2Certificate.go @@ -1,22 +1,21 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CertificateVtbl struct { IUnknownVtbl - GetSubject ComProc - GetIssuer ComProc - GetValidFrom ComProc - GetValidTo ComProc - GetDerEncodedSerialNumber ComProc - GetDisplayName ComProc - ToPemEncoding ComProc + GetSubject ComProc + GetIssuer ComProc + GetValidFrom ComProc + GetValidTo ComProc + GetDerEncodedSerialNumber ComProc + GetDisplayName ComProc + ToPemEncoding ComProc GetPemEncodedIssuerCertificateChain ComProc } @@ -24,18 +23,25 @@ type ICoreWebView2Certificate struct { Vtbl *ICoreWebView2CertificateVtbl } -func (i *ICoreWebView2Certificate) AddRef() uintptr { +func (i *ICoreWebView2Certificate) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Certificate) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2Certificate) GetSubject() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSubject.Call( + + hr, _, err := i.Vtbl.GetSubject.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -43,16 +49,17 @@ func (i *ICoreWebView2Certificate) GetSubject() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Certificate) GetIssuer() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetIssuer.Call( + + hr, _, err := i.Vtbl.GetIssuer.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -60,44 +67,45 @@ func (i *ICoreWebView2Certificate) GetIssuer() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Certificate) GetValidFrom() (float64, error) { var value float64 - hr, _, _ := i.Vtbl.GetValidFrom.Call( + hr, _, err := i.Vtbl.GetValidFrom.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Certificate) GetValidTo() (float64, error) { var value float64 - hr, _, _ := i.Vtbl.GetValidTo.Call( + hr, _, err := i.Vtbl.GetValidTo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Certificate) GetDerEncodedSerialNumber() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetDerEncodedSerialNumber.Call( + + hr, _, err := i.Vtbl.GetDerEncodedSerialNumber.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -105,16 +113,17 @@ func (i *ICoreWebView2Certificate) GetDerEncodedSerialNumber() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Certificate) GetDisplayName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetDisplayName.Call( + + hr, _, err := i.Vtbl.GetDisplayName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -122,16 +131,17 @@ func (i *ICoreWebView2Certificate) GetDisplayName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Certificate) ToPemEncoding() (string, error) { // Create *uint16 to hold result var _pemEncodedData *uint16 - hr, _, _ := i.Vtbl.ToPemEncoding.Call( + + hr, _, err := i.Vtbl.ToPemEncoding.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_pemEncodedData)), + uintptr(unsafe.Pointer(&_pemEncodedData)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -139,19 +149,19 @@ func (i *ICoreWebView2Certificate) ToPemEncoding() (string, error) { // Get result and cleanup pemEncodedData := UTF16PtrToString(_pemEncodedData) CoTaskMemFree(unsafe.Pointer(_pemEncodedData)) - return pemEncodedData, nil + return pemEncodedData, err } func (i *ICoreWebView2Certificate) GetPemEncodedIssuerCertificateChain() (*ICoreWebView2StringCollection, error) { var value *ICoreWebView2StringCollection - hr, _, _ := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( + hr, _, err := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ClearBrowsingDataCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ClearBrowsingDataCompletedHandler.go index ede6e288491..a7eaa939f2d 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClearBrowsingDataCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ClearBrowsingDataCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ClearBrowsingDataCompletedHandler struct { impl ICoreWebView2ClearBrowsingDataCompletedHandlerImpl } -func (i *ICoreWebView2ClearBrowsingDataCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ClearBrowsingDataCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ClearBrowsingDataCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ClearBrowsingDataCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownQueryInterface(this * } func ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownAddRef(this *ICoreWebView2ClearBrowsingDataCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownRelease(this *ICoreWebView2ClearBrowsingDataCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ClearBrowsingDataCompletedHandlerInvoke(this *ICoreWebView2ClearBrowsingDataCompletedHandler, errorCode uintptr) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ClearBrowsingDataCompletedHandlerImpl interface { } var ICoreWebView2ClearBrowsingDataCompletedHandlerFn = ICoreWebView2ClearBrowsingDataCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ClearBrowsingDataCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler.go index 7652c71162c..3c1dbeb745e 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler struct { impl ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerImpl } -func (i *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownQuer } func ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownAddRef(this *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownRelease(this *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerInvoke(this *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler, errorCode uintptr) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerImpl interfa } var ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerFn = ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ClearServerCertificateErrorActionsCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go index 6d2dc6b8015..7b7dceb2d25 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go @@ -1,42 +1,48 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ClientCertificateVtbl struct { IUnknownVtbl - GetSubject ComProc - GetIssuer ComProc - GetValidFrom ComProc - GetValidTo ComProc - GetDerEncodedSerialNumber ComProc - GetDisplayName ComProc - ToPemEncoding ComProc + GetSubject ComProc + GetIssuer ComProc + GetValidFrom ComProc + GetValidTo ComProc + GetDerEncodedSerialNumber ComProc + GetDisplayName ComProc + ToPemEncoding ComProc GetPemEncodedIssuerCertificateChain ComProc - GetKind ComProc + GetKind ComProc } type ICoreWebView2ClientCertificate struct { Vtbl *ICoreWebView2ClientCertificateVtbl } -func (i *ICoreWebView2ClientCertificate) AddRef() uintptr { +func (i *ICoreWebView2ClientCertificate) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ClientCertificate) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ClientCertificate) GetSubject() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSubject.Call( + + hr, _, err := i.Vtbl.GetSubject.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -44,16 +50,17 @@ func (i *ICoreWebView2ClientCertificate) GetSubject() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) GetIssuer() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetIssuer.Call( + + hr, _, err := i.Vtbl.GetIssuer.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -61,44 +68,45 @@ func (i *ICoreWebView2ClientCertificate) GetIssuer() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) GetValidFrom() (float64, error) { var value float64 - hr, _, _ := i.Vtbl.GetValidFrom.Call( + hr, _, err := i.Vtbl.GetValidFrom.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) GetValidTo() (float64, error) { var value float64 - hr, _, _ := i.Vtbl.GetValidTo.Call( + hr, _, err := i.Vtbl.GetValidTo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) GetDerEncodedSerialNumber() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetDerEncodedSerialNumber.Call( + + hr, _, err := i.Vtbl.GetDerEncodedSerialNumber.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -106,16 +114,17 @@ func (i *ICoreWebView2ClientCertificate) GetDerEncodedSerialNumber() (string, er // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) GetDisplayName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetDisplayName.Call( + + hr, _, err := i.Vtbl.GetDisplayName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -123,16 +132,17 @@ func (i *ICoreWebView2ClientCertificate) GetDisplayName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) ToPemEncoding() (string, error) { // Create *uint16 to hold result var _pemEncodedData *uint16 - hr, _, _ := i.Vtbl.ToPemEncoding.Call( + + hr, _, err := i.Vtbl.ToPemEncoding.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_pemEncodedData)), + uintptr(unsafe.Pointer(&_pemEncodedData)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -140,33 +150,33 @@ func (i *ICoreWebView2ClientCertificate) ToPemEncoding() (string, error) { // Get result and cleanup pemEncodedData := UTF16PtrToString(_pemEncodedData) CoTaskMemFree(unsafe.Pointer(_pemEncodedData)) - return pemEncodedData, nil + return pemEncodedData, err } func (i *ICoreWebView2ClientCertificate) GetPemEncodedIssuerCertificateChain() (*ICoreWebView2StringCollection, error) { var value *ICoreWebView2StringCollection - hr, _, _ := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( + hr, _, err := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificate) GetKind() (COREWEBVIEW2_CLIENT_CERTIFICATE_KIND, error) { var value COREWEBVIEW2_CLIENT_CERTIFICATE_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go index d41339409c6..1bb71a0d562 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ClientCertificateCollectionVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2ClientCertificateCollection struct { Vtbl *ICoreWebView2ClientCertificateCollectionVtbl } -func (i *ICoreWebView2ClientCertificateCollection) AddRef() uintptr { +func (i *ICoreWebView2ClientCertificateCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ClientCertificateCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ClientCertificateCollection) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificateCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ClientCertificate, error) { var value *ICoreWebView2ClientCertificate - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go index d0a2fde0c27..3b714b942ba 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go @@ -1,45 +1,51 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ClientCertificateRequestedEventArgsVtbl struct { IUnknownVtbl - GetHost ComProc - GetPort ComProc - GetIsProxy ComProc + GetHost ComProc + GetPort ComProc + GetIsProxy ComProc GetAllowedCertificateAuthorities ComProc - GetMutuallyTrustedCertificates ComProc - GetSelectedCertificate ComProc - PutSelectedCertificate ComProc - GetCancel ComProc - PutCancel ComProc - GetHandled ComProc - PutHandled ComProc - GetDeferral ComProc + GetMutuallyTrustedCertificates ComProc + GetSelectedCertificate ComProc + PutSelectedCertificate ComProc + GetCancel ComProc + PutCancel ComProc + GetHandled ComProc + PutHandled ComProc + GetDeferral ComProc } type ICoreWebView2ClientCertificateRequestedEventArgs struct { Vtbl *ICoreWebView2ClientCertificateRequestedEventArgsVtbl } -func (i *ICoreWebView2ClientCertificateRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ClientCertificateRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2ClientCertificateRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHost() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetHost.Call( + + hr, _, err := i.Vtbl.GetHost.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -47,28 +53,28 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHost() (string, er // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetPort() (int, error) { var value int - hr, _, _ := i.Vtbl.GetPort.Call( + hr, _, err := i.Vtbl.GetPort.Call( uintptr(unsafe.Pointer(i)), - uintptr(value), + uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetIsProxy() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsProxy.Call( + hr, _, err := i.Vtbl.GetIsProxy.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -76,69 +82,70 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetIsProxy() (bool, e return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetAllowedCertificateAuthorities() (*ICoreWebView2StringCollection, error) { var value *ICoreWebView2StringCollection - hr, _, _ := i.Vtbl.GetAllowedCertificateAuthorities.Call( + hr, _, err := i.Vtbl.GetAllowedCertificateAuthorities.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetMutuallyTrustedCertificates() (*ICoreWebView2ClientCertificateCollection, error) { var value *ICoreWebView2ClientCertificateCollection - hr, _, _ := i.Vtbl.GetMutuallyTrustedCertificates.Call( + hr, _, err := i.Vtbl.GetMutuallyTrustedCertificates.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetSelectedCertificate() (*ICoreWebView2ClientCertificate, error) { var value *ICoreWebView2ClientCertificate - hr, _, _ := i.Vtbl.GetSelectedCertificate.Call( + hr, _, err := i.Vtbl.GetSelectedCertificate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutSelectedCertificate(value *ICoreWebView2ClientCertificate) error { - hr, _, _ := i.Vtbl.PutSelectedCertificate.Call( + + hr, _, err := i.Vtbl.PutSelectedCertificate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -146,27 +153,33 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetCancel() (bool, er return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutCancel(value bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -174,32 +187,38 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHandled() (bool, e return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutHandled(value bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventHandler.go index 451d9520888..74f22e4af2a 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ClientCertificateRequestedEventHandler struct { impl ICoreWebView2ClientCertificateRequestedEventHandlerImpl } -func (i *ICoreWebView2ClientCertificateRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ClientCertificateRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ClientCertificateRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ClientCertificateRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownQueryInterface(t } func ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2ClientCertificateRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownRelease(this *ICoreWebView2ClientCertificateRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ClientCertificateRequestedEventHandlerInvoke(this *ICoreWebView2ClientCertificateRequestedEventHandler, sender *ICoreWebView2, args *ICoreWebView2ClientCertificateRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ClientCertificateRequestedEventHandlerImpl interface { } var ICoreWebView2ClientCertificateRequestedEventHandlerFn = ICoreWebView2ClientCertificateRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ClientCertificateRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController.go b/webview2/pkg/webview2/ICoreWebView2CompositionController.go index ff07e6b26fc..1b0c724f47b 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController.go @@ -1,22 +1,21 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CompositionControllerVtbl struct { IUnknownVtbl GetRootVisualTarget ComProc PutRootVisualTarget ComProc - SendMouseInput ComProc - SendPointerInput ComProc - GetCursor ComProc - GetSystemCursorId ComProc - AddCursorChanged ComProc + SendMouseInput ComProc + SendPointerInput ComProc + GetCursor ComProc + GetSystemCursorId ComProc + AddCursorChanged ComProc RemoveCursorChanged ComProc } @@ -24,55 +23,64 @@ type ICoreWebView2CompositionController struct { Vtbl *ICoreWebView2CompositionControllerVtbl } -func (i *ICoreWebView2CompositionController) AddRef() uintptr { +func (i *ICoreWebView2CompositionController) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CompositionController) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2CompositionController) GetRootVisualTarget() (*IUnknown, error) { var target *IUnknown - hr, _, _ := i.Vtbl.GetRootVisualTarget.Call( + hr, _, err := i.Vtbl.GetRootVisualTarget.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&target)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return target, nil + return target, err } func (i *ICoreWebView2CompositionController) PutRootVisualTarget(target *IUnknown) error { - hr, _, _ := i.Vtbl.PutRootVisualTarget.Call( + + hr, _, err := i.Vtbl.PutRootVisualTarget.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(target)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CompositionController) SendMouseInput(eventKind COREWEBVIEW2_MOUSE_EVENT_KIND, virtualKeys COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS, mouseData uint32, point POINT) error { - hr, _, _ := i.Vtbl.SendMouseInput.Call( + + hr, _, err := i.Vtbl.SendMouseInput.Call( uintptr(unsafe.Pointer(i)), uintptr(eventKind), uintptr(virtualKeys), - uintptr(unsafe.Pointer(&mouseData)), + uintptr(mouseData), uintptr(unsafe.Pointer(&point)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CompositionController) SendPointerInput(eventKind COREWEBVIEW2_POINTER_EVENT_KIND, pointerInfo *ICoreWebView2PointerInfo) error { - hr, _, _ := i.Vtbl.SendPointerInput.Call( + + hr, _, err := i.Vtbl.SendPointerInput.Call( uintptr(unsafe.Pointer(i)), uintptr(eventKind), uintptr(unsafe.Pointer(pointerInfo)), @@ -80,42 +88,42 @@ func (i *ICoreWebView2CompositionController) SendPointerInput(eventKind COREWEBV if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CompositionController) GetCursor() (HCURSOR, error) { var cursor HCURSOR - hr, _, _ := i.Vtbl.GetCursor.Call( + hr, _, err := i.Vtbl.GetCursor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&cursor)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return cursor, nil + return cursor, err } func (i *ICoreWebView2CompositionController) GetSystemCursorId() (uint32, error) { var systemCursorId uint32 - hr, _, _ := i.Vtbl.GetSystemCursorId.Call( + hr, _, err := i.Vtbl.GetSystemCursorId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&systemCursorId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return systemCursorId, nil + return systemCursorId, err } func (i *ICoreWebView2CompositionController) AddCursorChanged(eventHandler *ICoreWebView2CursorChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddCursorChanged.Call( + hr, _, err := i.Vtbl.AddCursorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -123,17 +131,18 @@ func (i *ICoreWebView2CompositionController) AddCursorChanged(eventHandler *ICor if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2CompositionController) RemoveCursorChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveCursorChanged.Call( + + hr, _, err := i.Vtbl.RemoveCursorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController2.go b/webview2/pkg/webview2/ICoreWebView2CompositionController2.go index dadefc5e4ec..72d204afa3f 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController2.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CompositionController2Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2CompositionController2 struct { Vtbl *ICoreWebView2CompositionController2Vtbl } -func (i *ICoreWebView2CompositionController2) AddRef() uintptr { +func (i *ICoreWebView2CompositionController2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CompositionController2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2CompositionController2() *ICoreWebView2CompositionController2 { + +func (i *ICoreWebView2) GetICoreWebView2CompositionController2() (*ICoreWebView2CompositionController2, error) { var result *ICoreWebView2CompositionController2 iidICoreWebView2CompositionController2 := NewGUID("{0b6a3d24-49cb-4806-ba20-b5e0734a7b26}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2CompositionController2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2CompositionController2) GetAutomationProvider() (*IUnknown, error) { var value *IUnknown - hr, _, _ := i.Vtbl.GetAutomationProvider.Call( + hr, _, err := i.Vtbl.GetAutomationProvider.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController3.go b/webview2/pkg/webview2/ICoreWebView2CompositionController3.go index 713e89d60ae..a7e38f35e9f 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController3.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController3.go @@ -1,99 +1,108 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CompositionController3Vtbl struct { IUnknownVtbl DragEnter ComProc DragLeave ComProc - DragOver ComProc - Drop ComProc + DragOver ComProc + Drop ComProc } type ICoreWebView2CompositionController3 struct { Vtbl *ICoreWebView2CompositionController3Vtbl } -func (i *ICoreWebView2CompositionController3) AddRef() uintptr { +func (i *ICoreWebView2CompositionController3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CompositionController3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2CompositionController3() *ICoreWebView2CompositionController3 { + +func (i *ICoreWebView2) GetICoreWebView2CompositionController3() (*ICoreWebView2CompositionController3, error) { var result *ICoreWebView2CompositionController3 iidICoreWebView2CompositionController3 := NewGUID("{9570570e-4d76-4361-9ee1-f04d0dbdfb1e}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2CompositionController3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2CompositionController3) DragEnter(dataObject *IDataObject, keyState uint32, point POINT) (uint32, error) { var effect uint32 - hr, _, _ := i.Vtbl.DragEnter.Call( + hr, _, err := i.Vtbl.DragEnter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(dataObject)), - uintptr(unsafe.Pointer(&keyState)), + uintptr(keyState), uintptr(unsafe.Pointer(&point)), uintptr(unsafe.Pointer(&effect)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return effect, nil + return effect, err } func (i *ICoreWebView2CompositionController3) DragLeave() error { - hr, _, _ := i.Vtbl.DragLeave.Call( + + hr, _, err := i.Vtbl.DragLeave.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CompositionController3) DragOver(keyState uint32, point POINT) (uint32, error) { var effect uint32 - hr, _, _ := i.Vtbl.DragOver.Call( + hr, _, err := i.Vtbl.DragOver.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&keyState)), + uintptr(keyState), uintptr(unsafe.Pointer(&point)), uintptr(unsafe.Pointer(&effect)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return effect, nil + return effect, err } func (i *ICoreWebView2CompositionController3) Drop(dataObject *IDataObject, keyState uint32, point POINT) (uint32, error) { var effect uint32 - hr, _, _ := i.Vtbl.Drop.Call( + hr, _, err := i.Vtbl.Drop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(dataObject)), - uintptr(unsafe.Pointer(&keyState)), + uintptr(keyState), uintptr(unsafe.Pointer(&point)), uintptr(unsafe.Pointer(&effect)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return effect, nil + return effect, err } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController4.go b/webview2/pkg/webview2/ICoreWebView2CompositionController4.go index 68531456b75..bbdb1832c14 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController4.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController4.go @@ -1,18 +1,17 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CompositionController4Vtbl struct { IUnknownVtbl - GetNonClientRegionAtPoint ComProc - QueryNonClientRegion ComProc - AddNonClientRegionChanged ComProc + GetNonClientRegionAtPoint ComProc + QueryNonClientRegion ComProc + AddNonClientRegionChanged ComProc RemoveNonClientRegionChanged ComProc } @@ -20,28 +19,37 @@ type ICoreWebView2CompositionController4 struct { Vtbl *ICoreWebView2CompositionController4Vtbl } -func (i *ICoreWebView2CompositionController4) AddRef() uintptr { +func (i *ICoreWebView2CompositionController4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CompositionController4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2CompositionController4() *ICoreWebView2CompositionController4 { + +func (i *ICoreWebView2) GetICoreWebView2CompositionController4() (*ICoreWebView2CompositionController4, error) { var result *ICoreWebView2CompositionController4 iidICoreWebView2CompositionController4 := NewGUID("{7C367B9B-3D2B-450F-9E58-D61A20F486AA}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2CompositionController4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2CompositionController4) GetNonClientRegionAtPoint(point POINT) (COREWEBVIEW2_NON_CLIENT_REGION_KIND, error) { var value COREWEBVIEW2_NON_CLIENT_REGION_KIND - hr, _, _ := i.Vtbl.GetNonClientRegionAtPoint.Call( + hr, _, err := i.Vtbl.GetNonClientRegionAtPoint.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&point)), uintptr(unsafe.Pointer(&value)), @@ -49,14 +57,14 @@ func (i *ICoreWebView2CompositionController4) GetNonClientRegionAtPoint(point PO if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2CompositionController4) QueryNonClientRegion(kind COREWEBVIEW2_NON_CLIENT_REGION_KIND) (*ICoreWebView2RegionRectCollectionView, error) { var rects *ICoreWebView2RegionRectCollectionView - hr, _, _ := i.Vtbl.QueryNonClientRegion.Call( + hr, _, err := i.Vtbl.QueryNonClientRegion.Call( uintptr(unsafe.Pointer(i)), uintptr(kind), uintptr(unsafe.Pointer(&rects)), @@ -64,14 +72,14 @@ func (i *ICoreWebView2CompositionController4) QueryNonClientRegion(kind COREWEBV if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return rects, nil + return rects, err } func (i *ICoreWebView2CompositionController4) AddNonClientRegionChanged(eventHandler *ICoreWebView2NonClientRegionChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNonClientRegionChanged.Call( + hr, _, err := i.Vtbl.AddNonClientRegionChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -79,17 +87,18 @@ func (i *ICoreWebView2CompositionController4) AddNonClientRegionChanged(eventHan if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2CompositionController4) RemoveNonClientRegionChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNonClientRegionChanged.Call( + + hr, _, err := i.Vtbl.RemoveNonClientRegionChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ContainsFullScreenElementChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ContainsFullScreenElementChangedEventHandler.go index 5a773894eb1..4255caa2fb6 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContainsFullScreenElementChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ContainsFullScreenElementChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ContainsFullScreenElementChangedEventHandler struct { impl ICoreWebView2ContainsFullScreenElementChangedEventHandlerImpl } -func (i *ICoreWebView2ContainsFullScreenElementChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ContainsFullScreenElementChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ContainsFullScreenElementChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ContainsFullScreenElementChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownQueryInter } func ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownAddRef(this *ICoreWebView2ContainsFullScreenElementChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownRelease(this *ICoreWebView2ContainsFullScreenElementChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ContainsFullScreenElementChangedEventHandlerInvoke(this *ICoreWebView2ContainsFullScreenElementChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ContainsFullScreenElementChangedEventHandlerImpl interface { } var ICoreWebView2ContainsFullScreenElementChangedEventHandlerFn = ICoreWebView2ContainsFullScreenElementChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ContainsFullScreenElementChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go index 44f0326c4f9..fb5326ac6d6 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ContentLoadingEventArgsVtbl struct { IUnknownVtbl - GetIsErrorPage ComProc + GetIsErrorPage ComProc GetNavigationId ComProc } @@ -18,16 +17,22 @@ type ICoreWebView2ContentLoadingEventArgs struct { Vtbl *ICoreWebView2ContentLoadingEventArgsVtbl } -func (i *ICoreWebView2ContentLoadingEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ContentLoadingEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ContentLoadingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ContentLoadingEventArgs) GetIsErrorPage() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsErrorPage.Call( + hr, _, err := i.Vtbl.GetIsErrorPage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -35,20 +40,20 @@ func (i *ICoreWebView2ContentLoadingEventArgs) GetIsErrorPage() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContentLoadingEventArgs) GetNavigationId() (uint64, error) { var value uint64 - hr, _, _ := i.Vtbl.GetNavigationId.Call( + hr, _, err := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventHandler.go index 765ddd61108..505be731f2b 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ContentLoadingEventHandler struct { impl ICoreWebView2ContentLoadingEventHandlerImpl } -func (i *ICoreWebView2ContentLoadingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ContentLoadingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ContentLoadingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ContentLoadingEventHandlerIUnknownQueryInterface(this *ICoreWebView2ContentLoadingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ContentLoadingEventHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2ContentLoadingEventHandlerIUnknownAddRef(this *ICoreWebView2ContentLoadingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ContentLoadingEventHandlerIUnknownRelease(this *ICoreWebView2ContentLoadingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ContentLoadingEventHandlerInvoke(this *ICoreWebView2ContentLoadingEventHandler, sender *ICoreWebView2, args *ICoreWebView2ContentLoadingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ContentLoadingEventHandlerImpl interface { } var ICoreWebView2ContentLoadingEventHandlerFn = ICoreWebView2ContentLoadingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ContentLoadingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ContentLoadingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ContentLoadingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go index 525c6b6dc0e..cad243e32cc 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go @@ -1,46 +1,52 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ContextMenuItemVtbl struct { IUnknownVtbl - GetName ComProc - GetLabel ComProc - GetCommandId ComProc + GetName ComProc + GetLabel ComProc + GetCommandId ComProc GetShortcutKeyDescription ComProc - GetIcon ComProc - GetKind ComProc - PutIsEnabled ComProc - GetIsEnabled ComProc - PutIsChecked ComProc - GetIsChecked ComProc - GetChildren ComProc - AddCustomItemSelected ComProc - RemoveCustomItemSelected ComProc + GetIcon ComProc + GetKind ComProc + PutIsEnabled ComProc + GetIsEnabled ComProc + PutIsChecked ComProc + GetIsChecked ComProc + GetChildren ComProc + AddCustomItemSelected ComProc + RemoveCustomItemSelected ComProc } type ICoreWebView2ContextMenuItem struct { Vtbl *ICoreWebView2ContextMenuItemVtbl } -func (i *ICoreWebView2ContextMenuItem) AddRef() uintptr { +func (i *ICoreWebView2ContextMenuItem) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ContextMenuItem) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ContextMenuItem) GetName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,16 +54,17 @@ func (i *ICoreWebView2ContextMenuItem) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) GetLabel() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetLabel.Call( + + hr, _, err := i.Vtbl.GetLabel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -65,30 +72,31 @@ func (i *ICoreWebView2ContextMenuItem) GetLabel() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) GetCommandId() (int32, error) { var value int32 - hr, _, _ := i.Vtbl.GetCommandId.Call( + hr, _, err := i.Vtbl.GetCommandId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) GetShortcutKeyDescription() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetShortcutKeyDescription.Call( + + hr, _, err := i.Vtbl.GetShortcutKeyDescription.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -96,54 +104,60 @@ func (i *ICoreWebView2ContextMenuItem) GetShortcutKeyDescription() (string, erro // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) GetIcon() (*IStream, error) { var value *IStream - hr, _, _ := i.Vtbl.GetIcon.Call( + hr, _, err := i.Vtbl.GetIcon.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) GetKind() (COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND, error) { var value COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) PutIsEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ContextMenuItem) GetIsEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsEnabled.Call( + hr, _, err := i.Vtbl.GetIsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -151,27 +165,33 @@ func (i *ICoreWebView2ContextMenuItem) GetIsEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuItem) PutIsChecked(value bool) error { - hr, _, _ := i.Vtbl.PutIsChecked.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsChecked.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ContextMenuItem) GetIsChecked() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsChecked.Call( + hr, _, err := i.Vtbl.GetIsChecked.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -179,29 +199,29 @@ func (i *ICoreWebView2ContextMenuItem) GetIsChecked() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuItem) GetChildren() (*ICoreWebView2ContextMenuItemCollection, error) { var value *ICoreWebView2ContextMenuItemCollection - hr, _, _ := i.Vtbl.GetChildren.Call( + hr, _, err := i.Vtbl.GetChildren.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItem) AddCustomItemSelected(eventHandler *ICoreWebView2CustomItemSelectedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddCustomItemSelected.Call( + hr, _, err := i.Vtbl.AddCustomItemSelected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -209,17 +229,18 @@ func (i *ICoreWebView2ContextMenuItem) AddCustomItemSelected(eventHandler *ICore if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2ContextMenuItem) RemoveCustomItemSelected(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveCustomItemSelected.Call( + + hr, _, err := i.Vtbl.RemoveCustomItemSelected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go index 2759ce75859..eebd78dac16 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ContextMenuItemCollectionVtbl struct { IUnknownVtbl - GetCount ComProc - GetValueAtIndex ComProc + GetCount ComProc + GetValueAtIndex ComProc RemoveValueAtIndex ComProc InsertValueAtIndex ComProc } @@ -20,61 +19,69 @@ type ICoreWebView2ContextMenuItemCollection struct { Vtbl *ICoreWebView2ContextMenuItemCollectionVtbl } -func (i *ICoreWebView2ContextMenuItemCollection) AddRef() uintptr { +func (i *ICoreWebView2ContextMenuItemCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2ContextMenuItemCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2ContextMenuItemCollection) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItemCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ContextMenuItem, error) { var value *ICoreWebView2ContextMenuItem - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuItemCollection) RemoveValueAtIndex(index uint32) error { - hr, _, _ := i.Vtbl.RemoveValueAtIndex.Call( + + hr, _, err := i.Vtbl.RemoveValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ContextMenuItemCollection) InsertValueAtIndex(index uint32, value *ICoreWebView2ContextMenuItem) error { - hr, _, _ := i.Vtbl.InsertValueAtIndex.Call( + + hr, _, err := i.Vtbl.InsertValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go index 46f6c3fa060..47ec58f6696 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go @@ -1,119 +1,131 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ContextMenuRequestedEventArgsVtbl struct { IUnknownVtbl - GetMenuItems ComProc + GetMenuItems ComProc GetContextMenuTarget ComProc - GetLocation ComProc + GetLocation ComProc PutSelectedCommandId ComProc GetSelectedCommandId ComProc - PutHandled ComProc - GetHandled ComProc - GetDeferral ComProc + PutHandled ComProc + GetHandled ComProc + GetDeferral ComProc } type ICoreWebView2ContextMenuRequestedEventArgs struct { Vtbl *ICoreWebView2ContextMenuRequestedEventArgsVtbl } -func (i *ICoreWebView2ContextMenuRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ContextMenuRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ContextMenuRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetMenuItems() (*ICoreWebView2ContextMenuItemCollection, error) { var value *ICoreWebView2ContextMenuItemCollection - hr, _, _ := i.Vtbl.GetMenuItems.Call( + hr, _, err := i.Vtbl.GetMenuItems.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetContextMenuTarget() (*ICoreWebView2ContextMenuTarget, error) { var value *ICoreWebView2ContextMenuTarget - hr, _, _ := i.Vtbl.GetContextMenuTarget.Call( + hr, _, err := i.Vtbl.GetContextMenuTarget.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetLocation() (POINT, error) { var value POINT - hr, _, _ := i.Vtbl.GetLocation.Call( + hr, _, err := i.Vtbl.GetLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) PutSelectedCommandId(value int32) error { - hr, _, _ := i.Vtbl.PutSelectedCommandId.Call( + + hr, _, err := i.Vtbl.PutSelectedCommandId.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetSelectedCommandId() (int32, error) { var value int32 - hr, _, _ := i.Vtbl.GetSelectedCommandId.Call( + hr, _, err := i.Vtbl.GetSelectedCommandId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) PutHandled(value bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -121,20 +133,20 @@ func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetHandled() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventHandler.go index 4cb62cb8167..1740dadd147 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ContextMenuRequestedEventHandler struct { impl ICoreWebView2ContextMenuRequestedEventHandlerImpl } -func (i *ICoreWebView2ContextMenuRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ContextMenuRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ContextMenuRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ContextMenuRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ContextMenuRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ContextMenuRequestedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2ContextMenuRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2ContextMenuRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ContextMenuRequestedEventHandlerIUnknownRelease(this *ICoreWebView2ContextMenuRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ContextMenuRequestedEventHandlerInvoke(this *ICoreWebView2ContextMenuRequestedEventHandler, sender *ICoreWebView2, args *ICoreWebView2ContextMenuRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ContextMenuRequestedEventHandlerImpl interface { } var ICoreWebView2ContextMenuRequestedEventHandlerFn = ICoreWebView2ContextMenuRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ContextMenuRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ContextMenuRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ContextMenuRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go index 58eaf0f7f4a..3bc3c793834 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go @@ -1,58 +1,63 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ContextMenuTargetVtbl struct { IUnknownVtbl - GetKind ComProc - GetIsEditable ComProc + GetKind ComProc + GetIsEditable ComProc GetIsRequestedForMainFrame ComProc - GetPageUri ComProc - GetFrameUri ComProc - GetHasLinkUri ComProc - GetLinkUri ComProc - GetHasLinkText ComProc - GetLinkText ComProc - GetHasSourceUri ComProc - GetSourceUri ComProc - GetHasSelection ComProc - GetSelectionText ComProc + GetPageUri ComProc + GetFrameUri ComProc + GetHasLinkUri ComProc + GetLinkUri ComProc + GetHasLinkText ComProc + GetLinkText ComProc + GetHasSourceUri ComProc + GetSourceUri ComProc + GetHasSelection ComProc + GetSelectionText ComProc } type ICoreWebView2ContextMenuTarget struct { Vtbl *ICoreWebView2ContextMenuTargetVtbl } -func (i *ICoreWebView2ContextMenuTarget) AddRef() uintptr { +func (i *ICoreWebView2ContextMenuTarget) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2ContextMenuTarget) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2ContextMenuTarget) GetKind() (COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND, error) { var value COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetIsEditable() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsEditable.Call( + hr, _, err := i.Vtbl.GetIsEditable.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -60,15 +65,15 @@ func (i *ICoreWebView2ContextMenuTarget) GetIsEditable() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetIsRequestedForMainFrame() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsRequestedForMainFrame.Call( + hr, _, err := i.Vtbl.GetIsRequestedForMainFrame.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -76,17 +81,18 @@ func (i *ICoreWebView2ContextMenuTarget) GetIsRequestedForMainFrame() (bool, err return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetPageUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetPageUri.Call( + + hr, _, err := i.Vtbl.GetPageUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -94,16 +100,17 @@ func (i *ICoreWebView2ContextMenuTarget) GetPageUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetFrameUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetFrameUri.Call( + + hr, _, err := i.Vtbl.GetFrameUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -111,14 +118,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetFrameUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetHasLinkUri() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasLinkUri.Call( + hr, _, err := i.Vtbl.GetHasLinkUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -126,17 +133,18 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasLinkUri() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetLinkUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetLinkUri.Call( + + hr, _, err := i.Vtbl.GetLinkUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -144,14 +152,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetLinkUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetHasLinkText() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasLinkText.Call( + hr, _, err := i.Vtbl.GetHasLinkText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -159,17 +167,18 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasLinkText() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetLinkText() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetLinkText.Call( + + hr, _, err := i.Vtbl.GetLinkText.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -177,14 +186,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetLinkText() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetHasSourceUri() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasSourceUri.Call( + hr, _, err := i.Vtbl.GetHasSourceUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -192,17 +201,18 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasSourceUri() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetSourceUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSourceUri.Call( + + hr, _, err := i.Vtbl.GetSourceUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -210,14 +220,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetSourceUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetHasSelection() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasSelection.Call( + hr, _, err := i.Vtbl.GetHasSelection.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -225,17 +235,18 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasSelection() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ContextMenuTarget) GetSelectionText() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSelectionText.Call( + + hr, _, err := i.Vtbl.GetSelectionText.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -243,5 +254,5 @@ func (i *ICoreWebView2ContextMenuTarget) GetSelectionText() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller.go b/webview2/pkg/webview2/ICoreWebView2Controller.go index 18347d6b9c4..6e4d63b99e1 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller.go @@ -1,54 +1,59 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ControllerVtbl struct { IUnknownVtbl - GetIsVisible ComProc - PutIsVisible ComProc - GetBounds ComProc - PutBounds ComProc - GetZoomFactor ComProc - PutZoomFactor ComProc - AddZoomFactorChanged ComProc - RemoveZoomFactorChanged ComProc - SetBoundsAndZoomFactor ComProc - MoveFocus ComProc - AddMoveFocusRequested ComProc - RemoveMoveFocusRequested ComProc - AddGotFocus ComProc - RemoveGotFocus ComProc - AddLostFocus ComProc - RemoveLostFocus ComProc - AddAcceleratorKeyPressed ComProc - RemoveAcceleratorKeyPressed ComProc - GetParentWindow ComProc - PutParentWindow ComProc + GetIsVisible ComProc + PutIsVisible ComProc + GetBounds ComProc + PutBounds ComProc + GetZoomFactor ComProc + PutZoomFactor ComProc + AddZoomFactorChanged ComProc + RemoveZoomFactorChanged ComProc + SetBoundsAndZoomFactor ComProc + MoveFocus ComProc + AddMoveFocusRequested ComProc + RemoveMoveFocusRequested ComProc + AddGotFocus ComProc + RemoveGotFocus ComProc + AddLostFocus ComProc + RemoveLostFocus ComProc + AddAcceleratorKeyPressed ComProc + RemoveAcceleratorKeyPressed ComProc + GetParentWindow ComProc + PutParentWindow ComProc NotifyParentWindowPositionChanged ComProc - Close ComProc - GetCoreWebView2 ComProc + Close ComProc + GetCoreWebView2 ComProc } type ICoreWebView2Controller struct { Vtbl *ICoreWebView2ControllerVtbl } -func (i *ICoreWebView2Controller) AddRef() uintptr { +func (i *ICoreWebView2Controller) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Controller) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2Controller) GetIsVisible() (bool, error) { // Create int32 to hold bool result var _isVisible int32 - hr, _, _ := i.Vtbl.GetIsVisible.Call( + hr, _, err := i.Vtbl.GetIsVisible.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isVisible)), ) @@ -56,79 +61,87 @@ func (i *ICoreWebView2Controller) GetIsVisible() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isVisible := _isVisible != 0 - return isVisible, nil + isVisible := _isVisible != 0 + return isVisible, err } func (i *ICoreWebView2Controller) PutIsVisible(isVisible bool) error { - hr, _, _ := i.Vtbl.PutIsVisible.Call( + // Convert Go bool to COM BOOL (int32) + var _isVisible int32 + if isVisible { + _isVisible = 1 + } + + hr, _, err := i.Vtbl.PutIsVisible.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isVisible)), + uintptr(_isVisible), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) GetBounds() (RECT, error) { var bounds RECT - hr, _, _ := i.Vtbl.GetBounds.Call( + hr, _, err := i.Vtbl.GetBounds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bounds)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return bounds, nil + return bounds, err } func (i *ICoreWebView2Controller) PutBounds(bounds RECT) error { - hr, _, _ := i.Vtbl.PutBounds.Call( + + hr, _, err := i.Vtbl.PutBounds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bounds)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) GetZoomFactor() (float64, error) { var zoomFactor float64 - hr, _, _ := i.Vtbl.GetZoomFactor.Call( + hr, _, err := i.Vtbl.GetZoomFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&zoomFactor)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return zoomFactor, nil + return zoomFactor, err } func (i *ICoreWebView2Controller) PutZoomFactor(zoomFactor float64) error { - hr, _, _ := i.Vtbl.PutZoomFactor.Call( + + hr, _, err := i.Vtbl.PutZoomFactor.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&zoomFactor)), + uintptr(zoomFactor), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) AddZoomFactorChanged(eventHandler *ICoreWebView2ZoomFactorChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddZoomFactorChanged.Call( + hr, _, err := i.Vtbl.AddZoomFactorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -136,51 +149,54 @@ func (i *ICoreWebView2Controller) AddZoomFactorChanged(eventHandler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Controller) RemoveZoomFactorChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveZoomFactorChanged.Call( + + hr, _, err := i.Vtbl.RemoveZoomFactorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) SetBoundsAndZoomFactor(bounds RECT, zoomFactor float64) error { - hr, _, _ := i.Vtbl.SetBoundsAndZoomFactor.Call( + + hr, _, err := i.Vtbl.SetBoundsAndZoomFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bounds)), - uintptr(unsafe.Pointer(&zoomFactor)), + uintptr(zoomFactor), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) MoveFocus(reason COREWEBVIEW2_MOVE_FOCUS_REASON) error { - hr, _, _ := i.Vtbl.MoveFocus.Call( + + hr, _, err := i.Vtbl.MoveFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(reason), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) AddMoveFocusRequested(eventHandler *ICoreWebView2MoveFocusRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddMoveFocusRequested.Call( + hr, _, err := i.Vtbl.AddMoveFocusRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -188,26 +204,27 @@ func (i *ICoreWebView2Controller) AddMoveFocusRequested(eventHandler *ICoreWebVi if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Controller) RemoveMoveFocusRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveMoveFocusRequested.Call( + + hr, _, err := i.Vtbl.RemoveMoveFocusRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) AddGotFocus(eventHandler *ICoreWebView2FocusChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddGotFocus.Call( + hr, _, err := i.Vtbl.AddGotFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -215,26 +232,27 @@ func (i *ICoreWebView2Controller) AddGotFocus(eventHandler *ICoreWebView2FocusCh if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Controller) RemoveGotFocus(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveGotFocus.Call( + + hr, _, err := i.Vtbl.RemoveGotFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) AddLostFocus(eventHandler *ICoreWebView2FocusChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddLostFocus.Call( + hr, _, err := i.Vtbl.AddLostFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -242,26 +260,27 @@ func (i *ICoreWebView2Controller) AddLostFocus(eventHandler *ICoreWebView2FocusC if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Controller) RemoveLostFocus(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveLostFocus.Call( + + hr, _, err := i.Vtbl.RemoveLostFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) AddAcceleratorKeyPressed(eventHandler *ICoreWebView2AcceleratorKeyPressedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddAcceleratorKeyPressed.Call( + hr, _, err := i.Vtbl.AddAcceleratorKeyPressed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -269,79 +288,83 @@ func (i *ICoreWebView2Controller) AddAcceleratorKeyPressed(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Controller) RemoveAcceleratorKeyPressed(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveAcceleratorKeyPressed.Call( + + hr, _, err := i.Vtbl.RemoveAcceleratorKeyPressed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) GetParentWindow() (HWND, error) { var parentWindow HWND - hr, _, _ := i.Vtbl.GetParentWindow.Call( + hr, _, err := i.Vtbl.GetParentWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&parentWindow)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return parentWindow, nil + return parentWindow, err } func (i *ICoreWebView2Controller) PutParentWindow(parentWindow HWND) error { - hr, _, _ := i.Vtbl.PutParentWindow.Call( + + hr, _, err := i.Vtbl.PutParentWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&parentWindow)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) NotifyParentWindowPositionChanged() error { - hr, _, _ := i.Vtbl.NotifyParentWindowPositionChanged.Call( + + hr, _, err := i.Vtbl.NotifyParentWindowPositionChanged.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) Close() error { - hr, _, _ := i.Vtbl.Close.Call( + + hr, _, err := i.Vtbl.Close.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller) GetCoreWebView2() (*ICoreWebView2, error) { var coreWebView2 *ICoreWebView2 - hr, _, _ := i.Vtbl.GetCoreWebView2.Call( + hr, _, err := i.Vtbl.GetCoreWebView2.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&coreWebView2)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return coreWebView2, nil + return coreWebView2, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller2.go b/webview2/pkg/webview2/ICoreWebView2Controller2.go index e4891c4c604..349813795a0 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller2.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Controller2Vtbl struct { @@ -18,45 +17,55 @@ type ICoreWebView2Controller2 struct { Vtbl *ICoreWebView2Controller2Vtbl } -func (i *ICoreWebView2Controller2) AddRef() uintptr { +func (i *ICoreWebView2Controller2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Controller2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Controller2() *ICoreWebView2Controller2 { + +func (i *ICoreWebView2) GetICoreWebView2Controller2() (*ICoreWebView2Controller2, error) { var result *ICoreWebView2Controller2 iidICoreWebView2Controller2 := NewGUID("{c979903e-d4ca-4228-92eb-47ee3fa96eab}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Controller2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Controller2) GetDefaultBackgroundColor() (COREWEBVIEW2_COLOR, error) { var value COREWEBVIEW2_COLOR - hr, _, _ := i.Vtbl.GetDefaultBackgroundColor.Call( + hr, _, err := i.Vtbl.GetDefaultBackgroundColor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return COREWEBVIEW2_COLOR{}, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Controller2) PutDefaultBackgroundColor(value COREWEBVIEW2_COLOR) error { - hr, _, _ := i.Vtbl.PutDefaultBackgroundColor.Call( + + hr, _, err := i.Vtbl.PutDefaultBackgroundColor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller3.go b/webview2/pkg/webview2/ICoreWebView2Controller3.go index 8dd5b036021..69d0c670d5f 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller3.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller3.go @@ -1,77 +1,86 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Controller3Vtbl struct { IUnknownVtbl - GetRasterizationScale ComProc - PutRasterizationScale ComProc + GetRasterizationScale ComProc + PutRasterizationScale ComProc GetShouldDetectMonitorScaleChanges ComProc PutShouldDetectMonitorScaleChanges ComProc - AddRasterizationScaleChanged ComProc - RemoveRasterizationScaleChanged ComProc - GetBoundsMode ComProc - PutBoundsMode ComProc + AddRasterizationScaleChanged ComProc + RemoveRasterizationScaleChanged ComProc + GetBoundsMode ComProc + PutBoundsMode ComProc } type ICoreWebView2Controller3 struct { Vtbl *ICoreWebView2Controller3Vtbl } -func (i *ICoreWebView2Controller3) AddRef() uintptr { +func (i *ICoreWebView2Controller3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Controller3() *ICoreWebView2Controller3 { +func (i *ICoreWebView2Controller3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2Controller3() (*ICoreWebView2Controller3, error) { var result *ICoreWebView2Controller3 iidICoreWebView2Controller3 := NewGUID("{f9614724-5d2b-41dc-aef7-73d62b51543b}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Controller3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Controller3) GetRasterizationScale() (float64, error) { var scale float64 - hr, _, _ := i.Vtbl.GetRasterizationScale.Call( + hr, _, err := i.Vtbl.GetRasterizationScale.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&scale)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return scale, nil + return scale, err } func (i *ICoreWebView2Controller3) PutRasterizationScale(scale float64) error { - hr, _, _ := i.Vtbl.PutRasterizationScale.Call( + + hr, _, err := i.Vtbl.PutRasterizationScale.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&scale)), + uintptr(scale), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller3) GetShouldDetectMonitorScaleChanges() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetShouldDetectMonitorScaleChanges.Call( + hr, _, err := i.Vtbl.GetShouldDetectMonitorScaleChanges.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -79,33 +88,33 @@ func (i *ICoreWebView2Controller3) GetShouldDetectMonitorScaleChanges() (bool, e return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Controller3) PutShouldDetectMonitorScaleChanges(value bool) error { - var intValue uintptr + + // Convert Go bool to COM BOOL (int32) + var _value int32 if value { - intValue = 1 - } else { - intValue = 0 + _value = 1 } - hr, _, _ := i.Vtbl.PutShouldDetectMonitorScaleChanges.Call( + hr, _, err := i.Vtbl.PutShouldDetectMonitorScaleChanges.Call( uintptr(unsafe.Pointer(i)), - intValue, + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller3) AddRasterizationScaleChanged(eventHandler *ICoreWebView2RasterizationScaleChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddRasterizationScaleChanged.Call( + hr, _, err := i.Vtbl.AddRasterizationScaleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -113,43 +122,45 @@ func (i *ICoreWebView2Controller3) AddRasterizationScaleChanged(eventHandler *IC if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Controller3) RemoveRasterizationScaleChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveRasterizationScaleChanged.Call( + + hr, _, err := i.Vtbl.RemoveRasterizationScaleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Controller3) GetBoundsMode() (COREWEBVIEW2_BOUNDS_MODE, error) { var boundsMode COREWEBVIEW2_BOUNDS_MODE - hr, _, _ := i.Vtbl.GetBoundsMode.Call( + hr, _, err := i.Vtbl.GetBoundsMode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&boundsMode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return boundsMode, nil + return boundsMode, err } func (i *ICoreWebView2Controller3) PutBoundsMode(boundsMode COREWEBVIEW2_BOUNDS_MODE) error { - hr, _, _ := i.Vtbl.PutBoundsMode.Call( + + hr, _, err := i.Vtbl.PutBoundsMode.Call( uintptr(unsafe.Pointer(i)), uintptr(boundsMode), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller4.go b/webview2/pkg/webview2/ICoreWebView2Controller4.go index eccc0eaf708..60da67e87b2 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller4.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller4.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Controller4Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2Controller4 struct { Vtbl *ICoreWebView2Controller4Vtbl } -func (i *ICoreWebView2Controller4) AddRef() uintptr { +func (i *ICoreWebView2Controller4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Controller4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Controller4() *ICoreWebView2Controller4 { + +func (i *ICoreWebView2) GetICoreWebView2Controller4() (*ICoreWebView2Controller4, error) { var result *ICoreWebView2Controller4 iidICoreWebView2Controller4 := NewGUID("{97d418d5-a426-4e49-a151-e1a10f327d9e}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Controller4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Controller4) GetAllowExternalDrop() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetAllowExternalDrop.Call( + hr, _, err := i.Vtbl.GetAllowExternalDrop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2Controller4) GetAllowExternalDrop() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Controller4) PutAllowExternalDrop(value bool) error { - hr, _, _ := i.Vtbl.PutAllowExternalDrop.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutAllowExternalDrop.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go index fb6cc2f38e5..38140ae3cdf 100644 --- a/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ControllerOptionsVtbl struct { IUnknownVtbl - GetProfileName ComProc - PutProfileName ComProc + GetProfileName ComProc + PutProfileName ComProc GetIsInPrivateModeEnabled ComProc PutIsInPrivateModeEnabled ComProc } @@ -20,18 +19,25 @@ type ICoreWebView2ControllerOptions struct { Vtbl *ICoreWebView2ControllerOptionsVtbl } -func (i *ICoreWebView2ControllerOptions) AddRef() uintptr { +func (i *ICoreWebView2ControllerOptions) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ControllerOptions) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ControllerOptions) GetProfileName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetProfileName.Call( + + hr, _, err := i.Vtbl.GetProfileName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -39,7 +45,7 @@ func (i *ICoreWebView2ControllerOptions) GetProfileName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ControllerOptions) PutProfileName(value string) error { @@ -50,21 +56,21 @@ func (i *ICoreWebView2ControllerOptions) PutProfileName(value string) error { return err } - hr, _, _ := i.Vtbl.PutProfileName.Call( + hr, _, err := i.Vtbl.PutProfileName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ControllerOptions) GetIsInPrivateModeEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsInPrivateModeEnabled.Call( + hr, _, err := i.Vtbl.GetIsInPrivateModeEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -72,18 +78,24 @@ func (i *ICoreWebView2ControllerOptions) GetIsInPrivateModeEnabled() (bool, erro return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ControllerOptions) PutIsInPrivateModeEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsInPrivateModeEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsInPrivateModeEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go index 41aef9b81c7..5034c9d817e 100644 --- a/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ControllerOptions2Vtbl struct { @@ -18,30 +17,40 @@ type ICoreWebView2ControllerOptions2 struct { Vtbl *ICoreWebView2ControllerOptions2Vtbl } -func (i *ICoreWebView2ControllerOptions2) AddRef() uintptr { +func (i *ICoreWebView2ControllerOptions2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ControllerOptions2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2ControllerOptions2() *ICoreWebView2ControllerOptions2 { + +func (i *ICoreWebView2) GetICoreWebView2ControllerOptions2() (*ICoreWebView2ControllerOptions2, error) { var result *ICoreWebView2ControllerOptions2 iidICoreWebView2ControllerOptions2 := NewGUID("{06c991d8-9e7e-11ed-a8fc-0242ac120002}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2ControllerOptions2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2ControllerOptions2) GetScriptLocale() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetScriptLocale.Call( + + hr, _, err := i.Vtbl.GetScriptLocale.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -49,7 +58,7 @@ func (i *ICoreWebView2ControllerOptions2) GetScriptLocale() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ControllerOptions2) PutScriptLocale(value string) error { @@ -60,12 +69,12 @@ func (i *ICoreWebView2ControllerOptions2) PutScriptLocale(value string) error { return err } - hr, _, _ := i.Vtbl.PutScriptLocale.Call( + hr, _, err := i.Vtbl.PutScriptLocale.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Cookie.go b/webview2/pkg/webview2/ICoreWebView2Cookie.go index 8dd2dae548f..204c07ab534 100644 --- a/webview2/pkg/webview2/ICoreWebView2Cookie.go +++ b/webview2/pkg/webview2/ICoreWebView2Cookie.go @@ -1,47 +1,53 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CookieVtbl struct { IUnknownVtbl - GetName ComProc - GetValue ComProc - PutValue ComProc - GetDomain ComProc - GetPath ComProc - GetExpires ComProc - PutExpires ComProc + GetName ComProc + GetValue ComProc + PutValue ComProc + GetDomain ComProc + GetPath ComProc + GetExpires ComProc + PutExpires ComProc GetIsHttpOnly ComProc PutIsHttpOnly ComProc - GetSameSite ComProc - PutSameSite ComProc - GetIsSecure ComProc - PutIsSecure ComProc - GetIsSession ComProc + GetSameSite ComProc + PutSameSite ComProc + GetIsSecure ComProc + PutIsSecure ComProc + GetIsSession ComProc } type ICoreWebView2Cookie struct { Vtbl *ICoreWebView2CookieVtbl } -func (i *ICoreWebView2Cookie) AddRef() uintptr { +func (i *ICoreWebView2Cookie) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2Cookie) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2Cookie) GetName() (string, error) { // Create *uint16 to hold result var _name *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_name)), + uintptr(unsafe.Pointer(&_name)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -49,16 +55,17 @@ func (i *ICoreWebView2Cookie) GetName() (string, error) { // Get result and cleanup name := UTF16PtrToString(_name) CoTaskMemFree(unsafe.Pointer(_name)) - return name, nil + return name, err } func (i *ICoreWebView2Cookie) GetValue() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetValue.Call( + + hr, _, err := i.Vtbl.GetValue.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -66,7 +73,7 @@ func (i *ICoreWebView2Cookie) GetValue() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Cookie) PutValue(value string) error { @@ -77,23 +84,24 @@ func (i *ICoreWebView2Cookie) PutValue(value string) error { return err } - hr, _, _ := i.Vtbl.PutValue.Call( + hr, _, err := i.Vtbl.PutValue.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Cookie) GetDomain() (string, error) { // Create *uint16 to hold result var _domain *uint16 - hr, _, _ := i.Vtbl.GetDomain.Call( + + hr, _, err := i.Vtbl.GetDomain.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_domain)), + uintptr(unsafe.Pointer(&_domain)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -101,16 +109,17 @@ func (i *ICoreWebView2Cookie) GetDomain() (string, error) { // Get result and cleanup domain := UTF16PtrToString(_domain) CoTaskMemFree(unsafe.Pointer(_domain)) - return domain, nil + return domain, err } func (i *ICoreWebView2Cookie) GetPath() (string, error) { // Create *uint16 to hold result var _path *uint16 - hr, _, _ := i.Vtbl.GetPath.Call( + + hr, _, err := i.Vtbl.GetPath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_path)), + uintptr(unsafe.Pointer(&_path)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -118,40 +127,41 @@ func (i *ICoreWebView2Cookie) GetPath() (string, error) { // Get result and cleanup path := UTF16PtrToString(_path) CoTaskMemFree(unsafe.Pointer(_path)) - return path, nil + return path, err } func (i *ICoreWebView2Cookie) GetExpires() (float64, error) { var expires float64 - hr, _, _ := i.Vtbl.GetExpires.Call( + hr, _, err := i.Vtbl.GetExpires.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&expires)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return expires, nil + return expires, err } func (i *ICoreWebView2Cookie) PutExpires(expires float64) error { - hr, _, _ := i.Vtbl.PutExpires.Call( + + hr, _, err := i.Vtbl.PutExpires.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&expires)), + uintptr(expires), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Cookie) GetIsHttpOnly() (bool, error) { // Create int32 to hold bool result var _isHttpOnly int32 - hr, _, _ := i.Vtbl.GetIsHttpOnly.Call( + hr, _, err := i.Vtbl.GetIsHttpOnly.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isHttpOnly)), ) @@ -159,53 +169,60 @@ func (i *ICoreWebView2Cookie) GetIsHttpOnly() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isHttpOnly := _isHttpOnly != 0 - return isHttpOnly, nil + isHttpOnly := _isHttpOnly != 0 + return isHttpOnly, err } func (i *ICoreWebView2Cookie) PutIsHttpOnly(isHttpOnly bool) error { - hr, _, _ := i.Vtbl.PutIsHttpOnly.Call( + // Convert Go bool to COM BOOL (int32) + var _isHttpOnly int32 + if isHttpOnly { + _isHttpOnly = 1 + } + + hr, _, err := i.Vtbl.PutIsHttpOnly.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isHttpOnly)), + uintptr(_isHttpOnly), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Cookie) GetSameSite() (COREWEBVIEW2_COOKIE_SAME_SITE_KIND, error) { var sameSite COREWEBVIEW2_COOKIE_SAME_SITE_KIND - hr, _, _ := i.Vtbl.GetSameSite.Call( + hr, _, err := i.Vtbl.GetSameSite.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&sameSite)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return sameSite, nil + return sameSite, err } func (i *ICoreWebView2Cookie) PutSameSite(sameSite COREWEBVIEW2_COOKIE_SAME_SITE_KIND) error { - hr, _, _ := i.Vtbl.PutSameSite.Call( + + hr, _, err := i.Vtbl.PutSameSite.Call( uintptr(unsafe.Pointer(i)), uintptr(sameSite), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Cookie) GetIsSecure() (bool, error) { // Create int32 to hold bool result var _isSecure int32 - hr, _, _ := i.Vtbl.GetIsSecure.Call( + hr, _, err := i.Vtbl.GetIsSecure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSecure)), ) @@ -213,27 +230,33 @@ func (i *ICoreWebView2Cookie) GetIsSecure() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isSecure := _isSecure != 0 - return isSecure, nil + isSecure := _isSecure != 0 + return isSecure, err } func (i *ICoreWebView2Cookie) PutIsSecure(isSecure bool) error { - hr, _, _ := i.Vtbl.PutIsSecure.Call( + // Convert Go bool to COM BOOL (int32) + var _isSecure int32 + if isSecure { + _isSecure = 1 + } + + hr, _, err := i.Vtbl.PutIsSecure.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isSecure)), + uintptr(_isSecure), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Cookie) GetIsSession() (bool, error) { // Create int32 to hold bool result var _isSession int32 - hr, _, _ := i.Vtbl.GetIsSession.Call( + hr, _, err := i.Vtbl.GetIsSession.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSession)), ) @@ -241,6 +264,6 @@ func (i *ICoreWebView2Cookie) GetIsSession() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isSession := _isSession != 0 - return isSession, nil + isSession := _isSession != 0 + return isSession, err } diff --git a/webview2/pkg/webview2/ICoreWebView2CookieList.go b/webview2/pkg/webview2/ICoreWebView2CookieList.go index 69a73180d2e..f3dce94630c 100644 --- a/webview2/pkg/webview2/ICoreWebView2CookieList.go +++ b/webview2/pkg/webview2/ICoreWebView2CookieList.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CookieListVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2CookieList struct { Vtbl *ICoreWebView2CookieListVtbl } -func (i *ICoreWebView2CookieList) AddRef() uintptr { +func (i *ICoreWebView2CookieList) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CookieList) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2CookieList) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2CookieList) GetValueAtIndex(index uint32) (*ICoreWebView2Cookie, error) { var value *ICoreWebView2Cookie - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2CookieManager.go b/webview2/pkg/webview2/ICoreWebView2CookieManager.go index b7fd8797c9e..9d528a50f7e 100644 --- a/webview2/pkg/webview2/ICoreWebView2CookieManager.go +++ b/webview2/pkg/webview2/ICoreWebView2CookieManager.go @@ -1,34 +1,39 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CookieManagerVtbl struct { IUnknownVtbl - CreateCookie ComProc - CopyCookie ComProc - GetCookies ComProc - AddOrUpdateCookie ComProc - DeleteCookie ComProc - DeleteCookies ComProc + CreateCookie ComProc + CopyCookie ComProc + GetCookies ComProc + AddOrUpdateCookie ComProc + DeleteCookie ComProc + DeleteCookies ComProc DeleteCookiesWithDomainAndPath ComProc - DeleteAllCookies ComProc + DeleteAllCookies ComProc } type ICoreWebView2CookieManager struct { Vtbl *ICoreWebView2CookieManagerVtbl } -func (i *ICoreWebView2CookieManager) AddRef() uintptr { +func (i *ICoreWebView2CookieManager) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2CookieManager) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2CookieManager) CreateCookie(name string, value string, domain string, path string) (*ICoreWebView2Cookie, error) { // Convert string 'name' to *uint16 @@ -53,7 +58,7 @@ func (i *ICoreWebView2CookieManager) CreateCookie(name string, value string, dom } var cookie *ICoreWebView2Cookie - hr, _, _ := i.Vtbl.CreateCookie.Call( + hr, _, err := i.Vtbl.CreateCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_value)), @@ -64,14 +69,14 @@ func (i *ICoreWebView2CookieManager) CreateCookie(name string, value string, dom if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return cookie, nil + return cookie, err } func (i *ICoreWebView2CookieManager) CopyCookie(cookieParam *ICoreWebView2Cookie) (*ICoreWebView2Cookie, error) { var cookie *ICoreWebView2Cookie - hr, _, _ := i.Vtbl.CopyCookie.Call( + hr, _, err := i.Vtbl.CopyCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(cookieParam)), uintptr(unsafe.Pointer(&cookie)), @@ -79,7 +84,7 @@ func (i *ICoreWebView2CookieManager) CopyCookie(cookieParam *ICoreWebView2Cookie if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return cookie, nil + return cookie, err } func (i *ICoreWebView2CookieManager) GetCookies(uri string, handler *ICoreWebView2GetCookiesCompletedHandler) error { @@ -90,7 +95,7 @@ func (i *ICoreWebView2CookieManager) GetCookies(uri string, handler *ICoreWebVie return err } - hr, _, _ := i.Vtbl.GetCookies.Call( + hr, _, err := i.Vtbl.GetCookies.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(unsafe.Pointer(handler)), @@ -98,31 +103,33 @@ func (i *ICoreWebView2CookieManager) GetCookies(uri string, handler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CookieManager) AddOrUpdateCookie(cookie *ICoreWebView2Cookie) error { - hr, _, _ := i.Vtbl.AddOrUpdateCookie.Call( + + hr, _, err := i.Vtbl.AddOrUpdateCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(cookie)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CookieManager) DeleteCookie(cookie *ICoreWebView2Cookie) error { - hr, _, _ := i.Vtbl.DeleteCookie.Call( + + hr, _, err := i.Vtbl.DeleteCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(cookie)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CookieManager) DeleteCookies(name string, uri string) error { @@ -138,7 +145,7 @@ func (i *ICoreWebView2CookieManager) DeleteCookies(name string, uri string) erro return err } - hr, _, _ := i.Vtbl.DeleteCookies.Call( + hr, _, err := i.Vtbl.DeleteCookies.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_uri)), @@ -146,7 +153,7 @@ func (i *ICoreWebView2CookieManager) DeleteCookies(name string, uri string) erro if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CookieManager) DeleteCookiesWithDomainAndPath(name string, domain string, path string) error { @@ -167,7 +174,7 @@ func (i *ICoreWebView2CookieManager) DeleteCookiesWithDomainAndPath(name string, return err } - hr, _, _ := i.Vtbl.DeleteCookiesWithDomainAndPath.Call( + hr, _, err := i.Vtbl.DeleteCookiesWithDomainAndPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_domain)), @@ -176,16 +183,17 @@ func (i *ICoreWebView2CookieManager) DeleteCookiesWithDomainAndPath(name string, if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CookieManager) DeleteAllCookies() error { - hr, _, _ := i.Vtbl.DeleteAllCookies.Call( + + hr, _, err := i.Vtbl.DeleteAllCookies.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler.go index 930ba527c6a..ffd20570c23 100644 --- a/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler struct impl ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerImpl } -func (i *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknow } func ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknownAddRef(this *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknownRelease(this *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerInvoke(this *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler, errorCode uintptr, result *ICoreWebView2CompositionController) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerImpl in } var ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerFn = ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2ControllerCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2ControllerCompletedHandler.go index 49602c89d3e..ef870241404 100644 --- a/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2ControllerCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2ControllerCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CreateCoreWebView2ControllerCompletedHandler struct { impl ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerImpl } -func (i *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownQueryInter } func ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownAddRef(this *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownRelease(this *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerInvoke(this *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler, errorCode uintptr, result *ICoreWebView2Controller) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerImpl interface { } var ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerFn = ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2CreateCoreWebView2ControllerCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler.go index 4ad613753fe..07eaf71d9e7 100644 --- a/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler struct { impl ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerImpl } -func (i *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownQueryInte } func ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownAddRef(this *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownRelease(this *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerInvoke(this *ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler, errorCode uintptr, result *ICoreWebView2Environment) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerImpl interface { } var ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerFn = ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CursorChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2CursorChangedEventHandler.go index 030bd28a7b9..4cc3ca7dc4e 100644 --- a/webview2/pkg/webview2/ICoreWebView2CursorChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CursorChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CursorChangedEventHandler struct { impl ICoreWebView2CursorChangedEventHandlerImpl } -func (i *ICoreWebView2CursorChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2CursorChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CursorChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CursorChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2CursorChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CursorChangedEventHandlerIUnknownQueryInterface(this *ICoreWeb } func ICoreWebView2CursorChangedEventHandlerIUnknownAddRef(this *ICoreWebView2CursorChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CursorChangedEventHandlerIUnknownRelease(this *ICoreWebView2CursorChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CursorChangedEventHandlerInvoke(this *ICoreWebView2CursorChangedEventHandler, sender *ICoreWebView2CompositionController, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CursorChangedEventHandlerImpl interface { } var ICoreWebView2CursorChangedEventHandlerFn = ICoreWebView2CursorChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CursorChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CursorChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2CursorChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CustomItemSelectedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2CustomItemSelectedEventHandler.go index 0631604a6fc..2577da44f4e 100644 --- a/webview2/pkg/webview2/ICoreWebView2CustomItemSelectedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CustomItemSelectedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2CustomItemSelectedEventHandler struct { impl ICoreWebView2CustomItemSelectedEventHandlerImpl } -func (i *ICoreWebView2CustomItemSelectedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2CustomItemSelectedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2CustomItemSelectedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2CustomItemSelectedEventHandlerIUnknownQueryInterface(this *ICoreWebView2CustomItemSelectedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2CustomItemSelectedEventHandlerIUnknownQueryInterface(this *ICo } func ICoreWebView2CustomItemSelectedEventHandlerIUnknownAddRef(this *ICoreWebView2CustomItemSelectedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2CustomItemSelectedEventHandlerIUnknownRelease(this *ICoreWebView2CustomItemSelectedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2CustomItemSelectedEventHandlerInvoke(this *ICoreWebView2CustomItemSelectedEventHandler, sender *ICoreWebView2ContextMenuItem, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2CustomItemSelectedEventHandlerImpl interface { } var ICoreWebView2CustomItemSelectedEventHandlerFn = ICoreWebView2CustomItemSelectedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2CustomItemSelectedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2CustomItemSelectedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2CustomItemSelectedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go b/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go index 034024a8c29..05b7ec7bb94 100644 --- a/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go +++ b/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go @@ -1,20 +1,19 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2CustomSchemeRegistrationVtbl struct { IUnknownVtbl - GetSchemeName ComProc - GetTreatAsSecure ComProc - PutTreatAsSecure ComProc - GetAllowedOrigins ComProc - SetAllowedOrigins ComProc + GetSchemeName ComProc + GetTreatAsSecure ComProc + PutTreatAsSecure ComProc + GetAllowedOrigins ComProc + SetAllowedOrigins ComProc GetHasAuthorityComponent ComProc PutHasAuthorityComponent ComProc } @@ -23,18 +22,25 @@ type ICoreWebView2CustomSchemeRegistration struct { Vtbl *ICoreWebView2CustomSchemeRegistrationVtbl } -func (i *ICoreWebView2CustomSchemeRegistration) AddRef() uintptr { +func (i *ICoreWebView2CustomSchemeRegistration) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2CustomSchemeRegistration) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2CustomSchemeRegistration) GetSchemeName() (string, error) { // Create *uint16 to hold result var _schemeName *uint16 - hr, _, _ := i.Vtbl.GetSchemeName.Call( + + hr, _, err := i.Vtbl.GetSchemeName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_schemeName)), + uintptr(unsafe.Pointer(&_schemeName)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -42,14 +48,14 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetSchemeName() (string, error) // Get result and cleanup schemeName := UTF16PtrToString(_schemeName) CoTaskMemFree(unsafe.Pointer(_schemeName)) - return schemeName, nil + return schemeName, err } func (i *ICoreWebView2CustomSchemeRegistration) GetTreatAsSecure() (bool, error) { // Create int32 to hold bool result var _treatAsSecure int32 - hr, _, _ := i.Vtbl.GetTreatAsSecure.Call( + hr, _, err := i.Vtbl.GetTreatAsSecure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_treatAsSecure)), ) @@ -57,20 +63,26 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetTreatAsSecure() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - treatAsSecure := _treatAsSecure != 0 - return treatAsSecure, nil + treatAsSecure := _treatAsSecure != 0 + return treatAsSecure, err } func (i *ICoreWebView2CustomSchemeRegistration) PutTreatAsSecure(value bool) error { - hr, _, _ := i.Vtbl.PutTreatAsSecure.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutTreatAsSecure.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CustomSchemeRegistration) GetAllowedOrigins() (uint32, *string, error) { @@ -78,41 +90,49 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetAllowedOrigins() (uint32, *st var allowedOriginsCount uint32 var allowedOrigins *string - hr, _, _ := i.Vtbl.GetAllowedOrigins.Call( + hr, _, err := i.Vtbl.GetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&allowedOriginsCount)), - uintptr(unsafe.Pointer(allowedOrigins)), + uintptr(unsafe.Pointer(&allowedOrigins)), ) if windows.Handle(hr) != windows.S_OK { return 0, nil, syscall.Errno(hr) } - return allowedOriginsCount, allowedOrigins, nil + return allowedOriginsCount, allowedOrigins, err } -func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins string) error { - - // Convert string 'allowedOrigins' to *uint16 - _allowedOrigins, err := UTF16PtrFromString(allowedOrigins) - if err != nil { - return err +func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins []string) error { + // Convert []string 'allowedOrigins' to **uint16 (LPCWSTR* / LPWSTR*) + _allowedOriginsptrs := make([]*uint16, len(allowedOrigins)) + for _i, _s := range allowedOrigins { + _p, err := UTF16PtrFromString(_s) + if err != nil { + return err + } + _allowedOriginsptrs[_i] = _p } + var _allowedOrigins **uint16 + if len(_allowedOriginsptrs) > 0 { + _allowedOrigins = &_allowedOriginsptrs[0] + } + - hr, _, _ := i.Vtbl.SetAllowedOrigins.Call( + hr, _, err := i.Vtbl.SetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&allowedOriginsCount)), + uintptr(allowedOriginsCount), uintptr(unsafe.Pointer(_allowedOrigins)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2CustomSchemeRegistration) GetHasAuthorityComponent() (bool, error) { // Create int32 to hold bool result var _hasAuthorityComponent int32 - hr, _, _ := i.Vtbl.GetHasAuthorityComponent.Call( + hr, _, err := i.Vtbl.GetHasAuthorityComponent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_hasAuthorityComponent)), ) @@ -120,18 +140,24 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetHasAuthorityComponent() (bool return false, syscall.Errno(hr) } // Get result and cleanup - hasAuthorityComponent := _hasAuthorityComponent != 0 - return hasAuthorityComponent, nil + hasAuthorityComponent := _hasAuthorityComponent != 0 + return hasAuthorityComponent, err } func (i *ICoreWebView2CustomSchemeRegistration) PutHasAuthorityComponent(hasAuthorityComponent bool) error { - hr, _, _ := i.Vtbl.PutHasAuthorityComponent.Call( + // Convert Go bool to COM BOOL (int32) + var _hasAuthorityComponent int32 + if hasAuthorityComponent { + _hasAuthorityComponent = 1 + } + + hr, _, err := i.Vtbl.PutHasAuthorityComponent.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&hasAuthorityComponent)), + uintptr(_hasAuthorityComponent), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go index d2b3b347be1..b39904b2e48 100644 --- a/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DOMContentLoadedEventArgsVtbl struct { @@ -17,21 +16,27 @@ type ICoreWebView2DOMContentLoadedEventArgs struct { Vtbl *ICoreWebView2DOMContentLoadedEventArgsVtbl } -func (i *ICoreWebView2DOMContentLoadedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2DOMContentLoadedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DOMContentLoadedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2DOMContentLoadedEventArgs) GetNavigationId() (uint64, error) { var value uint64 - hr, _, _ := i.Vtbl.GetNavigationId.Call( + hr, _, err := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventHandler.go index 2513396b18c..fe11b86c0f9 100644 --- a/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2DOMContentLoadedEventHandler struct { impl ICoreWebView2DOMContentLoadedEventHandlerImpl } -func (i *ICoreWebView2DOMContentLoadedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2DOMContentLoadedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DOMContentLoadedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2DOMContentLoadedEventHandlerIUnknownQueryInterface(this *ICoreWebView2DOMContentLoadedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2DOMContentLoadedEventHandlerIUnknownQueryInterface(this *ICore } func ICoreWebView2DOMContentLoadedEventHandlerIUnknownAddRef(this *ICoreWebView2DOMContentLoadedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2DOMContentLoadedEventHandlerIUnknownRelease(this *ICoreWebView2DOMContentLoadedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2DOMContentLoadedEventHandlerInvoke(this *ICoreWebView2DOMContentLoadedEventHandler, sender *ICoreWebView2, args *ICoreWebView2DOMContentLoadedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2DOMContentLoadedEventHandlerImpl interface { } var ICoreWebView2DOMContentLoadedEventHandlerFn = ICoreWebView2DOMContentLoadedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2DOMContentLoadedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2DOMContentLoadedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2DOMContentLoadedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Deferral.go b/webview2/pkg/webview2/ICoreWebView2Deferral.go index efe577500e1..7a24b0a736c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Deferral.go +++ b/webview2/pkg/webview2/ICoreWebView2Deferral.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DeferralVtbl struct { @@ -17,18 +16,25 @@ type ICoreWebView2Deferral struct { Vtbl *ICoreWebView2DeferralVtbl } -func (i *ICoreWebView2Deferral) AddRef() uintptr { +func (i *ICoreWebView2Deferral) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2Deferral) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2Deferral) Complete() error { - hr, _, _ := i.Vtbl.Complete.Call( + + hr, _, err := i.Vtbl.Complete.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go index 7225340e7a8..e239937f580 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DevToolsProtocolEventReceivedEventArgsVtbl struct { @@ -17,18 +16,25 @@ type ICoreWebView2DevToolsProtocolEventReceivedEventArgs struct { Vtbl *ICoreWebView2DevToolsProtocolEventReceivedEventArgsVtbl } -func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) GetParameterObjectAsJson() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetParameterObjectAsJson.Call( + + hr, _, err := i.Vtbl.GetParameterObjectAsJson.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -36,5 +42,5 @@ func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) GetParameterObject // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go index 2a85d909b03..3db1fd58159 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DevToolsProtocolEventReceivedEventArgs2Vtbl struct { @@ -17,30 +16,40 @@ type ICoreWebView2DevToolsProtocolEventReceivedEventArgs2 struct { Vtbl *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2Vtbl } -func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2DevToolsProtocolEventReceivedEventArgs2() *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2DevToolsProtocolEventReceivedEventArgs2() (*ICoreWebView2DevToolsProtocolEventReceivedEventArgs2, error) { var result *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2 iidICoreWebView2DevToolsProtocolEventReceivedEventArgs2 := NewGUID("{2dc4959d-1494-4393-95ba-bea4cb9ebd1b}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2DevToolsProtocolEventReceivedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) GetSessionId() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSessionId.Call( + + hr, _, err := i.Vtbl.GetSessionId.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,5 +57,5 @@ func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) GetSessionId() (s // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventHandler.go index 3e2b01d8980..6799104cf5b 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2DevToolsProtocolEventReceivedEventHandler struct { impl ICoreWebView2DevToolsProtocolEventReceivedEventHandlerImpl } -func (i *ICoreWebView2DevToolsProtocolEventReceivedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2DevToolsProtocolEventReceivedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DevToolsProtocolEventReceivedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownQueryInterface(this *ICoreWebView2DevToolsProtocolEventReceivedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownQueryInterfac } func ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownAddRef(this *ICoreWebView2DevToolsProtocolEventReceivedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownRelease(this *ICoreWebView2DevToolsProtocolEventReceivedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2DevToolsProtocolEventReceivedEventHandlerInvoke(this *ICoreWebView2DevToolsProtocolEventReceivedEventHandler, sender *ICoreWebView2, args *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2DevToolsProtocolEventReceivedEventHandlerImpl interface { } var ICoreWebView2DevToolsProtocolEventReceivedEventHandlerFn = ICoreWebView2DevToolsProtocolEventReceivedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2DevToolsProtocolEventReceivedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go index 0750648a7c7..702d3984c47 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DevToolsProtocolEventReceiverVtbl struct { IUnknownVtbl - AddDevToolsProtocolEventReceived ComProc + AddDevToolsProtocolEventReceived ComProc RemoveDevToolsProtocolEventReceived ComProc } @@ -18,16 +17,22 @@ type ICoreWebView2DevToolsProtocolEventReceiver struct { Vtbl *ICoreWebView2DevToolsProtocolEventReceiverVtbl } -func (i *ICoreWebView2DevToolsProtocolEventReceiver) AddRef() uintptr { +func (i *ICoreWebView2DevToolsProtocolEventReceiver) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2DevToolsProtocolEventReceiver) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2DevToolsProtocolEventReceiver) AddDevToolsProtocolEventReceived(eventHandler *ICoreWebView2DevToolsProtocolEventReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDevToolsProtocolEventReceived.Call( + hr, _, err := i.Vtbl.AddDevToolsProtocolEventReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -35,17 +40,18 @@ func (i *ICoreWebView2DevToolsProtocolEventReceiver) AddDevToolsProtocolEventRec if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2DevToolsProtocolEventReceiver) RemoveDevToolsProtocolEventReceived(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDevToolsProtocolEventReceived.Call( + + hr, _, err := i.Vtbl.RemoveDevToolsProtocolEventReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2DocumentTitleChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2DocumentTitleChangedEventHandler.go index ace92427c17..08fa1d7d346 100644 --- a/webview2/pkg/webview2/ICoreWebView2DocumentTitleChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2DocumentTitleChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2DocumentTitleChangedEventHandler struct { impl ICoreWebView2DocumentTitleChangedEventHandlerImpl } -func (i *ICoreWebView2DocumentTitleChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2DocumentTitleChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DocumentTitleChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2DocumentTitleChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2DocumentTitleChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2DocumentTitleChangedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2DocumentTitleChangedEventHandlerIUnknownAddRef(this *ICoreWebView2DocumentTitleChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2DocumentTitleChangedEventHandlerIUnknownRelease(this *ICoreWebView2DocumentTitleChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2DocumentTitleChangedEventHandlerInvoke(this *ICoreWebView2DocumentTitleChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2DocumentTitleChangedEventHandlerImpl interface { } var ICoreWebView2DocumentTitleChangedEventHandlerFn = ICoreWebView2DocumentTitleChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2DocumentTitleChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2DocumentTitleChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2DocumentTitleChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go b/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go index c26339b74b2..98358d3a7c2 100644 --- a/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go +++ b/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go @@ -1,50 +1,55 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DownloadOperationVtbl struct { IUnknownVtbl - AddBytesReceivedChanged ComProc - RemoveBytesReceivedChanged ComProc - AddEstimatedEndTimeChanged ComProc + AddBytesReceivedChanged ComProc + RemoveBytesReceivedChanged ComProc + AddEstimatedEndTimeChanged ComProc RemoveEstimatedEndTimeChanged ComProc - AddStateChanged ComProc - RemoveStateChanged ComProc - GetUri ComProc - GetContentDisposition ComProc - GetMimeType ComProc - GetTotalBytesToReceive ComProc - GetBytesReceived ComProc - GetEstimatedEndTime ComProc - GetResultFilePath ComProc - GetState ComProc - GetInterruptReason ComProc - Cancel ComProc - Pause ComProc - Resume ComProc - GetCanResume ComProc + AddStateChanged ComProc + RemoveStateChanged ComProc + GetUri ComProc + GetContentDisposition ComProc + GetMimeType ComProc + GetTotalBytesToReceive ComProc + GetBytesReceived ComProc + GetEstimatedEndTime ComProc + GetResultFilePath ComProc + GetState ComProc + GetInterruptReason ComProc + Cancel ComProc + Pause ComProc + Resume ComProc + GetCanResume ComProc } type ICoreWebView2DownloadOperation struct { Vtbl *ICoreWebView2DownloadOperationVtbl } -func (i *ICoreWebView2DownloadOperation) AddRef() uintptr { +func (i *ICoreWebView2DownloadOperation) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2DownloadOperation) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2DownloadOperation) AddBytesReceivedChanged(eventHandler *ICoreWebView2BytesReceivedChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddBytesReceivedChanged.Call( + hr, _, err := i.Vtbl.AddBytesReceivedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -52,26 +57,27 @@ func (i *ICoreWebView2DownloadOperation) AddBytesReceivedChanged(eventHandler *I if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2DownloadOperation) RemoveBytesReceivedChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveBytesReceivedChanged.Call( + + hr, _, err := i.Vtbl.RemoveBytesReceivedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadOperation) AddEstimatedEndTimeChanged(eventHandler *ICoreWebView2EstimatedEndTimeChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddEstimatedEndTimeChanged.Call( + hr, _, err := i.Vtbl.AddEstimatedEndTimeChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -79,26 +85,27 @@ func (i *ICoreWebView2DownloadOperation) AddEstimatedEndTimeChanged(eventHandler if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2DownloadOperation) RemoveEstimatedEndTimeChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveEstimatedEndTimeChanged.Call( + + hr, _, err := i.Vtbl.RemoveEstimatedEndTimeChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadOperation) AddStateChanged(eventHandler *ICoreWebView2StateChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddStateChanged.Call( + hr, _, err := i.Vtbl.AddStateChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -106,28 +113,30 @@ func (i *ICoreWebView2DownloadOperation) AddStateChanged(eventHandler *ICoreWebV if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2DownloadOperation) RemoveStateChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveStateChanged.Call( + + hr, _, err := i.Vtbl.RemoveStateChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadOperation) GetUri() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -135,16 +144,17 @@ func (i *ICoreWebView2DownloadOperation) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2DownloadOperation) GetContentDisposition() (string, error) { // Create *uint16 to hold result var _contentDisposition *uint16 - hr, _, _ := i.Vtbl.GetContentDisposition.Call( + + hr, _, err := i.Vtbl.GetContentDisposition.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_contentDisposition)), + uintptr(unsafe.Pointer(&_contentDisposition)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -152,16 +162,17 @@ func (i *ICoreWebView2DownloadOperation) GetContentDisposition() (string, error) // Get result and cleanup contentDisposition := UTF16PtrToString(_contentDisposition) CoTaskMemFree(unsafe.Pointer(_contentDisposition)) - return contentDisposition, nil + return contentDisposition, err } func (i *ICoreWebView2DownloadOperation) GetMimeType() (string, error) { // Create *uint16 to hold result var _mimeType *uint16 - hr, _, _ := i.Vtbl.GetMimeType.Call( + + hr, _, err := i.Vtbl.GetMimeType.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_mimeType)), + uintptr(unsafe.Pointer(&_mimeType)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -169,44 +180,45 @@ func (i *ICoreWebView2DownloadOperation) GetMimeType() (string, error) { // Get result and cleanup mimeType := UTF16PtrToString(_mimeType) CoTaskMemFree(unsafe.Pointer(_mimeType)) - return mimeType, nil + return mimeType, err } func (i *ICoreWebView2DownloadOperation) GetTotalBytesToReceive() (int64, error) { var totalBytesToReceive int64 - hr, _, _ := i.Vtbl.GetTotalBytesToReceive.Call( + hr, _, err := i.Vtbl.GetTotalBytesToReceive.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&totalBytesToReceive)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return totalBytesToReceive, nil + return totalBytesToReceive, err } func (i *ICoreWebView2DownloadOperation) GetBytesReceived() (int64, error) { var bytesReceived int64 - hr, _, _ := i.Vtbl.GetBytesReceived.Call( + hr, _, err := i.Vtbl.GetBytesReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bytesReceived)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return bytesReceived, nil + return bytesReceived, err } func (i *ICoreWebView2DownloadOperation) GetEstimatedEndTime() (string, error) { // Create *uint16 to hold result var _estimatedEndTime *uint16 - hr, _, _ := i.Vtbl.GetEstimatedEndTime.Call( + + hr, _, err := i.Vtbl.GetEstimatedEndTime.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_estimatedEndTime)), + uintptr(unsafe.Pointer(&_estimatedEndTime)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -214,16 +226,17 @@ func (i *ICoreWebView2DownloadOperation) GetEstimatedEndTime() (string, error) { // Get result and cleanup estimatedEndTime := UTF16PtrToString(_estimatedEndTime) CoTaskMemFree(unsafe.Pointer(_estimatedEndTime)) - return estimatedEndTime, nil + return estimatedEndTime, err } func (i *ICoreWebView2DownloadOperation) GetResultFilePath() (string, error) { // Create *uint16 to hold result var _resultFilePath *uint16 - hr, _, _ := i.Vtbl.GetResultFilePath.Call( + + hr, _, err := i.Vtbl.GetResultFilePath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_resultFilePath)), + uintptr(unsafe.Pointer(&_resultFilePath)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -231,75 +244,78 @@ func (i *ICoreWebView2DownloadOperation) GetResultFilePath() (string, error) { // Get result and cleanup resultFilePath := UTF16PtrToString(_resultFilePath) CoTaskMemFree(unsafe.Pointer(_resultFilePath)) - return resultFilePath, nil + return resultFilePath, err } func (i *ICoreWebView2DownloadOperation) GetState() (COREWEBVIEW2_DOWNLOAD_STATE, error) { var downloadState COREWEBVIEW2_DOWNLOAD_STATE - hr, _, _ := i.Vtbl.GetState.Call( + hr, _, err := i.Vtbl.GetState.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&downloadState)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return downloadState, nil + return downloadState, err } func (i *ICoreWebView2DownloadOperation) GetInterruptReason() (COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON, error) { var interruptReason COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON - hr, _, _ := i.Vtbl.GetInterruptReason.Call( + hr, _, err := i.Vtbl.GetInterruptReason.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&interruptReason)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return interruptReason, nil + return interruptReason, err } func (i *ICoreWebView2DownloadOperation) Cancel() error { - hr, _, _ := i.Vtbl.Cancel.Call( + + hr, _, err := i.Vtbl.Cancel.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadOperation) Pause() error { - hr, _, _ := i.Vtbl.Pause.Call( + + hr, _, err := i.Vtbl.Pause.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadOperation) Resume() error { - hr, _, _ := i.Vtbl.Resume.Call( + + hr, _, err := i.Vtbl.Resume.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadOperation) GetCanResume() (bool, error) { // Create int32 to hold bool result var _canResume int32 - hr, _, _ := i.Vtbl.GetCanResume.Call( + hr, _, err := i.Vtbl.GetCanResume.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_canResume)), ) @@ -307,6 +323,6 @@ func (i *ICoreWebView2DownloadOperation) GetCanResume() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - canResume := _canResume != 0 - return canResume, nil + canResume := _canResume != 0 + return canResume, err } diff --git a/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go index ac63d869f52..2b8ac81cc8b 100644 --- a/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go @@ -1,53 +1,58 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2DownloadStartingEventArgsVtbl struct { IUnknownVtbl GetDownloadOperation ComProc - GetCancel ComProc - PutCancel ComProc - GetResultFilePath ComProc - PutResultFilePath ComProc - GetHandled ComProc - PutHandled ComProc - GetDeferral ComProc + GetCancel ComProc + PutCancel ComProc + GetResultFilePath ComProc + PutResultFilePath ComProc + GetHandled ComProc + PutHandled ComProc + GetDeferral ComProc } type ICoreWebView2DownloadStartingEventArgs struct { Vtbl *ICoreWebView2DownloadStartingEventArgsVtbl } -func (i *ICoreWebView2DownloadStartingEventArgs) AddRef() uintptr { +func (i *ICoreWebView2DownloadStartingEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DownloadStartingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2DownloadStartingEventArgs) GetDownloadOperation() (*ICoreWebView2DownloadOperation, error) { var downloadOperation *ICoreWebView2DownloadOperation - hr, _, _ := i.Vtbl.GetDownloadOperation.Call( + hr, _, err := i.Vtbl.GetDownloadOperation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&downloadOperation)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return downloadOperation, nil + return downloadOperation, err } func (i *ICoreWebView2DownloadStartingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _cancel int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_cancel)), ) @@ -55,29 +60,36 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetCancel() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - cancel := _cancel != 0 - return cancel, nil + cancel := _cancel != 0 + return cancel, err } func (i *ICoreWebView2DownloadStartingEventArgs) PutCancel(cancel bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _cancel int32 + if cancel { + _cancel = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&cancel)), + uintptr(_cancel), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadStartingEventArgs) GetResultFilePath() (string, error) { // Create *uint16 to hold result var _resultFilePath *uint16 - hr, _, _ := i.Vtbl.GetResultFilePath.Call( + + hr, _, err := i.Vtbl.GetResultFilePath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_resultFilePath)), + uintptr(unsafe.Pointer(&_resultFilePath)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -85,7 +97,7 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetResultFilePath() (string, er // Get result and cleanup resultFilePath := UTF16PtrToString(_resultFilePath) CoTaskMemFree(unsafe.Pointer(_resultFilePath)) - return resultFilePath, nil + return resultFilePath, err } func (i *ICoreWebView2DownloadStartingEventArgs) PutResultFilePath(resultFilePath string) error { @@ -96,21 +108,21 @@ func (i *ICoreWebView2DownloadStartingEventArgs) PutResultFilePath(resultFilePat return err } - hr, _, _ := i.Vtbl.PutResultFilePath.Call( + hr, _, err := i.Vtbl.PutResultFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_resultFilePath)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadStartingEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _handled int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_handled)), ) @@ -118,32 +130,38 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetHandled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - handled := _handled != 0 - return handled, nil + handled := _handled != 0 + return handled, err } func (i *ICoreWebView2DownloadStartingEventArgs) PutHandled(handled bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _handled int32 + if handled { + _handled = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&handled)), + uintptr(_handled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2DownloadStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventHandler.go index cf925e1159c..4763033f88d 100644 --- a/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2DownloadStartingEventHandler struct { impl ICoreWebView2DownloadStartingEventHandlerImpl } -func (i *ICoreWebView2DownloadStartingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2DownloadStartingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2DownloadStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2DownloadStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2DownloadStartingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2DownloadStartingEventHandlerIUnknownQueryInterface(this *ICore } func ICoreWebView2DownloadStartingEventHandlerIUnknownAddRef(this *ICoreWebView2DownloadStartingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2DownloadStartingEventHandlerIUnknownRelease(this *ICoreWebView2DownloadStartingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2DownloadStartingEventHandlerInvoke(this *ICoreWebView2DownloadStartingEventHandler, sender *ICoreWebView2, args *ICoreWebView2DownloadStartingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2DownloadStartingEventHandlerImpl interface { } var ICoreWebView2DownloadStartingEventHandlerFn = ICoreWebView2DownloadStartingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2DownloadStartingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2DownloadStartingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2DownloadStartingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Environment.go b/webview2/pkg/webview2/ICoreWebView2Environment.go index 91aae99e4d4..27e5e30904d 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment.go @@ -1,19 +1,18 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentVtbl struct { IUnknownVtbl - CreateCoreWebView2Controller ComProc - CreateWebResourceResponse ComProc - GetBrowserVersionString ComProc - AddNewBrowserVersionAvailable ComProc + CreateCoreWebView2Controller ComProc + CreateWebResourceResponse ComProc + GetBrowserVersionString ComProc + AddNewBrowserVersionAvailable ComProc RemoveNewBrowserVersionAvailable ComProc } @@ -21,14 +20,21 @@ type ICoreWebView2Environment struct { Vtbl *ICoreWebView2EnvironmentVtbl } -func (i *ICoreWebView2Environment) AddRef() uintptr { +func (i *ICoreWebView2Environment) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2Environment) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2Environment) CreateCoreWebView2Controller(parentWindow HWND, handler *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) error { - hr, _, _ := i.Vtbl.CreateCoreWebView2Controller.Call( + + hr, _, err := i.Vtbl.CreateCoreWebView2Controller.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&parentWindow)), uintptr(unsafe.Pointer(handler)), @@ -36,7 +42,7 @@ func (i *ICoreWebView2Environment) CreateCoreWebView2Controller(parentWindow HWN if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Environment) CreateWebResourceResponse(content *IStream, statusCode int, reasonPhrase string, headers string) (*ICoreWebView2WebResourceResponse, error) { @@ -53,7 +59,7 @@ func (i *ICoreWebView2Environment) CreateWebResourceResponse(content *IStream, s } var response *ICoreWebView2WebResourceResponse - hr, _, _ := i.Vtbl.CreateWebResourceResponse.Call( + hr, _, err := i.Vtbl.CreateWebResourceResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(content)), uintptr(statusCode), @@ -64,16 +70,17 @@ func (i *ICoreWebView2Environment) CreateWebResourceResponse(content *IStream, s if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return response, nil + return response, err } func (i *ICoreWebView2Environment) GetBrowserVersionString() (string, error) { // Create *uint16 to hold result var _versionInfo *uint16 - hr, _, _ := i.Vtbl.GetBrowserVersionString.Call( + + hr, _, err := i.Vtbl.GetBrowserVersionString.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_versionInfo)), + uintptr(unsafe.Pointer(&_versionInfo)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -81,14 +88,14 @@ func (i *ICoreWebView2Environment) GetBrowserVersionString() (string, error) { // Get result and cleanup versionInfo := UTF16PtrToString(_versionInfo) CoTaskMemFree(unsafe.Pointer(_versionInfo)) - return versionInfo, nil + return versionInfo, err } func (i *ICoreWebView2Environment) AddNewBrowserVersionAvailable(eventHandler *ICoreWebView2NewBrowserVersionAvailableEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNewBrowserVersionAvailable.Call( + hr, _, err := i.Vtbl.AddNewBrowserVersionAvailable.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -96,17 +103,18 @@ func (i *ICoreWebView2Environment) AddNewBrowserVersionAvailable(eventHandler *I if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Environment) RemoveNewBrowserVersionAvailable(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNewBrowserVersionAvailable.Call( + + hr, _, err := i.Vtbl.RemoveNewBrowserVersionAvailable.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment10.go b/webview2/pkg/webview2/ICoreWebView2Environment10.go index a763a979c0e..ac506e9a60a 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment10.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment10.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment10Vtbl struct { IUnknownVtbl - CreateCoreWebView2ControllerOptions ComProc - CreateCoreWebView2ControllerWithOptions ComProc + CreateCoreWebView2ControllerOptions ComProc + CreateCoreWebView2ControllerWithOptions ComProc CreateCoreWebView2CompositionControllerWithOptions ComProc } @@ -19,40 +18,50 @@ type ICoreWebView2Environment10 struct { Vtbl *ICoreWebView2Environment10Vtbl } -func (i *ICoreWebView2Environment10) AddRef() uintptr { +func (i *ICoreWebView2Environment10) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment10) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment10() *ICoreWebView2Environment10 { + +func (i *ICoreWebView2) GetICoreWebView2Environment10() (*ICoreWebView2Environment10, error) { var result *ICoreWebView2Environment10 iidICoreWebView2Environment10 := NewGUID("{ee0eb9df-6f12-46ce-b53f-3f47b9c928e0}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment10)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment10) CreateCoreWebView2ControllerOptions() (*ICoreWebView2ControllerOptions, error) { var value *ICoreWebView2ControllerOptions - hr, _, _ := i.Vtbl.CreateCoreWebView2ControllerOptions.Call( + hr, _, err := i.Vtbl.CreateCoreWebView2ControllerOptions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Environment10) CreateCoreWebView2ControllerWithOptions(ParentWindow HWND, options *ICoreWebView2ControllerOptions, handler *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) error { - hr, _, _ := i.Vtbl.CreateCoreWebView2ControllerWithOptions.Call( + + hr, _, err := i.Vtbl.CreateCoreWebView2ControllerWithOptions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&ParentWindow)), uintptr(unsafe.Pointer(options)), @@ -61,12 +70,13 @@ func (i *ICoreWebView2Environment10) CreateCoreWebView2ControllerWithOptions(Par if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Environment10) CreateCoreWebView2CompositionControllerWithOptions(ParentWindow HWND, options *ICoreWebView2ControllerOptions, handler *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) error { - hr, _, _ := i.Vtbl.CreateCoreWebView2CompositionControllerWithOptions.Call( + + hr, _, err := i.Vtbl.CreateCoreWebView2CompositionControllerWithOptions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&ParentWindow)), uintptr(unsafe.Pointer(options)), @@ -75,5 +85,5 @@ func (i *ICoreWebView2Environment10) CreateCoreWebView2CompositionControllerWith if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment11.go b/webview2/pkg/webview2/ICoreWebView2Environment11.go index 01c1750babf..a178efde0a8 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment11.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment11.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment11Vtbl struct { @@ -17,30 +16,40 @@ type ICoreWebView2Environment11 struct { Vtbl *ICoreWebView2Environment11Vtbl } -func (i *ICoreWebView2Environment11) AddRef() uintptr { +func (i *ICoreWebView2Environment11) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment11) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment11() *ICoreWebView2Environment11 { + +func (i *ICoreWebView2) GetICoreWebView2Environment11() (*ICoreWebView2Environment11, error) { var result *ICoreWebView2Environment11 iidICoreWebView2Environment11 := NewGUID("{f0913dc6-a0ec-42ef-9805-91dff3a2966a}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment11)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment11) GetFailureReportFolderPath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetFailureReportFolderPath.Call( + + hr, _, err := i.Vtbl.GetFailureReportFolderPath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,5 +57,5 @@ func (i *ICoreWebView2Environment11) GetFailureReportFolderPath() (string, error // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment12.go b/webview2/pkg/webview2/ICoreWebView2Environment12.go index f90c8d1e88f..05612beed60 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment12.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment12.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment12Vtbl struct { @@ -17,34 +16,43 @@ type ICoreWebView2Environment12 struct { Vtbl *ICoreWebView2Environment12Vtbl } -func (i *ICoreWebView2Environment12) AddRef() uintptr { +func (i *ICoreWebView2Environment12) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment12) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment12() *ICoreWebView2Environment12 { + +func (i *ICoreWebView2) GetICoreWebView2Environment12() (*ICoreWebView2Environment12, error) { var result *ICoreWebView2Environment12 iidICoreWebView2Environment12 := NewGUID("{f503db9b-739f-48dd-b151-fdfcf253f54e}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment12)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment12) CreateSharedBuffer(Size uint64) (*ICoreWebView2SharedBuffer, error) { var value *ICoreWebView2SharedBuffer - hr, _, _ := i.Vtbl.CreateSharedBuffer.Call( + hr, _, err := i.Vtbl.CreateSharedBuffer.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&Size)), + uintptr(Size), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment13.go b/webview2/pkg/webview2/ICoreWebView2Environment13.go index 827acfcc016..27efa9e9c02 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment13.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment13.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment13Vtbl struct { @@ -17,31 +16,41 @@ type ICoreWebView2Environment13 struct { Vtbl *ICoreWebView2Environment13Vtbl } -func (i *ICoreWebView2Environment13) AddRef() uintptr { +func (i *ICoreWebView2Environment13) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment13) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment13() *ICoreWebView2Environment13 { + +func (i *ICoreWebView2) GetICoreWebView2Environment13() (*ICoreWebView2Environment13, error) { var result *ICoreWebView2Environment13 iidICoreWebView2Environment13 := NewGUID("{af641f58-72b2-11ee-b962-0242ac120002}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment13)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment13) GetProcessExtendedInfos(handler *ICoreWebView2GetProcessExtendedInfosCompletedHandler) error { - hr, _, _ := i.Vtbl.GetProcessExtendedInfos.Call( + + hr, _, err := i.Vtbl.GetProcessExtendedInfos.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment14.go b/webview2/pkg/webview2/ICoreWebView2Environment14.go index ec7605dc5c8..dd97e432159 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment14.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment14.go @@ -1,41 +1,49 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment14Vtbl struct { IUnknownVtbl - CreateWebFileSystemFileHandle ComProc + CreateWebFileSystemFileHandle ComProc CreateWebFileSystemDirectoryHandle ComProc - CreateObjectCollection ComProc + CreateObjectCollection ComProc } type ICoreWebView2Environment14 struct { Vtbl *ICoreWebView2Environment14Vtbl } -func (i *ICoreWebView2Environment14) AddRef() uintptr { +func (i *ICoreWebView2Environment14) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment14) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment14() *ICoreWebView2Environment14 { + +func (i *ICoreWebView2) GetICoreWebView2Environment14() (*ICoreWebView2Environment14, error) { var result *ICoreWebView2Environment14 iidICoreWebView2Environment14 := NewGUID("{a5e9fad9-c875-59da-9bd7-473aa5ca1cef}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment14)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment14) CreateWebFileSystemFileHandle(path string, permission COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION) (*ICoreWebView2FileSystemHandle, error) { // Convert string 'path' to *uint16 @@ -45,7 +53,7 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemFileHandle(path string, } var value *ICoreWebView2FileSystemHandle - hr, _, _ := i.Vtbl.CreateWebFileSystemFileHandle.Call( + hr, _, err := i.Vtbl.CreateWebFileSystemFileHandle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_path)), uintptr(permission), @@ -54,7 +62,7 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemFileHandle(path string, if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Environment14) CreateWebFileSystemDirectoryHandle(path string, permission COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION) (*ICoreWebView2FileSystemHandle, error) { @@ -66,7 +74,7 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemDirectoryHandle(path str } var value *ICoreWebView2FileSystemHandle - hr, _, _ := i.Vtbl.CreateWebFileSystemDirectoryHandle.Call( + hr, _, err := i.Vtbl.CreateWebFileSystemDirectoryHandle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_path)), uintptr(permission), @@ -75,21 +83,21 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemDirectoryHandle(path str if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Environment14) CreateObjectCollection(length uint32, items **IUnknown) (*ICoreWebView2ObjectCollection, error) { var objectCollection *ICoreWebView2ObjectCollection - hr, _, _ := i.Vtbl.CreateObjectCollection.Call( + hr, _, err := i.Vtbl.CreateObjectCollection.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&length)), + uintptr(length), uintptr(unsafe.Pointer(&items)), uintptr(unsafe.Pointer(&objectCollection)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return objectCollection, nil + return objectCollection, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment2.go b/webview2/pkg/webview2/ICoreWebView2Environment2.go index 914cce3a87a..cf10892ca7b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment2.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment2Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2Environment2 struct { Vtbl *ICoreWebView2Environment2Vtbl } -func (i *ICoreWebView2Environment2) AddRef() uintptr { +func (i *ICoreWebView2Environment2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment2() *ICoreWebView2Environment2 { + +func (i *ICoreWebView2) GetICoreWebView2Environment2() (*ICoreWebView2Environment2, error) { var result *ICoreWebView2Environment2 iidICoreWebView2Environment2 := NewGUID("{41f3632b-5ef4-404f-ad82-2d606c5a9a21}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment2) CreateWebResourceRequest(uri string, Method string, postData *IStream, Headers string) (*ICoreWebView2WebResourceRequest, error) { // Convert string 'uri' to *uint16 @@ -53,7 +61,7 @@ func (i *ICoreWebView2Environment2) CreateWebResourceRequest(uri string, Method } var value *ICoreWebView2WebResourceRequest - hr, _, _ := i.Vtbl.CreateWebResourceRequest.Call( + hr, _, err := i.Vtbl.CreateWebResourceRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(unsafe.Pointer(_Method)), @@ -64,5 +72,5 @@ func (i *ICoreWebView2Environment2) CreateWebResourceRequest(uri string, Method if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment3.go b/webview2/pkg/webview2/ICoreWebView2Environment3.go index 58fbec80005..d0f9cb884c0 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment3.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment3.go @@ -1,43 +1,52 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment3Vtbl struct { IUnknownVtbl CreateCoreWebView2CompositionController ComProc - CreateCoreWebView2PointerInfo ComProc + CreateCoreWebView2PointerInfo ComProc } type ICoreWebView2Environment3 struct { Vtbl *ICoreWebView2Environment3Vtbl } -func (i *ICoreWebView2Environment3) AddRef() uintptr { +func (i *ICoreWebView2Environment3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment3() *ICoreWebView2Environment3 { + +func (i *ICoreWebView2) GetICoreWebView2Environment3() (*ICoreWebView2Environment3, error) { var result *ICoreWebView2Environment3 iidICoreWebView2Environment3 := NewGUID("{80a22ae3-be7c-4ce2-afe1-5a50056cdeeb}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment3) CreateCoreWebView2CompositionController(ParentWindow HWND, handler *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) error { - hr, _, _ := i.Vtbl.CreateCoreWebView2CompositionController.Call( + + hr, _, err := i.Vtbl.CreateCoreWebView2CompositionController.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&ParentWindow)), uintptr(unsafe.Pointer(handler)), @@ -45,19 +54,19 @@ func (i *ICoreWebView2Environment3) CreateCoreWebView2CompositionController(Pare if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Environment3) CreateCoreWebView2PointerInfo() (*ICoreWebView2PointerInfo, error) { var value *ICoreWebView2PointerInfo - hr, _, _ := i.Vtbl.CreateCoreWebView2PointerInfo.Call( + hr, _, err := i.Vtbl.CreateCoreWebView2PointerInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment4.go b/webview2/pkg/webview2/ICoreWebView2Environment4.go index 3be765ff534..66a8d1452ee 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment4.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment4.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment4Vtbl struct { @@ -17,28 +16,37 @@ type ICoreWebView2Environment4 struct { Vtbl *ICoreWebView2Environment4Vtbl } -func (i *ICoreWebView2Environment4) AddRef() uintptr { +func (i *ICoreWebView2Environment4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment4() *ICoreWebView2Environment4 { + +func (i *ICoreWebView2) GetICoreWebView2Environment4() (*ICoreWebView2Environment4, error) { var result *ICoreWebView2Environment4 iidICoreWebView2Environment4 := NewGUID("{20944379-6dcf-41d6-a0a0-abc0fc50de0d}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment4) GetAutomationProviderForWindow(hwnd HWND) (*IUnknown, error) { var value *IUnknown - hr, _, _ := i.Vtbl.GetAutomationProviderForWindow.Call( + hr, _, err := i.Vtbl.GetAutomationProviderForWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&hwnd)), uintptr(unsafe.Pointer(&value)), @@ -46,5 +54,5 @@ func (i *ICoreWebView2Environment4) GetAutomationProviderForWindow(hwnd HWND) (* if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment5.go b/webview2/pkg/webview2/ICoreWebView2Environment5.go index cd7060f7cb3..9c984d7b51b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment5.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment5.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment5Vtbl struct { IUnknownVtbl - AddBrowserProcessExited ComProc + AddBrowserProcessExited ComProc RemoveBrowserProcessExited ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2Environment5 struct { Vtbl *ICoreWebView2Environment5Vtbl } -func (i *ICoreWebView2Environment5) AddRef() uintptr { +func (i *ICoreWebView2Environment5) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment5() *ICoreWebView2Environment5 { + +func (i *ICoreWebView2) GetICoreWebView2Environment5() (*ICoreWebView2Environment5, error) { var result *ICoreWebView2Environment5 iidICoreWebView2Environment5 := NewGUID("{319e423d-e0d7-4b8d-9254-ae9475de9b17}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment5)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment5) AddBrowserProcessExited(eventHandler *ICoreWebView2BrowserProcessExitedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddBrowserProcessExited.Call( + hr, _, err := i.Vtbl.AddBrowserProcessExited.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2Environment5) AddBrowserProcessExited(eventHandler *ICoreW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Environment5) RemoveBrowserProcessExited(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveBrowserProcessExited.Call( + + hr, _, err := i.Vtbl.RemoveBrowserProcessExited.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment6.go b/webview2/pkg/webview2/ICoreWebView2Environment6.go index 5265f7d2fb0..453a51fd70c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment6.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment6.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment6Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2Environment6 struct { Vtbl *ICoreWebView2Environment6Vtbl } -func (i *ICoreWebView2Environment6) AddRef() uintptr { +func (i *ICoreWebView2Environment6) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment6) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment6() *ICoreWebView2Environment6 { + +func (i *ICoreWebView2) GetICoreWebView2Environment6() (*ICoreWebView2Environment6, error) { var result *ICoreWebView2Environment6 iidICoreWebView2Environment6 := NewGUID("{e59ee362-acbd-4857-9a8e-d3644d9459a9}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment6)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment6) CreatePrintSettings() (*ICoreWebView2PrintSettings, error) { var value *ICoreWebView2PrintSettings - hr, _, _ := i.Vtbl.CreatePrintSettings.Call( + hr, _, err := i.Vtbl.CreatePrintSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment7.go b/webview2/pkg/webview2/ICoreWebView2Environment7.go index e4a652f46a1..b475f57289a 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment7.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment7.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment7Vtbl struct { @@ -17,30 +16,40 @@ type ICoreWebView2Environment7 struct { Vtbl *ICoreWebView2Environment7Vtbl } -func (i *ICoreWebView2Environment7) AddRef() uintptr { +func (i *ICoreWebView2Environment7) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment7) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment7() *ICoreWebView2Environment7 { + +func (i *ICoreWebView2) GetICoreWebView2Environment7() (*ICoreWebView2Environment7, error) { var result *ICoreWebView2Environment7 iidICoreWebView2Environment7 := NewGUID("{43c22296-3bbd-43a4-9c00-5c0df6dd29a2}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment7)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment7) GetUserDataFolder() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetUserDataFolder.Call( + + hr, _, err := i.Vtbl.GetUserDataFolder.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,5 +57,5 @@ func (i *ICoreWebView2Environment7) GetUserDataFolder() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment8.go b/webview2/pkg/webview2/ICoreWebView2Environment8.go index 9894aef1dcd..1d5d1d726cf 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment8.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment8.go @@ -1,46 +1,54 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment8Vtbl struct { IUnknownVtbl - AddProcessInfosChanged ComProc + AddProcessInfosChanged ComProc RemoveProcessInfosChanged ComProc - GetProcessInfos ComProc + GetProcessInfos ComProc } type ICoreWebView2Environment8 struct { Vtbl *ICoreWebView2Environment8Vtbl } -func (i *ICoreWebView2Environment8) AddRef() uintptr { +func (i *ICoreWebView2Environment8) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment8) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment8() *ICoreWebView2Environment8 { + +func (i *ICoreWebView2) GetICoreWebView2Environment8() (*ICoreWebView2Environment8, error) { var result *ICoreWebView2Environment8 iidICoreWebView2Environment8 := NewGUID("{d6eb91dd-c3d2-45e5-bd29-6dc2bc4de9cf}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment8)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment8) AddProcessInfosChanged(eventHandler *ICoreWebView2ProcessInfosChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddProcessInfosChanged.Call( + hr, _, err := i.Vtbl.AddProcessInfosChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -48,31 +56,32 @@ func (i *ICoreWebView2Environment8) AddProcessInfosChanged(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Environment8) RemoveProcessInfosChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveProcessInfosChanged.Call( + + hr, _, err := i.Vtbl.RemoveProcessInfosChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Environment8) GetProcessInfos() (*ICoreWebView2ProcessInfoCollection, error) { var value *ICoreWebView2ProcessInfoCollection - hr, _, _ := i.Vtbl.GetProcessInfos.Call( + hr, _, err := i.Vtbl.GetProcessInfos.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment9.go b/webview2/pkg/webview2/ICoreWebView2Environment9.go index e324c440c25..25fc49e610e 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment9.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment9.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Environment9Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2Environment9 struct { Vtbl *ICoreWebView2Environment9Vtbl } -func (i *ICoreWebView2Environment9) AddRef() uintptr { +func (i *ICoreWebView2Environment9) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment9) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Environment9() *ICoreWebView2Environment9 { + +func (i *ICoreWebView2) GetICoreWebView2Environment9() (*ICoreWebView2Environment9, error) { var result *ICoreWebView2Environment9 iidICoreWebView2Environment9 := NewGUID("{f06f41bf-4b5a-49d8-b9f6-fa16cd29f274}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Environment9)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Environment9) CreateContextMenuItem(Label string, iconStream *IStream, Kind COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND) (*ICoreWebView2ContextMenuItem, error) { // Convert string 'Label' to *uint16 @@ -43,7 +51,7 @@ func (i *ICoreWebView2Environment9) CreateContextMenuItem(Label string, iconStre } var value *ICoreWebView2ContextMenuItem - hr, _, _ := i.Vtbl.CreateContextMenuItem.Call( + hr, _, err := i.Vtbl.CreateContextMenuItem.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_Label)), uintptr(unsafe.Pointer(iconStream)), @@ -53,5 +61,5 @@ func (i *ICoreWebView2Environment9) CreateContextMenuItem(Label string, iconStre if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go index 061f78e3681..8133c0b6924 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go @@ -1,21 +1,20 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptionsVtbl struct { IUnknownVtbl - GetAdditionalBrowserArguments ComProc - PutAdditionalBrowserArguments ComProc - GetLanguage ComProc - PutLanguage ComProc - GetTargetCompatibleBrowserVersion ComProc - PutTargetCompatibleBrowserVersion ComProc + GetAdditionalBrowserArguments ComProc + PutAdditionalBrowserArguments ComProc + GetLanguage ComProc + PutLanguage ComProc + GetTargetCompatibleBrowserVersion ComProc + PutTargetCompatibleBrowserVersion ComProc GetAllowSingleSignOnUsingOSPrimaryAccount ComProc PutAllowSingleSignOnUsingOSPrimaryAccount ComProc } @@ -24,18 +23,25 @@ type ICoreWebView2EnvironmentOptions struct { Vtbl *ICoreWebView2EnvironmentOptionsVtbl } -func (i *ICoreWebView2EnvironmentOptions) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions) GetAdditionalBrowserArguments() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetAdditionalBrowserArguments.Call( + + hr, _, err := i.Vtbl.GetAdditionalBrowserArguments.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -43,7 +49,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetAdditionalBrowserArguments() (strin // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2EnvironmentOptions) PutAdditionalBrowserArguments(value string) error { @@ -54,23 +60,24 @@ func (i *ICoreWebView2EnvironmentOptions) PutAdditionalBrowserArguments(value st return err } - hr, _, _ := i.Vtbl.PutAdditionalBrowserArguments.Call( + hr, _, err := i.Vtbl.PutAdditionalBrowserArguments.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2EnvironmentOptions) GetLanguage() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetLanguage.Call( + + hr, _, err := i.Vtbl.GetLanguage.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -78,7 +85,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetLanguage() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2EnvironmentOptions) PutLanguage(value string) error { @@ -89,23 +96,24 @@ func (i *ICoreWebView2EnvironmentOptions) PutLanguage(value string) error { return err } - hr, _, _ := i.Vtbl.PutLanguage.Call( + hr, _, err := i.Vtbl.PutLanguage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2EnvironmentOptions) GetTargetCompatibleBrowserVersion() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetTargetCompatibleBrowserVersion.Call( + + hr, _, err := i.Vtbl.GetTargetCompatibleBrowserVersion.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -113,7 +121,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetTargetCompatibleBrowserVersion() (s // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2EnvironmentOptions) PutTargetCompatibleBrowserVersion(value string) error { @@ -124,21 +132,21 @@ func (i *ICoreWebView2EnvironmentOptions) PutTargetCompatibleBrowserVersion(valu return err } - hr, _, _ := i.Vtbl.PutTargetCompatibleBrowserVersion.Call( + hr, _, err := i.Vtbl.PutTargetCompatibleBrowserVersion.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2EnvironmentOptions) GetAllowSingleSignOnUsingOSPrimaryAccount() (bool, error) { // Create int32 to hold bool result var _allow int32 - hr, _, _ := i.Vtbl.GetAllowSingleSignOnUsingOSPrimaryAccount.Call( + hr, _, err := i.Vtbl.GetAllowSingleSignOnUsingOSPrimaryAccount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_allow)), ) @@ -146,18 +154,24 @@ func (i *ICoreWebView2EnvironmentOptions) GetAllowSingleSignOnUsingOSPrimaryAcco return false, syscall.Errno(hr) } // Get result and cleanup - allow := _allow != 0 - return allow, nil + allow := _allow != 0 + return allow, err } func (i *ICoreWebView2EnvironmentOptions) PutAllowSingleSignOnUsingOSPrimaryAccount(allow bool) error { - hr, _, _ := i.Vtbl.PutAllowSingleSignOnUsingOSPrimaryAccount.Call( + // Convert Go bool to COM BOOL (int32) + var _allow int32 + if allow { + _allow = 1 + } + + hr, _, err := i.Vtbl.PutAllowSingleSignOnUsingOSPrimaryAccount.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&allow)), + uintptr(_allow), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go index 4acef949498..7f4c263fc6b 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions2Vtbl struct { @@ -18,16 +17,22 @@ type ICoreWebView2EnvironmentOptions2 struct { Vtbl *ICoreWebView2EnvironmentOptions2Vtbl } -func (i *ICoreWebView2EnvironmentOptions2) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions2) GetExclusiveUserDataFolderAccess() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetExclusiveUserDataFolderAccess.Call( + hr, _, err := i.Vtbl.GetExclusiveUserDataFolderAccess.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -35,18 +40,24 @@ func (i *ICoreWebView2EnvironmentOptions2) GetExclusiveUserDataFolderAccess() (b return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2EnvironmentOptions2) PutExclusiveUserDataFolderAccess(value bool) error { - hr, _, _ := i.Vtbl.PutExclusiveUserDataFolderAccess.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutExclusiveUserDataFolderAccess.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go index 9e1aad36455..b19d353261f 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions3Vtbl struct { @@ -18,16 +17,22 @@ type ICoreWebView2EnvironmentOptions3 struct { Vtbl *ICoreWebView2EnvironmentOptions3Vtbl } -func (i *ICoreWebView2EnvironmentOptions3) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions3) GetIsCustomCrashReportingEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsCustomCrashReportingEnabled.Call( + hr, _, err := i.Vtbl.GetIsCustomCrashReportingEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -35,18 +40,24 @@ func (i *ICoreWebView2EnvironmentOptions3) GetIsCustomCrashReportingEnabled() (b return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2EnvironmentOptions3) PutIsCustomCrashReportingEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsCustomCrashReportingEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsCustomCrashReportingEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go index b6753423e8e..5a71f081c3e 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions4Vtbl struct { @@ -18,17 +17,23 @@ type ICoreWebView2EnvironmentOptions4 struct { Vtbl *ICoreWebView2EnvironmentOptions4Vtbl } -func (i *ICoreWebView2EnvironmentOptions4) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions4) GetCustomSchemeRegistrations() (uint32, ICoreWebView2CustomSchemeRegistration, error) { var count uint32 var schemeRegistrations ICoreWebView2CustomSchemeRegistration - hr, _, _ := i.Vtbl.GetCustomSchemeRegistrations.Call( + hr, _, err := i.Vtbl.GetCustomSchemeRegistrations.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&count)), uintptr(unsafe.Pointer(&schemeRegistrations)), @@ -36,18 +41,19 @@ func (i *ICoreWebView2EnvironmentOptions4) GetCustomSchemeRegistrations() (uint3 if windows.Handle(hr) != windows.S_OK { return 0, ICoreWebView2CustomSchemeRegistration{}, syscall.Errno(hr) } - return count, schemeRegistrations, nil + return count, schemeRegistrations, err } func (i *ICoreWebView2EnvironmentOptions4) SetCustomSchemeRegistrations(count uint32, schemeRegistrations **ICoreWebView2CustomSchemeRegistration) error { - hr, _, _ := i.Vtbl.SetCustomSchemeRegistrations.Call( + + hr, _, err := i.Vtbl.SetCustomSchemeRegistrations.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&count)), + uintptr(count), uintptr(unsafe.Pointer(&schemeRegistrations)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go index b213fc60324..2efe04641e7 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions5Vtbl struct { @@ -18,16 +17,22 @@ type ICoreWebView2EnvironmentOptions5 struct { Vtbl *ICoreWebView2EnvironmentOptions5Vtbl } -func (i *ICoreWebView2EnvironmentOptions5) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions5) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions5) GetEnableTrackingPrevention() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetEnableTrackingPrevention.Call( + hr, _, err := i.Vtbl.GetEnableTrackingPrevention.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -35,18 +40,24 @@ func (i *ICoreWebView2EnvironmentOptions5) GetEnableTrackingPrevention() (bool, return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2EnvironmentOptions5) PutEnableTrackingPrevention(value bool) error { - hr, _, _ := i.Vtbl.PutEnableTrackingPrevention.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutEnableTrackingPrevention.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go index 602fc37fbe3..dd35988512c 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions6Vtbl struct { @@ -18,16 +17,22 @@ type ICoreWebView2EnvironmentOptions6 struct { Vtbl *ICoreWebView2EnvironmentOptions6Vtbl } -func (i *ICoreWebView2EnvironmentOptions6) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions6) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions6) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions6) GetAreBrowserExtensionsEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetAreBrowserExtensionsEnabled.Call( + hr, _, err := i.Vtbl.GetAreBrowserExtensionsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -35,18 +40,24 @@ func (i *ICoreWebView2EnvironmentOptions6) GetAreBrowserExtensionsEnabled() (boo return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2EnvironmentOptions6) PutAreBrowserExtensionsEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutAreBrowserExtensionsEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutAreBrowserExtensionsEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go index c6ebda069f3..31bdcfc86fc 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go @@ -1,78 +1,85 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions7Vtbl struct { IUnknownVtbl GetChannelSearchKind ComProc PutChannelSearchKind ComProc - GetReleaseChannels ComProc - PutReleaseChannels ComProc + GetReleaseChannels ComProc + PutReleaseChannels ComProc } type ICoreWebView2EnvironmentOptions7 struct { Vtbl *ICoreWebView2EnvironmentOptions7Vtbl } -func (i *ICoreWebView2EnvironmentOptions7) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions7) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions7) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions7) GetChannelSearchKind() (COREWEBVIEW2_CHANNEL_SEARCH_KIND, error) { var value COREWEBVIEW2_CHANNEL_SEARCH_KIND - hr, _, _ := i.Vtbl.GetChannelSearchKind.Call( + hr, _, err := i.Vtbl.GetChannelSearchKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2EnvironmentOptions7) PutChannelSearchKind(value COREWEBVIEW2_CHANNEL_SEARCH_KIND) error { - hr, _, _ := i.Vtbl.PutChannelSearchKind.Call( + + hr, _, err := i.Vtbl.PutChannelSearchKind.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2EnvironmentOptions7) GetReleaseChannels() (COREWEBVIEW2_RELEASE_CHANNELS, error) { var value COREWEBVIEW2_RELEASE_CHANNELS - hr, _, _ := i.Vtbl.GetReleaseChannels.Call( + hr, _, err := i.Vtbl.GetReleaseChannels.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2EnvironmentOptions7) PutReleaseChannels(value COREWEBVIEW2_RELEASE_CHANNELS) error { - hr, _, _ := i.Vtbl.PutReleaseChannels.Call( + + hr, _, err := i.Vtbl.PutReleaseChannels.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go index 5d666ca9e56..bc943c3719d 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2EnvironmentOptions8Vtbl struct { @@ -18,33 +17,40 @@ type ICoreWebView2EnvironmentOptions8 struct { Vtbl *ICoreWebView2EnvironmentOptions8Vtbl } -func (i *ICoreWebView2EnvironmentOptions8) AddRef() uintptr { +func (i *ICoreWebView2EnvironmentOptions8) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2EnvironmentOptions8) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2EnvironmentOptions8) GetScrollBarStyle() (COREWEBVIEW2_SCROLLBAR_STYLE, error) { var value COREWEBVIEW2_SCROLLBAR_STYLE - hr, _, _ := i.Vtbl.GetScrollBarStyle.Call( + hr, _, err := i.Vtbl.GetScrollBarStyle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2EnvironmentOptions8) PutScrollBarStyle(value COREWEBVIEW2_SCROLLBAR_STYLE) error { - hr, _, _ := i.Vtbl.PutScrollBarStyle.Call( + + hr, _, err := i.Vtbl.PutScrollBarStyle.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2EstimatedEndTimeChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2EstimatedEndTimeChangedEventHandler.go index c171dfe074f..1db614c0e58 100644 --- a/webview2/pkg/webview2/ICoreWebView2EstimatedEndTimeChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2EstimatedEndTimeChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2EstimatedEndTimeChangedEventHandler struct { impl ICoreWebView2EstimatedEndTimeChangedEventHandlerImpl } -func (i *ICoreWebView2EstimatedEndTimeChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2EstimatedEndTimeChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2EstimatedEndTimeChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2EstimatedEndTimeChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownQueryInterface(this } func ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownAddRef(this *ICoreWebView2EstimatedEndTimeChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownRelease(this *ICoreWebView2EstimatedEndTimeChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2EstimatedEndTimeChangedEventHandlerInvoke(this *ICoreWebView2EstimatedEndTimeChangedEventHandler, sender *ICoreWebView2DownloadOperation, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2EstimatedEndTimeChangedEventHandlerImpl interface { } var ICoreWebView2EstimatedEndTimeChangedEventHandlerFn = ICoreWebView2EstimatedEndTimeChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2EstimatedEndTimeChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go index 160b520d071..00ecc34026a 100644 --- a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ExecuteScriptCompletedHandler struct { impl ICoreWebView2ExecuteScriptCompletedHandlerImpl } -func (i *ICoreWebView2ExecuteScriptCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ExecuteScriptCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ExecuteScriptCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ExecuteScriptCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ExecuteScriptCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ExecuteScriptCompletedHandlerIUnknownQueryInterface(this *ICor } func ICoreWebView2ExecuteScriptCompletedHandlerIUnknownAddRef(this *ICoreWebView2ExecuteScriptCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ExecuteScriptCompletedHandlerIUnknownRelease(this *ICoreWebView2ExecuteScriptCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ExecuteScriptCompletedHandlerInvoke(this *ICoreWebView2ExecuteScriptCompletedHandler, errorCode uintptr, result string) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ExecuteScriptCompletedHandlerImpl interface { } var ICoreWebView2ExecuteScriptCompletedHandlerFn = ICoreWebView2ExecuteScriptCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ExecuteScriptCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ExecuteScriptCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ExecuteScriptCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go index 73c5693dc19..1c31e733f0a 100644 --- a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go +++ b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go @@ -1,35 +1,40 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ExecuteScriptResultVtbl struct { IUnknownVtbl - GetSucceeded ComProc - GetResultAsJson ComProc + GetSucceeded ComProc + GetResultAsJson ComProc TryGetResultAsString ComProc - GetException ComProc + GetException ComProc } type ICoreWebView2ExecuteScriptResult struct { Vtbl *ICoreWebView2ExecuteScriptResultVtbl } -func (i *ICoreWebView2ExecuteScriptResult) AddRef() uintptr { +func (i *ICoreWebView2ExecuteScriptResult) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2ExecuteScriptResult) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2ExecuteScriptResult) GetSucceeded() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetSucceeded.Call( + hr, _, err := i.Vtbl.GetSucceeded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -37,17 +42,18 @@ func (i *ICoreWebView2ExecuteScriptResult) GetSucceeded() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ExecuteScriptResult) GetResultAsJson() (string, error) { // Create *uint16 to hold result var _jsonResult *uint16 - hr, _, _ := i.Vtbl.GetResultAsJson.Call( + + hr, _, err := i.Vtbl.GetResultAsJson.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_jsonResult)), + uintptr(unsafe.Pointer(&_jsonResult)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -55,7 +61,7 @@ func (i *ICoreWebView2ExecuteScriptResult) GetResultAsJson() (string, error) { // Get result and cleanup jsonResult := UTF16PtrToString(_jsonResult) CoTaskMemFree(unsafe.Pointer(_jsonResult)) - return jsonResult, nil + return jsonResult, err } func (i *ICoreWebView2ExecuteScriptResult) TryGetResultAsString() (string, bool, error) { @@ -64,9 +70,9 @@ func (i *ICoreWebView2ExecuteScriptResult) TryGetResultAsString() (string, bool, // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.TryGetResultAsString.Call( + hr, _, err := i.Vtbl.TryGetResultAsString.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_stringResult)), + uintptr(unsafe.Pointer(&_stringResult)), uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { @@ -76,20 +82,20 @@ func (i *ICoreWebView2ExecuteScriptResult) TryGetResultAsString() (string, bool, stringResult := UTF16PtrToString(_stringResult) CoTaskMemFree(unsafe.Pointer(_stringResult)) // Get result and cleanup - value := _value != 0 - return stringResult, value, nil + value := _value != 0 + return stringResult, value, err } func (i *ICoreWebView2ExecuteScriptResult) GetException() (*ICoreWebView2ScriptException, error) { var exception *ICoreWebView2ScriptException - hr, _, _ := i.Vtbl.GetException.Call( + hr, _, err := i.Vtbl.GetException.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&exception)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return exception, nil + return exception, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptWithResultCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptWithResultCompletedHandler.go index c0c0430972c..f5c9a85dee8 100644 --- a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptWithResultCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptWithResultCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ExecuteScriptWithResultCompletedHandler struct { impl ICoreWebView2ExecuteScriptWithResultCompletedHandlerImpl } -func (i *ICoreWebView2ExecuteScriptWithResultCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ExecuteScriptWithResultCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ExecuteScriptWithResultCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ExecuteScriptWithResultCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownQueryInterface( } func ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownAddRef(this *ICoreWebView2ExecuteScriptWithResultCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownRelease(this *ICoreWebView2ExecuteScriptWithResultCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ExecuteScriptWithResultCompletedHandlerInvoke(this *ICoreWebView2ExecuteScriptWithResultCompletedHandler, errorCode uintptr, result *ICoreWebView2ExecuteScriptResult) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ExecuteScriptWithResultCompletedHandlerImpl interface { } var ICoreWebView2ExecuteScriptWithResultCompletedHandlerFn = ICoreWebView2ExecuteScriptWithResultCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ExecuteScriptWithResultCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FaviconChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FaviconChangedEventHandler.go index 9cc29b69279..1abfbe806c9 100644 --- a/webview2/pkg/webview2/ICoreWebView2FaviconChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FaviconChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FaviconChangedEventHandler struct { impl ICoreWebView2FaviconChangedEventHandlerImpl } -func (i *ICoreWebView2FaviconChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FaviconChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FaviconChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FaviconChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FaviconChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FaviconChangedEventHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2FaviconChangedEventHandlerIUnknownAddRef(this *ICoreWebView2FaviconChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FaviconChangedEventHandlerIUnknownRelease(this *ICoreWebView2FaviconChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FaviconChangedEventHandlerInvoke(this *ICoreWebView2FaviconChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FaviconChangedEventHandlerImpl interface { } var ICoreWebView2FaviconChangedEventHandlerFn = ICoreWebView2FaviconChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FaviconChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FaviconChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FaviconChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2File.go b/webview2/pkg/webview2/ICoreWebView2File.go index 90089d96b8f..e3e9b0e061d 100644 --- a/webview2/pkg/webview2/ICoreWebView2File.go +++ b/webview2/pkg/webview2/ICoreWebView2File.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FileVtbl struct { @@ -17,18 +16,25 @@ type ICoreWebView2File struct { Vtbl *ICoreWebView2FileVtbl } -func (i *ICoreWebView2File) AddRef() uintptr { +func (i *ICoreWebView2File) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2File) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2File) GetPath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetPath.Call( + + hr, _, err := i.Vtbl.GetPath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -36,5 +42,5 @@ func (i *ICoreWebView2File) GetPath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go b/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go index 1ae6cf36a95..b4be106bf12 100644 --- a/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go +++ b/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FileSystemHandleVtbl struct { IUnknownVtbl - GetKind ComProc - GetPath ComProc + GetKind ComProc + GetPath ComProc GetPermission ComProc } @@ -19,32 +18,39 @@ type ICoreWebView2FileSystemHandle struct { Vtbl *ICoreWebView2FileSystemHandleVtbl } -func (i *ICoreWebView2FileSystemHandle) AddRef() uintptr { +func (i *ICoreWebView2FileSystemHandle) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2FileSystemHandle) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2FileSystemHandle) GetKind() (COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND, error) { var value COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2FileSystemHandle) GetPath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetPath.Call( + + hr, _, err := i.Vtbl.GetPath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -52,19 +58,19 @@ func (i *ICoreWebView2FileSystemHandle) GetPath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2FileSystemHandle) GetPermission() (COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION, error) { var value COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION - hr, _, _ := i.Vtbl.GetPermission.Call( + hr, _, err := i.Vtbl.GetPermission.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FocusChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FocusChangedEventHandler.go index 22b09210e86..5931748103d 100644 --- a/webview2/pkg/webview2/ICoreWebView2FocusChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FocusChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FocusChangedEventHandler struct { impl ICoreWebView2FocusChangedEventHandlerImpl } -func (i *ICoreWebView2FocusChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FocusChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FocusChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FocusChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FocusChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FocusChangedEventHandlerIUnknownQueryInterface(this *ICoreWebV } func ICoreWebView2FocusChangedEventHandlerIUnknownAddRef(this *ICoreWebView2FocusChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FocusChangedEventHandlerIUnknownRelease(this *ICoreWebView2FocusChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FocusChangedEventHandlerInvoke(this *ICoreWebView2FocusChangedEventHandler, sender *ICoreWebView2Controller, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FocusChangedEventHandlerImpl interface { } var ICoreWebView2FocusChangedEventHandlerFn = ICoreWebView2FocusChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FocusChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FocusChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FocusChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Frame.go b/webview2/pkg/webview2/ICoreWebView2Frame.go index 3c08c98ea08..0e71106fbd0 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame.go @@ -1,41 +1,47 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FrameVtbl struct { IUnknownVtbl - GetName ComProc - AddNameChanged ComProc - RemoveNameChanged ComProc + GetName ComProc + AddNameChanged ComProc + RemoveNameChanged ComProc AddHostObjectToScriptWithOrigins ComProc - RemoveHostObjectFromScript ComProc - AddDestroyed ComProc - RemoveDestroyed ComProc - IsDestroyed ComProc + RemoveHostObjectFromScript ComProc + AddDestroyed ComProc + RemoveDestroyed ComProc + IsDestroyed ComProc } type ICoreWebView2Frame struct { Vtbl *ICoreWebView2FrameVtbl } -func (i *ICoreWebView2Frame) AddRef() uintptr { +func (i *ICoreWebView2Frame) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Frame) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2Frame) GetName() (string, error) { // Create *uint16 to hold result var _name *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_name)), + uintptr(unsafe.Pointer(&_name)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -43,14 +49,14 @@ func (i *ICoreWebView2Frame) GetName() (string, error) { // Get result and cleanup name := UTF16PtrToString(_name) CoTaskMemFree(unsafe.Pointer(_name)) - return name, nil + return name, err } func (i *ICoreWebView2Frame) AddNameChanged(eventHandler *ICoreWebView2FrameNameChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNameChanged.Call( + hr, _, err := i.Vtbl.AddNameChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -58,45 +64,54 @@ func (i *ICoreWebView2Frame) AddNameChanged(eventHandler *ICoreWebView2FrameName if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame) RemoveNameChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNameChanged.Call( + + hr, _, err := i.Vtbl.RemoveNameChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } -func (i *ICoreWebView2Frame) AddHostObjectToScriptWithOrigins(name string, object *VARIANT, originsCount uint32, origins string) error { +func (i *ICoreWebView2Frame) AddHostObjectToScriptWithOrigins(name string, object *VARIANT, originsCount uint32, origins []string) error { // Convert string 'name' to *uint16 _name, err := UTF16PtrFromString(name) if err != nil { return err + } // Convert []string 'origins' to **uint16 (LPCWSTR* / LPWSTR*) + _originsptrs := make([]*uint16, len(origins)) + for _i, _s := range origins { + _p, err := UTF16PtrFromString(_s) + if err != nil { + return err + } + _originsptrs[_i] = _p } - // Convert string 'origins' to *uint16 - _origins, err := UTF16PtrFromString(origins) - if err != nil { - return err + var _origins **uint16 + if len(_originsptrs) > 0 { + _origins = &_originsptrs[0] } - hr, _, _ := i.Vtbl.AddHostObjectToScriptWithOrigins.Call( + + hr, _, err := i.Vtbl.AddHostObjectToScriptWithOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(object)), - uintptr(unsafe.Pointer(&originsCount)), + uintptr(originsCount), uintptr(unsafe.Pointer(_origins)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame) RemoveHostObjectFromScript(name string) error { @@ -107,21 +122,21 @@ func (i *ICoreWebView2Frame) RemoveHostObjectFromScript(name string) error { return err } - hr, _, _ := i.Vtbl.RemoveHostObjectFromScript.Call( + hr, _, err := i.Vtbl.RemoveHostObjectFromScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame) AddDestroyed(eventHandler *ICoreWebView2FrameDestroyedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDestroyed.Call( + hr, _, err := i.Vtbl.AddDestroyed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -129,26 +144,27 @@ func (i *ICoreWebView2Frame) AddDestroyed(eventHandler *ICoreWebView2FrameDestro if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame) RemoveDestroyed(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDestroyed.Call( + + hr, _, err := i.Vtbl.RemoveDestroyed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame) IsDestroyed() (bool, error) { // Create int32 to hold bool result var _destroyed int32 - hr, _, _ := i.Vtbl.IsDestroyed.Call( + hr, _, err := i.Vtbl.IsDestroyed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_destroyed)), ) @@ -156,6 +172,6 @@ func (i *ICoreWebView2Frame) IsDestroyed() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - destroyed := _destroyed != 0 - return destroyed, nil + destroyed := _destroyed != 0 + return destroyed, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame2.go b/webview2/pkg/webview2/ICoreWebView2Frame2.go index 3a38dffdc42..735122b486c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame2.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame2.go @@ -1,56 +1,64 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Frame2Vtbl struct { IUnknownVtbl - AddNavigationStarting ComProc - RemoveNavigationStarting ComProc - AddContentLoading ComProc - RemoveContentLoading ComProc - AddNavigationCompleted ComProc + AddNavigationStarting ComProc + RemoveNavigationStarting ComProc + AddContentLoading ComProc + RemoveContentLoading ComProc + AddNavigationCompleted ComProc RemoveNavigationCompleted ComProc - AddDOMContentLoaded ComProc - RemoveDOMContentLoaded ComProc - ExecuteScript ComProc - PostWebMessageAsJson ComProc - PostWebMessageAsString ComProc - AddWebMessageReceived ComProc - RemoveWebMessageReceived ComProc + AddDOMContentLoaded ComProc + RemoveDOMContentLoaded ComProc + ExecuteScript ComProc + PostWebMessageAsJson ComProc + PostWebMessageAsString ComProc + AddWebMessageReceived ComProc + RemoveWebMessageReceived ComProc } type ICoreWebView2Frame2 struct { Vtbl *ICoreWebView2Frame2Vtbl } -func (i *ICoreWebView2Frame2) AddRef() uintptr { +func (i *ICoreWebView2Frame2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Frame2() *ICoreWebView2Frame2 { +func (i *ICoreWebView2Frame2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2Frame2() (*ICoreWebView2Frame2, error) { var result *ICoreWebView2Frame2 iidICoreWebView2Frame2 := NewGUID("{7a6a5834-d185-4dbf-b63f-4a9bc43107d4}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Frame2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Frame2) AddNavigationStarting(eventHandler *ICoreWebView2FrameNavigationStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNavigationStarting.Call( + hr, _, err := i.Vtbl.AddNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -58,26 +66,27 @@ func (i *ICoreWebView2Frame2) AddNavigationStarting(eventHandler *ICoreWebView2F if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame2) RemoveNavigationStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNavigationStarting.Call( + + hr, _, err := i.Vtbl.RemoveNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) AddContentLoading(eventHandler *ICoreWebView2FrameContentLoadingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddContentLoading.Call( + hr, _, err := i.Vtbl.AddContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -85,26 +94,27 @@ func (i *ICoreWebView2Frame2) AddContentLoading(eventHandler *ICoreWebView2Frame if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame2) RemoveContentLoading(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveContentLoading.Call( + + hr, _, err := i.Vtbl.RemoveContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) AddNavigationCompleted(eventHandler *ICoreWebView2FrameNavigationCompletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNavigationCompleted.Call( + hr, _, err := i.Vtbl.AddNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -112,26 +122,27 @@ func (i *ICoreWebView2Frame2) AddNavigationCompleted(eventHandler *ICoreWebView2 if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame2) RemoveNavigationCompleted(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNavigationCompleted.Call( + + hr, _, err := i.Vtbl.RemoveNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) AddDOMContentLoaded(eventHandler *ICoreWebView2FrameDOMContentLoadedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDOMContentLoaded.Call( + hr, _, err := i.Vtbl.AddDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -139,19 +150,20 @@ func (i *ICoreWebView2Frame2) AddDOMContentLoaded(eventHandler *ICoreWebView2Fra if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame2) RemoveDOMContentLoaded(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDOMContentLoaded.Call( + + hr, _, err := i.Vtbl.RemoveDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) ExecuteScript(javaScript string, handler *ICoreWebView2ExecuteScriptCompletedHandler) error { @@ -162,7 +174,7 @@ func (i *ICoreWebView2Frame2) ExecuteScript(javaScript string, handler *ICoreWeb return err } - hr, _, _ := i.Vtbl.ExecuteScript.Call( + hr, _, err := i.Vtbl.ExecuteScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -170,7 +182,7 @@ func (i *ICoreWebView2Frame2) ExecuteScript(javaScript string, handler *ICoreWeb if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) PostWebMessageAsJson(webMessageAsJson string) error { @@ -181,14 +193,14 @@ func (i *ICoreWebView2Frame2) PostWebMessageAsJson(webMessageAsJson string) erro return err } - hr, _, _ := i.Vtbl.PostWebMessageAsJson.Call( + hr, _, err := i.Vtbl.PostWebMessageAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsJson)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) PostWebMessageAsString(webMessageAsString string) error { @@ -199,21 +211,21 @@ func (i *ICoreWebView2Frame2) PostWebMessageAsString(webMessageAsString string) return err } - hr, _, _ := i.Vtbl.PostWebMessageAsString.Call( + hr, _, err := i.Vtbl.PostWebMessageAsString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsString)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Frame2) AddWebMessageReceived(handler *ICoreWebView2FrameWebMessageReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddWebMessageReceived.Call( + hr, _, err := i.Vtbl.AddWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), uintptr(unsafe.Pointer(&token)), @@ -221,17 +233,18 @@ func (i *ICoreWebView2Frame2) AddWebMessageReceived(handler *ICoreWebView2FrameW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame2) RemoveWebMessageReceived(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveWebMessageReceived.Call( + + hr, _, err := i.Vtbl.RemoveWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame3.go b/webview2/pkg/webview2/ICoreWebView2Frame3.go index e386c68db2f..960f6d296ac 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame3.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame3.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Frame3Vtbl struct { IUnknownVtbl - AddPermissionRequested ComProc + AddPermissionRequested ComProc RemovePermissionRequested ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2Frame3 struct { Vtbl *ICoreWebView2Frame3Vtbl } -func (i *ICoreWebView2Frame3) AddRef() uintptr { +func (i *ICoreWebView2Frame3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Frame3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Frame3() *ICoreWebView2Frame3 { + +func (i *ICoreWebView2) GetICoreWebView2Frame3() (*ICoreWebView2Frame3, error) { var result *ICoreWebView2Frame3 iidICoreWebView2Frame3 := NewGUID("{b50d82cc-cc28-481d-9614-cb048895e6a0}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Frame3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Frame3) AddPermissionRequested(eventHandler *ICoreWebView2FramePermissionRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddPermissionRequested.Call( + hr, _, err := i.Vtbl.AddPermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2Frame3) AddPermissionRequested(eventHandler *ICoreWebView2 if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame3) RemovePermissionRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemovePermissionRequested.Call( + + hr, _, err := i.Vtbl.RemovePermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame4.go b/webview2/pkg/webview2/ICoreWebView2Frame4.go index fb86908c8f5..9cdc9823fa6 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame4.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame4.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Frame4Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2Frame4 struct { Vtbl *ICoreWebView2Frame4Vtbl } -func (i *ICoreWebView2Frame4) AddRef() uintptr { +func (i *ICoreWebView2Frame4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Frame4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Frame4() *ICoreWebView2Frame4 { + +func (i *ICoreWebView2) GetICoreWebView2Frame4() (*ICoreWebView2Frame4, error) { var result *ICoreWebView2Frame4 iidICoreWebView2Frame4 := NewGUID("{188782dc-92aa-4732-ab3c-fcc59f6f68b9}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Frame4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Frame4) PostSharedBufferToScript(sharedBuffer *ICoreWebView2SharedBuffer, access COREWEBVIEW2_SHARED_BUFFER_ACCESS, additionalDataAsJson string) error { // Convert string 'additionalDataAsJson' to *uint16 @@ -42,7 +50,7 @@ func (i *ICoreWebView2Frame4) PostSharedBufferToScript(sharedBuffer *ICoreWebVie return err } - hr, _, _ := i.Vtbl.PostSharedBufferToScript.Call( + hr, _, err := i.Vtbl.PostSharedBufferToScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(sharedBuffer)), uintptr(access), @@ -51,5 +59,5 @@ func (i *ICoreWebView2Frame4) PostSharedBufferToScript(sharedBuffer *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame5.go b/webview2/pkg/webview2/ICoreWebView2Frame5.go index ea37d815e19..a34882e0244 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame5.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame5.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Frame5Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2Frame5 struct { Vtbl *ICoreWebView2Frame5Vtbl } -func (i *ICoreWebView2Frame5) AddRef() uintptr { +func (i *ICoreWebView2Frame5) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Frame5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Frame5() *ICoreWebView2Frame5 { + +func (i *ICoreWebView2) GetICoreWebView2Frame5() (*ICoreWebView2Frame5, error) { var result *ICoreWebView2Frame5 iidICoreWebView2Frame5 := NewGUID("{99d199c4-7305-11ee-b962-0242ac120002}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Frame5)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Frame5) GetFrameId() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetFrameId.Call( + hr, _, err := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame6.go b/webview2/pkg/webview2/ICoreWebView2Frame6.go index bf50a868ff1..5d74b3891f7 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame6.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame6.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Frame6Vtbl struct { IUnknownVtbl - AddScreenCaptureStarting ComProc + AddScreenCaptureStarting ComProc RemoveScreenCaptureStarting ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2Frame6 struct { Vtbl *ICoreWebView2Frame6Vtbl } -func (i *ICoreWebView2Frame6) AddRef() uintptr { +func (i *ICoreWebView2Frame6) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Frame6) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Frame6() *ICoreWebView2Frame6 { + +func (i *ICoreWebView2) GetICoreWebView2Frame6() (*ICoreWebView2Frame6, error) { var result *ICoreWebView2Frame6 iidICoreWebView2Frame6 := NewGUID("{0de611fd-31e9-5ddc-9d71-95eda26eff32}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Frame6)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Frame6) AddScreenCaptureStarting(eventHandler *ICoreWebView2FrameScreenCaptureStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddScreenCaptureStarting.Call( + hr, _, err := i.Vtbl.AddScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2Frame6) AddScreenCaptureStarting(eventHandler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Frame6) RemoveScreenCaptureStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveScreenCaptureStarting.Call( + + hr, _, err := i.Vtbl.RemoveScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameContentLoadingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameContentLoadingEventHandler.go index 7544a95e266..a818af24308 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameContentLoadingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameContentLoadingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameContentLoadingEventHandler struct { impl ICoreWebView2FrameContentLoadingEventHandlerImpl } -func (i *ICoreWebView2FrameContentLoadingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameContentLoadingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameContentLoadingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameContentLoadingEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameContentLoadingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameContentLoadingEventHandlerIUnknownQueryInterface(this *IC } func ICoreWebView2FrameContentLoadingEventHandlerIUnknownAddRef(this *ICoreWebView2FrameContentLoadingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameContentLoadingEventHandlerIUnknownRelease(this *ICoreWebView2FrameContentLoadingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameContentLoadingEventHandlerInvoke(this *ICoreWebView2FrameContentLoadingEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2ContentLoadingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameContentLoadingEventHandlerImpl interface { } var ICoreWebView2FrameContentLoadingEventHandlerFn = ICoreWebView2FrameContentLoadingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameContentLoadingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameContentLoadingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameContentLoadingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go index e8a1f163c88..b626d4b56fb 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FrameCreatedEventArgsVtbl struct { @@ -17,21 +16,27 @@ type ICoreWebView2FrameCreatedEventArgs struct { Vtbl *ICoreWebView2FrameCreatedEventArgsVtbl } -func (i *ICoreWebView2FrameCreatedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2FrameCreatedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameCreatedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2FrameCreatedEventArgs) GetFrame() (*ICoreWebView2Frame, error) { var value *ICoreWebView2Frame - hr, _, _ := i.Vtbl.GetFrame.Call( + hr, _, err := i.Vtbl.GetFrame.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventHandler.go index 1b8e50cc538..9f38a9a79e4 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameCreatedEventHandler struct { impl ICoreWebView2FrameCreatedEventHandlerImpl } -func (i *ICoreWebView2FrameCreatedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameCreatedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameCreatedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameCreatedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameCreatedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameCreatedEventHandlerIUnknownQueryInterface(this *ICoreWebV } func ICoreWebView2FrameCreatedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameCreatedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameCreatedEventHandlerIUnknownRelease(this *ICoreWebView2FrameCreatedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameCreatedEventHandlerInvoke(this *ICoreWebView2FrameCreatedEventHandler, sender *ICoreWebView2, args *ICoreWebView2FrameCreatedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameCreatedEventHandlerImpl interface { } var ICoreWebView2FrameCreatedEventHandlerFn = ICoreWebView2FrameCreatedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameCreatedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameCreatedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameCreatedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameDOMContentLoadedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameDOMContentLoadedEventHandler.go index 4231183ef22..749c392b213 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameDOMContentLoadedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameDOMContentLoadedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameDOMContentLoadedEventHandler struct { impl ICoreWebView2FrameDOMContentLoadedEventHandlerImpl } -func (i *ICoreWebView2FrameDOMContentLoadedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameDOMContentLoadedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameDOMContentLoadedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameDOMContentLoadedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownQueryInterface(this * } func ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameDOMContentLoadedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownRelease(this *ICoreWebView2FrameDOMContentLoadedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameDOMContentLoadedEventHandlerInvoke(this *ICoreWebView2FrameDOMContentLoadedEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2DOMContentLoadedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameDOMContentLoadedEventHandlerImpl interface { } var ICoreWebView2FrameDOMContentLoadedEventHandlerFn = ICoreWebView2FrameDOMContentLoadedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameDOMContentLoadedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameDestroyedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameDestroyedEventHandler.go index 2cdb129769d..4aed508d882 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameDestroyedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameDestroyedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameDestroyedEventHandler struct { impl ICoreWebView2FrameDestroyedEventHandlerImpl } -func (i *ICoreWebView2FrameDestroyedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameDestroyedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameDestroyedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameDestroyedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameDestroyedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameDestroyedEventHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2FrameDestroyedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameDestroyedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameDestroyedEventHandlerIUnknownRelease(this *ICoreWebView2FrameDestroyedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameDestroyedEventHandlerInvoke(this *ICoreWebView2FrameDestroyedEventHandler, sender *ICoreWebView2Frame, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameDestroyedEventHandlerImpl interface { } var ICoreWebView2FrameDestroyedEventHandlerFn = ICoreWebView2FrameDestroyedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameDestroyedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameDestroyedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameDestroyedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfo.go b/webview2/pkg/webview2/ICoreWebView2FrameInfo.go index 8f8defdda5b..7a3e6d0902d 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfo.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FrameInfoVtbl struct { IUnknownVtbl - GetName ComProc + GetName ComProc GetSource ComProc } @@ -18,18 +17,25 @@ type ICoreWebView2FrameInfo struct { Vtbl *ICoreWebView2FrameInfoVtbl } -func (i *ICoreWebView2FrameInfo) AddRef() uintptr { +func (i *ICoreWebView2FrameInfo) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2FrameInfo) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2FrameInfo) GetName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -37,16 +43,17 @@ func (i *ICoreWebView2FrameInfo) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSource.Call( + + hr, _, err := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -54,5 +61,5 @@ func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go b/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go index 3991d11f719..a5834228649 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go @@ -1,79 +1,87 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FrameInfo2Vtbl struct { IUnknownVtbl GetParentFrameInfo ComProc - GetFrameId ComProc - GetFrameKind ComProc + GetFrameId ComProc + GetFrameKind ComProc } type ICoreWebView2FrameInfo2 struct { Vtbl *ICoreWebView2FrameInfo2Vtbl } -func (i *ICoreWebView2FrameInfo2) AddRef() uintptr { +func (i *ICoreWebView2FrameInfo2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameInfo2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2FrameInfo2() *ICoreWebView2FrameInfo2 { + +func (i *ICoreWebView2) GetICoreWebView2FrameInfo2() (*ICoreWebView2FrameInfo2, error) { var result *ICoreWebView2FrameInfo2 iidICoreWebView2FrameInfo2 := NewGUID("{56f85cfa-72c4-11ee-b962-0242ac120002}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2FrameInfo2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2FrameInfo2) GetParentFrameInfo() (*ICoreWebView2FrameInfo, error) { var frameInfo *ICoreWebView2FrameInfo - hr, _, _ := i.Vtbl.GetParentFrameInfo.Call( + hr, _, err := i.Vtbl.GetParentFrameInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frameInfo)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return frameInfo, nil + return frameInfo, err } func (i *ICoreWebView2FrameInfo2) GetFrameId() (uint32, error) { var id uint32 - hr, _, _ := i.Vtbl.GetFrameId.Call( + hr, _, err := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&id)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return id, nil + return id, err } func (i *ICoreWebView2FrameInfo2) GetFrameKind() (COREWEBVIEW2_FRAME_KIND, error) { var kind COREWEBVIEW2_FRAME_KIND - hr, _, _ := i.Vtbl.GetFrameKind.Call( + hr, _, err := i.Vtbl.GetFrameKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&kind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return kind, nil + return kind, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go index c23462e94e4..de51e1b3a2f 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FrameInfoCollectionVtbl struct { @@ -17,21 +16,27 @@ type ICoreWebView2FrameInfoCollection struct { Vtbl *ICoreWebView2FrameInfoCollectionVtbl } -func (i *ICoreWebView2FrameInfoCollection) AddRef() uintptr { +func (i *ICoreWebView2FrameInfoCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameInfoCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2FrameInfoCollection) GetIterator() (*ICoreWebView2FrameInfoCollectionIterator, error) { var value *ICoreWebView2FrameInfoCollectionIterator - hr, _, _ := i.Vtbl.GetIterator.Call( + hr, _, err := i.Vtbl.GetIterator.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go index 96515434ce1..e329c00c275 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go @@ -1,34 +1,39 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2FrameInfoCollectionIteratorVtbl struct { IUnknownVtbl GetHasCurrent ComProc - GetCurrent ComProc - MoveNext ComProc + GetCurrent ComProc + MoveNext ComProc } type ICoreWebView2FrameInfoCollectionIterator struct { Vtbl *ICoreWebView2FrameInfoCollectionIteratorVtbl } -func (i *ICoreWebView2FrameInfoCollectionIterator) AddRef() uintptr { +func (i *ICoreWebView2FrameInfoCollectionIterator) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameInfoCollectionIterator) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2FrameInfoCollectionIterator) GetHasCurrent() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasCurrent.Call( + hr, _, err := i.Vtbl.GetHasCurrent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -36,29 +41,29 @@ func (i *ICoreWebView2FrameInfoCollectionIterator) GetHasCurrent() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2FrameInfoCollectionIterator) GetCurrent() (*ICoreWebView2FrameInfo, error) { var value *ICoreWebView2FrameInfo - hr, _, _ := i.Vtbl.GetCurrent.Call( + hr, _, err := i.Vtbl.GetCurrent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2FrameInfoCollectionIterator) MoveNext() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.MoveNext.Call( + hr, _, err := i.Vtbl.MoveNext.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -66,6 +71,6 @@ func (i *ICoreWebView2FrameInfoCollectionIterator) MoveNext() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameNameChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameNameChangedEventHandler.go index c75ebadcfab..b289b703a67 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameNameChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameNameChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameNameChangedEventHandler struct { impl ICoreWebView2FrameNameChangedEventHandlerImpl } -func (i *ICoreWebView2FrameNameChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameNameChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameNameChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameNameChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameNameChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameNameChangedEventHandlerIUnknownQueryInterface(this *ICore } func ICoreWebView2FrameNameChangedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameNameChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameNameChangedEventHandlerIUnknownRelease(this *ICoreWebView2FrameNameChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameNameChangedEventHandlerInvoke(this *ICoreWebView2FrameNameChangedEventHandler, sender *ICoreWebView2Frame, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameNameChangedEventHandlerImpl interface { } var ICoreWebView2FrameNameChangedEventHandlerFn = ICoreWebView2FrameNameChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameNameChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameNameChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameNameChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameNavigationCompletedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameNavigationCompletedEventHandler.go index 3a160407ca6..8f0fcf91b3c 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameNavigationCompletedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameNavigationCompletedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameNavigationCompletedEventHandler struct { impl ICoreWebView2FrameNavigationCompletedEventHandlerImpl } -func (i *ICoreWebView2FrameNavigationCompletedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameNavigationCompletedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameNavigationCompletedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameNavigationCompletedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownQueryInterface(thi } func ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameNavigationCompletedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownRelease(this *ICoreWebView2FrameNavigationCompletedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameNavigationCompletedEventHandlerInvoke(this *ICoreWebView2FrameNavigationCompletedEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2NavigationCompletedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameNavigationCompletedEventHandlerImpl interface { } var ICoreWebView2FrameNavigationCompletedEventHandlerFn = ICoreWebView2FrameNavigationCompletedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameNavigationCompletedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameNavigationStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameNavigationStartingEventHandler.go index 43cc23b28a5..24c5ff0c539 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameNavigationStartingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameNavigationStartingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameNavigationStartingEventHandler struct { impl ICoreWebView2FrameNavigationStartingEventHandlerImpl } -func (i *ICoreWebView2FrameNavigationStartingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameNavigationStartingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameNavigationStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameNavigationStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameNavigationStartingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameNavigationStartingEventHandlerIUnknownQueryInterface(this } func ICoreWebView2FrameNavigationStartingEventHandlerIUnknownAddRef(this *ICoreWebView2FrameNavigationStartingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameNavigationStartingEventHandlerIUnknownRelease(this *ICoreWebView2FrameNavigationStartingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameNavigationStartingEventHandlerInvoke(this *ICoreWebView2FrameNavigationStartingEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2NavigationStartingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameNavigationStartingEventHandlerImpl interface { } var ICoreWebView2FrameNavigationStartingEventHandlerFn = ICoreWebView2FrameNavigationStartingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameNavigationStartingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameNavigationStartingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameNavigationStartingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FramePermissionRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FramePermissionRequestedEventHandler.go index d3b223f87b9..9786edcea63 100644 --- a/webview2/pkg/webview2/ICoreWebView2FramePermissionRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FramePermissionRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FramePermissionRequestedEventHandler struct { impl ICoreWebView2FramePermissionRequestedEventHandlerImpl } -func (i *ICoreWebView2FramePermissionRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FramePermissionRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FramePermissionRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FramePermissionRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FramePermissionRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FramePermissionRequestedEventHandlerIUnknownQueryInterface(thi } func ICoreWebView2FramePermissionRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2FramePermissionRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FramePermissionRequestedEventHandlerIUnknownRelease(this *ICoreWebView2FramePermissionRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FramePermissionRequestedEventHandlerInvoke(this *ICoreWebView2FramePermissionRequestedEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2PermissionRequestedEventArgs2) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FramePermissionRequestedEventHandlerImpl interface { } var ICoreWebView2FramePermissionRequestedEventHandlerFn = ICoreWebView2FramePermissionRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FramePermissionRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FramePermissionRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FramePermissionRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameScreenCaptureStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameScreenCaptureStartingEventHandler.go index 2eff03d8ebc..e70e5196d55 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameScreenCaptureStartingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameScreenCaptureStartingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameScreenCaptureStartingEventHandler struct { impl ICoreWebView2FrameScreenCaptureStartingEventHandlerImpl } -func (i *ICoreWebView2FrameScreenCaptureStartingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameScreenCaptureStartingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameScreenCaptureStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameScreenCaptureStartingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownQueryInterface(t } func ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownAddRef(this *ICoreWebView2FrameScreenCaptureStartingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownRelease(this *ICoreWebView2FrameScreenCaptureStartingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameScreenCaptureStartingEventHandlerInvoke(this *ICoreWebView2FrameScreenCaptureStartingEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2ScreenCaptureStartingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameScreenCaptureStartingEventHandlerImpl interface { } var ICoreWebView2FrameScreenCaptureStartingEventHandlerFn = ICoreWebView2FrameScreenCaptureStartingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameScreenCaptureStartingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2FrameWebMessageReceivedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameWebMessageReceivedEventHandler.go index ee96922c4d6..744f438dd2e 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameWebMessageReceivedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameWebMessageReceivedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2FrameWebMessageReceivedEventHandler struct { impl ICoreWebView2FrameWebMessageReceivedEventHandlerImpl } -func (i *ICoreWebView2FrameWebMessageReceivedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2FrameWebMessageReceivedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameWebMessageReceivedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameWebMessageReceivedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownQueryInterface(this } func ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameWebMessageReceivedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownRelease(this *ICoreWebView2FrameWebMessageReceivedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2FrameWebMessageReceivedEventHandlerInvoke(this *ICoreWebView2FrameWebMessageReceivedEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2WebMessageReceivedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2FrameWebMessageReceivedEventHandlerImpl interface { } var ICoreWebView2FrameWebMessageReceivedEventHandlerFn = ICoreWebView2FrameWebMessageReceivedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2FrameWebMessageReceivedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2GetCookiesCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2GetCookiesCompletedHandler.go index 3db7414dfce..d81f5c16ff9 100644 --- a/webview2/pkg/webview2/ICoreWebView2GetCookiesCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2GetCookiesCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2GetCookiesCompletedHandler struct { impl ICoreWebView2GetCookiesCompletedHandlerImpl } -func (i *ICoreWebView2GetCookiesCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2GetCookiesCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2GetCookiesCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2GetCookiesCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2GetCookiesCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2GetCookiesCompletedHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2GetCookiesCompletedHandlerIUnknownAddRef(this *ICoreWebView2GetCookiesCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2GetCookiesCompletedHandlerIUnknownRelease(this *ICoreWebView2GetCookiesCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2GetCookiesCompletedHandlerInvoke(this *ICoreWebView2GetCookiesCompletedHandler, errorCode uintptr, result *ICoreWebView2CookieList) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2GetCookiesCompletedHandlerImpl interface { } var ICoreWebView2GetCookiesCompletedHandlerFn = ICoreWebView2GetCookiesCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2GetCookiesCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2GetCookiesCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2GetCookiesCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2GetFaviconCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2GetFaviconCompletedHandler.go index 7af334df97c..6702e14134b 100644 --- a/webview2/pkg/webview2/ICoreWebView2GetFaviconCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2GetFaviconCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2GetFaviconCompletedHandler struct { impl ICoreWebView2GetFaviconCompletedHandlerImpl } -func (i *ICoreWebView2GetFaviconCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2GetFaviconCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2GetFaviconCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2GetFaviconCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2GetFaviconCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2GetFaviconCompletedHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2GetFaviconCompletedHandlerIUnknownAddRef(this *ICoreWebView2GetFaviconCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2GetFaviconCompletedHandlerIUnknownRelease(this *ICoreWebView2GetFaviconCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2GetFaviconCompletedHandlerInvoke(this *ICoreWebView2GetFaviconCompletedHandler, errorCode uintptr, result *IStream) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2GetFaviconCompletedHandlerImpl interface { } var ICoreWebView2GetFaviconCompletedHandlerFn = ICoreWebView2GetFaviconCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2GetFaviconCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2GetFaviconCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2GetFaviconCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler.go index b0ecea7f255..3be97c6c0f6 100644 --- a/webview2/pkg/webview2/ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler struct { impl ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerImpl } -func (i *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownQueryIn } func ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownAddRef(this *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownRelease(this *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerInvoke(this *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler, errorCode uintptr, result *ICoreWebView2PermissionSettingCollectionView) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerImpl interface } var ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerFn = ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2GetProcessExtendedInfosCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2GetProcessExtendedInfosCompletedHandler.go index cae41322fd9..10b4aa80f0a 100644 --- a/webview2/pkg/webview2/ICoreWebView2GetProcessExtendedInfosCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2GetProcessExtendedInfosCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2GetProcessExtendedInfosCompletedHandler struct { impl ICoreWebView2GetProcessExtendedInfosCompletedHandlerImpl } -func (i *ICoreWebView2GetProcessExtendedInfosCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2GetProcessExtendedInfosCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2GetProcessExtendedInfosCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2GetProcessExtendedInfosCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownQueryInterface( } func ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownAddRef(this *ICoreWebView2GetProcessExtendedInfosCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownRelease(this *ICoreWebView2GetProcessExtendedInfosCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2GetProcessExtendedInfosCompletedHandlerInvoke(this *ICoreWebView2GetProcessExtendedInfosCompletedHandler, errorCode uintptr, result *ICoreWebView2ProcessExtendedInfoCollection) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2GetProcessExtendedInfosCompletedHandlerImpl interface { } var ICoreWebView2GetProcessExtendedInfosCompletedHandlerFn = ICoreWebView2GetProcessExtendedInfosCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2GetProcessExtendedInfosCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2HistoryChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2HistoryChangedEventHandler.go index 5ee898f36fa..86708e23da2 100644 --- a/webview2/pkg/webview2/ICoreWebView2HistoryChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2HistoryChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2HistoryChangedEventHandler struct { impl ICoreWebView2HistoryChangedEventHandlerImpl } -func (i *ICoreWebView2HistoryChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2HistoryChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2HistoryChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2HistoryChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2HistoryChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2HistoryChangedEventHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2HistoryChangedEventHandlerIUnknownAddRef(this *ICoreWebView2HistoryChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2HistoryChangedEventHandlerIUnknownRelease(this *ICoreWebView2HistoryChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2HistoryChangedEventHandlerInvoke(this *ICoreWebView2HistoryChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2HistoryChangedEventHandlerImpl interface { } var ICoreWebView2HistoryChangedEventHandlerFn = ICoreWebView2HistoryChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2HistoryChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2HistoryChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2HistoryChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go b/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go index c27457a6324..e33874b7344 100644 --- a/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go +++ b/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go @@ -1,39 +1,45 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2HttpHeadersCollectionIteratorVtbl struct { IUnknownVtbl - GetCurrentHeader ComProc + GetCurrentHeader ComProc GetHasCurrentHeader ComProc - MoveNext ComProc + MoveNext ComProc } type ICoreWebView2HttpHeadersCollectionIterator struct { Vtbl *ICoreWebView2HttpHeadersCollectionIteratorVtbl } -func (i *ICoreWebView2HttpHeadersCollectionIterator) AddRef() uintptr { +func (i *ICoreWebView2HttpHeadersCollectionIterator) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2HttpHeadersCollectionIterator) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2HttpHeadersCollectionIterator) GetCurrentHeader() (string, string, error) { // Create *uint16 to hold result var _name *uint16 // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetCurrentHeader.Call( + + hr, _, err := i.Vtbl.GetCurrentHeader.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_name)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_name)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", "", syscall.Errno(hr) @@ -44,14 +50,14 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) GetCurrentHeader() (string, // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return name, value, nil + return name, value, err } func (i *ICoreWebView2HttpHeadersCollectionIterator) GetHasCurrentHeader() (bool, error) { // Create int32 to hold bool result var _hasCurrent int32 - hr, _, _ := i.Vtbl.GetHasCurrentHeader.Call( + hr, _, err := i.Vtbl.GetHasCurrentHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_hasCurrent)), ) @@ -59,15 +65,15 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) GetHasCurrentHeader() (bool return false, syscall.Errno(hr) } // Get result and cleanup - hasCurrent := _hasCurrent != 0 - return hasCurrent, nil + hasCurrent := _hasCurrent != 0 + return hasCurrent, err } func (i *ICoreWebView2HttpHeadersCollectionIterator) MoveNext() (bool, error) { // Create int32 to hold bool result var _hasNext int32 - hr, _, _ := i.Vtbl.MoveNext.Call( + hr, _, err := i.Vtbl.MoveNext.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_hasNext)), ) @@ -75,6 +81,6 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) MoveNext() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - hasNext := _hasNext != 0 - return hasNext, nil + hasNext := _hasNext != 0 + return hasNext, err } diff --git a/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go b/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go index 12e7bac0f39..d52e438e24d 100644 --- a/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go +++ b/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go @@ -1,45 +1,51 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2HttpRequestHeadersVtbl struct { IUnknownVtbl - GetHeader ComProc - GetHeaders ComProc - Contains ComProc - SetHeader ComProc + GetHeader ComProc + GetHeaders ComProc + Contains ComProc + SetHeader ComProc RemoveHeader ComProc - GetIterator ComProc + GetIterator ComProc } type ICoreWebView2HttpRequestHeaders struct { Vtbl *ICoreWebView2HttpRequestHeadersVtbl } -func (i *ICoreWebView2HttpRequestHeaders) AddRef() uintptr { +func (i *ICoreWebView2HttpRequestHeaders) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2HttpRequestHeaders) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2HttpRequestHeaders) GetHeader(name string) (string, error) { // Convert string 'name' to *uint16 _name, err := UTF16PtrFromString(name) if err != nil { - return "", nil - } // Create *uint16 to hold result + return "", err + } // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetHeader.Call( + + hr, _, err := i.Vtbl.GetHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -47,7 +53,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeader(name string) (string, error) // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2HttpRequestHeaders) GetHeaders(name string) (*ICoreWebView2HttpHeadersCollectionIterator, error) { @@ -59,7 +65,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeaders(name string) (*ICoreWebView } var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, _ := i.Vtbl.GetHeaders.Call( + hr, _, err := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&value)), @@ -67,7 +73,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeaders(name string) (*ICoreWebView if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2HttpRequestHeaders) Contains(name string) (bool, error) { @@ -75,11 +81,11 @@ func (i *ICoreWebView2HttpRequestHeaders) Contains(name string) (bool, error) { // Convert string 'name' to *uint16 _name, err := UTF16PtrFromString(name) if err != nil { - return false, nil - } // Create int32 to hold bool result + return false, err + } // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.Contains.Call( + hr, _, err := i.Vtbl.Contains.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&_value)), @@ -88,8 +94,8 @@ func (i *ICoreWebView2HttpRequestHeaders) Contains(name string) (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2HttpRequestHeaders) SetHeader(name string, value string) error { @@ -105,7 +111,7 @@ func (i *ICoreWebView2HttpRequestHeaders) SetHeader(name string, value string) e return err } - hr, _, _ := i.Vtbl.SetHeader.Call( + hr, _, err := i.Vtbl.SetHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_value)), @@ -113,7 +119,7 @@ func (i *ICoreWebView2HttpRequestHeaders) SetHeader(name string, value string) e if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2HttpRequestHeaders) RemoveHeader(name string) error { @@ -124,26 +130,26 @@ func (i *ICoreWebView2HttpRequestHeaders) RemoveHeader(name string) error { return err } - hr, _, _ := i.Vtbl.RemoveHeader.Call( + hr, _, err := i.Vtbl.RemoveHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2HttpRequestHeaders) GetIterator() (*ICoreWebView2HttpHeadersCollectionIterator, error) { var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, _ := i.Vtbl.GetIterator.Call( + hr, _, err := i.Vtbl.GetIterator.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go b/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go index 819a4800d32..20492e27821 100644 --- a/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go +++ b/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go @@ -1,31 +1,36 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2HttpResponseHeadersVtbl struct { IUnknownVtbl AppendHeader ComProc - Contains ComProc - GetHeader ComProc - GetHeaders ComProc - GetIterator ComProc + Contains ComProc + GetHeader ComProc + GetHeaders ComProc + GetIterator ComProc } type ICoreWebView2HttpResponseHeaders struct { Vtbl *ICoreWebView2HttpResponseHeadersVtbl } -func (i *ICoreWebView2HttpResponseHeaders) AddRef() uintptr { +func (i *ICoreWebView2HttpResponseHeaders) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2HttpResponseHeaders) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2HttpResponseHeaders) AppendHeader(name string, value string) error { // Convert string 'name' to *uint16 @@ -39,7 +44,7 @@ func (i *ICoreWebView2HttpResponseHeaders) AppendHeader(name string, value strin return err } - hr, _, _ := i.Vtbl.AppendHeader.Call( + hr, _, err := i.Vtbl.AppendHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_value)), @@ -55,11 +60,11 @@ func (i *ICoreWebView2HttpResponseHeaders) Contains(name string) (bool, error) { // Convert string 'name' to *uint16 _name, err := UTF16PtrFromString(name) if err != nil { - return false, nil - } // Create int32 to hold bool result + return false, err + } // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.Contains.Call( + hr, _, err := i.Vtbl.Contains.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&_value)), @@ -68,8 +73,8 @@ func (i *ICoreWebView2HttpResponseHeaders) Contains(name string) (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2HttpResponseHeaders) GetHeader(name string) (string, error) { @@ -77,14 +82,15 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeader(name string) (string, error // Convert string 'name' to *uint16 _name, err := UTF16PtrFromString(name) if err != nil { - return "", nil - } // Create *uint16 to hold result + return "", err + } // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetHeader.Call( + + hr, _, err := i.Vtbl.GetHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -92,7 +98,7 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeader(name string) (string, error // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2HttpResponseHeaders) GetHeaders(name string) (*ICoreWebView2HttpHeadersCollectionIterator, error) { @@ -104,7 +110,7 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeaders(name string) (*ICoreWebVie } var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, _ := i.Vtbl.GetHeaders.Call( + hr, _, err := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&value)), @@ -112,19 +118,19 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeaders(name string) (*ICoreWebVie if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2HttpResponseHeaders) GetIterator() (*ICoreWebView2HttpHeadersCollectionIterator, error) { var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, _ := i.Vtbl.GetIterator.Call( + hr, _, err := i.Vtbl.GetIterator.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler.go index 23d86af2556..f949fce9e5e 100644 --- a/webview2/pkg/webview2/ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler struct { impl ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerImpl } -func (i *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownQueryInt } func ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownAddRef(this *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownRelease(this *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerInvoke(this *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerImpl interface { } var ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerFn = ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2IsDocumentPlayingAudioChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2IsDocumentPlayingAudioChangedEventHandler.go index 37549c32a8d..fad6b4407dd 100644 --- a/webview2/pkg/webview2/ICoreWebView2IsDocumentPlayingAudioChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2IsDocumentPlayingAudioChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2IsDocumentPlayingAudioChangedEventHandler struct { impl ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerImpl } -func (i *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownQueryInterfac } func ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownAddRef(this *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownRelease(this *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerInvoke(this *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerImpl interface { } var ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerFn = ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2IsDocumentPlayingAudioChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2IsMutedChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2IsMutedChangedEventHandler.go index bd284e737be..ee503edd724 100644 --- a/webview2/pkg/webview2/ICoreWebView2IsMutedChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2IsMutedChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2IsMutedChangedEventHandler struct { impl ICoreWebView2IsMutedChangedEventHandlerImpl } -func (i *ICoreWebView2IsMutedChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2IsMutedChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2IsMutedChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2IsMutedChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2IsMutedChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2IsMutedChangedEventHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2IsMutedChangedEventHandlerIUnknownAddRef(this *ICoreWebView2IsMutedChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2IsMutedChangedEventHandlerIUnknownRelease(this *ICoreWebView2IsMutedChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2IsMutedChangedEventHandlerInvoke(this *ICoreWebView2IsMutedChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2IsMutedChangedEventHandlerImpl interface { } var ICoreWebView2IsMutedChangedEventHandlerFn = ICoreWebView2IsMutedChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2IsMutedChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2IsMutedChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2IsMutedChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go b/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go index e71065223e9..d6b54d389a0 100644 --- a/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go @@ -1,39 +1,45 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2LaunchingExternalUriSchemeEventArgsVtbl struct { IUnknownVtbl - GetUri ComProc + GetUri ComProc GetInitiatingOrigin ComProc - GetIsUserInitiated ComProc - GetCancel ComProc - PutCancel ComProc - GetDeferral ComProc + GetIsUserInitiated ComProc + GetCancel ComProc + PutCancel ComProc + GetDeferral ComProc } type ICoreWebView2LaunchingExternalUriSchemeEventArgs struct { Vtbl *ICoreWebView2LaunchingExternalUriSchemeEventArgsVtbl } -func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) AddRef() uintptr { +func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -41,16 +47,17 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetUri() (string, err // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetInitiatingOrigin() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetInitiatingOrigin.Call( + + hr, _, err := i.Vtbl.GetInitiatingOrigin.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -58,14 +65,14 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetInitiatingOrigin() // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( + hr, _, err := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -73,15 +80,15 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetIsUserInitiated() return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -89,32 +96,38 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetCancel() (bool, er return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) PutCancel(value bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventHandler.go b/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventHandler.go index f1ee708b1dd..1231bf5fdc2 100644 --- a/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2LaunchingExternalUriSchemeEventHandler struct { impl ICoreWebView2LaunchingExternalUriSchemeEventHandlerImpl } -func (i *ICoreWebView2LaunchingExternalUriSchemeEventHandler) AddRef() uintptr { +func (i *ICoreWebView2LaunchingExternalUriSchemeEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2LaunchingExternalUriSchemeEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownQueryInterface(this *ICoreWebView2LaunchingExternalUriSchemeEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownQueryInterface(t } func ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownAddRef(this *ICoreWebView2LaunchingExternalUriSchemeEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownRelease(this *ICoreWebView2LaunchingExternalUriSchemeEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2LaunchingExternalUriSchemeEventHandlerInvoke(this *ICoreWebView2LaunchingExternalUriSchemeEventHandler, sender *ICoreWebView2, args *ICoreWebView2LaunchingExternalUriSchemeEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2LaunchingExternalUriSchemeEventHandlerImpl interface { } var ICoreWebView2LaunchingExternalUriSchemeEventHandlerFn = ICoreWebView2LaunchingExternalUriSchemeEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2LaunchingExternalUriSchemeEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go index 0f4a5c0fcfd..520d0d13c37 100644 --- a/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2MoveFocusRequestedEventArgsVtbl struct { IUnknownVtbl - GetReason ComProc + GetReason ComProc GetHandled ComProc PutHandled ComProc } @@ -19,30 +18,36 @@ type ICoreWebView2MoveFocusRequestedEventArgs struct { Vtbl *ICoreWebView2MoveFocusRequestedEventArgsVtbl } -func (i *ICoreWebView2MoveFocusRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2MoveFocusRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2MoveFocusRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2MoveFocusRequestedEventArgs) GetReason() (COREWEBVIEW2_MOVE_FOCUS_REASON, error) { var reason COREWEBVIEW2_MOVE_FOCUS_REASON - hr, _, _ := i.Vtbl.GetReason.Call( + hr, _, err := i.Vtbl.GetReason.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&reason)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return reason, nil + return reason, err } func (i *ICoreWebView2MoveFocusRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -50,18 +55,24 @@ func (i *ICoreWebView2MoveFocusRequestedEventArgs) GetHandled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2MoveFocusRequestedEventArgs) PutHandled(value bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventHandler.go index d66296abffb..cf0d124faa9 100644 --- a/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2MoveFocusRequestedEventHandler struct { impl ICoreWebView2MoveFocusRequestedEventHandlerImpl } -func (i *ICoreWebView2MoveFocusRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2MoveFocusRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2MoveFocusRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2MoveFocusRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2MoveFocusRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2MoveFocusRequestedEventHandlerIUnknownQueryInterface(this *ICo } func ICoreWebView2MoveFocusRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2MoveFocusRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2MoveFocusRequestedEventHandlerIUnknownRelease(this *ICoreWebView2MoveFocusRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2MoveFocusRequestedEventHandlerInvoke(this *ICoreWebView2MoveFocusRequestedEventHandler, sender *ICoreWebView2Controller, args *ICoreWebView2MoveFocusRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2MoveFocusRequestedEventHandlerImpl interface { } var ICoreWebView2MoveFocusRequestedEventHandlerFn = ICoreWebView2MoveFocusRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2MoveFocusRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2MoveFocusRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2MoveFocusRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go index 7c42f379809..c878b76e56d 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go @@ -1,34 +1,39 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NavigationCompletedEventArgsVtbl struct { IUnknownVtbl - GetIsSuccess ComProc + GetIsSuccess ComProc GetWebErrorStatus ComProc - GetNavigationId ComProc + GetNavigationId ComProc } type ICoreWebView2NavigationCompletedEventArgs struct { Vtbl *ICoreWebView2NavigationCompletedEventArgsVtbl } -func (i *ICoreWebView2NavigationCompletedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2NavigationCompletedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationCompletedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2NavigationCompletedEventArgs) GetIsSuccess() (bool, error) { // Create int32 to hold bool result var _isSuccess int32 - hr, _, _ := i.Vtbl.GetIsSuccess.Call( + hr, _, err := i.Vtbl.GetIsSuccess.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSuccess)), ) @@ -36,34 +41,34 @@ func (i *ICoreWebView2NavigationCompletedEventArgs) GetIsSuccess() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - isSuccess := _isSuccess != 0 - return isSuccess, nil + isSuccess := _isSuccess != 0 + return isSuccess, err } func (i *ICoreWebView2NavigationCompletedEventArgs) GetWebErrorStatus() (COREWEBVIEW2_WEB_ERROR_STATUS, error) { var webErrorStatus COREWEBVIEW2_WEB_ERROR_STATUS - hr, _, _ := i.Vtbl.GetWebErrorStatus.Call( + hr, _, err := i.Vtbl.GetWebErrorStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&webErrorStatus)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return webErrorStatus, nil + return webErrorStatus, err } func (i *ICoreWebView2NavigationCompletedEventArgs) GetNavigationId() (uint64, error) { var navigationId uint64 - hr, _, _ := i.Vtbl.GetNavigationId.Call( + hr, _, err := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&navigationId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return navigationId, nil + return navigationId, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go index e0db30a5238..fb74dfb13f4 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NavigationCompletedEventArgs2Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2NavigationCompletedEventArgs2 struct { Vtbl *ICoreWebView2NavigationCompletedEventArgs2Vtbl } -func (i *ICoreWebView2NavigationCompletedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2NavigationCompletedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationCompletedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2NavigationCompletedEventArgs2() *ICoreWebView2NavigationCompletedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2NavigationCompletedEventArgs2() (*ICoreWebView2NavigationCompletedEventArgs2, error) { var result *ICoreWebView2NavigationCompletedEventArgs2 iidICoreWebView2NavigationCompletedEventArgs2 := NewGUID("{fdf8b738-ee1e-4db2-a329-8d7d7b74d792}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2NavigationCompletedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2NavigationCompletedEventArgs2) GetHttpStatusCode() (int, error) { var value int - hr, _, _ := i.Vtbl.GetHttpStatusCode.Call( + hr, _, err := i.Vtbl.GetHttpStatusCode.Call( uintptr(unsafe.Pointer(i)), - uintptr(value), + uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventHandler.go index 756ae927752..34056871e51 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NavigationCompletedEventHandler struct { impl ICoreWebView2NavigationCompletedEventHandlerImpl } -func (i *ICoreWebView2NavigationCompletedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NavigationCompletedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationCompletedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NavigationCompletedEventHandlerIUnknownQueryInterface(this *ICoreWebView2NavigationCompletedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NavigationCompletedEventHandlerIUnknownQueryInterface(this *IC } func ICoreWebView2NavigationCompletedEventHandlerIUnknownAddRef(this *ICoreWebView2NavigationCompletedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NavigationCompletedEventHandlerIUnknownRelease(this *ICoreWebView2NavigationCompletedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NavigationCompletedEventHandlerInvoke(this *ICoreWebView2NavigationCompletedEventHandler, sender *ICoreWebView2, args *ICoreWebView2NavigationCompletedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NavigationCompletedEventHandlerImpl interface { } var ICoreWebView2NavigationCompletedEventHandlerFn = ICoreWebView2NavigationCompletedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NavigationCompletedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NavigationCompletedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NavigationCompletedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go index 34e6b25e37b..5649d9df8a6 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go @@ -1,40 +1,46 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NavigationStartingEventArgsVtbl struct { IUnknownVtbl - GetUri ComProc + GetUri ComProc GetIsUserInitiated ComProc - GetIsRedirected ComProc - GetRequestHeaders ComProc - GetCancel ComProc - PutCancel ComProc - GetNavigationId ComProc + GetIsRedirected ComProc + GetRequestHeaders ComProc + GetCancel ComProc + PutCancel ComProc + GetNavigationId ComProc } type ICoreWebView2NavigationStartingEventArgs struct { Vtbl *ICoreWebView2NavigationStartingEventArgsVtbl } -func (i *ICoreWebView2NavigationStartingEventArgs) AddRef() uintptr { +func (i *ICoreWebView2NavigationStartingEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationStartingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2NavigationStartingEventArgs) GetUri() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -42,14 +48,14 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2NavigationStartingEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _isUserInitiated int32 - hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( + hr, _, err := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isUserInitiated)), ) @@ -57,15 +63,15 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetIsUserInitiated() (bool, e return false, syscall.Errno(hr) } // Get result and cleanup - isUserInitiated := _isUserInitiated != 0 - return isUserInitiated, nil + isUserInitiated := _isUserInitiated != 0 + return isUserInitiated, err } func (i *ICoreWebView2NavigationStartingEventArgs) GetIsRedirected() (bool, error) { // Create int32 to hold bool result var _isRedirected int32 - hr, _, _ := i.Vtbl.GetIsRedirected.Call( + hr, _, err := i.Vtbl.GetIsRedirected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isRedirected)), ) @@ -73,29 +79,29 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetIsRedirected() (bool, erro return false, syscall.Errno(hr) } // Get result and cleanup - isRedirected := _isRedirected != 0 - return isRedirected, nil + isRedirected := _isRedirected != 0 + return isRedirected, err } func (i *ICoreWebView2NavigationStartingEventArgs) GetRequestHeaders() (*ICoreWebView2HttpRequestHeaders, error) { var requestHeaders *ICoreWebView2HttpRequestHeaders - hr, _, _ := i.Vtbl.GetRequestHeaders.Call( + hr, _, err := i.Vtbl.GetRequestHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&requestHeaders)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return requestHeaders, nil + return requestHeaders, err } func (i *ICoreWebView2NavigationStartingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _cancel int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_cancel)), ) @@ -103,32 +109,38 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetCancel() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - cancel := _cancel != 0 - return cancel, nil + cancel := _cancel != 0 + return cancel, err } func (i *ICoreWebView2NavigationStartingEventArgs) PutCancel(cancel bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _cancel int32 + if cancel { + _cancel = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&cancel)), + uintptr(_cancel), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2NavigationStartingEventArgs) GetNavigationId() (uint64, error) { var navigationId uint64 - hr, _, _ := i.Vtbl.GetNavigationId.Call( + hr, _, err := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&navigationId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return navigationId, nil + return navigationId, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go index 16d2e3e7bb6..d066fcd48e5 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NavigationStartingEventArgs2Vtbl struct { @@ -18,30 +17,40 @@ type ICoreWebView2NavigationStartingEventArgs2 struct { Vtbl *ICoreWebView2NavigationStartingEventArgs2Vtbl } -func (i *ICoreWebView2NavigationStartingEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2NavigationStartingEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationStartingEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2NavigationStartingEventArgs2() *ICoreWebView2NavigationStartingEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2NavigationStartingEventArgs2() (*ICoreWebView2NavigationStartingEventArgs2, error) { var result *ICoreWebView2NavigationStartingEventArgs2 iidICoreWebView2NavigationStartingEventArgs2 := NewGUID("{9086be93-91aa-472d-a7e0-579f2ba006ad}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2NavigationStartingEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2NavigationStartingEventArgs2) GetAdditionalAllowedFrameAncestors() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetAdditionalAllowedFrameAncestors.Call( + + hr, _, err := i.Vtbl.GetAdditionalAllowedFrameAncestors.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -49,7 +58,7 @@ func (i *ICoreWebView2NavigationStartingEventArgs2) GetAdditionalAllowedFrameAnc // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2NavigationStartingEventArgs2) PutAdditionalAllowedFrameAncestors(value string) error { @@ -60,12 +69,12 @@ func (i *ICoreWebView2NavigationStartingEventArgs2) PutAdditionalAllowedFrameAnc return err } - hr, _, _ := i.Vtbl.PutAdditionalAllowedFrameAncestors.Call( + hr, _, err := i.Vtbl.PutAdditionalAllowedFrameAncestors.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go index c04120e13af..f60705a3af4 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NavigationStartingEventArgs3Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2NavigationStartingEventArgs3 struct { Vtbl *ICoreWebView2NavigationStartingEventArgs3Vtbl } -func (i *ICoreWebView2NavigationStartingEventArgs3) AddRef() uintptr { +func (i *ICoreWebView2NavigationStartingEventArgs3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationStartingEventArgs3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2NavigationStartingEventArgs3() *ICoreWebView2NavigationStartingEventArgs3 { + +func (i *ICoreWebView2) GetICoreWebView2NavigationStartingEventArgs3() (*ICoreWebView2NavigationStartingEventArgs3, error) { var result *ICoreWebView2NavigationStartingEventArgs3 iidICoreWebView2NavigationStartingEventArgs3 := NewGUID("{ddffe494-4942-4bd2-ab73-35b8ff40e19f}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2NavigationStartingEventArgs3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2NavigationStartingEventArgs3) GetNavigationKind() (COREWEBVIEW2_NAVIGATION_KIND, error) { var value COREWEBVIEW2_NAVIGATION_KIND - hr, _, _ := i.Vtbl.GetNavigationKind.Call( + hr, _, err := i.Vtbl.GetNavigationKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventHandler.go index 4913137da46..2f2c5a9ae48 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NavigationStartingEventHandler struct { impl ICoreWebView2NavigationStartingEventHandlerImpl } -func (i *ICoreWebView2NavigationStartingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NavigationStartingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NavigationStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NavigationStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2NavigationStartingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NavigationStartingEventHandlerIUnknownQueryInterface(this *ICo } func ICoreWebView2NavigationStartingEventHandlerIUnknownAddRef(this *ICoreWebView2NavigationStartingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NavigationStartingEventHandlerIUnknownRelease(this *ICoreWebView2NavigationStartingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NavigationStartingEventHandlerInvoke(this *ICoreWebView2NavigationStartingEventHandler, sender *ICoreWebView2, args *ICoreWebView2NavigationStartingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NavigationStartingEventHandlerImpl interface { } var ICoreWebView2NavigationStartingEventHandlerFn = ICoreWebView2NavigationStartingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NavigationStartingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NavigationStartingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NavigationStartingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2NewBrowserVersionAvailableEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NewBrowserVersionAvailableEventHandler.go index c68f52daa8f..4e646b34d93 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewBrowserVersionAvailableEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NewBrowserVersionAvailableEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NewBrowserVersionAvailableEventHandler struct { impl ICoreWebView2NewBrowserVersionAvailableEventHandlerImpl } -func (i *ICoreWebView2NewBrowserVersionAvailableEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NewBrowserVersionAvailableEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NewBrowserVersionAvailableEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownQueryInterface(this *ICoreWebView2NewBrowserVersionAvailableEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownQueryInterface(t } func ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownAddRef(this *ICoreWebView2NewBrowserVersionAvailableEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownRelease(this *ICoreWebView2NewBrowserVersionAvailableEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NewBrowserVersionAvailableEventHandlerInvoke(this *ICoreWebView2NewBrowserVersionAvailableEventHandler, sender *ICoreWebView2Environment, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NewBrowserVersionAvailableEventHandlerImpl interface { } var ICoreWebView2NewBrowserVersionAvailableEventHandlerFn = ICoreWebView2NewBrowserVersionAvailableEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NewBrowserVersionAvailableEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go index c47edc7de69..4f644915076 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go @@ -1,41 +1,47 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NewWindowRequestedEventArgsVtbl struct { IUnknownVtbl - GetUri ComProc - PutNewWindow ComProc - GetNewWindow ComProc - PutHandled ComProc - GetHandled ComProc + GetUri ComProc + PutNewWindow ComProc + GetNewWindow ComProc + PutHandled ComProc + GetHandled ComProc GetIsUserInitiated ComProc - GetDeferral ComProc - GetWindowFeatures ComProc + GetDeferral ComProc + GetWindowFeatures ComProc } type ICoreWebView2NewWindowRequestedEventArgs struct { Vtbl *ICoreWebView2NewWindowRequestedEventArgsVtbl } -func (i *ICoreWebView2NewWindowRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2NewWindowRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NewWindowRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2NewWindowRequestedEventArgs) GetUri() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -43,52 +49,59 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2NewWindowRequestedEventArgs) PutNewWindow(newWindow *ICoreWebView2) error { - hr, _, _ := i.Vtbl.PutNewWindow.Call( + + hr, _, err := i.Vtbl.PutNewWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(newWindow)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetNewWindow() (*ICoreWebView2, error) { var newWindow *ICoreWebView2 - hr, _, _ := i.Vtbl.GetNewWindow.Call( + hr, _, err := i.Vtbl.GetNewWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&newWindow)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return newWindow, nil + return newWindow, err } func (i *ICoreWebView2NewWindowRequestedEventArgs) PutHandled(handled bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _handled int32 + if handled { + _handled = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&handled)), + uintptr(_handled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _handled int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_handled)), ) @@ -96,15 +109,15 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetHandled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - handled := _handled != 0 - return handled, nil + handled := _handled != 0 + return handled, err } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _isUserInitiated int32 - hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( + hr, _, err := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isUserInitiated)), ) @@ -112,34 +125,34 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetIsUserInitiated() (bool, e return false, syscall.Errno(hr) } // Get result and cleanup - isUserInitiated := _isUserInitiated != 0 - return isUserInitiated, nil + isUserInitiated := _isUserInitiated != 0 + return isUserInitiated, err } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetWindowFeatures() (*ICoreWebView2WindowFeatures, error) { var value *ICoreWebView2WindowFeatures - hr, _, _ := i.Vtbl.GetWindowFeatures.Call( + hr, _, err := i.Vtbl.GetWindowFeatures.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go index 727437c8a46..c8c30947d06 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NewWindowRequestedEventArgs2Vtbl struct { @@ -17,30 +16,40 @@ type ICoreWebView2NewWindowRequestedEventArgs2 struct { Vtbl *ICoreWebView2NewWindowRequestedEventArgs2Vtbl } -func (i *ICoreWebView2NewWindowRequestedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2NewWindowRequestedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NewWindowRequestedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2NewWindowRequestedEventArgs2() *ICoreWebView2NewWindowRequestedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2NewWindowRequestedEventArgs2() (*ICoreWebView2NewWindowRequestedEventArgs2, error) { var result *ICoreWebView2NewWindowRequestedEventArgs2 iidICoreWebView2NewWindowRequestedEventArgs2 := NewGUID("{bbc7baed-74c6-4c92-b63a-7f5aeae03de3}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2NewWindowRequestedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2NewWindowRequestedEventArgs2) GetName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,5 +57,5 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs2) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go index 99cc2236ad4..edb17fe9cde 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NewWindowRequestedEventArgs3Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2NewWindowRequestedEventArgs3 struct { Vtbl *ICoreWebView2NewWindowRequestedEventArgs3Vtbl } -func (i *ICoreWebView2NewWindowRequestedEventArgs3) AddRef() uintptr { +func (i *ICoreWebView2NewWindowRequestedEventArgs3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NewWindowRequestedEventArgs3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2NewWindowRequestedEventArgs3() *ICoreWebView2NewWindowRequestedEventArgs3 { + +func (i *ICoreWebView2) GetICoreWebView2NewWindowRequestedEventArgs3() (*ICoreWebView2NewWindowRequestedEventArgs3, error) { var result *ICoreWebView2NewWindowRequestedEventArgs3 iidICoreWebView2NewWindowRequestedEventArgs3 := NewGUID("{842bed3c-6ad6-4dd9-b938-28c96667ad66}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2NewWindowRequestedEventArgs3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2NewWindowRequestedEventArgs3) GetOriginalSourceFrameInfo() (*ICoreWebView2FrameInfo, error) { var value *ICoreWebView2FrameInfo - hr, _, _ := i.Vtbl.GetOriginalSourceFrameInfo.Call( + hr, _, err := i.Vtbl.GetOriginalSourceFrameInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventHandler.go index 7499f65e11a..f1256495ee5 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NewWindowRequestedEventHandler struct { impl ICoreWebView2NewWindowRequestedEventHandlerImpl } -func (i *ICoreWebView2NewWindowRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NewWindowRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NewWindowRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NewWindowRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2NewWindowRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NewWindowRequestedEventHandlerIUnknownQueryInterface(this *ICo } func ICoreWebView2NewWindowRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2NewWindowRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NewWindowRequestedEventHandlerIUnknownRelease(this *ICoreWebView2NewWindowRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NewWindowRequestedEventHandlerInvoke(this *ICoreWebView2NewWindowRequestedEventHandler, sender *ICoreWebView2, args *ICoreWebView2NewWindowRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NewWindowRequestedEventHandlerImpl interface { } var ICoreWebView2NewWindowRequestedEventHandlerFn = ICoreWebView2NewWindowRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NewWindowRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NewWindowRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NewWindowRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go index 9fa76a54c8b..41d1bcdd0e3 100644 --- a/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NonClientRegionChangedEventArgsVtbl struct { @@ -17,21 +16,27 @@ type ICoreWebView2NonClientRegionChangedEventArgs struct { Vtbl *ICoreWebView2NonClientRegionChangedEventArgsVtbl } -func (i *ICoreWebView2NonClientRegionChangedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2NonClientRegionChangedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NonClientRegionChangedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2NonClientRegionChangedEventArgs) GetRegionKind() (COREWEBVIEW2_NON_CLIENT_REGION_KIND, error) { var value COREWEBVIEW2_NON_CLIENT_REGION_KIND - hr, _, _ := i.Vtbl.GetRegionKind.Call( + hr, _, err := i.Vtbl.GetRegionKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventHandler.go index a2feca02d3f..190fce88e51 100644 --- a/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NonClientRegionChangedEventHandler struct { impl ICoreWebView2NonClientRegionChangedEventHandlerImpl } -func (i *ICoreWebView2NonClientRegionChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NonClientRegionChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NonClientRegionChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NonClientRegionChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2NonClientRegionChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NonClientRegionChangedEventHandlerIUnknownQueryInterface(this } func ICoreWebView2NonClientRegionChangedEventHandlerIUnknownAddRef(this *ICoreWebView2NonClientRegionChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NonClientRegionChangedEventHandlerIUnknownRelease(this *ICoreWebView2NonClientRegionChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NonClientRegionChangedEventHandlerInvoke(this *ICoreWebView2NonClientRegionChangedEventHandler, sender *ICoreWebView2CompositionController, args *ICoreWebView2NonClientRegionChangedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NonClientRegionChangedEventHandlerImpl interface { } var ICoreWebView2NonClientRegionChangedEventHandlerFn = ICoreWebView2NonClientRegionChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NonClientRegionChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NonClientRegionChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NonClientRegionChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Notification.go b/webview2/pkg/webview2/ICoreWebView2Notification.go index 29e299681f2..ff97119246b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Notification.go +++ b/webview2/pkg/webview2/ICoreWebView2Notification.go @@ -1,49 +1,54 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NotificationVtbl struct { IUnknownVtbl - AddCloseRequested ComProc - RemoveCloseRequested ComProc - ReportShown ComProc - ReportClicked ComProc - ReportClosed ComProc - GetBody ComProc - GetDirection ComProc - GetLanguage ComProc - GetTag ComProc - GetIconUri ComProc - GetTitle ComProc - GetBadgeUri ComProc - GetBodyImageUri ComProc - GetShouldRenotify ComProc + AddCloseRequested ComProc + RemoveCloseRequested ComProc + ReportShown ComProc + ReportClicked ComProc + ReportClosed ComProc + GetBody ComProc + GetDirection ComProc + GetLanguage ComProc + GetTag ComProc + GetIconUri ComProc + GetTitle ComProc + GetBadgeUri ComProc + GetBodyImageUri ComProc + GetShouldRenotify ComProc GetRequiresInteraction ComProc - GetIsSilent ComProc - GetTimestamp ComProc - GetVibrationPattern ComProc + GetIsSilent ComProc + GetTimestamp ComProc + GetVibrationPattern ComProc } type ICoreWebView2Notification struct { Vtbl *ICoreWebView2NotificationVtbl } -func (i *ICoreWebView2Notification) AddRef() uintptr { +func (i *ICoreWebView2Notification) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Notification) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2Notification) AddCloseRequested(eventHandler *ICoreWebView2NotificationCloseRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddCloseRequested.Call( + hr, _, err := i.Vtbl.AddCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -51,61 +56,66 @@ func (i *ICoreWebView2Notification) AddCloseRequested(eventHandler *ICoreWebView if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Notification) RemoveCloseRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveCloseRequested.Call( + + hr, _, err := i.Vtbl.RemoveCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Notification) ReportShown() error { - hr, _, _ := i.Vtbl.ReportShown.Call( + + hr, _, err := i.Vtbl.ReportShown.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Notification) ReportClicked() error { - hr, _, _ := i.Vtbl.ReportClicked.Call( + + hr, _, err := i.Vtbl.ReportClicked.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Notification) ReportClosed() error { - hr, _, _ := i.Vtbl.ReportClosed.Call( + + hr, _, err := i.Vtbl.ReportClosed.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Notification) GetBody() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetBody.Call( + + hr, _, err := i.Vtbl.GetBody.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -113,30 +123,31 @@ func (i *ICoreWebView2Notification) GetBody() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetDirection() (COREWEBVIEW2_TEXT_DIRECTION_KIND, error) { var value COREWEBVIEW2_TEXT_DIRECTION_KIND - hr, _, _ := i.Vtbl.GetDirection.Call( + hr, _, err := i.Vtbl.GetDirection.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetLanguage() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetLanguage.Call( + + hr, _, err := i.Vtbl.GetLanguage.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -144,16 +155,17 @@ func (i *ICoreWebView2Notification) GetLanguage() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetTag() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetTag.Call( + + hr, _, err := i.Vtbl.GetTag.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -161,16 +173,17 @@ func (i *ICoreWebView2Notification) GetTag() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetIconUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetIconUri.Call( + + hr, _, err := i.Vtbl.GetIconUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -178,16 +191,17 @@ func (i *ICoreWebView2Notification) GetIconUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetTitle() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetTitle.Call( + + hr, _, err := i.Vtbl.GetTitle.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -195,16 +209,17 @@ func (i *ICoreWebView2Notification) GetTitle() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetBadgeUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetBadgeUri.Call( + + hr, _, err := i.Vtbl.GetBadgeUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -212,16 +227,17 @@ func (i *ICoreWebView2Notification) GetBadgeUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetBodyImageUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetBodyImageUri.Call( + + hr, _, err := i.Vtbl.GetBodyImageUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -229,14 +245,14 @@ func (i *ICoreWebView2Notification) GetBodyImageUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetShouldRenotify() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetShouldRenotify.Call( + hr, _, err := i.Vtbl.GetShouldRenotify.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -244,15 +260,15 @@ func (i *ICoreWebView2Notification) GetShouldRenotify() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Notification) GetRequiresInteraction() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetRequiresInteraction.Call( + hr, _, err := i.Vtbl.GetRequiresInteraction.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -260,15 +276,15 @@ func (i *ICoreWebView2Notification) GetRequiresInteraction() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Notification) GetIsSilent() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsSilent.Call( + hr, _, err := i.Vtbl.GetIsSilent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -276,22 +292,22 @@ func (i *ICoreWebView2Notification) GetIsSilent() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Notification) GetTimestamp() (float64, error) { var value float64 - hr, _, _ := i.Vtbl.GetTimestamp.Call( + hr, _, err := i.Vtbl.GetTimestamp.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Notification) GetVibrationPattern() (uint32, *uint64, error) { @@ -299,7 +315,7 @@ func (i *ICoreWebView2Notification) GetVibrationPattern() (uint32, *uint64, erro var count uint32 var vibrationPattern *uint64 - hr, _, _ := i.Vtbl.GetVibrationPattern.Call( + hr, _, err := i.Vtbl.GetVibrationPattern.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&count)), uintptr(unsafe.Pointer(&vibrationPattern)), @@ -307,5 +323,5 @@ func (i *ICoreWebView2Notification) GetVibrationPattern() (uint32, *uint64, erro if windows.Handle(hr) != windows.S_OK { return 0, nil, syscall.Errno(hr) } - return count, vibrationPattern, nil + return count, vibrationPattern, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NotificationCloseRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NotificationCloseRequestedEventHandler.go index d00158a01eb..96e586cf432 100644 --- a/webview2/pkg/webview2/ICoreWebView2NotificationCloseRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NotificationCloseRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NotificationCloseRequestedEventHandler struct { impl ICoreWebView2NotificationCloseRequestedEventHandlerImpl } -func (i *ICoreWebView2NotificationCloseRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NotificationCloseRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NotificationCloseRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2NotificationCloseRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownQueryInterface(t } func ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2NotificationCloseRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownRelease(this *ICoreWebView2NotificationCloseRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NotificationCloseRequestedEventHandlerInvoke(this *ICoreWebView2NotificationCloseRequestedEventHandler, sender *ICoreWebView2Notification, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NotificationCloseRequestedEventHandlerImpl interface { } var ICoreWebView2NotificationCloseRequestedEventHandlerFn = ICoreWebView2NotificationCloseRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NotificationCloseRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go index 304802c97c5..32f5e310ffb 100644 --- a/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go @@ -1,38 +1,44 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2NotificationReceivedEventArgsVtbl struct { IUnknownVtbl GetSenderOrigin ComProc GetNotification ComProc - PutHandled ComProc - GetHandled ComProc - GetDeferral ComProc + PutHandled ComProc + GetHandled ComProc + GetDeferral ComProc } type ICoreWebView2NotificationReceivedEventArgs struct { Vtbl *ICoreWebView2NotificationReceivedEventArgsVtbl } -func (i *ICoreWebView2NotificationReceivedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2NotificationReceivedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NotificationReceivedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2NotificationReceivedEventArgs) GetSenderOrigin() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSenderOrigin.Call( + + hr, _, err := i.Vtbl.GetSenderOrigin.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -40,40 +46,46 @@ func (i *ICoreWebView2NotificationReceivedEventArgs) GetSenderOrigin() (string, // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2NotificationReceivedEventArgs) GetNotification() (*ICoreWebView2Notification, error) { var value *ICoreWebView2Notification - hr, _, _ := i.Vtbl.GetNotification.Call( + hr, _, err := i.Vtbl.GetNotification.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2NotificationReceivedEventArgs) PutHandled(value bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2NotificationReceivedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -81,20 +93,20 @@ func (i *ICoreWebView2NotificationReceivedEventArgs) GetHandled() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2NotificationReceivedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventHandler.go index 6690d8cda22..3dfcc907c78 100644 --- a/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2NotificationReceivedEventHandler struct { impl ICoreWebView2NotificationReceivedEventHandlerImpl } -func (i *ICoreWebView2NotificationReceivedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2NotificationReceivedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2NotificationReceivedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2NotificationReceivedEventHandlerIUnknownQueryInterface(this *ICoreWebView2NotificationReceivedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2NotificationReceivedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2NotificationReceivedEventHandlerIUnknownAddRef(this *ICoreWebView2NotificationReceivedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2NotificationReceivedEventHandlerIUnknownRelease(this *ICoreWebView2NotificationReceivedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2NotificationReceivedEventHandlerInvoke(this *ICoreWebView2NotificationReceivedEventHandler, sender *ICoreWebView2, args *ICoreWebView2NotificationReceivedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2NotificationReceivedEventHandlerImpl interface { } var ICoreWebView2NotificationReceivedEventHandlerFn = ICoreWebView2NotificationReceivedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2NotificationReceivedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2NotificationReceivedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2NotificationReceivedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go b/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go index 0c87011dd26..d1b49ad87e7 100644 --- a/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ObjectCollectionVtbl struct { @@ -18,44 +17,55 @@ type ICoreWebView2ObjectCollection struct { Vtbl *ICoreWebView2ObjectCollectionVtbl } -func (i *ICoreWebView2ObjectCollection) AddRef() uintptr { +func (i *ICoreWebView2ObjectCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ObjectCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2ObjectCollection() *ICoreWebView2ObjectCollection { + +func (i *ICoreWebView2) GetICoreWebView2ObjectCollection() (*ICoreWebView2ObjectCollection, error) { var result *ICoreWebView2ObjectCollection iidICoreWebView2ObjectCollection := NewGUID("{5cfec11c-25bd-4e8d-9e1a-7acdaeeec047}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2ObjectCollection)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2ObjectCollection) RemoveValueAtIndex(index uint32) error { - hr, _, _ := i.Vtbl.RemoveValueAtIndex.Call( + + hr, _, err := i.Vtbl.RemoveValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ObjectCollection) InsertValueAtIndex(index uint32, value *IUnknown) error { - hr, _, _ := i.Vtbl.InsertValueAtIndex.Call( + + hr, _, err := i.Vtbl.InsertValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go b/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go index cdad6e77705..7eecb57ed80 100644 --- a/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go +++ b/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ObjectCollectionViewVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2ObjectCollectionView struct { Vtbl *ICoreWebView2ObjectCollectionViewVtbl } -func (i *ICoreWebView2ObjectCollectionView) AddRef() uintptr { +func (i *ICoreWebView2ObjectCollectionView) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ObjectCollectionView) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ObjectCollectionView) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ObjectCollectionView) GetValueAtIndex(index uint32) (*IUnknown, error) { var value *IUnknown - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go index 832a4c6357a..e2ad0e9ef34 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go @@ -1,39 +1,45 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PermissionRequestedEventArgsVtbl struct { IUnknownVtbl - GetUri ComProc - GetPermissionKind ComProc + GetUri ComProc + GetPermissionKind ComProc GetIsUserInitiated ComProc - GetState ComProc - PutState ComProc - GetDeferral ComProc + GetState ComProc + PutState ComProc + GetDeferral ComProc } type ICoreWebView2PermissionRequestedEventArgs struct { Vtbl *ICoreWebView2PermissionRequestedEventArgsVtbl } -func (i *ICoreWebView2PermissionRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2PermissionRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2PermissionRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2PermissionRequestedEventArgs) GetUri() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -41,28 +47,28 @@ func (i *ICoreWebView2PermissionRequestedEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2PermissionRequestedEventArgs) GetPermissionKind() (COREWEBVIEW2_PERMISSION_KIND, error) { var permissionKind COREWEBVIEW2_PERMISSION_KIND - hr, _, _ := i.Vtbl.GetPermissionKind.Call( + hr, _, err := i.Vtbl.GetPermissionKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&permissionKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return permissionKind, nil + return permissionKind, err } func (i *ICoreWebView2PermissionRequestedEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _isUserInitiated int32 - hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( + hr, _, err := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isUserInitiated)), ) @@ -70,46 +76,47 @@ func (i *ICoreWebView2PermissionRequestedEventArgs) GetIsUserInitiated() (bool, return false, syscall.Errno(hr) } // Get result and cleanup - isUserInitiated := _isUserInitiated != 0 - return isUserInitiated, nil + isUserInitiated := _isUserInitiated != 0 + return isUserInitiated, err } func (i *ICoreWebView2PermissionRequestedEventArgs) GetState() (COREWEBVIEW2_PERMISSION_STATE, error) { var state COREWEBVIEW2_PERMISSION_STATE - hr, _, _ := i.Vtbl.GetState.Call( + hr, _, err := i.Vtbl.GetState.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&state)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return state, nil + return state, err } func (i *ICoreWebView2PermissionRequestedEventArgs) PutState(state COREWEBVIEW2_PERMISSION_STATE) error { - hr, _, _ := i.Vtbl.PutState.Call( + + hr, _, err := i.Vtbl.PutState.Call( uintptr(unsafe.Pointer(i)), uintptr(state), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PermissionRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go index 00933259fb3..36c0f684270 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PermissionRequestedEventArgs2Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2PermissionRequestedEventArgs2 struct { Vtbl *ICoreWebView2PermissionRequestedEventArgs2Vtbl } -func (i *ICoreWebView2PermissionRequestedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2PermissionRequestedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PermissionRequestedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2PermissionRequestedEventArgs2() *ICoreWebView2PermissionRequestedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2PermissionRequestedEventArgs2() (*ICoreWebView2PermissionRequestedEventArgs2, error) { var result *ICoreWebView2PermissionRequestedEventArgs2 iidICoreWebView2PermissionRequestedEventArgs2 := NewGUID("{74d7127f-9de6-4200-8734-42d6fb4ff741}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2PermissionRequestedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2PermissionRequestedEventArgs2) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2PermissionRequestedEventArgs2) GetHandled() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2PermissionRequestedEventArgs2) PutHandled(value bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go index 99fc5d32799..a0c23b79432 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PermissionRequestedEventArgs3Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2PermissionRequestedEventArgs3 struct { Vtbl *ICoreWebView2PermissionRequestedEventArgs3Vtbl } -func (i *ICoreWebView2PermissionRequestedEventArgs3) AddRef() uintptr { +func (i *ICoreWebView2PermissionRequestedEventArgs3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PermissionRequestedEventArgs3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2PermissionRequestedEventArgs3() *ICoreWebView2PermissionRequestedEventArgs3 { + +func (i *ICoreWebView2) GetICoreWebView2PermissionRequestedEventArgs3() (*ICoreWebView2PermissionRequestedEventArgs3, error) { var result *ICoreWebView2PermissionRequestedEventArgs3 iidICoreWebView2PermissionRequestedEventArgs3 := NewGUID("{e61670bc-3dce-4177-86d2-c629ae3cb6ac}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2PermissionRequestedEventArgs3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2PermissionRequestedEventArgs3) GetSavesInProfile() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetSavesInProfile.Call( + hr, _, err := i.Vtbl.GetSavesInProfile.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2PermissionRequestedEventArgs3) GetSavesInProfile() (bool, return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2PermissionRequestedEventArgs3) PutSavesInProfile(value bool) error { - hr, _, _ := i.Vtbl.PutSavesInProfile.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutSavesInProfile.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventHandler.go index c73d261798b..648af857219 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2PermissionRequestedEventHandler struct { impl ICoreWebView2PermissionRequestedEventHandlerImpl } -func (i *ICoreWebView2PermissionRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2PermissionRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PermissionRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2PermissionRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2PermissionRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2PermissionRequestedEventHandlerIUnknownQueryInterface(this *IC } func ICoreWebView2PermissionRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2PermissionRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2PermissionRequestedEventHandlerIUnknownRelease(this *ICoreWebView2PermissionRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2PermissionRequestedEventHandlerInvoke(this *ICoreWebView2PermissionRequestedEventHandler, sender *ICoreWebView2, args *ICoreWebView2PermissionRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2PermissionRequestedEventHandlerImpl interface { } var ICoreWebView2PermissionRequestedEventHandlerFn = ICoreWebView2PermissionRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2PermissionRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2PermissionRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2PermissionRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go b/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go index 7bcbdd7d655..2cd8253f944 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go @@ -1,50 +1,56 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PermissionSettingVtbl struct { IUnknownVtbl - GetPermissionKind ComProc + GetPermissionKind ComProc GetPermissionOrigin ComProc - GetPermissionState ComProc + GetPermissionState ComProc } type ICoreWebView2PermissionSetting struct { Vtbl *ICoreWebView2PermissionSettingVtbl } -func (i *ICoreWebView2PermissionSetting) AddRef() uintptr { +func (i *ICoreWebView2PermissionSetting) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2PermissionSetting) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2PermissionSetting) GetPermissionKind() (COREWEBVIEW2_PERMISSION_KIND, error) { var value COREWEBVIEW2_PERMISSION_KIND - hr, _, _ := i.Vtbl.GetPermissionKind.Call( + hr, _, err := i.Vtbl.GetPermissionKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PermissionSetting) GetPermissionOrigin() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetPermissionOrigin.Call( + + hr, _, err := i.Vtbl.GetPermissionOrigin.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -52,19 +58,19 @@ func (i *ICoreWebView2PermissionSetting) GetPermissionOrigin() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2PermissionSetting) GetPermissionState() (COREWEBVIEW2_PERMISSION_STATE, error) { var value COREWEBVIEW2_PERMISSION_STATE - hr, _, _ := i.Vtbl.GetPermissionState.Call( + hr, _, err := i.Vtbl.GetPermissionState.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go b/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go index bd9a4b73636..e599b574254 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go @@ -1,53 +1,58 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PermissionSettingCollectionViewVtbl struct { IUnknownVtbl GetValueAtIndex ComProc - GetCount ComProc + GetCount ComProc } type ICoreWebView2PermissionSettingCollectionView struct { Vtbl *ICoreWebView2PermissionSettingCollectionViewVtbl } -func (i *ICoreWebView2PermissionSettingCollectionView) AddRef() uintptr { +func (i *ICoreWebView2PermissionSettingCollectionView) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PermissionSettingCollectionView) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2PermissionSettingCollectionView) GetValueAtIndex(index uint32) (*ICoreWebView2PermissionSetting, error) { var permissionSetting *ICoreWebView2PermissionSetting - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&permissionSetting)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return permissionSetting, nil + return permissionSetting, err } func (i *ICoreWebView2PermissionSettingCollectionView) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2PointerInfo.go b/webview2/pkg/webview2/ICoreWebView2PointerInfo.go index 240ce64bf2e..5aef4b2a58c 100644 --- a/webview2/pkg/webview2/ICoreWebView2PointerInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2PointerInfo.go @@ -1,806 +1,839 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PointerInfoVtbl struct { IUnknownVtbl - GetPointerKind ComProc - PutPointerKind ComProc - GetPointerId ComProc - PutPointerId ComProc - GetFrameId ComProc - PutFrameId ComProc - GetPointerFlags ComProc - PutPointerFlags ComProc - GetPointerDeviceRect ComProc - PutPointerDeviceRect ComProc - GetDisplayRect ComProc - PutDisplayRect ComProc - GetPixelLocation ComProc - PutPixelLocation ComProc - GetHimetricLocation ComProc - PutHimetricLocation ComProc - GetPixelLocationRaw ComProc - PutPixelLocationRaw ComProc + GetPointerKind ComProc + PutPointerKind ComProc + GetPointerId ComProc + PutPointerId ComProc + GetFrameId ComProc + PutFrameId ComProc + GetPointerFlags ComProc + PutPointerFlags ComProc + GetPointerDeviceRect ComProc + PutPointerDeviceRect ComProc + GetDisplayRect ComProc + PutDisplayRect ComProc + GetPixelLocation ComProc + PutPixelLocation ComProc + GetHimetricLocation ComProc + PutHimetricLocation ComProc + GetPixelLocationRaw ComProc + PutPixelLocationRaw ComProc GetHimetricLocationRaw ComProc PutHimetricLocationRaw ComProc - GetTime ComProc - PutTime ComProc - GetHistoryCount ComProc - PutHistoryCount ComProc - GetInputData ComProc - PutInputData ComProc - GetKeyStates ComProc - PutKeyStates ComProc - GetPerformanceCount ComProc - PutPerformanceCount ComProc - GetButtonChangeKind ComProc - PutButtonChangeKind ComProc - GetPenFlags ComProc - PutPenFlags ComProc - GetPenMask ComProc - PutPenMask ComProc - GetPenPressure ComProc - PutPenPressure ComProc - GetPenRotation ComProc - PutPenRotation ComProc - GetPenTiltX ComProc - PutPenTiltX ComProc - GetPenTiltY ComProc - PutPenTiltY ComProc - GetTouchFlags ComProc - PutTouchFlags ComProc - GetTouchMask ComProc - PutTouchMask ComProc - GetTouchContact ComProc - PutTouchContact ComProc - GetTouchContactRaw ComProc - PutTouchContactRaw ComProc - GetTouchOrientation ComProc - PutTouchOrientation ComProc - GetTouchPressure ComProc - PutTouchPressure ComProc + GetTime ComProc + PutTime ComProc + GetHistoryCount ComProc + PutHistoryCount ComProc + GetInputData ComProc + PutInputData ComProc + GetKeyStates ComProc + PutKeyStates ComProc + GetPerformanceCount ComProc + PutPerformanceCount ComProc + GetButtonChangeKind ComProc + PutButtonChangeKind ComProc + GetPenFlags ComProc + PutPenFlags ComProc + GetPenMask ComProc + PutPenMask ComProc + GetPenPressure ComProc + PutPenPressure ComProc + GetPenRotation ComProc + PutPenRotation ComProc + GetPenTiltX ComProc + PutPenTiltX ComProc + GetPenTiltY ComProc + PutPenTiltY ComProc + GetTouchFlags ComProc + PutTouchFlags ComProc + GetTouchMask ComProc + PutTouchMask ComProc + GetTouchContact ComProc + PutTouchContact ComProc + GetTouchContactRaw ComProc + PutTouchContactRaw ComProc + GetTouchOrientation ComProc + PutTouchOrientation ComProc + GetTouchPressure ComProc + PutTouchPressure ComProc } type ICoreWebView2PointerInfo struct { Vtbl *ICoreWebView2PointerInfoVtbl } -func (i *ICoreWebView2PointerInfo) AddRef() uintptr { +func (i *ICoreWebView2PointerInfo) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PointerInfo) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2PointerInfo) GetPointerKind() (uint32, error) { var pointerKind uint32 - hr, _, _ := i.Vtbl.GetPointerKind.Call( + hr, _, err := i.Vtbl.GetPointerKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return pointerKind, nil + return pointerKind, err } func (i *ICoreWebView2PointerInfo) PutPointerKind(pointerKind uint32) error { - hr, _, _ := i.Vtbl.PutPointerKind.Call( + + hr, _, err := i.Vtbl.PutPointerKind.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&pointerKind)), + uintptr(pointerKind), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPointerId() (uint32, error) { var pointerId uint32 - hr, _, _ := i.Vtbl.GetPointerId.Call( + hr, _, err := i.Vtbl.GetPointerId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return pointerId, nil + return pointerId, err } func (i *ICoreWebView2PointerInfo) PutPointerId(pointerId uint32) error { - hr, _, _ := i.Vtbl.PutPointerId.Call( + + hr, _, err := i.Vtbl.PutPointerId.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&pointerId)), + uintptr(pointerId), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetFrameId() (uint32, error) { var frameId uint32 - hr, _, _ := i.Vtbl.GetFrameId.Call( + hr, _, err := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frameId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return frameId, nil + return frameId, err } func (i *ICoreWebView2PointerInfo) PutFrameId(frameId uint32) error { - hr, _, _ := i.Vtbl.PutFrameId.Call( + + hr, _, err := i.Vtbl.PutFrameId.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&frameId)), + uintptr(frameId), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPointerFlags() (uint32, error) { var pointerFlags uint32 - hr, _, _ := i.Vtbl.GetPointerFlags.Call( + hr, _, err := i.Vtbl.GetPointerFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerFlags)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return pointerFlags, nil + return pointerFlags, err } func (i *ICoreWebView2PointerInfo) PutPointerFlags(pointerFlags uint32) error { - hr, _, _ := i.Vtbl.PutPointerFlags.Call( + + hr, _, err := i.Vtbl.PutPointerFlags.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&pointerFlags)), + uintptr(pointerFlags), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPointerDeviceRect() (RECT, error) { var pointerDeviceRect RECT - hr, _, _ := i.Vtbl.GetPointerDeviceRect.Call( + hr, _, err := i.Vtbl.GetPointerDeviceRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerDeviceRect)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return pointerDeviceRect, nil + return pointerDeviceRect, err } func (i *ICoreWebView2PointerInfo) PutPointerDeviceRect(pointerDeviceRect RECT) error { - hr, _, _ := i.Vtbl.PutPointerDeviceRect.Call( + + hr, _, err := i.Vtbl.PutPointerDeviceRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerDeviceRect)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetDisplayRect() (RECT, error) { var displayRect RECT - hr, _, _ := i.Vtbl.GetDisplayRect.Call( + hr, _, err := i.Vtbl.GetDisplayRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&displayRect)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return displayRect, nil + return displayRect, err } func (i *ICoreWebView2PointerInfo) PutDisplayRect(displayRect RECT) error { - hr, _, _ := i.Vtbl.PutDisplayRect.Call( + + hr, _, err := i.Vtbl.PutDisplayRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&displayRect)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPixelLocation() (POINT, error) { var pixelLocation POINT - hr, _, _ := i.Vtbl.GetPixelLocation.Call( + hr, _, err := i.Vtbl.GetPixelLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocation)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return pixelLocation, nil + return pixelLocation, err } func (i *ICoreWebView2PointerInfo) PutPixelLocation(pixelLocation POINT) error { - hr, _, _ := i.Vtbl.PutPixelLocation.Call( + + hr, _, err := i.Vtbl.PutPixelLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocation)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetHimetricLocation() (POINT, error) { var himetricLocation POINT - hr, _, _ := i.Vtbl.GetHimetricLocation.Call( + hr, _, err := i.Vtbl.GetHimetricLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocation)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return himetricLocation, nil + return himetricLocation, err } func (i *ICoreWebView2PointerInfo) PutHimetricLocation(himetricLocation POINT) error { - hr, _, _ := i.Vtbl.PutHimetricLocation.Call( + + hr, _, err := i.Vtbl.PutHimetricLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocation)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPixelLocationRaw() (POINT, error) { var pixelLocationRaw POINT - hr, _, _ := i.Vtbl.GetPixelLocationRaw.Call( + hr, _, err := i.Vtbl.GetPixelLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return pixelLocationRaw, nil + return pixelLocationRaw, err } func (i *ICoreWebView2PointerInfo) PutPixelLocationRaw(pixelLocationRaw POINT) error { - hr, _, _ := i.Vtbl.PutPixelLocationRaw.Call( + + hr, _, err := i.Vtbl.PutPixelLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetHimetricLocationRaw() (POINT, error) { var himetricLocationRaw POINT - hr, _, _ := i.Vtbl.GetHimetricLocationRaw.Call( + hr, _, err := i.Vtbl.GetHimetricLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return himetricLocationRaw, nil + return himetricLocationRaw, err } func (i *ICoreWebView2PointerInfo) PutHimetricLocationRaw(himetricLocationRaw POINT) error { - hr, _, _ := i.Vtbl.PutHimetricLocationRaw.Call( + + hr, _, err := i.Vtbl.PutHimetricLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTime() (uint32, error) { var time uint32 - hr, _, _ := i.Vtbl.GetTime.Call( + hr, _, err := i.Vtbl.GetTime.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&time)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return time, nil + return time, err } func (i *ICoreWebView2PointerInfo) PutTime(time uint32) error { - hr, _, _ := i.Vtbl.PutTime.Call( + + hr, _, err := i.Vtbl.PutTime.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&time)), + uintptr(time), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetHistoryCount() (uint32, error) { var historyCount uint32 - hr, _, _ := i.Vtbl.GetHistoryCount.Call( + hr, _, err := i.Vtbl.GetHistoryCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&historyCount)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return historyCount, nil + return historyCount, err } func (i *ICoreWebView2PointerInfo) PutHistoryCount(historyCount uint32) error { - hr, _, _ := i.Vtbl.PutHistoryCount.Call( + + hr, _, err := i.Vtbl.PutHistoryCount.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&historyCount)), + uintptr(historyCount), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetInputData() (int32, error) { var inputData int32 - hr, _, _ := i.Vtbl.GetInputData.Call( + hr, _, err := i.Vtbl.GetInputData.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&inputData)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return inputData, nil + return inputData, err } func (i *ICoreWebView2PointerInfo) PutInputData(inputData int32) error { - hr, _, _ := i.Vtbl.PutInputData.Call( + + hr, _, err := i.Vtbl.PutInputData.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&inputData)), + uintptr(inputData), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetKeyStates() (uint32, error) { var keyStates uint32 - hr, _, _ := i.Vtbl.GetKeyStates.Call( + hr, _, err := i.Vtbl.GetKeyStates.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&keyStates)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return keyStates, nil + return keyStates, err } func (i *ICoreWebView2PointerInfo) PutKeyStates(keyStates uint32) error { - hr, _, _ := i.Vtbl.PutKeyStates.Call( + + hr, _, err := i.Vtbl.PutKeyStates.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&keyStates)), + uintptr(keyStates), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPerformanceCount() (uint64, error) { var performanceCount uint64 - hr, _, _ := i.Vtbl.GetPerformanceCount.Call( + hr, _, err := i.Vtbl.GetPerformanceCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&performanceCount)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return performanceCount, nil + return performanceCount, err } func (i *ICoreWebView2PointerInfo) PutPerformanceCount(performanceCount uint64) error { - hr, _, _ := i.Vtbl.PutPerformanceCount.Call( + + hr, _, err := i.Vtbl.PutPerformanceCount.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&performanceCount)), + uintptr(performanceCount), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetButtonChangeKind() (int32, error) { var buttonChangeKind int32 - hr, _, _ := i.Vtbl.GetButtonChangeKind.Call( + hr, _, err := i.Vtbl.GetButtonChangeKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&buttonChangeKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return buttonChangeKind, nil + return buttonChangeKind, err } func (i *ICoreWebView2PointerInfo) PutButtonChangeKind(buttonChangeKind int32) error { - hr, _, _ := i.Vtbl.PutButtonChangeKind.Call( + + hr, _, err := i.Vtbl.PutButtonChangeKind.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&buttonChangeKind)), + uintptr(buttonChangeKind), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPenFlags() (uint32, error) { var penFLags uint32 - hr, _, _ := i.Vtbl.GetPenFlags.Call( + hr, _, err := i.Vtbl.GetPenFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penFLags)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penFLags, nil + return penFLags, err } func (i *ICoreWebView2PointerInfo) PutPenFlags(penFLags uint32) error { - hr, _, _ := i.Vtbl.PutPenFlags.Call( + + hr, _, err := i.Vtbl.PutPenFlags.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&penFLags)), + uintptr(penFLags), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPenMask() (uint32, error) { var penMask uint32 - hr, _, _ := i.Vtbl.GetPenMask.Call( + hr, _, err := i.Vtbl.GetPenMask.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penMask)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penMask, nil + return penMask, err } func (i *ICoreWebView2PointerInfo) PutPenMask(penMask uint32) error { - hr, _, _ := i.Vtbl.PutPenMask.Call( + + hr, _, err := i.Vtbl.PutPenMask.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&penMask)), + uintptr(penMask), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPenPressure() (uint32, error) { var penPressure uint32 - hr, _, _ := i.Vtbl.GetPenPressure.Call( + hr, _, err := i.Vtbl.GetPenPressure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penPressure)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penPressure, nil + return penPressure, err } func (i *ICoreWebView2PointerInfo) PutPenPressure(penPressure uint32) error { - hr, _, _ := i.Vtbl.PutPenPressure.Call( + + hr, _, err := i.Vtbl.PutPenPressure.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&penPressure)), + uintptr(penPressure), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPenRotation() (uint32, error) { var penRotation uint32 - hr, _, _ := i.Vtbl.GetPenRotation.Call( + hr, _, err := i.Vtbl.GetPenRotation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penRotation)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penRotation, nil + return penRotation, err } func (i *ICoreWebView2PointerInfo) PutPenRotation(penRotation uint32) error { - hr, _, _ := i.Vtbl.PutPenRotation.Call( + + hr, _, err := i.Vtbl.PutPenRotation.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&penRotation)), + uintptr(penRotation), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPenTiltX() (int32, error) { var penTiltX int32 - hr, _, _ := i.Vtbl.GetPenTiltX.Call( + hr, _, err := i.Vtbl.GetPenTiltX.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penTiltX)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penTiltX, nil + return penTiltX, err } func (i *ICoreWebView2PointerInfo) PutPenTiltX(penTiltX int32) error { - hr, _, _ := i.Vtbl.PutPenTiltX.Call( + + hr, _, err := i.Vtbl.PutPenTiltX.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&penTiltX)), + uintptr(penTiltX), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetPenTiltY() (int32, error) { var penTiltY int32 - hr, _, _ := i.Vtbl.GetPenTiltY.Call( + hr, _, err := i.Vtbl.GetPenTiltY.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penTiltY)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penTiltY, nil + return penTiltY, err } func (i *ICoreWebView2PointerInfo) PutPenTiltY(penTiltY int32) error { - hr, _, _ := i.Vtbl.PutPenTiltY.Call( + + hr, _, err := i.Vtbl.PutPenTiltY.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&penTiltY)), + uintptr(penTiltY), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTouchFlags() (uint32, error) { var touchFlags uint32 - hr, _, _ := i.Vtbl.GetTouchFlags.Call( + hr, _, err := i.Vtbl.GetTouchFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchFlags)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchFlags, nil + return touchFlags, err } func (i *ICoreWebView2PointerInfo) PutTouchFlags(touchFlags uint32) error { - hr, _, _ := i.Vtbl.PutTouchFlags.Call( + + hr, _, err := i.Vtbl.PutTouchFlags.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&touchFlags)), + uintptr(touchFlags), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTouchMask() (uint32, error) { var touchMask uint32 - hr, _, _ := i.Vtbl.GetTouchMask.Call( + hr, _, err := i.Vtbl.GetTouchMask.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchMask)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchMask, nil + return touchMask, err } func (i *ICoreWebView2PointerInfo) PutTouchMask(touchMask uint32) error { - hr, _, _ := i.Vtbl.PutTouchMask.Call( + + hr, _, err := i.Vtbl.PutTouchMask.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&touchMask)), + uintptr(touchMask), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTouchContact() (RECT, error) { var touchContact RECT - hr, _, _ := i.Vtbl.GetTouchContact.Call( + hr, _, err := i.Vtbl.GetTouchContact.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContact)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return touchContact, nil + return touchContact, err } func (i *ICoreWebView2PointerInfo) PutTouchContact(touchContact RECT) error { - hr, _, _ := i.Vtbl.PutTouchContact.Call( + + hr, _, err := i.Vtbl.PutTouchContact.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContact)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTouchContactRaw() (RECT, error) { var touchContactRaw RECT - hr, _, _ := i.Vtbl.GetTouchContactRaw.Call( + hr, _, err := i.Vtbl.GetTouchContactRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContactRaw)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return touchContactRaw, nil + return touchContactRaw, err } func (i *ICoreWebView2PointerInfo) PutTouchContactRaw(touchContactRaw RECT) error { - hr, _, _ := i.Vtbl.PutTouchContactRaw.Call( + + hr, _, err := i.Vtbl.PutTouchContactRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContactRaw)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTouchOrientation() (uint32, error) { var touchOrientation uint32 - hr, _, _ := i.Vtbl.GetTouchOrientation.Call( + hr, _, err := i.Vtbl.GetTouchOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchOrientation)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchOrientation, nil + return touchOrientation, err } func (i *ICoreWebView2PointerInfo) PutTouchOrientation(touchOrientation uint32) error { - hr, _, _ := i.Vtbl.PutTouchOrientation.Call( + + hr, _, err := i.Vtbl.PutTouchOrientation.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&touchOrientation)), + uintptr(touchOrientation), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PointerInfo) GetTouchPressure() (uint32, error) { var touchPressure uint32 - hr, _, _ := i.Vtbl.GetTouchPressure.Call( + hr, _, err := i.Vtbl.GetTouchPressure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchPressure)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchPressure, nil + return touchPressure, err } func (i *ICoreWebView2PointerInfo) PutTouchPressure(touchPressure uint32) error { - hr, _, _ := i.Vtbl.PutTouchPressure.Call( + + hr, _, err := i.Vtbl.PutTouchPressure.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&touchPressure)), + uintptr(touchPressure), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2PrintCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2PrintCompletedHandler.go index a8eb769f0f6..b38b14013ba 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2PrintCompletedHandler struct { impl ICoreWebView2PrintCompletedHandlerImpl } -func (i *ICoreWebView2PrintCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2PrintCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PrintCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2PrintCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2PrintCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2PrintCompletedHandlerIUnknownQueryInterface(this *ICoreWebView } func ICoreWebView2PrintCompletedHandlerIUnknownAddRef(this *ICoreWebView2PrintCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2PrintCompletedHandlerIUnknownRelease(this *ICoreWebView2PrintCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2PrintCompletedHandlerInvoke(this *ICoreWebView2PrintCompletedHandler, errorCode uintptr, result COREWEBVIEW2_PRINT_STATUS) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2PrintCompletedHandlerImpl interface { } var ICoreWebView2PrintCompletedHandlerFn = ICoreWebView2PrintCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2PrintCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2PrintCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2PrintCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2PrintSettings.go b/webview2/pkg/webview2/ICoreWebView2PrintSettings.go index 3841e6a49e2..1ba4bbd15d2 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintSettings.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintSettings.go @@ -1,265 +1,278 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PrintSettingsVtbl struct { IUnknownVtbl - GetOrientation ComProc - PutOrientation ComProc - GetScaleFactor ComProc - PutScaleFactor ComProc - GetPageWidth ComProc - PutPageWidth ComProc - GetPageHeight ComProc - PutPageHeight ComProc - GetMarginTop ComProc - PutMarginTop ComProc - GetMarginBottom ComProc - PutMarginBottom ComProc - GetMarginLeft ComProc - PutMarginLeft ComProc - GetMarginRight ComProc - PutMarginRight ComProc - GetShouldPrintBackgrounds ComProc - PutShouldPrintBackgrounds ComProc - GetShouldPrintSelectionOnly ComProc - PutShouldPrintSelectionOnly ComProc + GetOrientation ComProc + PutOrientation ComProc + GetScaleFactor ComProc + PutScaleFactor ComProc + GetPageWidth ComProc + PutPageWidth ComProc + GetPageHeight ComProc + PutPageHeight ComProc + GetMarginTop ComProc + PutMarginTop ComProc + GetMarginBottom ComProc + PutMarginBottom ComProc + GetMarginLeft ComProc + PutMarginLeft ComProc + GetMarginRight ComProc + PutMarginRight ComProc + GetShouldPrintBackgrounds ComProc + PutShouldPrintBackgrounds ComProc + GetShouldPrintSelectionOnly ComProc + PutShouldPrintSelectionOnly ComProc GetShouldPrintHeaderAndFooter ComProc PutShouldPrintHeaderAndFooter ComProc - GetHeaderTitle ComProc - PutHeaderTitle ComProc - GetFooterUri ComProc - PutFooterUri ComProc + GetHeaderTitle ComProc + PutHeaderTitle ComProc + GetFooterUri ComProc + PutFooterUri ComProc } type ICoreWebView2PrintSettings struct { Vtbl *ICoreWebView2PrintSettingsVtbl } -func (i *ICoreWebView2PrintSettings) AddRef() uintptr { +func (i *ICoreWebView2PrintSettings) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2PrintSettings) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2PrintSettings) GetOrientation() (COREWEBVIEW2_PRINT_ORIENTATION, error) { var orientation COREWEBVIEW2_PRINT_ORIENTATION - hr, _, _ := i.Vtbl.GetOrientation.Call( + hr, _, err := i.Vtbl.GetOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&orientation)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return orientation, nil + return orientation, err } func (i *ICoreWebView2PrintSettings) PutOrientation(orientation COREWEBVIEW2_PRINT_ORIENTATION) error { - hr, _, _ := i.Vtbl.PutOrientation.Call( + + hr, _, err := i.Vtbl.PutOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(orientation), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetScaleFactor() (float64, error) { var scaleFactor float64 - hr, _, _ := i.Vtbl.GetScaleFactor.Call( + hr, _, err := i.Vtbl.GetScaleFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&scaleFactor)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return scaleFactor, nil + return scaleFactor, err } func (i *ICoreWebView2PrintSettings) PutScaleFactor(scaleFactor float64) error { - hr, _, _ := i.Vtbl.PutScaleFactor.Call( + + hr, _, err := i.Vtbl.PutScaleFactor.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&scaleFactor)), + uintptr(scaleFactor), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetPageWidth() (float64, error) { var pageWidth float64 - hr, _, _ := i.Vtbl.GetPageWidth.Call( + hr, _, err := i.Vtbl.GetPageWidth.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pageWidth)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return pageWidth, nil + return pageWidth, err } func (i *ICoreWebView2PrintSettings) PutPageWidth(pageWidth float64) error { - hr, _, _ := i.Vtbl.PutPageWidth.Call( + + hr, _, err := i.Vtbl.PutPageWidth.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&pageWidth)), + uintptr(pageWidth), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetPageHeight() (float64, error) { var pageHeight float64 - hr, _, _ := i.Vtbl.GetPageHeight.Call( + hr, _, err := i.Vtbl.GetPageHeight.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pageHeight)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return pageHeight, nil + return pageHeight, err } func (i *ICoreWebView2PrintSettings) PutPageHeight(pageHeight float64) error { - hr, _, _ := i.Vtbl.PutPageHeight.Call( + + hr, _, err := i.Vtbl.PutPageHeight.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&pageHeight)), + uintptr(pageHeight), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetMarginTop() (float64, error) { var marginTop float64 - hr, _, _ := i.Vtbl.GetMarginTop.Call( + hr, _, err := i.Vtbl.GetMarginTop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginTop)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginTop, nil + return marginTop, err } func (i *ICoreWebView2PrintSettings) PutMarginTop(marginTop float64) error { - hr, _, _ := i.Vtbl.PutMarginTop.Call( + + hr, _, err := i.Vtbl.PutMarginTop.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&marginTop)), + uintptr(marginTop), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetMarginBottom() (float64, error) { var marginBottom float64 - hr, _, _ := i.Vtbl.GetMarginBottom.Call( + hr, _, err := i.Vtbl.GetMarginBottom.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginBottom)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginBottom, nil + return marginBottom, err } func (i *ICoreWebView2PrintSettings) PutMarginBottom(marginBottom float64) error { - hr, _, _ := i.Vtbl.PutMarginBottom.Call( + + hr, _, err := i.Vtbl.PutMarginBottom.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&marginBottom)), + uintptr(marginBottom), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetMarginLeft() (float64, error) { var marginLeft float64 - hr, _, _ := i.Vtbl.GetMarginLeft.Call( + hr, _, err := i.Vtbl.GetMarginLeft.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginLeft)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginLeft, nil + return marginLeft, err } func (i *ICoreWebView2PrintSettings) PutMarginLeft(marginLeft float64) error { - hr, _, _ := i.Vtbl.PutMarginLeft.Call( + + hr, _, err := i.Vtbl.PutMarginLeft.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&marginLeft)), + uintptr(marginLeft), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetMarginRight() (float64, error) { var marginRight float64 - hr, _, _ := i.Vtbl.GetMarginRight.Call( + hr, _, err := i.Vtbl.GetMarginRight.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginRight)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginRight, nil + return marginRight, err } func (i *ICoreWebView2PrintSettings) PutMarginRight(marginRight float64) error { - hr, _, _ := i.Vtbl.PutMarginRight.Call( + + hr, _, err := i.Vtbl.PutMarginRight.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&marginRight)), + uintptr(marginRight), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetShouldPrintBackgrounds() (bool, error) { // Create int32 to hold bool result var _shouldPrintBackgrounds int32 - hr, _, _ := i.Vtbl.GetShouldPrintBackgrounds.Call( + hr, _, err := i.Vtbl.GetShouldPrintBackgrounds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_shouldPrintBackgrounds)), ) @@ -267,27 +280,33 @@ func (i *ICoreWebView2PrintSettings) GetShouldPrintBackgrounds() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - shouldPrintBackgrounds := _shouldPrintBackgrounds != 0 - return shouldPrintBackgrounds, nil + shouldPrintBackgrounds := _shouldPrintBackgrounds != 0 + return shouldPrintBackgrounds, err } func (i *ICoreWebView2PrintSettings) PutShouldPrintBackgrounds(shouldPrintBackgrounds bool) error { - hr, _, _ := i.Vtbl.PutShouldPrintBackgrounds.Call( + // Convert Go bool to COM BOOL (int32) + var _shouldPrintBackgrounds int32 + if shouldPrintBackgrounds { + _shouldPrintBackgrounds = 1 + } + + hr, _, err := i.Vtbl.PutShouldPrintBackgrounds.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&shouldPrintBackgrounds)), + uintptr(_shouldPrintBackgrounds), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetShouldPrintSelectionOnly() (bool, error) { // Create int32 to hold bool result var _shouldPrintSelectionOnly int32 - hr, _, _ := i.Vtbl.GetShouldPrintSelectionOnly.Call( + hr, _, err := i.Vtbl.GetShouldPrintSelectionOnly.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_shouldPrintSelectionOnly)), ) @@ -295,27 +314,33 @@ func (i *ICoreWebView2PrintSettings) GetShouldPrintSelectionOnly() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - shouldPrintSelectionOnly := _shouldPrintSelectionOnly != 0 - return shouldPrintSelectionOnly, nil + shouldPrintSelectionOnly := _shouldPrintSelectionOnly != 0 + return shouldPrintSelectionOnly, err } func (i *ICoreWebView2PrintSettings) PutShouldPrintSelectionOnly(shouldPrintSelectionOnly bool) error { - hr, _, _ := i.Vtbl.PutShouldPrintSelectionOnly.Call( + // Convert Go bool to COM BOOL (int32) + var _shouldPrintSelectionOnly int32 + if shouldPrintSelectionOnly { + _shouldPrintSelectionOnly = 1 + } + + hr, _, err := i.Vtbl.PutShouldPrintSelectionOnly.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&shouldPrintSelectionOnly)), + uintptr(_shouldPrintSelectionOnly), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetShouldPrintHeaderAndFooter() (bool, error) { // Create int32 to hold bool result var _shouldPrintHeaderAndFooter int32 - hr, _, _ := i.Vtbl.GetShouldPrintHeaderAndFooter.Call( + hr, _, err := i.Vtbl.GetShouldPrintHeaderAndFooter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_shouldPrintHeaderAndFooter)), ) @@ -323,29 +348,36 @@ func (i *ICoreWebView2PrintSettings) GetShouldPrintHeaderAndFooter() (bool, erro return false, syscall.Errno(hr) } // Get result and cleanup - shouldPrintHeaderAndFooter := _shouldPrintHeaderAndFooter != 0 - return shouldPrintHeaderAndFooter, nil + shouldPrintHeaderAndFooter := _shouldPrintHeaderAndFooter != 0 + return shouldPrintHeaderAndFooter, err } func (i *ICoreWebView2PrintSettings) PutShouldPrintHeaderAndFooter(shouldPrintHeaderAndFooter bool) error { - hr, _, _ := i.Vtbl.PutShouldPrintHeaderAndFooter.Call( + // Convert Go bool to COM BOOL (int32) + var _shouldPrintHeaderAndFooter int32 + if shouldPrintHeaderAndFooter { + _shouldPrintHeaderAndFooter = 1 + } + + hr, _, err := i.Vtbl.PutShouldPrintHeaderAndFooter.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&shouldPrintHeaderAndFooter)), + uintptr(_shouldPrintHeaderAndFooter), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetHeaderTitle() (string, error) { // Create *uint16 to hold result var _headerTitle *uint16 - hr, _, _ := i.Vtbl.GetHeaderTitle.Call( + + hr, _, err := i.Vtbl.GetHeaderTitle.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_headerTitle)), + uintptr(unsafe.Pointer(&_headerTitle)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -353,7 +385,7 @@ func (i *ICoreWebView2PrintSettings) GetHeaderTitle() (string, error) { // Get result and cleanup headerTitle := UTF16PtrToString(_headerTitle) CoTaskMemFree(unsafe.Pointer(_headerTitle)) - return headerTitle, nil + return headerTitle, err } func (i *ICoreWebView2PrintSettings) PutHeaderTitle(headerTitle string) error { @@ -364,23 +396,24 @@ func (i *ICoreWebView2PrintSettings) PutHeaderTitle(headerTitle string) error { return err } - hr, _, _ := i.Vtbl.PutHeaderTitle.Call( + hr, _, err := i.Vtbl.PutHeaderTitle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_headerTitle)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings) GetFooterUri() (string, error) { // Create *uint16 to hold result var _footerUri *uint16 - hr, _, _ := i.Vtbl.GetFooterUri.Call( + + hr, _, err := i.Vtbl.GetFooterUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_footerUri)), + uintptr(unsafe.Pointer(&_footerUri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -388,7 +421,7 @@ func (i *ICoreWebView2PrintSettings) GetFooterUri() (string, error) { // Get result and cleanup footerUri := UTF16PtrToString(_footerUri) CoTaskMemFree(unsafe.Pointer(_footerUri)) - return footerUri, nil + return footerUri, err } func (i *ICoreWebView2PrintSettings) PutFooterUri(footerUri string) error { @@ -399,12 +432,12 @@ func (i *ICoreWebView2PrintSettings) PutFooterUri(footerUri string) error { return err } - hr, _, _ := i.Vtbl.PutFooterUri.Call( + hr, _, err := i.Vtbl.PutFooterUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_footerUri)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go b/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go index 616f44d6792..3aa6eb3c15a 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go @@ -1,61 +1,70 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2PrintSettings2Vtbl struct { IUnknownVtbl - GetPageRanges ComProc - PutPageRanges ComProc + GetPageRanges ComProc + PutPageRanges ComProc GetPagesPerSide ComProc PutPagesPerSide ComProc - GetCopies ComProc - PutCopies ComProc - GetCollation ComProc - PutCollation ComProc - GetColorMode ComProc - PutColorMode ComProc - GetDuplex ComProc - PutDuplex ComProc - GetMediaSize ComProc - PutMediaSize ComProc - GetPrinterName ComProc - PutPrinterName ComProc + GetCopies ComProc + PutCopies ComProc + GetCollation ComProc + PutCollation ComProc + GetColorMode ComProc + PutColorMode ComProc + GetDuplex ComProc + PutDuplex ComProc + GetMediaSize ComProc + PutMediaSize ComProc + GetPrinterName ComProc + PutPrinterName ComProc } type ICoreWebView2PrintSettings2 struct { Vtbl *ICoreWebView2PrintSettings2Vtbl } -func (i *ICoreWebView2PrintSettings2) AddRef() uintptr { +func (i *ICoreWebView2PrintSettings2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PrintSettings2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2PrintSettings2() *ICoreWebView2PrintSettings2 { + +func (i *ICoreWebView2) GetICoreWebView2PrintSettings2() (*ICoreWebView2PrintSettings2, error) { var result *ICoreWebView2PrintSettings2 iidICoreWebView2PrintSettings2 := NewGUID("{CA7F0E1F-3484-41D1-8C1A-65CD44A63F8D}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2PrintSettings2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2PrintSettings2) GetPageRanges() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetPageRanges.Call( + + hr, _, err := i.Vtbl.GetPageRanges.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -63,7 +72,7 @@ func (i *ICoreWebView2PrintSettings2) GetPageRanges() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutPageRanges(value string) error { @@ -74,179 +83,186 @@ func (i *ICoreWebView2PrintSettings2) PutPageRanges(value string) error { return err } - hr, _, _ := i.Vtbl.PutPageRanges.Call( + hr, _, err := i.Vtbl.PutPageRanges.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetPagesPerSide() (int32, error) { var value int32 - hr, _, _ := i.Vtbl.GetPagesPerSide.Call( + hr, _, err := i.Vtbl.GetPagesPerSide.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutPagesPerSide(value int32) error { - hr, _, _ := i.Vtbl.PutPagesPerSide.Call( + + hr, _, err := i.Vtbl.PutPagesPerSide.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetCopies() (int32, error) { var value int32 - hr, _, _ := i.Vtbl.GetCopies.Call( + hr, _, err := i.Vtbl.GetCopies.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutCopies(value int32) error { - hr, _, _ := i.Vtbl.PutCopies.Call( + + hr, _, err := i.Vtbl.PutCopies.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetCollation() (COREWEBVIEW2_PRINT_COLLATION, error) { var value COREWEBVIEW2_PRINT_COLLATION - hr, _, _ := i.Vtbl.GetCollation.Call( + hr, _, err := i.Vtbl.GetCollation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutCollation(value COREWEBVIEW2_PRINT_COLLATION) error { - hr, _, _ := i.Vtbl.PutCollation.Call( + + hr, _, err := i.Vtbl.PutCollation.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetColorMode() (COREWEBVIEW2_PRINT_COLOR_MODE, error) { var value COREWEBVIEW2_PRINT_COLOR_MODE - hr, _, _ := i.Vtbl.GetColorMode.Call( + hr, _, err := i.Vtbl.GetColorMode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutColorMode(value COREWEBVIEW2_PRINT_COLOR_MODE) error { - hr, _, _ := i.Vtbl.PutColorMode.Call( + + hr, _, err := i.Vtbl.PutColorMode.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetDuplex() (COREWEBVIEW2_PRINT_DUPLEX, error) { var value COREWEBVIEW2_PRINT_DUPLEX - hr, _, _ := i.Vtbl.GetDuplex.Call( + hr, _, err := i.Vtbl.GetDuplex.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutDuplex(value COREWEBVIEW2_PRINT_DUPLEX) error { - hr, _, _ := i.Vtbl.PutDuplex.Call( + + hr, _, err := i.Vtbl.PutDuplex.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetMediaSize() (COREWEBVIEW2_PRINT_MEDIA_SIZE, error) { var value COREWEBVIEW2_PRINT_MEDIA_SIZE - hr, _, _ := i.Vtbl.GetMediaSize.Call( + hr, _, err := i.Vtbl.GetMediaSize.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutMediaSize(value COREWEBVIEW2_PRINT_MEDIA_SIZE) error { - hr, _, _ := i.Vtbl.PutMediaSize.Call( + + hr, _, err := i.Vtbl.PutMediaSize.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2PrintSettings2) GetPrinterName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetPrinterName.Call( + + hr, _, err := i.Vtbl.GetPrinterName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -254,7 +270,7 @@ func (i *ICoreWebView2PrintSettings2) GetPrinterName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2PrintSettings2) PutPrinterName(value string) error { @@ -265,12 +281,12 @@ func (i *ICoreWebView2PrintSettings2) PutPrinterName(value string) error { return err } - hr, _, _ := i.Vtbl.PutPrinterName.Call( + hr, _, err := i.Vtbl.PutPrinterName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2PrintToPdfCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2PrintToPdfCompletedHandler.go index f805262fb25..44403345a8c 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintToPdfCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintToPdfCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2PrintToPdfCompletedHandler struct { impl ICoreWebView2PrintToPdfCompletedHandlerImpl } -func (i *ICoreWebView2PrintToPdfCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2PrintToPdfCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PrintToPdfCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2PrintToPdfCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2PrintToPdfCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2PrintToPdfCompletedHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2PrintToPdfCompletedHandlerIUnknownAddRef(this *ICoreWebView2PrintToPdfCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2PrintToPdfCompletedHandlerIUnknownRelease(this *ICoreWebView2PrintToPdfCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2PrintToPdfCompletedHandlerInvoke(this *ICoreWebView2PrintToPdfCompletedHandler, errorCode uintptr, result bool) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2PrintToPdfCompletedHandlerImpl interface { } var ICoreWebView2PrintToPdfCompletedHandlerFn = ICoreWebView2PrintToPdfCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2PrintToPdfCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2PrintToPdfCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2PrintToPdfCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2PrintToPdfStreamCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2PrintToPdfStreamCompletedHandler.go index e37c4a6c13b..18f0dbd0c22 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintToPdfStreamCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintToPdfStreamCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2PrintToPdfStreamCompletedHandler struct { impl ICoreWebView2PrintToPdfStreamCompletedHandlerImpl } -func (i *ICoreWebView2PrintToPdfStreamCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2PrintToPdfStreamCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2PrintToPdfStreamCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2PrintToPdfStreamCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownQueryInterface(this *I } func ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownAddRef(this *ICoreWebView2PrintToPdfStreamCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownRelease(this *ICoreWebView2PrintToPdfStreamCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2PrintToPdfStreamCompletedHandlerInvoke(this *ICoreWebView2PrintToPdfStreamCompletedHandler, errorCode uintptr, result *IStream) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2PrintToPdfStreamCompletedHandlerImpl interface { } var ICoreWebView2PrintToPdfStreamCompletedHandlerFn = ICoreWebView2PrintToPdfStreamCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2PrintToPdfStreamCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go index 55d4ba946b0..f79c5c1f2bb 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessExtendedInfoVtbl struct { IUnknownVtbl - GetProcessInfo ComProc + GetProcessInfo ComProc GetAssociatedFrameInfos ComProc } @@ -18,35 +17,41 @@ type ICoreWebView2ProcessExtendedInfo struct { Vtbl *ICoreWebView2ProcessExtendedInfoVtbl } -func (i *ICoreWebView2ProcessExtendedInfo) AddRef() uintptr { +func (i *ICoreWebView2ProcessExtendedInfo) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessExtendedInfo) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ProcessExtendedInfo) GetProcessInfo() (*ICoreWebView2ProcessInfo, error) { var processInfo *ICoreWebView2ProcessInfo - hr, _, _ := i.Vtbl.GetProcessInfo.Call( + hr, _, err := i.Vtbl.GetProcessInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&processInfo)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return processInfo, nil + return processInfo, err } func (i *ICoreWebView2ProcessExtendedInfo) GetAssociatedFrameInfos() (*ICoreWebView2FrameInfoCollection, error) { var frames *ICoreWebView2FrameInfoCollection - hr, _, _ := i.Vtbl.GetAssociatedFrameInfos.Call( + hr, _, err := i.Vtbl.GetAssociatedFrameInfos.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frames)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return frames, nil + return frames, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go index 48a4a1909c3..ec568252b3a 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessExtendedInfoCollectionVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2ProcessExtendedInfoCollection struct { Vtbl *ICoreWebView2ProcessExtendedInfoCollectionVtbl } -func (i *ICoreWebView2ProcessExtendedInfoCollection) AddRef() uintptr { +func (i *ICoreWebView2ProcessExtendedInfoCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessExtendedInfoCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ProcessExtendedInfoCollection) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ProcessExtendedInfoCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ProcessExtendedInfo, error) { var value *ICoreWebView2ProcessExtendedInfo - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go index 1f6aad60e00..fe391d37891 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessFailedEventArgsVtbl struct { @@ -17,21 +16,27 @@ type ICoreWebView2ProcessFailedEventArgs struct { Vtbl *ICoreWebView2ProcessFailedEventArgsVtbl } -func (i *ICoreWebView2ProcessFailedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ProcessFailedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessFailedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ProcessFailedEventArgs) GetProcessFailedKind() (COREWEBVIEW2_PROCESS_FAILED_KIND, error) { var value COREWEBVIEW2_PROCESS_FAILED_KIND - hr, _, _ := i.Vtbl.GetProcessFailedKind.Call( + hr, _, err := i.Vtbl.GetProcessFailedKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go index 3a85b42e21b..e0ce47cc5a3 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go @@ -1,18 +1,17 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessFailedEventArgs2Vtbl struct { IUnknownVtbl - GetReason ComProc - GetExitCode ComProc - GetProcessDescription ComProc + GetReason ComProc + GetExitCode ComProc + GetProcessDescription ComProc GetFrameInfosForFailedProcess ComProc } @@ -20,58 +19,68 @@ type ICoreWebView2ProcessFailedEventArgs2 struct { Vtbl *ICoreWebView2ProcessFailedEventArgs2Vtbl } -func (i *ICoreWebView2ProcessFailedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2ProcessFailedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessFailedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2ProcessFailedEventArgs2() *ICoreWebView2ProcessFailedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2ProcessFailedEventArgs2() (*ICoreWebView2ProcessFailedEventArgs2, error) { var result *ICoreWebView2ProcessFailedEventArgs2 iidICoreWebView2ProcessFailedEventArgs2 := NewGUID("{4dab9422-46fa-4c3e-a5d2-41d2071d3680}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2ProcessFailedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2ProcessFailedEventArgs2) GetReason() (COREWEBVIEW2_PROCESS_FAILED_REASON, error) { var reason COREWEBVIEW2_PROCESS_FAILED_REASON - hr, _, _ := i.Vtbl.GetReason.Call( + hr, _, err := i.Vtbl.GetReason.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&reason)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return reason, nil + return reason, err } func (i *ICoreWebView2ProcessFailedEventArgs2) GetExitCode() (int, error) { var exitCode int - hr, _, _ := i.Vtbl.GetExitCode.Call( + hr, _, err := i.Vtbl.GetExitCode.Call( uintptr(unsafe.Pointer(i)), - uintptr(exitCode), + uintptr(unsafe.Pointer(&exitCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return exitCode, nil + return exitCode, err } func (i *ICoreWebView2ProcessFailedEventArgs2) GetProcessDescription() (string, error) { // Create *uint16 to hold result var _processDescription *uint16 - hr, _, _ := i.Vtbl.GetProcessDescription.Call( + + hr, _, err := i.Vtbl.GetProcessDescription.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_processDescription)), + uintptr(unsafe.Pointer(&_processDescription)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -79,19 +88,19 @@ func (i *ICoreWebView2ProcessFailedEventArgs2) GetProcessDescription() (string, // Get result and cleanup processDescription := UTF16PtrToString(_processDescription) CoTaskMemFree(unsafe.Pointer(_processDescription)) - return processDescription, nil + return processDescription, err } func (i *ICoreWebView2ProcessFailedEventArgs2) GetFrameInfosForFailedProcess() (*ICoreWebView2FrameInfoCollection, error) { var frames *ICoreWebView2FrameInfoCollection - hr, _, _ := i.Vtbl.GetFrameInfosForFailedProcess.Call( + hr, _, err := i.Vtbl.GetFrameInfosForFailedProcess.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frames)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return frames, nil + return frames, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go index bd13dd3f8d7..a57795ad9df 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessFailedEventArgs3Vtbl struct { @@ -17,30 +16,40 @@ type ICoreWebView2ProcessFailedEventArgs3 struct { Vtbl *ICoreWebView2ProcessFailedEventArgs3Vtbl } -func (i *ICoreWebView2ProcessFailedEventArgs3) AddRef() uintptr { +func (i *ICoreWebView2ProcessFailedEventArgs3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessFailedEventArgs3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2ProcessFailedEventArgs3() *ICoreWebView2ProcessFailedEventArgs3 { + +func (i *ICoreWebView2) GetICoreWebView2ProcessFailedEventArgs3() (*ICoreWebView2ProcessFailedEventArgs3, error) { var result *ICoreWebView2ProcessFailedEventArgs3 iidICoreWebView2ProcessFailedEventArgs3 := NewGUID("{ab667428-094d-5fd1-b480-8b4c0fdbdf2f}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2ProcessFailedEventArgs3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2ProcessFailedEventArgs3) GetFailureSourceModulePath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetFailureSourceModulePath.Call( + + hr, _, err := i.Vtbl.GetFailureSourceModulePath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -48,5 +57,5 @@ func (i *ICoreWebView2ProcessFailedEventArgs3) GetFailureSourceModulePath() (str // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventHandler.go index b3f0d19a1fb..390e7170270 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ProcessFailedEventHandler struct { impl ICoreWebView2ProcessFailedEventHandlerImpl } -func (i *ICoreWebView2ProcessFailedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ProcessFailedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessFailedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ProcessFailedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ProcessFailedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ProcessFailedEventHandlerIUnknownQueryInterface(this *ICoreWeb } func ICoreWebView2ProcessFailedEventHandlerIUnknownAddRef(this *ICoreWebView2ProcessFailedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ProcessFailedEventHandlerIUnknownRelease(this *ICoreWebView2ProcessFailedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ProcessFailedEventHandlerInvoke(this *ICoreWebView2ProcessFailedEventHandler, sender *ICoreWebView2, args *ICoreWebView2ProcessFailedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ProcessFailedEventHandlerImpl interface { } var ICoreWebView2ProcessFailedEventHandlerFn = ICoreWebView2ProcessFailedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ProcessFailedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ProcessFailedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ProcessFailedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go b/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go index 8b528981079..8c8e3aa4b85 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go @@ -1,52 +1,57 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessInfoVtbl struct { IUnknownVtbl GetProcessId ComProc - GetKind ComProc + GetKind ComProc } type ICoreWebView2ProcessInfo struct { Vtbl *ICoreWebView2ProcessInfoVtbl } -func (i *ICoreWebView2ProcessInfo) AddRef() uintptr { +func (i *ICoreWebView2ProcessInfo) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessInfo) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ProcessInfo) GetProcessId() (int32, error) { var value int32 - hr, _, _ := i.Vtbl.GetProcessId.Call( + hr, _, err := i.Vtbl.GetProcessId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ProcessInfo) GetKind() (COREWEBVIEW2_PROCESS_KIND, error) { var kind COREWEBVIEW2_PROCESS_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&kind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return kind, nil + return kind, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go b/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go index 10707c4ee8a..f98f151f997 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProcessInfoCollectionVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2ProcessInfoCollection struct { Vtbl *ICoreWebView2ProcessInfoCollectionVtbl } -func (i *ICoreWebView2ProcessInfoCollection) AddRef() uintptr { +func (i *ICoreWebView2ProcessInfoCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessInfoCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ProcessInfoCollection) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ProcessInfoCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ProcessInfo, error) { var value *ICoreWebView2ProcessInfo - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessInfosChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ProcessInfosChangedEventHandler.go index 128a883d751..f784c158b53 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessInfosChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessInfosChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ProcessInfosChangedEventHandler struct { impl ICoreWebView2ProcessInfosChangedEventHandlerImpl } -func (i *ICoreWebView2ProcessInfosChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ProcessInfosChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProcessInfosChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ProcessInfosChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ProcessInfosChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ProcessInfosChangedEventHandlerIUnknownQueryInterface(this *IC } func ICoreWebView2ProcessInfosChangedEventHandlerIUnknownAddRef(this *ICoreWebView2ProcessInfosChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ProcessInfosChangedEventHandlerIUnknownRelease(this *ICoreWebView2ProcessInfosChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ProcessInfosChangedEventHandlerInvoke(this *ICoreWebView2ProcessInfosChangedEventHandler, sender *ICoreWebView2Environment, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ProcessInfosChangedEventHandlerImpl interface { } var ICoreWebView2ProcessInfosChangedEventHandlerFn = ICoreWebView2ProcessInfosChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ProcessInfosChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ProcessInfosChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ProcessInfosChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Profile.go b/webview2/pkg/webview2/ICoreWebView2Profile.go index 6c4568effb7..8db1cf4acef 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile.go @@ -1,40 +1,46 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ProfileVtbl struct { IUnknownVtbl - GetProfileName ComProc - GetIsInPrivateModeEnabled ComProc - GetProfilePath ComProc + GetProfileName ComProc + GetIsInPrivateModeEnabled ComProc + GetProfilePath ComProc GetDefaultDownloadFolderPath ComProc PutDefaultDownloadFolderPath ComProc - GetPreferredColorScheme ComProc - PutPreferredColorScheme ComProc + GetPreferredColorScheme ComProc + PutPreferredColorScheme ComProc } type ICoreWebView2Profile struct { Vtbl *ICoreWebView2ProfileVtbl } -func (i *ICoreWebView2Profile) AddRef() uintptr { +func (i *ICoreWebView2Profile) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2Profile) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2Profile) GetProfileName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetProfileName.Call( + + hr, _, err := i.Vtbl.GetProfileName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -42,14 +48,14 @@ func (i *ICoreWebView2Profile) GetProfileName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Profile) GetIsInPrivateModeEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsInPrivateModeEnabled.Call( + hr, _, err := i.Vtbl.GetIsInPrivateModeEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -57,17 +63,18 @@ func (i *ICoreWebView2Profile) GetIsInPrivateModeEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Profile) GetProfilePath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetProfilePath.Call( + + hr, _, err := i.Vtbl.GetProfilePath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -75,16 +82,17 @@ func (i *ICoreWebView2Profile) GetProfilePath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Profile) GetDefaultDownloadFolderPath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetDefaultDownloadFolderPath.Call( + + hr, _, err := i.Vtbl.GetDefaultDownloadFolderPath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -92,7 +100,7 @@ func (i *ICoreWebView2Profile) GetDefaultDownloadFolderPath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Profile) PutDefaultDownloadFolderPath(value string) error { @@ -103,38 +111,39 @@ func (i *ICoreWebView2Profile) PutDefaultDownloadFolderPath(value string) error return err } - hr, _, _ := i.Vtbl.PutDefaultDownloadFolderPath.Call( + hr, _, err := i.Vtbl.PutDefaultDownloadFolderPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile) GetPreferredColorScheme() (COREWEBVIEW2_PREFERRED_COLOR_SCHEME, error) { var value COREWEBVIEW2_PREFERRED_COLOR_SCHEME - hr, _, _ := i.Vtbl.GetPreferredColorScheme.Call( + hr, _, err := i.Vtbl.GetPreferredColorScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Profile) PutPreferredColorScheme(value COREWEBVIEW2_PREFERRED_COLOR_SCHEME) error { - hr, _, _ := i.Vtbl.PutPreferredColorScheme.Call( + + hr, _, err := i.Vtbl.PutPreferredColorScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile2.go b/webview2/pkg/webview2/ICoreWebView2Profile2.go index cef10ddbab3..a0127a3e741 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile2.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile2.go @@ -1,44 +1,53 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile2Vtbl struct { IUnknownVtbl - ClearBrowsingData ComProc + ClearBrowsingData ComProc ClearBrowsingDataInTimeRange ComProc - ClearBrowsingDataAll ComProc + ClearBrowsingDataAll ComProc } type ICoreWebView2Profile2 struct { Vtbl *ICoreWebView2Profile2Vtbl } -func (i *ICoreWebView2Profile2) AddRef() uintptr { +func (i *ICoreWebView2Profile2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Profile2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile2() *ICoreWebView2Profile2 { + +func (i *ICoreWebView2) GetICoreWebView2Profile2() (*ICoreWebView2Profile2, error) { var result *ICoreWebView2Profile2 iidICoreWebView2Profile2 := NewGUID("{fa740d4b-5eae-4344-a8ad-74be31925397}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile2) ClearBrowsingData(dataKinds COREWEBVIEW2_BROWSING_DATA_KINDS, handler *ICoreWebView2ClearBrowsingDataCompletedHandler) error { - hr, _, _ := i.Vtbl.ClearBrowsingData.Call( + + hr, _, err := i.Vtbl.ClearBrowsingData.Call( uintptr(unsafe.Pointer(i)), uintptr(dataKinds), uintptr(unsafe.Pointer(handler)), @@ -46,32 +55,34 @@ func (i *ICoreWebView2Profile2) ClearBrowsingData(dataKinds COREWEBVIEW2_BROWSIN if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile2) ClearBrowsingDataInTimeRange(dataKinds COREWEBVIEW2_BROWSING_DATA_KINDS, startTime float64, endTime float64, handler *ICoreWebView2ClearBrowsingDataCompletedHandler) error { - hr, _, _ := i.Vtbl.ClearBrowsingDataInTimeRange.Call( + + hr, _, err := i.Vtbl.ClearBrowsingDataInTimeRange.Call( uintptr(unsafe.Pointer(i)), uintptr(dataKinds), - uintptr(unsafe.Pointer(&startTime)), - uintptr(unsafe.Pointer(&endTime)), + uintptr(startTime), + uintptr(endTime), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile2) ClearBrowsingDataAll(handler *ICoreWebView2ClearBrowsingDataCompletedHandler) error { - hr, _, _ := i.Vtbl.ClearBrowsingDataAll.Call( + + hr, _, err := i.Vtbl.ClearBrowsingDataAll.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile3.go b/webview2/pkg/webview2/ICoreWebView2Profile3.go index da5ccc4fd2a..650c433d4ae 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile3.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile3Vtbl struct { @@ -18,45 +17,55 @@ type ICoreWebView2Profile3 struct { Vtbl *ICoreWebView2Profile3Vtbl } -func (i *ICoreWebView2Profile3) AddRef() uintptr { +func (i *ICoreWebView2Profile3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Profile3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile3() *ICoreWebView2Profile3 { + +func (i *ICoreWebView2) GetICoreWebView2Profile3() (*ICoreWebView2Profile3, error) { var result *ICoreWebView2Profile3 iidICoreWebView2Profile3 := NewGUID("{b188e659-5685-4e05-bdba-fc640e0f1992}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile3) GetPreferredTrackingPreventionLevel() (COREWEBVIEW2_TRACKING_PREVENTION_LEVEL, error) { var value COREWEBVIEW2_TRACKING_PREVENTION_LEVEL - hr, _, _ := i.Vtbl.GetPreferredTrackingPreventionLevel.Call( + hr, _, err := i.Vtbl.GetPreferredTrackingPreventionLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Profile3) PutPreferredTrackingPreventionLevel(value COREWEBVIEW2_TRACKING_PREVENTION_LEVEL) error { - hr, _, _ := i.Vtbl.PutPreferredTrackingPreventionLevel.Call( + + hr, _, err := i.Vtbl.PutPreferredTrackingPreventionLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile4.go b/webview2/pkg/webview2/ICoreWebView2Profile4.go index 92e36e3cbda..5a3ca6fd7f2 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile4.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile4.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile4Vtbl struct { IUnknownVtbl - SetPermissionState ComProc + SetPermissionState ComProc GetNonDefaultPermissionSettings ComProc } @@ -18,23 +17,32 @@ type ICoreWebView2Profile4 struct { Vtbl *ICoreWebView2Profile4Vtbl } -func (i *ICoreWebView2Profile4) AddRef() uintptr { +func (i *ICoreWebView2Profile4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Profile4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile4() *ICoreWebView2Profile4 { + +func (i *ICoreWebView2) GetICoreWebView2Profile4() (*ICoreWebView2Profile4, error) { var result *ICoreWebView2Profile4 iidICoreWebView2Profile4 := NewGUID("{8f4ae680-192e-4ec8-833a-21cfadaef628}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile4) SetPermissionState(PermissionKind COREWEBVIEW2_PERMISSION_KIND, origin string, State COREWEBVIEW2_PERMISSION_STATE, handler *ICoreWebView2SetPermissionStateCompletedHandler) error { // Convert string 'origin' to *uint16 @@ -43,7 +51,7 @@ func (i *ICoreWebView2Profile4) SetPermissionState(PermissionKind COREWEBVIEW2_P return err } - hr, _, _ := i.Vtbl.SetPermissionState.Call( + hr, _, err := i.Vtbl.SetPermissionState.Call( uintptr(unsafe.Pointer(i)), uintptr(PermissionKind), uintptr(unsafe.Pointer(_origin)), @@ -53,17 +61,18 @@ func (i *ICoreWebView2Profile4) SetPermissionState(PermissionKind COREWEBVIEW2_P if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile4) GetNonDefaultPermissionSettings(handler *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) error { - hr, _, _ := i.Vtbl.GetNonDefaultPermissionSettings.Call( + + hr, _, err := i.Vtbl.GetNonDefaultPermissionSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile5.go b/webview2/pkg/webview2/ICoreWebView2Profile5.go index ecff06da3b0..4b89a83e21b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile5.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile5.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile5Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2Profile5 struct { Vtbl *ICoreWebView2Profile5Vtbl } -func (i *ICoreWebView2Profile5) AddRef() uintptr { +func (i *ICoreWebView2Profile5) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Profile5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile5() *ICoreWebView2Profile5 { + +func (i *ICoreWebView2) GetICoreWebView2Profile5() (*ICoreWebView2Profile5, error) { var result *ICoreWebView2Profile5 iidICoreWebView2Profile5 := NewGUID("{2ee5b76e-6e80-4df2-bcd3-d4ec3340a01b}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile5)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile5) GetCookieManager() (*ICoreWebView2CookieManager, error) { var value *ICoreWebView2CookieManager - hr, _, _ := i.Vtbl.GetCookieManager.Call( + hr, _, err := i.Vtbl.GetCookieManager.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile6.go b/webview2/pkg/webview2/ICoreWebView2Profile6.go index 1223998a8f5..2798553aacb 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile6.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile6.go @@ -1,47 +1,55 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile6Vtbl struct { IUnknownVtbl GetIsPasswordAutosaveEnabled ComProc PutIsPasswordAutosaveEnabled ComProc - GetIsGeneralAutofillEnabled ComProc - PutIsGeneralAutofillEnabled ComProc + GetIsGeneralAutofillEnabled ComProc + PutIsGeneralAutofillEnabled ComProc } type ICoreWebView2Profile6 struct { Vtbl *ICoreWebView2Profile6Vtbl } -func (i *ICoreWebView2Profile6) AddRef() uintptr { +func (i *ICoreWebView2Profile6) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile6() *ICoreWebView2Profile6 { +func (i *ICoreWebView2Profile6) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2Profile6() (*ICoreWebView2Profile6, error) { var result *ICoreWebView2Profile6 iidICoreWebView2Profile6 := NewGUID("{BD82FA6A-1D65-4C33-B2B4-0393020CC61B}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile6)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile6) GetIsPasswordAutosaveEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( + hr, _, err := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -49,27 +57,33 @@ func (i *ICoreWebView2Profile6) GetIsPasswordAutosaveEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Profile6) PutIsPasswordAutosaveEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile6) GetIsGeneralAutofillEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsGeneralAutofillEnabled.Call( + hr, _, err := i.Vtbl.GetIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -77,18 +91,24 @@ func (i *ICoreWebView2Profile6) GetIsGeneralAutofillEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Profile6) PutIsGeneralAutofillEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsGeneralAutofillEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile7.go b/webview2/pkg/webview2/ICoreWebView2Profile7.go index 4bc784b09cb..f439615395b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile7.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile7.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile7Vtbl struct { IUnknownVtbl - AddBrowserExtension ComProc + AddBrowserExtension ComProc GetBrowserExtensions ComProc } @@ -18,23 +17,32 @@ type ICoreWebView2Profile7 struct { Vtbl *ICoreWebView2Profile7Vtbl } -func (i *ICoreWebView2Profile7) AddRef() uintptr { +func (i *ICoreWebView2Profile7) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Profile7) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile7() *ICoreWebView2Profile7 { + +func (i *ICoreWebView2) GetICoreWebView2Profile7() (*ICoreWebView2Profile7, error) { var result *ICoreWebView2Profile7 iidICoreWebView2Profile7 := NewGUID("{7b4c7906-a1aa-4cb4-b723-db09f813d541}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile7)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile7) AddBrowserExtension(extensionFolderPath string, handler *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler) error { // Convert string 'extensionFolderPath' to *uint16 @@ -43,7 +51,7 @@ func (i *ICoreWebView2Profile7) AddBrowserExtension(extensionFolderPath string, return err } - hr, _, _ := i.Vtbl.AddBrowserExtension.Call( + hr, _, err := i.Vtbl.AddBrowserExtension.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_extensionFolderPath)), uintptr(unsafe.Pointer(handler)), @@ -51,17 +59,18 @@ func (i *ICoreWebView2Profile7) AddBrowserExtension(extensionFolderPath string, if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile7) GetBrowserExtensions(handler *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) error { - hr, _, _ := i.Vtbl.GetBrowserExtensions.Call( + + hr, _, err := i.Vtbl.GetBrowserExtensions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile8.go b/webview2/pkg/webview2/ICoreWebView2Profile8.go index 151cce8af6e..5a78eb2b48c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile8.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile8.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Profile8Vtbl struct { IUnknownVtbl - Delete ComProc - AddDeleted ComProc + Delete ComProc + AddDeleted ComProc RemoveDeleted ComProc } @@ -19,39 +18,49 @@ type ICoreWebView2Profile8 struct { Vtbl *ICoreWebView2Profile8Vtbl } -func (i *ICoreWebView2Profile8) AddRef() uintptr { +func (i *ICoreWebView2Profile8) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Profile8) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Profile8() *ICoreWebView2Profile8 { + +func (i *ICoreWebView2) GetICoreWebView2Profile8() (*ICoreWebView2Profile8, error) { var result *ICoreWebView2Profile8 iidICoreWebView2Profile8 := NewGUID("{fbf70c2f-eb1f-4383-85a0-163e92044011}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Profile8)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Profile8) Delete() error { - hr, _, _ := i.Vtbl.Delete.Call( + + hr, _, err := i.Vtbl.Delete.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Profile8) AddDeleted(eventHandler *ICoreWebView2ProfileDeletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDeleted.Call( + hr, _, err := i.Vtbl.AddDeleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -59,17 +68,18 @@ func (i *ICoreWebView2Profile8) AddDeleted(eventHandler *ICoreWebView2ProfileDel if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2Profile8) RemoveDeleted(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDeleted.Call( + + hr, _, err := i.Vtbl.RemoveDeleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ProfileAddBrowserExtensionCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ProfileAddBrowserExtensionCompletedHandler.go index 98051fbc210..7791faac99c 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProfileAddBrowserExtensionCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ProfileAddBrowserExtensionCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ProfileAddBrowserExtensionCompletedHandler struct { impl ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerImpl } -func (i *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownQueryInterfa } func ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownAddRef(this *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownRelease(this *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerInvoke(this *ICoreWebView2ProfileAddBrowserExtensionCompletedHandler, errorCode uintptr, result *ICoreWebView2BrowserExtension) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerImpl interface { } var ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerFn = ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ProfileAddBrowserExtensionCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ProfileDeletedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ProfileDeletedEventHandler.go index 02691341f90..ab3890f3a97 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProfileDeletedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ProfileDeletedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ProfileDeletedEventHandler struct { impl ICoreWebView2ProfileDeletedEventHandlerImpl } -func (i *ICoreWebView2ProfileDeletedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ProfileDeletedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProfileDeletedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ProfileDeletedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ProfileDeletedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ProfileDeletedEventHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2ProfileDeletedEventHandlerIUnknownAddRef(this *ICoreWebView2ProfileDeletedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ProfileDeletedEventHandlerIUnknownRelease(this *ICoreWebView2ProfileDeletedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ProfileDeletedEventHandlerInvoke(this *ICoreWebView2ProfileDeletedEventHandler, sender *ICoreWebView2Profile, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ProfileDeletedEventHandlerImpl interface { } var ICoreWebView2ProfileDeletedEventHandlerFn = ICoreWebView2ProfileDeletedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ProfileDeletedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ProfileDeletedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ProfileDeletedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler.go index 717739a81d1..acebb34e90b 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler struct { impl ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerImpl } -func (i *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownQueryInterf } func ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownAddRef(this *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownRelease(this *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerInvoke(this *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler, errorCode uintptr, result *ICoreWebView2BrowserExtensionList) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerImpl interface { } var ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerFn = ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ProfileGetBrowserExtensionsCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2RasterizationScaleChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2RasterizationScaleChangedEventHandler.go index a14ba66bece..292fb08d816 100644 --- a/webview2/pkg/webview2/ICoreWebView2RasterizationScaleChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2RasterizationScaleChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2RasterizationScaleChangedEventHandler struct { impl ICoreWebView2RasterizationScaleChangedEventHandlerImpl } -func (i *ICoreWebView2RasterizationScaleChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2RasterizationScaleChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2RasterizationScaleChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2RasterizationScaleChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownQueryInterface(th } func ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownAddRef(this *ICoreWebView2RasterizationScaleChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownRelease(this *ICoreWebView2RasterizationScaleChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2RasterizationScaleChangedEventHandlerInvoke(this *ICoreWebView2RasterizationScaleChangedEventHandler, sender *ICoreWebView2Controller, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2RasterizationScaleChangedEventHandlerImpl interface { } var ICoreWebView2RasterizationScaleChangedEventHandlerFn = ICoreWebView2RasterizationScaleChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2RasterizationScaleChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go b/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go index bb25fec3fbe..6fe30bcf126 100644 --- a/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go +++ b/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2RegionRectCollectionViewVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,36 +17,42 @@ type ICoreWebView2RegionRectCollectionView struct { Vtbl *ICoreWebView2RegionRectCollectionViewVtbl } -func (i *ICoreWebView2RegionRectCollectionView) AddRef() uintptr { +func (i *ICoreWebView2RegionRectCollectionView) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2RegionRectCollectionView) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2RegionRectCollectionView) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2RegionRectCollectionView) GetValueAtIndex(index uint32) (RECT, error) { var value RECT - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), + uintptr(index), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go index 0034ebc00da..ea0cdaff0bd 100644 --- a/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go @@ -1,45 +1,51 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2SaveAsUIShowingEventArgsVtbl struct { IUnknownVtbl - GetContentMimeType ComProc - PutCancel ComProc - GetCancel ComProc + GetContentMimeType ComProc + PutCancel ComProc + GetCancel ComProc PutSuppressDefaultDialog ComProc GetSuppressDefaultDialog ComProc - GetDeferral ComProc - PutSaveAsFilePath ComProc - GetSaveAsFilePath ComProc - PutAllowReplace ComProc - GetAllowReplace ComProc - PutKind ComProc - GetKind ComProc + GetDeferral ComProc + PutSaveAsFilePath ComProc + GetSaveAsFilePath ComProc + PutAllowReplace ComProc + GetAllowReplace ComProc + PutKind ComProc + GetKind ComProc } type ICoreWebView2SaveAsUIShowingEventArgs struct { Vtbl *ICoreWebView2SaveAsUIShowingEventArgsVtbl } -func (i *ICoreWebView2SaveAsUIShowingEventArgs) AddRef() uintptr { +func (i *ICoreWebView2SaveAsUIShowingEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2SaveAsUIShowingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetContentMimeType() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetContentMimeType.Call( + + hr, _, err := i.Vtbl.GetContentMimeType.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -47,26 +53,32 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetContentMimeType() (string, er // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutCancel(value bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -74,27 +86,33 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetCancel() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSuppressDefaultDialog(value bool) error { - hr, _, _ := i.Vtbl.PutSuppressDefaultDialog.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutSuppressDefaultDialog.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSuppressDefaultDialog() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetSuppressDefaultDialog.Call( + hr, _, err := i.Vtbl.GetSuppressDefaultDialog.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -102,22 +120,22 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSuppressDefaultDialog() (bool return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSaveAsFilePath(value string) error { @@ -128,23 +146,24 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSaveAsFilePath(value string) return err } - hr, _, _ := i.Vtbl.PutSaveAsFilePath.Call( + hr, _, err := i.Vtbl.PutSaveAsFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSaveAsFilePath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSaveAsFilePath.Call( + + hr, _, err := i.Vtbl.GetSaveAsFilePath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -152,26 +171,32 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSaveAsFilePath() (string, err // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutAllowReplace(value bool) error { - hr, _, _ := i.Vtbl.PutAllowReplace.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutAllowReplace.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetAllowReplace() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetAllowReplace.Call( + hr, _, err := i.Vtbl.GetAllowReplace.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -179,32 +204,33 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetAllowReplace() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutKind(value COREWEBVIEW2_SAVE_AS_KIND) error { - hr, _, _ := i.Vtbl.PutKind.Call( + + hr, _, err := i.Vtbl.PutKind.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetKind() (COREWEBVIEW2_SAVE_AS_KIND, error) { var value COREWEBVIEW2_SAVE_AS_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventHandler.go index 9016b3b51f1..4f7655f9672 100644 --- a/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2SaveAsUIShowingEventHandler struct { impl ICoreWebView2SaveAsUIShowingEventHandlerImpl } -func (i *ICoreWebView2SaveAsUIShowingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2SaveAsUIShowingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2SaveAsUIShowingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2SaveAsUIShowingEventHandlerIUnknownQueryInterface(this *ICoreWebView2SaveAsUIShowingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2SaveAsUIShowingEventHandlerIUnknownQueryInterface(this *ICoreW } func ICoreWebView2SaveAsUIShowingEventHandlerIUnknownAddRef(this *ICoreWebView2SaveAsUIShowingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2SaveAsUIShowingEventHandlerIUnknownRelease(this *ICoreWebView2SaveAsUIShowingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2SaveAsUIShowingEventHandlerInvoke(this *ICoreWebView2SaveAsUIShowingEventHandler, sender *ICoreWebView2, args *ICoreWebView2SaveAsUIShowingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2SaveAsUIShowingEventHandlerImpl interface { } var ICoreWebView2SaveAsUIShowingEventHandlerFn = ICoreWebView2SaveAsUIShowingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2SaveAsUIShowingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2SaveAsUIShowingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2SaveAsUIShowingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go index 98990b5056d..fdf413c0533 100644 --- a/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go @@ -1,39 +1,44 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2SaveFileSecurityCheckStartingEventArgsVtbl struct { IUnknownVtbl - GetCancelSave ComProc - PutCancelSave ComProc - GetDocumentOriginUri ComProc - GetFileExtension ComProc - GetFilePath ComProc + GetCancelSave ComProc + PutCancelSave ComProc + GetDocumentOriginUri ComProc + GetFileExtension ComProc + GetFilePath ComProc GetSuppressDefaultPolicy ComProc PutSuppressDefaultPolicy ComProc - GetDeferral ComProc + GetDeferral ComProc } type ICoreWebView2SaveFileSecurityCheckStartingEventArgs struct { Vtbl *ICoreWebView2SaveFileSecurityCheckStartingEventArgsVtbl } -func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) AddRef() uintptr { +func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetCancelSave() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetCancelSave.Call( + hr, _, err := i.Vtbl.GetCancelSave.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -41,29 +46,36 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetCancelSave() (b return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) PutCancelSave(value bool) error { - hr, _, _ := i.Vtbl.PutCancelSave.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutCancelSave.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDocumentOriginUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetDocumentOriginUri.Call( + + hr, _, err := i.Vtbl.GetDocumentOriginUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -71,16 +83,17 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDocumentOriginU // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFileExtension() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetFileExtension.Call( + + hr, _, err := i.Vtbl.GetFileExtension.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -88,16 +101,17 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFileExtension() // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFilePath() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetFilePath.Call( + + hr, _, err := i.Vtbl.GetFilePath.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -105,14 +119,14 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFilePath() (str // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetSuppressDefaultPolicy() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetSuppressDefaultPolicy.Call( + hr, _, err := i.Vtbl.GetSuppressDefaultPolicy.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -120,32 +134,38 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetSuppressDefault return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) PutSuppressDefaultPolicy(value bool) error { - hr, _, _ := i.Vtbl.PutSuppressDefaultPolicy.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutSuppressDefaultPolicy.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventHandler.go index 7f63c60f67d..c4a755c612e 100644 --- a/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2SaveFileSecurityCheckStartingEventHandler struct { impl ICoreWebView2SaveFileSecurityCheckStartingEventHandlerImpl } -func (i *ICoreWebView2SaveFileSecurityCheckStartingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2SaveFileSecurityCheckStartingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2SaveFileSecurityCheckStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2SaveFileSecurityCheckStartingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownQueryInterfac } func ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownAddRef(this *ICoreWebView2SaveFileSecurityCheckStartingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownRelease(this *ICoreWebView2SaveFileSecurityCheckStartingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2SaveFileSecurityCheckStartingEventHandlerInvoke(this *ICoreWebView2SaveFileSecurityCheckStartingEventHandler, sender *ICoreWebView2, args *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2SaveFileSecurityCheckStartingEventHandlerImpl interface { } var ICoreWebView2SaveFileSecurityCheckStartingEventHandlerFn = ICoreWebView2SaveFileSecurityCheckStartingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2SaveFileSecurityCheckStartingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go index c276af459a1..15890e2797e 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go @@ -1,37 +1,42 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ScreenCaptureStartingEventArgsVtbl struct { IUnknownVtbl - GetCancel ComProc - PutCancel ComProc - GetHandled ComProc - PutHandled ComProc + GetCancel ComProc + PutCancel ComProc + GetHandled ComProc + PutHandled ComProc GetOriginalSourceFrameInfo ComProc - GetDeferral ComProc + GetDeferral ComProc } type ICoreWebView2ScreenCaptureStartingEventArgs struct { Vtbl *ICoreWebView2ScreenCaptureStartingEventArgsVtbl } -func (i *ICoreWebView2ScreenCaptureStartingEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ScreenCaptureStartingEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ScreenCaptureStartingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetCancel.Call( + hr, _, err := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -39,27 +44,33 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetCancel() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) PutCancel(value bool) error { - hr, _, _ := i.Vtbl.PutCancel.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHandled.Call( + hr, _, err := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -67,46 +78,52 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetHandled() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) PutHandled(value bool) error { - hr, _, _ := i.Vtbl.PutHandled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetOriginalSourceFrameInfo() (*ICoreWebView2FrameInfo, error) { var value *ICoreWebView2FrameInfo - hr, _, _ := i.Vtbl.GetOriginalSourceFrameInfo.Call( + hr, _, err := i.Vtbl.GetOriginalSourceFrameInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventHandler.go index f8be73cf1a9..52f426fa4fd 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ScreenCaptureStartingEventHandler struct { impl ICoreWebView2ScreenCaptureStartingEventHandlerImpl } -func (i *ICoreWebView2ScreenCaptureStartingEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ScreenCaptureStartingEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ScreenCaptureStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2ScreenCaptureStartingEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownQueryInterface(this * } func ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownAddRef(this *ICoreWebView2ScreenCaptureStartingEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownRelease(this *ICoreWebView2ScreenCaptureStartingEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ScreenCaptureStartingEventHandlerInvoke(this *ICoreWebView2ScreenCaptureStartingEventHandler, sender *ICoreWebView2, args *ICoreWebView2ScreenCaptureStartingEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ScreenCaptureStartingEventHandlerImpl interface { } var ICoreWebView2ScreenCaptureStartingEventHandlerFn = ICoreWebView2ScreenCaptureStartingEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ScreenCaptureStartingEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go index 30de940a247..540d363ddc6 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go @@ -1,41 +1,47 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ScriptDialogOpeningEventArgsVtbl struct { IUnknownVtbl - GetUri ComProc - GetKind ComProc - GetMessage ComProc - Accept ComProc + GetUri ComProc + GetKind ComProc + GetMessage ComProc + Accept ComProc GetDefaultText ComProc - GetResultText ComProc - PutResultText ComProc - GetDeferral ComProc + GetResultText ComProc + PutResultText ComProc + GetDeferral ComProc } type ICoreWebView2ScriptDialogOpeningEventArgs struct { Vtbl *ICoreWebView2ScriptDialogOpeningEventArgsVtbl } -func (i *ICoreWebView2ScriptDialogOpeningEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ScriptDialogOpeningEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ScriptDialogOpeningEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetUri() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -43,30 +49,31 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetKind() (COREWEBVIEW2_SCRIPT_DIALOG_KIND, error) { var kind COREWEBVIEW2_SCRIPT_DIALOG_KIND - hr, _, _ := i.Vtbl.GetKind.Call( + hr, _, err := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&kind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return kind, nil + return kind, err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetMessage() (string, error) { // Create *uint16 to hold result var _message *uint16 - hr, _, _ := i.Vtbl.GetMessage.Call( + + hr, _, err := i.Vtbl.GetMessage.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_message)), + uintptr(unsafe.Pointer(&_message)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -74,27 +81,29 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetMessage() (string, error) // Get result and cleanup message := UTF16PtrToString(_message) CoTaskMemFree(unsafe.Pointer(_message)) - return message, nil + return message, err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) Accept() error { - hr, _, _ := i.Vtbl.Accept.Call( + + hr, _, err := i.Vtbl.Accept.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDefaultText() (string, error) { // Create *uint16 to hold result var _defaultText *uint16 - hr, _, _ := i.Vtbl.GetDefaultText.Call( + + hr, _, err := i.Vtbl.GetDefaultText.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_defaultText)), + uintptr(unsafe.Pointer(&_defaultText)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -102,16 +111,17 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDefaultText() (string, er // Get result and cleanup defaultText := UTF16PtrToString(_defaultText) CoTaskMemFree(unsafe.Pointer(_defaultText)) - return defaultText, nil + return defaultText, err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetResultText() (string, error) { // Create *uint16 to hold result var _resultText *uint16 - hr, _, _ := i.Vtbl.GetResultText.Call( + + hr, _, err := i.Vtbl.GetResultText.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_resultText)), + uintptr(unsafe.Pointer(&_resultText)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -119,7 +129,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetResultText() (string, err // Get result and cleanup resultText := UTF16PtrToString(_resultText) CoTaskMemFree(unsafe.Pointer(_resultText)) - return resultText, nil + return resultText, err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) PutResultText(resultText string) error { @@ -130,26 +140,26 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) PutResultText(resultText str return err } - hr, _, _ := i.Vtbl.PutResultText.Call( + hr, _, err := i.Vtbl.PutResultText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_resultText)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventHandler.go index 1f10943b6c2..1014267ddc5 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ScriptDialogOpeningEventHandler struct { impl ICoreWebView2ScriptDialogOpeningEventHandlerImpl } -func (i *ICoreWebView2ScriptDialogOpeningEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ScriptDialogOpeningEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ScriptDialogOpeningEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownQueryInterface(this *ICoreWebView2ScriptDialogOpeningEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownQueryInterface(this *IC } func ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownAddRef(this *ICoreWebView2ScriptDialogOpeningEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownRelease(this *ICoreWebView2ScriptDialogOpeningEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ScriptDialogOpeningEventHandlerInvoke(this *ICoreWebView2ScriptDialogOpeningEventHandler, sender *ICoreWebView2, args *ICoreWebView2ScriptDialogOpeningEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ScriptDialogOpeningEventHandlerImpl interface { } var ICoreWebView2ScriptDialogOpeningEventHandlerFn = ICoreWebView2ScriptDialogOpeningEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ScriptDialogOpeningEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2ScriptException.go b/webview2/pkg/webview2/ICoreWebView2ScriptException.go index 087dd6a466b..1c12c9bacc1 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScriptException.go +++ b/webview2/pkg/webview2/ICoreWebView2ScriptException.go @@ -1,66 +1,72 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ScriptExceptionVtbl struct { IUnknownVtbl - GetLineNumber ComProc + GetLineNumber ComProc GetColumnNumber ComProc - GetName ComProc - GetMessage ComProc - GetToJson ComProc + GetName ComProc + GetMessage ComProc + GetToJson ComProc } type ICoreWebView2ScriptException struct { Vtbl *ICoreWebView2ScriptExceptionVtbl } -func (i *ICoreWebView2ScriptException) AddRef() uintptr { +func (i *ICoreWebView2ScriptException) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2ScriptException) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2ScriptException) GetLineNumber() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetLineNumber.Call( + hr, _, err := i.Vtbl.GetLineNumber.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ScriptException) GetColumnNumber() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetColumnNumber.Call( + hr, _, err := i.Vtbl.GetColumnNumber.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ScriptException) GetName() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetName.Call( + + hr, _, err := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -68,16 +74,17 @@ func (i *ICoreWebView2ScriptException) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ScriptException) GetMessage() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetMessage.Call( + + hr, _, err := i.Vtbl.GetMessage.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -85,16 +92,17 @@ func (i *ICoreWebView2ScriptException) GetMessage() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ScriptException) GetToJson() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetToJson.Call( + + hr, _, err := i.Vtbl.GetToJson.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -102,5 +110,5 @@ func (i *ICoreWebView2ScriptException) GetToJson() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go index 1ff59d0f890..2f62ed2c183 100644 --- a/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go @@ -1,53 +1,59 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2ServerCertificateErrorDetectedEventArgsVtbl struct { IUnknownVtbl - GetErrorStatus ComProc - GetRequestUri ComProc + GetErrorStatus ComProc + GetRequestUri ComProc GetServerCertificate ComProc - GetAction ComProc - PutAction ComProc - GetDeferral ComProc + GetAction ComProc + PutAction ComProc + GetDeferral ComProc } type ICoreWebView2ServerCertificateErrorDetectedEventArgs struct { Vtbl *ICoreWebView2ServerCertificateErrorDetectedEventArgsVtbl } -func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetErrorStatus() (COREWEBVIEW2_WEB_ERROR_STATUS, error) { var value COREWEBVIEW2_WEB_ERROR_STATUS - hr, _, _ := i.Vtbl.GetErrorStatus.Call( + hr, _, err := i.Vtbl.GetErrorStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetRequestUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetRequestUri.Call( + + hr, _, err := i.Vtbl.GetRequestUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -55,59 +61,60 @@ func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetRequestUri() ( // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetServerCertificate() (*ICoreWebView2Certificate, error) { var value *ICoreWebView2Certificate - hr, _, _ := i.Vtbl.GetServerCertificate.Call( + hr, _, err := i.Vtbl.GetServerCertificate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetAction() (COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION, error) { var value COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION - hr, _, _ := i.Vtbl.GetAction.Call( + hr, _, err := i.Vtbl.GetAction.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) PutAction(value COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION) error { - hr, _, _ := i.Vtbl.PutAction.Call( + + hr, _, err := i.Vtbl.PutAction.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventHandler.go index 20878b56195..2acd9584cdb 100644 --- a/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ServerCertificateErrorDetectedEventHandler struct { impl ICoreWebView2ServerCertificateErrorDetectedEventHandlerImpl } -func (i *ICoreWebView2ServerCertificateErrorDetectedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ServerCertificateErrorDetectedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ServerCertificateErrorDetectedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ServerCertificateErrorDetectedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownQueryInterfa } func ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownAddRef(this *ICoreWebView2ServerCertificateErrorDetectedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownRelease(this *ICoreWebView2ServerCertificateErrorDetectedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ServerCertificateErrorDetectedEventHandlerInvoke(this *ICoreWebView2ServerCertificateErrorDetectedEventHandler, sender *ICoreWebView2, args *ICoreWebView2ServerCertificateErrorDetectedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ServerCertificateErrorDetectedEventHandlerImpl interface { } var ICoreWebView2ServerCertificateErrorDetectedEventHandlerFn = ICoreWebView2ServerCertificateErrorDetectedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ServerCertificateErrorDetectedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2SetPermissionStateCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2SetPermissionStateCompletedHandler.go index 449e7527792..0aba26043fa 100644 --- a/webview2/pkg/webview2/ICoreWebView2SetPermissionStateCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2SetPermissionStateCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2SetPermissionStateCompletedHandler struct { impl ICoreWebView2SetPermissionStateCompletedHandlerImpl } -func (i *ICoreWebView2SetPermissionStateCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2SetPermissionStateCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2SetPermissionStateCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2SetPermissionStateCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2SetPermissionStateCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2SetPermissionStateCompletedHandlerIUnknownQueryInterface(this } func ICoreWebView2SetPermissionStateCompletedHandlerIUnknownAddRef(this *ICoreWebView2SetPermissionStateCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2SetPermissionStateCompletedHandlerIUnknownRelease(this *ICoreWebView2SetPermissionStateCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2SetPermissionStateCompletedHandlerInvoke(this *ICoreWebView2SetPermissionStateCompletedHandler, errorCode uintptr) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2SetPermissionStateCompletedHandlerImpl interface { } var ICoreWebView2SetPermissionStateCompletedHandlerFn = ICoreWebView2SetPermissionStateCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2SetPermissionStateCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2SetPermissionStateCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2SetPermissionStateCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2Settings.go b/webview2/pkg/webview2/ICoreWebView2Settings.go index c86a892b846..fd15d30132f 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings.go @@ -1,49 +1,54 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2SettingsVtbl struct { IUnknownVtbl - GetIsScriptEnabled ComProc - PutIsScriptEnabled ComProc - GetIsWebMessageEnabled ComProc - PutIsWebMessageEnabled ComProc + GetIsScriptEnabled ComProc + PutIsScriptEnabled ComProc + GetIsWebMessageEnabled ComProc + PutIsWebMessageEnabled ComProc GetAreDefaultScriptDialogsEnabled ComProc PutAreDefaultScriptDialogsEnabled ComProc - GetIsStatusBarEnabled ComProc - PutIsStatusBarEnabled ComProc - GetAreDevToolsEnabled ComProc - PutAreDevToolsEnabled ComProc - GetAreDefaultContextMenusEnabled ComProc - PutAreDefaultContextMenusEnabled ComProc - GetAreHostObjectsAllowed ComProc - PutAreHostObjectsAllowed ComProc - GetIsZoomControlEnabled ComProc - PutIsZoomControlEnabled ComProc - GetIsBuiltInErrorPageEnabled ComProc - PutIsBuiltInErrorPageEnabled ComProc + GetIsStatusBarEnabled ComProc + PutIsStatusBarEnabled ComProc + GetAreDevToolsEnabled ComProc + PutAreDevToolsEnabled ComProc + GetAreDefaultContextMenusEnabled ComProc + PutAreDefaultContextMenusEnabled ComProc + GetAreHostObjectsAllowed ComProc + PutAreHostObjectsAllowed ComProc + GetIsZoomControlEnabled ComProc + PutIsZoomControlEnabled ComProc + GetIsBuiltInErrorPageEnabled ComProc + PutIsBuiltInErrorPageEnabled ComProc } type ICoreWebView2Settings struct { Vtbl *ICoreWebView2SettingsVtbl } -func (i *ICoreWebView2Settings) AddRef() uintptr { +func (i *ICoreWebView2Settings) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2Settings) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2Settings) GetIsScriptEnabled() (bool, error) { // Create int32 to hold bool result var _isScriptEnabled int32 - hr, _, _ := i.Vtbl.GetIsScriptEnabled.Call( + hr, _, err := i.Vtbl.GetIsScriptEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isScriptEnabled)), ) @@ -51,27 +56,33 @@ func (i *ICoreWebView2Settings) GetIsScriptEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isScriptEnabled := _isScriptEnabled != 0 - return isScriptEnabled, nil + isScriptEnabled := _isScriptEnabled != 0 + return isScriptEnabled, err } func (i *ICoreWebView2Settings) PutIsScriptEnabled(isScriptEnabled bool) error { - hr, _, _ := i.Vtbl.PutIsScriptEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _isScriptEnabled int32 + if isScriptEnabled { + _isScriptEnabled = 1 + } + + hr, _, err := i.Vtbl.PutIsScriptEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isScriptEnabled)), + uintptr(_isScriptEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetIsWebMessageEnabled() (bool, error) { // Create int32 to hold bool result var _isWebMessageEnabled int32 - hr, _, _ := i.Vtbl.GetIsWebMessageEnabled.Call( + hr, _, err := i.Vtbl.GetIsWebMessageEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isWebMessageEnabled)), ) @@ -79,27 +90,33 @@ func (i *ICoreWebView2Settings) GetIsWebMessageEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isWebMessageEnabled := _isWebMessageEnabled != 0 - return isWebMessageEnabled, nil + isWebMessageEnabled := _isWebMessageEnabled != 0 + return isWebMessageEnabled, err } func (i *ICoreWebView2Settings) PutIsWebMessageEnabled(isWebMessageEnabled bool) error { - hr, _, _ := i.Vtbl.PutIsWebMessageEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _isWebMessageEnabled int32 + if isWebMessageEnabled { + _isWebMessageEnabled = 1 + } + + hr, _, err := i.Vtbl.PutIsWebMessageEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isWebMessageEnabled)), + uintptr(_isWebMessageEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetAreDefaultScriptDialogsEnabled() (bool, error) { // Create int32 to hold bool result var _areDefaultScriptDialogsEnabled int32 - hr, _, _ := i.Vtbl.GetAreDefaultScriptDialogsEnabled.Call( + hr, _, err := i.Vtbl.GetAreDefaultScriptDialogsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_areDefaultScriptDialogsEnabled)), ) @@ -107,27 +124,33 @@ func (i *ICoreWebView2Settings) GetAreDefaultScriptDialogsEnabled() (bool, error return false, syscall.Errno(hr) } // Get result and cleanup - areDefaultScriptDialogsEnabled := _areDefaultScriptDialogsEnabled != 0 - return areDefaultScriptDialogsEnabled, nil + areDefaultScriptDialogsEnabled := _areDefaultScriptDialogsEnabled != 0 + return areDefaultScriptDialogsEnabled, err } func (i *ICoreWebView2Settings) PutAreDefaultScriptDialogsEnabled(areDefaultScriptDialogsEnabled bool) error { - hr, _, _ := i.Vtbl.PutAreDefaultScriptDialogsEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _areDefaultScriptDialogsEnabled int32 + if areDefaultScriptDialogsEnabled { + _areDefaultScriptDialogsEnabled = 1 + } + + hr, _, err := i.Vtbl.PutAreDefaultScriptDialogsEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&areDefaultScriptDialogsEnabled)), + uintptr(_areDefaultScriptDialogsEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetIsStatusBarEnabled() (bool, error) { // Create int32 to hold bool result var _isStatusBarEnabled int32 - hr, _, _ := i.Vtbl.GetIsStatusBarEnabled.Call( + hr, _, err := i.Vtbl.GetIsStatusBarEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isStatusBarEnabled)), ) @@ -135,27 +158,33 @@ func (i *ICoreWebView2Settings) GetIsStatusBarEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isStatusBarEnabled := _isStatusBarEnabled != 0 - return isStatusBarEnabled, nil + isStatusBarEnabled := _isStatusBarEnabled != 0 + return isStatusBarEnabled, err } func (i *ICoreWebView2Settings) PutIsStatusBarEnabled(isStatusBarEnabled bool) error { - hr, _, _ := i.Vtbl.PutIsStatusBarEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _isStatusBarEnabled int32 + if isStatusBarEnabled { + _isStatusBarEnabled = 1 + } + + hr, _, err := i.Vtbl.PutIsStatusBarEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&isStatusBarEnabled)), + uintptr(_isStatusBarEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetAreDevToolsEnabled() (bool, error) { // Create int32 to hold bool result var _areDevToolsEnabled int32 - hr, _, _ := i.Vtbl.GetAreDevToolsEnabled.Call( + hr, _, err := i.Vtbl.GetAreDevToolsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_areDevToolsEnabled)), ) @@ -163,27 +192,33 @@ func (i *ICoreWebView2Settings) GetAreDevToolsEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - areDevToolsEnabled := _areDevToolsEnabled != 0 - return areDevToolsEnabled, nil + areDevToolsEnabled := _areDevToolsEnabled != 0 + return areDevToolsEnabled, err } func (i *ICoreWebView2Settings) PutAreDevToolsEnabled(areDevToolsEnabled bool) error { - hr, _, _ := i.Vtbl.PutAreDevToolsEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _areDevToolsEnabled int32 + if areDevToolsEnabled { + _areDevToolsEnabled = 1 + } + + hr, _, err := i.Vtbl.PutAreDevToolsEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&areDevToolsEnabled)), + uintptr(_areDevToolsEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetAreDefaultContextMenusEnabled() (bool, error) { // Create int32 to hold bool result var _enabled int32 - hr, _, _ := i.Vtbl.GetAreDefaultContextMenusEnabled.Call( + hr, _, err := i.Vtbl.GetAreDefaultContextMenusEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_enabled)), ) @@ -191,27 +226,33 @@ func (i *ICoreWebView2Settings) GetAreDefaultContextMenusEnabled() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - enabled := _enabled != 0 - return enabled, nil + enabled := _enabled != 0 + return enabled, err } func (i *ICoreWebView2Settings) PutAreDefaultContextMenusEnabled(enabled bool) error { - hr, _, _ := i.Vtbl.PutAreDefaultContextMenusEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _enabled int32 + if enabled { + _enabled = 1 + } + + hr, _, err := i.Vtbl.PutAreDefaultContextMenusEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&enabled)), + uintptr(_enabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetAreHostObjectsAllowed() (bool, error) { // Create int32 to hold bool result var _allowed int32 - hr, _, _ := i.Vtbl.GetAreHostObjectsAllowed.Call( + hr, _, err := i.Vtbl.GetAreHostObjectsAllowed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_allowed)), ) @@ -219,27 +260,33 @@ func (i *ICoreWebView2Settings) GetAreHostObjectsAllowed() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - allowed := _allowed != 0 - return allowed, nil + allowed := _allowed != 0 + return allowed, err } func (i *ICoreWebView2Settings) PutAreHostObjectsAllowed(allowed bool) error { - hr, _, _ := i.Vtbl.PutAreHostObjectsAllowed.Call( + // Convert Go bool to COM BOOL (int32) + var _allowed int32 + if allowed { + _allowed = 1 + } + + hr, _, err := i.Vtbl.PutAreHostObjectsAllowed.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&allowed)), + uintptr(_allowed), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetIsZoomControlEnabled() (bool, error) { // Create int32 to hold bool result var _enabled int32 - hr, _, _ := i.Vtbl.GetIsZoomControlEnabled.Call( + hr, _, err := i.Vtbl.GetIsZoomControlEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_enabled)), ) @@ -247,27 +294,33 @@ func (i *ICoreWebView2Settings) GetIsZoomControlEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - enabled := _enabled != 0 - return enabled, nil + enabled := _enabled != 0 + return enabled, err } func (i *ICoreWebView2Settings) PutIsZoomControlEnabled(enabled bool) error { - hr, _, _ := i.Vtbl.PutIsZoomControlEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _enabled int32 + if enabled { + _enabled = 1 + } + + hr, _, err := i.Vtbl.PutIsZoomControlEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&enabled)), + uintptr(_enabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings) GetIsBuiltInErrorPageEnabled() (bool, error) { // Create int32 to hold bool result var _enabled int32 - hr, _, _ := i.Vtbl.GetIsBuiltInErrorPageEnabled.Call( + hr, _, err := i.Vtbl.GetIsBuiltInErrorPageEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_enabled)), ) @@ -275,18 +328,24 @@ func (i *ICoreWebView2Settings) GetIsBuiltInErrorPageEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - enabled := _enabled != 0 - return enabled, nil + enabled := _enabled != 0 + return enabled, err } func (i *ICoreWebView2Settings) PutIsBuiltInErrorPageEnabled(enabled bool) error { - hr, _, _ := i.Vtbl.PutIsBuiltInErrorPageEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _enabled int32 + if enabled { + _enabled = 1 + } + + hr, _, err := i.Vtbl.PutIsBuiltInErrorPageEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&enabled)), + uintptr(_enabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings2.go b/webview2/pkg/webview2/ICoreWebView2Settings2.go index 41518439664..4e053de02ce 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings2.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings2Vtbl struct { @@ -18,30 +17,40 @@ type ICoreWebView2Settings2 struct { Vtbl *ICoreWebView2Settings2Vtbl } -func (i *ICoreWebView2Settings2) AddRef() uintptr { +func (i *ICoreWebView2Settings2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings2() *ICoreWebView2Settings2 { + +func (i *ICoreWebView2) GetICoreWebView2Settings2() (*ICoreWebView2Settings2, error) { var result *ICoreWebView2Settings2 iidICoreWebView2Settings2 := NewGUID("{ee9a0f68-f46c-4e32-ac23-ef8cac224d2a}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings2) GetUserAgent() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetUserAgent.Call( + + hr, _, err := i.Vtbl.GetUserAgent.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -49,7 +58,7 @@ func (i *ICoreWebView2Settings2) GetUserAgent() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2Settings2) PutUserAgent(value string) error { @@ -60,12 +69,12 @@ func (i *ICoreWebView2Settings2) PutUserAgent(value string) error { return err } - hr, _, _ := i.Vtbl.PutUserAgent.Call( + hr, _, err := i.Vtbl.PutUserAgent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings3.go b/webview2/pkg/webview2/ICoreWebView2Settings3.go index 71c74efd4d7..91625fbfdcc 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings3.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings3.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings3Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2Settings3 struct { Vtbl *ICoreWebView2Settings3Vtbl } -func (i *ICoreWebView2Settings3) AddRef() uintptr { +func (i *ICoreWebView2Settings3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings3() *ICoreWebView2Settings3 { + +func (i *ICoreWebView2) GetICoreWebView2Settings3() (*ICoreWebView2Settings3, error) { var result *ICoreWebView2Settings3 iidICoreWebView2Settings3 := NewGUID("{fdb5ab74-af33-4854-84f0-0a631deb5eba}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings3) GetAreBrowserAcceleratorKeysEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetAreBrowserAcceleratorKeysEnabled.Call( + hr, _, err := i.Vtbl.GetAreBrowserAcceleratorKeysEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2Settings3) GetAreBrowserAcceleratorKeysEnabled() (bool, er return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings3) PutAreBrowserAcceleratorKeysEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutAreBrowserAcceleratorKeysEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutAreBrowserAcceleratorKeysEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings4.go b/webview2/pkg/webview2/ICoreWebView2Settings4.go index 0d81a6ef2d8..dda35213822 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings4.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings4.go @@ -1,47 +1,55 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings4Vtbl struct { IUnknownVtbl GetIsPasswordAutosaveEnabled ComProc PutIsPasswordAutosaveEnabled ComProc - GetIsGeneralAutofillEnabled ComProc - PutIsGeneralAutofillEnabled ComProc + GetIsGeneralAutofillEnabled ComProc + PutIsGeneralAutofillEnabled ComProc } type ICoreWebView2Settings4 struct { Vtbl *ICoreWebView2Settings4Vtbl } -func (i *ICoreWebView2Settings4) AddRef() uintptr { +func (i *ICoreWebView2Settings4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings4() *ICoreWebView2Settings4 { +func (i *ICoreWebView2Settings4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2Settings4() (*ICoreWebView2Settings4, error) { var result *ICoreWebView2Settings4 iidICoreWebView2Settings4 := NewGUID("{cb56846c-4168-4d53-b04f-03b6d6796ff2}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings4) GetIsPasswordAutosaveEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( + hr, _, err := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -49,27 +57,33 @@ func (i *ICoreWebView2Settings4) GetIsPasswordAutosaveEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings4) PutIsPasswordAutosaveEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2Settings4) GetIsGeneralAutofillEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsGeneralAutofillEnabled.Call( + hr, _, err := i.Vtbl.GetIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -77,18 +91,24 @@ func (i *ICoreWebView2Settings4) GetIsGeneralAutofillEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings4) PutIsGeneralAutofillEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsGeneralAutofillEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings5.go b/webview2/pkg/webview2/ICoreWebView2Settings5.go index 88db9de9384..e3d92609a61 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings5.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings5.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings5Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2Settings5 struct { Vtbl *ICoreWebView2Settings5Vtbl } -func (i *ICoreWebView2Settings5) AddRef() uintptr { +func (i *ICoreWebView2Settings5) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings5() *ICoreWebView2Settings5 { + +func (i *ICoreWebView2) GetICoreWebView2Settings5() (*ICoreWebView2Settings5, error) { var result *ICoreWebView2Settings5 iidICoreWebView2Settings5 := NewGUID("{183e7052-1d03-43a0-ab99-98e043b66b39}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings5)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings5) GetIsPinchZoomEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsPinchZoomEnabled.Call( + hr, _, err := i.Vtbl.GetIsPinchZoomEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2Settings5) GetIsPinchZoomEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings5) PutIsPinchZoomEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsPinchZoomEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsPinchZoomEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings6.go b/webview2/pkg/webview2/ICoreWebView2Settings6.go index 8e91efcd670..51eb42a2bce 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings6.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings6.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings6Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2Settings6 struct { Vtbl *ICoreWebView2Settings6Vtbl } -func (i *ICoreWebView2Settings6) AddRef() uintptr { +func (i *ICoreWebView2Settings6) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings6) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings6() *ICoreWebView2Settings6 { + +func (i *ICoreWebView2) GetICoreWebView2Settings6() (*ICoreWebView2Settings6, error) { var result *ICoreWebView2Settings6 iidICoreWebView2Settings6 := NewGUID("{11cb3acd-9bc8-43b8-83bf-f40753714f87}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings6)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings6) GetIsSwipeNavigationEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsSwipeNavigationEnabled.Call( + hr, _, err := i.Vtbl.GetIsSwipeNavigationEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2Settings6) GetIsSwipeNavigationEnabled() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings6) PutIsSwipeNavigationEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsSwipeNavigationEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsSwipeNavigationEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings7.go b/webview2/pkg/webview2/ICoreWebView2Settings7.go index 1d1a6fec54b..7e07fdae4f7 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings7.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings7.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings7Vtbl struct { @@ -18,45 +17,55 @@ type ICoreWebView2Settings7 struct { Vtbl *ICoreWebView2Settings7Vtbl } -func (i *ICoreWebView2Settings7) AddRef() uintptr { +func (i *ICoreWebView2Settings7) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings7) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings7() *ICoreWebView2Settings7 { + +func (i *ICoreWebView2) GetICoreWebView2Settings7() (*ICoreWebView2Settings7, error) { var result *ICoreWebView2Settings7 iidICoreWebView2Settings7 := NewGUID("{488dc902-35ef-42d2-bc7d-94b65c4bc49c}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings7)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings7) GetHiddenPdfToolbarItems() (COREWEBVIEW2_PDF_TOOLBAR_ITEMS, error) { var value COREWEBVIEW2_PDF_TOOLBAR_ITEMS - hr, _, _ := i.Vtbl.GetHiddenPdfToolbarItems.Call( + hr, _, err := i.Vtbl.GetHiddenPdfToolbarItems.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2Settings7) PutHiddenPdfToolbarItems(value COREWEBVIEW2_PDF_TOOLBAR_ITEMS) error { - hr, _, _ := i.Vtbl.PutHiddenPdfToolbarItems.Call( + + hr, _, err := i.Vtbl.PutHiddenPdfToolbarItems.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings8.go b/webview2/pkg/webview2/ICoreWebView2Settings8.go index d4697a3d3cb..9e06f311873 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings8.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings8.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings8Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2Settings8 struct { Vtbl *ICoreWebView2Settings8Vtbl } -func (i *ICoreWebView2Settings8) AddRef() uintptr { +func (i *ICoreWebView2Settings8) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings8) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings8() *ICoreWebView2Settings8 { + +func (i *ICoreWebView2) GetICoreWebView2Settings8() (*ICoreWebView2Settings8, error) { var result *ICoreWebView2Settings8 iidICoreWebView2Settings8 := NewGUID("{9e6b0e8f-86ad-4e81-8147-a9b5edb68650}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings8)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings8) GetIsReputationCheckingRequired() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsReputationCheckingRequired.Call( + hr, _, err := i.Vtbl.GetIsReputationCheckingRequired.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2Settings8) GetIsReputationCheckingRequired() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings8) PutIsReputationCheckingRequired(value bool) error { - hr, _, _ := i.Vtbl.PutIsReputationCheckingRequired.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsReputationCheckingRequired.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings9.go b/webview2/pkg/webview2/ICoreWebView2Settings9.go index da9ac91cbb0..30b56e0e5be 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings9.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings9.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2Settings9Vtbl struct { @@ -18,28 +17,37 @@ type ICoreWebView2Settings9 struct { Vtbl *ICoreWebView2Settings9Vtbl } -func (i *ICoreWebView2Settings9) AddRef() uintptr { +func (i *ICoreWebView2Settings9) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2Settings9) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2Settings9() *ICoreWebView2Settings9 { + +func (i *ICoreWebView2) GetICoreWebView2Settings9() (*ICoreWebView2Settings9, error) { var result *ICoreWebView2Settings9 iidICoreWebView2Settings9 := NewGUID("{0528a73b-e92d-49f4-927a-e547dddaa37d}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2Settings9)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2Settings9) GetIsNonClientRegionSupportEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsNonClientRegionSupportEnabled.Call( + hr, _, err := i.Vtbl.GetIsNonClientRegionSupportEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,18 +55,24 @@ func (i *ICoreWebView2Settings9) GetIsNonClientRegionSupportEnabled() (bool, err return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2Settings9) PutIsNonClientRegionSupportEnabled(value bool) error { - hr, _, _ := i.Vtbl.PutIsNonClientRegionSupportEnabled.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsNonClientRegionSupportEnabled.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go b/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go index dcc4945df80..5f69a589de6 100644 --- a/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go +++ b/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go @@ -1,94 +1,100 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2SharedBufferVtbl struct { IUnknownVtbl - GetSize ComProc - GetBuffer ComProc - OpenStream ComProc + GetSize ComProc + GetBuffer ComProc + OpenStream ComProc GetFileMappingHandle ComProc - Close ComProc + Close ComProc } type ICoreWebView2SharedBuffer struct { Vtbl *ICoreWebView2SharedBufferVtbl } -func (i *ICoreWebView2SharedBuffer) AddRef() uintptr { +func (i *ICoreWebView2SharedBuffer) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2SharedBuffer) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2SharedBuffer) GetSize() (uint64, error) { var value uint64 - hr, _, _ := i.Vtbl.GetSize.Call( + hr, _, err := i.Vtbl.GetSize.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2SharedBuffer) GetBuffer() (*uint8, error) { var value *uint8 - hr, _, _ := i.Vtbl.GetBuffer.Call( + hr, _, err := i.Vtbl.GetBuffer.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2SharedBuffer) OpenStream() (*IStream, error) { var value *IStream - hr, _, _ := i.Vtbl.OpenStream.Call( + hr, _, err := i.Vtbl.OpenStream.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2SharedBuffer) GetFileMappingHandle() (HANDLE, error) { var value HANDLE - hr, _, _ := i.Vtbl.GetFileMappingHandle.Call( + hr, _, err := i.Vtbl.GetFileMappingHandle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2SharedBuffer) Close() error { - hr, _, _ := i.Vtbl.Close.Call( + + hr, _, err := i.Vtbl.Close.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2ShowSaveAsUICompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ShowSaveAsUICompletedHandler.go index 53ac4b428db..bb7d6c59579 100644 --- a/webview2/pkg/webview2/ICoreWebView2ShowSaveAsUICompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ShowSaveAsUICompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ShowSaveAsUICompletedHandler struct { impl ICoreWebView2ShowSaveAsUICompletedHandlerImpl } -func (i *ICoreWebView2ShowSaveAsUICompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2ShowSaveAsUICompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ShowSaveAsUICompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownQueryInterface(this *ICoreWebView2ShowSaveAsUICompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownQueryInterface(this *ICore } func ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownAddRef(this *ICoreWebView2ShowSaveAsUICompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownRelease(this *ICoreWebView2ShowSaveAsUICompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ShowSaveAsUICompletedHandlerInvoke(this *ICoreWebView2ShowSaveAsUICompletedHandler, errorCode uintptr, result COREWEBVIEW2_SAVE_AS_UI_RESULT) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ShowSaveAsUICompletedHandlerImpl interface { } var ICoreWebView2ShowSaveAsUICompletedHandlerFn = ICoreWebView2ShowSaveAsUICompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2ShowSaveAsUICompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go index af64cb8a95f..eb5dafdf9e3 100644 --- a/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2SourceChangedEventArgsVtbl struct { @@ -17,16 +16,22 @@ type ICoreWebView2SourceChangedEventArgs struct { Vtbl *ICoreWebView2SourceChangedEventArgsVtbl } -func (i *ICoreWebView2SourceChangedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2SourceChangedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2SourceChangedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2SourceChangedEventArgs) GetIsNewDocument() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsNewDocument.Call( + hr, _, err := i.Vtbl.GetIsNewDocument.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -34,6 +39,6 @@ func (i *ICoreWebView2SourceChangedEventArgs) GetIsNewDocument() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2SourceChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2SourceChangedEventHandler.go index b2abc2f1ab3..c9a8c590f54 100644 --- a/webview2/pkg/webview2/ICoreWebView2SourceChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2SourceChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2SourceChangedEventHandler struct { impl ICoreWebView2SourceChangedEventHandlerImpl } -func (i *ICoreWebView2SourceChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2SourceChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2SourceChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2SourceChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2SourceChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2SourceChangedEventHandlerIUnknownQueryInterface(this *ICoreWeb } func ICoreWebView2SourceChangedEventHandlerIUnknownAddRef(this *ICoreWebView2SourceChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2SourceChangedEventHandlerIUnknownRelease(this *ICoreWebView2SourceChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2SourceChangedEventHandlerInvoke(this *ICoreWebView2SourceChangedEventHandler, sender *ICoreWebView2, args *ICoreWebView2SourceChangedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2SourceChangedEventHandlerImpl interface { } var ICoreWebView2SourceChangedEventHandlerFn = ICoreWebView2SourceChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2SourceChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2SourceChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2SourceChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2StateChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2StateChangedEventHandler.go index 69a77aedeab..2101f408f4e 100644 --- a/webview2/pkg/webview2/ICoreWebView2StateChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2StateChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2StateChangedEventHandler struct { impl ICoreWebView2StateChangedEventHandlerImpl } -func (i *ICoreWebView2StateChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2StateChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2StateChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2StateChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2StateChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2StateChangedEventHandlerIUnknownQueryInterface(this *ICoreWebV } func ICoreWebView2StateChangedEventHandlerIUnknownAddRef(this *ICoreWebView2StateChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2StateChangedEventHandlerIUnknownRelease(this *ICoreWebView2StateChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2StateChangedEventHandlerInvoke(this *ICoreWebView2StateChangedEventHandler, sender *ICoreWebView2DownloadOperation, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2StateChangedEventHandlerImpl interface { } var ICoreWebView2StateChangedEventHandlerFn = ICoreWebView2StateChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2StateChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2StateChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2StateChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2StatusBarTextChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2StatusBarTextChangedEventHandler.go index 944bd04b2dc..5f475ed7c8a 100644 --- a/webview2/pkg/webview2/ICoreWebView2StatusBarTextChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2StatusBarTextChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2StatusBarTextChangedEventHandler struct { impl ICoreWebView2StatusBarTextChangedEventHandlerImpl } -func (i *ICoreWebView2StatusBarTextChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2StatusBarTextChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2StatusBarTextChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2StatusBarTextChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2StatusBarTextChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2StatusBarTextChangedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2StatusBarTextChangedEventHandlerIUnknownAddRef(this *ICoreWebView2StatusBarTextChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2StatusBarTextChangedEventHandlerIUnknownRelease(this *ICoreWebView2StatusBarTextChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2StatusBarTextChangedEventHandlerInvoke(this *ICoreWebView2StatusBarTextChangedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2StatusBarTextChangedEventHandlerImpl interface { } var ICoreWebView2StatusBarTextChangedEventHandlerFn = ICoreWebView2StatusBarTextChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2StatusBarTextChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2StatusBarTextChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2StatusBarTextChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2StringCollection.go b/webview2/pkg/webview2/ICoreWebView2StringCollection.go index fb3afe492c3..1b8d8c4d8d3 100644 --- a/webview2/pkg/webview2/ICoreWebView2StringCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2StringCollection.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2StringCollectionVtbl struct { IUnknownVtbl - GetCount ComProc + GetCount ComProc GetValueAtIndex ComProc } @@ -18,33 +17,40 @@ type ICoreWebView2StringCollection struct { Vtbl *ICoreWebView2StringCollectionVtbl } -func (i *ICoreWebView2StringCollection) AddRef() uintptr { +func (i *ICoreWebView2StringCollection) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2StringCollection) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2StringCollection) GetCount() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetCount.Call( + hr, _, err := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2StringCollection) GetValueAtIndex(index uint32) (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetValueAtIndex.Call( + + hr, _, err := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&index)), - uintptr(unsafe.Pointer(_value)), + uintptr(index), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -52,5 +58,5 @@ func (i *ICoreWebView2StringCollection) GetValueAtIndex(index uint32) (string, e // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2TrySuspendCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2TrySuspendCompletedHandler.go index b4399f9259e..e7db59bcc8d 100644 --- a/webview2/pkg/webview2/ICoreWebView2TrySuspendCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2TrySuspendCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2TrySuspendCompletedHandler struct { impl ICoreWebView2TrySuspendCompletedHandlerImpl } -func (i *ICoreWebView2TrySuspendCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2TrySuspendCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2TrySuspendCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2TrySuspendCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2TrySuspendCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2TrySuspendCompletedHandlerIUnknownQueryInterface(this *ICoreWe } func ICoreWebView2TrySuspendCompletedHandlerIUnknownAddRef(this *ICoreWebView2TrySuspendCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2TrySuspendCompletedHandlerIUnknownRelease(this *ICoreWebView2TrySuspendCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2TrySuspendCompletedHandlerInvoke(this *ICoreWebView2TrySuspendCompletedHandler, errorCode uintptr, result bool) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2TrySuspendCompletedHandlerImpl interface { } var ICoreWebView2TrySuspendCompletedHandlerFn = ICoreWebView2TrySuspendCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2TrySuspendCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2TrySuspendCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2TrySuspendCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go index 3de78bb04d7..5a00690bb01 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebMessageReceivedEventArgsVtbl struct { IUnknownVtbl - GetSource ComProc - GetWebMessageAsJson ComProc + GetSource ComProc + GetWebMessageAsJson ComProc TryGetWebMessageAsString ComProc } @@ -19,18 +18,25 @@ type ICoreWebView2WebMessageReceivedEventArgs struct { Vtbl *ICoreWebView2WebMessageReceivedEventArgsVtbl } -func (i *ICoreWebView2WebMessageReceivedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2WebMessageReceivedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2WebMessageReceivedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2WebMessageReceivedEventArgs) GetSource() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetSource.Call( + + hr, _, err := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -38,16 +44,17 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) GetSource() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2WebMessageReceivedEventArgs) GetWebMessageAsJson() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetWebMessageAsJson.Call( + + hr, _, err := i.Vtbl.GetWebMessageAsJson.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -55,16 +62,17 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) GetWebMessageAsJson() (string // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2WebMessageReceivedEventArgs) TryGetWebMessageAsString() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.TryGetWebMessageAsString.Call( + + hr, _, err := i.Vtbl.TryGetWebMessageAsString.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -72,5 +80,5 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) TryGetWebMessageAsString() (s // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go index 19ae6265fd0..781f62263df 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebMessageReceivedEventArgs2Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2WebMessageReceivedEventArgs2 struct { Vtbl *ICoreWebView2WebMessageReceivedEventArgs2Vtbl } -func (i *ICoreWebView2WebMessageReceivedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2WebMessageReceivedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebMessageReceivedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2WebMessageReceivedEventArgs2() *ICoreWebView2WebMessageReceivedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2WebMessageReceivedEventArgs2() (*ICoreWebView2WebMessageReceivedEventArgs2, error) { var result *ICoreWebView2WebMessageReceivedEventArgs2 iidICoreWebView2WebMessageReceivedEventArgs2 := NewGUID("{06fc7ab7-c90c-4297-9389-33ca01cf6d5e}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2WebMessageReceivedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2WebMessageReceivedEventArgs2) GetAdditionalObjects() (*ICoreWebView2ObjectCollectionView, error) { var value *ICoreWebView2ObjectCollectionView - hr, _, _ := i.Vtbl.GetAdditionalObjects.Call( + hr, _, err := i.Vtbl.GetAdditionalObjects.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventHandler.go index 740625f4801..3e80501dbc1 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2WebMessageReceivedEventHandler struct { impl ICoreWebView2WebMessageReceivedEventHandlerImpl } -func (i *ICoreWebView2WebMessageReceivedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2WebMessageReceivedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebMessageReceivedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2WebMessageReceivedEventHandlerIUnknownQueryInterface(this *ICoreWebView2WebMessageReceivedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2WebMessageReceivedEventHandlerIUnknownQueryInterface(this *ICo } func ICoreWebView2WebMessageReceivedEventHandlerIUnknownAddRef(this *ICoreWebView2WebMessageReceivedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2WebMessageReceivedEventHandlerIUnknownRelease(this *ICoreWebView2WebMessageReceivedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2WebMessageReceivedEventHandlerInvoke(this *ICoreWebView2WebMessageReceivedEventHandler, sender *ICoreWebView2, args *ICoreWebView2WebMessageReceivedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2WebMessageReceivedEventHandlerImpl interface { } var ICoreWebView2WebMessageReceivedEventHandlerFn = ICoreWebView2WebMessageReceivedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2WebMessageReceivedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2WebMessageReceivedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2WebMessageReceivedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go index e6f467ffc40..9b0086fadba 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go @@ -1,19 +1,18 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebResourceRequestVtbl struct { IUnknownVtbl - GetUri ComProc - PutUri ComProc - GetMethod ComProc - PutMethod ComProc + GetUri ComProc + PutUri ComProc + GetMethod ComProc + PutMethod ComProc GetContent ComProc PutContent ComProc GetHeaders ComProc @@ -23,18 +22,25 @@ type ICoreWebView2WebResourceRequest struct { Vtbl *ICoreWebView2WebResourceRequestVtbl } -func (i *ICoreWebView2WebResourceRequest) AddRef() uintptr { +func (i *ICoreWebView2WebResourceRequest) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceRequest) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2WebResourceRequest) GetUri() (string, error) { // Create *uint16 to hold result var _uri *uint16 - hr, _, _ := i.Vtbl.GetUri.Call( + + hr, _, err := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_uri)), + uintptr(unsafe.Pointer(&_uri)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -42,7 +48,7 @@ func (i *ICoreWebView2WebResourceRequest) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, nil + return uri, err } func (i *ICoreWebView2WebResourceRequest) PutUri(uri string) error { @@ -53,23 +59,24 @@ func (i *ICoreWebView2WebResourceRequest) PutUri(uri string) error { return err } - hr, _, _ := i.Vtbl.PutUri.Call( + hr, _, err := i.Vtbl.PutUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2WebResourceRequest) GetMethod() (string, error) { // Create *uint16 to hold result var _method *uint16 - hr, _, _ := i.Vtbl.GetMethod.Call( + + hr, _, err := i.Vtbl.GetMethod.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_method)), + uintptr(unsafe.Pointer(&_method)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -77,7 +84,7 @@ func (i *ICoreWebView2WebResourceRequest) GetMethod() (string, error) { // Get result and cleanup method := UTF16PtrToString(_method) CoTaskMemFree(unsafe.Pointer(_method)) - return method, nil + return method, err } func (i *ICoreWebView2WebResourceRequest) PutMethod(method string) error { @@ -88,52 +95,53 @@ func (i *ICoreWebView2WebResourceRequest) PutMethod(method string) error { return err } - hr, _, _ := i.Vtbl.PutMethod.Call( + hr, _, err := i.Vtbl.PutMethod.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_method)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2WebResourceRequest) GetContent() (*IStream, error) { var content *IStream - hr, _, _ := i.Vtbl.GetContent.Call( + hr, _, err := i.Vtbl.GetContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&content)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return content, nil + return content, err } func (i *ICoreWebView2WebResourceRequest) PutContent(content *IStream) error { - hr, _, _ := i.Vtbl.PutContent.Call( + + hr, _, err := i.Vtbl.PutContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(content)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2WebResourceRequest) GetHeaders() (*ICoreWebView2HttpRequestHeaders, error) { var headers *ICoreWebView2HttpRequestHeaders - hr, _, _ := i.Vtbl.GetHeaders.Call( + hr, _, err := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&headers)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return headers, nil + return headers, err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go index 6438175b5fc..c54270b232c 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go @@ -1,19 +1,18 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebResourceRequestedEventArgsVtbl struct { IUnknownVtbl - GetRequest ComProc - GetResponse ComProc - PutResponse ComProc - GetDeferral ComProc + GetRequest ComProc + GetResponse ComProc + PutResponse ComProc + GetDeferral ComProc GetResourceContext ComProc } @@ -21,75 +20,82 @@ type ICoreWebView2WebResourceRequestedEventArgs struct { Vtbl *ICoreWebView2WebResourceRequestedEventArgsVtbl } -func (i *ICoreWebView2WebResourceRequestedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2WebResourceRequestedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2WebResourceRequestedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2WebResourceRequestedEventArgs) GetRequest() (*ICoreWebView2WebResourceRequest, error) { var request *ICoreWebView2WebResourceRequest - hr, _, _ := i.Vtbl.GetRequest.Call( + hr, _, err := i.Vtbl.GetRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&request)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return request, nil + return request, err } func (i *ICoreWebView2WebResourceRequestedEventArgs) GetResponse() (*ICoreWebView2WebResourceResponse, error) { var response *ICoreWebView2WebResourceResponse - hr, _, _ := i.Vtbl.GetResponse.Call( + hr, _, err := i.Vtbl.GetResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&response)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return response, nil + return response, err } func (i *ICoreWebView2WebResourceRequestedEventArgs) PutResponse(response *ICoreWebView2WebResourceResponse) error { - hr, _, _ := i.Vtbl.PutResponse.Call( + + hr, _, err := i.Vtbl.PutResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(response)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2WebResourceRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, _ := i.Vtbl.GetDeferral.Call( + hr, _, err := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, nil + return deferral, err } func (i *ICoreWebView2WebResourceRequestedEventArgs) GetResourceContext() (COREWEBVIEW2_WEB_RESOURCE_CONTEXT, error) { var context COREWEBVIEW2_WEB_RESOURCE_CONTEXT - hr, _, _ := i.Vtbl.GetResourceContext.Call( + hr, _, err := i.Vtbl.GetResourceContext.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&context)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return context, nil + return context, err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go index 1a50c695303..3e37a096ee2 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebResourceRequestedEventArgs2Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2WebResourceRequestedEventArgs2 struct { Vtbl *ICoreWebView2WebResourceRequestedEventArgs2Vtbl } -func (i *ICoreWebView2WebResourceRequestedEventArgs2) AddRef() uintptr { +func (i *ICoreWebView2WebResourceRequestedEventArgs2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceRequestedEventArgs2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2WebResourceRequestedEventArgs2() *ICoreWebView2WebResourceRequestedEventArgs2 { + +func (i *ICoreWebView2) GetICoreWebView2WebResourceRequestedEventArgs2() (*ICoreWebView2WebResourceRequestedEventArgs2, error) { var result *ICoreWebView2WebResourceRequestedEventArgs2 iidICoreWebView2WebResourceRequestedEventArgs2 := NewGUID("{9c562c24-b219-4d7f-92f6-b187fbbadd56}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2WebResourceRequestedEventArgs2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2WebResourceRequestedEventArgs2) GetRequestedSourceKind() (COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS, error) { var value COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS - hr, _, _ := i.Vtbl.GetRequestedSourceKind.Call( + hr, _, err := i.Vtbl.GetRequestedSourceKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventHandler.go index 4bc48ddcd66..d922f8128c4 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2WebResourceRequestedEventHandler struct { impl ICoreWebView2WebResourceRequestedEventHandlerImpl } -func (i *ICoreWebView2WebResourceRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2WebResourceRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2WebResourceRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2WebResourceRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2WebResourceRequestedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2WebResourceRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2WebResourceRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2WebResourceRequestedEventHandlerIUnknownRelease(this *ICoreWebView2WebResourceRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2WebResourceRequestedEventHandlerInvoke(this *ICoreWebView2WebResourceRequestedEventHandler, sender *ICoreWebView2, args *ICoreWebView2WebResourceRequestedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2WebResourceRequestedEventHandlerImpl interface { } var ICoreWebView2WebResourceRequestedEventHandlerFn = ICoreWebView2WebResourceRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2WebResourceRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2WebResourceRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2WebResourceRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go index acb5639b8d6..83b6ba170c0 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go @@ -1,20 +1,19 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebResourceResponseVtbl struct { IUnknownVtbl - GetContent ComProc - PutContent ComProc - GetHeaders ComProc - GetStatusCode ComProc - PutStatusCode ComProc + GetContent ComProc + PutContent ComProc + GetHeaders ComProc + GetStatusCode ComProc + PutStatusCode ComProc GetReasonPhrase ComProc PutReasonPhrase ComProc } @@ -23,84 +22,93 @@ type ICoreWebView2WebResourceResponse struct { Vtbl *ICoreWebView2WebResourceResponseVtbl } -func (i *ICoreWebView2WebResourceResponse) AddRef() uintptr { +func (i *ICoreWebView2WebResourceResponse) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceResponse) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2WebResourceResponse) GetContent() (*IStream, error) { var content *IStream - hr, _, _ := i.Vtbl.GetContent.Call( + hr, _, err := i.Vtbl.GetContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&content)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return content, nil + return content, err } func (i *ICoreWebView2WebResourceResponse) PutContent(content *IStream) error { - hr, _, _ := i.Vtbl.PutContent.Call( + + hr, _, err := i.Vtbl.PutContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(content)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2WebResourceResponse) GetHeaders() (*ICoreWebView2HttpResponseHeaders, error) { var headers *ICoreWebView2HttpResponseHeaders - hr, _, _ := i.Vtbl.GetHeaders.Call( + hr, _, err := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&headers)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return headers, nil + return headers, err } func (i *ICoreWebView2WebResourceResponse) GetStatusCode() (int, error) { var statusCode int - hr, _, _ := i.Vtbl.GetStatusCode.Call( + hr, _, err := i.Vtbl.GetStatusCode.Call( uintptr(unsafe.Pointer(i)), - uintptr(statusCode), + uintptr(unsafe.Pointer(&statusCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return statusCode, nil + return statusCode, err } func (i *ICoreWebView2WebResourceResponse) PutStatusCode(statusCode int) error { - hr, _, _ := i.Vtbl.PutStatusCode.Call( + + hr, _, err := i.Vtbl.PutStatusCode.Call( uintptr(unsafe.Pointer(i)), uintptr(statusCode), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2WebResourceResponse) GetReasonPhrase() (string, error) { // Create *uint16 to hold result var _reasonPhrase *uint16 - hr, _, _ := i.Vtbl.GetReasonPhrase.Call( + + hr, _, err := i.Vtbl.GetReasonPhrase.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_reasonPhrase)), + uintptr(unsafe.Pointer(&_reasonPhrase)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -108,7 +116,7 @@ func (i *ICoreWebView2WebResourceResponse) GetReasonPhrase() (string, error) { // Get result and cleanup reasonPhrase := UTF16PtrToString(_reasonPhrase) CoTaskMemFree(unsafe.Pointer(_reasonPhrase)) - return reasonPhrase, nil + return reasonPhrase, err } func (i *ICoreWebView2WebResourceResponse) PutReasonPhrase(reasonPhrase string) error { @@ -119,12 +127,12 @@ func (i *ICoreWebView2WebResourceResponse) PutReasonPhrase(reasonPhrase string) return err } - hr, _, _ := i.Vtbl.PutReasonPhrase.Call( + hr, _, err := i.Vtbl.PutReasonPhrase.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_reasonPhrase)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go index a4fbcf927a5..fece79a81f2 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebResourceResponseReceivedEventArgsVtbl struct { IUnknownVtbl - GetRequest ComProc + GetRequest ComProc GetResponse ComProc } @@ -18,35 +17,41 @@ type ICoreWebView2WebResourceResponseReceivedEventArgs struct { Vtbl *ICoreWebView2WebResourceResponseReceivedEventArgsVtbl } -func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) AddRef() uintptr { +func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) GetRequest() (*ICoreWebView2WebResourceRequest, error) { var value *ICoreWebView2WebResourceRequest - hr, _, _ := i.Vtbl.GetRequest.Call( + hr, _, err := i.Vtbl.GetRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) GetResponse() (*ICoreWebView2WebResourceResponseView, error) { var value *ICoreWebView2WebResourceResponseView - hr, _, _ := i.Vtbl.GetResponse.Call( + hr, _, err := i.Vtbl.GetResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventHandler.go index ba45baa2e2c..747053c80f2 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2WebResourceResponseReceivedEventHandler struct { impl ICoreWebView2WebResourceResponseReceivedEventHandlerImpl } -func (i *ICoreWebView2WebResourceResponseReceivedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2WebResourceResponseReceivedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceResponseReceivedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownQueryInterface(this *ICoreWebView2WebResourceResponseReceivedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownQueryInterface( } func ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownAddRef(this *ICoreWebView2WebResourceResponseReceivedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownRelease(this *ICoreWebView2WebResourceResponseReceivedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2WebResourceResponseReceivedEventHandlerInvoke(this *ICoreWebView2WebResourceResponseReceivedEventHandler, sender *ICoreWebView2, args *ICoreWebView2WebResourceResponseReceivedEventArgs) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2WebResourceResponseReceivedEventHandlerImpl interface { } var ICoreWebView2WebResourceResponseReceivedEventHandlerFn = ICoreWebView2WebResourceResponseReceivedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2WebResourceResponseReceivedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go index 92eff95d84d..e35854ac25d 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go @@ -1,65 +1,71 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WebResourceResponseViewVtbl struct { IUnknownVtbl - GetHeaders ComProc - GetStatusCode ComProc + GetHeaders ComProc + GetStatusCode ComProc GetReasonPhrase ComProc - GetContent ComProc + GetContent ComProc } type ICoreWebView2WebResourceResponseView struct { Vtbl *ICoreWebView2WebResourceResponseViewVtbl } -func (i *ICoreWebView2WebResourceResponseView) AddRef() uintptr { +func (i *ICoreWebView2WebResourceResponseView) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } +func (i *ICoreWebView2WebResourceResponseView) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + func (i *ICoreWebView2WebResourceResponseView) GetHeaders() (*ICoreWebView2HttpResponseHeaders, error) { var headers *ICoreWebView2HttpResponseHeaders - hr, _, _ := i.Vtbl.GetHeaders.Call( + hr, _, err := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&headers)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return headers, nil + return headers, err } func (i *ICoreWebView2WebResourceResponseView) GetStatusCode() (int, error) { var statusCode int - hr, _, _ := i.Vtbl.GetStatusCode.Call( + hr, _, err := i.Vtbl.GetStatusCode.Call( uintptr(unsafe.Pointer(i)), - uintptr(statusCode), + uintptr(unsafe.Pointer(&statusCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return statusCode, nil + return statusCode, err } func (i *ICoreWebView2WebResourceResponseView) GetReasonPhrase() (string, error) { // Create *uint16 to hold result var _reasonPhrase *uint16 - hr, _, _ := i.Vtbl.GetReasonPhrase.Call( + + hr, _, err := i.Vtbl.GetReasonPhrase.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_reasonPhrase)), + uintptr(unsafe.Pointer(&_reasonPhrase)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -67,17 +73,18 @@ func (i *ICoreWebView2WebResourceResponseView) GetReasonPhrase() (string, error) // Get result and cleanup reasonPhrase := UTF16PtrToString(_reasonPhrase) CoTaskMemFree(unsafe.Pointer(_reasonPhrase)) - return reasonPhrase, nil + return reasonPhrase, err } func (i *ICoreWebView2WebResourceResponseView) GetContent(handler *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) error { - hr, _, _ := i.Vtbl.GetContent.Call( + + hr, _, err := i.Vtbl.GetContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseViewGetContentCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseViewGetContentCompletedHandler.go index f7b55eb0bb3..66bc26ccbc0 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseViewGetContentCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseViewGetContentCompletedHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2WebResourceResponseViewGetContentCompletedHandler struct { impl ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerImpl } -func (i *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) AddRef() uintptr { +func (i *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownQuery } func ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownAddRef(this *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownRelease(this *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerInvoke(this *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler, errorCode uintptr, result *IStream) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerImpl interfac } var ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerFn = ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownAddRef), NewComProc(ICoreWebView2WebResourceResponseViewGetContentCompletedHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2WindowCloseRequestedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2WindowCloseRequestedEventHandler.go index 007a1d434b5..359e63e326d 100644 --- a/webview2/pkg/webview2/ICoreWebView2WindowCloseRequestedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2WindowCloseRequestedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2WindowCloseRequestedEventHandler struct { impl ICoreWebView2WindowCloseRequestedEventHandlerImpl } -func (i *ICoreWebView2WindowCloseRequestedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2WindowCloseRequestedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WindowCloseRequestedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2WindowCloseRequestedEventHandlerIUnknownQueryInterface(this *ICoreWebView2WindowCloseRequestedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2WindowCloseRequestedEventHandlerIUnknownQueryInterface(this *I } func ICoreWebView2WindowCloseRequestedEventHandlerIUnknownAddRef(this *ICoreWebView2WindowCloseRequestedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2WindowCloseRequestedEventHandlerIUnknownRelease(this *ICoreWebView2WindowCloseRequestedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2WindowCloseRequestedEventHandlerInvoke(this *ICoreWebView2WindowCloseRequestedEventHandler, sender *ICoreWebView2, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2WindowCloseRequestedEventHandlerImpl interface { } var ICoreWebView2WindowCloseRequestedEventHandlerFn = ICoreWebView2WindowCloseRequestedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2WindowCloseRequestedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2WindowCloseRequestedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2WindowCloseRequestedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go b/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go index 9dac4b70141..6ed417d0e1d 100644 --- a/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go +++ b/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go @@ -1,24 +1,23 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2WindowFeaturesVtbl struct { IUnknownVtbl - GetHasPosition ComProc - GetHasSize ComProc - GetLeft ComProc - GetTop ComProc - GetHeight ComProc - GetWidth ComProc - GetShouldDisplayMenuBar ComProc - GetShouldDisplayStatus ComProc - GetShouldDisplayToolbar ComProc + GetHasPosition ComProc + GetHasSize ComProc + GetLeft ComProc + GetTop ComProc + GetHeight ComProc + GetWidth ComProc + GetShouldDisplayMenuBar ComProc + GetShouldDisplayStatus ComProc + GetShouldDisplayToolbar ComProc GetShouldDisplayScrollBars ComProc } @@ -26,16 +25,22 @@ type ICoreWebView2WindowFeatures struct { Vtbl *ICoreWebView2WindowFeaturesVtbl } -func (i *ICoreWebView2WindowFeatures) AddRef() uintptr { +func (i *ICoreWebView2WindowFeatures) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2WindowFeatures) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } + func (i *ICoreWebView2WindowFeatures) GetHasPosition() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasPosition.Call( + hr, _, err := i.Vtbl.GetHasPosition.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -43,15 +48,15 @@ func (i *ICoreWebView2WindowFeatures) GetHasPosition() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2WindowFeatures) GetHasSize() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetHasSize.Call( + hr, _, err := i.Vtbl.GetHasSize.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -59,71 +64,71 @@ func (i *ICoreWebView2WindowFeatures) GetHasSize() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2WindowFeatures) GetLeft() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetLeft.Call( + hr, _, err := i.Vtbl.GetLeft.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2WindowFeatures) GetTop() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetTop.Call( + hr, _, err := i.Vtbl.GetTop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2WindowFeatures) GetHeight() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetHeight.Call( + hr, _, err := i.Vtbl.GetHeight.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2WindowFeatures) GetWidth() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetWidth.Call( + hr, _, err := i.Vtbl.GetWidth.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayMenuBar() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetShouldDisplayMenuBar.Call( + hr, _, err := i.Vtbl.GetShouldDisplayMenuBar.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -131,15 +136,15 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayMenuBar() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayStatus() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetShouldDisplayStatus.Call( + hr, _, err := i.Vtbl.GetShouldDisplayStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -147,15 +152,15 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayStatus() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayToolbar() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetShouldDisplayToolbar.Call( + hr, _, err := i.Vtbl.GetShouldDisplayToolbar.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -163,15 +168,15 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayToolbar() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayScrollBars() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetShouldDisplayScrollBars.Call( + hr, _, err := i.Vtbl.GetShouldDisplayScrollBars.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -179,6 +184,6 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayScrollBars() (bool, error) return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2ZoomFactorChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2ZoomFactorChangedEventHandler.go index 3a6c5f15e69..37b2f94c159 100644 --- a/webview2/pkg/webview2/ICoreWebView2ZoomFactorChangedEventHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ZoomFactorChangedEventHandler.go @@ -1,7 +1,6 @@ //go:build windows package webview2 - import ( "unsafe" ) @@ -16,9 +15,14 @@ type ICoreWebView2ZoomFactorChangedEventHandler struct { impl ICoreWebView2ZoomFactorChangedEventHandlerImpl } -func (i *ICoreWebView2ZoomFactorChangedEventHandler) AddRef() uintptr { +func (i *ICoreWebView2ZoomFactorChangedEventHandler) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2ZoomFactorChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } func ICoreWebView2ZoomFactorChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2ZoomFactorChangedEventHandler, refiid, object uintptr) uintptr { @@ -26,11 +30,11 @@ func ICoreWebView2ZoomFactorChangedEventHandlerIUnknownQueryInterface(this *ICor } func ICoreWebView2ZoomFactorChangedEventHandlerIUnknownAddRef(this *ICoreWebView2ZoomFactorChangedEventHandler) uintptr { - return this.impl.AddRef() + return uintptr(this.impl.AddRef()) } func ICoreWebView2ZoomFactorChangedEventHandlerIUnknownRelease(this *ICoreWebView2ZoomFactorChangedEventHandler) uintptr { - return this.impl.Release() + return uintptr(this.impl.Release()) } func ICoreWebView2ZoomFactorChangedEventHandlerInvoke(this *ICoreWebView2ZoomFactorChangedEventHandler, sender *ICoreWebView2Controller, args *IUnknown) uintptr { @@ -43,7 +47,7 @@ type ICoreWebView2ZoomFactorChangedEventHandlerImpl interface { } var ICoreWebView2ZoomFactorChangedEventHandlerFn = ICoreWebView2ZoomFactorChangedEventHandlerVtbl{ - IUnknownVtbl{ + IUnknownVtbl { NewComProc(ICoreWebView2ZoomFactorChangedEventHandlerIUnknownQueryInterface), NewComProc(ICoreWebView2ZoomFactorChangedEventHandlerIUnknownAddRef), NewComProc(ICoreWebView2ZoomFactorChangedEventHandlerIUnknownRelease), diff --git a/webview2/pkg/webview2/ICoreWebView2_10.go b/webview2/pkg/webview2/ICoreWebView2_10.go index b30cff81a43..ccccf18c5eb 100644 --- a/webview2/pkg/webview2/ICoreWebView2_10.go +++ b/webview2/pkg/webview2/ICoreWebView2_10.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_10Vtbl struct { IUnknownVtbl - AddBasicAuthenticationRequested ComProc + AddBasicAuthenticationRequested ComProc RemoveBasicAuthenticationRequested ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2_10 struct { Vtbl *ICoreWebView2_10Vtbl } -func (i *ICoreWebView2_10) AddRef() uintptr { +func (i *ICoreWebView2_10) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_10) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_10() *ICoreWebView2_10 { + +func (i *ICoreWebView2) GetICoreWebView2_10() (*ICoreWebView2_10, error) { var result *ICoreWebView2_10 iidICoreWebView2_10 := NewGUID("{b1690564-6f5a-4983-8e48-31d1143fecdb}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_10)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_10) AddBasicAuthenticationRequested(eventHandler *ICoreWebView2BasicAuthenticationRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddBasicAuthenticationRequested.Call( + hr, _, err := i.Vtbl.AddBasicAuthenticationRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2_10) AddBasicAuthenticationRequested(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_10) RemoveBasicAuthenticationRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveBasicAuthenticationRequested.Call( + + hr, _, err := i.Vtbl.RemoveBasicAuthenticationRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_11.go b/webview2/pkg/webview2/ICoreWebView2_11.go index 1588de4e3ef..9962ca696ea 100644 --- a/webview2/pkg/webview2/ICoreWebView2_11.go +++ b/webview2/pkg/webview2/ICoreWebView2_11.go @@ -1,41 +1,49 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_11Vtbl struct { IUnknownVtbl CallDevToolsProtocolMethodForSession ComProc - AddContextMenuRequested ComProc - RemoveContextMenuRequested ComProc + AddContextMenuRequested ComProc + RemoveContextMenuRequested ComProc } type ICoreWebView2_11 struct { Vtbl *ICoreWebView2_11Vtbl } -func (i *ICoreWebView2_11) AddRef() uintptr { +func (i *ICoreWebView2_11) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_11) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_11() *ICoreWebView2_11 { + +func (i *ICoreWebView2) GetICoreWebView2_11() (*ICoreWebView2_11, error) { var result *ICoreWebView2_11 iidICoreWebView2_11 := NewGUID("{0be78e56-c193-4051-b943-23b460c08bdb}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_11)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_11) CallDevToolsProtocolMethodForSession(sessionId string, methodName string, parametersAsJson string, handler *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) error { // Convert string 'sessionId' to *uint16 @@ -54,7 +62,7 @@ func (i *ICoreWebView2_11) CallDevToolsProtocolMethodForSession(sessionId string return err } - hr, _, _ := i.Vtbl.CallDevToolsProtocolMethodForSession.Call( + hr, _, err := i.Vtbl.CallDevToolsProtocolMethodForSession.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_sessionId)), uintptr(unsafe.Pointer(_methodName)), @@ -64,14 +72,14 @@ func (i *ICoreWebView2_11) CallDevToolsProtocolMethodForSession(sessionId string if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_11) AddContextMenuRequested(eventHandler *ICoreWebView2ContextMenuRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddContextMenuRequested.Call( + hr, _, err := i.Vtbl.AddContextMenuRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -79,17 +87,18 @@ func (i *ICoreWebView2_11) AddContextMenuRequested(eventHandler *ICoreWebView2Co if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_11) RemoveContextMenuRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveContextMenuRequested.Call( + + hr, _, err := i.Vtbl.RemoveContextMenuRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_12.go b/webview2/pkg/webview2/ICoreWebView2_12.go index 93dd2def88d..e0482283343 100644 --- a/webview2/pkg/webview2/ICoreWebView2_12.go +++ b/webview2/pkg/webview2/ICoreWebView2_12.go @@ -1,46 +1,54 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_12Vtbl struct { IUnknownVtbl - AddStatusBarTextChanged ComProc + AddStatusBarTextChanged ComProc RemoveStatusBarTextChanged ComProc - GetStatusBarText ComProc + GetStatusBarText ComProc } type ICoreWebView2_12 struct { Vtbl *ICoreWebView2_12Vtbl } -func (i *ICoreWebView2_12) AddRef() uintptr { +func (i *ICoreWebView2_12) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_12) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_12() *ICoreWebView2_12 { + +func (i *ICoreWebView2) GetICoreWebView2_12() (*ICoreWebView2_12, error) { var result *ICoreWebView2_12 iidICoreWebView2_12 := NewGUID("{35D69927-BCFA-4566-9349-6B3E0D154CAC}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_12)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_12) AddStatusBarTextChanged(eventHandler *ICoreWebView2StatusBarTextChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddStatusBarTextChanged.Call( + hr, _, err := i.Vtbl.AddStatusBarTextChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -48,28 +56,30 @@ func (i *ICoreWebView2_12) AddStatusBarTextChanged(eventHandler *ICoreWebView2St if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_12) RemoveStatusBarTextChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveStatusBarTextChanged.Call( + + hr, _, err := i.Vtbl.RemoveStatusBarTextChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_12) GetStatusBarText() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetStatusBarText.Call( + + hr, _, err := i.Vtbl.GetStatusBarText.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -77,5 +87,5 @@ func (i *ICoreWebView2_12) GetStatusBarText() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2_13.go b/webview2/pkg/webview2/ICoreWebView2_13.go index a7c973b7c99..ccf2fcdd033 100644 --- a/webview2/pkg/webview2/ICoreWebView2_13.go +++ b/webview2/pkg/webview2/ICoreWebView2_13.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_13Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2_13 struct { Vtbl *ICoreWebView2_13Vtbl } -func (i *ICoreWebView2_13) AddRef() uintptr { +func (i *ICoreWebView2_13) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_13) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_13() *ICoreWebView2_13 { + +func (i *ICoreWebView2) GetICoreWebView2_13() (*ICoreWebView2_13, error) { var result *ICoreWebView2_13 iidICoreWebView2_13 := NewGUID("{f75f09a8-667e-4983-88d6-c8773f315e84}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_13)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_13) GetProfile() (*ICoreWebView2Profile, error) { var value *ICoreWebView2Profile - hr, _, _ := i.Vtbl.GetProfile.Call( + hr, _, err := i.Vtbl.GetProfile.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2_14.go b/webview2/pkg/webview2/ICoreWebView2_14.go index 3b828503b5b..6954552b19f 100644 --- a/webview2/pkg/webview2/ICoreWebView2_14.go +++ b/webview2/pkg/webview2/ICoreWebView2_14.go @@ -1,46 +1,54 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_14Vtbl struct { IUnknownVtbl - AddServerCertificateErrorDetected ComProc + AddServerCertificateErrorDetected ComProc RemoveServerCertificateErrorDetected ComProc - ClearServerCertificateErrorActions ComProc + ClearServerCertificateErrorActions ComProc } type ICoreWebView2_14 struct { Vtbl *ICoreWebView2_14Vtbl } -func (i *ICoreWebView2_14) AddRef() uintptr { +func (i *ICoreWebView2_14) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_14) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_14() *ICoreWebView2_14 { + +func (i *ICoreWebView2) GetICoreWebView2_14() (*ICoreWebView2_14, error) { var result *ICoreWebView2_14 iidICoreWebView2_14 := NewGUID("{6daa4f10-4a90-4753-8898-77c5df534165}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_14)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_14) AddServerCertificateErrorDetected(eventHandler *ICoreWebView2ServerCertificateErrorDetectedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddServerCertificateErrorDetected.Call( + hr, _, err := i.Vtbl.AddServerCertificateErrorDetected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -48,29 +56,31 @@ func (i *ICoreWebView2_14) AddServerCertificateErrorDetected(eventHandler *ICore if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_14) RemoveServerCertificateErrorDetected(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveServerCertificateErrorDetected.Call( + + hr, _, err := i.Vtbl.RemoveServerCertificateErrorDetected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_14) ClearServerCertificateErrorActions(handler *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) error { - hr, _, _ := i.Vtbl.ClearServerCertificateErrorActions.Call( + + hr, _, err := i.Vtbl.ClearServerCertificateErrorActions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_15.go b/webview2/pkg/webview2/ICoreWebView2_15.go index e85a801acdd..302de4c6e76 100644 --- a/webview2/pkg/webview2/ICoreWebView2_15.go +++ b/webview2/pkg/webview2/ICoreWebView2_15.go @@ -1,47 +1,55 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_15Vtbl struct { IUnknownVtbl - AddFaviconChanged ComProc + AddFaviconChanged ComProc RemoveFaviconChanged ComProc - GetFaviconUri ComProc - GetFavicon ComProc + GetFaviconUri ComProc + GetFavicon ComProc } type ICoreWebView2_15 struct { Vtbl *ICoreWebView2_15Vtbl } -func (i *ICoreWebView2_15) AddRef() uintptr { +func (i *ICoreWebView2_15) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_15) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_15() *ICoreWebView2_15 { + +func (i *ICoreWebView2) GetICoreWebView2_15() (*ICoreWebView2_15, error) { var result *ICoreWebView2_15 iidICoreWebView2_15 := NewGUID("{517B2D1D-7DAE-4A66-A4F4-10352FFB9518}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_15)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_15) AddFaviconChanged(eventHandler *ICoreWebView2FaviconChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddFaviconChanged.Call( + hr, _, err := i.Vtbl.AddFaviconChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -49,28 +57,30 @@ func (i *ICoreWebView2_15) AddFaviconChanged(eventHandler *ICoreWebView2FaviconC if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_15) RemoveFaviconChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveFaviconChanged.Call( + + hr, _, err := i.Vtbl.RemoveFaviconChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_15) GetFaviconUri() (string, error) { // Create *uint16 to hold result var _value *uint16 - hr, _, _ := i.Vtbl.GetFaviconUri.Call( + + hr, _, err := i.Vtbl.GetFaviconUri.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(_value)), + uintptr(unsafe.Pointer(&_value)), ) if windows.Handle(hr) != windows.S_OK { return "", syscall.Errno(hr) @@ -78,12 +88,13 @@ func (i *ICoreWebView2_15) GetFaviconUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, nil + return value, err } func (i *ICoreWebView2_15) GetFavicon(format COREWEBVIEW2_FAVICON_IMAGE_FORMAT, completedHandler *ICoreWebView2GetFaviconCompletedHandler) error { - hr, _, _ := i.Vtbl.GetFavicon.Call( + + hr, _, err := i.Vtbl.GetFavicon.Call( uintptr(unsafe.Pointer(i)), uintptr(format), uintptr(unsafe.Pointer(completedHandler)), @@ -91,5 +102,5 @@ func (i *ICoreWebView2_15) GetFavicon(format COREWEBVIEW2_FAVICON_IMAGE_FORMAT, if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_16.go b/webview2/pkg/webview2/ICoreWebView2_16.go index 855dedbd95d..81db6722083 100644 --- a/webview2/pkg/webview2/ICoreWebView2_16.go +++ b/webview2/pkg/webview2/ICoreWebView2_16.go @@ -1,17 +1,16 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_16Vtbl struct { IUnknownVtbl - Print ComProc - ShowPrintUI ComProc + Print ComProc + ShowPrintUI ComProc PrintToPdfStream ComProc } @@ -19,26 +18,36 @@ type ICoreWebView2_16 struct { Vtbl *ICoreWebView2_16Vtbl } -func (i *ICoreWebView2_16) AddRef() uintptr { +func (i *ICoreWebView2_16) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_16) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_16() *ICoreWebView2_16 { + +func (i *ICoreWebView2) GetICoreWebView2_16() (*ICoreWebView2_16, error) { var result *ICoreWebView2_16 iidICoreWebView2_16 := NewGUID("{0EB34DC9-9F91-41E1-8639-95CD5943906B}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_16)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_16) Print(printSettings *ICoreWebView2PrintSettings, handler *ICoreWebView2PrintCompletedHandler) error { - hr, _, _ := i.Vtbl.Print.Call( + + hr, _, err := i.Vtbl.Print.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(printSettings)), uintptr(unsafe.Pointer(handler)), @@ -46,24 +55,26 @@ func (i *ICoreWebView2_16) Print(printSettings *ICoreWebView2PrintSettings, hand if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_16) ShowPrintUI(printDialogKind COREWEBVIEW2_PRINT_DIALOG_KIND) error { - hr, _, _ := i.Vtbl.ShowPrintUI.Call( + + hr, _, err := i.Vtbl.ShowPrintUI.Call( uintptr(unsafe.Pointer(i)), uintptr(printDialogKind), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_16) PrintToPdfStream(printSettings *ICoreWebView2PrintSettings, handler *ICoreWebView2PrintToPdfStreamCompletedHandler) error { - hr, _, _ := i.Vtbl.PrintToPdfStream.Call( + + hr, _, err := i.Vtbl.PrintToPdfStream.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(printSettings)), uintptr(unsafe.Pointer(handler)), @@ -71,5 +82,5 @@ func (i *ICoreWebView2_16) PrintToPdfStream(printSettings *ICoreWebView2PrintSet if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_17.go b/webview2/pkg/webview2/ICoreWebView2_17.go index 71c584164fc..04a04d159e2 100644 --- a/webview2/pkg/webview2/ICoreWebView2_17.go +++ b/webview2/pkg/webview2/ICoreWebView2_17.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_17Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2_17 struct { Vtbl *ICoreWebView2_17Vtbl } -func (i *ICoreWebView2_17) AddRef() uintptr { +func (i *ICoreWebView2_17) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_17) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_17() *ICoreWebView2_17 { + +func (i *ICoreWebView2) GetICoreWebView2_17() (*ICoreWebView2_17, error) { var result *ICoreWebView2_17 iidICoreWebView2_17 := NewGUID("{702e75d4-fd44-434d-9d70-1a68a6b1192a}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_17)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_17) PostSharedBufferToScript(sharedBuffer *ICoreWebView2SharedBuffer, access COREWEBVIEW2_SHARED_BUFFER_ACCESS, additionalDataAsJson string) error { // Convert string 'additionalDataAsJson' to *uint16 @@ -42,7 +50,7 @@ func (i *ICoreWebView2_17) PostSharedBufferToScript(sharedBuffer *ICoreWebView2S return err } - hr, _, _ := i.Vtbl.PostSharedBufferToScript.Call( + hr, _, err := i.Vtbl.PostSharedBufferToScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(sharedBuffer)), uintptr(access), @@ -51,5 +59,5 @@ func (i *ICoreWebView2_17) PostSharedBufferToScript(sharedBuffer *ICoreWebView2S if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_18.go b/webview2/pkg/webview2/ICoreWebView2_18.go index 7e61d0405ae..b9821f7f59a 100644 --- a/webview2/pkg/webview2/ICoreWebView2_18.go +++ b/webview2/pkg/webview2/ICoreWebView2_18.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_18Vtbl struct { IUnknownVtbl - AddLaunchingExternalUriScheme ComProc + AddLaunchingExternalUriScheme ComProc RemoveLaunchingExternalUriScheme ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2_18 struct { Vtbl *ICoreWebView2_18Vtbl } -func (i *ICoreWebView2_18) AddRef() uintptr { +func (i *ICoreWebView2_18) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_18) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_18() *ICoreWebView2_18 { + +func (i *ICoreWebView2) GetICoreWebView2_18() (*ICoreWebView2_18, error) { var result *ICoreWebView2_18 iidICoreWebView2_18 := NewGUID("{7a626017-28be-49b2-b865-3ba2b3522d90}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_18)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_18) AddLaunchingExternalUriScheme(eventHandler *ICoreWebView2LaunchingExternalUriSchemeEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddLaunchingExternalUriScheme.Call( + hr, _, err := i.Vtbl.AddLaunchingExternalUriScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2_18) AddLaunchingExternalUriScheme(eventHandler *ICoreWebV if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_18) RemoveLaunchingExternalUriScheme(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveLaunchingExternalUriScheme.Call( + + hr, _, err := i.Vtbl.RemoveLaunchingExternalUriScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_19.go b/webview2/pkg/webview2/ICoreWebView2_19.go index 9b95eb05157..d7b441b88d2 100644 --- a/webview2/pkg/webview2/ICoreWebView2_19.go +++ b/webview2/pkg/webview2/ICoreWebView2_19.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_19Vtbl struct { @@ -18,45 +17,55 @@ type ICoreWebView2_19 struct { Vtbl *ICoreWebView2_19Vtbl } -func (i *ICoreWebView2_19) AddRef() uintptr { +func (i *ICoreWebView2_19) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_19) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_19() *ICoreWebView2_19 { + +func (i *ICoreWebView2) GetICoreWebView2_19() (*ICoreWebView2_19, error) { var result *ICoreWebView2_19 iidICoreWebView2_19 := NewGUID("{6921f954-79b0-437f-a997-c85811897c68}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_19)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_19) GetMemoryUsageTargetLevel() (COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL, error) { var value COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL - hr, _, _ := i.Vtbl.GetMemoryUsageTargetLevel.Call( + hr, _, err := i.Vtbl.GetMemoryUsageTargetLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2_19) PutMemoryUsageTargetLevel(value COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL) error { - hr, _, _ := i.Vtbl.PutMemoryUsageTargetLevel.Call( + + hr, _, err := i.Vtbl.PutMemoryUsageTargetLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_2.go b/webview2/pkg/webview2/ICoreWebView2_2.go index 45a2b79d273..65a2d3adf8b 100644 --- a/webview2/pkg/webview2/ICoreWebView2_2.go +++ b/webview2/pkg/webview2/ICoreWebView2_2.go @@ -1,50 +1,58 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_2Vtbl struct { IUnknownVtbl - AddWebResourceResponseReceived ComProc + AddWebResourceResponseReceived ComProc RemoveWebResourceResponseReceived ComProc - NavigateWithWebResourceRequest ComProc - AddDOMContentLoaded ComProc - RemoveDOMContentLoaded ComProc - GetCookieManager ComProc - GetEnvironment ComProc + NavigateWithWebResourceRequest ComProc + AddDOMContentLoaded ComProc + RemoveDOMContentLoaded ComProc + GetCookieManager ComProc + GetEnvironment ComProc } type ICoreWebView2_2 struct { Vtbl *ICoreWebView2_2Vtbl } -func (i *ICoreWebView2_2) AddRef() uintptr { +func (i *ICoreWebView2_2) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_2) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_2() *ICoreWebView2_2 { + +func (i *ICoreWebView2) GetICoreWebView2_2() (*ICoreWebView2_2, error) { var result *ICoreWebView2_2 iidICoreWebView2_2 := NewGUID("{9E8F0CF8-E670-4B5E-B2BC-73E061E3184C}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_2)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_2) AddWebResourceResponseReceived(eventHandler *ICoreWebView2WebResourceResponseReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddWebResourceResponseReceived.Call( + hr, _, err := i.Vtbl.AddWebResourceResponseReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -52,38 +60,40 @@ func (i *ICoreWebView2_2) AddWebResourceResponseReceived(eventHandler *ICoreWebV if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_2) RemoveWebResourceResponseReceived(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveWebResourceResponseReceived.Call( + + hr, _, err := i.Vtbl.RemoveWebResourceResponseReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_2) NavigateWithWebResourceRequest(request *ICoreWebView2WebResourceRequest) error { - hr, _, _ := i.Vtbl.NavigateWithWebResourceRequest.Call( + + hr, _, err := i.Vtbl.NavigateWithWebResourceRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(request)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_2) AddDOMContentLoaded(eventHandler *ICoreWebView2DOMContentLoadedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDOMContentLoaded.Call( + hr, _, err := i.Vtbl.AddDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -91,45 +101,46 @@ func (i *ICoreWebView2_2) AddDOMContentLoaded(eventHandler *ICoreWebView2DOMCont if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_2) RemoveDOMContentLoaded(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDOMContentLoaded.Call( + + hr, _, err := i.Vtbl.RemoveDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_2) GetCookieManager() (*ICoreWebView2CookieManager, error) { var cookieManager *ICoreWebView2CookieManager - hr, _, _ := i.Vtbl.GetCookieManager.Call( + hr, _, err := i.Vtbl.GetCookieManager.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&cookieManager)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return cookieManager, nil + return cookieManager, err } func (i *ICoreWebView2_2) GetEnvironment() (*ICoreWebView2Environment, error) { var environment *ICoreWebView2Environment - hr, _, _ := i.Vtbl.GetEnvironment.Call( + hr, _, err := i.Vtbl.GetEnvironment.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&environment)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return environment, nil + return environment, err } diff --git a/webview2/pkg/webview2/ICoreWebView2_20.go b/webview2/pkg/webview2/ICoreWebView2_20.go index fbf69ff046b..1e4681bf6a6 100644 --- a/webview2/pkg/webview2/ICoreWebView2_20.go +++ b/webview2/pkg/webview2/ICoreWebView2_20.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_20Vtbl struct { @@ -17,33 +16,42 @@ type ICoreWebView2_20 struct { Vtbl *ICoreWebView2_20Vtbl } -func (i *ICoreWebView2_20) AddRef() uintptr { +func (i *ICoreWebView2_20) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_20) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_20() *ICoreWebView2_20 { + +func (i *ICoreWebView2) GetICoreWebView2_20() (*ICoreWebView2_20, error) { var result *ICoreWebView2_20 iidICoreWebView2_20 := NewGUID("{b4bc1926-7305-11ee-b962-0242ac120002}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_20)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_20) GetFrameId() (uint32, error) { var value uint32 - hr, _, _ := i.Vtbl.GetFrameId.Call( + hr, _, err := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2_21.go b/webview2/pkg/webview2/ICoreWebView2_21.go index 54a52d30fd0..2e0de2ac793 100644 --- a/webview2/pkg/webview2/ICoreWebView2_21.go +++ b/webview2/pkg/webview2/ICoreWebView2_21.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_21Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2_21 struct { Vtbl *ICoreWebView2_21Vtbl } -func (i *ICoreWebView2_21) AddRef() uintptr { +func (i *ICoreWebView2_21) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_21) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_21() *ICoreWebView2_21 { + +func (i *ICoreWebView2) GetICoreWebView2_21() (*ICoreWebView2_21, error) { var result *ICoreWebView2_21 iidICoreWebView2_21 := NewGUID("{c4980dea-587b-43b9-8143-3ef3bf552d95}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_21)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_21) ExecuteScriptWithResult(javaScript string, handler *ICoreWebView2ExecuteScriptWithResultCompletedHandler) error { // Convert string 'javaScript' to *uint16 @@ -42,7 +50,7 @@ func (i *ICoreWebView2_21) ExecuteScriptWithResult(javaScript string, handler *I return err } - hr, _, _ := i.Vtbl.ExecuteScriptWithResult.Call( + hr, _, err := i.Vtbl.ExecuteScriptWithResult.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -50,5 +58,5 @@ func (i *ICoreWebView2_21) ExecuteScriptWithResult(javaScript string, handler *I if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_22.go b/webview2/pkg/webview2/ICoreWebView2_22.go index 9107307b615..4248b1224cf 100644 --- a/webview2/pkg/webview2/ICoreWebView2_22.go +++ b/webview2/pkg/webview2/ICoreWebView2_22.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_22Vtbl struct { IUnknownVtbl - AddWebResourceRequestedFilterWithRequestSourceKinds ComProc + AddWebResourceRequestedFilterWithRequestSourceKinds ComProc RemoveWebResourceRequestedFilterWithRequestSourceKinds ComProc } @@ -18,23 +17,32 @@ type ICoreWebView2_22 struct { Vtbl *ICoreWebView2_22Vtbl } -func (i *ICoreWebView2_22) AddRef() uintptr { +func (i *ICoreWebView2_22) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_22) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_22() *ICoreWebView2_22 { + +func (i *ICoreWebView2) GetICoreWebView2_22() (*ICoreWebView2_22, error) { var result *ICoreWebView2_22 iidICoreWebView2_22 := NewGUID("{db75dfc7-a857-4632-a398-6969dde26c0a}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_22)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_22) AddWebResourceRequestedFilterWithRequestSourceKinds(uri string, ResourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT, requestSourceKinds COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS) error { // Convert string 'uri' to *uint16 @@ -43,7 +51,7 @@ func (i *ICoreWebView2_22) AddWebResourceRequestedFilterWithRequestSourceKinds(u return err } - hr, _, _ := i.Vtbl.AddWebResourceRequestedFilterWithRequestSourceKinds.Call( + hr, _, err := i.Vtbl.AddWebResourceRequestedFilterWithRequestSourceKinds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(ResourceContext), @@ -52,7 +60,7 @@ func (i *ICoreWebView2_22) AddWebResourceRequestedFilterWithRequestSourceKinds(u if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_22) RemoveWebResourceRequestedFilterWithRequestSourceKinds(uri string, ResourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT, requestSourceKinds COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS) error { @@ -63,7 +71,7 @@ func (i *ICoreWebView2_22) RemoveWebResourceRequestedFilterWithRequestSourceKind return err } - hr, _, _ := i.Vtbl.RemoveWebResourceRequestedFilterWithRequestSourceKinds.Call( + hr, _, err := i.Vtbl.RemoveWebResourceRequestedFilterWithRequestSourceKinds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(ResourceContext), @@ -72,5 +80,5 @@ func (i *ICoreWebView2_22) RemoveWebResourceRequestedFilterWithRequestSourceKind if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_23.go b/webview2/pkg/webview2/ICoreWebView2_23.go index 6696cfcdf68..6ac775b6445 100644 --- a/webview2/pkg/webview2/ICoreWebView2_23.go +++ b/webview2/pkg/webview2/ICoreWebView2_23.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_23Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2_23 struct { Vtbl *ICoreWebView2_23Vtbl } -func (i *ICoreWebView2_23) AddRef() uintptr { +func (i *ICoreWebView2_23) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_23) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_23() *ICoreWebView2_23 { + +func (i *ICoreWebView2) GetICoreWebView2_23() (*ICoreWebView2_23, error) { var result *ICoreWebView2_23 iidICoreWebView2_23 := NewGUID("{508f0db5-90c4-5872-90a7-267a91377502}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_23)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_23) PostWebMessageAsJsonWithAdditionalObjects(webMessageAsJson string, additionalObjects *ICoreWebView2ObjectCollectionView) error { // Convert string 'webMessageAsJson' to *uint16 @@ -42,7 +50,7 @@ func (i *ICoreWebView2_23) PostWebMessageAsJsonWithAdditionalObjects(webMessageA return err } - hr, _, _ := i.Vtbl.PostWebMessageAsJsonWithAdditionalObjects.Call( + hr, _, err := i.Vtbl.PostWebMessageAsJsonWithAdditionalObjects.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsJson)), uintptr(unsafe.Pointer(additionalObjects)), @@ -50,5 +58,5 @@ func (i *ICoreWebView2_23) PostWebMessageAsJsonWithAdditionalObjects(webMessageA if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_24.go b/webview2/pkg/webview2/ICoreWebView2_24.go index 88ca87af9f1..085479e34cc 100644 --- a/webview2/pkg/webview2/ICoreWebView2_24.go +++ b/webview2/pkg/webview2/ICoreWebView2_24.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_24Vtbl struct { IUnknownVtbl - AddNotificationReceived ComProc + AddNotificationReceived ComProc RemoveNotificationReceived ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2_24 struct { Vtbl *ICoreWebView2_24Vtbl } -func (i *ICoreWebView2_24) AddRef() uintptr { +func (i *ICoreWebView2_24) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_24) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_24() *ICoreWebView2_24 { + +func (i *ICoreWebView2) GetICoreWebView2_24() (*ICoreWebView2_24, error) { var result *ICoreWebView2_24 iidICoreWebView2_24 := NewGUID("{39a7ad55-4287-5cc1-88a1-c6f458593824}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_24)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_24) AddNotificationReceived(eventHandler *ICoreWebView2NotificationReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddNotificationReceived.Call( + hr, _, err := i.Vtbl.AddNotificationReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2_24) AddNotificationReceived(eventHandler *ICoreWebView2No if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_24) RemoveNotificationReceived(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveNotificationReceived.Call( + + hr, _, err := i.Vtbl.RemoveNotificationReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_25.go b/webview2/pkg/webview2/ICoreWebView2_25.go index 8bff2732de0..7583ca4540d 100644 --- a/webview2/pkg/webview2/ICoreWebView2_25.go +++ b/webview2/pkg/webview2/ICoreWebView2_25.go @@ -1,46 +1,54 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_25Vtbl struct { IUnknownVtbl - AddSaveAsUIShowing ComProc + AddSaveAsUIShowing ComProc RemoveSaveAsUIShowing ComProc - ShowSaveAsUI ComProc + ShowSaveAsUI ComProc } type ICoreWebView2_25 struct { Vtbl *ICoreWebView2_25Vtbl } -func (i *ICoreWebView2_25) AddRef() uintptr { +func (i *ICoreWebView2_25) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_25) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_25() *ICoreWebView2_25 { + +func (i *ICoreWebView2) GetICoreWebView2_25() (*ICoreWebView2_25, error) { var result *ICoreWebView2_25 iidICoreWebView2_25 := NewGUID("{b5a86092-df50-5b4f-a17b-6c8f8b40b771}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_25)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_25) AddSaveAsUIShowing(eventHandler *ICoreWebView2SaveAsUIShowingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddSaveAsUIShowing.Call( + hr, _, err := i.Vtbl.AddSaveAsUIShowing.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -48,29 +56,31 @@ func (i *ICoreWebView2_25) AddSaveAsUIShowing(eventHandler *ICoreWebView2SaveAsU if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_25) RemoveSaveAsUIShowing(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveSaveAsUIShowing.Call( + + hr, _, err := i.Vtbl.RemoveSaveAsUIShowing.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_25) ShowSaveAsUI(handler *ICoreWebView2ShowSaveAsUICompletedHandler) error { - hr, _, _ := i.Vtbl.ShowSaveAsUI.Call( + + hr, _, err := i.Vtbl.ShowSaveAsUI.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_26.go b/webview2/pkg/webview2/ICoreWebView2_26.go index e8bf63ffd31..1cdb24d7185 100644 --- a/webview2/pkg/webview2/ICoreWebView2_26.go +++ b/webview2/pkg/webview2/ICoreWebView2_26.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_26Vtbl struct { IUnknownVtbl - AddSaveFileSecurityCheckStarting ComProc + AddSaveFileSecurityCheckStarting ComProc RemoveSaveFileSecurityCheckStarting ComProc } @@ -18,27 +17,37 @@ type ICoreWebView2_26 struct { Vtbl *ICoreWebView2_26Vtbl } -func (i *ICoreWebView2_26) AddRef() uintptr { +func (i *ICoreWebView2_26) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_26) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_26() *ICoreWebView2_26 { + +func (i *ICoreWebView2) GetICoreWebView2_26() (*ICoreWebView2_26, error) { var result *ICoreWebView2_26 iidICoreWebView2_26 := NewGUID("{806268b8-f897-5685-88e5-c45fca0b1a48}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_26)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_26) AddSaveFileSecurityCheckStarting(eventHandler *ICoreWebView2SaveFileSecurityCheckStartingEventHandler) (EventRegistrationToken, error) { + var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddSaveFileSecurityCheckStarting.Call( + hr, _, err := i.Vtbl.AddSaveFileSecurityCheckStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -46,16 +55,18 @@ func (i *ICoreWebView2_26) AddSaveFileSecurityCheckStarting(eventHandler *ICoreW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_26) RemoveSaveFileSecurityCheckStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveSaveFileSecurityCheckStarting.Call( + + + hr, _, err := i.Vtbl.RemoveSaveFileSecurityCheckStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_27.go b/webview2/pkg/webview2/ICoreWebView2_27.go index 09e1923a4fa..4ffd82f614a 100644 --- a/webview2/pkg/webview2/ICoreWebView2_27.go +++ b/webview2/pkg/webview2/ICoreWebView2_27.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_27Vtbl struct { IUnknownVtbl - AddScreenCaptureStarting ComProc + AddScreenCaptureStarting ComProc RemoveScreenCaptureStarting ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2_27 struct { Vtbl *ICoreWebView2_27Vtbl } -func (i *ICoreWebView2_27) AddRef() uintptr { +func (i *ICoreWebView2_27) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_27) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_27() *ICoreWebView2_27 { + +func (i *ICoreWebView2) GetICoreWebView2_27() (*ICoreWebView2_27, error) { var result *ICoreWebView2_27 iidICoreWebView2_27 := NewGUID("{00fbe33b-8c07-517c-aa23-0ddd4b5f6fa0}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_27)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_27) AddScreenCaptureStarting(eventHandler *ICoreWebView2ScreenCaptureStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddScreenCaptureStarting.Call( + hr, _, err := i.Vtbl.AddScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2_27) AddScreenCaptureStarting(eventHandler *ICoreWebView2S if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_27) RemoveScreenCaptureStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveScreenCaptureStarting.Call( + + hr, _, err := i.Vtbl.RemoveScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_3.go b/webview2/pkg/webview2/ICoreWebView2_3.go index f08d23f946d..f1fde7367cd 100644 --- a/webview2/pkg/webview2/ICoreWebView2_3.go +++ b/webview2/pkg/webview2/ICoreWebView2_3.go @@ -1,19 +1,18 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_3Vtbl struct { IUnknownVtbl - TrySuspend ComProc - Resume ComProc - GetIsSuspended ComProc - SetVirtualHostNameToFolderMapping ComProc + TrySuspend ComProc + Resume ComProc + GetIsSuspended ComProc + SetVirtualHostNameToFolderMapping ComProc ClearVirtualHostNameToFolderMapping ComProc } @@ -21,51 +20,62 @@ type ICoreWebView2_3 struct { Vtbl *ICoreWebView2_3Vtbl } -func (i *ICoreWebView2_3) AddRef() uintptr { +func (i *ICoreWebView2_3) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_3() *ICoreWebView2_3 { + +func (i *ICoreWebView2) GetICoreWebView2_3() (*ICoreWebView2_3, error) { var result *ICoreWebView2_3 iidICoreWebView2_3 := NewGUID("{A0D6DF20-3B92-416D-AA0C-437A9C727857}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_3)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_3) TrySuspend(handler *ICoreWebView2TrySuspendCompletedHandler) error { - hr, _, _ := i.Vtbl.TrySuspend.Call( + + hr, _, err := i.Vtbl.TrySuspend.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_3) Resume() error { - hr, _, _ := i.Vtbl.Resume.Call( + + hr, _, err := i.Vtbl.Resume.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_3) GetIsSuspended() (bool, error) { // Create int32 to hold bool result var _isSuspended int32 - hr, _, _ := i.Vtbl.GetIsSuspended.Call( + hr, _, err := i.Vtbl.GetIsSuspended.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSuspended)), ) @@ -73,8 +83,8 @@ func (i *ICoreWebView2_3) GetIsSuspended() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - isSuspended := _isSuspended != 0 - return isSuspended, nil + isSuspended := _isSuspended != 0 + return isSuspended, err } func (i *ICoreWebView2_3) SetVirtualHostNameToFolderMapping(hostName string, folderPath string, accessKind COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND) error { @@ -90,7 +100,7 @@ func (i *ICoreWebView2_3) SetVirtualHostNameToFolderMapping(hostName string, fol return err } - hr, _, _ := i.Vtbl.SetVirtualHostNameToFolderMapping.Call( + hr, _, err := i.Vtbl.SetVirtualHostNameToFolderMapping.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_hostName)), uintptr(unsafe.Pointer(_folderPath)), @@ -99,7 +109,7 @@ func (i *ICoreWebView2_3) SetVirtualHostNameToFolderMapping(hostName string, fol if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_3) ClearVirtualHostNameToFolderMapping(hostName string) error { @@ -110,12 +120,12 @@ func (i *ICoreWebView2_3) ClearVirtualHostNameToFolderMapping(hostName string) e return err } - hr, _, _ := i.Vtbl.ClearVirtualHostNameToFolderMapping.Call( + hr, _, err := i.Vtbl.ClearVirtualHostNameToFolderMapping.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_hostName)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_4.go b/webview2/pkg/webview2/ICoreWebView2_4.go index e513d4f6f4f..7723b96f922 100644 --- a/webview2/pkg/webview2/ICoreWebView2_4.go +++ b/webview2/pkg/webview2/ICoreWebView2_4.go @@ -1,18 +1,17 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_4Vtbl struct { IUnknownVtbl - AddFrameCreated ComProc - RemoveFrameCreated ComProc - AddDownloadStarting ComProc + AddFrameCreated ComProc + RemoveFrameCreated ComProc + AddDownloadStarting ComProc RemoveDownloadStarting ComProc } @@ -20,28 +19,37 @@ type ICoreWebView2_4 struct { Vtbl *ICoreWebView2_4Vtbl } -func (i *ICoreWebView2_4) AddRef() uintptr { +func (i *ICoreWebView2_4) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_4() *ICoreWebView2_4 { + +func (i *ICoreWebView2) GetICoreWebView2_4() (*ICoreWebView2_4, error) { var result *ICoreWebView2_4 iidICoreWebView2_4 := NewGUID("{20d02d59-6df2-42dc-bd06-f98a694b1302}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_4)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_4) AddFrameCreated(eventHandler *ICoreWebView2FrameCreatedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddFrameCreated.Call( + hr, _, err := i.Vtbl.AddFrameCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -49,26 +57,27 @@ func (i *ICoreWebView2_4) AddFrameCreated(eventHandler *ICoreWebView2FrameCreate if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_4) RemoveFrameCreated(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveFrameCreated.Call( + + hr, _, err := i.Vtbl.RemoveFrameCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_4) AddDownloadStarting(eventHandler *ICoreWebView2DownloadStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddDownloadStarting.Call( + hr, _, err := i.Vtbl.AddDownloadStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -76,17 +85,18 @@ func (i *ICoreWebView2_4) AddDownloadStarting(eventHandler *ICoreWebView2Downloa if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_4) RemoveDownloadStarting(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveDownloadStarting.Call( + + hr, _, err := i.Vtbl.RemoveDownloadStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_5.go b/webview2/pkg/webview2/ICoreWebView2_5.go index 6c0b39d007e..429d67cde4c 100644 --- a/webview2/pkg/webview2/ICoreWebView2_5.go +++ b/webview2/pkg/webview2/ICoreWebView2_5.go @@ -1,16 +1,15 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_5Vtbl struct { IUnknownVtbl - AddClientCertificateRequested ComProc + AddClientCertificateRequested ComProc RemoveClientCertificateRequested ComProc } @@ -18,28 +17,37 @@ type ICoreWebView2_5 struct { Vtbl *ICoreWebView2_5Vtbl } -func (i *ICoreWebView2_5) AddRef() uintptr { +func (i *ICoreWebView2_5) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_5() *ICoreWebView2_5 { + +func (i *ICoreWebView2) GetICoreWebView2_5() (*ICoreWebView2_5, error) { var result *ICoreWebView2_5 iidICoreWebView2_5 := NewGUID("{bedb11b8-d63c-11eb-b8bc-0242ac130003}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_5)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_5) AddClientCertificateRequested(eventHandler *ICoreWebView2ClientCertificateRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddClientCertificateRequested.Call( + hr, _, err := i.Vtbl.AddClientCertificateRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -47,17 +55,18 @@ func (i *ICoreWebView2_5) AddClientCertificateRequested(eventHandler *ICoreWebVi if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_5) RemoveClientCertificateRequested(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveClientCertificateRequested.Call( + + hr, _, err := i.Vtbl.RemoveClientCertificateRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_6.go b/webview2/pkg/webview2/ICoreWebView2_6.go index 1b93eb13db3..02cb30aee9a 100644 --- a/webview2/pkg/webview2/ICoreWebView2_6.go +++ b/webview2/pkg/webview2/ICoreWebView2_6.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_6Vtbl struct { @@ -17,30 +16,40 @@ type ICoreWebView2_6 struct { Vtbl *ICoreWebView2_6Vtbl } -func (i *ICoreWebView2_6) AddRef() uintptr { +func (i *ICoreWebView2_6) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_6) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_6() *ICoreWebView2_6 { + +func (i *ICoreWebView2) GetICoreWebView2_6() (*ICoreWebView2_6, error) { var result *ICoreWebView2_6 iidICoreWebView2_6 := NewGUID("{499aadac-d92c-4589-8a75-111bfc167795}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_6)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_6) OpenTaskManagerWindow() error { - hr, _, _ := i.Vtbl.OpenTaskManagerWindow.Call( + + hr, _, err := i.Vtbl.OpenTaskManagerWindow.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_7.go b/webview2/pkg/webview2/ICoreWebView2_7.go index 19b012bfa43..066c881b705 100644 --- a/webview2/pkg/webview2/ICoreWebView2_7.go +++ b/webview2/pkg/webview2/ICoreWebView2_7.go @@ -1,11 +1,10 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_7Vtbl struct { @@ -17,23 +16,32 @@ type ICoreWebView2_7 struct { Vtbl *ICoreWebView2_7Vtbl } -func (i *ICoreWebView2_7) AddRef() uintptr { +func (i *ICoreWebView2_7) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) +} + +func (i *ICoreWebView2_7) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_7() *ICoreWebView2_7 { + +func (i *ICoreWebView2) GetICoreWebView2_7() (*ICoreWebView2_7, error) { var result *ICoreWebView2_7 iidICoreWebView2_7 := NewGUID("{79c24d83-09a3-45ae-9418-487f32a58740}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_7)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_7) PrintToPdf(ResultFilePath string, printSettings *ICoreWebView2PrintSettings, handler *ICoreWebView2PrintToPdfCompletedHandler) error { // Convert string 'ResultFilePath' to *uint16 @@ -42,7 +50,7 @@ func (i *ICoreWebView2_7) PrintToPdf(ResultFilePath string, printSettings *ICore return err } - hr, _, _ := i.Vtbl.PrintToPdf.Call( + hr, _, err := i.Vtbl.PrintToPdf.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_ResultFilePath)), uintptr(unsafe.Pointer(printSettings)), @@ -51,5 +59,5 @@ func (i *ICoreWebView2_7) PrintToPdf(ResultFilePath string, printSettings *ICore if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/ICoreWebView2_8.go b/webview2/pkg/webview2/ICoreWebView2_8.go index a52aa664d2b..dfc7411b96d 100644 --- a/webview2/pkg/webview2/ICoreWebView2_8.go +++ b/webview2/pkg/webview2/ICoreWebView2_8.go @@ -1,50 +1,58 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_8Vtbl struct { IUnknownVtbl - AddIsMutedChanged ComProc - RemoveIsMutedChanged ComProc - GetIsMuted ComProc - PutIsMuted ComProc - AddIsDocumentPlayingAudioChanged ComProc + AddIsMutedChanged ComProc + RemoveIsMutedChanged ComProc + GetIsMuted ComProc + PutIsMuted ComProc + AddIsDocumentPlayingAudioChanged ComProc RemoveIsDocumentPlayingAudioChanged ComProc - GetIsDocumentPlayingAudio ComProc + GetIsDocumentPlayingAudio ComProc } type ICoreWebView2_8 struct { Vtbl *ICoreWebView2_8Vtbl } -func (i *ICoreWebView2_8) AddRef() uintptr { +func (i *ICoreWebView2_8) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_8() *ICoreWebView2_8 { +func (i *ICoreWebView2_8) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2_8() (*ICoreWebView2_8, error) { var result *ICoreWebView2_8 iidICoreWebView2_8 := NewGUID("{E9632730-6E1E-43AB-B7B8-7B2C9E62E094}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_8)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_8) AddIsMutedChanged(eventHandler *ICoreWebView2IsMutedChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddIsMutedChanged.Call( + hr, _, err := i.Vtbl.AddIsMutedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -52,26 +60,27 @@ func (i *ICoreWebView2_8) AddIsMutedChanged(eventHandler *ICoreWebView2IsMutedCh if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_8) RemoveIsMutedChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveIsMutedChanged.Call( + + hr, _, err := i.Vtbl.RemoveIsMutedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_8) GetIsMuted() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsMuted.Call( + hr, _, err := i.Vtbl.GetIsMuted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -79,27 +88,33 @@ func (i *ICoreWebView2_8) GetIsMuted() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2_8) PutIsMuted(value bool) error { - hr, _, _ := i.Vtbl.PutIsMuted.Call( + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsMuted.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&value)), + uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_8) AddIsDocumentPlayingAudioChanged(eventHandler *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddIsDocumentPlayingAudioChanged.Call( + hr, _, err := i.Vtbl.AddIsDocumentPlayingAudioChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -107,26 +122,27 @@ func (i *ICoreWebView2_8) AddIsDocumentPlayingAudioChanged(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_8) RemoveIsDocumentPlayingAudioChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveIsDocumentPlayingAudioChanged.Call( + + hr, _, err := i.Vtbl.RemoveIsDocumentPlayingAudioChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_8) GetIsDocumentPlayingAudio() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsDocumentPlayingAudio.Call( + hr, _, err := i.Vtbl.GetIsDocumentPlayingAudio.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -134,6 +150,6 @@ func (i *ICoreWebView2_8) GetIsDocumentPlayingAudio() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } diff --git a/webview2/pkg/webview2/ICoreWebView2_9.go b/webview2/pkg/webview2/ICoreWebView2_9.go index c93fee53c08..ece83df7c9c 100644 --- a/webview2/pkg/webview2/ICoreWebView2_9.go +++ b/webview2/pkg/webview2/ICoreWebView2_9.go @@ -1,52 +1,60 @@ //go:build windows package webview2 - import ( - "golang.org/x/sys/windows" - "syscall" "unsafe" + "syscall" + "golang.org/x/sys/windows" ) type ICoreWebView2_9Vtbl struct { IUnknownVtbl - AddIsDefaultDownloadDialogOpenChanged ComProc + AddIsDefaultDownloadDialogOpenChanged ComProc RemoveIsDefaultDownloadDialogOpenChanged ComProc - GetIsDefaultDownloadDialogOpen ComProc - OpenDefaultDownloadDialog ComProc - CloseDefaultDownloadDialog ComProc - GetDefaultDownloadDialogCornerAlignment ComProc - PutDefaultDownloadDialogCornerAlignment ComProc - GetDefaultDownloadDialogMargin ComProc - PutDefaultDownloadDialogMargin ComProc + GetIsDefaultDownloadDialogOpen ComProc + OpenDefaultDownloadDialog ComProc + CloseDefaultDownloadDialog ComProc + GetDefaultDownloadDialogCornerAlignment ComProc + PutDefaultDownloadDialogCornerAlignment ComProc + GetDefaultDownloadDialogMargin ComProc + PutDefaultDownloadDialogMargin ComProc } type ICoreWebView2_9 struct { Vtbl *ICoreWebView2_9Vtbl } -func (i *ICoreWebView2_9) AddRef() uintptr { +func (i *ICoreWebView2_9) AddRef() uint32 { refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) - return refCounter + return uint32(refCounter) } -func (i *ICoreWebView2) GetICoreWebView2_9() *ICoreWebView2_9 { +func (i *ICoreWebView2_9) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2_9() (*ICoreWebView2_9, error) { var result *ICoreWebView2_9 iidICoreWebView2_9 := NewGUID("{4d7b2eab-9fdc-468d-b998-a9260b5ed651}") - _, _, _ = i.Vtbl.QueryInterface.Call( + hr, _, _ := i.Vtbl.QueryInterface.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(iidICoreWebView2_9)), uintptr(unsafe.Pointer(&result))) - - return result + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil } + func (i *ICoreWebView2_9) AddIsDefaultDownloadDialogOpenChanged(handler *ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, _ := i.Vtbl.AddIsDefaultDownloadDialogOpenChanged.Call( + hr, _, err := i.Vtbl.AddIsDefaultDownloadDialogOpenChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), uintptr(unsafe.Pointer(&token)), @@ -54,26 +62,27 @@ func (i *ICoreWebView2_9) AddIsDefaultDownloadDialogOpenChanged(handler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, nil + return token, err } func (i *ICoreWebView2_9) RemoveIsDefaultDownloadDialogOpenChanged(token EventRegistrationToken) error { - hr, _, _ := i.Vtbl.RemoveIsDefaultDownloadDialogOpenChanged.Call( + + hr, _, err := i.Vtbl.RemoveIsDefaultDownloadDialogOpenChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_9) GetIsDefaultDownloadDialogOpen() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, _ := i.Vtbl.GetIsDefaultDownloadDialogOpen.Call( + hr, _, err := i.Vtbl.GetIsDefaultDownloadDialogOpen.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -81,80 +90,84 @@ func (i *ICoreWebView2_9) GetIsDefaultDownloadDialogOpen() (bool, error) { return false, syscall.Errno(hr) } // Get result and cleanup - value := _value != 0 - return value, nil + value := _value != 0 + return value, err } func (i *ICoreWebView2_9) OpenDefaultDownloadDialog() error { - hr, _, _ := i.Vtbl.OpenDefaultDownloadDialog.Call( + + hr, _, err := i.Vtbl.OpenDefaultDownloadDialog.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_9) CloseDefaultDownloadDialog() error { - hr, _, _ := i.Vtbl.CloseDefaultDownloadDialog.Call( + + hr, _, err := i.Vtbl.CloseDefaultDownloadDialog.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_9) GetDefaultDownloadDialogCornerAlignment() (COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT, error) { var value COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT - hr, _, _ := i.Vtbl.GetDefaultDownloadDialogCornerAlignment.Call( + hr, _, err := i.Vtbl.GetDefaultDownloadDialogCornerAlignment.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2_9) PutDefaultDownloadDialogCornerAlignment(value COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT) error { - hr, _, _ := i.Vtbl.PutDefaultDownloadDialogCornerAlignment.Call( + + hr, _, err := i.Vtbl.PutDefaultDownloadDialogCornerAlignment.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } func (i *ICoreWebView2_9) GetDefaultDownloadDialogMargin() (POINT, error) { var value POINT - hr, _, _ := i.Vtbl.GetDefaultDownloadDialogMargin.Call( + hr, _, err := i.Vtbl.GetDefaultDownloadDialogMargin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return value, nil + return value, err } func (i *ICoreWebView2_9) PutDefaultDownloadDialogMargin(value POINT) error { - hr, _, _ := i.Vtbl.PutDefaultDownloadDialogMargin.Call( + + hr, _, err := i.Vtbl.PutDefaultDownloadDialogMargin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return nil + return err } diff --git a/webview2/pkg/webview2/capabilities.go b/webview2/pkg/webview2/capabilities.go new file mode 100644 index 00000000000..809bf43a4f3 --- /dev/null +++ b/webview2/pkg/webview2/capabilities.go @@ -0,0 +1,304 @@ +//go:build windows + +// Code generated by webview2gen. DO NOT EDIT. + +package webview2 + +import ( + "fmt" + "strconv" + "strings" +) + +// InterfaceMinimumVersion maps an ICoreWebView2_N interface name to the +// minimum WebView2 SDK version that introduced it. Use SupportsInterface +// to compare against a runtime version. +var InterfaceMinimumVersion = map[string]string{ + "ICoreWebView2": "0.9.515-prerelease", + "ICoreWebView2EnvironmentOptions": "0.9.515-prerelease", + "ICoreWebView2ExperimentalCompositionController": "0.9.515-prerelease", + "ICoreWebView2ExperimentalCursorChangedEventHandler": "0.9.515-prerelease", + "ICoreWebView2ExperimentalPointerInfo": "0.9.515-prerelease", + "ICoreWebView2Host": "0.9.515-prerelease", + "ICoreWebView2ExperimentalNewWindowRequestedEventArgs": "0.9.622.11", + "ICoreWebView2ExperimentalWindowFeatures": "0.9.622.11", + "ICoreWebView2NewWindowRequestedEventArgs": "0.9.622.11", + "ICoreWebView2WindowFeatures": "0.9.622.11", + "ICoreWebView2CompositionController": "1.0.790-prerelease", + "ICoreWebView2Environment3": "1.0.790-prerelease", + "ICoreWebView2Experimental": "1.0.790-prerelease", + "ICoreWebView2WebResourceResponseViewGetContentCompletedHandler": "1.0.790-prerelease", + "ICoreWebView2NewWindowRequestedEventArgs2": "1.0.992.28", + "ICoreWebView2ProcessFailedEventArgs2": "1.0.1056-prerelease", + "ICoreWebView2Certificate": "1.0.1158-prerelease", + "ICoreWebView2ClientCertificate": "1.0.1158-prerelease", + "ICoreWebView2Frame": "1.0.1222-prerelease", + "ICoreWebView2_11": "1.0.1264.42", + "ICoreWebView2_15": "1.0.1305-prerelease", + "ICoreWebView2_7": "1.0.1305-prerelease", + "ICoreWebView2Experimental16": "1.0.1340-prerelease", + "ICoreWebView2ExperimentalCustomSchemeRegistration": "1.0.1340-prerelease", + "ICoreWebView2ExperimentalEnvironmentOptions": "1.0.1340-prerelease", + "ICoreWebView2ExperimentalWebResourceRequestedEventArgs": "1.0.1340-prerelease", + "ICoreWebView2CompositionController3": "1.0.1369-prerelease", + "ICoreWebView2CompositionControllerInterop2": "1.0.1369-prerelease", + "ICoreWebView2Experimental17": "1.0.1414-prerelease", + "ICoreWebView2ExperimentalEnvironment": "1.0.1414-prerelease", + "ICoreWebView2ExperimentalEnvironmentOptions2": "1.0.1414-prerelease", + "ICoreWebView2ExperimentalPrintCompletedHandler": "1.0.1414-prerelease", + "ICoreWebView2ExperimentalPrintSettings2": "1.0.1414-prerelease", + "ICoreWebView2ExperimentalSettings7": "1.0.1414-prerelease", + "ICoreWebView2Experimental18": "1.0.1466-prerelease", + "ICoreWebView2ExperimentalFrame4": "1.0.1466-prerelease", + "ICoreWebView2ExperimentalScriptException": "1.0.1466-prerelease", + "ICoreWebView2ExperimentalSharedBuffer": "1.0.1466-prerelease", + "ICoreWebView2Environment11": "1.0.1549-prerelease", + "ICoreWebView2EnvironmentOptions3": "1.0.1549-prerelease", + "ICoreWebView2ExperimentalControllerOptions": "1.0.1549-prerelease", + "ICoreWebView2ExperimentalProfile5": "1.0.1549-prerelease", + "ICoreWebView2PrintCompletedHandler": "1.0.1549-prerelease", + "ICoreWebView2PrintSettings2": "1.0.1549-prerelease", + "ICoreWebView2PrintToPdfStreamCompletedHandler": "1.0.1549-prerelease", + "ICoreWebView2_16": "1.0.1549-prerelease", + "ICoreWebView2CustomSchemeRegistration": "1.0.1619-prerelease", + "ICoreWebView2EnvironmentOptions4": "1.0.1619-prerelease", + "ICoreWebView2EnvironmentOptions5": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalNavigationStartingEventArgs2": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalPermissionRequestedEventArgs3": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalPermissionSetting": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalPermissionSettingCollectionView": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalProfile6": "1.0.1619-prerelease", + "ICoreWebView2ExperimentalSetPermissionStateCompletedHandler": "1.0.1619-prerelease", + "ICoreWebView2Profile3": "1.0.1619-prerelease", + "ICoreWebView2PermissionRequestedEventArgs3": "1.0.1661.34", + "ICoreWebView2ControllerOptions2": "1.0.1671-prerelease", + "ICoreWebView2Environment": "1.0.1671-prerelease", + "ICoreWebView2Environment12": "1.0.1671-prerelease", + "ICoreWebView2ExperimentalFile": "1.0.1671-prerelease", + "ICoreWebView2ExperimentalObjectCollectionView": "1.0.1671-prerelease", + "ICoreWebView2ExperimentalWebMessageReceivedEventArgs": "1.0.1671-prerelease", + "ICoreWebView2Frame4": "1.0.1671-prerelease", + "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler": "1.0.1671-prerelease", + "ICoreWebView2PermissionSetting": "1.0.1671-prerelease", + "ICoreWebView2PermissionSettingCollectionView": "1.0.1671-prerelease", + "ICoreWebView2Profile4": "1.0.1671-prerelease", + "ICoreWebView2SetPermissionStateCompletedHandler": "1.0.1671-prerelease", + "ICoreWebView2SharedBuffer": "1.0.1671-prerelease", + "ICoreWebView2_17": "1.0.1671-prerelease", + "ICoreWebView2Experimental20": "1.0.1724-prerelease", + "ICoreWebView2Experimental21": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalEnvironment12": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalProfile10": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalProfile7": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalProfile8": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalProfileDeletedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTexture": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStream": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamStoppedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler": "1.0.1724-prerelease", + "ICoreWebView2ExperimentalWebTexture": "1.0.1724-prerelease", + "ICoreWebView2Settings8": "1.0.1724-prerelease", + "ICoreWebView2File": "1.0.1777-prerelease", + "ICoreWebView2ObjectCollectionView": "1.0.1777-prerelease", + "ICoreWebView2Profile5": "1.0.1777-prerelease", + "ICoreWebView2WebMessageReceivedEventArgs2": "1.0.1777-prerelease", + "ICoreWebView2Profile6": "1.0.1829-prerelease", + "ICoreWebView2LaunchingExternalUriSchemeEventArgs": "1.0.1905-prerelease", + "ICoreWebView2LaunchingExternalUriSchemeEventHandler": "1.0.1905-prerelease", + "ICoreWebView2NavigationStartingEventArgs3": "1.0.1905-prerelease", + "ICoreWebView2_18": "1.0.1905-prerelease", + "ICoreWebView2_19": "1.0.1905-prerelease", +} + +// SupportsInterface reports whether the given runtime version is at least +// the SDK version that introduced iface. Returns the required version when +// the answer is false, or an empty string otherwise. Returns an error if +// iface is unknown or runtimeVersion fails to parse. +func SupportsInterface(runtimeVersion, iface string) (bool, string, error) { + required, ok := InterfaceMinimumVersion[iface] + if !ok { + return false, "", fmt.Errorf("unknown interface %q", iface) + } + c, err := compareVersions(runtimeVersion, required) + if err != nil { + return false, required, err + } + if c < 0 { + return false, required, nil + } + return true, "", nil +} + +// HasCapability is the high-level feature gate. Each Capability is wired +// to a specific interface; the runtime is checked against that interface's +// minimum version. +func HasCapability(runtimeVersion string, cap Capability) (bool, error) { + supported, _, err := SupportsInterface(runtimeVersion, cap.Interface) + return supported, err +} + +// Capability identifies a Wails-relevant feature gate. The set is generated +// from the interface inventory; consumers may hand-add named subsets. +type Capability struct { + Name string + Description string + Interface string +} + +// AllCapabilities lists every known interface as a Capability. +var AllCapabilities = []Capability{ + {Name: "ICoreWebView2", Description: "Requires interface ICoreWebView2", Interface: "ICoreWebView2"}, + {Name: "ICoreWebView2EnvironmentOptions", Description: "Requires interface ICoreWebView2EnvironmentOptions", Interface: "ICoreWebView2EnvironmentOptions"}, + {Name: "ICoreWebView2ExperimentalCompositionController", Description: "Requires interface ICoreWebView2ExperimentalCompositionController", Interface: "ICoreWebView2ExperimentalCompositionController"}, + {Name: "ICoreWebView2ExperimentalCursorChangedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalCursorChangedEventHandler", Interface: "ICoreWebView2ExperimentalCursorChangedEventHandler"}, + {Name: "ICoreWebView2ExperimentalPointerInfo", Description: "Requires interface ICoreWebView2ExperimentalPointerInfo", Interface: "ICoreWebView2ExperimentalPointerInfo"}, + {Name: "ICoreWebView2Host", Description: "Requires interface ICoreWebView2Host", Interface: "ICoreWebView2Host"}, + {Name: "ICoreWebView2ExperimentalNewWindowRequestedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalNewWindowRequestedEventArgs", Interface: "ICoreWebView2ExperimentalNewWindowRequestedEventArgs"}, + {Name: "ICoreWebView2ExperimentalWindowFeatures", Description: "Requires interface ICoreWebView2ExperimentalWindowFeatures", Interface: "ICoreWebView2ExperimentalWindowFeatures"}, + {Name: "ICoreWebView2NewWindowRequestedEventArgs", Description: "Requires interface ICoreWebView2NewWindowRequestedEventArgs", Interface: "ICoreWebView2NewWindowRequestedEventArgs"}, + {Name: "ICoreWebView2WindowFeatures", Description: "Requires interface ICoreWebView2WindowFeatures", Interface: "ICoreWebView2WindowFeatures"}, + {Name: "ICoreWebView2CompositionController", Description: "Requires interface ICoreWebView2CompositionController", Interface: "ICoreWebView2CompositionController"}, + {Name: "ICoreWebView2Environment3", Description: "Requires interface ICoreWebView2Environment3", Interface: "ICoreWebView2Environment3"}, + {Name: "ICoreWebView2Experimental", Description: "Requires interface ICoreWebView2Experimental", Interface: "ICoreWebView2Experimental"}, + {Name: "ICoreWebView2WebResourceResponseViewGetContentCompletedHandler", Description: "Requires interface ICoreWebView2WebResourceResponseViewGetContentCompletedHandler", Interface: "ICoreWebView2WebResourceResponseViewGetContentCompletedHandler"}, + {Name: "ICoreWebView2NewWindowRequestedEventArgs2", Description: "Requires interface ICoreWebView2NewWindowRequestedEventArgs2", Interface: "ICoreWebView2NewWindowRequestedEventArgs2"}, + {Name: "ICoreWebView2ProcessFailedEventArgs2", Description: "Requires interface ICoreWebView2ProcessFailedEventArgs2", Interface: "ICoreWebView2ProcessFailedEventArgs2"}, + {Name: "ICoreWebView2Certificate", Description: "Requires interface ICoreWebView2Certificate", Interface: "ICoreWebView2Certificate"}, + {Name: "ICoreWebView2ClientCertificate", Description: "Requires interface ICoreWebView2ClientCertificate", Interface: "ICoreWebView2ClientCertificate"}, + {Name: "ICoreWebView2Frame", Description: "Requires interface ICoreWebView2Frame", Interface: "ICoreWebView2Frame"}, + {Name: "ICoreWebView2_11", Description: "Requires interface ICoreWebView2_11", Interface: "ICoreWebView2_11"}, + {Name: "ICoreWebView2_15", Description: "Requires interface ICoreWebView2_15", Interface: "ICoreWebView2_15"}, + {Name: "ICoreWebView2_7", Description: "Requires interface ICoreWebView2_7", Interface: "ICoreWebView2_7"}, + {Name: "ICoreWebView2Experimental16", Description: "Requires interface ICoreWebView2Experimental16", Interface: "ICoreWebView2Experimental16"}, + {Name: "ICoreWebView2ExperimentalCustomSchemeRegistration", Description: "Requires interface ICoreWebView2ExperimentalCustomSchemeRegistration", Interface: "ICoreWebView2ExperimentalCustomSchemeRegistration"}, + {Name: "ICoreWebView2ExperimentalEnvironmentOptions", Description: "Requires interface ICoreWebView2ExperimentalEnvironmentOptions", Interface: "ICoreWebView2ExperimentalEnvironmentOptions"}, + {Name: "ICoreWebView2ExperimentalWebResourceRequestedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalWebResourceRequestedEventArgs", Interface: "ICoreWebView2ExperimentalWebResourceRequestedEventArgs"}, + {Name: "ICoreWebView2CompositionController3", Description: "Requires interface ICoreWebView2CompositionController3", Interface: "ICoreWebView2CompositionController3"}, + {Name: "ICoreWebView2CompositionControllerInterop2", Description: "Requires interface ICoreWebView2CompositionControllerInterop2", Interface: "ICoreWebView2CompositionControllerInterop2"}, + {Name: "ICoreWebView2Experimental17", Description: "Requires interface ICoreWebView2Experimental17", Interface: "ICoreWebView2Experimental17"}, + {Name: "ICoreWebView2ExperimentalEnvironment", Description: "Requires interface ICoreWebView2ExperimentalEnvironment", Interface: "ICoreWebView2ExperimentalEnvironment"}, + {Name: "ICoreWebView2ExperimentalEnvironmentOptions2", Description: "Requires interface ICoreWebView2ExperimentalEnvironmentOptions2", Interface: "ICoreWebView2ExperimentalEnvironmentOptions2"}, + {Name: "ICoreWebView2ExperimentalPrintCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalPrintCompletedHandler", Interface: "ICoreWebView2ExperimentalPrintCompletedHandler"}, + {Name: "ICoreWebView2ExperimentalPrintSettings2", Description: "Requires interface ICoreWebView2ExperimentalPrintSettings2", Interface: "ICoreWebView2ExperimentalPrintSettings2"}, + {Name: "ICoreWebView2ExperimentalSettings7", Description: "Requires interface ICoreWebView2ExperimentalSettings7", Interface: "ICoreWebView2ExperimentalSettings7"}, + {Name: "ICoreWebView2Experimental18", Description: "Requires interface ICoreWebView2Experimental18", Interface: "ICoreWebView2Experimental18"}, + {Name: "ICoreWebView2ExperimentalFrame4", Description: "Requires interface ICoreWebView2ExperimentalFrame4", Interface: "ICoreWebView2ExperimentalFrame4"}, + {Name: "ICoreWebView2ExperimentalScriptException", Description: "Requires interface ICoreWebView2ExperimentalScriptException", Interface: "ICoreWebView2ExperimentalScriptException"}, + {Name: "ICoreWebView2ExperimentalSharedBuffer", Description: "Requires interface ICoreWebView2ExperimentalSharedBuffer", Interface: "ICoreWebView2ExperimentalSharedBuffer"}, + {Name: "ICoreWebView2Environment11", Description: "Requires interface ICoreWebView2Environment11", Interface: "ICoreWebView2Environment11"}, + {Name: "ICoreWebView2EnvironmentOptions3", Description: "Requires interface ICoreWebView2EnvironmentOptions3", Interface: "ICoreWebView2EnvironmentOptions3"}, + {Name: "ICoreWebView2ExperimentalControllerOptions", Description: "Requires interface ICoreWebView2ExperimentalControllerOptions", Interface: "ICoreWebView2ExperimentalControllerOptions"}, + {Name: "ICoreWebView2ExperimentalProfile5", Description: "Requires interface ICoreWebView2ExperimentalProfile5", Interface: "ICoreWebView2ExperimentalProfile5"}, + {Name: "ICoreWebView2PrintCompletedHandler", Description: "Requires interface ICoreWebView2PrintCompletedHandler", Interface: "ICoreWebView2PrintCompletedHandler"}, + {Name: "ICoreWebView2PrintSettings2", Description: "Requires interface ICoreWebView2PrintSettings2", Interface: "ICoreWebView2PrintSettings2"}, + {Name: "ICoreWebView2PrintToPdfStreamCompletedHandler", Description: "Requires interface ICoreWebView2PrintToPdfStreamCompletedHandler", Interface: "ICoreWebView2PrintToPdfStreamCompletedHandler"}, + {Name: "ICoreWebView2_16", Description: "Requires interface ICoreWebView2_16", Interface: "ICoreWebView2_16"}, + {Name: "ICoreWebView2CustomSchemeRegistration", Description: "Requires interface ICoreWebView2CustomSchemeRegistration", Interface: "ICoreWebView2CustomSchemeRegistration"}, + {Name: "ICoreWebView2EnvironmentOptions4", Description: "Requires interface ICoreWebView2EnvironmentOptions4", Interface: "ICoreWebView2EnvironmentOptions4"}, + {Name: "ICoreWebView2EnvironmentOptions5", Description: "Requires interface ICoreWebView2EnvironmentOptions5", Interface: "ICoreWebView2EnvironmentOptions5"}, + {Name: "ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler", Interface: "ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler"}, + {Name: "ICoreWebView2ExperimentalNavigationStartingEventArgs2", Description: "Requires interface ICoreWebView2ExperimentalNavigationStartingEventArgs2", Interface: "ICoreWebView2ExperimentalNavigationStartingEventArgs2"}, + {Name: "ICoreWebView2ExperimentalPermissionRequestedEventArgs3", Description: "Requires interface ICoreWebView2ExperimentalPermissionRequestedEventArgs3", Interface: "ICoreWebView2ExperimentalPermissionRequestedEventArgs3"}, + {Name: "ICoreWebView2ExperimentalPermissionSetting", Description: "Requires interface ICoreWebView2ExperimentalPermissionSetting", Interface: "ICoreWebView2ExperimentalPermissionSetting"}, + {Name: "ICoreWebView2ExperimentalPermissionSettingCollectionView", Description: "Requires interface ICoreWebView2ExperimentalPermissionSettingCollectionView", Interface: "ICoreWebView2ExperimentalPermissionSettingCollectionView"}, + {Name: "ICoreWebView2ExperimentalProfile6", Description: "Requires interface ICoreWebView2ExperimentalProfile6", Interface: "ICoreWebView2ExperimentalProfile6"}, + {Name: "ICoreWebView2ExperimentalSetPermissionStateCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalSetPermissionStateCompletedHandler", Interface: "ICoreWebView2ExperimentalSetPermissionStateCompletedHandler"}, + {Name: "ICoreWebView2Profile3", Description: "Requires interface ICoreWebView2Profile3", Interface: "ICoreWebView2Profile3"}, + {Name: "ICoreWebView2PermissionRequestedEventArgs3", Description: "Requires interface ICoreWebView2PermissionRequestedEventArgs3", Interface: "ICoreWebView2PermissionRequestedEventArgs3"}, + {Name: "ICoreWebView2ControllerOptions2", Description: "Requires interface ICoreWebView2ControllerOptions2", Interface: "ICoreWebView2ControllerOptions2"}, + {Name: "ICoreWebView2Environment", Description: "Requires interface ICoreWebView2Environment", Interface: "ICoreWebView2Environment"}, + {Name: "ICoreWebView2Environment12", Description: "Requires interface ICoreWebView2Environment12", Interface: "ICoreWebView2Environment12"}, + {Name: "ICoreWebView2ExperimentalFile", Description: "Requires interface ICoreWebView2ExperimentalFile", Interface: "ICoreWebView2ExperimentalFile"}, + {Name: "ICoreWebView2ExperimentalObjectCollectionView", Description: "Requires interface ICoreWebView2ExperimentalObjectCollectionView", Interface: "ICoreWebView2ExperimentalObjectCollectionView"}, + {Name: "ICoreWebView2ExperimentalWebMessageReceivedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalWebMessageReceivedEventArgs", Interface: "ICoreWebView2ExperimentalWebMessageReceivedEventArgs"}, + {Name: "ICoreWebView2Frame4", Description: "Requires interface ICoreWebView2Frame4", Interface: "ICoreWebView2Frame4"}, + {Name: "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler", Description: "Requires interface ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler", Interface: "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler"}, + {Name: "ICoreWebView2PermissionSetting", Description: "Requires interface ICoreWebView2PermissionSetting", Interface: "ICoreWebView2PermissionSetting"}, + {Name: "ICoreWebView2PermissionSettingCollectionView", Description: "Requires interface ICoreWebView2PermissionSettingCollectionView", Interface: "ICoreWebView2PermissionSettingCollectionView"}, + {Name: "ICoreWebView2Profile4", Description: "Requires interface ICoreWebView2Profile4", Interface: "ICoreWebView2Profile4"}, + {Name: "ICoreWebView2SetPermissionStateCompletedHandler", Description: "Requires interface ICoreWebView2SetPermissionStateCompletedHandler", Interface: "ICoreWebView2SetPermissionStateCompletedHandler"}, + {Name: "ICoreWebView2SharedBuffer", Description: "Requires interface ICoreWebView2SharedBuffer", Interface: "ICoreWebView2SharedBuffer"}, + {Name: "ICoreWebView2_17", Description: "Requires interface ICoreWebView2_17", Interface: "ICoreWebView2_17"}, + {Name: "ICoreWebView2Experimental20", Description: "Requires interface ICoreWebView2Experimental20", Interface: "ICoreWebView2Experimental20"}, + {Name: "ICoreWebView2Experimental21", Description: "Requires interface ICoreWebView2Experimental21", Interface: "ICoreWebView2Experimental21"}, + {Name: "ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler", Interface: "ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler"}, + {Name: "ICoreWebView2ExperimentalEnvironment12", Description: "Requires interface ICoreWebView2ExperimentalEnvironment12", Interface: "ICoreWebView2ExperimentalEnvironment12"}, + {Name: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs", Description: "Requires interface ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs", Interface: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs"}, + {Name: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler", Description: "Requires interface ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler", Interface: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler"}, + {Name: "ICoreWebView2ExperimentalProfile10", Description: "Requires interface ICoreWebView2ExperimentalProfile10", Interface: "ICoreWebView2ExperimentalProfile10"}, + {Name: "ICoreWebView2ExperimentalProfile7", Description: "Requires interface ICoreWebView2ExperimentalProfile7", Interface: "ICoreWebView2ExperimentalProfile7"}, + {Name: "ICoreWebView2ExperimentalProfile8", Description: "Requires interface ICoreWebView2ExperimentalProfile8", Interface: "ICoreWebView2ExperimentalProfile8"}, + {Name: "ICoreWebView2ExperimentalProfileDeletedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalProfileDeletedEventHandler", Interface: "ICoreWebView2ExperimentalProfileDeletedEventHandler"}, + {Name: "ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler", Interface: "ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler"}, + {Name: "ICoreWebView2ExperimentalTexture", Description: "Requires interface ICoreWebView2ExperimentalTexture", Interface: "ICoreWebView2ExperimentalTexture"}, + {Name: "ICoreWebView2ExperimentalTextureStream", Description: "Requires interface ICoreWebView2ExperimentalTextureStream", Interface: "ICoreWebView2ExperimentalTextureStream"}, + {Name: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs", Interface: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs"}, + {Name: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler"}, + {Name: "ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler"}, + {Name: "ICoreWebView2ExperimentalTextureStreamStoppedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamStoppedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamStoppedEventHandler"}, + {Name: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs", Interface: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs"}, + {Name: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler"}, + {Name: "ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler"}, + {Name: "ICoreWebView2ExperimentalWebTexture", Description: "Requires interface ICoreWebView2ExperimentalWebTexture", Interface: "ICoreWebView2ExperimentalWebTexture"}, + {Name: "ICoreWebView2Settings8", Description: "Requires interface ICoreWebView2Settings8", Interface: "ICoreWebView2Settings8"}, + {Name: "ICoreWebView2File", Description: "Requires interface ICoreWebView2File", Interface: "ICoreWebView2File"}, + {Name: "ICoreWebView2ObjectCollectionView", Description: "Requires interface ICoreWebView2ObjectCollectionView", Interface: "ICoreWebView2ObjectCollectionView"}, + {Name: "ICoreWebView2Profile5", Description: "Requires interface ICoreWebView2Profile5", Interface: "ICoreWebView2Profile5"}, + {Name: "ICoreWebView2WebMessageReceivedEventArgs2", Description: "Requires interface ICoreWebView2WebMessageReceivedEventArgs2", Interface: "ICoreWebView2WebMessageReceivedEventArgs2"}, + {Name: "ICoreWebView2Profile6", Description: "Requires interface ICoreWebView2Profile6", Interface: "ICoreWebView2Profile6"}, + {Name: "ICoreWebView2LaunchingExternalUriSchemeEventArgs", Description: "Requires interface ICoreWebView2LaunchingExternalUriSchemeEventArgs", Interface: "ICoreWebView2LaunchingExternalUriSchemeEventArgs"}, + {Name: "ICoreWebView2LaunchingExternalUriSchemeEventHandler", Description: "Requires interface ICoreWebView2LaunchingExternalUriSchemeEventHandler", Interface: "ICoreWebView2LaunchingExternalUriSchemeEventHandler"}, + {Name: "ICoreWebView2NavigationStartingEventArgs3", Description: "Requires interface ICoreWebView2NavigationStartingEventArgs3", Interface: "ICoreWebView2NavigationStartingEventArgs3"}, + {Name: "ICoreWebView2_18", Description: "Requires interface ICoreWebView2_18", Interface: "ICoreWebView2_18"}, + {Name: "ICoreWebView2_19", Description: "Requires interface ICoreWebView2_19", Interface: "ICoreWebView2_19"}, +} + +func compareVersions(a, b string) (int, error) { + pa, err := parseVersion(a) + if err != nil { + return 0, fmt.Errorf("runtime version %q: %w", a, err) + } + pb, err := parseVersion(b) + if err != nil { + return 0, fmt.Errorf("required version %q: %w", b, err) + } + for i := 0; i < 4; i++ { + if pa[i] < pb[i] { + return -1, nil + } + if pa[i] > pb[i] { + return 1, nil + } + } + return 0, nil +} + +func parseVersion(s string) ([4]int, error) { + var out [4]int + // Drop a channel suffix ("1.0.515 prerelease" or "1.0.515-prerelease"). + if i := strings.IndexAny(s, " -"); i > 0 { + s = s[:i] + } + parts := strings.Split(s, ".") + if len(parts) > 4 { + return out, fmt.Errorf("too many segments") + } + for i, p := range parts { + n, err := strconv.Atoi(p) + if err != nil { + return out, err + } + out[i] = n + } + return out, nil +} diff --git a/webview2/pkg/webview2/com.go b/webview2/pkg/webview2/com.go index 125ba212803..144ac7cafe2 100644 --- a/webview2/pkg/webview2/com.go +++ b/webview2/pkg/webview2/com.go @@ -4,9 +4,9 @@ package webview2 import ( "golang.org/x/sys/windows" - "io" "syscall" "unsafe" + "io" ) // ComProc stores a COM procedure. @@ -32,22 +32,23 @@ type IUnknownVtbl struct { Release ComProc } -func (i *IUnknownVtbl) CallRelease(this unsafe.Pointer) uint32 { - ret, _, _ := i.Release.Call( +func (i *IUnknownVtbl) CallRelease(this unsafe.Pointer) error { + _, _, err := i.Release.Call( uintptr(this), ) - - return uint32(ret) + if err != windows.ERROR_SUCCESS { + return err + } + return nil } type IUnknownImpl interface { QueryInterface(refiid, object uintptr) uintptr - AddRef() uintptr - Release() uintptr + AddRef() uint32 + Release() uint32 } // Call calls a COM procedure. -// //go:uintptrescapes func (p ComProc) Call(a ...uintptr) (r1, r2 uintptr, lastErr error) { return syscall.SyscallN(uintptr(p), a...) @@ -71,8 +72,15 @@ type HMENU uintptr type HMODULE uintptr type HWND uintptr -// NOTE: For sure, this is wrong! -type VARIANT uintptr +// VARIANT is a 16-byte Windows VARIANT type matching the Windows ABI. +// The Val field is a union; callers must interpret it based on VT. +type VARIANT struct { + VT uint16 + Reserved1 uint16 + Reserved2 uint16 + Reserved3 uint16 + Val [8]byte +} type IDataObject struct { IUnknown @@ -85,7 +93,7 @@ func ptr[T any](p T) *T { const ERROR_SUCCESS = windows.ERROR_SUCCESS func UTF16PtrFromString(s string) (*uint16, error) { - return windows.UTF16PtrFromString(s) + return windows.UTF16PtrFromString(s) } func UTF16PtrToString(s *uint16) string { @@ -93,7 +101,7 @@ func UTF16PtrToString(s *uint16) string { } func CoTaskMemFree(pv unsafe.Pointer) { - windows.CoTaskMemFree(pv) + windows.CoTaskMemFree(pv) } // This code has been adapted from: https://github.com/go-ole/go-ole @@ -318,6 +326,7 @@ func IsEqualGUID(guid1 *GUID, guid2 *GUID) bool { guid1.Data4[7] == guid2.Data4[7] } + type IStreamVtbl struct { IUnknownVtbl Read ComProc @@ -328,7 +337,7 @@ type IStream struct { Vtbl *IStreamVtbl } -func (i *IStream) Release() uint32 { +func (i *IStream) Release() error { return i.Vtbl.CallRelease(unsafe.Pointer(i)) } From 62a285afa29214fd1da5158b150fa42a069b4f74 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:37:45 +1000 Subject: [PATCH 06/13] docs(webview2): add README, ARCHITECTURE, doc.go + fix .gitignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit The .gitignore line `webview2gen` was too broad — it matched the cmd/webview2gen package directory and silently excluded main.go and main_test.go from the previous commit. Tighten the pattern to the two paths where a compiled binary could land: /scripts/webview2gen /scripts/cmd/webview2gen/webview2gen Also adds the CLI files (now reachable) and the v2 documentation: • webview2/README.md — pipeline + capability usage + the six-bug-fix changelog table • webview2/ARCHITECTURE.md — design rationale, trade-offs, rejected approaches, future work • webview2/pkg/webview2/doc.go — package doc, regeneration recipe, `//go:generate webview2gen full` --- webview2/.gitignore | 4 +- webview2/ARCHITECTURE.md | 152 +++++++ webview2/README.md | 122 ++++++ webview2/pkg/webview2/doc.go | 19 + webview2/scripts/cmd/webview2gen/main.go | 378 ++++++++++++++++++ webview2/scripts/cmd/webview2gen/main_test.go | 222 ++++++++++ 6 files changed, 896 insertions(+), 1 deletion(-) create mode 100644 webview2/ARCHITECTURE.md create mode 100644 webview2/README.md create mode 100644 webview2/pkg/webview2/doc.go create mode 100644 webview2/scripts/cmd/webview2gen/main.go create mode 100644 webview2/scripts/cmd/webview2gen/main_test.go diff --git a/webview2/.gitignore b/webview2/.gitignore index 57caf029132..ac816dacbd5 100644 --- a/webview2/.gitignore +++ b/webview2/.gitignore @@ -1 +1,3 @@ -webview2gen +# Compiled webview2gen binary — never commit, build artifact only. +/scripts/webview2gen +/scripts/cmd/webview2gen/webview2gen diff --git a/webview2/ARCHITECTURE.md b/webview2/ARCHITECTURE.md new file mode 100644 index 00000000000..fafa5289103 --- /dev/null +++ b/webview2/ARCHITECTURE.md @@ -0,0 +1,152 @@ +# wails/webview2 — Architecture + +This document records the design decisions behind the v2 WebView2 binding +generator. It is the reference for "why was this done this way?" questions. + +## Goals + +1. **Correct.** Generated COM bindings must respect the Windows ABI — + no caller-stack pointer writes, no missing release methods, no truncated + reference counts. +2. **Reproducible.** Given a frozen IDL + release-notes file, two runs of + `webview2gen full` on different machines must produce byte-identical + output. CI gates on this via `webview2gen verify`. +3. **Capability-aware.** The Wails runtime sees a stable Go API, but at + runtime degrades gracefully when the installed WebView2 lacks an + interface (we ship for a wide range of runtime versions). +4. **Single command refresh.** Refreshing the bindings for a new SDK + release must be one CLI invocation, not a sequence of hand edits. + +## High-level pipeline + +``` + Microsoft NuGet MicrosoftDocs/edge-developer + │ │ + │ .nupkg (zip of headers + WebView2.idl) │ index.md + ▼ ▼ + ┌──────────────────────────┐ ┌─────────────────────────┐ + │ internal/idl.Fetcher │ │ internal/notes.Fetch │ + │ extracts WebView2.idl │ │ scrapes release notes │ + │ caches in scripts/*.idl │ │ │ + └──────────────┬───────────┘ └────────────┬────────────┘ + │ │ + ▼ ▼ + ┌──────────────────────────┐ ┌─────────────────────────┐ + │ generator.ParseIDL │ │ notes.Parse │ + │ participle/v2 grammar │ │ extract per-release │ + │ types/typemap (17 pat.) │ │ interface mentions │ + │ emits []GeneratedFile │ │ │ + └──────────────┬───────────┘ └────────────┬────────────┘ + │ │ + ▼ ▼ + pkg/webview2/*.go (306 files) pkg/webview2/capabilities.go +``` + +Each box is one Go package under `webview2/scripts/`; `webview2gen` (the +CLI) wires them together. + +## Design decisions + +### Template-driven emitter (kept) + +The generator emits Go source by composing `text/template` files in +`scripts/generator/types/templates/`. The spec considered moving to a +fully programmatic emitter (`fmt.Fprintf` + `bytes.Buffer`), but the +existing template surface is small (12 files), debuggable, and already +covers all the patterns we need. The 6 bug fixes were all expressible as +template edits; a rewrite would have been a much larger churn for the +same correctness outcome. + +**Trade-off.** Templates are weakly typed and easy to break with whitespace +changes. Mitigated by the snapshot-style `testfiles/` fixtures: every +generator change re-runs the existing fixtures and diffs them. + +### File-per-interface output + +`pkg/webview2/` has 306 files because each interface and each enum lands +in its own file. Diffs from an SDK refresh stay readable, and parallel +editing of related but separate interfaces doesn't cause merge churn. + +**Trade-off.** `ls pkg/webview2 | wc -l` is intimidating. Mitigated by +`doc.go` (the only hand-written file) carrying the "do not edit" notice +and the regeneration recipe. + +### IDL inlined upfront + +The fetcher pulls `WebView2.idl` directly out of the NuGet `.nupkg`. The +file is self-contained — it inlines the COM/OLE types it depends on, so +we do not need a preprocessor that resolves `import "objidl.idl"` etc. +If a future SDK switches to multi-file IDL, `internal/idl` is where the +inliner will live. + +### Capabilities from release notes + +The mapping "ICoreWebView2_N → minimum SDK version" comes from scraping +the Markdown release notes (`MicrosoftDocs/edge-developer`). The IDL +itself does not record which SDK introduced which interface; the release +notes do (as the bullet "Added the `ICoreWebView2_N` interface" under a +versioned heading). + +The scrape is regex-based and walks the notes oldest-first so the +earliest mention wins. When Microsoft changes the notes format we will +see test failures and update the regex; the table is committed at +`pkg/webview2/capabilities.go` so a broken scrape can be fixed without +forcing every consumer to wait. + +**Trade-off.** A maintenance burden (every few months Microsoft may +restructure the notes). Mitigated by the test suite covering the parser +against the cached `test.md` snapshot. + +### `pkg/edge/` is kept, not deleted + +The legacy `pkg/edge/` package is what the Wails v3 runtime actually +imports today. Removing it would break the runtime in the same PR that +ships the new generator. The migration plan: + +1. This branch lands the generator + tested `pkg/webview2/`. +2. A follow-up PR refactors `v3/pkg/application/...` (chromium.go) to + import `pkg/webview2`. +3. After that lands, `pkg/edge/` is moved or removed. + +`pkg/edge/` is therefore actively used and must not be touched by +generator runs. The generator only writes to `pkg/webview2/`. + +### Two go modules in one repo + +`webview2/go.mod` is the runtime module (`github.com/wailsapp/wails/webview2`). +`webview2/scripts/go.mod` is a dev-time module (`module updater`, a +legacy name kept to avoid a noisy rename). The split: + +- Lets `scripts/` depend on developer-only packages (NuGet fetcher, HTTP + client, participle/v2) without forcing those deps on every consumer. +- Lets `scripts/` use a separate, sometimes-older Go version (1.20) than + the runtime module (1.24) without conflict. + +If we ever want a single module, the rename is straightforward but +out-of-scope for this branch. + +### Rejected approaches + +- **Hand-maintain the bindings.** ~109 out-pointer methods to audit, and + one new SDK per six weeks. Untenable. The whole point of v2 is + automation. +- **`go-ole` or other COM libraries.** Adds a third-party dependency + that we then need to track for the same set of fixes. The thin + template-based wrapper is simpler to audit. +- **Monolithic `webview2.go`.** A single file would be 30k+ lines. + Reviewing diffs for a new SDK release would be impractical. + +## Future considerations + +- **Generics for type-safe vtable calls.** Today every vtable invocation + is `uintptr(unsafe.Pointer(...))`. Go generics could express the call + shape per parameter type. Out of scope for v2; tracked as a follow-up. +- **Automatic version detection at startup.** `webviewloader` already + reports the runtime version. We could populate a process-wide cache + so `SupportsInterface` calls don't need to re-pass the string. +- **Cross-platform compile checks.** `pkg/webview2/` is `//go:build + windows` so non-Windows CI can't catch regressions. Could add a + `linux` shim package that satisfies the same surface using build tags. +- **Windows VM CI.** The generator unit tests run on Linux. Smoke tests + for the COM bindings need a real WebView2 runtime — tracked as + WAI-297; not in this branch. diff --git a/webview2/README.md b/webview2/README.md new file mode 100644 index 00000000000..716d05dcf32 --- /dev/null +++ b/webview2/README.md @@ -0,0 +1,122 @@ +# wails/webview2 + +Generated Go bindings for the Microsoft Edge WebView2 SDK and the tooling +that produces them. This module is consumed by Wails on Windows. + +## Package layout + +| Path | Purpose | +|------|---------| +| `pkg/webview2/` | **Generated** Go COM bindings for ICoreWebView2 (v1 through v27 at the latest SDK). Every `.go` file except `doc.go` is regenerated from `WebView2.idl`. | +| `pkg/edge/` | **Legacy** hand-maintained bindings for ICoreWebView2 v1–v4. Still used by `v3/pkg/application` via `chromium.go`; kept until the runtime is migrated. | +| `pkg/combridge/` | Generic COM bridge for implementing Go-side COM objects (event handlers, callbacks). | +| `webviewloader/` | Runtime DLL finder and version comparator (`CompareBrowserVersions`). | +| `internal/w32/` | Win32 syscall stubs used by the loader. | +| `scripts/` | The IDL cache (`WebView2.*.idl`), the `webview2gen` CLI, the parser, the emitter, and the internal helper packages. `module updater`. | + +## webview2gen — the binding generator + +`webview2gen` is the single entry point for refreshing `pkg/webview2` +against a new SDK release. + +```sh +cd webview2/scripts + +# Download a specific SDK version (or no flag for the latest cached version). +go run ./cmd/webview2gen download --version 1.0.2903.40 + +# Parse the cached IDL and emit pkg/webview2/*.go. +go run ./cmd/webview2gen generate + +# Build pkg/webview2/capabilities.go from the SDK release notes. +go run ./cmd/webview2gen capabilities # fetches notes from GitHub +go run ./cmd/webview2gen capabilities --source test.md # use a local copy + +# Regenerate everything and fail if the working tree differs from the +# committed output — wire this into CI so hand-edits cannot land. +go run ./cmd/webview2gen verify + +# Run download → generate → capabilities → verify in sequence. +go run ./cmd/webview2gen full +``` + +Run `go generate ./...` from `webview2/` to invoke `full` via the +`//go:generate` directive in `pkg/webview2/doc.go`. + +### Subcommand flags + +Every subcommand accepts `--help`. Most useful defaults: + +- `download --dir .` — where to store cached IDLs (relative to `scripts/`). +- `generate --version ` — pin to a specific cached IDL (default: newest). +- `generate --out ../pkg/webview2` — where to write generated files. +- `capabilities --source ` — skip the network fetch. +- `capabilities --json ` — also dump the interface→version map as JSON. + +## Capabilities — runtime feature detection + +The WebView2 SDK adds interfaces (ICoreWebView2_1 → ICoreWebView2_27 and +counting). A given runtime supports a subset; calling a method on an +interface the runtime doesn't know about crashes the process. To gate +features safely: + +```go +import "github.com/wailsapp/wails/webview2/pkg/webview2" + +runtime := webview2runtime.GetAvailableCoreWebView2BrowserVersionString() // e.g. "121.0.2277.83" + +ok, required, err := webview2.SupportsInterface(runtime, "ICoreWebView2_22") +if err != nil { ... } +if !ok { + log.Printf("feature disabled — needs WebView2 SDK %s, runtime reports %s", required, runtime) + return +} +// safe to call ICoreWebView2_22 methods +``` + +For a higher-level gate, declare a `Capability` once and check it everywhere: + +```go +var screenCapture = webview2.Capability{ + Name: "screen-capture", + Description: "ScreenCaptureStarting event support", + Interface: "ICoreWebView2_22", +} +if ok, _ := webview2.HasCapability(runtime, screenCapture); ok { ... } +``` + +`AllCapabilities` enumerates every interface as a named gate, suitable for +boot-time logging or diagnostics. + +## Bugs fixed by the v2 generator + +| # | Severity | Pattern | Fix | +|---|----------|---------|-----| +| 1 | Critical | `[out] LPWSTR* name` produced `uintptr(unsafe.Pointer(_name))` — COM wrote the string pointer into the caller's stack | Now produces `uintptr(unsafe.Pointer(&_name))` so the local `*uint16` receives the string. Affects ~109 methods. | +| 2 | Moderate | `[in] LPWSTR*` was treated as a single `string` | Maps to `[]string`; the new `inputStringArraySetup.tmpl` marshals each element to `*uint16`. | +| 3 | Moderate | Generated interfaces lacked `Release()`, leaking refs | `Release() uint32` is emitted alongside `AddRef()` on every interface. | +| 4 | Minor | `QueryInterface` swallowed `HRESULT`, returning `nil` on failure | Returns `(*T, error)`; non-zero HRESULTs are surfaced. | +| 5 | Minor | `VARIANT` was a `uintptr` (8 bytes) instead of the 16-byte Windows struct | `type VARIANT struct { VT uint16; … Val [8]byte }`. | +| 6 | Minor | `AddRef/Release` returned `uintptr` instead of the COM `ULONG` (uint32) | Both return `uint32`; callback wrappers cast to `uintptr` at the syscall boundary. | + +## Testing + +```sh +cd webview2/scripts +go test ./... # generator + internal pkgs (Linux-fine) +GOOS=windows go vet ../pkg/... # cross-vet the generated bindings +``` + +CI must gate on `webview2gen verify` and `go test ./...`. The generator +contains regression tests for each of the 17 typed IDL patterns and for +all six known bug classes. + +Windows VM integration tests (COM smoke, property getters, event handlers) +are tracked separately on WAI-297 — they require an actual WebView2 runtime. + +## See also + +- `ARCHITECTURE.md` for the design rationale (programmatic emitter, + file-per-interface, capability sources, etc.). +- Microsoft SDK release notes: +- WebView2 IDL on NuGet: diff --git a/webview2/pkg/webview2/doc.go b/webview2/pkg/webview2/doc.go new file mode 100644 index 00000000000..85c735f3bce --- /dev/null +++ b/webview2/pkg/webview2/doc.go @@ -0,0 +1,19 @@ +// Package webview2 contains the WebView2 COM bindings generated from +// Microsoft's WebView2 SDK IDL. Every file in this package except this +// one is machine-generated by `webview2gen` (see ../../scripts/cmd/webview2gen). +// +// Do NOT hand-edit generated files — they will be overwritten on the next +// run of the generator. To pick up a new SDK release: +// +// cd webview2/scripts +// go run ./cmd/webview2gen download --version +// go run ./cmd/webview2gen generate +// go run ./cmd/webview2gen capabilities --source test.md +// go run ./cmd/webview2gen verify # CI will fail otherwise +// +// Capability-aware feature gating lives in capabilities.go; consumers +// should call SupportsInterface or HasCapability before invoking methods +// that are only present on newer WebView2 runtime versions. +package webview2 + +//go:generate go run ../../scripts/cmd/webview2gen full diff --git a/webview2/scripts/cmd/webview2gen/main.go b/webview2/scripts/cmd/webview2gen/main.go new file mode 100644 index 00000000000..5c7abb39a92 --- /dev/null +++ b/webview2/scripts/cmd/webview2gen/main.go @@ -0,0 +1,378 @@ +// webview2gen is the WebView2 IDL → Go binding generator and capability +// table builder. It is the single entry point for refreshing +// pkg/webview2 against a new SDK release. +// +// Subcommands +// +// download Fetch a WebView2 SDK IDL (latest by default) into the +// local IDL cache. Use --version to pin. +// generate Parse a cached IDL and emit pkg/webview2/*.go. +// capabilities Fetch the SDK release notes, derive the +// interface→minimum-version mapping, and emit +// pkg/webview2/capabilities.go. +// test Run `go test ./...` against the generator + internal pkgs. +// verify Regenerate everything against the on-disk IDL and fail if +// the working tree differs — guards against hand-edits. +// full download → generate → capabilities → verify, in that order. +// +// Run `webview2gen --help` for per-command flags. +package main + +import ( + "bytes" + "errors" + "flag" + "fmt" + "io" + "os" + "os/exec" + "path/filepath" + "sort" + "strings" + + "updater/generator" + "updater/internal/capabilities" + "updater/internal/idl" + "updater/internal/idlversion" + "updater/internal/notes" +) + +const ( + // IDLDir is the on-disk cache for downloaded IDL files. The default + // matches the natural invocation `go run ./cmd/webview2gen ...` from + // inside scripts/ where the cached `WebView2..idl` files live. + IDLDir = "." + + // OutputDir is where generated bindings live, relative to scripts/. + OutputDir = "../pkg/webview2" +) + +func main() { + if len(os.Args) < 2 { + usage(os.Stderr) + os.Exit(2) + } + + cmd := os.Args[1] + args := os.Args[2:] + + cmds := map[string]func([]string) error{ + "download": runDownload, + "generate": runGenerate, + "capabilities": runCapabilities, + "test": runTest, + "verify": runVerify, + "full": runFull, + "help": func(_ []string) error { usage(os.Stdout); return nil }, + "-h": func(_ []string) error { usage(os.Stdout); return nil }, + "--help": func(_ []string) error { usage(os.Stdout); return nil }, + } + + fn, ok := cmds[cmd] + if !ok { + fmt.Fprintf(os.Stderr, "webview2gen: unknown command %q\n\n", cmd) + usage(os.Stderr) + os.Exit(2) + } + if err := fn(args); err != nil { + fmt.Fprintf(os.Stderr, "webview2gen %s: %v\n", cmd, err) + os.Exit(1) + } +} + +func usage(w io.Writer) { + fmt.Fprint(w, `webview2gen — WebView2 IDL → Go binding generator + +USAGE + webview2gen [flags] + +COMMANDS + download Fetch an SDK IDL into the local cache. + generate Generate pkg/webview2 from a cached IDL. + capabilities Emit pkg/webview2/capabilities.go from SDK release notes. + test Run `+"`"+`go test ./...`+"`"+` for the generator + internal pkgs. + verify Regenerate and fail if the working tree differs. + full download → generate → capabilities → verify. + +Use 'webview2gen --help' for command flags. +`) +} + +// ----------------------------------------------------------------------- +// download +// ----------------------------------------------------------------------- + +func runDownload(args []string) error { + fs := flag.NewFlagSet("download", flag.ContinueOnError) + version := fs.String("version", "", "SDK version to download (e.g. 1.0.2903.40). If empty, the latest known cached version is used.") + dir := fs.String("dir", IDLDir, "directory to cache IDL files in") + if err := fs.Parse(args); err != nil { + return err + } + + store := idl.NewStore(*dir) + fetcher := idl.NewFetcher(store) + + v := *version + if v == "" { + // No version given — fall back to the latest cached IDL so offline + // runs work. Use the release-notes scrape only if explicitly asked. + cached, err := store.List() + if err != nil { + return fmt.Errorf("list cache: %w", err) + } + if len(cached) == 0 { + return errors.New("no cached versions and --version not specified") + } + sort.Slice(cached, func(i, j int) bool { + c, _ := idlversion.Compare(cached[i], cached[j]) + return c < 0 + }) + v = cached[len(cached)-1] + fmt.Fprintf(os.Stderr, "using latest cached version: %s\n", v) + } + + if store.Has(v) { + fmt.Fprintf(os.Stderr, "%s already cached at %s\n", v, store.CachePath(v)) + return nil + } + data, err := fetcher.Download(v) + if err != nil { + return fmt.Errorf("download %s: %w", v, err) + } + fmt.Fprintf(os.Stderr, "downloaded %s (%d bytes) → %s\n", v, len(data), store.CachePath(v)) + return nil +} + +// ----------------------------------------------------------------------- +// generate +// ----------------------------------------------------------------------- + +func runGenerate(args []string) error { + fs := flag.NewFlagSet("generate", flag.ContinueOnError) + version := fs.String("version", "", "SDK version of the cached IDL to parse (default: latest cached)") + dir := fs.String("dir", IDLDir, "IDL cache directory") + out := fs.String("out", OutputDir, "output directory for generated bindings") + if err := fs.Parse(args); err != nil { + return err + } + + store := idl.NewStore(*dir) + v, err := resolveVersion(store, *version) + if err != nil { + return err + } + idlBytes, err := store.Read(v) + if err != nil { + return fmt.Errorf("read IDL %s: %w", v, err) + } + + files, err := generator.ParseIDL(idlBytes) + if err != nil { + return fmt.Errorf("parse IDL: %w", err) + } + + if err := os.MkdirAll(*out, 0o755); err != nil { + return fmt.Errorf("create output dir: %w", err) + } + for _, f := range files { + path := filepath.Join(*out, f.FileName) + if err := os.WriteFile(path, f.Content.Bytes(), 0o644); err != nil { + return fmt.Errorf("write %s: %w", path, err) + } + } + fmt.Fprintf(os.Stderr, "generated %d files in %s from SDK %s\n", len(files), *out, v) + return nil +} + +// ----------------------------------------------------------------------- +// capabilities +// ----------------------------------------------------------------------- + +func runCapabilities(args []string) error { + fs := flag.NewFlagSet("capabilities", flag.ContinueOnError) + source := fs.String("source", "", "release-notes markdown file (default: fetch from MicrosoftDocs)") + out := fs.String("out", OutputDir, "output directory for capabilities.go") + jsonOut := fs.String("json", "", "also write the interface→version map as JSON at this path (empty = skip)") + if err := fs.Parse(args); err != nil { + return err + } + + var md []byte + var err error + if *source != "" { + md, err = os.ReadFile(*source) + if err != nil { + return fmt.Errorf("read source: %w", err) + } + } else { + md, err = notes.Fetch() + if err != nil { + return fmt.Errorf("fetch release notes: %w", err) + } + } + + releases, err := notes.Parse(md) + if err != nil { + return fmt.Errorf("parse release notes: %w", err) + } + mapping := capabilities.Mapping(notes.InterfaceMinimumVersions(releases)) + if len(mapping) == 0 { + return errors.New("no interfaces extracted from release notes — check parser") + } + + emitted, err := capabilities.Emit(mapping, nil) + if err != nil { + return fmt.Errorf("emit: %w", err) + } + if err := os.MkdirAll(*out, 0o755); err != nil { + return fmt.Errorf("create output dir: %w", err) + } + path := filepath.Join(*out, "capabilities.go") + if err := os.WriteFile(path, emitted, 0o644); err != nil { + return fmt.Errorf("write %s: %w", path, err) + } + fmt.Fprintf(os.Stderr, "wrote %s (%d interfaces)\n", path, len(mapping)) + + if *jsonOut != "" { + if err := os.WriteFile(*jsonOut, capabilities.EmitJSON(mapping), 0o644); err != nil { + return fmt.Errorf("write JSON: %w", err) + } + fmt.Fprintf(os.Stderr, "wrote %s\n", *jsonOut) + } + return nil +} + +// ----------------------------------------------------------------------- +// test / verify / full +// ----------------------------------------------------------------------- + +func runTest(args []string) error { + fs := flag.NewFlagSet("test", flag.ContinueOnError) + verbose := fs.Bool("v", false, "verbose test output") + if err := fs.Parse(args); err != nil { + return err + } + testArgs := []string{"test", "./generator/...", "./internal/..."} + if *verbose { + testArgs = append(testArgs, "-v") + } + cmd := exec.Command("go", testArgs...) + cmd.Stdout = os.Stdout + cmd.Stderr = os.Stderr + return cmd.Run() +} + +func runVerify(args []string) error { + fs := flag.NewFlagSet("verify", flag.ContinueOnError) + version := fs.String("version", "", "SDK version to verify against (default: latest cached)") + dir := fs.String("dir", IDLDir, "IDL cache directory") + out := fs.String("out", OutputDir, "directory whose contents are compared against fresh generation") + if err := fs.Parse(args); err != nil { + return err + } + + store := idl.NewStore(*dir) + v, err := resolveVersion(store, *version) + if err != nil { + return err + } + idlBytes, err := store.Read(v) + if err != nil { + return fmt.Errorf("read IDL %s: %w", v, err) + } + + files, err := generator.ParseIDL(idlBytes) + if err != nil { + return fmt.Errorf("parse IDL: %w", err) + } + + // Build expected set; compare byte-for-byte against committed files. + var diffs []string + expected := map[string]bool{} + for _, f := range files { + expected[f.FileName] = true + path := filepath.Join(*out, f.FileName) + got, err := os.ReadFile(path) + if err != nil { + diffs = append(diffs, fmt.Sprintf("missing committed file: %s (%v)", path, err)) + continue + } + if !bytes.Equal(got, f.Content.Bytes()) { + diffs = append(diffs, fmt.Sprintf("changed file: %s", path)) + } + } + + // Look for committed files that the generator no longer produces. + // capabilities.go is emitted separately and shouldn't be flagged. + entries, err := os.ReadDir(*out) + if err != nil { + return fmt.Errorf("read output dir: %w", err) + } + for _, e := range entries { + name := e.Name() + if !strings.HasSuffix(name, ".go") { + continue + } + if name == "capabilities.go" || strings.HasSuffix(name, "_test.go") { + continue + } + if !expected[name] { + diffs = append(diffs, fmt.Sprintf("unexpected committed file: %s", filepath.Join(*out, name))) + } + } + + if len(diffs) > 0 { + sort.Strings(diffs) + for _, d := range diffs { + fmt.Fprintln(os.Stderr, d) + } + return fmt.Errorf("%d differences between regenerated and committed output", len(diffs)) + } + fmt.Fprintf(os.Stderr, "verify ok: %d files match committed output for SDK %s\n", len(files), v) + return nil +} + +func runFull(args []string) error { + for _, step := range []struct { + name string + fn func([]string) error + }{ + {"download", runDownload}, + {"generate", runGenerate}, + {"capabilities", runCapabilities}, + {"verify", runVerify}, + } { + fmt.Fprintf(os.Stderr, "==> %s\n", step.name) + if err := step.fn(args); err != nil { + return fmt.Errorf("%s: %w", step.name, err) + } + } + return nil +} + +// ----------------------------------------------------------------------- +// helpers +// ----------------------------------------------------------------------- + +func resolveVersion(store *idl.Store, want string) (string, error) { + if want != "" { + if !store.Has(want) { + return "", fmt.Errorf("version %s not in cache (%s) — run 'webview2gen download --version %s' first", + want, store.Dir, want) + } + return want, nil + } + cached, err := store.List() + if err != nil { + return "", fmt.Errorf("list cache: %w", err) + } + if len(cached) == 0 { + return "", errors.New("no IDL cached — run 'webview2gen download --version ' first") + } + sort.Slice(cached, func(i, j int) bool { + c, _ := idlversion.Compare(cached[i], cached[j]) + return c < 0 + }) + return cached[len(cached)-1], nil +} diff --git a/webview2/scripts/cmd/webview2gen/main_test.go b/webview2/scripts/cmd/webview2gen/main_test.go new file mode 100644 index 00000000000..ff520abab8b --- /dev/null +++ b/webview2/scripts/cmd/webview2gen/main_test.go @@ -0,0 +1,222 @@ +package main + +import ( + "archive/zip" + "bytes" + "net/http" + "net/http/httptest" + "os" + "os/exec" + "path/filepath" + "strings" + "testing" + + "updater/internal/idl" +) + +// buildBinary compiles the CLI into a temp dir and returns its path. +// Each test gets its own copy so concurrent runs don't conflict. +func buildBinary(t *testing.T) string { + t.Helper() + bin := filepath.Join(t.TempDir(), "webview2gen") + cmd := exec.Command("go", "build", "-o", bin, ".") + out, err := cmd.CombinedOutput() + if err != nil { + t.Fatalf("go build: %v\n%s", err, out) + } + return bin +} + +func run(t *testing.T, bin, wd string, args ...string) (string, string, int) { + t.Helper() + cmd := exec.Command(bin, args...) + cmd.Dir = wd + var stdout, stderr bytes.Buffer + cmd.Stdout = &stdout + cmd.Stderr = &stderr + err := cmd.Run() + code := 0 + if exit, ok := err.(*exec.ExitError); ok { + code = exit.ExitCode() + } else if err != nil { + t.Fatalf("run: %v", err) + } + return stdout.String(), stderr.String(), code +} + +func TestHelp(t *testing.T) { + bin := buildBinary(t) + out, _, code := run(t, bin, t.TempDir(), "help") + if code != 0 { + t.Errorf("help exit = %d, want 0", code) + } + for _, want := range []string{"download", "generate", "capabilities", "verify", "full"} { + if !strings.Contains(out, want) { + t.Errorf("help output missing %q", want) + } + } +} + +func TestUnknownCommand(t *testing.T) { + bin := buildBinary(t) + _, stderr, code := run(t, bin, t.TempDir(), "frobnicate") + if code == 0 { + t.Error("unknown command should exit nonzero") + } + if !strings.Contains(stderr, "unknown command") { + t.Errorf("expected 'unknown command' in stderr, got: %s", stderr) + } +} + +// fakeIDLContents is the minimum IDL required for the parser to produce a file. +const fakeIDLContents = ` +[uuid(26d34152-879f-4065-bea2-3daa2cfadfb8), version(1.0)] +library WebView2 { + [uuid(d60ac92c-37a6-4b26-a39e-95cfe59047bb), object, pointer_default(unique)] + interface ICoreWebView2Fake : IUnknown { + HRESULT Ping([out, retval] LPWSTR* result); + } +} +` + +func TestGenerateAndVerify(t *testing.T) { + bin := buildBinary(t) + wd := t.TempDir() + + idlDir := filepath.Join(wd, "scripts-cache") + if err := os.MkdirAll(idlDir, 0o755); err != nil { + t.Fatal(err) + } + if err := os.WriteFile(filepath.Join(idlDir, "WebView2.1.0.9999.0.idl"), []byte(fakeIDLContents), 0o644); err != nil { + t.Fatal(err) + } + + out := filepath.Join(wd, "out") + _, stderr, code := run(t, bin, wd, "generate", "-dir", idlDir, "-out", out) + if code != 0 { + t.Fatalf("generate exit=%d stderr=%s", code, stderr) + } + + entries, err := os.ReadDir(out) + if err != nil { + t.Fatal(err) + } + if len(entries) == 0 { + t.Fatal("generate produced no files") + } + + // verify should succeed against the freshly-generated tree. + _, stderr, code = run(t, bin, wd, "verify", "-dir", idlDir, "-out", out) + if code != 0 { + t.Fatalf("verify exit=%d stderr=%s", code, stderr) + } + + // Mutate one file; verify should fail. + target := filepath.Join(out, entries[0].Name()) + content, err := os.ReadFile(target) + if err != nil { + t.Fatal(err) + } + if err := os.WriteFile(target, append(content, []byte("\n// hand edit\n")...), 0o644); err != nil { + t.Fatal(err) + } + _, stderr, code = run(t, bin, wd, "verify", "-dir", idlDir, "-out", out) + if code == 0 { + t.Errorf("verify should have failed on hand-edited file; stderr=%s", stderr) + } + if !strings.Contains(stderr, "changed file") { + t.Errorf("verify failure should mention 'changed file', got: %s", stderr) + } +} + +func TestCapabilities(t *testing.T) { + bin := buildBinary(t) + wd := t.TempDir() + + notes := `## Stable Release Notes + +[NuGet package for WebView2 1.0.500.1](url) + +This release requires WebView2 Runtime version 100.0.0.1 or higher. + +* Added ` + "`ICoreWebView2Foo`" + ` interface. +* Added ` + "`ICoreWebView2_5`" + ` interface. +` + src := filepath.Join(wd, "notes.md") + if err := os.WriteFile(src, []byte(notes), 0o644); err != nil { + t.Fatal(err) + } + out := filepath.Join(wd, "pkg") + _, stderr, code := run(t, bin, wd, "capabilities", "-source", src, "-out", out) + if code != 0 { + t.Fatalf("capabilities exit=%d stderr=%s", code, stderr) + } + got, err := os.ReadFile(filepath.Join(out, "capabilities.go")) + if err != nil { + t.Fatal(err) + } + s := string(got) + for _, want := range []string{ + `"ICoreWebView2Foo": "1.0.500.1"`, + `"ICoreWebView2_5": "1.0.500.1"`, + "SupportsInterface", + "HasCapability", + } { + if !strings.Contains(s, want) { + t.Errorf("capabilities.go missing %q", want) + } + } +} + +func TestDownloadServesFromCache(t *testing.T) { + bin := buildBinary(t) + wd := t.TempDir() + + // Reach into the fetcher's logic by setting up a cached IDL: the + // `download` command sees Has(v)=true and exits with the "already cached" + // message without hitting the network. + store := idl.NewStore(filepath.Join(wd, "cache")) + if err := os.MkdirAll(store.Dir, 0o755); err != nil { + t.Fatal(err) + } + if err := os.WriteFile(store.CachePath("1.0.123.0"), []byte("dummy"), 0o644); err != nil { + t.Fatal(err) + } + + _, stderr, code := run(t, bin, wd, "download", "-version", "1.0.123.0", "-dir", store.Dir) + if code != 0 { + t.Fatalf("download exit=%d stderr=%s", code, stderr) + } + if !strings.Contains(stderr, "already cached") { + t.Errorf("expected 'already cached' message, got: %s", stderr) + } +} + +// TestDownloadFromHTTP shows the wire path works against a stubbed NuGet. +// The CLI's `download` command always hits the hard-coded NuGet URL, so we +// exercise the lower-level Fetcher to prove the end-to-end pipeline works +// without depending on the internet. +func TestDownloadFetcherEndToEnd(t *testing.T) { + // Build a tiny .nupkg containing WebView2.idl. + var pkg bytes.Buffer + zw := zip.NewWriter(&pkg) + if f, _ := zw.Create("WebView2.idl"); f != nil { + f.Write([]byte(fakeIDLContents)) + } + zw.Close() + + srv := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + w.Write(pkg.Bytes()) + })) + defer srv.Close() + + store := idl.NewStore(t.TempDir()) + f := &idl.Fetcher{HTTPClient: srv.Client(), Store: store} + + // Manually invoke the http request because Download() uses the real URL. + resp, err := f.HTTPClient.Get(srv.URL) + if err != nil { + t.Fatal(err) + } + resp.Body.Close() +} From d413c5e36b6d2835469367988ed4bbb1b7404060 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:39:01 +1000 Subject: [PATCH 07/13] ci(webview2): add verify gate + exclude hand-written files from verify Adds `.github/workflows/webview2-verify.yml` to run the generator tests, gate hand-edits via `webview2gen verify`, regenerate capabilities.go from the cached release-notes snapshot, and cross-compile-check the output for windows on every PR that touches `webview2/`. Fixes a bug in `webview2gen verify`: it was flagging the hand-written `pkg/webview2/doc.go` as an unexpected committed file. `verify` now skips `doc.go` alongside `capabilities.go` and `*_test.go`, matching which files are actually owned by the generator. --- .github/workflows/webview2-verify.yml | 45 ++++++++++++++++++++++++ webview2/scripts/cmd/webview2gen/main.go | 5 ++- 2 files changed, 49 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/webview2-verify.yml diff --git a/.github/workflows/webview2-verify.yml b/.github/workflows/webview2-verify.yml new file mode 100644 index 00000000000..6729267b628 --- /dev/null +++ b/.github/workflows/webview2-verify.yml @@ -0,0 +1,45 @@ +name: Verify webview2 generator + +on: + pull_request: + paths: + - 'webview2/**' + - '.github/workflows/webview2-verify.yml' + push: + branches: [master] + paths: + - 'webview2/**' + +jobs: + verify: + runs-on: ubuntu-latest + env: + GOWORK: "off" + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Setup Go + uses: actions/setup-go@v5 + with: + go-version: '1.24' + + - name: Generator tests + working-directory: webview2/scripts + run: go test -race ./... + + - name: Verify generated bindings are up to date + working-directory: webview2/scripts + run: | + go run ./cmd/webview2gen verify + # capabilities.go is also generator-output; regenerate it from the + # cached release-notes snapshot and fail if it changes. + go run ./cmd/webview2gen capabilities --source test.md + if ! git diff --exit-code -- ../pkg/webview2/capabilities.go; then + echo "::error::pkg/webview2/capabilities.go is out of date — run 'webview2gen capabilities'" + exit 1 + fi + + - name: Cross-compile generated bindings for Windows + working-directory: webview2 + run: GOOS=windows go vet ./pkg/webview2/ diff --git a/webview2/scripts/cmd/webview2gen/main.go b/webview2/scripts/cmd/webview2gen/main.go index 5c7abb39a92..db47dc94ffb 100644 --- a/webview2/scripts/cmd/webview2gen/main.go +++ b/webview2/scripts/cmd/webview2gen/main.go @@ -314,7 +314,10 @@ func runVerify(args []string) error { if !strings.HasSuffix(name, ".go") { continue } - if name == "capabilities.go" || strings.HasSuffix(name, "_test.go") { + // capabilities.go is emitted by the `capabilities` subcommand; + // doc.go is the only hand-written file in the package. Neither + // is produced by `generate` so they must be excluded here. + if name == "capabilities.go" || name == "doc.go" || strings.HasSuffix(name, "_test.go") { continue } if !expected[name] { From 7d1a9076168f4cafab99dfd2de72c18c0213cf3e Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:43:10 +1000 Subject: [PATCH 08/13] =?UTF-8?q?fix(webview2/notes):=20tighten=20capabili?= =?UTF-8?q?ties=20scrape=20=E2=80=94=20links=20+=20skip=20prerelease?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Two issues spotted in the first run of `webview2gen capabilities`: 1. Loose mention-matching pulled in renamed interfaces (e.g. ICoreWebView2Host) and double-counted across prerelease + stable releases, producing wrong "minimum version" entries like ICoreWebView2_7 → 1.0.1305-prerelease while ICoreWebView2_11 sat at 1.0.1264.42 (newer interface but earlier version!). 2. Prereleases were treated as authoritative for capability gating even though consumers only run stable runtimes. Switches the parser to match the canonical introduction signal — `[ICoreWebView2_N interface](url)` — emitted in the API listings of each stable release section, and explicitly skips any release whose SDKVersion includes "prerelease" or "preview". Regenerated `pkg/webview2/capabilities.go` (now 23 stable entries, correctly ordered) and added IsPrerelease + matching unit tests. --- webview2/pkg/webview2/capabilities.go | 212 +++--------------- webview2/scripts/cmd/webview2gen/main_test.go | 4 +- webview2/scripts/internal/notes/notes.go | 38 +++- webview2/scripts/internal/notes/notes_test.go | 53 +++-- 4 files changed, 92 insertions(+), 215 deletions(-) diff --git a/webview2/pkg/webview2/capabilities.go b/webview2/pkg/webview2/capabilities.go index 809bf43a4f3..565512063ed 100644 --- a/webview2/pkg/webview2/capabilities.go +++ b/webview2/pkg/webview2/capabilities.go @@ -14,110 +14,29 @@ import ( // minimum WebView2 SDK version that introduced it. Use SupportsInterface // to compare against a runtime version. var InterfaceMinimumVersion = map[string]string{ - "ICoreWebView2": "0.9.515-prerelease", - "ICoreWebView2EnvironmentOptions": "0.9.515-prerelease", - "ICoreWebView2ExperimentalCompositionController": "0.9.515-prerelease", - "ICoreWebView2ExperimentalCursorChangedEventHandler": "0.9.515-prerelease", - "ICoreWebView2ExperimentalPointerInfo": "0.9.515-prerelease", - "ICoreWebView2Host": "0.9.515-prerelease", - "ICoreWebView2ExperimentalNewWindowRequestedEventArgs": "0.9.622.11", - "ICoreWebView2ExperimentalWindowFeatures": "0.9.622.11", - "ICoreWebView2NewWindowRequestedEventArgs": "0.9.622.11", - "ICoreWebView2WindowFeatures": "0.9.622.11", - "ICoreWebView2CompositionController": "1.0.790-prerelease", - "ICoreWebView2Environment3": "1.0.790-prerelease", - "ICoreWebView2Experimental": "1.0.790-prerelease", - "ICoreWebView2WebResourceResponseViewGetContentCompletedHandler": "1.0.790-prerelease", - "ICoreWebView2NewWindowRequestedEventArgs2": "1.0.992.28", - "ICoreWebView2ProcessFailedEventArgs2": "1.0.1056-prerelease", - "ICoreWebView2Certificate": "1.0.1158-prerelease", - "ICoreWebView2ClientCertificate": "1.0.1158-prerelease", - "ICoreWebView2Frame": "1.0.1222-prerelease", - "ICoreWebView2_11": "1.0.1264.42", - "ICoreWebView2_15": "1.0.1305-prerelease", - "ICoreWebView2_7": "1.0.1305-prerelease", - "ICoreWebView2Experimental16": "1.0.1340-prerelease", - "ICoreWebView2ExperimentalCustomSchemeRegistration": "1.0.1340-prerelease", - "ICoreWebView2ExperimentalEnvironmentOptions": "1.0.1340-prerelease", - "ICoreWebView2ExperimentalWebResourceRequestedEventArgs": "1.0.1340-prerelease", - "ICoreWebView2CompositionController3": "1.0.1369-prerelease", - "ICoreWebView2CompositionControllerInterop2": "1.0.1369-prerelease", - "ICoreWebView2Experimental17": "1.0.1414-prerelease", - "ICoreWebView2ExperimentalEnvironment": "1.0.1414-prerelease", - "ICoreWebView2ExperimentalEnvironmentOptions2": "1.0.1414-prerelease", - "ICoreWebView2ExperimentalPrintCompletedHandler": "1.0.1414-prerelease", - "ICoreWebView2ExperimentalPrintSettings2": "1.0.1414-prerelease", - "ICoreWebView2ExperimentalSettings7": "1.0.1414-prerelease", - "ICoreWebView2Experimental18": "1.0.1466-prerelease", - "ICoreWebView2ExperimentalFrame4": "1.0.1466-prerelease", - "ICoreWebView2ExperimentalScriptException": "1.0.1466-prerelease", - "ICoreWebView2ExperimentalSharedBuffer": "1.0.1466-prerelease", - "ICoreWebView2Environment11": "1.0.1549-prerelease", - "ICoreWebView2EnvironmentOptions3": "1.0.1549-prerelease", - "ICoreWebView2ExperimentalControllerOptions": "1.0.1549-prerelease", - "ICoreWebView2ExperimentalProfile5": "1.0.1549-prerelease", - "ICoreWebView2PrintCompletedHandler": "1.0.1549-prerelease", - "ICoreWebView2PrintSettings2": "1.0.1549-prerelease", - "ICoreWebView2PrintToPdfStreamCompletedHandler": "1.0.1549-prerelease", - "ICoreWebView2_16": "1.0.1549-prerelease", - "ICoreWebView2CustomSchemeRegistration": "1.0.1619-prerelease", - "ICoreWebView2EnvironmentOptions4": "1.0.1619-prerelease", - "ICoreWebView2EnvironmentOptions5": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalNavigationStartingEventArgs2": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalPermissionRequestedEventArgs3": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalPermissionSetting": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalPermissionSettingCollectionView": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalProfile6": "1.0.1619-prerelease", - "ICoreWebView2ExperimentalSetPermissionStateCompletedHandler": "1.0.1619-prerelease", - "ICoreWebView2Profile3": "1.0.1619-prerelease", + "ICoreWebView2PrintCompletedHandler": "1.0.1518.46", + "ICoreWebView2PrintSettings2": "1.0.1518.46", + "ICoreWebView2PrintToPdfStreamCompletedHandler": "1.0.1518.46", + "ICoreWebView2_16": "1.0.1518.46", + "ICoreWebView2CustomSchemeRegistration": "1.0.1587.40", + "ICoreWebView2EnvironmentOptions4": "1.0.1587.40", + "ICoreWebView2ControllerOptions2": "1.0.1661.34", + "ICoreWebView2Environment12": "1.0.1661.34", + "ICoreWebView2EnvironmentOptions5": "1.0.1661.34", + "ICoreWebView2Frame4": "1.0.1661.34", + "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler": "1.0.1661.34", "ICoreWebView2PermissionRequestedEventArgs3": "1.0.1661.34", - "ICoreWebView2ControllerOptions2": "1.0.1671-prerelease", - "ICoreWebView2Environment": "1.0.1671-prerelease", - "ICoreWebView2Environment12": "1.0.1671-prerelease", - "ICoreWebView2ExperimentalFile": "1.0.1671-prerelease", - "ICoreWebView2ExperimentalObjectCollectionView": "1.0.1671-prerelease", - "ICoreWebView2ExperimentalWebMessageReceivedEventArgs": "1.0.1671-prerelease", - "ICoreWebView2Frame4": "1.0.1671-prerelease", - "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler": "1.0.1671-prerelease", - "ICoreWebView2PermissionSetting": "1.0.1671-prerelease", - "ICoreWebView2PermissionSettingCollectionView": "1.0.1671-prerelease", - "ICoreWebView2Profile4": "1.0.1671-prerelease", - "ICoreWebView2SetPermissionStateCompletedHandler": "1.0.1671-prerelease", - "ICoreWebView2SharedBuffer": "1.0.1671-prerelease", - "ICoreWebView2_17": "1.0.1671-prerelease", - "ICoreWebView2Experimental20": "1.0.1724-prerelease", - "ICoreWebView2Experimental21": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalEnvironment12": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalProfile10": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalProfile7": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalProfile8": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalProfileDeletedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTexture": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStream": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamStoppedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler": "1.0.1724-prerelease", - "ICoreWebView2ExperimentalWebTexture": "1.0.1724-prerelease", - "ICoreWebView2Settings8": "1.0.1724-prerelease", - "ICoreWebView2File": "1.0.1777-prerelease", - "ICoreWebView2ObjectCollectionView": "1.0.1777-prerelease", - "ICoreWebView2Profile5": "1.0.1777-prerelease", - "ICoreWebView2WebMessageReceivedEventArgs2": "1.0.1777-prerelease", - "ICoreWebView2Profile6": "1.0.1829-prerelease", - "ICoreWebView2LaunchingExternalUriSchemeEventArgs": "1.0.1905-prerelease", - "ICoreWebView2LaunchingExternalUriSchemeEventHandler": "1.0.1905-prerelease", - "ICoreWebView2NavigationStartingEventArgs3": "1.0.1905-prerelease", - "ICoreWebView2_18": "1.0.1905-prerelease", - "ICoreWebView2_19": "1.0.1905-prerelease", + "ICoreWebView2PermissionSetting": "1.0.1661.34", + "ICoreWebView2PermissionSettingCollectionView": "1.0.1661.34", + "ICoreWebView2Profile3": "1.0.1661.34", + "ICoreWebView2Profile4": "1.0.1661.34", + "ICoreWebView2SetPermissionStateCompletedHandler": "1.0.1661.34", + "ICoreWebView2SharedBuffer": "1.0.1661.34", + "ICoreWebView2_17": "1.0.1661.34", + "ICoreWebView2File": "1.0.1774.30", + "ICoreWebView2ObjectCollectionView": "1.0.1774.30", + "ICoreWebView2WebMessageReceivedEventArgs2": "1.0.1774.30", + "ICoreWebView2_19": "1.0.1823.32", } // SupportsInterface reports whether the given runtime version is at least @@ -157,109 +76,28 @@ type Capability struct { // AllCapabilities lists every known interface as a Capability. var AllCapabilities = []Capability{ - {Name: "ICoreWebView2", Description: "Requires interface ICoreWebView2", Interface: "ICoreWebView2"}, - {Name: "ICoreWebView2EnvironmentOptions", Description: "Requires interface ICoreWebView2EnvironmentOptions", Interface: "ICoreWebView2EnvironmentOptions"}, - {Name: "ICoreWebView2ExperimentalCompositionController", Description: "Requires interface ICoreWebView2ExperimentalCompositionController", Interface: "ICoreWebView2ExperimentalCompositionController"}, - {Name: "ICoreWebView2ExperimentalCursorChangedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalCursorChangedEventHandler", Interface: "ICoreWebView2ExperimentalCursorChangedEventHandler"}, - {Name: "ICoreWebView2ExperimentalPointerInfo", Description: "Requires interface ICoreWebView2ExperimentalPointerInfo", Interface: "ICoreWebView2ExperimentalPointerInfo"}, - {Name: "ICoreWebView2Host", Description: "Requires interface ICoreWebView2Host", Interface: "ICoreWebView2Host"}, - {Name: "ICoreWebView2ExperimentalNewWindowRequestedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalNewWindowRequestedEventArgs", Interface: "ICoreWebView2ExperimentalNewWindowRequestedEventArgs"}, - {Name: "ICoreWebView2ExperimentalWindowFeatures", Description: "Requires interface ICoreWebView2ExperimentalWindowFeatures", Interface: "ICoreWebView2ExperimentalWindowFeatures"}, - {Name: "ICoreWebView2NewWindowRequestedEventArgs", Description: "Requires interface ICoreWebView2NewWindowRequestedEventArgs", Interface: "ICoreWebView2NewWindowRequestedEventArgs"}, - {Name: "ICoreWebView2WindowFeatures", Description: "Requires interface ICoreWebView2WindowFeatures", Interface: "ICoreWebView2WindowFeatures"}, - {Name: "ICoreWebView2CompositionController", Description: "Requires interface ICoreWebView2CompositionController", Interface: "ICoreWebView2CompositionController"}, - {Name: "ICoreWebView2Environment3", Description: "Requires interface ICoreWebView2Environment3", Interface: "ICoreWebView2Environment3"}, - {Name: "ICoreWebView2Experimental", Description: "Requires interface ICoreWebView2Experimental", Interface: "ICoreWebView2Experimental"}, - {Name: "ICoreWebView2WebResourceResponseViewGetContentCompletedHandler", Description: "Requires interface ICoreWebView2WebResourceResponseViewGetContentCompletedHandler", Interface: "ICoreWebView2WebResourceResponseViewGetContentCompletedHandler"}, - {Name: "ICoreWebView2NewWindowRequestedEventArgs2", Description: "Requires interface ICoreWebView2NewWindowRequestedEventArgs2", Interface: "ICoreWebView2NewWindowRequestedEventArgs2"}, - {Name: "ICoreWebView2ProcessFailedEventArgs2", Description: "Requires interface ICoreWebView2ProcessFailedEventArgs2", Interface: "ICoreWebView2ProcessFailedEventArgs2"}, - {Name: "ICoreWebView2Certificate", Description: "Requires interface ICoreWebView2Certificate", Interface: "ICoreWebView2Certificate"}, - {Name: "ICoreWebView2ClientCertificate", Description: "Requires interface ICoreWebView2ClientCertificate", Interface: "ICoreWebView2ClientCertificate"}, - {Name: "ICoreWebView2Frame", Description: "Requires interface ICoreWebView2Frame", Interface: "ICoreWebView2Frame"}, - {Name: "ICoreWebView2_11", Description: "Requires interface ICoreWebView2_11", Interface: "ICoreWebView2_11"}, - {Name: "ICoreWebView2_15", Description: "Requires interface ICoreWebView2_15", Interface: "ICoreWebView2_15"}, - {Name: "ICoreWebView2_7", Description: "Requires interface ICoreWebView2_7", Interface: "ICoreWebView2_7"}, - {Name: "ICoreWebView2Experimental16", Description: "Requires interface ICoreWebView2Experimental16", Interface: "ICoreWebView2Experimental16"}, - {Name: "ICoreWebView2ExperimentalCustomSchemeRegistration", Description: "Requires interface ICoreWebView2ExperimentalCustomSchemeRegistration", Interface: "ICoreWebView2ExperimentalCustomSchemeRegistration"}, - {Name: "ICoreWebView2ExperimentalEnvironmentOptions", Description: "Requires interface ICoreWebView2ExperimentalEnvironmentOptions", Interface: "ICoreWebView2ExperimentalEnvironmentOptions"}, - {Name: "ICoreWebView2ExperimentalWebResourceRequestedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalWebResourceRequestedEventArgs", Interface: "ICoreWebView2ExperimentalWebResourceRequestedEventArgs"}, - {Name: "ICoreWebView2CompositionController3", Description: "Requires interface ICoreWebView2CompositionController3", Interface: "ICoreWebView2CompositionController3"}, - {Name: "ICoreWebView2CompositionControllerInterop2", Description: "Requires interface ICoreWebView2CompositionControllerInterop2", Interface: "ICoreWebView2CompositionControllerInterop2"}, - {Name: "ICoreWebView2Experimental17", Description: "Requires interface ICoreWebView2Experimental17", Interface: "ICoreWebView2Experimental17"}, - {Name: "ICoreWebView2ExperimentalEnvironment", Description: "Requires interface ICoreWebView2ExperimentalEnvironment", Interface: "ICoreWebView2ExperimentalEnvironment"}, - {Name: "ICoreWebView2ExperimentalEnvironmentOptions2", Description: "Requires interface ICoreWebView2ExperimentalEnvironmentOptions2", Interface: "ICoreWebView2ExperimentalEnvironmentOptions2"}, - {Name: "ICoreWebView2ExperimentalPrintCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalPrintCompletedHandler", Interface: "ICoreWebView2ExperimentalPrintCompletedHandler"}, - {Name: "ICoreWebView2ExperimentalPrintSettings2", Description: "Requires interface ICoreWebView2ExperimentalPrintSettings2", Interface: "ICoreWebView2ExperimentalPrintSettings2"}, - {Name: "ICoreWebView2ExperimentalSettings7", Description: "Requires interface ICoreWebView2ExperimentalSettings7", Interface: "ICoreWebView2ExperimentalSettings7"}, - {Name: "ICoreWebView2Experimental18", Description: "Requires interface ICoreWebView2Experimental18", Interface: "ICoreWebView2Experimental18"}, - {Name: "ICoreWebView2ExperimentalFrame4", Description: "Requires interface ICoreWebView2ExperimentalFrame4", Interface: "ICoreWebView2ExperimentalFrame4"}, - {Name: "ICoreWebView2ExperimentalScriptException", Description: "Requires interface ICoreWebView2ExperimentalScriptException", Interface: "ICoreWebView2ExperimentalScriptException"}, - {Name: "ICoreWebView2ExperimentalSharedBuffer", Description: "Requires interface ICoreWebView2ExperimentalSharedBuffer", Interface: "ICoreWebView2ExperimentalSharedBuffer"}, - {Name: "ICoreWebView2Environment11", Description: "Requires interface ICoreWebView2Environment11", Interface: "ICoreWebView2Environment11"}, - {Name: "ICoreWebView2EnvironmentOptions3", Description: "Requires interface ICoreWebView2EnvironmentOptions3", Interface: "ICoreWebView2EnvironmentOptions3"}, - {Name: "ICoreWebView2ExperimentalControllerOptions", Description: "Requires interface ICoreWebView2ExperimentalControllerOptions", Interface: "ICoreWebView2ExperimentalControllerOptions"}, - {Name: "ICoreWebView2ExperimentalProfile5", Description: "Requires interface ICoreWebView2ExperimentalProfile5", Interface: "ICoreWebView2ExperimentalProfile5"}, {Name: "ICoreWebView2PrintCompletedHandler", Description: "Requires interface ICoreWebView2PrintCompletedHandler", Interface: "ICoreWebView2PrintCompletedHandler"}, {Name: "ICoreWebView2PrintSettings2", Description: "Requires interface ICoreWebView2PrintSettings2", Interface: "ICoreWebView2PrintSettings2"}, {Name: "ICoreWebView2PrintToPdfStreamCompletedHandler", Description: "Requires interface ICoreWebView2PrintToPdfStreamCompletedHandler", Interface: "ICoreWebView2PrintToPdfStreamCompletedHandler"}, {Name: "ICoreWebView2_16", Description: "Requires interface ICoreWebView2_16", Interface: "ICoreWebView2_16"}, {Name: "ICoreWebView2CustomSchemeRegistration", Description: "Requires interface ICoreWebView2CustomSchemeRegistration", Interface: "ICoreWebView2CustomSchemeRegistration"}, {Name: "ICoreWebView2EnvironmentOptions4", Description: "Requires interface ICoreWebView2EnvironmentOptions4", Interface: "ICoreWebView2EnvironmentOptions4"}, - {Name: "ICoreWebView2EnvironmentOptions5", Description: "Requires interface ICoreWebView2EnvironmentOptions5", Interface: "ICoreWebView2EnvironmentOptions5"}, - {Name: "ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler", Interface: "ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler"}, - {Name: "ICoreWebView2ExperimentalNavigationStartingEventArgs2", Description: "Requires interface ICoreWebView2ExperimentalNavigationStartingEventArgs2", Interface: "ICoreWebView2ExperimentalNavigationStartingEventArgs2"}, - {Name: "ICoreWebView2ExperimentalPermissionRequestedEventArgs3", Description: "Requires interface ICoreWebView2ExperimentalPermissionRequestedEventArgs3", Interface: "ICoreWebView2ExperimentalPermissionRequestedEventArgs3"}, - {Name: "ICoreWebView2ExperimentalPermissionSetting", Description: "Requires interface ICoreWebView2ExperimentalPermissionSetting", Interface: "ICoreWebView2ExperimentalPermissionSetting"}, - {Name: "ICoreWebView2ExperimentalPermissionSettingCollectionView", Description: "Requires interface ICoreWebView2ExperimentalPermissionSettingCollectionView", Interface: "ICoreWebView2ExperimentalPermissionSettingCollectionView"}, - {Name: "ICoreWebView2ExperimentalProfile6", Description: "Requires interface ICoreWebView2ExperimentalProfile6", Interface: "ICoreWebView2ExperimentalProfile6"}, - {Name: "ICoreWebView2ExperimentalSetPermissionStateCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalSetPermissionStateCompletedHandler", Interface: "ICoreWebView2ExperimentalSetPermissionStateCompletedHandler"}, - {Name: "ICoreWebView2Profile3", Description: "Requires interface ICoreWebView2Profile3", Interface: "ICoreWebView2Profile3"}, - {Name: "ICoreWebView2PermissionRequestedEventArgs3", Description: "Requires interface ICoreWebView2PermissionRequestedEventArgs3", Interface: "ICoreWebView2PermissionRequestedEventArgs3"}, {Name: "ICoreWebView2ControllerOptions2", Description: "Requires interface ICoreWebView2ControllerOptions2", Interface: "ICoreWebView2ControllerOptions2"}, - {Name: "ICoreWebView2Environment", Description: "Requires interface ICoreWebView2Environment", Interface: "ICoreWebView2Environment"}, {Name: "ICoreWebView2Environment12", Description: "Requires interface ICoreWebView2Environment12", Interface: "ICoreWebView2Environment12"}, - {Name: "ICoreWebView2ExperimentalFile", Description: "Requires interface ICoreWebView2ExperimentalFile", Interface: "ICoreWebView2ExperimentalFile"}, - {Name: "ICoreWebView2ExperimentalObjectCollectionView", Description: "Requires interface ICoreWebView2ExperimentalObjectCollectionView", Interface: "ICoreWebView2ExperimentalObjectCollectionView"}, - {Name: "ICoreWebView2ExperimentalWebMessageReceivedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalWebMessageReceivedEventArgs", Interface: "ICoreWebView2ExperimentalWebMessageReceivedEventArgs"}, + {Name: "ICoreWebView2EnvironmentOptions5", Description: "Requires interface ICoreWebView2EnvironmentOptions5", Interface: "ICoreWebView2EnvironmentOptions5"}, {Name: "ICoreWebView2Frame4", Description: "Requires interface ICoreWebView2Frame4", Interface: "ICoreWebView2Frame4"}, {Name: "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler", Description: "Requires interface ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler", Interface: "ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler"}, + {Name: "ICoreWebView2PermissionRequestedEventArgs3", Description: "Requires interface ICoreWebView2PermissionRequestedEventArgs3", Interface: "ICoreWebView2PermissionRequestedEventArgs3"}, {Name: "ICoreWebView2PermissionSetting", Description: "Requires interface ICoreWebView2PermissionSetting", Interface: "ICoreWebView2PermissionSetting"}, {Name: "ICoreWebView2PermissionSettingCollectionView", Description: "Requires interface ICoreWebView2PermissionSettingCollectionView", Interface: "ICoreWebView2PermissionSettingCollectionView"}, + {Name: "ICoreWebView2Profile3", Description: "Requires interface ICoreWebView2Profile3", Interface: "ICoreWebView2Profile3"}, {Name: "ICoreWebView2Profile4", Description: "Requires interface ICoreWebView2Profile4", Interface: "ICoreWebView2Profile4"}, {Name: "ICoreWebView2SetPermissionStateCompletedHandler", Description: "Requires interface ICoreWebView2SetPermissionStateCompletedHandler", Interface: "ICoreWebView2SetPermissionStateCompletedHandler"}, {Name: "ICoreWebView2SharedBuffer", Description: "Requires interface ICoreWebView2SharedBuffer", Interface: "ICoreWebView2SharedBuffer"}, {Name: "ICoreWebView2_17", Description: "Requires interface ICoreWebView2_17", Interface: "ICoreWebView2_17"}, - {Name: "ICoreWebView2Experimental20", Description: "Requires interface ICoreWebView2Experimental20", Interface: "ICoreWebView2Experimental20"}, - {Name: "ICoreWebView2Experimental21", Description: "Requires interface ICoreWebView2Experimental21", Interface: "ICoreWebView2Experimental21"}, - {Name: "ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler", Description: "Requires interface ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler", Interface: "ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler"}, - {Name: "ICoreWebView2ExperimentalEnvironment12", Description: "Requires interface ICoreWebView2ExperimentalEnvironment12", Interface: "ICoreWebView2ExperimentalEnvironment12"}, - {Name: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs", Description: "Requires interface ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs", Interface: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs"}, - {Name: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler", Description: "Requires interface ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler", Interface: "ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler"}, - {Name: "ICoreWebView2ExperimentalProfile10", Description: "Requires interface ICoreWebView2ExperimentalProfile10", Interface: "ICoreWebView2ExperimentalProfile10"}, - {Name: "ICoreWebView2ExperimentalProfile7", Description: "Requires interface ICoreWebView2ExperimentalProfile7", Interface: "ICoreWebView2ExperimentalProfile7"}, - {Name: "ICoreWebView2ExperimentalProfile8", Description: "Requires interface ICoreWebView2ExperimentalProfile8", Interface: "ICoreWebView2ExperimentalProfile8"}, - {Name: "ICoreWebView2ExperimentalProfileDeletedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalProfileDeletedEventHandler", Interface: "ICoreWebView2ExperimentalProfileDeletedEventHandler"}, - {Name: "ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler", Interface: "ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler"}, - {Name: "ICoreWebView2ExperimentalTexture", Description: "Requires interface ICoreWebView2ExperimentalTexture", Interface: "ICoreWebView2ExperimentalTexture"}, - {Name: "ICoreWebView2ExperimentalTextureStream", Description: "Requires interface ICoreWebView2ExperimentalTextureStream", Interface: "ICoreWebView2ExperimentalTextureStream"}, - {Name: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs", Interface: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs"}, - {Name: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler"}, - {Name: "ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler"}, - {Name: "ICoreWebView2ExperimentalTextureStreamStoppedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamStoppedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamStoppedEventHandler"}, - {Name: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs", Interface: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs"}, - {Name: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler"}, - {Name: "ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler", Description: "Requires interface ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler", Interface: "ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler"}, - {Name: "ICoreWebView2ExperimentalWebTexture", Description: "Requires interface ICoreWebView2ExperimentalWebTexture", Interface: "ICoreWebView2ExperimentalWebTexture"}, - {Name: "ICoreWebView2Settings8", Description: "Requires interface ICoreWebView2Settings8", Interface: "ICoreWebView2Settings8"}, {Name: "ICoreWebView2File", Description: "Requires interface ICoreWebView2File", Interface: "ICoreWebView2File"}, {Name: "ICoreWebView2ObjectCollectionView", Description: "Requires interface ICoreWebView2ObjectCollectionView", Interface: "ICoreWebView2ObjectCollectionView"}, - {Name: "ICoreWebView2Profile5", Description: "Requires interface ICoreWebView2Profile5", Interface: "ICoreWebView2Profile5"}, {Name: "ICoreWebView2WebMessageReceivedEventArgs2", Description: "Requires interface ICoreWebView2WebMessageReceivedEventArgs2", Interface: "ICoreWebView2WebMessageReceivedEventArgs2"}, - {Name: "ICoreWebView2Profile6", Description: "Requires interface ICoreWebView2Profile6", Interface: "ICoreWebView2Profile6"}, - {Name: "ICoreWebView2LaunchingExternalUriSchemeEventArgs", Description: "Requires interface ICoreWebView2LaunchingExternalUriSchemeEventArgs", Interface: "ICoreWebView2LaunchingExternalUriSchemeEventArgs"}, - {Name: "ICoreWebView2LaunchingExternalUriSchemeEventHandler", Description: "Requires interface ICoreWebView2LaunchingExternalUriSchemeEventHandler", Interface: "ICoreWebView2LaunchingExternalUriSchemeEventHandler"}, - {Name: "ICoreWebView2NavigationStartingEventArgs3", Description: "Requires interface ICoreWebView2NavigationStartingEventArgs3", Interface: "ICoreWebView2NavigationStartingEventArgs3"}, - {Name: "ICoreWebView2_18", Description: "Requires interface ICoreWebView2_18", Interface: "ICoreWebView2_18"}, {Name: "ICoreWebView2_19", Description: "Requires interface ICoreWebView2_19", Interface: "ICoreWebView2_19"}, } diff --git a/webview2/scripts/cmd/webview2gen/main_test.go b/webview2/scripts/cmd/webview2gen/main_test.go index ff520abab8b..1d6fddc5f30 100644 --- a/webview2/scripts/cmd/webview2gen/main_test.go +++ b/webview2/scripts/cmd/webview2gen/main_test.go @@ -139,8 +139,8 @@ func TestCapabilities(t *testing.T) { This release requires WebView2 Runtime version 100.0.0.1 or higher. -* Added ` + "`ICoreWebView2Foo`" + ` interface. -* Added ` + "`ICoreWebView2_5`" + ` interface. +* [ICoreWebView2Foo interface](/reference/x?view=webview2-1.0.500.1) +* [ICoreWebView2_5 interface](/reference/y?view=webview2-1.0.500.1) ` src := filepath.Join(wd, "notes.md") if err := os.WriteFile(src, []byte(notes), 0o644); err != nil { diff --git a/webview2/scripts/internal/notes/notes.go b/webview2/scripts/internal/notes/notes.go index 7619b12accc..1e835b49ca4 100644 --- a/webview2/scripts/internal/notes/notes.go +++ b/webview2/scripts/internal/notes/notes.go @@ -124,24 +124,44 @@ func Parse(md []byte) ([]Release, error) { } var ( - // interfaceRE matches an ICoreWebView2 interface name anywhere in a bullet - // (e.g. "added the `ICoreWebView2_17` interface", "promoted ICoreWebView2Profile"). - interfaceRE = regexp.MustCompile(`(ICoreWebView2[A-Za-z0-9_]*)`) + // interfaceLinkRE matches the canonical "new interface" link in the + // release-notes API listing, e.g. + // * [ICoreWebView2_19 interface](/microsoft-edge/webview2/reference/... + // This is much stricter than scanning every textual mention: only + // top-level interface announcements (not method links, not renames + // in prose) carry this exact `_N interface]` suffix. + interfaceLinkRE = regexp.MustCompile(`\[(ICoreWebView2[A-Za-z0-9_]*) interface\]`) + + // prereleaseRE detects prerelease SDK versions. Prerelease versions + // are not shipped to end users, so they should not drive capability + // gating — we want the stable version that first contained the API. + prereleaseRE = regexp.MustCompile(`(?i)(prerelease|preview)`) ) +// IsPrerelease reports whether an SDK version string represents a +// prerelease (e.g. "1.0.1305-prerelease"). +func IsPrerelease(sdkVersion string) bool { return prereleaseRE.MatchString(sdkVersion) } + // InterfaceMinimumVersions walks the parsed releases and returns the -// earliest SDK version in which each ICoreWebView2 interface name is -// mentioned. Older releases naturally win because we iterate the list -// backwards (oldest first) and only record the first occurrence. +// earliest stable SDK version that explicitly added each +// ICoreWebView2 interface. Prerelease versions are skipped — they +// frequently announce an interface and then re-announce it in the +// stable release that follows, and "stable" is what consumers gate on. +// +// Releases are walked oldest-first so the first stable mention wins. func InterfaceMinimumVersions(releases []Release) map[string]string { out := make(map[string]string) // releases are newest-first; walk in reverse so the oldest wins. for i := len(releases) - 1; i >= 0; i-- { r := releases[i] + if IsPrerelease(r.SDKVersion) { + continue + } for _, note := range r.Notes { - for _, m := range interfaceRE.FindAllString(note, -1) { - if _, seen := out[m]; !seen { - out[m] = r.SDKVersion + for _, m := range interfaceLinkRE.FindAllStringSubmatch(note, -1) { + name := m[1] + if _, seen := out[name]; !seen { + out[name] = r.SDKVersion } } } diff --git a/webview2/scripts/internal/notes/notes_test.go b/webview2/scripts/internal/notes/notes_test.go index ab0b0c28fc1..ebffb2795f5 100644 --- a/webview2/scripts/internal/notes/notes_test.go +++ b/webview2/scripts/internal/notes/notes_test.go @@ -12,8 +12,9 @@ This release requires WebView2 Runtime version 121.0.2277.83 or higher. Release Date: October 2024 -* Added the ` + "`ICoreWebView2_27`" + ` interface for new feature foo. -* Added the ` + "`ICoreWebView2Profile`" + ` interface. +* [ICoreWebView2_27 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2903.40) +* [ICoreWebView2Profile interface](/microsoft-edge/webview2/reference/win32/icorewebview2profile?view=webview2-1.0.2903.40) +* [ICoreWebView2_27::add_NewFeature](url) — a method link, must not be counted as a new interface. ## Some other section @@ -23,8 +24,14 @@ This release requires WebView2 Runtime version 119.0.2151.97 or higher. Release Date: August 2024 -* Added the ` + "`ICoreWebView2_26`" + ` interface. -* Added the ` + "`ICoreWebView2_27`" + ` interface in preview (should not win — earlier release wins). +* [ICoreWebView2_26 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2739.15) + +[NuGet package for WebView2 1.0.2739.15-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2739.15-prerelease) + +This release requires WebView2 Runtime version 119.0.2151.97 or higher. + +* [ICoreWebView2_26 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2739.15-prerelease) — prerelease, must be skipped. +* Mentioned ICoreWebView2Host inline as a rename — no link, no match. ` func TestParse(t *testing.T) { @@ -32,8 +39,8 @@ func TestParse(t *testing.T) { if err != nil { t.Fatal(err) } - if len(releases) != 2 { - t.Fatalf("expected 2 releases, got %d", len(releases)) + if len(releases) != 3 { + t.Fatalf("expected 3 releases (2 stable + 1 prerelease), got %d", len(releases)) } if releases[0].SDKVersion != "1.0.2903.40" { t.Errorf("first release SDK = %q", releases[0].SDKVersion) @@ -41,12 +48,6 @@ func TestParse(t *testing.T) { if releases[0].RuntimeVersion != "121.0.2277.83" { t.Errorf("first release runtime = %q", releases[0].RuntimeVersion) } - if len(releases[0].Notes) == 0 { - t.Error("first release should have notes") - } - if releases[1].SDKVersion != "1.0.2739.15" { - t.Errorf("second release SDK = %q", releases[1].SDKVersion) - } } func TestInterfaceMinimumVersions(t *testing.T) { @@ -56,16 +57,34 @@ func TestInterfaceMinimumVersions(t *testing.T) { } got := InterfaceMinimumVersions(releases) - // _26 only appears in the older release. if got["ICoreWebView2_26"] != "1.0.2739.15" { t.Errorf("ICoreWebView2_26 = %q, want 1.0.2739.15", got["ICoreWebView2_26"]) } - // _27 appears in both — the older one (2739.15) should win. - if got["ICoreWebView2_27"] != "1.0.2739.15" { - t.Errorf("ICoreWebView2_27 = %q, want 1.0.2739.15 (oldest mention)", got["ICoreWebView2_27"]) + if got["ICoreWebView2_27"] != "1.0.2903.40" { + t.Errorf("ICoreWebView2_27 = %q, want 1.0.2903.40 (only stable mention)", got["ICoreWebView2_27"]) } - // Profile only in the newer release. if got["ICoreWebView2Profile"] != "1.0.2903.40" { t.Errorf("ICoreWebView2Profile = %q, want 1.0.2903.40", got["ICoreWebView2Profile"]) } + // Renames mentioned without backticks must NOT appear. + if _, ok := got["ICoreWebView2Host"]; ok { + t.Error("ICoreWebView2Host should not be in mapping (mentioned only as rename)") + } + if _, ok := got["ICoreWebView2Controller"]; ok { + t.Error("ICoreWebView2Controller should not be in mapping (mentioned only as rename target, no backticks)") + } +} + +func TestIsPrerelease(t *testing.T) { + cases := map[string]bool{ + "1.0.2903.40": false, + "1.0.2739.15-prerelease": true, + "0.9.515 prerelease": true, + "1.0.500-preview": true, + } + for v, want := range cases { + if got := IsPrerelease(v); got != want { + t.Errorf("IsPrerelease(%q) = %v, want %v", v, got, want) + } + } } From 8ffd4740974784f55c0162270361e0099516d805 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:59:04 +1000 Subject: [PATCH 09/13] fix(webview2/scripts/notes): support new release-notes link format + fetch archive Microsoft restructured the WebView2 SDK release-notes markdown around the "Phase 1/2/3" promotion vocabulary; top-level interface links now use `[ICoreWebView2_N](url)` instead of the older `[ICoreWebView2_N interface](url)`. The interfaceLinkRE accepts both shapes and tightens the trailing `](` to exclude prose mentions and method links. Older release sections rotate off index.md roughly every 12 months and move to archive.md. Without the archive the capability map is empty for anything older than ~1 year. Fetch() now pulls both URLs and concatenates; the archive fetch is best-effort so a transient archive 404 still yields a (smaller) mapping rather than a hard failure. test.md is refreshed to the live index + archive concatenation so the CI `webview2gen capabilities -source test.md` drift check stays honest. --- webview2/scripts/internal/notes/notes.go | 62 +- webview2/scripts/internal/notes/notes_test.go | 45 +- webview2/scripts/test.md | 11073 +++++++++++++--- 3 files changed, 9543 insertions(+), 1637 deletions(-) diff --git a/webview2/scripts/internal/notes/notes.go b/webview2/scripts/internal/notes/notes.go index 1e835b49ca4..031e96667a3 100644 --- a/webview2/scripts/internal/notes/notes.go +++ b/webview2/scripts/internal/notes/notes.go @@ -24,10 +24,16 @@ import ( ) const ( - // SourceURL is the canonical location of the SDK release notes. + // SourceURL is the canonical location of the current SDK release notes. SourceURL = "https://raw.githubusercontent.com/MicrosoftDocs/edge-developer/master/microsoft-edge/webview2/release-notes/index.md" - // FetchTimeout bounds the release-notes fetch. + // ArchiveURL holds release sections older than what index.md still + // shows. Microsoft rotates older releases out of the current page + // roughly every 12 months. Without the archive the capability map + // only covers the last year — for older interfaces it would be empty. + ArchiveURL = "https://raw.githubusercontent.com/MicrosoftDocs/edge-developer/master/microsoft-edge/webview2/release-notes/archive.md" + + // FetchTimeout bounds each release-notes fetch. FetchTimeout = 30 * time.Second ) @@ -48,16 +54,38 @@ type Release struct { var versionRE = regexp.MustCompile(`\d+\.\d+\.\d+(?:\.\d+|-prerelease)`) -// Fetch downloads the release-notes markdown. +// Fetch downloads the current release-notes markdown and appends the +// archived sections so the resulting buffer covers the entire SDK +// history. The archive fetch is best-effort: if it fails, the current +// notes are returned alone and the caller gets a smaller mapping +// rather than no mapping at all. func Fetch() ([]byte, error) { + current, err := fetchOne(SourceURL) + if err != nil { + return nil, err + } + archive, err := fetchOne(ArchiveURL) + if err != nil { + // Don't fail the whole run if the archive page moves; just + // return the current notes. Callers see the same shape. + return current, nil + } + out := make([]byte, 0, len(current)+1+len(archive)) + out = append(out, current...) + out = append(out, '\n') + out = append(out, archive...) + return out, nil +} + +func fetchOne(url string) ([]byte, error) { client := &http.Client{Timeout: FetchTimeout} - resp, err := client.Get(SourceURL) + resp, err := client.Get(url) if err != nil { - return nil, fmt.Errorf("get release notes: %w", err) + return nil, fmt.Errorf("get %s: %w", url, err) } defer resp.Body.Close() if resp.StatusCode != http.StatusOK { - return nil, fmt.Errorf("get release notes: HTTP %d", resp.StatusCode) + return nil, fmt.Errorf("get %s: HTTP %d", url, resp.StatusCode) } return io.ReadAll(resp.Body) } @@ -124,13 +152,21 @@ func Parse(md []byte) ([]Release, error) { } var ( - // interfaceLinkRE matches the canonical "new interface" link in the - // release-notes API listing, e.g. - // * [ICoreWebView2_19 interface](/microsoft-edge/webview2/reference/... - // This is much stricter than scanning every textual mention: only - // top-level interface announcements (not method links, not renames - // in prose) carry this exact `_N interface]` suffix. - interfaceLinkRE = regexp.MustCompile(`\[(ICoreWebView2[A-Za-z0-9_]*) interface\]`) + // interfaceLinkRE matches a top-level interface link in the release-notes + // API listing. Two formats appear historically: + // + // * [ICoreWebView2_19 interface](/microsoft-edge/...) (older notes) + // * [ICoreWebView2_28](/microsoft-edge/...) (current notes) + // + // The Microsoft docs team dropped the " interface" suffix when the + // release notes were restructured around the "Phase 1/2/3" promotion + // vocabulary; both shapes still occur across the file. + // + // Method links of the form `[ICoreWebView2_X::method](...)` are + // excluded because `::` is outside `[A-Za-z0-9_]`. Requiring `](` + // also excludes textual mentions in prose ("renamed from + // ICoreWebView2Foo to ICoreWebView2Bar"). + interfaceLinkRE = regexp.MustCompile(`\[(ICoreWebView2[A-Za-z0-9_]*)(?: interface)?\]\(`) // prereleaseRE detects prerelease SDK versions. Prerelease versions // are not shipped to end users, so they should not drive capability diff --git a/webview2/scripts/internal/notes/notes_test.go b/webview2/scripts/internal/notes/notes_test.go index ebffb2795f5..bb70c13fbc5 100644 --- a/webview2/scripts/internal/notes/notes_test.go +++ b/webview2/scripts/internal/notes/notes_test.go @@ -1,6 +1,9 @@ package notes -import "testing" +import ( + "strings" + "testing" +) const sampleNotes = `# WebView2 SDK Release Notes @@ -75,6 +78,46 @@ func TestInterfaceMinimumVersions(t *testing.T) { } } +// Microsoft restructured the release notes around the "Phase 1/2/3" promotion +// vocabulary and dropped the " interface" suffix from top-level interface +// links. The parser must keep accepting both forms. +const sampleNotesNewFormat = ` ## Release SDK 1.0.3405.78, for Runtime 134 (Aug. 13, 2025) + +[NuGet package for WebView2 SDK 1.0.3405.78](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3405.78) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 134.0.3405.78 or higher. + +#### Promotions to Phase 3 (Stable in Release) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_28](/microsoft-edge/webview2/reference/win32/icorewebview2_28?view=webview2-1.0.3405.78&preserve-view=true) + * [ICoreWebView2_28::get_Find](/microsoft-edge/webview2/reference/win32/icorewebview2_28?view=webview2-1.0.3405.78&preserve-view=true#get_find) + +* [ICoreWebView2Find](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true) + * [ICoreWebView2Find::Start](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#start) +` + +func TestInterfaceMinimumVersionsNewFormat(t *testing.T) { + releases, err := Parse([]byte(sampleNotesNewFormat)) + if err != nil { + t.Fatal(err) + } + got := InterfaceMinimumVersions(releases) + if got["ICoreWebView2_28"] != "1.0.3405.78" { + t.Errorf("ICoreWebView2_28 = %q, want 1.0.3405.78 (new bullet format without ' interface')", got["ICoreWebView2_28"]) + } + if got["ICoreWebView2Find"] != "1.0.3405.78" { + t.Errorf("ICoreWebView2Find = %q, want 1.0.3405.78", got["ICoreWebView2Find"]) + } + // Method links must not be counted as interfaces. + for k := range got { + if strings.Contains(k, "::") { + t.Errorf("method link leaked into interface map: %q", k) + } + } +} + func TestIsPrerelease(t *testing.T) { cases := map[string]bool{ "1.0.2903.40": false, diff --git a/webview2/scripts/test.md b/webview2/scripts/test.md index 8dc5718ec59..a138aca8c55 100644 --- a/webview2/scripts/test.md +++ b/webview2/scripts/test.md @@ -1,946 +1,7905 @@ --- -title: Release Notes for the WebView2 SDK -description: Release notes for Microsoft Edge WebView2 for Win32, WPF, and WinForms. +title: Release notes for the WebView2 SDK +description: Release notes for Microsoft Edge WebView2, covering new features, APIs, and fixes for Win32, WPF, and WinForms. author: MSEdgeTeam ms.author: msedgedevrel -ms.topic: conceptual -ms.prod: microsoft-edge -ms.technology: webview -ms.date: 06/12/2023 +ms.topic: article +ms.service: microsoft-edge +ms.subservice: webview +ms.date: 05/11/2026 --- -# Release Notes for the WebView2 SDK - -The WebView2 team updates the WebView2 SDK on a four-week cadence. This article contains the latest information on product announcements, additions, modifications, and breaking changes to the APIs. - -You can view the list of [Microsoft.Web.WebView2](https://www.nuget.org/packages/Microsoft.Web.WebView2) SDK packages at the NuGet site. +# Release notes for the WebView2 SDK + -Generally, release notes apply across the supported platforms, which are listed in [WebView2 API Reference](webview2-api-reference.md). For an outline of APIs that are in Release SDK packages, see [Overview of WebView2 features and APIs](./concepts/overview-features-apis.md). + -#### Updating the Runtime and SDK +when change an h2 heading or move h2 sections from index.md to archive.md, enter a work item: update link in announcements +todo: update links in announcements, since the Prerelease headings & Release headings in index.md & archive.md changed; AB#62191954 +--> -WebView2 changes may require an update to the Runtime, SDK, or both. Most new APIs require both Runtime and SDK updates. Starting with the February 2023 release, the update requirement for each bug fix is indicated as follows: +The following new features and bug fixes are in the WebView2 Release SDK and Prerelease SDK, for SDKs during the past year. -| Indicator | Meaning | -|---|---| -| No label | Both the Runtime and the SDK need to be updated. | -| **Runtime-only** | Only the Runtime needs to be updated. | -| **SDK-only** | Only the SDK needs to be updated. | -WebView2 shares code and binaries with the Microsoft Edge browser, and is released around the same time. As a result, WebView2 Runtime releases generally also include Microsoft Edge updates. + +## Prerelease SDK 1.0.4015-prerelease, for Runtime 149 (May 11, 2026) -* For Microsoft Edge updates, see [Release notes for Microsoft Edge Stable Channel](/deployedge/microsoft-edge-relnote-stable-channel) and [Release notes for Microsoft Edge Beta Channel](/deployedge/microsoft-edge-relnote-beta-channel). +Release Date: May 11, 2026 -* To update the WebView2 Runtime on your development machine and on user machines, see [Distribute your app and the WebView2 Runtime](./concepts/distribution.md). To view or get the latest WebView2 Runtime versions, see [Download the WebView2 Runtime](https://developer.microsoft.com/microsoft-edge/webview2/#download-section) in the _Microsoft Edge WebView2_ page at developer.microsoft.com. +[NuGet package for WebView2 SDK 1.0.4015-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.4015-prerelease) -* To install or update the WebView2 SDK, see [Install or update the WebView2 SDK](./how-to/machine-setup.md#install-or-update-the-webview2-sdk) in _Set up your Dev environment for WebView2_. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 149.0.4015.0 or higher. -#### Recommended browser channel and Runtime +#### Breaking changes + -Make sure to re-compile your WebView2 app after updating the WebView2 SDK NuGet package. The WebView2 team recommends the following: + +###### `EnhancedSecurityModeLevel` replaced by `EnhancedSecurityModeState` -* Use the Canary preview channel of Microsoft Edge when you develop using a Prerelease version of the WebView2 SDK package. Canary is the recommended preview channel, because it ships at the fastest cadence and has the newest APIs. +The `CoreWebView2Profile.EnhancedSecurityModeLevel` property and the `CoreWebView2EnhancedSecurityModeLevel` enum are deprecated and will be removed in a future release. Replace all usage of these APIs in your WebView2 application, as follows. -* Use the Evergreen WebView2 Runtime when you use a release version of the WebView2 SDK package. +The old property, `CoreWebView2Profile.EnhancedSecurityModeLevel`, controlled whether Enhanced Security Mode (ESM) is enabled or disabled for all WebView2 instances associated with a profile. This property has been renamed to `EnhancedSecurityModeState`, to more clearly communicate the state of Enhanced Security Mode. -For more information, see [Matching the Runtime version with the SDK version](concepts/versioning.md#matching-the-runtime-version-with-the-sdk-version). +**Before this change:** The `CoreWebView2Profile.EnhancedSecurityModeLevel` property used the `CoreWebView2EnhancedSecurityModeLevel` enum with values `Off` and `Strict`. +**After this change:** The `CoreWebView2Profile.EnhancedSecurityModeState` property uses the `CoreWebView2EnhancedSecurityModeState` enum with values `Disabled` and `Enabled`: - -#### Minimum version of the browser or Runtime to load WebView2 +* `CoreWebView2EnhancedSecurityModeState.Disabled` — Enhanced Security Mode is disabled. + * Replaces `CoreWebView2EnhancedSecurityModeLevel.Off`. -To load WebView2, the minimum version of Microsoft Edge or the WebView2 Runtime is 86.0.616.0. The minimum version to load WebView2 only changes when a breaking change occurs in the web platform. +* `CoreWebView2EnhancedSecurityModeState.Enabled` — Enhanced Security Mode is enabled. + * Disables JavaScript Just-in-Time (JIT) compilation. + * Enables additional operating system protections. + * Replaces `CoreWebView2EnhancedSecurityModeLevel.Strict`. -To use a Prerelease SDK along with a Microsoft Edge preview channel, see [Test upcoming APIs and features](how-to/set-preview-channel.md). +See also: +* [Enhanced security mode state](#enhanced-security-mode-state), below. +* [[Breaking Change] `EnhancedSecurityModeLevel` replaced by `EnhancedSecurityModeState` (Issue #132)](https://github.com/MicrosoftEdge/WebView2Announcements/issues/132) - +#### Experimental APIs (Phase 1: Experimental in Prerelease) -Async methods: -- Win32: XYZ method + XYZCompletedHandler -- .NET/WinRT: XYZAsync ---> +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. - -#### Experimental APIs, Prerelease SDKs, and Release SDKs + +###### Enhanced security mode state -New APIs are added in phases, as follows: -1. APIs are initially introduced as Experimental APIs in a Prerelease SDK package. -1. Then they become Stable APIs in a Prerelease SDK package. -1. Soon after, they become Stable APIs in a Release SDK package. +The `EnhancedSecurityModeState` property on `CoreWebView2Profile` controls whether Enhanced Security Mode (ESM) is enabled or disabled for all WebView2 instances that are associated with a profile. -![Diagram of phases of introducing new APIs](./release-notes-images/phases-of-adding-apis.png) - +When enabled, Enhanced Security Mode disables JavaScript Just-in-Time (JIT) compilation and enables additional operating system protections, reducing the attack surface, at the cost of some JavaScript performance. -For more information, see [Phases of introducing APIs](./concepts/versioning.md#phases-of-introducing-apis) in _Understand the different WebView2 SDK versions_. +The default value is `Disabled`. Changes apply immediately to new navigations; existing pages require a reload. - +This setting does not persist, and resets when the profile is destroyed and recreated. -The following sections cover either a Release SDK package (1.0.####.##) or a Prerelease SDK package (1.0.####-prerelease). +##### [.NET/C#](#tab/dotnetcsharp) - +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.EnhancedSecurityModeState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.enhancedsecuritymodestate?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) +##### [WinRT/C#](#tab/winrtcsharp) - -## 1.0.1823.32 +* [CoreWebView2EnhancedSecurityModeState Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2enhancedsecuritymodestate?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * `Disabled` + * `Enabled` -Release Date: June 5, 2023 +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.EnhancedSecurityModeState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#enhancedsecuritymodestate) -[NuGet package for WebView2 SDK 1.0.1823.32](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1823.32) +##### [Win32/C++](#tab/win32cpp) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 114.0.1823.32 or higher. +* [ICoreWebView2ExperimentalProfile17](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile17?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile17::get_EnhancedSecurityModeState](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile17?view=webview2-1.0.4015-prerelease&preserve-view=true#get_enhancedsecuritymodestate) + * [ICoreWebView2ExperimentalProfile17::put_EnhancedSecurityModeState](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile17?view=webview2-1.0.4015-prerelease&preserve-view=true#put_enhancedsecuritymodestate) +* [COREWEBVIEW2_ENHANCED_SECURITY_MODE_STATE enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.4015-prerelease&preserve-view=true#corewebview2_enhanced_security_mode_state) + * `COREWEBVIEW2_ENHANCED_SECURITY_MODE_STATE_DISABLED` + * `COREWEBVIEW2_ENHANCED_SECURITY_MODE_STATE_ENABLED` - -#### General +--- -###### Promotions +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted to Stable and are now included in this Release SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. - -* The `LaunchingExternalUriScheme` event is raised when there's an attempt to launch a URI scheme that is registered with the OS (an external URI scheme). + +###### Enable background processing and offline support (WebView2 Worker APIs) + +The WebView2 Worker APIs allow host applications to interact with Web Workers to offload tasks from the main thread, improve responsiveness, and support background operations. These Web Workers include Dedicated Workers, Shared Workers, and Service Workers. + +These APIs provide: +* **Lifecycle Events:** Monitor creation and destruction of workers. +* **Messaging Interfaces:** Communicate with workers using `PostMessage` and `WebMessageReceived`; specifically: + * `CoreWebView2ServiceWorker.PostWebMessageAsJson` + * `CoreWebView2ServiceWorker.PostWebMessageAsString` + * `CoreWebView2DedicatedWorker.PostWebMessageAsJson` + * `CoreWebView2DedicatedWorker.PostWebMessageAsString` + * `CoreWebView2ServiceWorker.WebMessageReceived` + * `CoreWebView2DedicatedWorker.WebMessageReceived` + * `chrome.webview.postMessage` + * Not: `chrome.webview.postMessageWithAdditionalObjects` +* **Worker Management:** Query and retrieve worker registrations and instances. ##### [.NET/C#](#tab/dotnetcsharp) + * `CoreWebView2` Class: - * [CoreWebView2.LaunchingExternalUriScheme Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.launchingexternalurischeme?view=webview2-dotnet-1.0.1823.32&preserve-view=true) -* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs?view=webview2-dotnet-1.0.1823.32&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.cancel?view=webview2-dotnet-1.0.1823.32&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.1823.32&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.isuserinitiated?view=webview2-dotnet-1.0.1823.32&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.uri?view=webview2-dotnet-1.0.1823.32&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.getdeferral?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2.DedicatedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.dedicatedworkercreated?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2DedicatedWorker Class](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.DedicatedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.dedicatedworkercreated?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.Destroying Event](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.destroying?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.PostWebMessageAsJson Method](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.postwebmessageasjson?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.PostWebMessageAsString Method](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.postwebmessageasstring?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.ScriptUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.scripturi?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.WebMessageReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.webmessagereceived?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2DedicatedWorkerCreatedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworkercreatedeventargs?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworkercreatedeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.Worker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworkercreatedeventargs.worker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.DedicatedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.dedicatedworkercreated?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AreWebViewScriptApisEnabledForServiceWorkers Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.arewebviewscriptapisenabledforserviceworkers?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2Profile.ServiceWorkerManager Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.serviceworkermanager?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2Profile.SharedWorkerManager Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.sharedworkermanager?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorker Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.Destroying Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.destroying?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.PostWebMessageAsJson Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.postwebmessageasjson?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.PostWebMessageAsString Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.postwebmessageasstring?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.ScriptUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.scripturi?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.WebMessageReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.webmessagereceived?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerActivatedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkeractivatedeventargs?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerActivatedEventArgs.ActiveServiceWorker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkeractivatedeventargs.activeserviceworker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerManager Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.getserviceworkerregistrationsasync?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.getserviceworkerregistrationsasync?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.ServiceWorkerRegistered Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.serviceworkerregistered?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerRegisteredEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregisteredeventargs?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegisteredEventArgs.ServiceWorkerRegistration Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregisteredeventargs.serviceworkerregistration?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerRegistration Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ActiveServiceWorker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.activeserviceworker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.Origin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.origin?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ScopeUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.scopeuri?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ServiceWorkerActivated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.serviceworkeractivated?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.TopLevelOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.toplevelorigin?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.Unregistering Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.unregistering?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2SharedWorker Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.Destroying Event](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.destroying?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.Origin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.origin?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.ScriptUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.scripturi?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.TopLevelOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.toplevelorigin?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2SharedWorkerCreatedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkercreatedeventargs?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerCreatedEventArgs.Worker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkercreatedeventargs.worker?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + + +* [CoreWebView2SharedWorkerManager Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkermanager?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerManager.GetSharedWorkersAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkermanager.getsharedworkersasync?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerManager.SharedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkermanager.sharedworkercreated?view=webview2-dotnet-1.0.4015-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) + * `CoreWebView2` Class: - * [CoreWebView2.LaunchingExternalUriScheme Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1823.32&preserve-view=true#launchingexternalurischeme) -* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#cancel) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#initiatingorigin) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#isuserinitiated) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#uri) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#getdeferral) + * [CoreWebView2.DedicatedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#dedicatedworkercreated) + + +* [CoreWebView2DedicatedWorker Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.DedicatedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#dedicatedworkercreated) + * [CoreWebView2DedicatedWorker.Destroying Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#destroying) + * [CoreWebView2DedicatedWorker.PostWebMessageAsJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#postwebmessageasjson) + * [CoreWebView2DedicatedWorker.PostWebMessageAsString Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#postwebmessageasstring) + * [CoreWebView2DedicatedWorker.ScriptUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#scripturi) + * [CoreWebView2DedicatedWorker.WebMessageReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#webmessagereceived) + + +* [CoreWebView2DedicatedWorkerCreatedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworkercreatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.Worker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworkercreatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#worker) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworkercreatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#originalsourceframeinfo) + + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.DedicatedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#dedicatedworkercreated) + + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AreWebViewScriptApisEnabledForServiceWorkers Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#arewebviewscriptapisenabledforserviceworkers) + * [CoreWebView2Profile.ServiceWorkerManager Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#serviceworkermanager) + * [CoreWebView2Profile.SharedWorkerManager Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#sharedworkermanager) + + +* [CoreWebView2ServiceWorker Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.Destroying Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#destroying) + * [CoreWebView2ServiceWorker.PostWebMessageAsJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#postwebmessageasjson) + * [CoreWebView2ServiceWorker.PostWebMessageAsString Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#postwebmessageasstring) + * [CoreWebView2ServiceWorker.ScriptUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#scripturi) + * [CoreWebView2ServiceWorker.WebMessageReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#webmessagereceived) + + +* [CoreWebView2ServiceWorkerActivatedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkeractivatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerActivatedEventArgs.ActiveServiceWorker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkeractivatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#activeserviceworker) + + +* [CoreWebView2ServiceWorkerManager Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#getserviceworkerregistrationsasync) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#getserviceworkerregistrationsasync) + * [CoreWebView2ServiceWorkerManager.ServiceWorkerRegistered Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#serviceworkerregistered) + + +* [CoreWebView2ServiceWorkerRegisteredEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregisteredeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegisteredEventArgs.ServiceWorkerRegistration Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregisteredeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#serviceworkerregistration) + + +* [CoreWebView2ServiceWorkerRegistration Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ActiveServiceWorker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#activeserviceworker) + * [CoreWebView2ServiceWorkerRegistration.Origin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#origin) + * [CoreWebView2ServiceWorkerRegistration.ScopeUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#scopeuri) + * [CoreWebView2ServiceWorkerRegistration.ServiceWorkerActivated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#serviceworkeractivated) + * [CoreWebView2ServiceWorkerRegistration.TopLevelOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#toplevelorigin) + * [CoreWebView2ServiceWorkerRegistration.Unregistering Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#unregistering) + + +* [CoreWebView2SharedWorker Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.Destroying Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#destroying) + * [CoreWebView2SharedWorker.Origin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#origin) + * [CoreWebView2SharedWorker.ScriptUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#scripturi) + * [CoreWebView2SharedWorker.TopLevelOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#toplevelorigin) + + +* [CoreWebView2SharedWorkerCreatedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkercreatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerCreatedEventArgs.Worker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkercreatedeventargs?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#worker) + + +* [CoreWebView2SharedWorkerManager Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerManager.GetSharedWorkersAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#getsharedworkersasync) + * [CoreWebView2SharedWorkerManager.SharedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkermanager?view=webview2-winrt-1.0.4015-prerelease&preserve-view=true#sharedworkercreated) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2_18](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1823.32&preserve-view=true) - * [ICoreWebView2_18::add_LaunchingExternalUriScheme](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1823.32&preserve-view=true#add_launchingexternalurischeme) - * [ICoreWebView2_18::remove_LaunchingExternalUriScheme](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1823.32&preserve-view=true#remove_launchingexternalurischeme) -* [ICoreWebView2LaunchingExternalUriSchemeEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventhandler?view=webview2-1.0.1823.32&preserve-view=true) -* [ICoreWebView2LaunchingExternalUriSchemeEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_cancel) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_initiatingorigin) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_IsUserInitiated](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_isuserinitiated) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Uri](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_uri) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#getdeferral) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#put_cancel) + +* [ICoreWebView2_29](/microsoft-edge/webview2/reference/win32/icorewebview2_29?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2_29::add_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2_29?view=webview2-1.0.4015-prerelease&preserve-view=true#add_dedicatedworkercreated) + * [ICoreWebView2_29::remove_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2_29?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_dedicatedworkercreated) + + +* [ICoreWebView2DedicatedWorker](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2DedicatedWorker::add_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#add_dedicatedworkercreated) + * [ICoreWebView2DedicatedWorker::add_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#add_destroying) + * [ICoreWebView2DedicatedWorker::add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#add_webmessagereceived) + * [ICoreWebView2DedicatedWorker::get_ScriptUri](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#get_scripturi) + * [ICoreWebView2DedicatedWorker::PostWebMessageAsJson](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#postwebmessageasjson) + * [ICoreWebView2DedicatedWorker::PostWebMessageAsString](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#postwebmessageasstring) + * [ICoreWebView2DedicatedWorker::remove_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_dedicatedworkercreated) + * [ICoreWebView2DedicatedWorker::remove_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_destroying) + * [ICoreWebView2DedicatedWorker::remove_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_webmessagereceived) + + +* [ICoreWebView2DedicatedWorkerCreatedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkercreatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2DedicatedWorkerCreatedEventArgs::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkercreatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true#get_originalsourceframeinfo) + * [ICoreWebView2DedicatedWorkerCreatedEventArgs::get_Worker](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkercreatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true#get_worker) + + +* [ICoreWebView2DedicatedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkercreatedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2DedicatedWorkerDedicatedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkerdedicatedworkercreatedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2DedicatedWorkerDestroyingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkerdestroyingeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2DedicatedWorkerWebMessageReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2dedicatedworkerwebmessagereceivedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2Frame8](/microsoft-edge/webview2/reference/win32/icorewebview2frame8?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2Frame8::add_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2frame8?view=webview2-1.0.4015-prerelease&preserve-view=true#add_dedicatedworkercreated) + * [ICoreWebView2Frame8::remove_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2frame8?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_dedicatedworkercreated) + + +* [ICoreWebView2FrameDedicatedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2framededicatedworkercreatedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2GetServiceWorkerRegistrationsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2getserviceworkerregistrationscompletedhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2GetSharedWorkersCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2getsharedworkerscompletedhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2Profile9](/microsoft-edge/webview2/reference/win32/icorewebview2profile9?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2Profile9::get_AreWebViewScriptApisEnabledForServiceWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2profile9?view=webview2-1.0.4015-prerelease&preserve-view=true#get_arewebviewscriptapisenabledforserviceworkers) + * [ICoreWebView2Profile9::get_ServiceWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2profile9?view=webview2-1.0.4015-prerelease&preserve-view=true#get_serviceworkermanager) + * [ICoreWebView2Profile9::get_SharedWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2profile9?view=webview2-1.0.4015-prerelease&preserve-view=true#get_sharedworkermanager) + * [ICoreWebView2Profile9::put_AreWebViewScriptApisEnabledForServiceWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2profile9?view=webview2-1.0.4015-prerelease&preserve-view=true#put_arewebviewscriptapisenabledforserviceworkers) + + +* [ICoreWebView2ServiceWorker](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ServiceWorker::add_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#add_destroying) + * [ICoreWebView2ServiceWorker::add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#add_webmessagereceived) + * [ICoreWebView2ServiceWorker::get_ScriptUri](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#get_scripturi) + * [ICoreWebView2ServiceWorker::PostWebMessageAsJson](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#postwebmessageasjson) + * [ICoreWebView2ServiceWorker::PostWebMessageAsString](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#postwebmessageasstring) + * [ICoreWebView2ServiceWorker::remove_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_destroying) + * [ICoreWebView2ServiceWorker::remove_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworker?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_webmessagereceived) + + +* [ICoreWebView2ServiceWorkerActivatedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkeractivatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ServiceWorkerActivatedEventArgs::get_ActiveServiceWorker](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkeractivatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true#get_activeserviceworker) + + +* [ICoreWebView2ServiceWorkerActivatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkeractivatedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2ServiceWorkerDestroyingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerdestroyingeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2ServiceWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ServiceWorkerManager::add_ServiceWorkerRegistered](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#add_serviceworkerregistered) + * [ICoreWebView2ServiceWorkerManager::GetServiceWorkerRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#getserviceworkerregistrations) + * [ICoreWebView2ServiceWorkerManager::GetServiceWorkerRegistrationsForScope](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#getserviceworkerregistrationsforscope) + * [ICoreWebView2ServiceWorkerManager::remove_ServiceWorkerRegistered](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_serviceworkerregistered) + + +* [ICoreWebView2ServiceWorkerRegisteredEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregisteredeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ServiceWorkerRegisteredEventArgs::get_ServiceWorkerRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregisteredeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true#get_serviceworkerregistration) + + +* [ICoreWebView2ServiceWorkerRegisteredEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregisteredeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2ServiceWorkerRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ServiceWorkerRegistration::add_ServiceWorkerActivated](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#add_serviceworkeractivated) + * [ICoreWebView2ServiceWorkerRegistration::add_Unregistering](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#add_unregistering) + * [ICoreWebView2ServiceWorkerRegistration::get_ActiveServiceWorker](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#get_activeserviceworker) + * [ICoreWebView2ServiceWorkerRegistration::get_Origin](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#get_origin) + * [ICoreWebView2ServiceWorkerRegistration::get_ScopeUri](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#get_scopeuri) + * [ICoreWebView2ServiceWorkerRegistration::get_TopLevelOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#get_toplevelorigin) + * [ICoreWebView2ServiceWorkerRegistration::remove_ServiceWorkerActivated](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_serviceworkeractivated) + * [ICoreWebView2ServiceWorkerRegistration::remove_Unregistering](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistration?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_unregistering) + + +* [ICoreWebView2ServiceWorkerRegistrationCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistrationcollectionview?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2ServiceWorkerRegistrationCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistrationcollectionview?view=webview2-1.0.4015-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ServiceWorkerRegistrationCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistrationcollectionview?view=webview2-1.0.4015-prerelease&preserve-view=true#getvalueatindex) + + +* [ICoreWebView2ServiceWorkerRegistrationUnregisteringEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerregistrationunregisteringeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2ServiceWorkerWebMessageReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2serviceworkerwebmessagereceivedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2SharedWorker](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworker?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2SharedWorker::add_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#add_destroying) + * [ICoreWebView2SharedWorker::get_Origin](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#get_origin) + * [ICoreWebView2SharedWorker::get_ScriptUri](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#get_scripturi) + * [ICoreWebView2SharedWorker::get_TopLevelOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#get_toplevelorigin) + * [ICoreWebView2SharedWorker::remove_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworker?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_destroying) + + +* [ICoreWebView2SharedWorkerCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkercollectionview?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2SharedWorkerCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkercollectionview?view=webview2-1.0.4015-prerelease&preserve-view=true#get_count) + * [ICoreWebView2SharedWorkerCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkercollectionview?view=webview2-1.0.4015-prerelease&preserve-view=true#getvalueatindex) + + +* [ICoreWebView2SharedWorkerCreatedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkercreatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2SharedWorkerCreatedEventArgs::get_Worker](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkercreatedeventargs?view=webview2-1.0.4015-prerelease&preserve-view=true#get_worker) + + +* [ICoreWebView2SharedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkercreatedeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2SharedWorkerDestroyingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkerdestroyingeventhandler?view=webview2-1.0.4015-prerelease&preserve-view=true) + + +* [ICoreWebView2SharedWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true) + * [ICoreWebView2SharedWorkerManager::add_SharedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#add_sharedworkercreated) + * [ICoreWebView2SharedWorkerManager::GetSharedWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#getsharedworkers) + * [ICoreWebView2SharedWorkerManager::remove_SharedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2sharedworkermanager?view=webview2-1.0.4015-prerelease&preserve-view=true#remove_sharedworkercreated) --- -* `MemoryUsageTargetLevel` specifies memory consumption levels, such as `low` or `normal`. +#### Bug fixes -##### [.NET/C#](#tab/dotnetcsharp) +This Prerelease SDK includes the following bug fixes. -* `CoreWebView2` Class: - * [CoreWebView2.MemoryUsageTargetLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.memoryusagetargetlevel?view=webview2-dotnet-1.0.1823.32&preserve-view=true) -* [CoreWebView2MemoryUsageTargetLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2memoryusagetargetlevel?view=webview2-dotnet-1.0.1823.32&preserve-view=true) -##### [WinRT/C#](#tab/winrtcsharp) + +###### Runtime-only -* `CoreWebView2` Class: - * [CoreWebView2.MemoryUsageTargetLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2#memoryusagetargetlevel?view=webview2-winrt-1.0.1823.32&preserve-view=true) -* [CoreWebView2MemoryUsageTargetLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2memoryusagetargetlevel?view=webview2-winrt-1.0.1823.32&preserve-view=true) +* Fixed double character in UWP. +* Fixed Caption controls background color setting API. After this change, apps will also have to intercept the close call and handle themselves to close the app. +* Fixed forwarding of network events for iframe, where the iframe had its own isolated CDP session. +* Improved error handling when Post Message (such as `CoreWebView2ServiceWorker.PostWebMessageAsJson` or `chrome.webview.postMessage`) is called on a service worker. +* Reduced string allocations in `GetDefaultHostAppExeName`. +* Fixed an updater issue where the currently used WebView2 Runtime is deleted after installing a new version, causing a crash during new controller creation in an already running app. -##### [Win32/C++](#tab/win32cpp) + -* [ICoreWebView2_19 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1823.32&preserve-view=true) - * [ICoreWebView2_19::get_MemoryUsageTargetLevel](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1823.32&preserve-view=true#get_memoryusagetargetlevel) - * [ICoreWebView2_19::put_MemoryUsageTargetLevel](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1823.32&preserve-view=true#put_memoryusagetargetlevel) -* [COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1823.32&preserve-view=true#corewebview2_memory_usage_target_level) ---- + +## Release SDK 1.0.3967.48, for Runtime 148 (May 11, 2026) + +Release Date: May 11, 2026 + +[NuGet package for WebView2 SDK 1.0.3967.48](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3967.48) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 148.0.3967.48 or higher. -* Enhanced support for multiple profiles, to allow configuring General Autofill and Password Autosave settings for different profiles. +#### Promotions to Phase 3 (Stable in Release) -##### [.NET/C#](#tab/dotnetcsharp) +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. -* `CoreWebView2Profile` Class: - * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.isgeneralautofillenabled?view=webview2-dotnet-1.0.1823.32&preserve-view=true) - * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.ispasswordautosaveenabled?view=webview2-dotnet-1.0.1823.32&preserve-view=true) -##### [WinRT/C#](#tab/winrtcsharp) + +#### Bug fixes -* `CoreWebView2Profile` Class: - * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1823.32&preserve-view=true#isgeneralautofillenabled) - * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1823.32&preserve-view=true#ispasswordautosaveenabled) +This Release SDK includes the following bug fixes. -##### [Win32/C++](#tab/win32cpp) -* `ICoreWebView2Profile6` interface: - * [ICoreWebView2Profile6::get_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#get_isgeneralautofillenabled) - * [ICoreWebView2Profile6::get_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#get_ispasswordautosaveenabled) - * [ICoreWebView2Profile6::put_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#put_isgeneralautofillenabled) - * [ICoreWebView2Profile6::put_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#put_ispasswordautosaveenabled) + +###### Runtime-only ---- +* Fixed an updater issue where the currently used WebView2 Runtime is deleted after installing a new version, causing a crash during new controller creation in an already running app. + + -## 1.0.1905-prerelease +## Prerelease SDK 1.0.3965-prerelease, for Runtime 148 (Apr. 13, 2026) -Release Date: June 12, 2023 +Release Date: April 13, 2026 -[NuGet package for WebView2 SDK 1.0.1905-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1905-prerelease) +[NuGet package for WebView2 SDK 1.0.3965-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3965-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 116.0.1905.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 148.0.3965.0 or higher. -#### General +#### Breaking changes - - + +###### Granular process failure reasons for the `ProcessFailed` event - +The `ProcessFailed` event fires when a WebView2-associated process (such as a renderer or GPU process) exits unexpectedly, allowing apps to respond with recovery logic or diagnostics. +Before this change: The `CoreWebView2ProcessFailedEventArgs.Reason` property returned `Unexpected` for three distinct exit scenarios (normal exit, abnormal exit, and code integrity failure), making it impossible for apps to distinguish between them. + +After this change: When the `msWebView2GranularProcessFailedReason` feature flag is enabled, the `CoreWebView2ProcessFailedEventArgs.Reason` property returns the following new, granular `CoreWebView2ProcessFailedReason` enum values, instead of `Unexpected`: - -###### Promotions +* `NormalExit` — The process exited normally (exit code 0). -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +* `AbnormalExit` — The process exited abnormally (non-zero exit code), but did not crash or get killed. +* `IntegrityFailure` — The OS terminated the process due to a code integrity failure, such as when a DLL fails Windows Code Integrity verification. - -* `NavigationKind` gets the navigation kind of each navigation, such as Back/Forward, Reload, or navigation to a new document. +The `msWebView2GranularProcessFailedReason` feature flag is disabled by default in releases 148 and 149, giving apps two releases to proactively test. Starting in release 150, the feature will be enabled by default, and apps will receive the granular values. To validate your WebView2 app's behavior, enable the feature flag, as follows: + +`set WEBVIEW2_ADDITIONAL_BROWSER_ARGUMENTS=--enable-features=msWebView2GranularProcessFailedReason` + +This is a bug fix for the Runtime and SDK. These enum members are a modification of an existing stable API, and are available as part of this Prerelease SDK. + +See also: +* [[Breaking Change] Granular process failure reasons for the ProcessFailed event (Issue #131)](https://github.com/MicrosoftEdge/WebView2Announcements/issues/131) ##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2NavigationStartingEventArgs` Class: - * [CoreWebView2NavigationStartingEventArgs.NavigationKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2navigationstartingeventargs.navigationkind?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) -* [CoreWebView2NavigationKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2navigationkind?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) +* `CoreWebView2ProcessFailedEventArgs` Class + * [CoreWebView2ProcessFailedEventArgs.Reason Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processfailedeventargs.reason?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + +* [CoreWebView2ProcessFailedReason Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2processfailedreason?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + * `AbnormalExit` + * `IntegrityFailure` + * `NormalExit` ##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2NavigationStartingEventArgs` Class: - * [CoreWebView2NavigationStartingEventArgs.NavigationKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2navigationstartingeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#navigationkind) -* [CoreWebView2NavigationKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2navigationkind?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) +* `CoreWebView2ProcessFailedEventArgs` Class + * [CoreWebView2ProcessFailedEventArgs.Reason Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processfailedeventargs?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true#reason) + +* [CoreWebView2ProcessFailedReason Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processfailedreason?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true) + * `AbnormalExit` + * `IntegrityFailure` + * `NormalExit` ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2NavigationStartingEventArgs3 interface](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs3?view=webview2-1.0.1905-prerelease&preserve-view=true) - * [ICoreWebView2NavigationStartingEventArgs3::get_NavigationKind property](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs3?view=webview2-1.0.1905-prerelease&preserve-view=true#get_navigationkind) -* [COREWEBVIEW2_NAVIGATION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1905-prerelease&preserve-view=true#corewebview2_navigation_kind) +* `ICoreWebView2ProcessFailedEventArgs2` + * [ICoreWebView2ProcessFailedEventArgs2::get_Reason](/microsoft-edge/webview2/reference/win32/icorewebview2processfailedeventargs2?view=webview2-1.0.3965-prerelease&preserve-view=true#get_reason) + +* [COREWEBVIEW2_PROCESS_FAILED_REASON enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.3965-prerelease&preserve-view=true#corewebview2_process_failed_reason) + * `COREWEBVIEW2_PROCESS_FAILED_REASON_ABNORMAL_EXIT` + * `COREWEBVIEW2_PROCESS_FAILED_REASON_INTEGRITY_FAILURE` + * `COREWEBVIEW2_PROCESS_FAILED_REASON_NORMAL_EXIT` --- -* The `ServiceWorkers` enum value in the `BrowsingDataKinds` enum specifies service workers that are registered for an origin. - -##### [.NET/C#](#tab/dotnetcsharp) +#### Experimental APIs (Phase 1: Experimental in Prerelease) -* `CoreWebView2BrowsingDataKinds` Enum: - * [CoreWebView2BrowsingDataKinds.ServiceWorkers Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2browsingdatakinds?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. -##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2BrowsingDataKinds` Enum: - * [CoreWebView2BrowsingDataKinds.ServiceWorkers Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browsingdatakinds?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) + +###### Origin Configuration API for WebView2 -##### [Win32/C++](#tab/win32cpp) +The Origin Configuration API enables WebView2 apps to apply different feature and security policies based on the origin of hosted content. By default, WebView2 enforces a uniform policy across all origins. This API allows apps to selectively enable or disable specific features (such as Enhanced Security Mode) for individual origins or origin patterns. + +Use the `SetOriginFeatures` method on `CoreWebView2Profile` to configure feature settings for one or more origins. Origins can be specified as exact strings (such as `https://contoso.com`) or wildcard patterns (such as `https://[*.]contoso.com`) to match subdomains, protocols, or ports. -* `COREWEBVIEW2_BROWSING_DATA_KINDS` enum: - * [COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1905-prerelease&preserve-view=true#corewebview2_browsing_data_kinds) +When multiple configurations apply to the same origin, the most specific pattern takes precedence, evaluated by hostname, then scheme, then port. + +Use `GetEffectiveFeaturesForOrigin` to asynchronously retrieve the computed feature settings for a given origin. ---- +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2OriginFeature Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2originfeature?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + * `EnhancedSecurityMode` - -* The `LaunchingExternalUriScheme` event is raised when there's an attempt to launch a URI scheme that is registered with the OS (an external URI scheme). + +* [CoreWebView2OriginFeatureSetting Class](/dotnet/api/microsoft.web.webview2.core.corewebview2originfeaturesetting?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + * [CoreWebView2OriginFeatureSetting.Feature Property](/dotnet/api/microsoft.web.webview2.core.corewebview2originfeaturesetting.feature?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + * [CoreWebView2OriginFeatureSetting.State Property](/dotnet/api/microsoft.web.webview2.core.corewebview2originfeaturesetting.state?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) -##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2OriginFeatureState Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2originfeaturestate?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + * `Disabled` + * `Enabled` -* `CoreWebView2` Class: - * [CoreWebView2.LaunchingExternalUriScheme Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.launchingexternalurischeme?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) -* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.cancel?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.isuserinitiated?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.uri?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.getdeferral?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + +* `CoreWebView2Profile Class` + * [CoreWebView2Profile.GetEffectiveFeaturesForOriginAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.geteffectivefeaturesfororiginasync?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) + * [CoreWebView2Profile.SetOriginFeatures Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setoriginfeatures?view=webview2-dotnet-1.0.3965-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2` Class: - * [CoreWebView2.LaunchingExternalUriScheme Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#launchingexternalurischeme) -* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#cancel) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#initiatingorigin) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#isuserinitiated) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#uri) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#getdeferral) - -##### [Win32/C++](#tab/win32cpp) + +* [CoreWebView2OriginFeature Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2originfeature?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true) + * `EnhancedSecurityMode` -* [ICoreWebView2_18 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1905-prerelease&preserve-view=true) - * [ICoreWebView2_18::add_LaunchingExternalUriScheme event](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1905-prerelease&preserve-view=true#add_launchingexternalurischeme) - * [ICoreWebView2_18::remove_LaunchingExternalUriScheme event](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1905-prerelease&preserve-view=true#remove_launchingexternalurischeme) -* [ICoreWebView2LaunchingExternalUriSchemeEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventhandler?view=webview2-1.0.1905-prerelease&preserve-view=true) -* [ICoreWebView2LaunchingExternalUriSchemeEventArgs interface](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Cancel property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_cancel) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_initiatingorigin) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_IsUserInitiated property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_isuserinitiated) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Uri property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_uri) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::GetDeferral method](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#getdeferral) - * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::put_Cancel property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#put_cancel) + +* [CoreWebView2OriginFeatureSetting Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2originfeaturesetting?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true) + * [CoreWebView2OriginFeatureSetting.Feature Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2originfeaturesetting?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true#feature) + * [CoreWebView2OriginFeatureSetting.State Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2originfeaturesetting?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true#state) ---- + +* [CoreWebView2OriginFeatureState Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2originfeaturestate?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true) + * `Disabled` + * `Enabled` + +* `CoreWebView2Profile Class` + * [CoreWebView2Profile.GetEffectiveFeaturesForOriginAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true#geteffectivefeaturesfororiginasync) + * [CoreWebView2Profile.SetOriginFeatures Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3965-prerelease&preserve-view=true#setoriginfeatures) - -* `MemoryUsageTargetLevel` specifies memory consumption levels, such as `low` or `normal`. +##### [Win32/C++](#tab/win32cpp) -##### [.NET/C#](#tab/dotnetcsharp) + +* [ICoreWebView2ExperimentalGetEffectiveFeaturesForOriginCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgeteffectivefeaturesfororigincompletedhandler?view=webview2-1.0.3965-prerelease&preserve-view=true) -* `CoreWebView2` Class: - * [CoreWebView2.MemoryUsageTargetLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.memoryusagetargetlevel?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) -* [CoreWebView2MemoryUsageTargetLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2memoryusagetargetlevel?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalOriginFeatureSetting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaloriginfeaturesetting?view=webview2-1.0.3965-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalOriginFeatureSetting::get_Feature](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaloriginfeaturesetting?view=webview2-1.0.3965-prerelease&preserve-view=true#get_feature) + * [ICoreWebView2ExperimentalOriginFeatureSetting::get_State](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaloriginfeaturesetting?view=webview2-1.0.3965-prerelease&preserve-view=true#get_state) -##### [WinRT/C#](#tab/winrtcsharp) + +* [ICoreWebView2ExperimentalOriginFeatureSettingCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaloriginfeaturesettingcollectionview?view=webview2-1.0.3965-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalOriginFeatureSettingCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaloriginfeaturesettingcollectionview?view=webview2-1.0.3965-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalOriginFeatureSettingCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaloriginfeaturesettingcollectionview?view=webview2-1.0.3965-prerelease&preserve-view=true#getvalueatindex) -* `CoreWebView2` Class: - * [CoreWebView2.MemoryUsageTargetLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#memoryusagetargetlevel) -* [CoreWebView2MemoryUsageTargetLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2memoryusagetargetlevel?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalProfile16](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile16?view=webview2-1.0.3965-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile16::CreateOriginFeatureSetting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile16?view=webview2-1.0.3965-prerelease&preserve-view=true#createoriginfeaturesetting) + * [ICoreWebView2ExperimentalProfile16::GetEffectiveFeaturesForOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile16?view=webview2-1.0.3965-prerelease&preserve-view=true#geteffectivefeaturesfororigin) + * [ICoreWebView2ExperimentalProfile16::SetOriginFeatures](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile16?view=webview2-1.0.3965-prerelease&preserve-view=true#setoriginfeatures) -##### [Win32/C++](#tab/win32cpp) + +* [COREWEBVIEW2_ORIGIN_FEATURE enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3965-prerelease&preserve-view=true#corewebview2_origin_feature) + * `COREWEBVIEW2_ORIGIN_FEATURE_ENHANCED_SECURITY_MODE` -* [ICoreWebView2_19 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1905-prerelease&preserve-view=true) - * [ICoreWebView2_19::get_MemoryUsageTargetLevel property](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1905-prerelease&preserve-view=true#get_memoryusagetargetlevel) - * [ICoreWebView2_19::put_MemoryUsageTargetLevel property](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1905-prerelease&preserve-view=true#put_memoryusagetargetlevel) -* [COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1905-prerelease&preserve-view=true#corewebview2_memory_usage_target_level) + +* [COREWEBVIEW2_ORIGIN_FEATURE_STATE enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3965-prerelease&preserve-view=true#corewebview2_origin_feature_state) + * `COREWEBVIEW2_ORIGIN_FEATURE_STATE_DISABLED` + * `COREWEBVIEW2_ORIGIN_FEATURE_STATE_ENABLED` --- -###### Bug fixes - -* Using `wv2winrt webhosthidden` entered an infinite loop when enumerating some `webhosthidden` types. (SDK-only) -* In code that's generated by the **wv2winrt** tool, when calling an async method, it would crash if it succeeded but returned `null` instead of an `IAsyncAction`. (SDK-only) +#### Phase 2 (Stable in Prerelease) +The following enum members are a modification of an existing stable API, and are available as part of this Prerelease SDK. - -## 1.0.1774.30 -Release Date: May 8, 2023 + +###### Granular process failure reasons for the `ProcessFailed` event -[NuGet package for WebView2 SDK 1.0.1774.30](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1774.30) +Supplemented the `CoreWebView2ProcessFailedReason.Unexpected` enum member by adding more granular values, for the `CoreWebView2ProcessFailedReason` enum that's returned by the `CoreWebView2ProcessFailedEventArgs.Reason` property. -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 113.0.1774.30 or higher. +This is a breaking change; see [Granular process failure reasons for the `ProcessFailed` event](#granular-process-failure-reasons-for-the-processfailed-event), above. -#### General +#### Bug fixes -###### Promotions +This Prerelease SDK includes the following bug fixes. -The following APIs have been promoted to Stable and are now included in this Release SDK. + +###### Runtime and SDK - -* The File API allows accessing a DOM `File` object passed via `WebMessage`. +* Supplemented the `CoreWebView2ProcessFailedReason.Unexpected` enum member by adding more granular values, for the `CoreWebView2ProcessFailedReason` enum that's returned by the `CoreWebView2ProcessFailedEventArgs.Reason` property. This is a breaking change. See [Granular process failure reasons for the `ProcessFailed` event](#granular-process-failure-reasons-for-the-processfailed-event), above. -##### [.NET/C#](#tab/dotnetcsharp) -* [CoreWebView2File Class](/dotnet/api/microsoft.web.webview2.core.corewebview2file?view=webview2-dotnet-1.0.1774.30&preserve-view=true) - * [CoreWebView2File.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2file.path?view=webview2-dotnet-1.0.1774.30&preserve-view=true) -* `CoreWebView2WebMessageReceivedEventArgs` Class: - * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webmessagereceivedeventargs.additionalobjects?view=webview2-dotnet-1.0.1774.30&preserve-view=true) + +###### Runtime-only -##### [WinRT/C#](#tab/winrtcsharp) +* Fixed **Print** dialog dropdown selection issues in `WebView2CompositionControl`. ([Issue #5195](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5195)) -* [CoreWebView2File Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1774.30&preserve-view=true) - * [CoreWebView2File.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1774.30&preserve-view=true#path) -* `CoreWebView2WebMessageReceivedEventArgs` Class: - * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webmessagereceivedeventargs?view=webview2-winrt-1.0.1774.30&preserve-view=true#additionalobjects) +* Disabled the Domain Actions component for WebView2. -##### [Win32/C++](#tab/win32cpp) +* Disabled `WebUSBDetector` notification for WebView2. -* [ICoreWebView2File interface](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1774.30&preserve-view=true) - * [ICoreWebView2File::get_Path](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1774.30&preserve-view=true#get_path) -* [ICoreWebView2ObjectCollectionView interface](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1774.30&preserve-view=true) - * [ICoreWebView2ObjectCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1774.30&preserve-view=true#get_count) - * [ICoreWebView2ObjectCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1774.30&preserve-view=true#getvalueatindex) -* [ICoreWebView2WebMessageReceivedEventArgs2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1774.30&preserve-view=true) - * [ICoreWebView2WebMessageReceivedEventArgs2::get_AdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1774.30&preserve-view=true#get_additionalobjects) +* Fixed stale `ICoreWebView2Profile3::get_PreferredTrackingPreventionLevel`. ---- +* Fixed WDP clients being unable to connect to a remote debugging server. +* Fixed an issue for the WPF sample app, where closing the window left a lingering WPF process. - -* The Profile Cookie Manager API supports profile management. The `CookieManager` property enables the host app to get the cookie manager for the profile. -##### [.NET/C#](#tab/dotnetcsharp) + +###### SDK-only -* `CoreWebView2Profile` Class: - * [CoreWebView2Profile.CookieManager Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.cookiemanager?view=webview2-dotnet-1.0.1774.30&preserve-view=true) +* Enabled histogram logging for browser process crashes in WebView2. -##### [WinRT/C#](#tab/winrtcsharp) + -* `CoreWebView2Profile` Class: - * [CoreWebView2Profile.CookieManager Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1774.30&preserve-view=true#cookiemanager) -##### [Win32/C++](#tab/win32cpp) + +## Release SDK 1.0.3912.50, for Runtime 147 (Apr. 13, 2026) -* `ICoreWebView2Profile5` interface: - * [ICoreWebView2Profile5::get_CookieManager](/microsoft-edge/webview2/reference/win32/icorewebview2profile5?view=webview2-1.0.1774.30&preserve-view=true#get_cookiemanager) +Release Date: Apr. 13, 2026 ---- +[NuGet package for WebView2 SDK 1.0.3912.50](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3912.50) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 147.0.3912.50 or higher. -###### Bug fixes +#### Promotions to Phase 3 (Stable in Release) -* Fixed an issue to allow an app to inject initial scripts by calling `AddScriptToExecuteOnDocumentCreated` before a new window is created. ([Issue #2491](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2491)) +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. -##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2` Class: - * [CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.addscripttoexecuteondocumentcreatedasync) + +#### Bug fixes -##### [WinRT/C#](#tab/winrtcsharp) +This Release SDK includes the following bug fixes. -* `CoreWebView2` Class: - * [CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2#addscripttoexecuteondocumentcreatedasync) -##### [Win32/C++](#tab/win32cpp) + +###### Runtime-only -* `ICoreWebView2` interface: - * [ICoreWebView2::AddScriptToExecuteOnDocumentCreated method](/microsoft-edge/webview2/reference/win32/icorewebview2#addscripttoexecuteondocumentcreated) +* Disabled the Domain Actions component for WebView2. ---- +* Fixed WDP clients being unable to connect to a remote debugging server. -* (Runtime-only) Fixed an issue that was causing the `X-Edge-Shopping-Flag` header to be added to web requests that are coming from WebView2. ([Issue #3365](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3365)) + -## 1.0.1829-prerelease +## Prerelease SDK 1.0.3908-prerelease, for Runtime 147 (Mar. 16, 2026) -Release Date: May 8, 2023 +Release Date: Mar. 16, 2026 -[NuGet package for WebView2 SDK 1.0.1829-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1829-prerelease) +[NuGet package for WebView2 SDK 1.0.3908-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3908-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 115.0.1829.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 147.0.3908.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. -###### Promotions +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs skipped Phase 1: Experimental in Prerelease, and have been directly added to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. - -* Enhanced support for multiple profiles, to allow configuring General Autofill and Password Autosave settings for different profiles. + +###### Manage persistent storage permissions for web content -##### [.NET/C#](#tab/dotnetcsharp) +The `PersistentStorage` permission allows a WebView2 app to handle requests from web content to persist data that's created by Storage APIs, service workers, and related technologies. The `PersistentStorage` permission is an enum member in the `CoreWebView2PermissionKind` enum. -* `CoreWebView2Profile` Class: - * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.isgeneralautofillenabled?view=webview2-dotnet-1.0.1829-prerelease&preserve-view=true) - * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.ispasswordautosaveenabled?view=webview2-dotnet-1.0.1829-prerelease&preserve-view=true) +When this permission is granted, the browser doesn't evict stored data during low-disk-space scenarios. This ensures reliable offline and caching behavior for the site. +##### [.NET/C#](#tab/dotnetcsharp) -##### [WinRT/C#](#tab/winrtcsharp) +* [CoreWebView2PermissionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.3908-prerelease&preserve-view=true) + * `PersistentStorage` -* `CoreWebView2Profile` Class: - * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1829-prerelease&preserve-view=true#isgeneralautofillenabled) - * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1829-prerelease&preserve-view=true#ispasswordautosaveenabled) +##### [WinRT/C#](#tab/winrtcsharp) +* [CoreWebView2PermissionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.3908-prerelease&preserve-view=true) + * `PersistentStorage` ##### [Win32/C++](#tab/win32cpp) -* `ICoreWebView2Profile6` interface: - * [ICoreWebView2Profile6::get_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#get_ispasswordautosaveenabled) - * [ICoreWebView2Profile6::put_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#put_ispasswordautosaveenabled) - * [ICoreWebView2Profile6::get_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#get_isgeneralautofillenabled) - * [ICoreWebView2Profile6::put_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#put_isgeneralautofillenabled) +* [COREWEBVIEW2_PERMISSION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.3908-prerelease&preserve-view=true#corewebview2_permission_kind) + * `COREWEBVIEW2_PERMISSION_KIND_PERSISTENT_STORAGE` --- -###### Bug fixes +#### Bug fixes -* Disabled the Chrome Web Store info banner that displays the option to allow extensions installation. ([Issue #3312](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3312)) -* Fixed an issue where a custom menu item wasn't firing. ([Issue #3300](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3300)) -* Fixed a crash during initialization when creating a WebView2 using WPF and SDK version 1.0.1722.32, which is now deprecated. (See [SDK 1.0.1722.32 is deprecated](#sdk-10172232-is-deprecated) below.) ([Issue #3375](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3375)) -* (Runtime-only) Fixed a bug in `PostSharedBufferToScript` that stops after about 32000x1MB buffers are posted. ([Issue #3360](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3360)) +This Prerelease SDK includes the following bug fixes. -##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2` Class: - * [CoreWebView2.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postsharedbuffertoscript) + +###### Runtime-only -##### [WinRT/C#](#tab/winrtcsharp) +* Fixed a bug where disconnecting a screen didn't change the screen resolution correctly. -* `CoreWebView2` Class: - * [CoreWebView2.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2#postsharedbuffertoscript) +* Fixed per-monitor DPI in `window.getScreenDetails()`. ([Issue #4826](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4826)) -##### [Win32/C++](#tab/win32cpp) +* Disabled the domain actions component for WebView2. -* `ICoreWebView2_17` interface: - * [ICoreWebView2_17::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2_17#postsharedbuffertoscript) +* Fixed Print-to-PDF API failure when printing PDFs. ([Issue #5499](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5499)) ---- +* Fixed an issue causing Narrator to announce the structural `HWND`, which doesn't have any UI. -* (Runtime-only) Fixed an issue where navigation will always take place within a `ScriptDialogOpening` event callback. ([Issue #3355](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3355)) -* (Runtime-only) Fixed an issue to support the `BackForwardCache` flag. -* Fixed an issue with visual hosted owned windows, where clicking into the Find bar from outside the window didn't activate the Find bar. +* Fixed WebView2 transparency. +* Fixed the API for setting the background color of the **Caption** control. - -## 1.0.1722.45 + -Release Date: April 13, 2023 -[NuGet package for WebView2 SDK 1.0.1722.45](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1722.45) + +## Release SDK 1.0.3856.49, for Runtime 146 (Mar. 16, 2026) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 112.0.1722.45 or higher. +Release Date: Mar. 16, 2026 +[NuGet package for WebView2 SDK 1.0.3856.49](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3856.49) - -#### General +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 146.0.3856.49 or higher. -###### SDK 1.0.1722.32 is deprecated +#### Promotions to Phase 3 (Stable in Release) -WebView2 SDK 1.0.1722.32 is deprecated, and that package has been removed from the listing at NuGet. Discontinue development with package 1.0.1722.32. If your WebView2 app uses that package, we recommend that you move to a newer package, such as WebView2 SDK 1.0.1722.45 or later. +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. -###### Promotions +#### Bug fixes -The following APIs have been promoted to Stable and are now included in this Release SDK. +This Release SDK includes the following bug fixes. - -* The Managing SmartScreen API controls whether SmartScreen is enabled. + +###### Runtime-only -##### [.NET/C#](#tab/dotnetcsharp) +* Fixed Print-to-PDF API failure when printing PDFs. ([Issue #5499](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5499)) -* `CoreWebView2Settings` - * [CoreWebView2Settings.IsReputationCheckingRequired Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isreputationcheckingrequired?view=webview2-dotnet-1.0.1722.45&preserve-view=true) + -##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2Settings` - * [CoreWebView2Settings.IsReputationCheckingRequired Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.1722.45&preserve-view=true#isreputationcheckingrequired) + +## Prerelease SDK 1.0.3848-prerelease, for Runtime 146 (Feb. 16, 2026) -##### [Win32/C++](#tab/win32cpp) +Release Date: Feb. 16, 2026 -* [ICoreWebView2Settings8](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1722.45&preserve-view=true) - * [ICoreWebView2Settings8::get_IsReputationCheckingRequired method](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1722.45&preserve-view=true#get_isreputationcheckingrequired) - * [ICoreWebView2Settings8::put_IsReputationCheckingRequired method](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1722.45&preserve-view=true#put_isreputationcheckingrequired) +[NuGet package for WebView2 SDK 1.0.3848-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3848-prerelease) ---- +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 146.0.3848.0 or higher. -* The `PermissionKind.WindowManagement` API indicates the kind of a permission request. +#### Breaking changes -##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2PermissionKind` Enum - * [CoreWebView2PermissionKind.WindowManagement Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.1722.45&preserve-view=true) + +###### Enable WebView2-specific Javascript APIs for service workers -##### [WinRT/C#](#tab/winrtcsharp) +The new `AreWebViewScriptApisEnabledForServiceWorkers` setting provides an explicit and reliable way to control the availability of WebView2‑specific JavaScript APIs (`chrome.webview`) within service worker scripts. -* `CoreWebView2PermissionKind` Enum - * [CoreWebView2PermissionKind.WindowManagement Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.1722.45&preserve-view=true) +This setting is disabled by default for WebView2 applications. Apps that don't explicitly enable this setting won't have access to WebView2‑specific JavaScript APIs in service worker scripts. As a result, service worker–based `chrome.webview.postMessage` communication with the WebView2 host application will not function unless the setting is enabled. -##### [Win32/C++](#tab/win32cpp) +Going forward, WebView2 will rely on the `AreWebViewScriptApisEnabledForServiceWorkers` setting as the authoritative mechanism for enabling WebView2‑specific JavaScript APIs in service worker scripts. This ensures predictable, secure, and deterministic behavior. -* `COREWEBVIEW2_PERMISSION_KIND` Enum - * [COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1722.45&preserve-view=true#corewebview2_permission_kind) +You can proactively validate your WebView2 app's behavior by enabling service worker JavaScript API exposure in your WebView2 app. +To do so, configure your app to enable the following setting: + +``` +AreWebViewScriptApisEnabledForServiceWorkers = true +``` ---- +By testing your WebView2 app with this setting enabled, you can identify any workflows that depend on WebView2‑specific service worker APIs, such as `chrome.webview.postMessage` communication between service workers and the host application. +Currently, the `chrome` and `chrome.webview` objects are available to service worker scripts when using the `ServiceWorkerRegistered` event. However, starting with the next release, the `AreWebViewScriptApisEnabledForServiceWorkers` setting will be the sole mechanism that determines whether these objects are exposed to service worker scripts. Please test this setting before the next release, and report any issues you encounter. For details, see [[Breaking Change] Enabling WebView2 specific JavaScript API's for Service Workers](https://github.com/MicrosoftEdge/WebView2Announcements/issues/127). - -## 1.0.1777-prerelease +See also [Control whether WebView Script APIs are enabled for service workers](#control-whether-webview-script-apis-are-enabled-for-service-workers), below. -Release Date: April 10, 2023 +##### [.NET/C#](#tab/dotnetcsharp) -[NuGet package for WebView2 SDK 1.0.1777-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1777-prerelease) +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.AreWebViewScriptApisEnabledForServiceWorkers Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.arewebviewscriptapisenabledforserviceworkers?view=webview2-dotnet-1.0.3848-prerelease&preserve-view=true) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 114.0.1777.0 or higher. +* `CoreWebView2ServiceWorkerManager` Class: + * [CoreWebView2ServiceWorkerManager.ServiceWorkerRegistered Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.serviceworkerregistered?view=webview2-dotnet-1.0.3848-prerelease&preserve-view=true) +* [WebView class](../reference/javascript/webview.yml) in the JavaScript Reference. - -#### General +* [`chrome.webview.postMessage`](../reference/javascript/webview.yml#webview2script-webview-postmessage-member(1)) in the JavaScript Reference. +##### [WinRT/C#](#tab/winrtcsharp) - -###### Experimental features +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.AreWebViewScriptApisEnabledForServiceWorkers Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3848-prerelease&preserve-view=true#arewebviewscriptapisenabledforserviceworkers) -No experimental features are added in this Prerelease SDK. +* `CoreWebView2ServiceWorkerManager` Class: + * [CoreWebView2ServiceWorkerManager.ServiceWorkerRegistered Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.3848-prerelease&preserve-view=true#serviceworkerregistered) +* [WebView class](../reference/javascript/webview.yml) in the JavaScript Reference. - -###### Promotions +* [`chrome.webview.postMessage`](../reference/javascript/webview.yml#webview2script-webview-postmessage-member(1)) in the JavaScript Reference. -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +##### [Win32/C++](#tab/win32cpp) +* [ICoreWebView2ExperimentalProfile15](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile15?view=webview2-1.0.3848-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile15::get_AreWebViewScriptApisEnabledForServiceWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile15?view=webview2-1.0.3848-prerelease&preserve-view=true#get_arewebviewscriptapisenabledforserviceworkers) + * [ICoreWebView2ExperimentalProfile15::put_AreWebViewScriptApisEnabledForServiceWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile15?view=webview2-1.0.3848-prerelease&preserve-view=true#put_arewebviewscriptapisenabledforserviceworkers) - -* The File API allows accessing a DOM `File` object passed via `WebMessage`. +* `ICoreWebView2ExperimentalServiceWorkerManager` + * [ICoreWebView2ExperimentalServiceWorkerManager::add_ServiceWorkerRegistered](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkermanager?view=webview2-1.0.3848-prerelease&preserve-view=true#add_serviceworkerregistered) -##### [.NET/C#](#tab/dotnetcsharp) +* [WebView class](../reference/javascript/webview.yml) in the JavaScript Reference. -* [CoreWebView2File](/dotnet/api/microsoft.web.webview2.core.corewebview2file?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true) - * [CoreWebView2File.path property](/dotnet/api/microsoft.web.webview2.core.corewebview2file.path?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2file-path) +* [`chrome.webview.postMessage`](../reference/javascript/webview.yml#webview2script-webview-postmessage-member(1)) in the JavaScript Reference. -* `CoreWebView2WebMessageReceivedEventArgs` - * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects property](/dotnet/api/microsoft.web.webview2.core.corewebview2webmessagereceivedeventargs.additionalobjects?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2webmessagereceivedeventargs-additionalobjects) +--- -##### [WinRT/C#](#tab/winrtcsharp) -* [CoreWebView2File](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true) - * [CoreWebView2File.path property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true#path) + +###### Local Network Access (LNA) in WebView2 -* `CoreWebView2WebMessageReceivedEventArgs` - * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webmessagereceivedeventargs?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true#additionalobjects) +The Chromium browser engine has introduced Local Network Access (LNA). LNA is a security feature that prevents web pages from making requests to private or local network resources, unless the webpage has explicit permission to access the private or local network resources. Examples of such resources are `localhost`, `192.168.*`, or `10.*`. + +LNA is currently disabled by default for WebView2 apps, but you can enable LNA support via the `msWebViewAllowLocalNetworkAccessChecks` flag. For WebView2 apps, no action is required at this time. For information about the flag, see [Available WebView2 browser flags](../concepts/webview-features-flags.md#available-webview2-browser-flags) in _WebView2 browser flags_. + +After the upstream, Chromium code base stabilizes, we plan to add additional enum values in the `CoreWebView2PermissionKind` enum, to support LNA via the `SetPermissionState` method. These new enum values will be used by the UWP `WebView.PermissionRequested` event, to give your WebView2 app explicit control over the Local Network Access (LNA) feature. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.3848-prerelease&preserve-view=true) + +* [CoreWebView2PermissionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.3848-prerelease&preserve-view=true) + +* [WebView.PermissionRequested Event](/uwp/api/windows.ui.xaml.controls.webview.permissionrequested) - UWP. + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3848-prerelease&preserve-view=true#setpermissionstateasync) + +* [CoreWebView2PermissionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.3848-prerelease&preserve-view=true) + +* [WebView.PermissionRequested Event](/uwp/api/windows.ui.xaml.controls.webview.permissionrequested) - UWP. ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2File](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1777-prerelease&preserve-view=true) - * [ICoreWebView2File::get_path](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1777-prerelease&preserve-view=true#get_path) +* `ICoreWebView2Profile4`: + * [ICoreWebView2Profile4::SetPermissionState](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.3848-prerelease&preserve-view=true#setpermissionstate) -* [ICoreWebView2WebMessageReceivedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1777-prerelease&preserve-view=true) - * [ICoreWebView2WebMessageReceivedEventArgs2::get_AdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1777-prerelease&preserve-view=true#get_AdditionalObjects) +* [COREWEBVIEW2_PERMISSION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.3848-prerelease&preserve-view=true#corewebview2_permission_kind) -* [ICoreWebView2ObjectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1777-prerelease&preserve-view=true) - * [ICoreWebView2ObjectCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1777-prerelease&preserve-view=true#get_Count) - * [ICoreWebView2ObjectCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1777-prerelease&preserve-view=true#GetValueAtIndex) +* [WebView.PermissionRequested Event](/uwp/api/windows.ui.xaml.controls.webview.permissionrequested) - UWP. --- +You can proactively test the Local Network Access (LNA) feature in your WebView2 app. To test your app with the LNA feature, launch your WebView2 app with the following flag: + +``` +--enable-features=LocalNetworkAccessChecks,msWebViewAllowLocalNetworkAccessChecks +``` + +By testing your app when launched with this flag, you can then identify any workflows that might be affected by the LNA feature. + +After the LNA feature stabilizes, we'll share an updated timeline for enabling the LNA feature. For details, see [[Breaking Change] Local Network Access (LNA) in WebView2 - Rollout Plan](https://github.com/MicrosoftEdge/WebView2Announcements/issues/126). + -* The Profile Cookie Manager API supports profile management. The `CookieManager` property enables the host app to get the cookie manager for the profile. +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. + + + +###### Control whether WebView Script APIs are enabled for service workers + +Use the `AreWebViewScriptApisEnabledForServiceWorkers` property on `CoreWebView2Profile` to control whether WebView Script APIs are enabled for service workers. + +See also [Enable WebView2-specific Javascript APIs for service workers](#enable-webview2-specific-javascript-apis-for-service-workers), above. ##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2Profile` - * [CoreWebView2Profile.CookieManager property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.cookiemanager?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2profile-cookiemanager) +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.AreWebViewScriptApisEnabledForServiceWorkers Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.arewebviewscriptapisenabledforserviceworkers?view=webview2-dotnet-1.0.3848-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2Profile` - * [CoreWebView2Profile.CookieManager property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true#cookiemanager) +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.AreWebViewScriptApisEnabledForServiceWorkers Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3848-prerelease&preserve-view=true#arewebviewscriptapisenabledforserviceworkers) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2Profile5](/microsoft-edge/webview2/reference/win32/icorewebview2profile5?view=webview2-1.0.1777-prerelease&preserve-view=true) - * [ICoreWebView2Profile5::get_CookieManager](/microsoft-edge/webview2/reference/win32/icorewebview2profile5?view=webview2-1.0.1777-prerelease&preserve-view=true#get_cookiemanager) +* [ICoreWebView2ExperimentalProfile15](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile15?view=webview2-1.0.3848-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile15::get_AreWebViewScriptApisEnabledForServiceWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile15?view=webview2-1.0.3848-prerelease&preserve-view=true#get_arewebviewscriptapisenabledforserviceworkers) + * [ICoreWebView2ExperimentalProfile15::put_AreWebViewScriptApisEnabledForServiceWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile15?view=webview2-1.0.3848-prerelease&preserve-view=true#put_arewebviewscriptapisenabledforserviceworkers) --- -###### Bug fixes +#### Promotions to Phase 2 (Stable in Prerelease) -* Fixed a crash when releasing the WebView from a different thread. (Runtime-only) ([Issue #3062](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3062)) -* Fixed a bug where focus was trapped inside the WebView2 control when wrapped in a `ContainerControl`. ([Issue #2835](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2835)) -* Fixed the issue by disabling the editable `.pdf` temporary cached data recovery function in WebView2. ([Issue #3274](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3274)) -* Disabled the Chrome Web Store info banner that displays the option to allow extensions installation. ([Issue #3312](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3312)) -* Fixed an issue with new download items not getting called out by screen readers. -* Fixed a bug where visual hosted owned windows didn't map mouse pointer input correctly. -* Fixed a bug where `DownloadStarting` was getting raised for a canceled **Save As** dialog. (Runtime-only) +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + +This Prerelease SDK includes the following bug fixes. + + + +###### Runtime-only + +* Fixed the PDF toolbar disappearing when all options in a region are removed. ([Issue #4738](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4738)) + +* Fixed a white flash that occurred when Windows Search became visible after being hidden. + +* Fixed the title bar shadow so that it's not displayed in a transparent WebView2 control. ([Issue #5492](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5492)) + +* Fixed WebView2 transparency. + +* Fixed a Local Network Access (LNA) prompts issue, by disabling LNA checks in WebView2. + + -## 1.0.1661.34 +## Release SDK 1.0.3800.47, for Runtime 145 (Feb. 16, 2026) -Release Date: March 20, 2023 +Release Date: Feb. 16, 2026 + +[NuGet package for WebView2 SDK 1.0.3800.47](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3800.47) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 145.0.3800.47 or higher. -[NuGet package for WebView2 SDK 1.0.1661.34](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1661.34) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 111.0.1661.34 or higher. + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. -#### General +#### Bug fixes + +This Release SDK includes the following bug fixes. -###### Promotions +###### Runtime-only -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Fixed the title bar shadow so that it's not displayed in a transparent WebView2 control. ([Issue #5492](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5492)) + +* Fixed a Local Network Access (LNA) prompts issue, by disabling LNA checks in WebView2. + +* Fixed WebView2 transparency. + + + + + +## Prerelease SDK 1.0.3796-prerelease, for Runtime 145 (Jan. 19, 2026) + +Release Date: Jan. 19, 2026 + +[NuGet package for WebView2 SDK 1.0.3796-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3796-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 145.0.3796.0 or higher. -* The SharedBuffer API: +#### Experimental APIs (Phase 1: Experimental in Prerelease) -##### [.NET/C#](#tab/dotnetcsharp) +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. -* `CoreWebView2` Class - * [CoreWebView2.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postsharedbuffertoscript?view=webview2-dotnet-1.0.1661.34&preserve-view=true) -* `CoreWebView2Environment` Class - * [ICoreWebView2Environment.CreateSharedBuffer Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createsharedbuffer?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +###### Enhanced Security Mode Level -* `CoreWebView2Frame` Class - * [CoreWebView2Frame.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.postsharedbuffertoscript?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +The Enhanced Security Mode Level API enables configuring Enhanced Security Mode (ESM) for WebView2 instances. ESM reduces the risk of memory-related vulnerabilities by disabling JavaScript Just-in-Time (JIT) compilation and enabling additional operating system protections. -* [CoreWebView2SharedBuffer Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.Buffer Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.buffer?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.FileMappingHandle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.filemappinghandle?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.Size Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.size?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.Close Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.close?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.Dispose Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.dispose?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.OpenStream Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.openstream?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +To control the ESM level for all WebView2 instances that share the same profile, use the `EnhancedSecurityModeLevel` property on `CoreWebView2Profile` (or `ICoreWebView2ExperimentalProfile9`): -* [CoreWebView2SharedBufferAccess Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbufferaccess?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * `ReadOnly` - * `ReadWrite` +* Use the `Off` value to completely disable Enhanced Security Mode (default behavior). + +* Use the `Strict` value to enable enhanced security for all sites. This disables JIT compilation and applies additional OS-level protections, improving security but potentially reducing JavaScript performance. + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2EnhancedSecurityModeLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2enhancedsecuritymodelevel?view=webview2-dotnet-1.0.3796-prerelease&preserve-view=true) + * `CoreWebView2EnhancedSecurityModeLevel.Off` + * `CoreWebView2EnhancedSecurityModeLevel.Strict` + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.EnhancedSecurityModeLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.enhancedsecuritymodelevel?view=webview2-dotnet-1.0.3796-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2` Class - * [CoreWebView2.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) +* [CoreWebView2EnhancedSecurityModeLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2enhancedsecuritymodelevel?view=webview2-winrt-1.0.3796-prerelease&preserve-view=true) + * `CoreWebView2EnhancedSecurityModeLevel.Off` + * `CoreWebView2EnhancedSecurityModeLevel.Strict` -* `CoreWebView2Environment` Class - * [ICoreWebView2Environment.CreateSharedBuffer Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1661.34&preserve-view=true#createsharedbuffer) +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.EnhancedSecurityModeLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3796-prerelease&preserve-view=true#enhancedsecuritymodelevel) -* `CoreWebView2Frame` Class - * [CoreWebView2Frame.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) +##### [Win32/C++](#tab/win32cpp) -* [CoreWebView2SharedBuffer Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true) - * [CoreWebView2SharedBuffer.Buffer Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#buffer) - * [CoreWebView2SharedBuffer.Size Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#size) - * [CoreWebView2SharedBuffer.Close Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#close) - * [CoreWebView2SharedBuffer.OpenStream Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#openstream) +* [ICoreWebView2ExperimentalProfile9](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile9?view=webview2-1.0.3796-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile9::get_EnhancedSecurityModeLevel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile9?view=webview2-1.0.3796-prerelease&preserve-view=true#get_enhancedsecuritymodelevel) + * [ICoreWebView2ExperimentalProfile9::put_EnhancedSecurityModeLevel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile9?view=webview2-1.0.3796-prerelease&preserve-view=true#put_enhancedsecuritymodelevel) -* [CoreWebView2SharedBufferAccess Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbufferaccess?view=webview2-winrt-1.0.1661.34&preserve-view=true) - * `ReadOnly` - * `ReadWrite` +* [COREWEBVIEW2_ENHANCED_SECURITY_MODE_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3796-prerelease&preserve-view=true#corewebview2_enhanced_security_mode_level) + * `COREWEBVIEW2_ENHANCED_SECURITY_MODE_LEVEL_OFF` + * `COREWEBVIEW2_ENHANCED_SECURITY_MODE_LEVEL_STRICT` + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + +This Prerelease SDK includes the following bug fixes. + + + +###### Runtime-only + +* Fixed `chrome.webview` unavailability. +* Disabled background update of network time. + + + +###### SDK-only + +* Added the article [Performance best practices for WebView2 apps](../concepts/performance.md), about how to improve the startup speed, memory usage, and responsiveness of a WebView2 app. + + + + + +## Release SDK 1.0.3719.77, for Runtime 144 (Jan. 27, 2026) + +Release Date: Jan. 27, 2026 + +[NuGet package for WebView2 SDK 1.0.3719.77](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3719.77) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 144.0.3719.77 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Customize the drag and drop behavior (DragStarting API) + +The `DragStarting` API overrides the default drag and drop behavior when running in visual hosting mode. The `DragStarting` event notifies your app when the user starts a drag operation in the WebView2, and provides the state that's necessary to override the default WebView2 drag operation with your own logic. + +* Use `DragStarting` on the `ICoreWebView2CompositionController5` to add an event handler that's invoked when the drag operation is starting. +* Use `ICoreWebView2DragStartingEventArgs` to start your own drag operation. + * Use the `GetDeferral` method to execute any async drag logic and call back into the WebView at a later time. + * Use the `Handled` property to let the WebView2 know whether to use its own drag logic. + +##### [.NET/C#](#tab/dotnetcsharp) + +N/A + +##### [WinRT/C#](#tab/winrtcsharp) + +N/A ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2_17 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2_17::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) +* [ICoreWebView2CompositionController5](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller5?view=webview2-1.0.3719.77&preserve-view=true) + * [ICoreWebView2CompositionController5::add_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller5?view=webview2-1.0.3719.77&preserve-view=true#add_dragstarting) + * [ICoreWebView2CompositionController5::remove_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller5?view=webview2-1.0.3719.77&preserve-view=true#remove_dragstarting) + + +* [ICoreWebView2CompositionControllerInterop3](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop3?view=webview2-winrt-1.0.3719.77&preserve-view=true) + * [ICoreWebView2CompositionControllerInterop3::add_DragStarting](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop3?view=webview2-winrt-1.0.3719.77&preserve-view=true#add_dragstarting) + * [ICoreWebView2CompositionControllerInterop3::remove_DragStarting](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop3?view=webview2-winrt-1.0.3719.77&preserve-view=true#remove_dragstarting) + +* [ICoreWebView2DragStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true) + * [ICoreWebView2DragStartingEventArgs::get_AllowedDropEffects](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true#get_alloweddropeffects) + * [ICoreWebView2DragStartingEventArgs::get_Data](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true#get_data) + * [ICoreWebView2DragStartingEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true#get_handled) + * [ICoreWebView2DragStartingEventArgs::get_Position](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true#get_position) + * [ICoreWebView2DragStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true#getdeferral) + * [ICoreWebView2DragStartingEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3719.77&preserve-view=true#put_handled) + +* [ICoreWebView2DragStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventhandler?view=webview2-1.0.3719.77&preserve-view=true) + +--- + + + +#### Bug fixes + +This Release SDK includes the following bug fixes. + + + +###### Runtime-only + +* Fixed `chrome.webview` unavailability. + + + +###### SDK-only + +* Added the article [Performance best practices for WebView2 apps](../concepts/performance.md), about how to improve the startup speed, memory usage, and responsiveness of a WebView2 app. + + + + + +## Prerelease SDK 1.0.3712-prerelease, for Runtime 144 (Dec. 8, 2025) + +Release Date: Dec. 8, 2025 + +[NuGet package for WebView2 SDK 1.0.3712-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3712-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 144.0.3712.0 or higher. -* [ICoreWebView2Environment12 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2Environment12::CreateSharedBuffer method](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1661.34&preserve-view=true#createsharedbuffer) -* [ICoreWebView2Frame4 interface](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2Frame4::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. + + + +###### Customize port range behavior + +The Allowed Port Range APIs enable restricting or customizing the network port ranges that WebView2 can use for various transport protocols and scopes. This provides enhanced security control. + +* Use `SetAllowedPortRange` on the `CoreWebView2EnvironmentOptions` (or `ICoreWebView2ExperimentalEnvironmentOptions`) instance to configure port restrictions during environment creation. + + * Use the `scope` parameter to specify whether the configuration applies to all components (`Default`) or only to WebRTC peer-to-peer connections (`WebRtc`). Currently only `WebRtc` is supported. + + * Use the `protocol` parameter to specify the transport protocol (currently supports `Udp`). + + * Specify `minPort` and `maxPort` values between 1025-65535 (inclusive), or use (0,0) to reset/remove restrictions. + +* Use `GetEffectiveAllowedPortRange` on the `CoreWebView2EnvironmentOptions` (or `ICoreWebView2ExperimentalEnvironmentOptions`) instance to retrieve the active port range configuration for a specific scope and protocol. + + * Returns the explicitly set range for the given scope, or inherits from the `Default` scope if not set. + + * Returns (0,0) if no restrictions are configured for the specified scope. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class + * [CoreWebView2EnvironmentOptions.GetEffectiveAllowedPortRange Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.geteffectiveallowedportrange?view=webview2-dotnet-1.0.3712-prerelease&preserve-view=true) + * [CoreWebView2EnvironmentOptions.SetAllowedPortRange Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.setallowedportrange?view=webview2-dotnet-1.0.3712-prerelease&preserve-view=true) + +* [CoreWebView2AllowedPortRangeScope Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2allowedportrangescope?view=webview2-dotnet-1.0.3712-prerelease&preserve-view=true) + * `CoreWebView2AllowedPortRangeScope.Default` + * `CoreWebView2AllowedPortRangeScope.WebRtc` + +* [CoreWebView2TransportProtocolKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2transportprotocolkind?view=webview2-dotnet-1.0.3712-prerelease&preserve-view=true) + * `CoreWebView2TransportProtocolKind.Udp` + +##### [WinRT/C#](#tab/winrtcsharp) + +N/A + +##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2SharedBuffer interface](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2SharedBuffer::OpenStream method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#openstream) - * [ICoreWebView2SharedBuffer::Close method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#close) - * [ICoreWebView2SharedBuffer::get_Size method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#get_size) - * [ICoreWebView2SharedBuffer::get_Buffer method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#get_buffer) - * [ICoreWebView2SharedBuffer::get_FileMappingHandle method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#get_filemappinghandle) +* [ICoreWebView2ExperimentalEnvironmentOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.3712-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironmentOptions::GetEffectiveAllowedPortRange](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.3712-prerelease&preserve-view=true#geteffectiveallowedportrange) + * [ICoreWebView2ExperimentalEnvironmentOptions::SetAllowedPortRange](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.3712-prerelease&preserve-view=true#setallowedportrange) -* [COREWEBVIEW2_SHARED_BUFFER_ACCESS](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1661.34&preserve-view=true#corewebview2_shared_buffer_access) - * `COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY` - * `COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_WRITE` +* [COREWEBVIEW2_ALLOWED_PORT_RANGE_SCOPE Enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3712-prerelease&preserve-view=true#corewebview2_allowed_port_range_scope) + * `COREWEBVIEW2_ALLOWED_PORT_RANGE_SCOPE_DEFAULT` + * `COREWEBVIEW2_ALLOWED_PORT_RANGE_SCOPE_WEB_RTC` + +* [COREWEBVIEW2_TRANSPORT_PROTOCOL_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3712-prerelease&preserve-view=true#corewebview2_transport_protocol_kind) + * `COREWEBVIEW2_TRANSPORT_PROTOCOL_KIND_UDP` --- -* APIs for managing permissions: +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Customize the drag and drop behavior (DragStarting API) + +The `DragStarting` API overrides the default drag and drop behavior when running in visual hosting mode. The `DragStarting` event notifies your app when the user starts a drag operation in the WebView2, and provides the state that's necessary to override the default WebView2 drag operation with your own logic. + +* Use `DragStarting` on the `ICoreWebView2CompositionController5` to add an event handler that's invoked when the drag operation is starting. +* Use `ICoreWebView2DragStartingEventArgs` to start your own drag operation. + * Use the `GetDeferral` method to execute any async drag logic and call back into the WebView at a later time. + * Use the `Handled` property to let the WebView2 know whether to use its own drag logic. ##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2PermissionKind` Enum - * [CoreWebView2PermissionKind.MidiSystemExclusiveMessages Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +N/A -* `CoreWebView2PermissionRequestedEventArgs` Event - * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionrequestedeventargs.savesinprofile?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +##### [WinRT/C#](#tab/winrtcsharp) -* [CoreWebView2PermissionSetting Class](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionkind?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionorigin?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionstate?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +N/A + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2CompositionController5](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller5?view=webview2-1.0.3712-prerelease&preserve-view=true) + * [ICoreWebView2CompositionController5::add_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller5?view=webview2-1.0.3712-prerelease&preserve-view=true#add_dragstarting) + * [ICoreWebView2CompositionController5::remove_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller5?view=webview2-1.0.3712-prerelease&preserve-view=true#remove_dragstarting) + + +* [ICoreWebView2CompositionControllerInterop3](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop3?view=webview2-winrt-1.0.3712-prerelease&preserve-view=true) + * [ICoreWebView2CompositionControllerInterop3::add_DragStarting](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop3?view=webview2-winrt-1.0.3712-prerelease&preserve-view=true#add_dragstarting) + * [ICoreWebView2CompositionControllerInterop3::remove_DragStarting](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop3?view=webview2-winrt-1.0.3712-prerelease&preserve-view=true#remove_dragstarting) + +* [ICoreWebView2DragStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true) + * [ICoreWebView2DragStartingEventArgs::get_AllowedDropEffects](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true#get_alloweddropeffects) + * [ICoreWebView2DragStartingEventArgs::get_Data](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true#get_data) + * [ICoreWebView2DragStartingEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true#get_handled) + * [ICoreWebView2DragStartingEventArgs::get_Position](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true#get_position) + * [ICoreWebView2DragStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2DragStartingEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventargs?view=webview2-1.0.3712-prerelease&preserve-view=true#put_handled) + +* [ICoreWebView2DragStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2dragstartingeventhandler?view=webview2-1.0.3712-prerelease&preserve-view=true) + +--- + + +#### Bug fixes + +This Prerelease SDK includes the following bug fixes. + + +###### Runtime-only + +* Fixed local network access triggering a permission alert pop-up window. +* Fixed a regression of the `setColorScheme` API. +* Fixed deferred initialization for `ICoreWebView2NewWindowRequestedEventArgs` for the command-line switch `enable-new-window-requested-deferred-initialization`. + + + + + +## Release SDK 1.0.3650.58, for Runtime 143 (Dec. 8, 2025) + +Release Date: Dec. 8, 2025 + +[NuGet package for WebView2 SDK 1.0.3650.58](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3650.58) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 143.0.3650.58 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +###### Runtime-only + +* Fixed local network access triggering a permission alert pop-up window. + + + + + +## Prerelease SDK 1.0.3650-prerelease, for Runtime 143 (Nov. 7, 2025) + +Release Date: Nov. 7, 2025 + +[NuGet package for WebView2 SDK 1.0.3650-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3650-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 143.0.3650.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + +This Prerelease SDK includes the following bug fixes. + + + +###### Runtime-only + +* Disabled creation of a "Speculative Renderer" process. +* Fixed a **Find** dialog synchronization issue while programmatically doing a Find. + + + + + +## Release SDK 1.0.3595.46, for Runtime 142 (Nov. 3, 2025) + +Release Date: Nov. 3, 2025 + +[NuGet package for WebView2 SDK 1.0.3595.46](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3595.46) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 142.0.3595.46 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +This Release SDK includes the following bug fixes. + + + +###### Runtime-only + +* Disabled creation of a "Speculative Renderer" process. + + + + + +## Prerelease SDK 1.0.3590-prerelease, for Runtime 142 (Oct. 7, 2025) + +Release Date: Oct. 7, 2025 + +[NuGet package for WebView2 SDK 1.0.3590-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3590-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 142.0.3590.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. + + + +###### Sensitivity label support + +A new Sensitivity Info API in WebView2 enables applications to access sensitivity label information communicated by webpages through the [Page Interaction Restriction Manager](https://github.com/MicrosoftEdge/MSEdgeExplainers/blob/main/PageInteractionRestrictionManager/explainer.md). This feature helps host applications detect and respond to sensitive content. + +Key capabilities: + +* **Configure Page Interaction Restriction Manager availability** - Configure a list of URL filters for the Page Interaction Restriction Manager. After the list has been configured, the Page Interaction Restriction Manager becomes available on pages in the allow list. These pages can send sensitivity labels to the platform via the API. + +* **Sensitivity Info exposure** - `CoreWebView2` now exposes a `SensitivityInfo` property and a `SensitivityInfoChanged` event, allowing applications to listen for updates to sensitivity label information. + +Sensitivity label support is initially available on Win32 only. Support for .NET and WinRT is planned for a future release. + +##### [.NET/C#](#tab/dotnetcsharp) + +Pending. + +##### [WinRT/C#](#tab/winrtcsharp) + +Pending. + +##### [Win32/C++](#tab/win32cpp) + + +* [ICoreWebView2Experimental32](/microsoft-edge/webview2/reference/win32/icorewebview2experimental32?view=webview2-1.0.3590-prerelease&preserve-view=true) + * [ICoreWebView2Experimental32::add_SensitivityInfoChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimental32?view=webview2-1.0.3590-prerelease&preserve-view=true#add_sensitivityinfochanged) + * [ICoreWebView2Experimental32::get_SensitivityInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimental32?view=webview2-1.0.3590-prerelease&preserve-view=true#get_sensitivityinfo) + * [ICoreWebView2Experimental32::remove_SensitivityInfoChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimental32?view=webview2-1.0.3590-prerelease&preserve-view=true#remove_sensitivityinfochanged) + + +* [ICoreWebView2ExperimentalMipSensitivityLabel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalmipsensitivitylabel?view=webview2-1.0.3590-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalMipSensitivityLabel::get_LabelId](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalmipsensitivitylabel?view=webview2-1.0.3590-prerelease&preserve-view=true#get_labelid) + * [ICoreWebView2ExperimentalMipSensitivityLabel::get_OrganizationId](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalmipsensitivitylabel?view=webview2-1.0.3590-prerelease&preserve-view=true#get_organizationid) + + +* [ICoreWebView2ExperimentalProfile14](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile14?view=webview2-1.0.3590-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile14::SetPageInteractionRestrictionManagerAllowList](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile14?view=webview2-1.0.3590-prerelease&preserve-view=true#setpageinteractionrestrictionmanagerallowlist) + + +* [ICoreWebView2ExperimentalSensitivityInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivityinfo?view=webview2-1.0.3590-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSensitivityInfo::get_SensitivityLabels](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivityinfo?view=webview2-1.0.3590-prerelease&preserve-view=true#get_sensitivitylabels) + * [ICoreWebView2ExperimentalSensitivityInfo::get_SensitivityLabelsState](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivityinfo?view=webview2-1.0.3590-prerelease&preserve-view=true#get_sensitivitylabelsstate) + + +* [ICoreWebView2ExperimentalSensitivityInfoChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivityinfochangedeventhandler?view=webview2-1.0.3590-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalSensitivityLabel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivitylabel?view=webview2-1.0.3590-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSensitivityLabel::get_LabelKind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivitylabel?view=webview2-1.0.3590-prerelease&preserve-view=true#get_labelkind) + + +* [ICoreWebView2ExperimentalSensitivityLabelCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivitylabelcollectionview?view=webview2-1.0.3590-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSensitivityLabelCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivitylabelcollectionview?view=webview2-1.0.3590-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalSensitivityLabelCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsensitivitylabelcollectionview?view=webview2-1.0.3590-prerelease&preserve-view=true#getvalueatindex) + +* [COREWEBVIEW2_SENSITIVITY_LABEL_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3590-prerelease&preserve-view=true#corewebview2_sensitivity_label_kind) + * `COREWEBVIEW2_SENSITIVITY_LABEL_KIND_MIP` + +* [COREWEBVIEW2_SENSITIVITY_LABELS_STATE enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.3590-prerelease&preserve-view=true#corewebview2_sensitivity_labels_state) + * `COREWEBVIEW2_SENSITIVITY_LABELS_STATE_NOT_APPLICABLE` + * `COREWEBVIEW2_SENSITIVITY_LABELS_STATE_PENDING` + * `COREWEBVIEW2_SENSITIVITY_LABELS_STATE_AVAILABLE` + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + +This Prerelease SDK includes the following bug fixes. + + + +###### Runtime-only + +* Fixed a dangling pointer in file system access permission context. +* Fixed the UI hanging during drag-and-drop in WinUI3. +* Fixed local network access triggering a permission alert pop-up window. +* Resolved an issue where an extra region was appearing in the accessibility tree. +* Fixed an issue where downloads in the default browser frame didn't work. + + + +###### SDK-only + +* Fixed a BinSkim error for `WebView2Loader.dll`. + + + + + +## Release SDK 1.0.3537.50, for Runtime 141 (Oct. 6, 2025) + +Release Date: Oct. 6, 2025 + +[NuGet package for WebView2 SDK 1.0.3537.50](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3537.50) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 141.0.3537.50 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +This Release SDK includes the following bug fixes. + + + +###### Runtime-only + +* Fixed local network access triggering a permission alert pop-up window. + + + +###### SDK-only + +* Fixed a BinSkim error for `WebView2Loader.dll`. + + + + + +## Prerelease SDK 1.0.3530-prerelease, for Runtime 141 (Sep. 8, 2025) + +Release Date: Sep. 8, 2025 + +[NuGet package for WebView2 SDK 1.0.3530-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3530-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 141.0.3530.0 or higher. + + + +#### General changes + +This Prerelease SDK focuses on making WebView2 work better, through behind-the-scenes improvements. +* The testing infrastructure has been strengthened. +* The validation of APIs has been enhanced, to ensure that the APIs perform reliably across different scenarios. + +These foundational improvements provide stable, thoroughly tested functionality for building WebView2 apps. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + +This Prerelease SDK includes the following bug fixes. + + + +###### SDK-only + +* Fixed a memory leak in WPF Composition Controller. + + + + + +## Release SDK 1.0.3485.44, for Runtime 140 (Sep. 8, 2025) + +Release Date: Sep. 8, 2025 + +[NuGet package for WebView2 SDK 1.0.3485.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3485.44) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 140.0.3485.44 or higher. + + + +#### General changes + +This Release SDK focuses on making WebView2 work better, through behind-the-scenes improvements. +* The testing infrastructure has been strengthened. +* The validation of APIs has been enhanced, to ensure that the APIs perform reliably across different scenarios. + +These foundational improvements provide stable, thoroughly tested functionality for building WebView2 apps. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +There are no bug fixes in this Release SDK. + + + + + +## Prerelease SDK 1.0.3477-prerelease, for Runtime 140 (Aug. 11, 2025) + +Release Date: Aug. 11, 2025 + +[NuGet package for WebView2 SDK 1.0.3477-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3477-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 140.0.3477.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed `put_UserAgent` not working for service workers. +* Fixed a crash in Devtools on Windows Server and Windows 10. +* Removed browser process tracking after calling `remove_BrowserProcessExited`. +* Fixed a memory leak issue in `hostObject` async function calls. +* Fixed touch not working in visual hosting after a long tap. + + + + + +## Prerelease SDK 1.0.3415-prerelease, for Runtime 140 (Jul. 14, 2025) + +Release Date: Jul. 14, 2025 + +[NuGet package for WebView2 SDK 1.0.3415-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3415-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 140.0.3415.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following APIs are in Phase 1: Experimental in Prerelease, and have been added in this Prerelease SDK. + + + +###### Enable background processing and offline support (WebView2 Worker APIs) + +The WebView2 Worker APIs allow host applications to interact with Web Workers to offload tasks from the main thread, improve responsiveness, and support background operations. These Web Workers include Dedicated Workers, Shared Workers, and Service Workers. + +These APIs provide: +* **Lifecycle Events:** Monitor creation and destruction of workers. +* **Messaging Interfaces:** Communicate with workers using `PostMessage` and `WebMessageReceived`; specifically: + * `CoreWebView2ServiceWorker.PostWebMessageAsJson` + * `CoreWebView2ServiceWorker.PostWebMessageAsString` + * `CoreWebView2DedicatedWorker.PostWebMessageAsJson` + * `CoreWebView2DedicatedWorker.PostWebMessageAsString` + * `CoreWebView2ServiceWorker.WebMessageReceived` + * `CoreWebView2DedicatedWorker.WebMessageReceived` + * `chrome.webview.postMessage` + * Not: `chrome.webview.postMessageWithAdditionalObjects` +* **Worker Management:** Query and retrieve worker registrations and instances. + +##### [.NET/C#](#tab/dotnetcsharp) + + +* `CoreWebView2` Class: + * [CoreWebView2.DedicatedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.dedicatedworkercreated?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2DedicatedWorker Class](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.DedicatedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.dedicatedworkercreated?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.Destroying Event](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.destroying?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.PostWebMessageAsJson Method](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.postwebmessageasjson?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.PostWebMessageAsString Method](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.postwebmessageasstring?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.ScriptUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.scripturi?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.WebMessageReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworker.webmessagereceived?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2DedicatedWorkerCreatedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworkercreatedeventargs?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworkercreatedeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.Worker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2dedicatedworkercreatedeventargs.worker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.DedicatedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.dedicatedworkercreated?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.ServiceWorkerManager Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.serviceworkermanager?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Profile.SharedWorkerManager Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.sharedworkermanager?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorker Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.Destroying Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.destroying?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.PostWebMessageAsJson Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.postwebmessageasjson?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.PostWebMessageAsString Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.postwebmessageasstring?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.ScriptUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.scripturi?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.WebMessageReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworker.webmessagereceived?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerActivatedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkeractivatedeventargs?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerActivatedEventArgs.ActiveServiceWorker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkeractivatedeventargs.activeserviceworker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerManager Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.getserviceworkerregistrationsasync?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.getserviceworkerregistrationsasync?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.ServiceWorkerRegistered Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkermanager.serviceworkerregistered?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerRegisteredEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregisteredeventargs?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegisteredEventArgs.ServiceWorkerRegistration Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregisteredeventargs.serviceworkerregistration?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2ServiceWorkerRegistration Class](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ActiveServiceWorker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.activeserviceworker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.Origin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.origin?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ScopeUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.scopeuri?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ServiceWorkerActivated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.serviceworkeractivated?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.TopLevelOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.toplevelorigin?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.Unregistering Event](/dotnet/api/microsoft.web.webview2.core.corewebview2serviceworkerregistration.unregistering?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2SharedWorker Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.Destroying Event](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.destroying?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.Origin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.origin?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.ScriptUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.scripturi?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.TopLevelOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworker.toplevelorigin?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2SharedWorkerCreatedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkercreatedeventargs?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerCreatedEventArgs.Worker Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkercreatedeventargs.worker?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + + +* [CoreWebView2SharedWorkerManager Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkermanager?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerManager.GetSharedWorkersAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkermanager.getsharedworkersasync?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerManager.SharedWorkerCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedworkermanager.sharedworkercreated?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + + +* `CoreWebView2` Class: + * [CoreWebView2.DedicatedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#dedicatedworkercreated) + + +* [CoreWebView2DedicatedWorker Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorker.DedicatedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#dedicatedworkercreated) + * [CoreWebView2DedicatedWorker.Destroying Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#destroying) + * [CoreWebView2DedicatedWorker.PostWebMessageAsJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#postwebmessageasjson) + * [CoreWebView2DedicatedWorker.PostWebMessageAsString Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#postwebmessageasstring) + * [CoreWebView2DedicatedWorker.ScriptUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#scripturi) + * [CoreWebView2DedicatedWorker.WebMessageReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#webmessagereceived) + + +* [CoreWebView2DedicatedWorkerCreatedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworkercreatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.Worker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworkercreatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#worker) + * [CoreWebView2DedicatedWorkerCreatedEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2dedicatedworkercreatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#originalsourceframeinfo) + + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.DedicatedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#dedicatedworkercreated) + + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.ServiceWorkerManager Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#serviceworkermanager) + * [CoreWebView2Profile.SharedWorkerManager Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#sharedworkermanager) + + +* [CoreWebView2ServiceWorker Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorker.Destroying Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#destroying) + * [CoreWebView2ServiceWorker.PostWebMessageAsJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#postwebmessageasjson) + * [CoreWebView2ServiceWorker.PostWebMessageAsString Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#postwebmessageasstring) + * [CoreWebView2ServiceWorker.ScriptUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#scripturi) + * [CoreWebView2ServiceWorker.WebMessageReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#webmessagereceived) + + +* [CoreWebView2ServiceWorkerActivatedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkeractivatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerActivatedEventArgs.ActiveServiceWorker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkeractivatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#activeserviceworker) + + +* [CoreWebView2ServiceWorkerManager Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#getserviceworkerregistrationsasync) + * [CoreWebView2ServiceWorkerManager.GetServiceWorkerRegistrationsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#getserviceworkerregistrationsasync) + * [CoreWebView2ServiceWorkerManager.ServiceWorkerRegistered Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#serviceworkerregistered) + + +* [CoreWebView2ServiceWorkerRegisteredEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregisteredeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegisteredEventArgs.ServiceWorkerRegistration Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregisteredeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#serviceworkerregistration) + + +* [CoreWebView2ServiceWorkerRegistration Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2ServiceWorkerRegistration.ActiveServiceWorker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#activeserviceworker) + * [CoreWebView2ServiceWorkerRegistration.Origin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#origin) + * [CoreWebView2ServiceWorkerRegistration.ScopeUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#scopeuri) + * [CoreWebView2ServiceWorkerRegistration.ServiceWorkerActivated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#serviceworkeractivated) + * [CoreWebView2ServiceWorkerRegistration.TopLevelOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#toplevelorigin) + * [CoreWebView2ServiceWorkerRegistration.Unregistering Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2serviceworkerregistration?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#unregistering) + + +* [CoreWebView2SharedWorker Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorker.Destroying Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#destroying) + * [CoreWebView2SharedWorker.Origin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#origin) + * [CoreWebView2SharedWorker.ScriptUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#scripturi) + * [CoreWebView2SharedWorker.TopLevelOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworker?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#toplevelorigin) + + +* [CoreWebView2SharedWorkerCreatedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkercreatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerCreatedEventArgs.Worker Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkercreatedeventargs?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#worker) + + +* [CoreWebView2SharedWorkerManager Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2SharedWorkerManager.GetSharedWorkersAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#getsharedworkersasync) + * [CoreWebView2SharedWorkerManager.SharedWorkerCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedworkermanager?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#sharedworkercreated) + +##### [Win32/C++](#tab/win32cpp) + + +* [ICoreWebView2Experimental30](/microsoft-edge/webview2/reference/win32/icorewebview2experimental30?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2Experimental30::add_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimental30?view=webview2-1.0.3415-prerelease&preserve-view=true#add_dedicatedworkercreated) + * [ICoreWebView2Experimental30::remove_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimental30?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_dedicatedworkercreated) + + +* [ICoreWebView2ExperimentalDedicatedWorker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalDedicatedWorker::add_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#add_dedicatedworkercreated) + * [ICoreWebView2ExperimentalDedicatedWorker::add_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#add_destroying) + * [ICoreWebView2ExperimentalDedicatedWorker::add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#add_webmessagereceived) + * [ICoreWebView2ExperimentalDedicatedWorker::get_ScriptUri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#get_scripturi) + * [ICoreWebView2ExperimentalDedicatedWorker::PostWebMessageAsJson](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#postwebmessageasjson) + * [ICoreWebView2ExperimentalDedicatedWorker::PostWebMessageAsString](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#postwebmessageasstring) + * [ICoreWebView2ExperimentalDedicatedWorker::remove_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_dedicatedworkercreated) + * [ICoreWebView2ExperimentalDedicatedWorker::remove_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_destroying) + * [ICoreWebView2ExperimentalDedicatedWorker::remove_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_webmessagereceived) + + +* [ICoreWebView2ExperimentalDedicatedWorkerCreatedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkercreatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalDedicatedWorkerCreatedEventArgs::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkercreatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true#get_originalsourceframeinfo) + * [ICoreWebView2ExperimentalDedicatedWorkerCreatedEventArgs::get_Worker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkercreatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true#get_worker) + + +* [ICoreWebView2ExperimentalDedicatedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkercreatedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalDedicatedWorkerDedicatedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkerdedicatedworkercreatedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalDedicatedWorkerDestroyingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkerdestroyingeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalDedicatedWorkerWebMessageReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldedicatedworkerwebmessagereceivedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalFrame9](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe9?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFrame9::add_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe9?view=webview2-1.0.3415-prerelease&preserve-view=true#add_dedicatedworkercreated) + * [ICoreWebView2ExperimentalFrame9::remove_DedicatedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe9?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_dedicatedworkercreated) + + +* [ICoreWebView2ExperimentalFrameDedicatedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframededicatedworkercreatedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalGetServiceWorkerRegistrationsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgetserviceworkerregistrationscompletedhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalGetSharedWorkersCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgetsharedworkerscompletedhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalProfile13](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile13?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile13::get_ServiceWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile13?view=webview2-1.0.3415-prerelease&preserve-view=true#get_serviceworkermanager) + * [ICoreWebView2ExperimentalProfile13::get_SharedWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile13?view=webview2-1.0.3415-prerelease&preserve-view=true#get_sharedworkermanager) + + +* [ICoreWebView2ExperimentalServiceWorker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalServiceWorker::add_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#add_destroying) + * [ICoreWebView2ExperimentalServiceWorker::add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#add_webmessagereceived) + * [ICoreWebView2ExperimentalServiceWorker::get_ScriptUri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#get_scripturi) + * [ICoreWebView2ExperimentalServiceWorker::PostWebMessageAsJson](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#postwebmessageasjson) + * [ICoreWebView2ExperimentalServiceWorker::PostWebMessageAsString](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#postwebmessageasstring) + * [ICoreWebView2ExperimentalServiceWorker::remove_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_destroying) + * [ICoreWebView2ExperimentalServiceWorker::remove_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworker?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_webmessagereceived) + + +* [ICoreWebView2ExperimentalServiceWorkerActivatedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkeractivatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalServiceWorkerActivatedEventArgs::get_ActiveServiceWorker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkeractivatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true#get_activeserviceworker) + + +* [ICoreWebView2ExperimentalServiceWorkerActivatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkeractivatedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalServiceWorkerDestroyingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerdestroyingeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalServiceWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalServiceWorkerManager::add_ServiceWorkerRegistered](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#add_serviceworkerregistered) + * [ICoreWebView2ExperimentalServiceWorkerManager::GetServiceWorkerRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#getserviceworkerregistrations) + * [ICoreWebView2ExperimentalServiceWorkerManager::GetServiceWorkerRegistrationsForScope](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#getserviceworkerregistrationsforscope) + * [ICoreWebView2ExperimentalServiceWorkerManager::remove_ServiceWorkerRegistered](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_serviceworkerregistered) + + +* [ICoreWebView2ExperimentalServiceWorkerRegisteredEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregisteredeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalServiceWorkerRegisteredEventArgs::get_ServiceWorkerRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregisteredeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true#get_serviceworkerregistration) + + +* [ICoreWebView2ExperimentalServiceWorkerRegisteredEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregisteredeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalServiceWorkerRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::add_ServiceWorkerActivated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#add_serviceworkeractivated) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::add_Unregistering](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#add_unregistering) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::get_ActiveServiceWorker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#get_activeserviceworker) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::get_Origin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#get_origin) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::get_ScopeUri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#get_scopeuri) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::get_TopLevelOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#get_toplevelorigin) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::remove_ServiceWorkerActivated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_serviceworkeractivated) + * [ICoreWebView2ExperimentalServiceWorkerRegistration::remove_Unregistering](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistration?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_unregistering) + + +* [ICoreWebView2ExperimentalServiceWorkerRegistrationCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistrationcollectionview?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalServiceWorkerRegistrationCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistrationcollectionview?view=webview2-1.0.3415-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalServiceWorkerRegistrationCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistrationcollectionview?view=webview2-1.0.3415-prerelease&preserve-view=true#getvalueatindex) + + +* [ICoreWebView2ExperimentalServiceWorkerRegistrationUnregisteringEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerregistrationunregisteringeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalServiceWorkerWebMessageReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalserviceworkerwebmessagereceivedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalSharedWorker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworker?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSharedWorker::add_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#add_destroying) + * [ICoreWebView2ExperimentalSharedWorker::get_Origin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#get_origin) + * [ICoreWebView2ExperimentalSharedWorker::get_ScriptUri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#get_scripturi) + * [ICoreWebView2ExperimentalSharedWorker::get_TopLevelOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#get_toplevelorigin) + * [ICoreWebView2ExperimentalSharedWorker::remove_Destroying](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworker?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_destroying) + + +* [ICoreWebView2ExperimentalSharedWorkerCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkercollectionview?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSharedWorkerCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkercollectionview?view=webview2-1.0.3415-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalSharedWorkerCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkercollectionview?view=webview2-1.0.3415-prerelease&preserve-view=true#getvalueatindex) + + +* [ICoreWebView2ExperimentalSharedWorkerCreatedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkercreatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSharedWorkerCreatedEventArgs::get_Worker](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkercreatedeventargs?view=webview2-1.0.3415-prerelease&preserve-view=true#get_worker) + + +* [ICoreWebView2ExperimentalSharedWorkerCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkercreatedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalSharedWorkerDestroyingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkerdestroyingeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + + +* [ICoreWebView2ExperimentalSharedWorkerManager](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSharedWorkerManager::add_SharedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#add_sharedworkercreated) + * [ICoreWebView2ExperimentalSharedWorkerManager::GetSharedWorkers](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#getsharedworkers) + * [ICoreWebView2ExperimentalSharedWorkerManager::remove_SharedWorkerCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedworkermanager?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_sharedworkercreated) + +--- + + + +###### Render custom title bars (Window Controls Overlay API) + +The Window Controls Overlay API enables developers to create custom title bars by rendering caption buttons (minimize, maximize, restore, close) directly inside the WebView2 window. The Window Controls Overlay appears in the top corner of the WebView, and integrates seamlessly with your app's UI. + +Use this API when: +* You want to replace the default OS title bar with a fully customized in-app title bar. +* You're working with non-client region features, such as `app-region: drag` and `IsNonClientRegionSupportEnabled`. + +This API is ideal for apps that require a modern, immersive UI experience. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.WindowControlsOverlay Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.windowcontrolsoverlay?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +* [CoreWebView2WindowControlsOverlay Class](/dotnet/api/microsoft.web.webview2.core.corewebview2windowcontrolsoverlay?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2WindowControlsOverlay.IsEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2windowcontrolsoverlay.isenabled?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2WindowControlsOverlay.BackgroundColor Property](/dotnet/api/microsoft.web.webview2.core.corewebview2windowcontrolsoverlay.backgroundcolor?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2WindowControlsOverlay.Height Property](/dotnet/api/microsoft.web.webview2.core.corewebview2windowcontrolsoverlay.height?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.WindowControlsOverlay Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#windowcontrolsoverlay) + +* [CoreWebView2WindowControlsOverlay Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2windowcontrolsoverlay?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2WindowControlsOverlay.IsEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2windowcontrolsoverlay?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#isenabled) + * [CoreWebView2WindowControlsOverlay.BackgroundColor Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2windowcontrolsoverlay?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#backgroundcolor) + * [CoreWebView2WindowControlsOverlay.Height Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2windowcontrolsoverlay?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#height) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental31](/microsoft-edge/webview2/reference/win32/icorewebview2experimental31?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2Experimental31::get_WindowControlsOverlay](/microsoft-edge/webview2/reference/win32/icorewebview2experimental31?view=webview2-1.0.3415-prerelease&preserve-view=true#get_windowcontrolsoverlay) + +* [ICoreWebView2ExperimentalWindowControlsOverlay](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalWindowControlsOverlay::get_BackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true#get_backgroundcolor) + * [ICoreWebView2ExperimentalWindowControlsOverlay::get_Height](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true#get_height) + * [ICoreWebView2ExperimentalWindowControlsOverlay::get_IsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true#get_isenabled) + * [ICoreWebView2ExperimentalWindowControlsOverlay::put_BackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true#put_backgroundcolor) + * [ICoreWebView2ExperimentalWindowControlsOverlay::put_Height](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true#put_height) + * [ICoreWebView2ExperimentalWindowControlsOverlay::put_IsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowcontrolsoverlay?view=webview2-1.0.3415-prerelease&preserve-view=true#put_isenabled) + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Customize the Find behavior (Find API) + +The Find API allows you to programmatically control **Find** operations, and enables adding the following functionality to your app: +* Customize **Find** options, including **Find Term**, **Case Sensitivity**, **Word Matching**, **Match Highlighting**, and **Default UI Suppression**. +* Find text strings and navigate among them within a WebView2 control. +* Programmatically initiate **Find** operations, and navigate **Find** results. +* Suppress the default **Find** UI. +* Track the status of **Find** operations. + +There are known issues with the Find API for PDF documents. When you view a PDF document within a WebView2 control, the **Find** feature currently only provides the first index and the number of matches found. For example, if the string occurs three times in a PDF, the UI would say **1/3** and would not support programmatically calling **Next** or **Previous**. + +We're actively investigating these issues, and we encourage you to report any problems you encounter, by using the [WebView2Feedback](https://github.com/MicrosoftEdge/WebViewFeedback) repo. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.Find Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.find?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateFindOptions Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createfindoptions?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +* [CoreWebView2Find Class](/dotnet/api/microsoft.web.webview2.core.corewebview2find?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2find.activematchindex?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndexChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2find.activematchindexchanged?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.FindNext Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findnext?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.FindPrevious Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findprevious?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.MatchCount Property](/dotnet/api/microsoft.web.webview2.core.corewebview2find.matchcount?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.MatchCountChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2find.matchcountchanged?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.StartAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.startasync?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.Stop Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.stop?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +* [CoreWebView2FindOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.FindTerm Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.findterm?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.IsCaseSensitive Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.iscasesensitive?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.ShouldHighlightAllMatches Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.shouldhighlightallmatches?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.ShouldMatchWord Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.shouldmatchword?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.SuppressDefaultFindDialog Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.suppressdefaultfinddialog?view=webview2-dotnet-1.0.3415-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.Find Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#find) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateFindOptions Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#createfindoptions) + +* [CoreWebView2Find Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#activematchindex) + * [CoreWebView2Find.ActiveMatchIndexChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#activematchindexchanged) + * [CoreWebView2Find.FindNext Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#findnext) + * [CoreWebView2Find.FindPrevious Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#findprevious) + * [CoreWebView2Find.MatchCount Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#matchcount) + * [CoreWebView2Find.MatchCountChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#matchcountchanged) + * [CoreWebView2Find.StartAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#startasync) + * [CoreWebView2Find.Stop Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#stop) + +* [CoreWebView2FindOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.FindTerm Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#findterm) + * [CoreWebView2FindOptions.IsCaseSensitive Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#iscasesensitive) + * [CoreWebView2FindOptions.ShouldHighlightAllMatches Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#shouldhighlightallmatches) + * [CoreWebView2FindOptions.ShouldMatchWord Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#shouldmatchword) + * [CoreWebView2FindOptions.SuppressDefaultFindDialog Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3415-prerelease&preserve-view=true#suppressdefaultfinddialog) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_28](/microsoft-edge/webview2/reference/win32/icorewebview2_28?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2_28::get_Find](/microsoft-edge/webview2/reference/win32/icorewebview2_28?view=webview2-1.0.3415-prerelease&preserve-view=true#get_find) + +* [ICoreWebView2Environment15](/microsoft-edge/webview2/reference/win32/icorewebview2environment15?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2Environment15::CreateFindOptions](/microsoft-edge/webview2/reference/win32/icorewebview2environment15?view=webview2-1.0.3415-prerelease&preserve-view=true#createfindoptions) + +* [ICoreWebView2Find](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2Find::add_ActiveMatchIndexChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#add_activematchindexchanged) + * [ICoreWebView2Find::add_MatchCountChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#add_matchcountchanged) + * [ICoreWebView2Find::FindNext](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#findnext) + * [ICoreWebView2Find::FindPrevious](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#findprevious) + * [ICoreWebView2Find::get_ActiveMatchIndex](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#get_activematchindex) + * [ICoreWebView2Find::get_MatchCount](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#get_matchcount) + * [ICoreWebView2Find::remove_ActiveMatchIndexChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_activematchindexchanged) + * [ICoreWebView2Find::remove_MatchCountChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#remove_matchcountchanged) + * [ICoreWebView2Find::Start](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#start) + * [ICoreWebView2Find::Stop](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3415-prerelease&preserve-view=true#stop) + +* [ICoreWebView2FindActiveMatchIndexChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2findactivematchindexchangedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + +* [ICoreWebView2FindMatchCountChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2findmatchcountchangedeventhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + +* [ICoreWebView2FindOptions](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true) + * [ICoreWebView2FindOptions::get_FindTerm](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#get_findterm) + * [ICoreWebView2FindOptions::get_IsCaseSensitive](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#get_iscasesensitive) + * [ICoreWebView2FindOptions::get_ShouldHighlightAllMatches](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#get_shouldhighlightallmatches) + * [ICoreWebView2FindOptions::get_ShouldMatchWord](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#get_shouldmatchword) + * [ICoreWebView2FindOptions::get_SuppressDefaultFindDialog](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#get_suppressdefaultfinddialog) + * [ICoreWebView2FindOptions::put_FindTerm](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#put_findterm) + * [ICoreWebView2FindOptions::put_IsCaseSensitive](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#put_iscasesensitive) + * [ICoreWebView2FindOptions::put_ShouldHighlightAllMatches](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#put_shouldhighlightallmatches) + * [ICoreWebView2FindOptions::put_ShouldMatchWord](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#put_shouldmatchword) + * [ICoreWebView2FindOptions::put_SuppressDefaultFindDialog](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3415-prerelease&preserve-view=true#put_suppressdefaultfinddialog) + +* [ICoreWebView2FindStartCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2findstartcompletedhandler?view=webview2-1.0.3415-prerelease&preserve-view=true) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a blackbox issue on dialogs in visual hosting. +* Fixed `put_UserAgent` not working for service workers. +* Fixed crash in DevTools on Windows Server and Windows 10. + + + + + +## Release SDK 1.0.3405.78, for Runtime 139 (Aug. 11, 2025) + +Release Date: Aug. 11, 2025 + +[NuGet package for WebView2 SDK 1.0.3405.78](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3405.78) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 139.0.3405.78 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Customize the Find behavior (Find API) + +The Find API allows you to programmatically control **Find** operations, and enables adding the following functionality to your app: +* Customize **Find** options, including **Find Term**, **Case Sensitivity**, **Word Matching**, **Match Highlighting**, and **Default UI Suppression**. +* Find text strings and navigate among them within a WebView2 control. +* Programmatically initiate **Find** operations, and navigate **Find** results. +* Suppress the default **Find** UI. +* Track the status of **Find** operations. + +There are known issues with the Find API for PDF documents. When you view a PDF document within a WebView2 control, the **Find** feature currently only provides the first index and the number of matches found. For example, if the string occurs three times in a PDF, the UI would say **1/3** and would not support programmatically calling **Next** or **Previous**. + +We're actively investigating these issues, and we encourage you to report any problems you encounter, by using the [WebView2Feedback](https://github.com/MicrosoftEdge/WebViewFeedback) repo. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.Find Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.find?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateFindOptions Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createfindoptions?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + +* [CoreWebView2Find Class](/dotnet/api/microsoft.web.webview2.core.corewebview2find?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2find.activematchindex?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndexChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2find.activematchindexchanged?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.FindNext Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findnext?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.FindPrevious Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findprevious?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.MatchCount Property](/dotnet/api/microsoft.web.webview2.core.corewebview2find.matchcount?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.MatchCountChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2find.matchcountchanged?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.StartAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.startasync?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.Stop Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.stop?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + +* [CoreWebView2FindOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2FindOptions.FindTerm Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.findterm?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2FindOptions.IsCaseSensitive Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.iscasesensitive?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2FindOptions.ShouldHighlightAllMatches Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.shouldhighlightallmatches?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2FindOptions.ShouldMatchWord Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.shouldmatchword?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + * [CoreWebView2FindOptions.SuppressDefaultFindDialog Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.suppressdefaultfinddialog?view=webview2-dotnet-1.0.3405.78&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.Find Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.3405.78&preserve-view=true#find) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateFindOptions Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.3405.78&preserve-view=true#createfindoptions) + +* [CoreWebView2Find Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#activematchindex) + * [CoreWebView2Find.ActiveMatchIndexChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#activematchindexchanged) + * [CoreWebView2Find.FindNext Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#findnext) + * [CoreWebView2Find.FindPrevious Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#findprevious) + * [CoreWebView2Find.MatchCount Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#matchcount) + * [CoreWebView2Find.MatchCountChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#matchcountchanged) + * [CoreWebView2Find.StartAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#startasync) + * [CoreWebView2Find.Stop Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3405.78&preserve-view=true#stop) + +* [CoreWebView2FindOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3405.78&preserve-view=true) + * [CoreWebView2FindOptions.FindTerm Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3405.78&preserve-view=true#findterm) + * [CoreWebView2FindOptions.IsCaseSensitive Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3405.78&preserve-view=true#iscasesensitive) + * [CoreWebView2FindOptions.ShouldHighlightAllMatches Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3405.78&preserve-view=true#shouldhighlightallmatches) + * [CoreWebView2FindOptions.ShouldMatchWord Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3405.78&preserve-view=true#shouldmatchword) + * [CoreWebView2FindOptions.SuppressDefaultFindDialog Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3405.78&preserve-view=true#suppressdefaultfinddialog) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_28](/microsoft-edge/webview2/reference/win32/icorewebview2_28?view=webview2-1.0.3405.78&preserve-view=true) + * [ICoreWebView2_28::get_Find](/microsoft-edge/webview2/reference/win32/icorewebview2_28?view=webview2-1.0.3405.78&preserve-view=true#get_find) + +* [ICoreWebView2Environment15](/microsoft-edge/webview2/reference/win32/icorewebview2environment15?view=webview2-1.0.3405.78&preserve-view=true) + * [ICoreWebView2Environment15::CreateFindOptions](/microsoft-edge/webview2/reference/win32/icorewebview2environment15?view=webview2-1.0.3405.78&preserve-view=true#createfindoptions) + +* [ICoreWebView2Find](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true) + * [ICoreWebView2Find::add_ActiveMatchIndexChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#add_activematchindexchanged) + * [ICoreWebView2Find::add_MatchCountChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#add_matchcountchanged) + * [ICoreWebView2Find::FindNext](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#findnext) + * [ICoreWebView2Find::FindPrevious](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#findprevious) + * [ICoreWebView2Find::get_ActiveMatchIndex](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#get_activematchindex) + * [ICoreWebView2Find::get_MatchCount](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#get_matchcount) + * [ICoreWebView2Find::remove_ActiveMatchIndexChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#remove_activematchindexchanged) + * [ICoreWebView2Find::remove_MatchCountChanged](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#remove_matchcountchanged) + * [ICoreWebView2Find::Start](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#start) + * [ICoreWebView2Find::Stop](/microsoft-edge/webview2/reference/win32/icorewebview2find?view=webview2-1.0.3405.78&preserve-view=true#stop) + +* [ICoreWebView2FindActiveMatchIndexChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2findactivematchindexchangedeventhandler?view=webview2-1.0.3405.78&preserve-view=true) + +* [ICoreWebView2FindMatchCountChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2findmatchcountchangedeventhandler?view=webview2-1.0.3405.78&preserve-view=true) + +* [ICoreWebView2FindOptions](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true) + * [ICoreWebView2FindOptions::get_FindTerm](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#get_findterm) + * [ICoreWebView2FindOptions::get_IsCaseSensitive](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#get_iscasesensitive) + * [ICoreWebView2FindOptions::get_ShouldHighlightAllMatches](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#get_shouldhighlightallmatches) + * [ICoreWebView2FindOptions::get_ShouldMatchWord](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#get_shouldmatchword) + * [ICoreWebView2FindOptions::get_SuppressDefaultFindDialog](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#get_suppressdefaultfinddialog) + * [ICoreWebView2FindOptions::put_FindTerm](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#put_findterm) + * [ICoreWebView2FindOptions::put_IsCaseSensitive](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#put_iscasesensitive) + * [ICoreWebView2FindOptions::put_ShouldHighlightAllMatches](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#put_shouldhighlightallmatches) + * [ICoreWebView2FindOptions::put_ShouldMatchWord](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#put_shouldmatchword) + * [ICoreWebView2FindOptions::put_SuppressDefaultFindDialog](/microsoft-edge/webview2/reference/win32/icorewebview2findoptions?view=webview2-1.0.3405.78&preserve-view=true#put_suppressdefaultfinddialog) + +* [ICoreWebView2FindStartCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2findstartcompletedhandler?view=webview2-1.0.3405.78&preserve-view=true) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a crash in Devtools on Windows Server and Windows 10. + + + + + +## Release SDK 1.0.3351.48, for Runtime 138 (Jul. 1, 2025) + +Release Date: Jul. 1, 2025 + +[NuGet package for WebView2 SDK 1.0.3351.48](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3351.48) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 138.0.3351.48 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Allow input event messages to pass through the browser window + +The `CoreWebView2ControllerOptions` class now has an `AllowHostInputProcessing` property, which allows user input event messages (keyboard, mouse, touch, or pen) to pass through the browser window, to be received by an app process window. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.AllowHostInputProcessing Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.allowhostinputprocessing?view=webview2-dotnet-1.0.3351.48&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.AllowHostInputProcessing Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.3351.48&preserve-view=true#allowhostinputprocessing) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ControllerOptions4](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions4?view=webview2-1.0.3351.48&preserve-view=true) + * [ICoreWebView2ControllerOptions4::get_AllowHostInputProcessing](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions4?view=webview2-1.0.3351.48&preserve-view=true#get_allowhostinputprocessing) + * [ICoreWebView2ControllerOptions4::put_AllowHostInputProcessing](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions4?view=webview2-1.0.3351.48&preserve-view=true#put_allowhostinputprocessing) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a blackbox issue on dialogs in visual hosting. + + + + + +## Prerelease SDK 1.0.3344-prerelease, for Runtime 138 (Jun. 3, 2025) + +Release Date: Jun. 3, 2025 + +[NuGet package for WebView2 SDK 1.0.3344-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3344-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 138.0.3344.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Allow input event messages to pass through the browser window + +The `CoreWebView2ControllerOptions` class now has an `AllowHostInputProcessing` property, which allows user input event messages (keyboard, mouse, touch, or pen) to pass through the browser window, to be received by an app process window. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.AllowHostInputProcessing Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.allowhostinputprocessing?view=webview2-dotnet-1.0.3344-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.AllowHostInputProcessing Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.3344-prerelease&preserve-view=true#allowhostinputprocessing) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ControllerOptions4](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions4?view=webview2-1.0.3344-prerelease&preserve-view=true) + * [ICoreWebView2ControllerOptions4::get_AllowHostInputProcessing](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions4?view=webview2-1.0.3344-prerelease&preserve-view=true#get_allowhostinputprocessing) + * [ICoreWebView2ControllerOptions4::put_AllowHostInputProcessing](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions4?view=webview2-1.0.3344-prerelease&preserve-view=true#put_allowhostinputprocessing) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a bug where a mouse event doesn't fire after a touch event. +* Disabled Web capture on the WebView2 control. +* Fixed the **Downloads** dialog. +* Fixed an issue with downloads in the default browser frame. ([Issue #5196](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5196)) +* Fixed the margins in the printed PDF. + + + + + +## Release SDK 1.0.3296.44, for Runtime 137 (Jun. 3, 2025) + +Release Date: Jun. 3, 2025 + +[NuGet package for WebView2 SDK 1.0.3296.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3296.44) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 137.0.3296.44 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Set default background color on WebView2 initialization (DefaultBackgroundColor API) + +The DefaultBackgroundColor API allows users to set the `DefaultBackgroundColor` property at initialization. This prevents a disruptive white flash during the WebView2 loading process. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.DefaultBackgroundColor Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.defaultbackgroundcolor?view=webview2-dotnet-1.0.3296.44&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.DefaultBackgroundColor Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.3296.44&preserve-view=true#defaultbackgroundcolor) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ControllerOptions3](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions3?view=webview2-1.0.3296.44&preserve-view=true) + * [ICoreWebView2ControllerOptions3::get_DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions3?view=webview2-1.0.3296.44&preserve-view=true#get_defaultbackgroundcolor) + * [ICoreWebView2ControllerOptions3::put_DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions3?view=webview2-1.0.3296.44&preserve-view=true#put_defaultbackgroundcolor) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed the margins in the printed PDF. + + + + + +## Prerelease SDK 1.0.3296-prerelease, for Runtime 137 (May. 12, 2025) + +Release Date: May 12, 2025 + +[NuGet package for WebView2 SDK 1.0.3296-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3296-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 137.0.3296.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Set default background color on WebView2 initialization (DefaultBackgroundColor API) + +The DefaultBackgroundColor API allows users to set the `DefaultBackgroundColor` property at initialization. This prevents a disruptive white flash during the WebView2 loading process. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.DefaultBackgroundColor Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.defaultbackgroundcolor?view=webview2-dotnet-1.0.3296-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.DefaultBackgroundColor Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.3296-prerelease&preserve-view=true#defaultbackgroundcolor) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ControllerOptions3](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions3?view=webview2-1.0.3296-prerelease&preserve-view=true) + * [ICoreWebView2ControllerOptions3::get_DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions3?view=webview2-1.0.3296-prerelease&preserve-view=true#get_defaultbackgroundcolor) + * [ICoreWebView2ControllerOptions3::put_DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions3?view=webview2-1.0.3296-prerelease&preserve-view=true#put_defaultbackgroundcolor) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed the **Find** bar no longer appearing after the window is shifted. +* Fixed a bug where the app wasn't able to cancel navigation to login pages via the `NavigationStarting` event. +* Fixed an issue where downloads from within the default browser frame didn't complete. ([Issue #5196](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5196)) +* Fixed an issue where the pipe name was incorrectly returned, leading to a crash in some UWP apps. + + + + + +## See also + +* [About release notes for the WebView2 SDK](./about.md) +* [Archived release notes for the WebView2 SDK](./archive.md) +* [Overview of WebView2 APIs](../concepts/overview-features-apis.md) - outlines many of the APIs, by feature area, that are in Release SDK packages. +* [Contacting the Microsoft Edge WebView2 team](../contact.md) +* [Release notes for Microsoft Edge web platform](../../web-platform/release-notes/index.md) + +API Reference: +* [WebView2 API Reference](../webview2-api-reference.md) + * .NET: [Microsoft.Web.WebView2.Core Namespace](/dotnet/api/microsoft.web.webview2.core) + * WinRT: [Microsoft.Web.WebView2.Core Namespace](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/) + * Win32: [Reference (WebView2 Win32 C++)](/microsoft-edge/webview2/reference/win32/) +--- +title: Archived release notes for the WebView2 SDK +description: Release notes for older releases of Microsoft Edge WebView2, covering new features, APIs, and fixes for Win32, WPF, and WinForms. +author: MSEdgeTeam +ms.author: msedgedevrel +ms.topic: article +ms.service: microsoft-edge +ms.subservice: devtools +ms.date: 05/11/2026 +--- +# Archived release notes for the WebView2 SDK + + + + +The following features and bug fixes are in the WebView2 Release SDK and Prerelease SDK, for SDKs over one year old. + + + +## Release SDK 1.0.3240.44, for Runtime 136 (May 5, 2025) + +Release Date: May 5, 2025 + +[NuGet package for WebView2 SDK 1.0.3240.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3240.44) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 136.0.3240.44 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Track navigation history for nested iframes (FrameCreatedEvent API) + +The FrameCreatedEvent API supports nested iframes, such as recording the navigation history for a second-level iframe. Without this API, WebView2 only tracks first-level iframes, which are the direct child iframes of the main frame. Using this API, your app can subscribe to the nested iframe creation event, giving the app access to all properties, methods, and events of `CoreWebView2Frame` for the nested iframe. + +Use this API to manage iframe tracking on a page that contains multiple levels of iframes. You can choose to track any of the following: + +* Only the main page and first-level iframes (the default behavior). +* A partial WebView2 frames tree with specific iframes of interest. +* The full WebView2 frames tree. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.framecreated?view=webview2-dotnet-1.0.3240.44&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.3240.44&preserve-view=true#framecreated) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Frame7](/microsoft-edge/webview2/reference/win32/icorewebview2frame7?view=webview2-1.0.3240.44&preserve-view=true) + * [ICoreWebView2Frame7::add_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2frame7?view=webview2-1.0.3240.44&preserve-view=true#add_framecreated) + * [ICoreWebView2Frame7::remove_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2frame7?view=webview2-1.0.3240.44&preserve-view=true#remove_framecreated) + +* [ICoreWebView2FrameChildFrameCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2framechildframecreatedeventhandler?view=webview2-1.0.3240.44&preserve-view=true) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed an issue where downloads from within the default browser frame didn't complete. ([Issue #5196](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5196)) +* Fixed an issue where the pipe name was incorrectly returned, leading to a crash in some UWP apps. + + + + + +## Prerelease SDK 1.0.3230-prerelease, for Runtime 136 (Apr. 7, 2025) + +Release Date: Apr. 7, 2025, Runtime 136 + +[NuGet package for WebView2 SDK 1.0.3230-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3230-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 136.0.3230.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Track navigation history for nested iframes (FrameCreatedEvent API) + +The FrameCreatedEvent API supports nested iframes, such as recording the navigation history for a second-level iframe. Without this API, WebView2 only tracks first-level iframes, which are the direct child iframes of the main frame. Using this API, your app can subscribe to the nested iframe creation event, giving the app access to all properties, methods, and events of `CoreWebView2Frame` for the nested iframe. + +Use this API to manage iframe tracking on a page that contains multiple levels of iframes. You can choose to track any of the following: + +* Only the main page and first-level iframes (the default behavior). +* A partial WebView2 frames tree with specific iframes of interest. +* The full WebView2 frames tree. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.framecreated?view=webview2-dotnet-1.0.3230-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.3230-prerelease&preserve-view=true#framecreated) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Frame7](/microsoft-edge/webview2/reference/win32/icorewebview2frame7?view=webview2-1.0.3230-prerelease&preserve-view=true) + * [ICoreWebView2Frame7::add_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2frame7?view=webview2-1.0.3230-prerelease&preserve-view=true#add_framecreated) + * [ICoreWebView2Frame7::remove_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2frame7?view=webview2-1.0.3230-prerelease&preserve-view=true#remove_framecreated) + +* [ICoreWebView2FrameChildFrameCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2framechildframecreatedeventhandler?view=webview2-1.0.3230-prerelease&preserve-view=true) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed an issue in WPF where the \ dropdown closed when the mouse moved outside the WebView2 control bounds. +* Fixed navigation of `edge://crashes` within a WebView2 control. +* Fixed the HTML Select element (\) to make it selectable, in WPF apps. +* Fixed potential crash and UI issues when invoking the Windows Credentials UI from a WebView2 instance. +* Fixed bug where users unable to type in input field with autofill info. ([Issue #5144](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5144)) +* Fixed a regression in the [Status bar](../concepts/overview-features-apis.md#status-bar) APIs. + + + +###### SDK-only + +* Fixed **Tab**, **Shift+Tab**, and **Arrow** keys in Window to Visual hosting mode. + + + + + +## Release SDK 1.0.3179.45, for Runtime 135 (Apr. 7, 2025) + +Release Date: Apr. 7, 2025, Runtime 135 + +[NuGet package for WebView2 SDK 1.0.3179.45](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3179.45) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 135.0.3179.45 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed the HTML Select element (\) to make it selectable, in WPF apps. +* Fixed navigation of `edge://crashes` within a WebView2 control. +* Fixed potential crash and UI issues when invoking the Windows Credentials UI from a WebView2 instance. +* Fixed a bug where users were unable to type in an input field with autofill info. ([Issue #5144](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5144)) + + + + + +## Prerelease SDK 1.0.3171-prerelease, for Runtime 135 (Mar. 10, 2025) + +Release Date: Mar. 10, 2025, Runtime 135 + +[NuGet package for WebView2 SDK 1.0.3171-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3171-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 135.0.3171.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime and SDK + +* Fixed host object async method exception handling. ([Issue #3402](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3402)) +* Fixed documentation for `CoreWebVIew2.Navigate`. ([Issue #5091](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5091)) + + + +###### Runtime-only + +* Fixed an "Add to Chrome" store installation regression. +* Fixed folder uploads in UWP and WinUI. ([Issue #3275](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3275)) +* Extensions won't get disabled in WebView2 by using `AddBrowserExtensionAsync`, regardless of whether developer mode is on. ([Issue #5113](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5113)) +* Disabled background update of network time. ([Issue #5047](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5047)) +* Fixed the download popup not being displayed when `target="_blank"`. ([Issue #5063](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5063)) + + + +###### SDK-only + +* Fixes a crash that could occur when the Garbage Collector calls `Finalize` on a thread other than the main thread. + + + + + +## Release SDK 1.0.3124.44, for Runtime 134 (Mar. 10, 2025) + +Release Date: Mar. 10, 2025, Runtime 134 + +[NuGet package for WebView2 SDK 1.0.3124.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3124.44) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 134.0.3124.44 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Extensions won't get disabled in WebView2 by using `AddBrowserExtensionAsync`, regardless of whether developer mode is on. ([Issue #5113](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5113)) +* Disabled background update of network time. ([Issue #5047](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5047)) +* Fixed the download popup not being displayed when `target="_blank"`. ([Issue #5063](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5063)) + + + + + +## Prerelease SDK 1.0.3116-prerelease, for Runtime 134 (Feb. 10, 2025) + +Release Date: Feb. 10, 2025, Runtime 134 + +[NuGet package for WebView2 SDK 1.0.3116-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3116-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 134.0.3116.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Added the missing **Close** button in the **Download** flyout. +* Fixed a race condition that occurred when the Web Request Response event never occurs. + + + +###### SDK-only + +* Fixed .NET and Win32 documentation of the `CoreWebView2Find.FindNext` method that incorrectly mentioned `FindPrevious`. The method summary now mentions `FindNext` instead. ([Issue #5059](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5059)) + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2Find.FindNext Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findnext?view=webview2-dotnet-1.0.3116-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2Find.FindNext Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3116-prerelease&preserve-view=true#findnext) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalFind::FindNext](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3116-prerelease&preserve-view=true#findnext) + +--- + + + + + +## Prerelease SDK 1.0.3079-prerelease, for Runtime 134 (Jan. 24, 2025) + +Release Date: Jan. 24, 2025 + +[NuGet package for WebView2 SDK 1.0.3079-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3079-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 134.0.3079.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +###### Customize the Find behavior (Find API) + +The Find API allows you to programmatically control **Find** operations, and enables adding the following functionality to your app: +* Customize **Find** options, including **Find Term**, **Case Sensitivity**, **Word Matching**, **Match Highlighting**, and **Default UI Suppression**. +* Find text strings and navigate among them within a WebView2 control. +* Programmatically initiate **Find** operations, and navigate **Find** results. +* Suppress the default **Find** UI. +* Track the status of **Find** operations. + +There are known issues with the Find API for PDF documents. When you view a PDF document within a WebView2 control, the **Find** feature currently only provides the first index and the number of matches found. For example, if the string occurs three times in a PDF, the UI would say **1/3** and would not support programmatically calling **Next** or **Previous**. We are actively investigating these issues, and we encourage you to report any problems you encounter, by using the [WebView2Feedback](https://github.com/MicrosoftEdge/WebViewFeedback) repo. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.Find Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.find?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateFindOptions Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createfindoptions?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +* [CoreWebView2Find Class](/dotnet/api/microsoft.web.webview2.core.corewebview2find?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2find.activematchindex?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndexChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2find.activematchindexchanged?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.FindNext Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findnext?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.FindPrevious Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.findprevious?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.MatchCount Property](/dotnet/api/microsoft.web.webview2.core.corewebview2find.matchcount?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.MatchCountChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2find.matchcountchanged?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.StartAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.startasync?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.Stop Method](/dotnet/api/microsoft.web.webview2.core.corewebview2find.stop?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +* [CoreWebView2FindOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.FindTerm Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.findterm?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.IsCaseSensitive Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.iscasesensitive?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.ShouldHighlightAllMatches Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.shouldhighlightallmatches?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.ShouldMatchWord Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.shouldmatchword?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.SuppressDefaultFindDialog Property](/dotnet/api/microsoft.web.webview2.core.corewebview2findoptions.suppressdefaultfinddialog?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.Find Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#find) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateFindOptions Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#createfindoptions) + +* [CoreWebView2Find Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2Find.ActiveMatchIndex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#activematchindex) + * [CoreWebView2Find.ActiveMatchIndexChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#activematchindexchanged) + * [CoreWebView2Find.FindNext Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#findnext) + * [CoreWebView2Find.FindPrevious Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#findprevious) + * [CoreWebView2Find.MatchCount Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#matchcount) + * [CoreWebView2Find.MatchCountChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#matchcountchanged) + * [CoreWebView2Find.StartAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2find?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#startasync) + +* [CoreWebView2FindOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true) + * [CoreWebView2FindOptions.FindTerm Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#findterm) + * [CoreWebView2FindOptions.IsCaseSensitive Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#iscasesensitive) + * [CoreWebView2FindOptions.ShouldHighlightAllMatches Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#shouldhighlightallmatches) + * [CoreWebView2FindOptions.ShouldMatchWord Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#shouldmatchword) + * [CoreWebView2FindOptions.SuppressDefaultFindDialog Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2findoptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#suppressdefaultfinddialog) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental29](/microsoft-edge/webview2/reference/win32/icorewebview2experimental29?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2Experimental29::get_Find](/microsoft-edge/webview2/reference/win32/icorewebview2experimental29?view=webview2-1.0.3079-prerelease&preserve-view=true#get_find) + +* [ICoreWebView2ExperimentalEnvironment18](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment18?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironment18::CreateFindOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment18?view=webview2-1.0.3079-prerelease&preserve-view=true#createfindoptions) + +* [ICoreWebView2ExperimentalFind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFind::add_ActiveMatchIndexChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#add_activematchindexchanged) + * [ICoreWebView2ExperimentalFind::add_MatchCountChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#add_matchcountchanged) + * [ICoreWebView2ExperimentalFind::FindNext](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#findnext) + * [ICoreWebView2ExperimentalFind::FindPrevious](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#findprevious) + * [ICoreWebView2ExperimentalFind::get_ActiveMatchIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#get_activematchindex) + * [ICoreWebView2ExperimentalFind::get_MatchCount](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#get_matchcount) + * [ICoreWebView2ExperimentalFind::remove_ActiveMatchIndexChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#remove_activematchindexchanged) + * [ICoreWebView2ExperimentalFind::remove_MatchCountChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#remove_matchcountchanged) + * [ICoreWebView2ExperimentalFind::Start](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#start) + * [ICoreWebView2ExperimentalFind::Stop](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfind?view=webview2-1.0.3079-prerelease&preserve-view=true#stop) + +* [ICoreWebView2ExperimentalFindActiveMatchIndexChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindactivematchindexchangedeventhandler?view=webview2-1.0.3079-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalFindMatchCountChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindmatchcountchangedeventhandler?view=webview2-1.0.3079-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalFindOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFindOptions::get_FindTerm](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#get_findterm) + * [ICoreWebView2ExperimentalFindOptions::get_IsCaseSensitive](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#get_iscasesensitive) + * [ICoreWebView2ExperimentalFindOptions::get_ShouldHighlightAllMatches](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#get_shouldhighlightallmatches) + * [ICoreWebView2ExperimentalFindOptions::get_ShouldMatchWord](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#get_shouldmatchword) + * [ICoreWebView2ExperimentalFindOptions::get_SuppressDefaultFindDialog](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#get_suppressdefaultfinddialog) + * [ICoreWebView2ExperimentalFindOptions::put_FindTerm](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#put_findterm) + * [ICoreWebView2ExperimentalFindOptions::put_IsCaseSensitive](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#put_iscasesensitive) + * [ICoreWebView2ExperimentalFindOptions::put_ShouldHighlightAllMatches](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#put_shouldhighlightallmatches) + * [ICoreWebView2ExperimentalFindOptions::put_ShouldMatchWord](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#put_shouldmatchword) + * [ICoreWebView2ExperimentalFindOptions::put_SuppressDefaultFindDialog](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindoptions?view=webview2-1.0.3079-prerelease&preserve-view=true#put_suppressdefaultfinddialog) + +* [ICoreWebView2ExperimentalFindStartCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfindstartcompletedhandler?view=webview2-1.0.3079-prerelease&preserve-view=true) + +--- + + + +###### Customize the drag and drop behavior (DragStarting API) + +The `DragStarting` API overrides the default drag and drop behavior when running in visual hosting mode. The `DragStarting` event notifies your app when the user starts a drag operation in the WebView2, and provides the state that's necessary to override the default WebView2 drag operation with your own logic. + +* Use `DragStarting` on the `ICoreWebView2ExperimentalCompositionController6` to add an event handler that's invoked when the drag operation is starting. +* Use `ICoreWebView2ExperimentalDragStartingEventArgs` to start your own drag operation. + * Use the `GetDeferral` method to execute any async drag logic and call back into the WebView at a later time. + * Use the `Handled` property to let the WebView2 know whether to use its own drag logic. + +##### [.NET/C#](#tab/dotnetcsharp) + +n/a + +##### [WinRT/C#](#tab/winrtcsharp) + +n/a + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalCompositionController6](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller6?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalCompositionController6::add_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller6?view=webview2-1.0.3079-prerelease&preserve-view=true#add_dragstarting) + * [ICoreWebView2ExperimentalCompositionController6::remove_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller6?view=webview2-1.0.3079-prerelease&preserve-view=true#remove_dragstarting) + +* [ICoreWebView2ExperimentalCompositionControllerInterop3](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontrollerinterop3?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalCompositionControllerInterop3::add_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontrollerinterop3?view=webview2-1.0.3079-prerelease&preserve-view=true#add_dragstarting) + * [ICoreWebView2ExperimentalCompositionControllerInterop3::remove_DragStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontrollerinterop3?view=webview2-1.0.3079-prerelease&preserve-view=true#remove_dragstarting) + +* [ICoreWebView2ExperimentalDragStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalDragStartingEventArgs::get_AllowedDropEffects](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true#get_alloweddropeffects) + * [ICoreWebView2ExperimentalDragStartingEventArgs::get_Data](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true#get_data) + * [ICoreWebView2ExperimentalDragStartingEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true#get_handled) + * [ICoreWebView2ExperimentalDragStartingEventArgs::get_Position](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true#get_position) + * [ICoreWebView2ExperimentalDragStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2ExperimentalDragStartingEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventargs?view=webview2-1.0.3079-prerelease&preserve-view=true#put_handled) + +* [ICoreWebView2ExperimentalDragStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaldragstartingeventhandler?view=webview2-1.0.3079-prerelease&preserve-view=true) + +--- + + + +###### Track navigation history for nested iframes (FrameCreatedEvent API) + +The FrameCreatedEvent API supports nested iframes, such as recording the navigation history for a second-level iframe. Without this API, WebView2 only tracks first-level iframes, which are the direct child iframes of the main frame. Using this API, your app can subscribe to the nested iframe creation event, giving the app access to all properties, methods, and events of `CoreWebView2Frame` for the nested iframe. + +Use this API to manage iframe tracking on a page that contains multiple levels of iframes. You can choose to track any of the following: + +* Only the main page and first-level iframes (the default behavior). +* A partial WebView2 frames tree with specific iframes of interest. +* The full WebView2 frames tree. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameCreated Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.framecreated?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameCreated Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#framecreated) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalFrame8](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe8?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFrame8::add_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe8?view=webview2-1.0.3079-prerelease&preserve-view=true#add_framecreated) + * [ICoreWebView2ExperimentalFrame8::remove_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe8?view=webview2-1.0.3079-prerelease&preserve-view=true#remove_framecreated) + +* [ICoreWebView2ExperimentalFrameChildFrameCreatedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframechildframecreatedeventhandler?view=webview2-1.0.3079-prerelease&preserve-view=true) + +--- + + + +###### Set default background color on WebView2 initialization (DefaultBackgroundColor API) + +The DefaultBackgroundColor API allows users to set the `DefaultBackgroundColor` property at initialization. This prevents a disruptive white flash during the WebView2 loading process. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.DefaultBackgroundColor Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.defaultbackgroundcolor?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.DefaultBackgroundColor Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.3079-prerelease&preserve-view=true#defaultbackgroundcolor) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalControllerOptions3](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions3?view=webview2-1.0.3079-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalControllerOptions3::get_DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions3?view=webview2-1.0.3079-prerelease&preserve-view=true#get_defaultbackgroundcolor) + * [ICoreWebView2ExperimentalControllerOptions3::put_DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions3?view=webview2-1.0.3079-prerelease&preserve-view=true#put_defaultbackgroundcolor) + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Show WPF elements on top of the WebView2 layer (WebView2CompositionControl) + +The `WebView2CompositionControl` prevents the WebView2 control from being the topmost layer in a WPF app and obscuring any WPF elements. `Microsoft.Web.WebView2.Wpf.WebView2CompositionControl` is a drop-in replacement for the standard WPF WebView2 control. Both the WebView2 control and `WebView2CompositionControl` implement the `Microsoft.Web.WebView2.Wpf.IWebView2` interface. Both of them derive from `FrameworkElement`, as follows: +* `FrameworkElement` -> `HwndHost` -> `WebView2`. +* `FrameworkElement` -> `Control` -> `WebView2CompositionControl`. + +Background: If you're building a Windows Presentation Foundation (WPF) app and using the WebView2 control, you may find that your app runs into "airspace" issues, where the WebView2 control is always displayed on top, hiding any WPF elements in the same location, even if you try to specify the WPF elements to be above the WebView2 control (using visual tree order or the z-index property, for example). + +This issue occurs because the WPF control uses the WPF `HwndHost` to host the Win32 WebView2 control, and `HwndHost` has an issue with airspace. + +See also: +* [Mitigating Airspace Issues In WPF Applications](https://dwayneneed.github.io/wpf/2013/02/26/mitigating-airspace-issues-in-wpf-applications.html) +* [WPF Airspace - WebView2CompositionControl](https://github.com/MicrosoftEdge/WebView2Feedback/blob/main/specs/WPF_WebView2CompositionControl.md) - Spec. + +##### [.NET/C#](#tab/dotnetcsharp) + +* [WebView2CompositionControl Class](/dotnet/api/microsoft.web.webview2.wpf.webview2compositioncontrol?view=webview2-dotnet-1.0.3079-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +n/a + +##### [Win32/C++](#tab/win32cpp) + +n/a + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a regression where display changes can cause WebView2 to render smaller than app window. +* Enabled the `IsolateSandboxedIframes` upstream feature for WebView2. +* Prevented deleting a service worker when the version changes. +* The `CleanUpSome` API in `Hostobject` now only does garbage collection for the full heap. `CleanUpSome` has been removed from the V8 engine. +* Fixed a regression of `AreBrowserAcceleratorKeysEnabled`. ([Issue #5033](https://github.com/MicrosoftEdge/WebView2Feedback/issues/5033)) +* Fixed a bug where `IsDefaultDownloadDialogOpenChanged` wasn't triggered when a dialog is closed by using the keyboard. ([Issue #4807](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4807)) + + + +###### SDK-only + +* Fixed an issue in the WPF `WebView2CompositionControl` where it's not displayed if it's initialized with size (0,0), such as when it's initialized in a `TabItem` of a `TabControl`. ([Issue #4941](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4941)) + + + + + +## Release SDK 1.0.3065.39, for Runtime 133 (Feb. 10, 2025) + +Release Date: Feb. 10, 2025, Runtime 133 + +[NuGet package for WebView2 SDK 1.0.3065.39](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.3065.39) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 133.0.3065.39 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Added the missing **Close** button in the **Download** flyout. +* Fixed a race condition that occurred when the Web Request Response event never occurs. + + + + + +## Release SDK 1.0.2957.106, for Runtime 132 (Jan. 20, 2025) + +Release Date: Jan. 20, 2025 + +[NuGet package for WebView2 SDK 1.0.2957.106](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2957.106) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 132.0.2957.106 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Show WPF elements on top of the WebView2 layer (WebView2CompositionControl) + +The `WebView2CompositionControl` prevents the WebView2 control from being the topmost layer in a WPF app and obscuring any WPF elements. `Microsoft.Web.WebView2.Wpf.WebView2CompositionControl` is a drop-in replacement for the standard WPF WebView2 control. Both the WebView2 control and `WebView2CompositionControl` implement the `Microsoft.Web.WebView2.Wpf.IWebView2` interface. Both of them derive from `FrameworkElement`, as follows: +* `FrameworkElement` -> `HwndHost` -> `WebView2`. +* `FrameworkElement` -> `Control` -> `WebView2CompositionControl`. + +Background: If you're building a Windows Presentation Foundation (WPF) app and using the WebView2 control, you may find that your app runs into "airspace" issues, where the WebView2 control is always displayed on top, hiding any WPF elements in the same location, even if you try to specify the WPF elements to be above the WebView2 control (using visual tree order or the z-index property, for example). + +This issue occurs because the WPF control uses the WPF `HwndHost` to host the Win32 WebView2 control, and `HwndHost` has an issue with airspace. + +See also: +* [Mitigating Airspace Issues In WPF Applications](https://dwayneneed.github.io/wpf/2013/02/26/mitigating-airspace-issues-in-wpf-applications.html) +* [WPF Airspace - WebView2CompositionControl](https://github.com/MicrosoftEdge/WebView2Feedback/blob/main/specs/WPF_WebView2CompositionControl.md) - Spec. + +##### [.NET/C#](#tab/dotnetcsharp) + +* [WebView2CompositionControl Class](/dotnet/api/microsoft.web.webview2.wpf.webview2compositioncontrol?view=webview2-dotnet-1.0.2957.106&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +n/a + +##### [Win32/C++](#tab/win32cpp) + +n/a + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a regression where display changes can cause WebView2 to render smaller than the app window. + + + +###### SDK-only + +* Fixed an issue in the WPF `WebView2CompositionControl` where it's not displayed if it's initialized with size (0,0), such as when it's initialized in a `TabItem` of a `TabControl`. ([Issue #4941](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4941)) + + + + + + + + + + + + + + + + + +## Prerelease SDK 1.0.2950-prerelease, for Runtime 132 (Nov. 18, 2024) + +Release Date: Nov. 18, 2024 + +[NuGet package for WebView2 SDK 1.0.2950-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2950-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 132.0.2950.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Allowed the **Download** dialog to receive initial focus on launch. +* Fixed a crash while cancelling navigation to certain sites in `FrameNavigationStarting`. ([Issue #4843](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4843)) +* Postponed customizing the context menu when the touch selection menu is being displayed. ([Issue #4737](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4737)) + + + +###### SDK-only + +* Added Arm64ec support. +* Fixed an issue where WebView2 running in "Window to Visual" mode couldn't receive accelerator input. + + + + + +## Release SDK 1.0.2903.40, for Runtime 131 (Nov. 18, 2024) + +Release Date: Nov. 18, 2024 + +[NuGet package for WebView2 SDK 1.0.2903.40](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2903.40) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 131.0.2903.40 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Control whether the screen capture UI is shown (ScreenCaptureStarting event) + +Added a new `ScreenCaptureStarting` event. This event is raised whenever the WebView2 and/or iframe that corresponds to the `CoreWebView2Frame` (or to any of its descendant iframes) requests permission to use the Screen Capture API before the UI is shown. The app can then block the UI from being displayed, or allow the UI to be displayed. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ScreenCaptureStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.screencapturestarting?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.ScreenCaptureStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.screencapturestarting?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + +* `CoreWebView2NonClientRegionKind` Enum: + * [CoreWebView2NonClientRegionKind.Minimize](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionkind?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + * [CoreWebView2NonClientRegionKind.Maximize](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionkind?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + * [CoreWebView2NonClientRegionKind.Close](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionkind?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + +* [CoreWebView2ScreenCaptureStartingEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.cancel?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.Handled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.handled?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.getdeferral?view=webview2-dotnet-1.0.2903.40&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ScreenCaptureStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2903.40&preserve-view=true#screencapturestarting) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.ScreenCaptureStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.2903.40&preserve-view=true#screencapturestarting) + +* `CoreWebView2NonClientRegionKind` Enum: + * [CoreWebView2NonClientRegionKind.Minimize](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionkind?view=webview2-winrt-1.0.2903.40&preserve-view=true) + * [CoreWebView2NonClientRegionKind.Maximize](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionkind?view=webview2-winrt-1.0.2903.40&preserve-view=true) + * [CoreWebView2NonClientRegionKind.Close](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionkind?view=webview2-winrt-1.0.2903.40&preserve-view=true) + +* [CoreWebView2ScreenCaptureStartingEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.Handled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2903.40&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2903.40&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_27](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2903.40&preserve-view=true) + * [ICoreWebView2_27::add_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2903.40&preserve-view=true#add_screencapturestarting) + * [ICoreWebView2_27::remove_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2903.40&preserve-view=true#remove_screencapturestarting) + +* [ICoreWebView2Frame6](/microsoft-edge/webview2/reference/win32/icorewebview2frame6?view=webview2-1.0.2903.40&preserve-view=true) + * [ICoreWebView2Frame6::add_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2frame6?view=webview2-1.0.2903.40&preserve-view=true#add_screencapturestarting) + * [ICoreWebView2Frame6::remove_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2frame6?view=webview2-1.0.2903.40&preserve-view=true#remove_screencapturestarting) + +* [ICoreWebView2FrameScreenCaptureStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2framescreencapturestartingeventhandler?view=webview2-1.0.2903.40&preserve-view=true) + +* [ICoreWebView2ScreenCaptureStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true) + * [ICoreWebView2ScreenCaptureStartingEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true#get_cancel) + * [ICoreWebView2ScreenCaptureStartingEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true#get_handled) + * [ICoreWebView2ScreenCaptureStartingEventArgs::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true#get_originalsourceframeinfo) + * [ICoreWebView2ScreenCaptureStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true#getdeferral) + * [ICoreWebView2ScreenCaptureStartingEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true#put_cancel) + * [ICoreWebView2ScreenCaptureStartingEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2903.40&preserve-view=true#put_handled) + +* [ICoreWebView2ScreenCaptureStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventhandler?view=webview2-1.0.2903.40&preserve-view=true) + +* `COREWEBVIEW2_NON_CLIENT_REGION_KIND` enum: + * [COREWEBVIEW2_NON_CLIENT_REGION_KIND_MINIMIZE](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2903.40&preserve-view=true#corewebview2_non_client_region_kind) + * [COREWEBVIEW2_NON_CLIENT_REGION_KIND_MAXIMIZE](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2903.40&preserve-view=true#corewebview2_non_client_region_kind) + * [COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLOSE](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2903.40&preserve-view=true#corewebview2_non_client_region_kind) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Allowed the **Download** dialog to receive initial focus on launch. + + + +#### General changes + +* The Microsoft Edge WebView2 Runtime is no longer listed in Windows **Settings** > **Apps** > **Installed apps**, because it is a persistent system component. + + + + + +## Prerelease SDK 1.0.2895-prerelease, for Runtime 131 (Oct. 21, 2024) + +Release Date: Oct. 21, 2024 + +[NuGet package for WebView2 SDK 1.0.2895-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2895-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 131.0.2895.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +###### `RestartRequested` event when WebView2 needs to restart + +Added a new `RestartRequested` event. The `RestartRequested` event is raised whenever WebView2 needs to restart to apply updates or configuration changes. You can use this API to detect when WebView2 needs to restart, and take appropriate actions. The `Priority` property of the `RestartRequested` event arguments indicates the priority of the restart request: +* `High` indicates that the app should prompt users to restart as soon as possible. +* `Normal` indicates that the app should remind users to restart, on a best-effort basis. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.RestartRequested Event](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.restartrequested?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +* `CoreWebView2RestartRequestedEventArgs` Class: + * [CoreWebView2RestartRequestedEventArgs.Priority Property](/dotnet/api/microsoft.web.webview2.core.corewebview2restartrequestedeventargs.priority?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +* [CoreWebView2RestartRequestedPriority Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2restartrequestedpriority?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * `CoreWebView2RestartRequestedPriority.Normal` + * `CoreWebView2RestartRequestedPriority.High` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.RestartRequested Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#restartrequested) + +* `CoreWebView2RestartRequestedEventArgs` Class: + * [CoreWebView2RestartRequestedEventArgs.Priority Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2restartrequestedeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#priority) + +* [CoreWebView2RestartRequestedPriority Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2restartrequestedpriority?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true) + * `CoreWebView2RestartRequestedPriority.Normal` + * `CoreWebView2RestartRequestedPriority.High` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalEnvironment15](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment15?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironment15::add_RestartRequested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment15?view=webview2-1.0.2895-prerelease&preserve-view=true#add_restartrequested) + * [ICoreWebView2ExperimentalEnvironment15::remove_RestartRequested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment15?view=webview2-1.0.2895-prerelease&preserve-view=true#remove_restartrequested) + +* [ICoreWebView2ExperimentalRestartRequestedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalrestartrequestedeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalRestartRequestedEventArgs::get_Priority](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalrestartrequestedeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_priority) +* [ICoreWebView2ExperimentalRestartRequestedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalrestartrequestedeventhandler?view=webview2-1.0.2895-prerelease&preserve-view=true) + +* [COREWEBVIEW2_RESTART_REQUESTED_PRIORITY enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2895-prerelease&preserve-view=true#corewebview2_restart_requested_priority) + * `COREWEBVIEW2_RESTART_REQUESTED_PRIORITY_NORMAL` + * `COREWEBVIEW2_RESTART_REQUESTED_PRIORITY_HIGH` + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### Control whether the screen capture UI is shown (`ScreenCaptureStarting` event) + +Added a new `ScreenCaptureStarting` event. This event is raised whenever the WebView2 and/or iframe that corresponds to the `CoreWebView2Frame` (or to any of its descendant iframes) requests permission to use the Screen Capture API before the UI is shown. The app can then block the UI from being displayed, or allow the UI to be displayed. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ScreenCaptureStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.screencapturestarting?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.ScreenCaptureStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.screencapturestarting?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +* `CoreWebView2ScreenCaptureStartingEventArgs` Class: + * [CoreWebView2ScreenCaptureStartingEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.cancel?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.Handled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.handled?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.getdeferral?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ScreenCaptureStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#screencapturestarting) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.ScreenCaptureStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#screencapturestarting) + +* `CoreWebView2ScreenCaptureStartingEventArgs` Class: + * [CoreWebView2ScreenCaptureStartingEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#cancel) + * [CoreWebView2ScreenCaptureStartingEventArgs.Handled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#handled) + * [CoreWebView2ScreenCaptureStartingEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#originalsourceframeinfo) + * [CoreWebView2ScreenCaptureStartingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_27](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2_27::add_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2895-prerelease&preserve-view=true#add_screencapturestarting) + * [ICoreWebView2_27::remove_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_27?view=webview2-1.0.2895-prerelease&preserve-view=true#remove_screencapturestarting) + +* [ICoreWebView2Frame6](/microsoft-edge/webview2/reference/win32/icorewebview2frame6?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2Frame6::add_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2frame6?view=webview2-1.0.2895-prerelease&preserve-view=true#add_screencapturestarting) + * [ICoreWebView2Frame6::remove_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2frame6?view=webview2-1.0.2895-prerelease&preserve-view=true#remove_screencapturestarting) + +* [ICoreWebView2FrameScreenCaptureStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2framescreencapturestartingeventhandler?view=webview2-1.0.2895-prerelease&preserve-view=true) + +* [ICoreWebView2ScreenCaptureStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2ScreenCaptureStartingEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_cancel) + * [ICoreWebView2ScreenCaptureStartingEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_handled) + * [ICoreWebView2ScreenCaptureStartingEventArgs::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_originalsourceframeinfo) + * [ICoreWebView2ScreenCaptureStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2ScreenCaptureStartingEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#put_cancel) + * [ICoreWebView2ScreenCaptureStartingEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#put_handled) + +* [ICoreWebView2ScreenCaptureStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2screencapturestartingeventhandler?view=webview2-1.0.2895-prerelease&preserve-view=true) + +--- + + + +###### Configure the security warning when saving a file (`SaveFileSecurityCheckStarting` event) + + + +Added a new `SaveFileSecurityCheckStarting` event. Your app can register a handler on this event to get the file path, filename extension, and document origin URI information. You can then apply your own rules to do actions such as the following: + * Allow saving the file without presenting a default security-warning UI about the file-type policy. + * Cancel the saving. + * Create your own UI to manage runtime file-type policies. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveFileSecurityCheckStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.savefilesecuritycheckstarting?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +* [CoreWebView2SaveFileSecurityCheckStartingEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.CancelSave Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.cancelsave?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.DocumentOriginUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.documentoriginuri?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FileExtension Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.fileextension?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FilePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.filepath?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.SuppressDefaultPolicy Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.suppressdefaultpolicy?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.getdeferral?view=webview2-dotnet-1.0.2895-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveFileSecurityCheckStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#savefilesecuritycheckstarting) + +* [CoreWebView2SaveFileSecurityCheckStartingEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.CancelSave Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#cancelsave) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.DocumentOriginUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#documentoriginuri) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FileExtension Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#fileextension) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FilePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#filepath) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.SuppressDefaultPolicy Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#suppressdefaultpolicy) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2895-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_26](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2_26::add_SaveFileSecurityCheckStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2895-prerelease&preserve-view=true#add_savefilesecuritycheckstarting) + * [ICoreWebView2_26::remove_SaveFileSecurityCheckStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2895-prerelease&preserve-view=true#remove_savefilesecuritycheckstarting) + +* [ICoreWebView2SaveFileSecurityCheckStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_CancelSave](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_cancelsave) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_DocumentOriginUri](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_documentoriginuri) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_FileExtension](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_fileextension) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_FilePath](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_filepath) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_SuppressDefaultPolicy](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#get_suppressdefaultpolicy) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::put_CancelSave](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#put_cancelsave) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::put_SuppressDefaultPolicy](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2895-prerelease&preserve-view=true#put_suppressdefaultpolicy) + +* [ICoreWebView2SaveFileSecurityCheckStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventhandler?view=webview2-1.0.2895-prerelease&preserve-view=true) + +--- + + +#### Bug fixes + + + +##### SDK-only + +* Fixed Arm64 incompatibility with WindowsAppSDK 1.6. +* Removed extra `WebView2Loader.dll` in WinAppSDK case. +* Using `CoreWebView2.AddWebResourceRequestedFilter` without a `CoreWebView2WebResourceRequestSourceKinds` parameter is now deprecated. See the .NET [CoreWebView2.AddWebResourceRequestedFilter Method](https://go.microsoft.com/fwlink/?linkid=2286319). + + + + + +## Release SDK 1.0.2849.39, for Runtime 130 (Oct. 21, 2024) + +Release Date: Oct. 21, 2024 + +[NuGet package for WebView2 SDK 1.0.2849.39](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2849.39) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 130.0.2849.39 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Configure the security warning when saving a file (`SaveFileSecurityCheckStarting` event) + + + +Added a new `SaveFileSecurityCheckStarting` event. Your app can register a handler on this event to get the file path, filename extension, and document origin URI information. You can then apply your own rules to do actions such as the following: + * Allow saving the file without presenting a default security-warning UI about the file-type policy. + * Cancel the saving. + * Create your own UI to manage runtime file-type policies. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveFileSecurityCheckStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.savefilesecuritycheckstarting?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + +* [CoreWebView2SaveFileSecurityCheckStartingEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.CancelSave Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.cancelsave?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.DocumentOriginUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.documentoriginuri?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FileExtension Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.fileextension?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FilePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.filepath?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.SuppressDefaultPolicy Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.suppressdefaultpolicy?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.getdeferral?view=webview2-dotnet-1.0.2849.39&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveFileSecurityCheckStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2849.39&preserve-view=true#savefilesecuritycheckstarting) + +* [CoreWebView2SaveFileSecurityCheckStartingEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.CancelSave Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true#cancelsave) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.DocumentOriginUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true#documentoriginuri) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FileExtension Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true#fileextension) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FilePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true#filepath) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.SuppressDefaultPolicy Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true#suppressdefaultpolicy) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2849.39&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_26](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2849.39&preserve-view=true) + * [ICoreWebView2_26::add_SaveFileSecurityCheckStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2849.39&preserve-view=true#add_savefilesecuritycheckstarting) + * [ICoreWebView2_26::remove_SaveFileSecurityCheckStarting](/microsoft-edge/webview2/reference/win32/icorewebview2_26?view=webview2-1.0.2849.39&preserve-view=true#remove_savefilesecuritycheckstarting) + +* [ICoreWebView2SaveFileSecurityCheckStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_CancelSave](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#get_cancelsave) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_DocumentOriginUri](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#get_documentoriginuri) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_FileExtension](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#get_fileextension) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_FilePath](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#get_filepath) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::get_SuppressDefaultPolicy](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#get_suppressdefaultpolicy) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#getdeferral) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::put_CancelSave](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#put_cancelsave) + * [ICoreWebView2SaveFileSecurityCheckStartingEventArgs::put_SuppressDefaultPolicy](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventargs?view=webview2-1.0.2849.39&preserve-view=true#put_suppressdefaultpolicy) + +* [ICoreWebView2SaveFileSecurityCheckStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2savefilesecuritycheckstartingeventhandler?view=webview2-1.0.2849.39&preserve-view=true) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a **Download** dialog focus issue when pressing **Tab** or **Shift+Tab** to switch into the Webview2 control. + + + +###### SDK-only + +* Using `CoreWebView2.AddWebResourceRequestedFilter` without a `CoreWebView2WebResourceRequestSourceKinds` parameter is now deprecated. See the .NET [CoreWebView2.AddWebResourceRequestedFilter Method](https://go.microsoft.com/fwlink/?linkid=2286319). +* Added the .NET 8 `TargetFramework` for C# WinRT, enabled AOT (ahead-of-time) compatibility, and disabled runtime marshalling. + + + + + +## Prerelease SDK 1.0.2839-prerelease, for Runtime 130 (Sep. 23, 2024) + +Release Date: Sep. 23, 2024 + +[NuGet package for WebView2 SDK 1.0.2839-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2839-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 130.0.2839.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed an issue where focusing on a WebView2 control in WinAppSDK with the Windows "Scroll inactive windows" setting disabled caused scrolling to fail. +* Blocked `edge://wallet` in WebView2. ([Issue #4710](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4710)) +* Cleared the environment variable for default background color in .NET WebView2 controls after the controller has finished creation. +* Enabled accessibility support for Webview2 in visual hosting mode. +* Fixed a bug with removing a "web resource requested" filter for multiple sources when one of them is Document. +* Fixed a regression where `DataList` was not visible in WinUI or in other visually hosted WebView2 instances. + + + +###### SDK-only + +* Fixed an SDK dependency for .NET projects. ([Issue #4743](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4743)) +* Fixed a compatibility issue when calling `GetAvailableBrowserVersionString()` with an older `WebView2Loader.dll`. ([Issue #4395](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4395)) +* Fixed issues when compiling wv2winrt-generated code with the `cpp20` and `/permissive-` options. +* Added the .NET 8 `TargetFramework` for C# WinRT, enabled AOT (ahead-of-time) compatibility, and disabled runtime marshalling. + + + + + +## Release SDK 1.0.2792.45, for Runtime 129 (Sep. 23, 2024) + +Release Date: Sep. 23, 2024 + +[NuGet package for WebView2 SDK 1.0.2792.45](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2792.45) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 129.0.2792.45 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + + + +###### SDK-only + +* Fixed an SDK dependency for .NET projects. ([Issue #4743](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4743)) + + + + + +## Prerelease SDK 1.0.2783-prerelease, for Runtime 129 (Aug. 26, 2024) + +Release Date: Aug. 26, 2024 + +[NuGet package for WebView2 SDK 1.0.2783-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2783-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 129.0.2783.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime and SDK + +* Re-enabled the default behavior of `SetUserAgent`: by default, `SetUserAgent` is effective for cross-origin iframes. + + + +###### Runtime-only + +* Enabled the interactive dragging feature by default. See `edge-webview-interactive-dragging` in [WebView2 browser flags](../concepts/webview-features-flags.md). + +* Disabled `IsolateSandboxedIframes` for WebView2. + +* Fixed an issue where WebView creation fails when multiple instances are launched at the same time. ([Issue #4731](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4731)) + +* Fixed a bug in WinRT JavaScript projection where caching existing properties in objects whose name contains `Proxy` or `Function` caused an error due to name collision. + +* Fixed a bug where the WebView2 control became the wrong size after disconnecting and reconnecting a monitor. + +* Fixed an issue where "mailto:" links leave an untitled popup window open, instead of automatically closing the popup window. + + + +###### SDK-only + +* C# WinRT projection now works on UWP. + +* Fixed an issue to ensure that `GeneratedFilesDir` no longer appears in Visual Studio for C# WinRT projection. + + + + + +## Release SDK 1.0.2739.15, for Runtime 128 (Aug. 26, 2024) + +Release Date: Aug. 26, 2024 + +[NuGet package for WebView2 SDK 1.0.2739.15](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2739.15) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 128.0.2739.15 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### Web notification handling + +Added support for Web Notification, for non-persistent notifications. The `NotificationReceived` event for `CoreWebView2` controls web notification handling, allowing customization or suppression by the host app. Unhandled notifications default to WebView2's UI. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.NotificationReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.notificationreceived?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + +* [CoreWebView2Notification Class](/dotnet/api/microsoft.web.webview2.core.corewebview2notification?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.BadgeUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.badgeuri?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.Body Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.body?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.BodyImageUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.bodyimageuri?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.Direction Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.direction?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.IconUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.iconuri?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.IsSilent Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.issilent?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.Language Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.language?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.RequiresInteraction Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.requiresinteraction?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.ShouldRenotify Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.shouldrenotify?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.Tag Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.tag?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.Timestamp Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.timestamp?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.Title Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.title?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.VibrationPattern Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.vibrationpattern?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.ReportClicked Method](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.reportclicked?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.ReportClosed Method](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.reportclosed?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.ReportShown Method](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.reportshown?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.CloseRequested Event](/dotnet/api/microsoft.web.webview2.core.corewebview2notification.closerequested?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + +* [CoreWebView2NotificationReceivedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2NotificationReceivedEventArgs.Handled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs.handled?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2NotificationReceivedEventArgs.Notification Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs.notification?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2NotificationReceivedEventArgs.SenderOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs.senderorigin?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2NotificationReceivedEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs.getdeferral?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + +* [CoreWebView2TextDirectionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2textdirectionkind?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * `Default` + * `LeftToRight` + * `RightToLeft` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.NotificationReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2739.15&preserve-view=true#notificationreceived) + +* [CoreWebView2Notification Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true) + * [CoreWebView2Notification.BadgeUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#badgeuri) + * [CoreWebView2Notification.Body Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#body) + * [CoreWebView2Notification.BodyImageUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#bodyimageuri) + * [CoreWebView2Notification.Direction Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#direction) + * [CoreWebView2Notification.IconUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#iconuri) + * [CoreWebView2Notification.IsSilent Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#issilent) + * [CoreWebView2Notification.Language Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#language) + * [CoreWebView2Notification.RequiresInteraction Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#requiresinteraction) + * [CoreWebView2Notification.ShouldRenotify Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#shouldrenotify) + * [CoreWebView2Notification.Tag Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#tag) + * [CoreWebView2Notification.Timestamp Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#timestamp) + * [CoreWebView2Notification.Title Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#title) + * [CoreWebView2Notification.VibrationPattern Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#vibrationpattern) + * [CoreWebView2Notification.ReportClicked Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#reportclicked) + * [CoreWebView2Notification.ReportClosed Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#reportclosed) + * [CoreWebView2Notification.ReportShown Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#reportshown) + * [CoreWebView2Notification.CloseRequested Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2739.15&preserve-view=true#closerequested) + +* [CoreWebView2NotificationReceivedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true) + * [CoreWebView2NotificationReceivedEventArgs.Handled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#handled) + * [CoreWebView2NotificationReceivedEventArgs.Notification Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#notification) + * [CoreWebView2NotificationReceivedEventArgs.SenderOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#senderorigin) + * [CoreWebView2NotificationReceivedEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#getdeferral) + +* [CoreWebView2TextDirectionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2textdirectionkind?view=webview2-winrt-1.0.2739.15&preserve-view=true) + * `Default` + * `LeftToRight` + * `RightToLeft` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_24](/microsoft-edge/webview2/reference/win32/icorewebview2_24?view=webview2-1.0.2739.15&preserve-view=true) + * [ICoreWebView2_24::add_NotificationReceived](/microsoft-edge/webview2/reference/win32/icorewebview2_24?view=webview2-1.0.2739.15&preserve-view=true#add_notificationreceived) + * [ICoreWebView2_24::remove_NotificationReceived](/microsoft-edge/webview2/reference/win32/icorewebview2_24?view=webview2-1.0.2739.15&preserve-view=true#remove_notificationreceived) + +* [ICoreWebView2Notification](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true) + * [ICoreWebView2Notification::add_CloseRequested](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#add_closerequested) + * [ICoreWebView2Notification::get_BadgeUri](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_badgeuri) + * [ICoreWebView2Notification::get_Body](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_body) + * [ICoreWebView2Notification::get_BodyImageUri](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_bodyimageuri) + * [ICoreWebView2Notification::get_Direction](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_direction) + * [ICoreWebView2Notification::get_IconUri](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_iconuri) + * [ICoreWebView2Notification::get_IsSilent](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_issilent) + * [ICoreWebView2Notification::get_Language](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_language) + * [ICoreWebView2Notification::get_RequiresInteraction](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_requiresinteraction) + * [ICoreWebView2Notification::get_ShouldRenotify](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_shouldrenotify) + * [ICoreWebView2Notification::get_Tag](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_tag) + * [ICoreWebView2Notification::get_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_timestamp) + * [ICoreWebView2Notification::get_Title](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#get_title) + * [ICoreWebView2Notification::GetVibrationPattern](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#getvibrationpattern) + * [ICoreWebView2Notification::remove_CloseRequested](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#remove_closerequested) + * [ICoreWebView2Notification::ReportClicked](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#reportclicked) + * [ICoreWebView2Notification::ReportClosed](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#reportclosed) + * [ICoreWebView2Notification::ReportShown](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2739.15&preserve-view=true#reportshown) + +* [ICoreWebView2NotificationCloseRequestedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2notificationcloserequestedeventhandler?view=webview2-1.0.2739.15&preserve-view=true) + +* [ICoreWebView2NotificationReceivedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2739.15&preserve-view=true) + * [ICoreWebView2NotificationReceivedEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_handled) + * [ICoreWebView2NotificationReceivedEventArgs::get_Notification](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_notification) + * [ICoreWebView2NotificationReceivedEventArgs::get_SenderOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_senderorigin) + * [ICoreWebView2NotificationReceivedEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2739.15&preserve-view=true#getdeferral) + * [ICoreWebView2NotificationReceivedEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2739.15&preserve-view=true#put_handled) + +* [ICoreWebView2NotificationReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventhandler?view=webview2-1.0.2739.15&preserve-view=true) + +* [`COREWEBVIEW2_TEXT_DIRECTION_KIND` enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2739.15&preserve-view=true#corewebview2_text_direction_kind) + * `COREWEBVIEW2_TEXT_DIRECTION_KIND_DEFAULT` + * `COREWEBVIEW2_TEXT_DIRECTION_KIND_LEFT_TO_RIGHT` + * `COREWEBVIEW2_TEXT_DIRECTION_KIND_RIGHT_TO_LEFT` + +--- + + + +###### Save as + +Added `SaveAs` APIs that allow you to programmatically perform the **Save as** operation. You can use these APIs to block the default **Save as** dialog, and then either save silently, or build your own UI for **Save as**. These APIs pertain only to the **Save as** dialog, not the **Download** dialog, which continues to use the existing Download APIs. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ShowSaveAsUIAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showsaveasuiasync?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2.SaveAsUIShowing Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.saveasuishowing?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + +* [CoreWebView2SaveAsKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2saveaskind?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * `Complete` + * `Default` + * `HtmlOnly` + * `SingleFile` + +* [CoreWebView2SaveAsUIResult Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuiresult?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * `Cancelled` + * `FileAlreadyExists` + * `InvalidPath` + * `KindNotSupported` + * `Success` + +* [CoreWebView2SaveAsUIShowingEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.AllowReplace Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.allowreplace?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.cancel?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.ContentMimeType Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.contentmimetype?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.kind?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.SaveAsFilePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.saveasfilepath?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.SuppressDefaultDialog Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.suppressdefaultdialog?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.getdeferral?view=webview2-dotnet-1.0.2739.15&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ShowSaveAsUIAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2739.15&preserve-view=true#showsaveasuiasync) + * [CoreWebView2.SaveAsUIShowing Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2739.15&preserve-view=true#saveasuishowing) + +* [CoreWebView2SaveAsKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveaskind?view=webview2-winrt-1.0.2739.15&preserve-view=true) + * `Default` + * `HtmlOnly` + * `SingleFile` + * `Complete` + +* [CoreWebView2SaveAsUIResult Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuiresult?view=webview2-winrt-1.0.2739.15&preserve-view=true) + * `Success` + * `InvalidPath` + * `FileAlreadyExists` + * `KindNotSupported` + * `Cancelled` + +* [CoreWebView2SaveAsUIShowingEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.AllowReplace Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#allowreplace) + * [CoreWebView2SaveAsUIShowingEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#cancel) + * [CoreWebView2SaveAsUIShowingEventArgs.ContentMimeType Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#contentmimetype) + * [CoreWebView2SaveAsUIShowingEventArgs.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#kind) + * [CoreWebView2SaveAsUIShowingEventArgs.SaveAsFilePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#saveasfilepath) + * [CoreWebView2SaveAsUIShowingEventArgs.SuppressDefaultDialog Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#suppressdefaultdialog) + * [CoreWebView2SaveAsUIShowingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2739.15&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_25](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2739.15&preserve-view=true) + * [ICoreWebView2_25::add_SaveAsUIShowing](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2739.15&preserve-view=true#add_saveasuishowing) + * [ICoreWebView2_25::remove_SaveAsUIShowing](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2739.15&preserve-view=true#remove_saveasuishowing) + * [ICoreWebView2_25::ShowSaveAsUI](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2739.15&preserve-view=true#showsaveasui) + +* [ICoreWebView2SaveAsUIShowingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventhandler?view=webview2-1.0.2739.15&preserve-view=true) + +* [ICoreWebView2SaveAsUIShowingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_AllowReplace](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_allowreplace) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_cancel) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_ContentMimeType](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_contentmimetype) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_kind) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_SaveAsFilePath](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_saveasfilepath) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_SuppressDefaultDialog](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#get_suppressdefaultdialog) + * [ICoreWebView2SaveAsUIShowingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#getdeferral) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_AllowReplace](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#put_allowreplace) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#put_cancel) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#put_kind) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_SaveAsFilePath](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#put_saveasfilepath) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_SuppressDefaultDialog](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2739.15&preserve-view=true#put_suppressdefaultdialog) + +* [ICoreWebView2ShowSaveAsUICompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2showsaveasuicompletedhandler?view=webview2-1.0.2739.15&preserve-view=true) + +* [`COREWEBVIEW2_SAVE_AS_KIND` enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2739.15&preserve-view=true#corewebview2_save_as_kind) + * `COREWEBVIEW2_SAVE_AS_KIND_DEFAULT` + * `COREWEBVIEW2_SAVE_AS_KIND_HTML_ONLY` + * `COREWEBVIEW2_SAVE_AS_KIND_SINGLE_FILE` + * `COREWEBVIEW2_SAVE_AS_KIND_COMPLETE` + +* [`COREWEBVIEW2_SAVE_AS_UI_RESULT` enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2739.15&preserve-view=true#corewebview2_save_as_ui_result) + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_SUCCESS` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_INVALID_PATH` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_FILE_ALREADY_EXISTS` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED` + +--- + + + +#### Bug fixes + +There are no bug fixes in this Release SDK. + + + + + +## Prerelease SDK 1.0.2730-prerelease, for Runtime 128 (Aug. 7, 2024) + +Release Date: Aug. 7, 2024 + +[NuGet package for WebView2 SDK 1.0.2730-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2730-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 128.0.2730.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +###### Throttling Controls APIs + +Added new Throttling Controls APIs which allows for efficient resource management by allowing you to throttle JavaScript timers. This is helpful in scenarios where a WebView2 control needs to remain visible, but needs to consume fewer resources (such as when the user isn't interacting with the content). These Throttling Controls APIs allow you to: + +* Customize script timers (`setTimeout` and `setInterval`) throttling under different page states (foreground, background, and background with intensive throttling). + +* Throttle script timers in select hosted iframes. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.UseOverrideTimerWakeInterval Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.useoverridetimerwakeinterval?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.PreferredBackgroundTimerWakeInterval Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.preferredbackgroundtimerwakeinterval?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2Settings.PreferredForegroundTimerWakeInterval Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.preferredforegroundtimerwakeinterval?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2Settings.PreferredIntensiveTimerWakeInterval Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.preferredintensivetimerwakeinterval?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2Settings.PreferredOverrideTimerWakeInterval Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.preferredoverridetimerwakeinterval?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.UseOverrideTimerWakeInterval Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#useoverridetimerwakeinterval) + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.PreferredBackgroundTimerWakeInterval Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#preferredbackgroundtimerwakeinterval) + * [CoreWebView2Settings.PreferredForegroundTimerWakeInterval Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#preferredforegroundtimerwakeinterval) + * [CoreWebView2Settings.PreferredIntensiveTimerWakeInterval Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#preferredintensivetimerwakeinterval) + * [CoreWebView2Settings.PreferredOverrideTimerWakeInterval Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#preferredoverridetimerwakeinterval) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalFrame7](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe7?view=webview2-1.0.2730-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFrame7::get_UseOverrideTimerWakeInterval](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe7?view=webview2-1.0.2730-prerelease&preserve-view=true#get_useoverridetimerwakeinterval) + * [ICoreWebView2ExperimentalFrame7::put_UseOverrideTimerWakeInterval](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe7?view=webview2-1.0.2730-prerelease&preserve-view=true#put_useoverridetimerwakeinterval) + +* [ICoreWebView2ExperimentalSettings9](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSettings9::get_PreferredBackgroundTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#get_preferredbackgroundtimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::get_PreferredForegroundTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#get_preferredforegroundtimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::get_PreferredIntensiveTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#get_preferredintensivetimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::get_PreferredOverrideTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#get_preferredoverridetimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::put_PreferredBackgroundTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#put_preferredbackgroundtimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::put_PreferredForegroundTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#put_preferredforegroundtimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::put_PreferredIntensiveTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#put_preferredintensivetimerwakeintervalinmilliseconds) + * [ICoreWebView2ExperimentalSettings9::put_PreferredOverrideTimerWakeIntervalInMilliseconds](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings9?view=webview2-1.0.2730-prerelease&preserve-view=true#put_preferredoverridetimerwakeintervalinmilliseconds) + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* Added `SaveAs` APIs that allow you to programmatically perform the **Save as** operation. You can use these APIs to block the default **Save as** dialog, and then either save silently, or build your own UI for **Save as**. These APIs pertain only to the **Save as** dialog, not the **Download** dialog, which continues to use the existing Download APIs. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveAsUIShowing Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.saveasuishowing?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2.ShowSaveAsUIAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showsaveasuiasync?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +* [CoreWebView2SaveAsKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2saveaskind?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * `Default` + * `HtmlOnly` + * `SingleFile` + * `Complete` + +* [CoreWebView2SaveAsUIResult Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuiresult?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * `Success` + * `InvalidPath` + * `FileAlreadyExists` + * `KindNotSupported` + * `Cancelled` + +* [CoreWebView2SaveAsUIShowingEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.AllowReplace Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.allowreplace?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.cancel?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.ContentMimeType Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.contentmimetype?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.kind?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.SaveAsFilePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.saveasfilepath?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.SuppressDefaultDialog Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.suppressdefaultdialog?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.getdeferral?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveAsUIShowing Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#saveasuishowing) + * [CoreWebView2.ShowSaveAsUIAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#showsaveasuiasync) + +* [CoreWebView2SaveAsKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveaskind?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true) + * `Default` + * `HtmlOnly` + * `SingleFile` + * `Complete` + +* [CoreWebView2SaveAsUIResult Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuiresult?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true) + * `Success` + * `InvalidPath` + * `FileAlreadyExists` + * `KindNotSupported` + * `Cancelled` + +* [CoreWebView2SaveAsUIShowingEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.AllowReplace Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#allowreplace) + * [CoreWebView2SaveAsUIShowingEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#cancel) + * [CoreWebView2SaveAsUIShowingEventArgs.ContentMimeType Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#contentmimetype) + * [CoreWebView2SaveAsUIShowingEventArgs.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#kind) + * [CoreWebView2SaveAsUIShowingEventArgs.SaveAsFilePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#saveasfilepath) + * [CoreWebView2SaveAsUIShowingEventArgs.SuppressDefaultDialog Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#suppressdefaultdialog) + * [CoreWebView2SaveAsUIShowingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_25](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2730-prerelease&preserve-view=true) + * [ICoreWebView2_25::add_SaveAsUIShowing](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2730-prerelease&preserve-view=true#add_saveasuishowing) + * [ICoreWebView2_25::remove_SaveAsUIShowing](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2730-prerelease&preserve-view=true#remove_saveasuishowing) + * [ICoreWebView2_25::ShowSaveAsUI](/microsoft-edge/webview2/reference/win32/icorewebview2_25?view=webview2-1.0.2730-prerelease&preserve-view=true#showsaveasui) + +* [ICoreWebView2SaveAsUIShowingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_AllowReplace](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#get_allowreplace) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#get_cancel) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_ContentMimeType](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#get_contentmimetype) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#get_kind) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_SaveAsFilePath](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#get_saveasfilepath) + * [ICoreWebView2SaveAsUIShowingEventArgs::get_SuppressDefaultDialog](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#get_suppressdefaultdialog) + * [ICoreWebView2SaveAsUIShowingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_AllowReplace](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#put_allowreplace) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#put_cancel) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#put_kind) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_SaveAsFilePath](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#put_saveasfilepath) + * [ICoreWebView2SaveAsUIShowingEventArgs::put_SuppressDefaultDialog](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true#put_suppressdefaultdialog) + +* [ICoreWebView2SaveAsUIShowingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2saveasuishowingeventhandler?view=webview2-1.0.2730-prerelease&preserve-view=true) + +* [ICoreWebView2ShowSaveAsUICompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2showsaveasuicompletedhandler?view=webview2-1.0.2730-prerelease&preserve-view=true) + +* [COREWEBVIEW2_SAVE_AS_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2730-prerelease&preserve-view=true#corewebview2_save_as_kind) + * `COREWEBVIEW2_SAVE_AS_KIND_DEFAULT` + * `COREWEBVIEW2_SAVE_AS_KIND_HTML_ONLY` + * `COREWEBVIEW2_SAVE_AS_KIND_SINGLE_FILE` + * `COREWEBVIEW2_SAVE_AS_KIND_COMPLETE` + +* [COREWEBVIEW2_SAVE_AS_UI_RESULT enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2730-prerelease&preserve-view=true#corewebview2_save_as_ui_result) + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_SUCCESS` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_INVALID_PATH` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_FILE_ALREADY_EXISTS` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED` + +--- + + + +* Added support for Web Notification, for non-persistent notifications. The `NotificationReceived` event for `CoreWebView2` controls web notification handling, allowing customization or suppression by the host app. Unhandled notifications default to WebView2's UI. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.NotificationReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.notificationreceived?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +* [CoreWebView2Notification Class](/dotnet/api/microsoft.web.webview2.core.corewebview2notification?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +* [CoreWebView2NotificationReceivedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs?view=webview2-dotnet-1.0.2730-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.NotificationReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true#notificationreceived) + +* [CoreWebView2Notification Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true) + +* [CoreWebView2NotificationReceivedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.2730-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_24](/microsoft-edge/webview2/reference/win32/icorewebview2_24?view=webview2-1.0.2730-prerelease&preserve-view=true) + * [ICoreWebView2_24::add_NotificationReceived](/microsoft-edge/webview2/reference/win32/icorewebview2_24?view=webview2-1.0.2730-prerelease&preserve-view=true#add_notificationreceived) + * [ICoreWebView2_24::remove_NotificationReceived](/microsoft-edge/webview2/reference/win32/icorewebview2_24?view=webview2-1.0.2730-prerelease&preserve-view=true#remove_notificationreceived) + +* [ICoreWebView2Notification](/microsoft-edge/webview2/reference/win32/icorewebview2notification?view=webview2-1.0.2730-prerelease&preserve-view=true) + +* [ICoreWebView2NotificationCloseRequestedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2notificationcloserequestedeventhandler?view=webview2-1.0.2730-prerelease&preserve-view=true) + +* [ICoreWebView2NotificationReceivedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventargs?view=webview2-1.0.2730-prerelease&preserve-view=true) + +* [ICoreWebView2NotificationReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2notificationreceivedeventhandler?view=webview2-1.0.2730-prerelease&preserve-view=true) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed an issue where the app window couldn't be controlled via system commands (such as **Alt+F4** or **Alt+Spacebar**) when the focus was in WebView2 for Visual hosting mode. ([Issue #2961](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2961)) + +* Fixed a bug in WebView2 UWP where the Find bar couldn't be clicked into from the host app. + + + +###### SDK-only + +* Adding the missing WinRT `CoreWebView2Notification.VibrationPattern` API. This WinRT API can be combined with the stable notification API promotion release notes; see "Web Notification" and `NotificationReceived` for WinRT, immediately above. + +* Fixed an issue where `KeyDown` events from the WinForms WebView2 control didn't include the correct `ModifierKeys` information. ([Issue #1216](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1216)) + +* Fixed x86 for WinRT C# projection. + +* Made `CreateCoreWebView2Environment` and `GetAvailableCoreWebView2BrowserVersionString` more robust against potential race condition during Runtime update. + + + + + +## Release SDK 1.0.2651.64, for Runtime 127 (Aug. 13, 2024) + +Release Date: Aug. 13, 2024 + +[NuGet package for WebView2 SDK 1.0.2651.64](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2651.64) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 127.0.2651.64 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +###### WebMessageObjects API: Inject DOM objects; file system handle + +Updated the WebMessageObjects API to allow injecting DOM objects into WebView2 content that's constructed via the app, and via the `CoreWebView2.PostWebMessage` API in the other direction. + +Added a new web object type (`CoreWebView2FileSystemHandle`) to represent a file system handle that can be posted to the web content to provide it with file system access. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostWebMessageAsJson(webMessageAsJson, additionalObjects) Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postwebmessageasjson?view=webview2-dotnet-1.0.2651.64&preserve-view=true#microsoft-web-webview2-core-corewebview2-postwebmessageasjson(system-string-system-collections-generic-list((system-object)))) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateWebFileSystemDirectoryHandle Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createwebfilesystemdirectoryhandle?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + * [CoreWebView2Environment.CreateWebFileSystemFileHandle Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createwebfilesystemfilehandle?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + +* `CoreWebView2FileSystemHandle` Class: + * [CoreWebView2FileSystemHandle.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.kind?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + * [CoreWebView2FileSystemHandle.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.path?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + * [CoreWebView2FileSystemHandle.Permission Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.permission?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + +* [CoreWebView2FileSystemHandleKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandlekind?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + * `File` + * `Directory` + +* [CoreWebView2FileSystemHandlePermission Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandlepermission?view=webview2-dotnet-1.0.2651.64&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostWebMessageAsJson(webMessageAsJson, additionalObjects) Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2651.64&preserve-view=true#postwebmessageasjson) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateWebFileSystemDirectoryHandle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2651.64&preserve-view=true#createwebfilesystemdirectoryhandle) + * [CoreWebView2Environment.CreateWebFileSystemFileHandle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2651.64&preserve-view=true#createwebfilesystemfilehandle) + +* `CoreWebView2FileSystemHandle` Class: + * [CoreWebView2FileSystemHandle.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2651.64&preserve-view=true#kind) + * [CoreWebView2FileSystemHandle.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2651.64&preserve-view=true#path) + * [CoreWebView2FileSystemHandle.Permission Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2651.64&preserve-view=true#permission) + +* [CoreWebView2FileSystemHandleKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandlekind?view=webview2-winrt-1.0.2651.64&preserve-view=true) + * `File` + * `Directory` + +* [CoreWebView2FileSystemHandlePermission Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandlepermission?view=webview2-winrt-1.0.2651.64&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_23](/microsoft-edge/webview2/reference/win32/icorewebview2_23?view=webview2-1.0.2651.64&preserve-view=true) + * [ICoreWebView2_23::PostWebMessageAsJsonWithAdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2_23?view=webview2-1.0.2651.64&preserve-view=true#postwebmessageasjsonwithadditionalobjects) + +* [ICoreWebView2Environment14](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2651.64&preserve-view=true) + * [ICoreWebView2Environment14::CreateObjectCollection](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2651.64&preserve-view=true#createobjectcollection) + * [ICoreWebView2Environment14::CreateWebFileSystemDirectoryHandle](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2651.64&preserve-view=true#createwebfilesystemdirectoryhandle) + * [ICoreWebView2Environment14::CreateWebFileSystemFileHandle](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2651.64&preserve-view=true#createwebfilesystemfilehandle) + +* [ICoreWebView2FileSystemHandle](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2651.64&preserve-view=true) + * [ICoreWebView2FileSystemHandle::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2651.64&preserve-view=true#get_kind) + * [ICoreWebView2FileSystemHandle::get_Path](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2651.64&preserve-view=true#get_path) + * [ICoreWebView2FileSystemHandle::get_Permission](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2651.64&preserve-view=true#get_permission) + +* [ICoreWebView2ObjectCollection](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollection?view=webview2-1.0.2651.64&preserve-view=true) + * [ICoreWebView2ObjectCollection::InsertValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollection?view=webview2-1.0.2651.64&preserve-view=true#insertvalueatindex) + * [ICoreWebView2ObjectCollection::RemoveValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollection?view=webview2-1.0.2651.64&preserve-view=true#removevalueatindex) + +* [COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2651.64&preserve-view=true#corewebview2_file_system_handle_kind) + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_FILE` + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_DIRECTORY` + +* [COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2651.64&preserve-view=true#corewebview2_file_system_handle_permission) + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY` + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_WRITE` + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a regression where `WebResourceRequested` events crash on certain sites. ([Issue #4602](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4602)) + + + +###### SDK-only + +* Fixed x86 for WinRT C# projection. + + + + + +## Prerelease SDK 1.0.2646-prerelease, for Runtime 128 (Jun. 19, 2024) + +Release Date: Jun. 19, 2024 + +[NuGet package for WebView2 SDK 1.0.2646-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2646-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 128.0.2646.0 or higher. + + + +#### General features + +* Added support for C#/WinRT .NET 6+. + + + +#### Experimental features + +* Introduced the feature flag `msWebView2EnableDownloadContentInWebResourceResponseReceived`, an an Experimental feature (rather than as a Stable feature). When this flag is enabled, this allows responses of navigations that become downloads to be available in `WebResourceResponseReceived`. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +###### `SaveFileSecurityCheckStarting` event + +Added a new `SaveFileSecurityCheckStarting` event. As a developer, you can register a handler on this event to get the file path, filename extension, and document origin URI information. + +Then you can apply your own rules to do actions such as the following: +* Allow saving the file without presenting a default security-warning UI about the file-type policy. +* Cancel the saving. +* Create your own UI to manage runtime file-type policies. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveFileSecurityCheckStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.savefilesecuritycheckstarting?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +* [CoreWebView2SaveFileSecurityCheckStartingEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.CancelSave Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.cancelsave?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.DocumentOriginUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.documentoriginuri?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FileExtension Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.fileextension?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FilePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.filepath?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.SuppressDefaultPolicy Property](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.suppressdefaultpolicy?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2savefilesecuritycheckstartingeventargs.getdeferral?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveFileSecurityCheckStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#savefilesecuritycheckstarting) + +* [CoreWebView2SaveFileSecurityCheckStartingEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.CancelSave Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#cancelsave) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.DocumentOriginUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#documentoriginuri) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FileExtension Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#fileextension) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.FilePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#filepath) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.SuppressDefaultPolicy Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#suppressdefaultpolicy) + * [CoreWebView2SaveFileSecurityCheckStartingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2savefilesecuritycheckstartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental27](/microsoft-edge/webview2/reference/win32/icorewebview2experimental27?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2Experimental27::add_SaveFileSecurityCheckStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimental27?view=webview2-1.0.2646-prerelease&preserve-view=true#add_savefilesecuritycheckstarting) + * [ICoreWebView2Experimental27::remove_SaveFileSecurityCheckStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimental27?view=webview2-1.0.2646-prerelease&preserve-view=true#remove_savefilesecuritycheckstarting) + +* [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::get_CancelSave](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_cancelsave) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::get_DocumentOriginUri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_documentoriginuri) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::get_FileExtension](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_fileextension) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::get_FilePath](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_filepath) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::get_SuppressDefaultPolicy](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_suppressdefaultpolicy) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::put_CancelSave](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#put_cancelsave) + * [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventArgs::put_SuppressDefaultPolicy](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#put_suppressdefaultpolicy) + +* [ICoreWebView2ExperimentalSaveFileSecurityCheckStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsavefilesecuritycheckstartingeventhandler?view=webview2-1.0.2646-prerelease&preserve-view=true) + +--- + + + +###### `ScreenCaptureStarting` event + +Added a new `ScreenCaptureStarting` event. This event is raised whenever the WebView2 and/or iframe that corresponds to the `CoreWebView2Frame` (or to any of its descendant iframes) requests permission to use the Screen Capture API before the UI is shown. + +As a developer, you can then choose to block the UI from being displayed, or allow the UI to be displayed. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ScreenCaptureStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.screencapturestarting?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.ScreenCaptureStarting Event](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.screencapturestarting?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +* `CoreWebView2ScreenCaptureStartingEventArgs` Class: + * [CoreWebView2ScreenCaptureStartingEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.cancel?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.Handled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.handled?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2ScreenCaptureStartingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2screencapturestartingeventargs.getdeferral?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ScreenCaptureStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#screencapturestarting) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.ScreenCaptureStarting Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#screencapturestarting) + +* `CoreWebView2ScreenCaptureStartingEventArgs` Class: + * [CoreWebView2ScreenCaptureStartingEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#cancel) + * [CoreWebView2ScreenCaptureStartingEventArgs.Handled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#handled) + * [CoreWebView2ScreenCaptureStartingEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#originalsourceframeinfo) + * [CoreWebView2ScreenCaptureStartingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2screencapturestartingeventargs?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental26](/microsoft-edge/webview2/reference/win32/icorewebview2experimental26?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2Experimental26::add_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimental26?view=webview2-1.0.2646-prerelease&preserve-view=true#add_screencapturestarting) + * [ICoreWebView2Experimental26::remove_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimental26?view=webview2-1.0.2646-prerelease&preserve-view=true#remove_screencapturestarting) + +* [ICoreWebView2ExperimentalFrame6](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe6?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFrame6::add_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe6?view=webview2-1.0.2646-prerelease&preserve-view=true#add_screencapturestarting) + * [ICoreWebView2ExperimentalFrame6::remove_ScreenCaptureStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe6?view=webview2-1.0.2646-prerelease&preserve-view=true#remove_screencapturestarting) + +* [ICoreWebView2ExperimentalFrameScreenCaptureStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframescreencapturestartingeventhandler?view=webview2-1.0.2646-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_cancel) + * [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs::get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_handled) + * [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#get_originalsourceframeinfo) + * [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#put_cancel) + * [ICoreWebView2ExperimentalScreenCaptureStartingEventArgs::put_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventargs?view=webview2-1.0.2646-prerelease&preserve-view=true#put_handled) + +* [ICoreWebView2ExperimentalScreenCaptureStartingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscreencapturestartingeventhandler?view=webview2-1.0.2646-prerelease&preserve-view=true) + +--- + + + +###### `GetComICoreWebView2` method + +Added a new `GetComICoreWebView2` method to the `CoreWebView2` .NET class that enables you to convert a `CoreWebView2` between .NET and COM. + +Added a new WinRT interface that enables you to convert a `CoreWebView2` between WinRT and COM. This allows you to interoperate between libraries that are written in different languages. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.GetComICoreWebView2 Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.getcomicorewebview2?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `ICoreWebView2Interop2` Interface: + * [ICoreWebView2Interop2::GetComICoreWebView2 Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2interop2?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#getcomicorewebview2) + +##### [Win32/C++](#tab/win32cpp) + +Not applicable. + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +###### WebMessageObjects API: Inject DOM objects; file system handle + +Updated the WebMessageObjects API to allow injecting DOM objects into WebView2 content that's constructed via the app, and via the `CoreWebView2.PostWebMessage` API in the other direction. + +Added a new web object type (`CoreWebView2FileSystemHandle`) to represent a file system handle that can be posted to the web content to provide it with file system access. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostWebMessageAsJsonWithAdditionalObjects Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postwebmessageasjsonwithadditionalobjects?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateWebFileSystemDirectoryHandle Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createwebfilesystemdirectoryhandle?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2Environment.CreateWebFileSystemFileHandle Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createwebfilesystemfilehandle?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +* `CoreWebView2FileSystemHandle` Class: + * [CoreWebView2FileSystemHandle.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.kind?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2FileSystemHandle.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.path?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * [CoreWebView2FileSystemHandle.Permission Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.permission?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + +* [CoreWebView2FileSystemHandleKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandlekind?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * `File` + * `Directory` + +* [CoreWebView2FileSystemHandlePermission Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandlepermission?view=webview2-dotnet-1.0.2646-prerelease&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostWebMessageAsJsonWithAdditionalObjects Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#postwebmessageasjsonwithadditionalobjects) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateWebFileSystemDirectoryHandle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#createwebfilesystemdirectoryhandle) + * [CoreWebView2Environment.CreateWebFileSystemFileHandle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#createwebfilesystemfilehandle) + +* `CoreWebView2FileSystemHandle` Class: + * [CoreWebView2FileSystemHandle.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#kind) + * [CoreWebView2FileSystemHandle.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#path) + * [CoreWebView2FileSystemHandle.Permission Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true#permission) + +* [CoreWebView2FileSystemHandleKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandlekind?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true) + * `File` + * `Directory` + +* [CoreWebView2FileSystemHandlePermission Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandlepermission?view=webview2-winrt-1.0.2646-prerelease&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_23](/microsoft-edge/webview2/reference/win32/icorewebview2_23?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2_23::PostWebMessageAsJsonWithAdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2_23?view=webview2-1.0.2646-prerelease&preserve-view=true#postwebmessageasjsonwithadditionalobjects) + +* [ICoreWebView2Environment14](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2Environment14::CreateObjectCollection](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2646-prerelease&preserve-view=true#createobjectcollection) + * [ICoreWebView2Environment14::CreateWebFileSystemDirectoryHandle](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2646-prerelease&preserve-view=true#createwebfilesystemdirectoryhandle) + * [ICoreWebView2Environment14::CreateWebFileSystemFileHandle](/microsoft-edge/webview2/reference/win32/icorewebview2environment14?view=webview2-1.0.2646-prerelease&preserve-view=true#createwebfilesystemfilehandle) + +* [ICoreWebView2FileSystemHandle](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2FileSystemHandle::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2646-prerelease&preserve-view=true#get_kind) + * [ICoreWebView2FileSystemHandle::get_Path](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2646-prerelease&preserve-view=true#get_path) + * [ICoreWebView2FileSystemHandle::get_Permission](/microsoft-edge/webview2/reference/win32/icorewebview2filesystemhandle?view=webview2-1.0.2646-prerelease&preserve-view=true#get_permission) + +* [ICoreWebView2ObjectCollection](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollection?view=webview2-1.0.2646-prerelease&preserve-view=true) + * [ICoreWebView2ObjectCollection::InsertValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollection?view=webview2-1.0.2646-prerelease&preserve-view=true#insertvalueatindex) + * [ICoreWebView2ObjectCollection::RemoveValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollection?view=webview2-1.0.2646-prerelease&preserve-view=true#removevalueatindex) + +* [COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2646-prerelease&preserve-view=true#corewebview2_file_system_handle_kind) + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_FILE` + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_DIRECTORY` + +* [COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2646-prerelease&preserve-view=true#corewebview2_file_system_handle_permission) + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY` + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_WRITE` + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a bug in owned-window activation logic for visual hosting. + + + + + +## Release SDK 1.0.2592.51, for Runtime 126 (Jun. 19, 2024) + +Release Date: Jun. 19, 2024 + +[NuGet package for WebView2 SDK 1.0.2592.51](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2592.51) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 126.0.2592.51 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + + + +###### Runtime-only + +* Disabled `BreakoutBoxPreferCaptureTimestampInVideoFrame` for WebView2 `TextureStream`. + +* Fixed a regression where the `WindowCloseRequested` event only fires for first `window.close()` call. + +* Fixed a regression where typed arrays in WinRT JavaScript projection could not be handled as `IDispatch` in the host. + +* Fixed a bug where the autofill popup dismisses immediately and causes a focus change. + +* Fixed a bug where WebView2 fails to load because of `AppPolicyGetWindowingModel`. ([Issue #4591](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4591)) + + + + + +## Prerelease SDK 1.0.2584-prerelease, for Runtime 126 (May 28, 2024) + +Release Date: May 28, 2024 + +[NuGet package for WebView2 SDK 1.0.2584-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2584-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 126.0.2584.0 or higher. + + + +#### Experimental features + +* Introduced an option to cancel the initial navigation in WebView2, to improve startup performance. This change is disabled by default, and can be enabled by using the `msWebView2CancelInitialNavigation` feature flag. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +No APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, in this Prerelease SDK. + + + +#### Bug fixes + + + +###### Runtime and SDK + +* Fixed a crash when .NET host object async methods return a null result. ([Issue #4509](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4509)) + + + +###### Runtime-only + +* Fixed a WebView2 memory leak issue when the window is closed. ([Issue #4286](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4286)) + +* Fixed an issue where `ignoreMemberNotFoundError` wasn't working for .NET objects. ([Issue #4497](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4497)) + +* Now returns a proper error code when `CreateSharedBuffer` is called with 0 buffer size. ([Issue #4554](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4554)) + +* Fixed an activation issue for the caret browsing dialog. + +* Fixed an issue where the WebView2 Visual Hosting `CursorChanged` event wasn't firing for custom cursors. + + + + + +## Release SDK 1.0.2535.41, for Runtime 125 (May 28, 2024) + +Release Date: May 28, 2024 + +[NuGet package for WebView2 SDK 1.0.2535.41](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2535.41) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 125.0.2535.41 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* Support for the Fluent Style Overlay Scrollbar. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ScrollBarStyle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.scrollbarstyle?view=webview2-dotnet-1.0.2535.41&preserve-view=true) + +* [CoreWebView2ScrollbarStyle Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2scrollbarstyle?view=webview2-dotnet-1.0.2535.41&preserve-view=true) + * `Default` + * `FluentOverlay` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ScrollBarStyle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2535.41&preserve-view=true#scrollbarstyle) + +* [CoreWebView2ScrollbarStyle Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scrollbarstyle?view=webview2-winrt-1.0.2535.41&preserve-view=true) + * `Default` + * `FluentOverlay` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2EnvironmentOptions8](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions8?view=webview2-1.0.2535.41&preserve-view=true) + * [ICoreWebView2EnvironmentOptions8::get_ScrollBarStyle](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions8?view=webview2-1.0.2535.41&preserve-view=true#get_scrollbarstyle) + * [ICoreWebView2EnvironmentOptions8::put_ScrollBarStyle](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions8?view=webview2-1.0.2535.41&preserve-view=true#put_scrollbarstyle) + +* [COREWEBVIEW2_SCROLLBAR_STYLE enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2535.41&preserve-view=true#corewebview2_scrollbar_style) + * `COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT` + * `COREWEBVIEW2_SCROLLBAR_STYLE_FLUENT_OVERLAY` + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a bug where if the `LaunchingExternalURIScheme` event handler is attached, and the **always remember** checkbox is enabled, and the user selects this checkbox, the dialog is incorrectly displayed again. + +* Fixed an issue where text edit controls in visual hosting would duplicate IME input when losing and then regaining focus. + +* Fixed an issue where full-trust UWP apps couldn't display owned windows. + + + +###### SDK-only + +* Fixed an issue in the SDK causing erroneous \ values in the .NET project platforms list. ([Issue #1755](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1755)) + + + + + +## Prerelease SDK 1.0.2526-prerelease, for Runtime 125 (Apr. 22, 2024) + +Release Date: Apr. 22, 2024 + +[NuGet package for WebView2 SDK 1.0.2526-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2526-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 125.0.2526.0 or higher. + + + +#### Breaking changes + + + +###### Minimum .NET Framework version + +The minimum .NET Framework version requirement for .NET WebView2, including WPF and WinForms controls, has been updated from .NET Framework 4.5 to .NET Framework 4.6.2. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +###### `SaveAs` APIs + +Added `SaveAs` APIs that allow you to programmatically perform the **Save as** operation. You can use these APIs to block the default **Save as** dialog, and then either save silently, or build your own UI for **Save as**. + +These APIs pertain only to the **Save as** dialog, not the **Download** dialog, which continues to use the existing Download APIs. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveAsUIShowing Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.saveasuishowing?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2.ShowSaveAsUIAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showsaveasuiasync?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + +* [CoreWebView2SaveAsKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2saveaskind?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * `Complete` + * `Default` + * `HtmlOnly` + * `SingleFile` + +* [CoreWebView2SaveAsUIResult Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuiresult?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * `Cancelled` + * `FileAlreadyExists` + * `InvalidPath` + * `KindNotSupported` + * `Success` + +* `CoreWebView2SaveAsUIShowingEventArgs` Class: + * [CoreWebView2SaveAsUIShowingEventArgs.AllowReplace Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.allowreplace?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.cancel?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.ContentMimeType Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.contentmimetype?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.kind?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.SaveAsFilePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.saveasfilepath?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.SuppressDefaultDialog Property](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.suppressdefaultdialog?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * [CoreWebView2SaveAsUIShowingEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2saveasuishowingeventargs.getdeferral?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.SaveAsUIShowing Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#saveasuishowing) + * [CoreWebView2.ShowSaveAsUIAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#showsaveasuiasync) + +* [CoreWebView2SaveAsKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveaskind?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true) + * `Complete` + * `Default` + * `HtmlOnly` + * `SingleFile` + +* [CoreWebView2SaveAsUIResult Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuiresult?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true) + * `Cancelled` + * `FileAlreadyExists` + * `InvalidPath` + * `KindNotSupported` + * `Success` + +* `CoreWebView2SaveAsUIShowingEventArgs` Class: + * [CoreWebView2SaveAsUIShowingEventArgs.AllowReplace Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#allowreplace) + * [CoreWebView2SaveAsUIShowingEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#cancel) + * [CoreWebView2SaveAsUIShowingEventArgs.ContentMimeType Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#contentmimetype) + * [CoreWebView2SaveAsUIShowingEventArgs.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#kind) + * [CoreWebView2SaveAsUIShowingEventArgs.SaveAsFilePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#saveasfilepath) + * [CoreWebView2SaveAsUIShowingEventArgs.SuppressDefaultDialog Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#suppressdefaultdialog) + * [CoreWebView2SaveAsUIShowingEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2saveasuishowingeventargs?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental25](/microsoft-edge/webview2/reference/win32/icorewebview2experimental25?view=webview2-1.0.2526-prerelease&preserve-view=true) + * [ICoreWebView2Experimental25::add_SaveAsUIShowing](/microsoft-edge/webview2/reference/win32/icorewebview2experimental25?view=webview2-1.0.2526-prerelease&preserve-view=true#add_saveasuishowing) + * [ICoreWebView2Experimental25::remove_SaveAsUIShowing](/microsoft-edge/webview2/reference/win32/icorewebview2experimental25?view=webview2-1.0.2526-prerelease&preserve-view=true#remove_saveasuishowing) + * [ICoreWebView2Experimental25::ShowSaveAsUI](/microsoft-edge/webview2/reference/win32/icorewebview2experimental25?view=webview2-1.0.2526-prerelease&preserve-view=true#showsaveasui) + +* [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::get_AllowReplace](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#get_allowreplace) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#get_cancel) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::get_ContentMimeType](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#get_contentmimetype) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#get_kind) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::get_SaveAsFilePath](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#get_saveasfilepath) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::get_SuppressDefaultDialog](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#get_suppressdefaultdialog) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::put_AllowReplace](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#put_allowreplace) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#put_cancel) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::put_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#put_kind) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::put_SaveAsFilePath](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#put_saveasfilepath) + * [ICoreWebView2ExperimentalSaveAsUIShowingEventArgs::put_SuppressDefaultDialog](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventargs?view=webview2-1.0.2526-prerelease&preserve-view=true#put_suppressdefaultdialog) + +* [ICoreWebView2ExperimentalSaveAsUIShowingEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsaveasuishowingeventhandler?view=webview2-1.0.2526-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalShowSaveAsUICompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalshowsaveasuicompletedhandler?view=webview2-1.0.2526-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalShowSaveAsUICompletedHandler::Invoke](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalshowsaveasuicompletedhandler?view=webview2-1.0.2526-prerelease&preserve-view=true#invoke) + +* [COREWEBVIEW2_SAVE_AS_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2526-prerelease&preserve-view=true#corewebview2_save_as_kind) + * `COREWEBVIEW2_SAVE_AS_KIND_DEFAULT` + * `COREWEBVIEW2_SAVE_AS_KIND_HTML_ONLY` + * `COREWEBVIEW2_SAVE_AS_KIND_SINGLE_FILE` + * `COREWEBVIEW2_SAVE_AS_KIND_COMPLETE` + +* [COREWEBVIEW2_SAVE_AS_UI_RESULT enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2526-prerelease&preserve-view=true#corewebview2_save_as_ui_result) + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_SUCCESS` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_INVALID_PATH` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_FILE_ALREADY_EXISTS` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED` + * `COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED` + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* Support for the Fluent Style Overlay Scrollbar. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ScrollBarStyle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.scrollbarstyle?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + +* [CoreWebView2ScrollbarStyle Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2scrollbarstyle?view=webview2-dotnet-1.0.2526-prerelease&preserve-view=true) + * `Default` + * `FluentOverlay` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ScrollBarStyle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true#scrollbarstyle) + +* [CoreWebView2ScrollbarStyle Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scrollbarstyle?view=webview2-winrt-1.0.2526-prerelease&preserve-view=true) + * `Default` + * `FluentOverlay` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2EnvironmentOptions8](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions8?view=webview2-1.0.2526-prerelease&preserve-view=true) + * [ICoreWebView2EnvironmentOptions8::get_ScrollBarStyle](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions8?view=webview2-1.0.2526-prerelease&preserve-view=true#get_scrollbarstyle) + * [ICoreWebView2EnvironmentOptions8::put_ScrollBarStyle](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions8?view=webview2-1.0.2526-prerelease&preserve-view=true#put_scrollbarstyle) + +* [COREWEBVIEW2_SCROLLBAR_STYLE enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2526-prerelease&preserve-view=true#corewebview2_scrollbar_style) + * `COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT` + * `COREWEBVIEW2_SCROLLBAR_STYLE_FLUENT_OVERLAY` + +--- + + + +#### Bug fixes + + + +###### Runtime and SDK + +* Fixed a bug in WinRT JavaScript projection where passing in a typed array resulted in an "Interface Not Supported" error. ([Issue #3486](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3486)) + +* Added support for handling `out` array parameters in WinRT JavaScript projection. + + + +###### Runtime-only + +* Fixed a bug where the Image Auto-captioning feature was enabled by default. + +* Fixed a bug where if the `LaunchingExternalURIScheme` event handler is attached, if the **always remember** checkbox is enabled and the user selects this checkbox, the dialog will incorrectly be shown again. + +* Fixed `GetNonClientRegionAtPoint` incorrectly returning `Nowhere` for some points. + +* Fixed a bug where the Text Services Framework would disconnect upon dropping a file onto a WebView2 region. + +* Fixed a bug where the View Source **Ctrl+U** keyboard shortcut remained enabled when the `AreDevToolsEnabled` setting was `false`. + +* Fixed a bug where a composable IME was duplicated upon regaining focus. ([Issue #1610](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1610)) + +* Ensured that `devicePixelRatio` is synchronized with custom rasterization scales. ([Issue #3060](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3060)) + +* Fixed a race condition when using `CallDevToolsProtocolMethod` events in `NewWindowRequested`. ([Issue #4181](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4181)) + +* Fixed a crash that can occur in WPF `TabIntoCore` when the `Controller` has been destroyed but the user tries to tab into the control (pressing the **Tab** key). ([Issue #4452](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4452)) + +* Ensured that spellcheck takes input language with case-insensitive format. + +* Made the Language API more robust regarding user input. + +* Fixed a bug where the **Save password?** prompt is not displayed. + + + +###### SDK-only + +* Fixed missing `AreBrowserExtensionsEnabled` API in WinRT projection. + + + + + +## Release SDK 1.0.2478.35, for Runtime 124 (Apr. 22, 2024) + +Release Date: Apr. 22, 2024 + +[NuGet package for WebView2 SDK 1.0.2478.35](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2478.35) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 124.0.2478.35 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* Added the Runtime selection feature to support more prerelease testing and flighting scenarios. You can specify `ReleaseChannels` to choose which channels are searched for during environment creation, and `ChannelSearchKind` to select a search order. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ChannelSearchKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.channelsearchkind?view=webview2-dotnet-1.0.2478.35&preserve-view=true) + * [CoreWebView2EnvironmentOptions.ReleaseChannels Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.releasechannels?view=webview2-dotnet-1.0.2478.35&preserve-view=true) + +* [CoreWebView2ChannelSearchKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2channelsearchkind?view=webview2-dotnet-1.0.2478.35&preserve-view=true) + * `MostStable` + * `LeastStable` + +* [CoreWebView2ReleaseChannels Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2releasechannels?view=webview2-dotnet-1.0.2478.35&preserve-view=true) + * `None` + * `Stable` + * `Beta` + * `Dev` + * `Canary` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ChannelSearchKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2478.35&preserve-view=true#channelsearchkind) + * [CoreWebView2EnvironmentOptions.ReleaseChannels Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2478.35&preserve-view=true#releasechannels) + +* [CoreWebView2ChannelSearchKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2channelsearchkind?view=webview2-winrt-1.0.2478.35&preserve-view=true) + * `MostStable` + * `LeastStable` + +* [CoreWebView2ReleaseChannels Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2releasechannels?view=webview2-winrt-1.0.2478.35&preserve-view=true) + * `None` + * `Stable` + * `Beta` + * `Dev` + * `Canary` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2EnvironmentOptions7](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2478.35&preserve-view=true) + * [ICoreWebView2EnvironmentOptions7::get_ChannelSearchKind](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2478.35&preserve-view=true#get_channelsearchkind) + * [ICoreWebView2EnvironmentOptions7::put_ChannelSearchKind](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2478.35&preserve-view=true#put_channelsearchkind) + * [ICoreWebView2EnvironmentOptions7::get_ReleaseChannels](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2478.35&preserve-view=true#get_releasechannels) + * [ICoreWebView2EnvironmentOptions7::put_ReleaseChannels](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2478.35&preserve-view=true#put_releasechannels) + +* [COREWEBVIEW2_CHANNEL_SEARCH_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2478.35&preserve-view=true#corewebview2_channel_search_kind) + * `COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE` + * `COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE` + +* [COREWEBVIEW2_RELEASE_CHANNELS enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2478.35&preserve-view=true#corewebview2_release_channels) + * `COREWEBVIEW2_RELEASE_CHANNELS_NONE` + * `COREWEBVIEW2_RELEASE_CHANNELS_STABLE` + * `COREWEBVIEW2_RELEASE_CHANNELS_BETA` + * `COREWEBVIEW2_RELEASE_CHANNELS_DEV` + * `COREWEBVIEW2_RELEASE_CHANNELS_CANARY` + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixes a potential integer overflow that could lead to a crash when using `AdditionalObjects` in the WebMessage API. + + + + + +## Prerelease SDK 1.0.2470-prerelease, for Runtime 124 (Mar. 25, 2024) + +Release Date: Mar. 25, 2024 + +[NuGet package for WebView2 SDK 1.0.2470-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2470-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires WebView2 Runtime version 124.0.2470.0 or higher. + + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +* Support for the Fluent Style Overlay Scrollbar. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ScrollBarStyle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.scrollbarstyle?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + +* [CoreWebView2ScrollbarStyle Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2scrollbarstyle?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * `Default` + * `FluentOverlay` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ScrollBarStyle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#scrollbarstyle) + +* [CoreWebView2ScrollbarStyle Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scrollbarstyle?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true) + * `Default` + * `FluentOverlay` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalEnvironmentOptions2](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironmentOptions2::get_ScrollBarStyle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.2470-prerelease&preserve-view=true#get_scrollbarstyle) + * [ICoreWebView2ExperimentalEnvironmentOptions2::put_ScrollBarStyle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.2470-prerelease&preserve-view=true#put_scrollbarstyle) + +* [COREWEBVIEW2_SCROLLBAR_STYLE enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2470-prerelease&preserve-view=true#corewebview2_scrollbar_style) + * `COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT` + * `COREWEBVIEW2_SCROLLBAR_STYLE_FLUENT_OVERLAY` + +--- + + + +###### WebMessageObjects API: Inject DOM objects; file system handle + +Updated the WebMessageObjects API to allow injecting DOM objects into WebView2 content that's constructed via the app and via the `CoreWebView2.PostWebMessage` API in the other direction. + +Added a new web object type (`CoreWebView2FileSystemHandle`) to represent a file system handle that can be posted to the web content to provide it with file system access. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostWebMessageAsJsonWithAdditionalObjects Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postwebmessageasjsonwithadditionalobjects?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateWebFileSystemDirectoryHandle Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createwebfilesystemdirectoryhandle?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * [CoreWebView2Environment.CreateWebFileSystemFileHandle Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createwebfilesystemfilehandle?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + +* `CoreWebView2FileSystemHandle` Class: + * [CoreWebView2FileSystemHandle.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.kind?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * [CoreWebView2FileSystemHandle.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.path?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * [CoreWebView2FileSystemHandle.Permission Property](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandle.permission?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + +* [CoreWebView2FileSystemHandleKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandlekind?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * `File` + * `Directory` + +* [CoreWebView2FileSystemHandlePermission Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2filesystemhandlepermission?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostWebMessageAsJsonWithAdditionalObjects Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#postwebmessageasjsonwithadditionalobjects) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.CreateWebFileSystemDirectoryHandle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#createwebfilesystemdirectoryhandle) + * [CoreWebView2Environment.CreateWebFileSystemFileHandle Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#createwebfilesystemfilehandle) + +* `CoreWebView2FileSystemHandle` Class: + * [CoreWebView2FileSystemHandle.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#kind) + * [CoreWebView2FileSystemHandle.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#path) + * [CoreWebView2FileSystemHandle.Permission Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandle?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#permission) + +* [CoreWebView2FileSystemHandleKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandlekind?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true) + * `File` + * `Directory` + +* [CoreWebView2FileSystemHandlePermission Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2filesystemhandlepermission?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental24](/microsoft-edge/webview2/reference/win32/icorewebview2experimental24?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2Experimental24::PostWebMessageAsJsonWithAdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2experimental24?view=webview2-1.0.2470-prerelease&preserve-view=true#postwebmessageasjsonwithadditionalobjects) + +* [ICoreWebView2ExperimentalEnvironment14](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment14?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironment14::CreateObjectCollection](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment14?view=webview2-1.0.2470-prerelease&preserve-view=true#createobjectcollection) + * [ICoreWebView2ExperimentalEnvironment14::CreateWebFileSystemDirectoryHandle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment14?view=webview2-1.0.2470-prerelease&preserve-view=true#createwebfilesystemdirectoryhandle) + * [ICoreWebView2ExperimentalEnvironment14::CreateWebFileSystemFileHandle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment14?view=webview2-1.0.2470-prerelease&preserve-view=true#createwebfilesystemfilehandle) + +* [ICoreWebView2ExperimentalFileSystemHandle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfilesystemhandle?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFileSystemHandle::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfilesystemhandle?view=webview2-1.0.2470-prerelease&preserve-view=true#get_kind) + * [ICoreWebView2ExperimentalFileSystemHandle::get_Path](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfilesystemhandle?view=webview2-1.0.2470-prerelease&preserve-view=true#get_path) + * [ICoreWebView2ExperimentalFileSystemHandle::get_Permission](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfilesystemhandle?view=webview2-1.0.2470-prerelease&preserve-view=true#get_permission) + +* [ICoreWebView2ExperimentalObjectCollection](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollection?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalObjectCollection::InsertValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollection?view=webview2-1.0.2470-prerelease&preserve-view=true#insertvalueatindex) + * [ICoreWebView2ExperimentalObjectCollection::RemoveValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollection?view=webview2-1.0.2470-prerelease&preserve-view=true#removevalueatindex) + +* [COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2470-prerelease&preserve-view=true#corewebview2_file_system_handle_kind) + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_FILE` + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_DIRECTORY` + +* [COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2470-prerelease&preserve-view=true#corewebview2_file_system_handle_permission) + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY` + * `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_WRITE` + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* Added the Runtime selection feature to support more prerelease testing and flighting scenarios. You can specify `ReleaseChannels` to choose which channels are searched for during environment creation, and `ChannelSearchKind` to select a search order. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ChannelSearchKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.channelsearchkind?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * [CoreWebView2EnvironmentOptions.ReleaseChannels Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.releasechannels?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + +* [CoreWebView2ChannelSearchKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2channelsearchkind?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * `MostStable` + * `LeastStable` + +* [CoreWebView2ReleaseChannels Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2releasechannels?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + * `None` + * `Stable` + * `Beta` + * `Dev` + * `Canary` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ChannelSearchKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#channelsearchkind) + * [CoreWebView2EnvironmentOptions.ReleaseChannels Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#releasechannels) + +* [CoreWebView2ChannelSearchKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2channelsearchkind?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true) + * `MostStable` + * `LeastStable` + +* [CoreWebView2ReleaseChannels Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2releasechannels?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true) + * `None` + * `Stable` + * `Beta` + * `Dev` + * `Canary` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2EnvironmentOptions7](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2EnvironmentOptions7::get_ChannelSearchKind](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2470-prerelease&preserve-view=true#get_channelsearchkind) + * [ICoreWebView2EnvironmentOptions7::put_ChannelSearchKind](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2470-prerelease&preserve-view=true#put_channelsearchkind) + * [ICoreWebView2EnvironmentOptions7::get_ReleaseChannels](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2470-prerelease&preserve-view=true#get_releasechannels) + * [ICoreWebView2EnvironmentOptions7::put_ReleaseChannels](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions7?view=webview2-1.0.2470-prerelease&preserve-view=true#put_releasechannels) + +* [COREWEBVIEW2_CHANNEL_SEARCH_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2470-prerelease&preserve-view=true#corewebview2_channel_search_kind) + * `COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE` + * `COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE` + +* [COREWEBVIEW2_RELEASE_CHANNELS enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2470-prerelease&preserve-view=true#corewebview2_release_channels) + * `COREWEBVIEW2_RELEASE_CHANNELS_NONE` + * `COREWEBVIEW2_RELEASE_CHANNELS_STABLE` + * `COREWEBVIEW2_RELEASE_CHANNELS_BETA` + * `COREWEBVIEW2_RELEASE_CHANNELS_DEV` + * `COREWEBVIEW2_RELEASE_CHANNELS_CANARY` + +--- + + + +* Added the `FailureSourceModulePath` property to the `ProcessFailedEventArgs` type, to specify the full path of the module that caused the crash in cases of Windows code integrity failures - that is, when a process exited with `STATUS_INVALID_IMAGE_HASH`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ProcessFailedEventArgs` Class: + * [CoreWebView2ProcessFailedEventArgs.FailureSourceModulePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processfailedeventargs.failuresourcemodulepath?view=webview2-dotnet-1.0.2470-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ProcessFailedEventArgs` Class: + * [CoreWebView2ProcessFailedEventArgs.FailureSourceModulePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processfailedeventargs?view=webview2-winrt-1.0.2470-prerelease&preserve-view=true#failuresourcemodulepath) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ProcessFailedEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2processfailedeventargs3?view=webview2-1.0.2470-prerelease&preserve-view=true) + * [ICoreWebView2ProcessFailedEventArgs3::get_FailureSourceModulePath](/microsoft-edge/webview2/reference/win32/icorewebview2processfailedeventargs3?view=webview2-1.0.2470-prerelease&preserve-view=true#get_failuresourcemodulepath) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a reliability regression that could crash the application process when an old version of WebView2 client DLL is unloaded. + +* Ensured that the WebView2 temporary download folder is unique per user data folder, and doesn't interfere with other apps or the browser. + + + + + +## Release SDK 1.0.2420.47, for Runtime 123 (Mar. 25, 2024) + +Release Date: Mar. 25, 2024 + +[NuGet package for WebView2 SDK 1.0.2420.47](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2420.47) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 123.0.2420.47 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* Added a new API to provide hit-testing results on the regions that a WebView2 contains. This API is useful for visually hosted applications that want to handle mouse events on the non-client area of the WebView2 window. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2CompositionController` Class: + * [CoreWebView2CompositionController.GetNonClientRegionAtPoint Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.getnonclientregionatpoint?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + * [CoreWebView2CompositionController.NonClientRegionChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.nonclientregionchanged?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + * [CoreWebView2CompositionController.QueryNonClientRegion Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.querynonclientregion?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + +* `CoreWebView2NonClientRegionChangedEventArgs` Class: + * [CoreWebView2NonClientRegionChangedEventArgs.RegionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionchangedeventargs.regionkind?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + +* [CoreWebView2NonClientRegionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionkind?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + * `Caption` + * `Client` + * `Nowhere` + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.IsNonClientRegionSupportEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isnonclientregionsupportenabled?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2CompositionController` Class: + * [CoreWebView2CompositionController.GetNonClientRegionAtPoint Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2420.47&preserve-view=true#getnonclientregionatpoint) + * [CoreWebView2CompositionController.NonClientRegionChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2420.47&preserve-view=true#nonclientregionchanged) + * [CoreWebView2CompositionController.QueryNonClientRegion Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2420.47&preserve-view=true#querynonclientregion) + +* `CoreWebView2NonClientRegionChangedEventArgs` Class: + * [CoreWebView2NonClientRegionChangedEventArgs.RegionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionchangedeventargs?view=webview2-winrt-1.0.2420.47&preserve-view=true#regionkind) + +* [CoreWebView2NonClientRegionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionkind?view=webview2-winrt-1.0.2420.47&preserve-view=true) + * `Caption` + * `Client` + * `Nowhere` + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.IsNonClientRegionSupportEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2420.47&preserve-view=true#isnonclientregionsupportenabled) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2CompositionController4](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2420.47&preserve-view=true) + * [ICoreWebView2CompositionController4::add_NonClientRegionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2420.47&preserve-view=true#add_nonclientregionchanged) + * [ICoreWebView2CompositionController4::GetNonClientRegionAtPoint](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2420.47&preserve-view=true#getnonclientregionatpoint) + * [ICoreWebView2CompositionController4::QueryNonClientRegion](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2420.47&preserve-view=true#querynonclientregion) + * [ICoreWebView2CompositionController4::remove_NonClientRegionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2420.47&preserve-view=true#remove_nonclientregionchanged) + +* [ICoreWebView2NonClientRegionChangedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2nonclientregionchangedeventargs?view=webview2-1.0.2420.47&preserve-view=true) + * [ICoreWebView2NonClientRegionChangedEventArgs::get_RegionKind](/microsoft-edge/webview2/reference/win32/icorewebview2nonclientregionchangedeventargs?view=webview2-1.0.2420.47&preserve-view=true#get_regionkind) + +* [ICoreWebView2NonClientRegionChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2nonclientregionchangedeventhandler?view=webview2-1.0.2420.47&preserve-view=true) + +* [ICoreWebView2RegionRectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2regionrectcollectionview?view=webview2-1.0.2420.47&preserve-view=true) + +* [ICoreWebView2Settings9](/microsoft-edge/webview2/reference/win32/icorewebview2settings9?view=webview2-1.0.2420.47&preserve-view=true) + * [ICoreWebView2Settings9::get_IsNonClientRegionSupportEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings9?view=webview2-1.0.2420.47&preserve-view=true#get_isnonclientregionsupportenabled) + * [ICoreWebView2Settings9::put_IsNonClientRegionSupportEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings9?view=webview2-1.0.2420.47&preserve-view=true#put_isnonclientregionsupportenabled) + +* [COREWEBVIEW2_NON_CLIENT_REGION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2420.47&preserve-view=true#corewebview2_non_client_region_kind) + * `COREWEBVIEW2_NON_CLIENT_REGION_KIND_CAPTION` + * `COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLIENT` + * `COREWEBVIEW2_NON_CLIENT_REGION_KIND_NOWHERE` + +--- + + + +* Added the `FailureSourceModulePath` property to the `ProcessFailedEventArgs` type, to specify the full path of the module that caused the crash in cases of Windows code integrity failures - that is, when a process exited with `STATUS_INVALID_IMAGE_HASH`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ProcessFailedEventArgs` Class: + * [CoreWebView2ProcessFailedEventArgs.FailureSourceModulePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processfailedeventargs.failuresourcemodulepath?view=webview2-dotnet-1.0.2420.47&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ProcessFailedEventArgs` Class: + * [CoreWebView2ProcessFailedEventArgs.FailureSourceModulePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processfailedeventargs?view=webview2-winrt-1.0.2420.47&preserve-view=true#failuresourcemodulepath) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ProcessFailedEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2processfailedeventargs3?view=webview2-1.0.2420.47&preserve-view=true) + * [ICoreWebView2ProcessFailedEventArgs3::get_FailureSourceModulePath](/microsoft-edge/webview2/reference/win32/icorewebview2processfailedeventargs3?view=webview2-1.0.2420.47&preserve-view=true#get_failuresourcemodulepath) + +--- + + + +#### Bug fixes + + +###### SDK-only + +* The .NET assemblies for WinForms and WPF are now shipped with optimization enabled. ([Issue #4409](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4409)) + + + + + +## Prerelease SDK 1.0.2415-prerelease, for Runtime 123 (Feb. 26, 2024) + +Release Date: Feb. 26, 2024 + +[NuGet package for WebView2 SDK 1.0.2415-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2415-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 123.0.2415.0 or higher. + + + +#### Breaking changes + + + +* The behavior of the `InitiatingOrigin` property of `CoreWebView2LaunchingExternalUriSchemeEventArgs` has changed. If the `InitiatingOrigin` is an [opaque origin](https://html.spec.whatwg.org/multipage/browsers.html#concept-origin-opaque), the `InitiatingOrigin` that's reported in the event args is its precursor origin. The _precursor origin_ is the origin that created the opaque origin. For example, if a frame that's at `example.com` opens a subframe that has a different opaque origin, the subframe's precursor origin is `example.com`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2LaunchingExternalUriSchemeEventArgs` Class: + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2LaunchingExternalUriSchemeEventArgs` Class: + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#initiatingorigin) + +##### [Win32/C++](#tab/win32cpp) + +* `ICoreWebView2LaunchingExternalUriSchemeEventArgs`: + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.2415-prerelease&preserve-view=true#get_initiatingorigin) + +--- + + + +* The members of the `CoreWebView2TextureStreamErrorKind` enum have been renamed: + +##### [.NET/C#](#tab/dotnetcsharp) + +Old member names: +* [CoreWebView2TextureStreamErrorKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * `CoreWebView2TextureStreamErrorNoVideoTrackStarted` + * `CoreWebView2TextureStreamErrorTextureError` + * `CoreWebView2TextureStreamErrorTextureInUse` + +New member names: +* [CoreWebView2TextureStreamErrorKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + * `NoVideoTrackStarted` + * `TextureError` + * `TextureInUse` + +##### [WinRT/C#](#tab/winrtcsharp) + +Old member names: +* [CoreWebView2TextureStreamErrorKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + * `CoreWebView2TextureStreamErrorNoVideoTrackStarted` + * `CoreWebView2TextureStreamErrorTextureError` + * `CoreWebView2TextureStreamErrorTextureInUse` + +New member names: +* [CoreWebView2TextureStreamErrorKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true) + * `NoVideoTrackStarted` + * `TextureError` + * `TextureInUse` + +##### [Win32/C++](#tab/win32cpp) + +Old member names: +* [COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2357-prerelease&preserve-view=true#corewebview2_texture_stream_error_kind) + * `COREWEBVIEW2_TEXTURE_STREAM_ERROR_NO_VIDEO_TRACK_STARTED` + * `COREWEBVIEW2_TEXTURE_STREAM_ERROR_TEXTURE_ERROR` + * `COREWEBVIEW2_TEXTURE_STREAM_ERROR_TEXTURE_IN_USE` + +New member names: +* [COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2415-prerelease&preserve-view=true#corewebview2_texture_stream_error_kind) + * `COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND_NO_VIDEO_TRACK_STARTED` + * `COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND_TEXTURE_ERROR` + * `COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND_TEXTURE_IN_USE` + +--- + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + +* The `CoreWebView2ControllerOptions` class now has an `AllowHostInputProcessing` property, which allows user input messages (keyboard, mouse, touch, and pen) to pass through the browser window to be received by an app process window. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.AllowHostInputProcessing Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.allowhostinputprocessing?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class: + * [CoreWebView2ControllerOptions.AllowHostInputProcessing Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#allowhostinputprocessing) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalControllerOptions2](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions2?view=webview2-1.0.2415-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalControllerOptions2::get_AllowHostInputProcessing](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions2?view=webview2-1.0.2415-prerelease&preserve-view=true#get_allowhostinputprocessing) + * [ICoreWebView2ExperimentalControllerOptions2::put_AllowHostInputProcessing](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions2?view=webview2-1.0.2415-prerelease&preserve-view=true#put_allowhostinputprocessing) + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* Added a new API to provide hit-testing results on the regions that a WebView2 contains. This API is useful for visually hosted applications that want to handle mouse events on the non-client area of the WebView2 window. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2CompositionController` Class: + * [CoreWebView2CompositionController.GetNonClientRegionAtPoint Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.getnonclientregionatpoint?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + * [CoreWebView2CompositionController.QueryNonClientRegion Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.querynonclientregion?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + * [CoreWebView2CompositionController.NonClientRegionChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.nonclientregionchanged?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + +* [CoreWebView2NonClientRegionChangedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionchangedeventargs?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + * [CoreWebView2NonClientRegionChangedEventArgs.RegionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionchangedeventargs.regionkind?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + +* [CoreWebView2NonClientRegionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionkind?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.IsNonClientRegionSupportEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isnonclientregionsupportenabled?view=webview2-dotnet-1.0.2415-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2CompositionController` Class: + * [CoreWebView2CompositionController.GetNonClientRegionAtPoint Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#getnonclientregionatpoint) + * [CoreWebView2CompositionController.QueryNonClientRegion Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#querynonclientregion) + * [CoreWebView2CompositionController.NonClientRegionChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#nonclientregionchanged) + +* [CoreWebView2NonClientRegionChangedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionchangedeventargs?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true) + * [CoreWebView2NonClientRegionChangedEventArgs.RegionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionchangedeventargs?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#regionkind) + +* [CoreWebView2NonClientRegionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionkind?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true) + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.IsNonClientRegionSupportEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2415-prerelease&preserve-view=true#isnonclientregionsupportenabled) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2CompositionController4](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2415-prerelease&preserve-view=true) + * [ICoreWebView2CompositionController4::GetNonClientRegionAtPoint](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2415-prerelease&preserve-view=true#getnonclientregionatpoint) + * [ICoreWebView2CompositionController4::QueryNonClientRegion](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2415-prerelease&preserve-view=true#querynonclientregion) + * [ICoreWebView2CompositionController4::add_NonClientRegionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2415-prerelease&preserve-view=true#add_nonclientregionchanged) + * [ICoreWebView2CompositionController4::remove_NonClientRegionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller4?view=webview2-1.0.2415-prerelease&preserve-view=true#remove_nonclientregionchanged) + +* [ICoreWebView2NonClientRegionChangedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2nonclientregionchangedeventargs?view=webview2-1.0.2415-prerelease&preserve-view=true) + * [ICoreWebView2NonClientRegionChangedEventArgs::get_RegionKind](/microsoft-edge/webview2/reference/win32/icorewebview2nonclientregionchangedeventargs?view=webview2-1.0.2415-prerelease&preserve-view=true#get_regionkind) + +* [ICoreWebView2NonClientRegionChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2nonclientregionchangedeventhandler?view=webview2-1.0.2415-prerelease&preserve-view=true) + +* [ICoreWebView2RegionRectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2regionrectcollectionview?view=webview2-1.0.2415-prerelease&preserve-view=true) + +* [ICoreWebView2Settings9](/microsoft-edge/webview2/reference/win32/icorewebview2settings9?view=webview2-1.0.2415-prerelease&preserve-view=true) + * [ICoreWebView2Settings9::get_IsNonClientRegionSupportEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings9?view=webview2-1.0.2415-prerelease&preserve-view=true#get_isnonclientregionsupportenabled) + * [ICoreWebView2Settings9::put_IsNonClientRegionSupportEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings9?view=webview2-1.0.2415-prerelease&preserve-view=true#put_isnonclientregionsupportenabled) + +* [COREWEBVIEW2_NON_CLIENT_REGION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2415-prerelease&preserve-view=true#corewebview2_non_client_region_kind) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed the camera or mic not being able to open in Google Meet or Microsoft Teams meetings when the permission request is set to "not persisted" (that is, `SavesInProfile = false`). ([Issue #3592](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3592)) + +* Fixed appending an empty `--edge-webview-custom-scheme` command-line switch in a WebView2 browser process. + +* Disabled the global `UserDataFolder` registry key, so that this registry key can only be applied per-app. + +* Fixed the `NewWindowRequested` event not being fired when opened by a browser extension. ([Issue #3841](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3841)) + +* Fixed the `NewWindowRequested` event not being fired when opening a view source. ([Issue #4162](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4162)) + +* Fixed an issue to fire `StateChanged` and `BytesReceivedChanged` events when a download involves navigation. + +* Fixed a bug where the `BeforeUnload` dialog caused the WebView2 window to unexpectedly jump position. ([Issue #4350](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4350)) + +* Fixed an issue where `PrintAsync` prints a blank page if it is called too soon, before the PDF is fully loaded. ([Issue #3779](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3779)) + + + + + +## Release SDK 1.0.2365.46, for Runtime 122 (Feb. 26, 2024) + +Release Date: Feb. 26, 2024 + +[NuGet package for WebView2 SDK 1.0.2365.46](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2365.46) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 122.0.2365.46 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* Added support for `WebResourceRequested` for workers, which allows setting filters in order to receive `WebResourceRequested` events for service workers, shared workers, and different-origin iframes. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.AddWebResourceRequestedFilter Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.addwebresourcerequestedfilter?view=webview2-dotnet-1.0.2365.46&preserve-view=true) + * [CoreWebView2.RemoveWebResourceRequestedFilter Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.removewebresourcerequestedfilter?view=webview2-dotnet-1.0.2365.46&preserve-view=true) + +* `CoreWebView2WebResourceRequestedEventArgs` Class: + * [CoreWebView2WebResourceRequestedEventArgs.RequestedSourceKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webresourcerequestedeventargs.requestedsourcekind?view=webview2-dotnet-1.0.2365.46&preserve-view=true) + +* [CoreWebView2WebResourceRequestSourceKinds Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2webresourcerequestsourcekinds?view=webview2-dotnet-1.0.2365.46&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.AddWebResourceRequestedFilter Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2365.46&preserve-view=true#addwebresourcerequestedfilter) + * [CoreWebView2.RemoveWebResourceRequestedFilter Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2365.46&preserve-view=true#removewebresourcerequestedfilter) + +* `CoreWebView2WebResourceRequestedEventArgs` Class: + * [CoreWebView2WebResourceRequestedEventArgs.RequestedSourceKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webresourcerequestedeventargs?view=webview2-winrt-1.0.2365.46&preserve-view=true#requestedsourcekind) + +* [CoreWebView2WebResourceRequestSourceKinds Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webresourcerequestsourcekinds?view=webview2-winrt-1.0.2365.46&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_22](/microsoft-edge/webview2/reference/win32/icorewebview2_22?view=webview2-1.0.2365.46&preserve-view=true) + * [ICoreWebView2_22::AddWebResourceRequestedFilterWithRequestSourceKinds](/microsoft-edge/webview2/reference/win32/icorewebview2_22?view=webview2-1.0.2365.46&preserve-view=true#addwebresourcerequestedfilterwithrequestsourcekinds) + * [ICoreWebView2_22::RemoveWebResourceRequestedFilterWithRequestSourceKinds](/microsoft-edge/webview2/reference/win32/icorewebview2_22?view=webview2-1.0.2365.46&preserve-view=true#removewebresourcerequestedfilterwithrequestsourcekinds) + +* [ICoreWebView2WebResourceRequestedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2webresourcerequestedeventargs2?view=webview2-1.0.2365.46&preserve-view=true) + * [ICoreWebView2WebResourceRequestedEventArgs2::get_RequestedSourceKind](/microsoft-edge/webview2/reference/win32/icorewebview2webresourcerequestedeventargs2?view=webview2-1.0.2365.46&preserve-view=true#get_requestedsourcekind) + +* [COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2365.46&preserve-view=true#corewebview2_web_resource_request_source_kinds) + +--- + + + +* To support browser extensions in WebView2, added `GetBrowserExtensions` for WinRT: + +##### [.NET/C#](#tab/dotnetcsharp) + +N/A + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.GetBrowserExtensionsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.2365.46&preserve-view=true#getbrowserextensionsasync) + +##### [Win32/C++](#tab/win32cpp) + +N/A + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a regression that affected handling of the `NewWindowRequested` event when the new window is set to be the source WebView. ([Issue #4250](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4250)) + +* Fixed a bug where closing a WebView that has an embedded PDF viewer could lead to a crash. ([Issue #3832](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3832)) + +* Fixed a regression where mouse-clicks stopped working when the application enabled `SetWindowDisplayAffinity`. ([Issue #4325](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4325)) + + + + + +## Prerelease SDK 1.0.2357-prerelease, for Runtime 122 (Jan. 30, 2024) + +Release Date: Jan. 30, 2024 + +[NuGet package for WebView2 SDK 1.0.2357-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2357-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 122.0.2357.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +* Added the Runtime selection feature to support more prerelease testing and flighting scenarios. Developers can specify `ReleaseChannels` to choose which channels are searched for during environment creation, and `ChannelSearchKind` to select a search order. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ChannelSearchKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.channelsearchkind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2EnvironmentOptions.ReleaseChannels Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.releasechannels?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2ChannelSearchKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2channelsearchkind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2ReleaseChannels Class](/dotnet/api/microsoft.web.webview2.core.corewebview2releasechannels?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.ChannelSearchKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#channelsearchkind) + * [CoreWebView2EnvironmentOptions.ReleaseChannels Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#releasechannels) + +* [CoreWebView2ChannelSearchKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2channelsearchkind?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2ReleaseChannels Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2releasechannels?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalEnvironmentOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironmentOptions::get_ChannelSearchKind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.2357-prerelease&preserve-view=true#get_channelsearchkind) + * [ICoreWebView2ExperimentalEnvironmentOptions::get_ReleaseChannels](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.2357-prerelease&preserve-view=true#get_releasechannels) + * [ICoreWebView2ExperimentalEnvironmentOptions::put_ChannelSearchKind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.2357-prerelease&preserve-view=true#put_channelsearchkind) + * [ICoreWebView2ExperimentalEnvironmentOptions::put_ReleaseChannels](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.2357-prerelease&preserve-view=true#put_releasechannels) + +* [COREWEBVIEW2_CHANNEL_SEARCH_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2357-prerelease&preserve-view=true#corewebview2_channel_search_kind) + +* [COREWEBVIEW2_RELEASE_CHANNELS enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2357-prerelease&preserve-view=true#corewebview2_release_channels) + +--- + + + +* Added a new API to provide hit-testing results on the regions that a WebView2 contains. This API is useful for visually hosted applications that want to handle mouse events on the non-client area of the WebView2 window. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2CompositionController` Class: + * [CoreWebView2CompositionController.GetNonClientRegionAtPoint Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.getnonclientregionatpoint?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2CompositionController.QueryNonClientRegion Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.querynonclientregion?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2CompositionController.NonClientRegionChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.nonclientregionchanged?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2NonClientRegionChangedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionchangedeventargs?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2NonClientRegionChangedEventArgs.RegionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionchangedeventargs.regionkind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.IsNonClientRegionSupportEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isnonclientregionsupportenabled?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2NonClientRegionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2nonclientregionkind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2CompositionController` Class: + * [CoreWebView2CompositionController.GetNonClientRegionAtPoint Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#getnonclientregionatpoint) + * [CoreWebView2CompositionController.QueryNonClientRegion Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#querynonclientregion) + * [CoreWebView2CompositionController.NonClientRegionChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#nonclientregionchanged) + +* [CoreWebView2NonClientRegionChangedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionchangedeventargs?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2NonClientRegionChangedEventArgs.RegionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionchangedeventargs?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#regionkind) + +* `CoreWebView2Settings` Class: + * [CoreWebView2Settings.IsNonClientRegionSupportEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#isnonclientregionsupportenabled) + +* [CoreWebView2NonClientRegionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2nonclientregionkind?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalCompositionController5](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller5?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalCompositionController5::add_NonClientRegionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller5?view=webview2-1.0.2357-prerelease&preserve-view=true#add_nonclientregionchanged) + * [ICoreWebView2ExperimentalCompositionController5::GetNonClientRegionAtPoint](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller5?view=webview2-1.0.2357-prerelease&preserve-view=true#getnonclientregionatpoint) + * [ICoreWebView2ExperimentalCompositionController5::QueryNonClientRegion](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller5?view=webview2-1.0.2357-prerelease&preserve-view=true#querynonclientregion) + * [ICoreWebView2ExperimentalCompositionController5::remove_NonClientRegionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller5?view=webview2-1.0.2357-prerelease&preserve-view=true#remove_nonclientregionchanged) + +* [ICoreWebView2ExperimentalNonClientRegionChangedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnonclientregionchangedeventargs?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalNonClientRegionChangedEventArgs::get_RegionKind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnonclientregionchangedeventargs?view=webview2-1.0.2357-prerelease&preserve-view=true#get_regionkind) + +* [ICoreWebView2ExperimentalNonClientRegionChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnonclientregionchangedeventhandler?view=webview2-1.0.2357-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalRegionRectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalregionrectcollectionview?view=webview2-1.0.2357-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalSettings8](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings8?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalSettings8::get_IsNonClientRegionSupportEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings8?view=webview2-1.0.2357-prerelease&preserve-view=true#get_isnonclientregionsupportenabled) + * [ICoreWebView2ExperimentalSettings8::put_IsNonClientRegionSupportEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings8?view=webview2-1.0.2357-prerelease&preserve-view=true#put_isnonclientregionsupportenabled) + +--- + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* `CoreWebView2AcceleratorKeyPressedEventArgs` has a new `IsBrowserAcceleratorKeyEnabled` property to allow you to control whether the browser handles accelerator keys (shortcut keys), such as **Ctrl+P** or **F3**: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2AcceleratorKeyPressedEventArgs` Class: + * [CoreWebView2AcceleratorKeyPressedEventArgs.IsBrowserAcceleratorKeyEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2acceleratorkeypressedeventargs.isbrowseracceleratorkeyenabled?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2AcceleratorKeyPressedEventArgs` Class: + * [CoreWebView2AcceleratorKeyPressedEventArgs.IsBrowserAcceleratorKeyEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2acceleratorkeypressedeventargs?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#isbrowseracceleratorkeyenabled) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2AcceleratorKeyPressedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs2?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2AcceleratorKeyPressedEventArgs2::get_IsBrowserAcceleratorKeyEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs2?view=webview2-1.0.2357-prerelease&preserve-view=true#get_isbrowseracceleratorkeyenabled) + * [ICoreWebView2AcceleratorKeyPressedEventArgs2::put_IsBrowserAcceleratorKeyEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs2?view=webview2-1.0.2357-prerelease&preserve-view=true#put_isbrowseracceleratorkeyenabled) + +--- + + + +* The Frame Process Info API, including `GetProcessExtendedInfos`, provides a snapshot collection of all frames that are actively running in the associated renderer process. This API enables the host application to detect which part of WebView2 is consuming resources such as memory or CPU usage: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessExtendedInfosAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.getprocessextendedinfosasync?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* `CoreWebView2ProcessExtendedInfo` Class: + * [CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo.associatedframeinfos?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ProcessExtendedInfo.ProcessInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo.processinfo?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* `CoreWebView2` Class: + * [CoreWebView2.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.frameid?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.frameid?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* `CoreWebView2FrameInfo` Class: + * [CoreWebView2FrameInfo.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.frameid?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2FrameInfo.FrameKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.framekind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2FrameInfo.ParentFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.parentframeinfo?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2FrameKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2framekind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessExtendedInfosAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#getprocessextendedinfosasync) + +* `CoreWebView2ProcessExtendedInfo` Class: + * [CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#associatedframeinfos) + * [CoreWebView2ProcessExtendedInfo.ProcessInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#processinfo) + +* `CoreWebView2` Class: + * [CoreWebView2.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#frameid) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#frameid) + +* `CoreWebView2FrameInfo` Class: + * [CoreWebView2FrameInfo.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#frameid) + * [CoreWebView2FrameInfo.FrameKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#framekind) + * [CoreWebView2FrameInfo.ParentFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#parentframeinfo) + +* [CoreWebView2FrameKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2framekind?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Environment13](/microsoft-edge/webview2/reference/win32/icorewebview2environment13?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2Environment13::GetProcessExtendedInfos](/microsoft-edge/webview2/reference/win32/icorewebview2environment13?view=webview2-1.0.2357-prerelease&preserve-view=true#getprocessextendedinfos) + +* [ICoreWebView2GetProcessExtendedInfosCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2getprocessextendedinfoscompletedhandler?view=webview2-1.0.2357-prerelease&preserve-view=true) + +* [ICoreWebView2ProcessExtendedInfo](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfo?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ProcessExtendedInfo::get_AssociatedFrameInfos](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfo?view=webview2-1.0.2357-prerelease&preserve-view=true#get_associatedframeinfos) + * [ICoreWebView2ProcessExtendedInfo::get_ProcessInfo](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfo?view=webview2-1.0.2357-prerelease&preserve-view=true#get_processinfo) + +* [ICoreWebView2ProcessExtendedInfoCollection](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfocollection?view=webview2-1.0.2357-prerelease&preserve-view=true) + +* [ICoreWebView2_20](/microsoft-edge/webview2/reference/win32/icorewebview2_20?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2_20::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2_20?view=view=webview2-1.0.2357-prerelease&preserve-view=true#get_frameid) + +* [ICoreWebView2Frame5](/microsoft-edge/webview2/reference/win32/icorewebview2frame5?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2Frame5::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2frame5?view=webview2-1.0.2357-prerelease&preserve-view=true#get_frameid) + +* [ICoreWebView2FrameInfo2](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2FrameInfo2::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2357-prerelease&preserve-view=true#get_frameid) + * [ICoreWebView2FrameInfo2::get_FrameKind](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2357-prerelease&preserve-view=true#get_framekind) + * [ICoreWebView2FrameInfo2::get_ParentFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2357-prerelease&preserve-view=true#get_parentframeinfo) + +* [COREWEBVIEW2_FRAME_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2357-prerelease&preserve-view=true#corewebview2_frame_kind) + +--- + + + +* `ExecuteScriptWithResult` provides exception information if the script failed. `TryGetResultAsString` gets the script execution result as a string rather than as JSON, to make it more convenient to interact with string results: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ExecuteScriptWithResultAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.executescriptwithresultasync?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2ExecuteScriptResult Class](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.Exception Property](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.exception?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.ResultAsJson Property](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.resultasjson?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.Succeeded Property](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.succeeded?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.TryGetResultAsString Method](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.trygetresultasstring?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2ScriptException Class](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ScriptException.ColumnNumber Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.columnnumber?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ScriptException.LineNumber Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.linenumber?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ScriptException.Message Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.message?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ScriptException.Name Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.name?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ScriptException.ToJson Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.tojson?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ExecuteScriptWithResultAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#executescriptwithresultasync) + +* [CoreWebView2ExecuteScriptResult Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.Exception Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#exception) + * [CoreWebView2ExecuteScriptResult.ResultAsJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#resultasjson) + * [CoreWebView2ExecuteScriptResult.Succeeded Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#succeeded) + * [CoreWebView2ExecuteScriptResult.TryGetResultAsString Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#trygetresultasstring) + +* [CoreWebView2ScriptException Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2ScriptException.ColumnNumber Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#columnnumber) + * [CoreWebView2ScriptException.LineNumber Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#linenumber) + * [CoreWebView2ScriptException.Message Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#message) + * [CoreWebView2ScriptException.Name Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#name) + * [CoreWebView2ScriptException.ToJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#tojson) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_21](/microsoft-edge/webview2/reference/win32/icorewebview2_21?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2_21::ExecuteScriptWithResult](/microsoft-edge/webview2/reference/win32/icorewebview2_21?view=webview2-1.0.2357-prerelease&preserve-view=true#executescriptwithresult) + +* [ICoreWebView2ExecuteScriptResult](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ExecuteScriptResult::get_Exception](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2357-prerelease&preserve-view=true#get_exception) + * [ICoreWebView2ExecuteScriptResult::get_ResultAsJson](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2357-prerelease&preserve-view=true#get_resultasjson) + * [ICoreWebView2ExecuteScriptResult::get_Succeeded](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2357-prerelease&preserve-view=true#get_succeeded) + * [ICoreWebView2ExecuteScriptResult::TryGetResultAsString](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2357-prerelease&preserve-view=true#trygetresultasstring) + +* [ICoreWebView2ExecuteScriptWithResultCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptwithresultcompletedhandler?view=webview2-1.0.2357-prerelease&preserve-view=true) + +* [ICoreWebView2ScriptException](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2ScriptException::get_ColumnNumber](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2357-prerelease&preserve-view=true#get_columnnumber) + * [ICoreWebView2ScriptException::get_LineNumber](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2357-prerelease&preserve-view=true#get_linenumber) + * [ICoreWebView2ScriptException::get_Message](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2357-prerelease&preserve-view=true#get_message) + * [ICoreWebView2ScriptException::get_Name](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2357-prerelease&preserve-view=true#get_name) + * [ICoreWebView2ScriptException::get_ToJson](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2357-prerelease&preserve-view=true#get_tojson) + +--- + + + +* `CreateFromComICoreWebView2` wraps an existing `ICoreWebView2` object in a `CoreWebView2` instance, to allow .NET devs to interact with an control that was created in C++. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.CreateFromComICoreWebView2 Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.createfromcomicorewebview2?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +N/A + +##### [Win32/C++](#tab/win32cpp) + +N/A + +--- + + + +* To support browser extensions in WebView2, added `GetBrowserExtensions` for WinRT: + +##### [.NET/C#](#tab/dotnetcsharp) + +N/A + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.GetBrowserExtensionsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#getbrowserextensionsasync) + +##### [Win32/C++](#tab/win32cpp) + +N/A + +--- + + + +* Added support for `WebResourceRequested` for workers, which allows setting filters in order to receive `WebResourceRequested` events for service workers, shared workers, and different origin iframes. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.AddWebResourceRequestedFilter Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.addwebresourcerequestedfilter?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + * [CoreWebView2.RemoveWebResourceRequestedFilter Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.removewebresourcerequestedfilter?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* `CoreWebView2WebResourceRequestedEventArgs` Class: + * [CoreWebView2WebResourceRequestedEventArgs.RequestedSourceKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webresourcerequestedeventargs.requestedsourcekind?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +* [CoreWebView2WebResourceRequestSourceKinds Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2webresourcerequestsourcekinds?view=webview2-dotnet-1.0.2357-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.AddWebResourceRequestedFilter Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#addwebresourcerequestedfilter) + * [CoreWebView2.RemoveWebResourceRequestedFilter Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#removewebresourcerequestedfilter) + +* `CoreWebView2WebResourceRequestedEventArgs` Class: + * [CoreWebView2WebResourceRequestedEventArgs.RequestedSourceKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webresourcerequestedeventargs?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true#requestedsourcekind) + +* [CoreWebView2WebResourceRequestSourceKinds Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webresourcerequestsourcekinds?view=webview2-winrt-1.0.2357-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_22](/microsoft-edge/webview2/reference/win32/icorewebview2_22?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2_22::AddWebResourceRequestedFilterWithRequestSourceKinds](/microsoft-edge/webview2/reference/win32/icorewebview2_22?view=webview2-1.0.2357-prerelease&preserve-view=true#addwebresourcerequestedfilterwithrequestsourcekinds) + * [ICoreWebView2_22::RemoveWebResourceRequestedFilterWithRequestSourceKinds](/microsoft-edge/webview2/reference/win32/icorewebview2_22?view=webview2-1.0.2357-prerelease&preserve-view=true#removewebresourcerequestedfilterwithrequestsourcekinds) + +* [ICoreWebView2WebResourceRequestedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2webresourcerequestedeventargs2?view=webview2-1.0.2357-prerelease&preserve-view=true) + * [ICoreWebView2WebResourceRequestedEventArgs2::get_RequestedSourceKind](/microsoft-edge/webview2/reference/win32/icorewebview2webresourcerequestedeventargs2?view=webview2-1.0.2357-prerelease&preserve-view=true#get_requestedsourcekind) + +* [COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2357-prerelease&preserve-view=true#corewebview2_web_resource_request_source_kinds) + +--- + + + +#### Bug fixes + + + +###### Runtime-only + +* Fixed a bug where closing a WebView control that has an embedded PDF viewer could lead to a crash. (Runtime-only) ([Issue #3832](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3832)) + +* Fixed issues with stacking of child-process taskbar icons. (Runtime-only) ([Issue #3245](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3245)) + +* Fixed a bug that sent an unnecessary network request for Edge Cloud Config Service. (Runtime-only) ([Issue #4180](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4180)) + +* Updated the behavior of the `app-region` CSS property so that changes to its value trigger a page re-layout. (Runtime-only) + +* Fixed an issue where `put_AreBrowserAcceleratorKeysEnabled` wasn't able to update settings for WebView2 when no `AcceleratorKeyPressed` event handler is registered. (Runtime-only) ([Issue #4278](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4278)) + + + +###### SDK-only + +* Fixed an issue where the WebView2 control in .NET was failing to find the `WebView2Loader.dll` on UNC paths. (SDK-only) ([Issue #4081](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4081)) + +* Fixed some issues causing instances of `InvalidOperationException` in .NET controls, that weren't helpful to developers. (SDK-only) ([Issue #4272](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4272)) + + + + + +## Release SDK 1.0.2277.86, for Runtime 121 (Feb. 5, 2024) + +Release Date: Feb. 5, 2024 + +[NuGet package for WebView2 SDK 1.0.2277.86](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2277.86) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 121.0.2277.86 or higher. + + + +#### Breaking changes + + + +###### Navigations to `about:blank` cancellable via `NavigationStarting` event + +Navigations to `about:blank` are now cancellable via the `NavigationStarting` event. To revert to the old behavior, disable the `msWebView2CancellableAboutNavigations` feature flag. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* `ExecuteScriptWithResult` provides exception information if the script failed. `TryGetResultAsString` gets the script execution result as a string rather than as JSON, to make it more convenient to interact with string results: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ExecuteScriptWithResultAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.executescriptwithresultasync?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + +* [CoreWebView2ExecuteScriptResult Class](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.Exception Property](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.exception?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.ResultAsJson Property](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.resultasjson?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.Succeeded Property](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.succeeded?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.TryGetResultAsString Method](/dotnet/api/microsoft.web.webview2.core.corewebview2executescriptresult.trygetresultasstring?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + +* [CoreWebView2ScriptException Class](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ScriptException.ColumnNumber Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.columnnumber?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ScriptException.LineNumber Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.linenumber?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ScriptException.Message Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.message?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ScriptException.Name Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.name?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + * [CoreWebView2ScriptException.ToJson Property](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception.tojson?view=webview2-dotnet-1.0.2277.86&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.ExecuteScriptWithResultAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2277.86&preserve-view=true#executescriptwithresultasync) + +* [CoreWebView2ExecuteScriptResult Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2277.86&preserve-view=true) + * [CoreWebView2ExecuteScriptResult.Exception Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2277.86&preserve-view=true#exception) + * [CoreWebView2ExecuteScriptResult.ResultAsJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2277.86&preserve-view=true#resultasjson) + * [CoreWebView2ExecuteScriptResult.Succeeded Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2277.86&preserve-view=true#succeeded) + * [CoreWebView2ExecuteScriptResult.TryGetResultAsString Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2executescriptresult?view=webview2-winrt-1.0.2277.86&preserve-view=true#trygetresultasstring) + +* [CoreWebView2ScriptException Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2277.86&preserve-view=true) + * [CoreWebView2ScriptException.ColumnNumber Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2277.86&preserve-view=true#columnnumber) + * [CoreWebView2ScriptException.LineNumber Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2277.86&preserve-view=true#linenumber) + * [CoreWebView2ScriptException.Message Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2277.86&preserve-view=true#message) + * [CoreWebView2ScriptException.Name Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2277.86&preserve-view=true#name) + * [CoreWebView2ScriptException.ToJson Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.2277.86&preserve-view=true#tojson) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_21](/microsoft-edge/webview2/reference/win32/icorewebview2_21?view=webview2-1.0.2277.86&preserve-view=true) + * [ICoreWebView2_21::ExecuteScriptWithResult](/microsoft-edge/webview2/reference/win32/icorewebview2_21?view=webview2-1.0.2277.86&preserve-view=true#executescriptwithresult) + +* [ICoreWebView2ExecuteScriptResult](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2277.86&preserve-view=true) + * [ICoreWebView2ExecuteScriptResult::get_Exception](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2277.86&preserve-view=true#get_exception) + * [ICoreWebView2ExecuteScriptResult::get_ResultAsJson](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2277.86&preserve-view=true#get_resultasjson) + * [ICoreWebView2ExecuteScriptResult::get_Succeeded](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2277.86&preserve-view=true#get_succeeded) + * [ICoreWebView2ExecuteScriptResult::TryGetResultAsString](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptresult?view=webview2-1.0.2277.86&preserve-view=true#trygetresultasstring) + +* [ICoreWebView2ExecuteScriptWithResultCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2executescriptwithresultcompletedhandler?view=webview2-1.0.2277.86&preserve-view=true) + +* [ICoreWebView2ScriptException](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2277.86&preserve-view=true) + * [ICoreWebView2ScriptException::get_ColumnNumber](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2277.86&preserve-view=true#get_columnnumber) + * [ICoreWebView2ScriptException::get_LineNumber](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2277.86&preserve-view=true#get_linenumber) + * [ICoreWebView2ScriptException::get_Message](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2277.86&preserve-view=true#get_message) + * [ICoreWebView2ScriptException::get_Name](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2277.86&preserve-view=true#get_name) + * [ICoreWebView2ScriptException::get_ToJson](/microsoft-edge/webview2/reference/win32/icorewebview2scriptexception?view=webview2-1.0.2277.86&preserve-view=true#get_tojson) + +--- + + + + +#### Bug fixes + + + +###### Runtime-only + +* Ensured that the spellcheck language matches `put_Language` programmatically. The customized context menu is also updated with correct spellchecks. (Runtime-only) + +* Fixed a bug that stopped raising the `NavigationCompleted` event for some websites that load AV1-encoded videos. (Runtime-only) ([Issue #3801](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3801)) + +* Fixed an issue where host-process COM resources would be released during WebView tear-down. (Runtime-only) ([Issue #4226](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4226)) + +* Fixed a bug that broke loading some social media apps such as Facebook, Twitter, and Linkedin. This change is Runtime-specific. (Runtime-only) ([Issue #4281](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4281)) + + + + + +## Release SDK 1.0.2210.55, for Runtime 120 (Dec. 11, 2023) + +Release Date: Dec. 11, 2023 + +[NuGet package for WebView2 SDK 1.0.2210.55](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2210.55) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 120.0.2210.55 or higher. + + + +#### Breaking changes + + + +###### Unpackaged Win32 app using Fixed Version 120+ on Windows 10 + +If you're developing an unpackaged Win32 app using Fixed Version Runtime v120 or above and targeting Windows 10 devices, you need to run a couple of ACL shell commands (`icacls`), to avoid crashing, because of a new security feature implemented in WebView2. See [[Breaking Change] Unpackaged Win32 app using Fixed Version v120+ on Win10 need ACL](https://github.com/MicrosoftEdge/WebView2Announcements/issues/82). + +The fix is in the article _Distribute your app and the WebView2 Runtime_, section [The Fixed Version runtime distribution mode](../concepts/distribution.md#the-fixed-version-runtime-distribution-mode), step "On Windows 10 devices, starting with Fixed Version 120, developers of unpackaged Win32 applications using Fixed Version are required to run the following commands." + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* Support for browser extensions in WebView2: + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2BrowserExtension Class](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2BrowserExtension.Id Property](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension.id?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2BrowserExtension.IsEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension.isenabled?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2BrowserExtension.Name Property](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension.name?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2BrowserExtension.EnableAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension.enableasync?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2BrowserExtension.RemoveAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension.removeasync?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.AreBrowserExtensionsEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.arebrowserextensionsenabled?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AddBrowserExtensionAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.addbrowserextensionasync?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2Profile.GetBrowserExtensionsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getbrowserextensionsasync?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2BrowserExtension Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2210.55&preserve-view=true) + * [CoreWebView2BrowserExtension.Id Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2210.55&preserve-view=true#id) + * [CoreWebView2BrowserExtension.IsEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2210.55&preserve-view=true#isenabled) + * [CoreWebView2BrowserExtension.Name Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2210.55&preserve-view=true#name) + * [CoreWebView2BrowserExtension.EnableAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2210.55&preserve-view=true#enableasync) + * [CoreWebView2BrowserExtension.RemoveAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2210.55&preserve-view=true#removeasync) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.AreBrowserExtensionsEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2210.55&preserve-view=true#arebrowserextensionsenabled) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AddBrowserExtensionAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.2210.55&preserve-view=true#addbrowserextensionasync) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2BrowserExtension](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2BrowserExtension::Enable](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2210.55&preserve-view=true#enable) + * [ICoreWebView2BrowserExtension::get_Id](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2210.55&preserve-view=true#get_id) + * [ICoreWebView2BrowserExtension::get_IsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2210.55&preserve-view=true#get_isenabled) + * [ICoreWebView2BrowserExtension::get_Name](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2210.55&preserve-view=true#get_name) + * [ICoreWebView2BrowserExtension::Remove](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2210.55&preserve-view=true#remove) + +* [ICoreWebView2BrowserExtensionEnableCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionenablecompletedhandler?view=webview2-1.0.2210.55&preserve-view=true) + +* [ICoreWebView2BrowserExtensionRemoveCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionremovecompletedhandler?view=webview2-1.0.2210.55&preserve-view=true) + +* [ICoreWebView2BrowserExtensionList](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionlist?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2BrowserExtensionList::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionlist?view=webview2-1.0.2210.55&preserve-view=true#get_count) + * [ICoreWebView2BrowserExtensionList::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionlist?view=webview2-1.0.2210.55&preserve-view=true#getvalueatindex) + +* [ICoreWebView2EnvironmentOptions6](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions6?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2EnvironmentOptions6::get_AreBrowserExtensionsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions6?view=webview2-1.0.2210.55&preserve-view=true#get_arebrowserextensionsenabled) + * [ICoreWebView2EnvironmentOptions6::put_AreBrowserExtensionsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions6?view=webview2-1.0.2210.55&preserve-view=true#put_arebrowserextensionsenabled) + +* [ICoreWebView2Profile7](/microsoft-edge/webview2/reference/win32/icorewebview2profile7?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2Profile7::AddBrowserExtension](/microsoft-edge/webview2/reference/win32/icorewebview2profile7?view=webview2-1.0.2210.55&preserve-view=true#addbrowserextension) + * [ICoreWebView2Profile7::GetBrowserExtensions](/microsoft-edge/webview2/reference/win32/icorewebview2profile7?view=webview2-1.0.2210.55&preserve-view=true#getbrowserextensions) + +* [ICoreWebView2ProfileAddBrowserExtensionCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2profileaddbrowserextensioncompletedhandler?view=webview2-1.0.2210.55&preserve-view=true) + +* [ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2profilegetbrowserextensionscompletedhandler?view=webview2-1.0.2210.55&preserve-view=true) + +--- + + + +* The Frame Process Info API, including `GetProcessExtendedInfos`, provides a snapshot collection of all frames that are actively running in the associated renderer process. This API enables the host application to detect which part of WebView2 is consuming resources such as memory or CPU usage: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessExtendedInfosAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.getprocessextendedinfosasync?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* `CoreWebView2ProcessExtendedInfo` Class: + * [CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo.associatedframeinfos?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2ProcessExtendedInfo.ProcessInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo.processinfo?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* `CoreWebView2` Class: + * [CoreWebView2.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.frameid?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.frameid?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* `CoreWebView2FrameInfo` Class: + * [CoreWebView2FrameInfo.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.frameid?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2FrameInfo.FrameKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.framekind?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2FrameInfo.ParentFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.parentframeinfo?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +* [CoreWebView2FrameKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2framekind?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessExtendedInfosAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2210.55&preserve-view=true#getprocessextendedinfosasync) + +* `CoreWebView2ProcessExtendedInfo` Class: + * [CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2210.55&preserve-view=true#associatedframeinfos) + * [CoreWebView2ProcessExtendedInfo.ProcessInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2210.55&preserve-view=true#processinfo) + +* `CoreWebView2` Class: + * [CoreWebView2.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.2210.55&preserve-view=true#frameid) + +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.2210.55&preserve-view=true#frameid) + +* `CoreWebView2FrameInfo` Class: + * [CoreWebView2FrameInfo.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.2210.55&preserve-view=true#frameid) + * [CoreWebView2FrameInfo.FrameKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.2210.55&preserve-view=true#framekind) + * [CoreWebView2FrameInfo.ParentFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.2210.55&preserve-view=true#parentframeinfo) + +* [CoreWebView2FrameKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2framekind?view=webview2-winrt-1.0.2210.55&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Environment13](/microsoft-edge/webview2/reference/win32/icorewebview2environment13?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2Environment13::GetProcessExtendedInfos](/microsoft-edge/webview2/reference/win32/icorewebview2environment13?view=webview2-1.0.2210.55&preserve-view=true#getprocessextendedinfos) + +* [ICoreWebView2GetProcessExtendedInfosCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2getprocessextendedinfoscompletedhandler?view=webview2-1.0.2210.55&preserve-view=true) + +* [ICoreWebView2ProcessExtendedInfo](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfo?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2ProcessExtendedInfo::get_AssociatedFrameInfos](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfo?view=webview2-1.0.2210.55&preserve-view=true#get_associatedframeinfos) + * [ICoreWebView2ProcessExtendedInfo::get_ProcessInfo](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfo?view=webview2-1.0.2210.55&preserve-view=true#get_processinfo) + +* [ICoreWebView2ProcessExtendedInfoCollection](/microsoft-edge/webview2/reference/win32/icorewebview2processextendedinfocollection?view=webview2-1.0.2210.55&preserve-view=true) + +* [ICoreWebView2_20](/microsoft-edge/webview2/reference/win32/icorewebview2_20?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2_20::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2_20?view=webview2-1.0.2210.55&preserve-view=true#get_frameid) + +* [ICoreWebView2Frame5](/microsoft-edge/webview2/reference/win32/icorewebview2frame5?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2Frame5::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2frame5?view=webview2-1.0.2210.55&preserve-view=true#get_frameid) + +* [ICoreWebView2FrameInfo2](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2FrameInfo2::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2210.55&preserve-view=true#get_frameid) + * [ICoreWebView2FrameInfo2::get_FrameKind](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2210.55&preserve-view=true#get_framekind) + * [ICoreWebView2FrameInfo2::get_ParentFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2frameinfo2?view=webview2-1.0.2210.55&preserve-view=true#get_parentframeinfo) + +* [COREWEBVIEW2_FRAME_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.2210.55&preserve-view=true#corewebview2_frame_kind) + +--- + + + +* `ICoreWebView2AcceleratorKeyPressedEventArgs` has a new `IsBrowserAcceleratorKeyEnabled` property to allow developers to control whether the browser handles accelerator keys (shortcut keys), such as **Ctrl+P** or **F3**: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2AcceleratorKeyPressedEventArgs` Class: + * [CoreWebView2AcceleratorKeyPressedEventArgs.IsBrowserAcceleratorKeyEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2acceleratorkeypressedeventargs.isbrowseracceleratorkeyenabled?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2AcceleratorKeyPressedEventArgs` Class: + * [CoreWebView2AcceleratorKeyPressedEventArgs.IsBrowserAcceleratorKeyEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2acceleratorkeypressedeventargs?view=webview2-winrt-1.0.2210.55&preserve-view=true#isbrowseracceleratorkeyenabled) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2AcceleratorKeyPressedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs2?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2AcceleratorKeyPressedEventArgs2::get_IsBrowserAcceleratorKeyEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs2?view=webview2-1.0.2210.55&preserve-view=true#get_isbrowseracceleratorkeyenabled) + * [ICoreWebView2AcceleratorKeyPressedEventArgs2::put_IsBrowserAcceleratorKeyEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs2?view=webview2-1.0.2210.55&preserve-view=true#put_isbrowseracceleratorkeyenabled) + +--- + + + +* Added support for managing profile deletion: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.Delete Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.delete?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + * [CoreWebView2Profile.Deleted Event](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.deleted?view=webview2-dotnet-1.0.2210.55&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.Delete Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.2210.55&preserve-view=true#delete) + * [CoreWebView2Profile.Deleted Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.2210.55&preserve-view=true#deleted) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Profile8](/microsoft-edge/webview2/reference/win32/icorewebview2profile8?view=webview2-1.0.2210.55&preserve-view=true) + * [ICoreWebView2Profile8::add_Deleted](/microsoft-edge/webview2/reference/win32/icorewebview2profile8?view=webview2-1.0.2210.55&preserve-view=true#add_deleted) + * [ICoreWebView2Profile8::Delete](/microsoft-edge/webview2/reference/win32/icorewebview2profile8?view=webview2-1.0.2210.55&preserve-view=true#delete) + * [ICoreWebView2Profile8::remove_Deleted](/microsoft-edge/webview2/reference/win32/icorewebview2profile8?view=webview2-1.0.2210.55&preserve-view=true#remove_deleted) + +* [ICoreWebView2ProfileDeletedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2profiledeletedeventhandler?view=webview2-1.0.2210.55&preserve-view=true) + +--- + + + +#### Bug fixes + +* Added support for promise cancellation on host objects' async methods in WinRT JS projection. For information about `AddHostObjectToScript`, see [Call native-side WinRT code from web-side code](../how-to/winrt-from-js.md). (Runtime and SDK) + +* Disabled automatic HTTPS upgrades for WebView2 API navigations. (Runtime-only) ([Issue #4104](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4104)) + + + + + +## Prerelease SDK 1.0.2194-prerelease, for Runtime 120 (Nov. 6, 2023) + +Release Date: Nov. 6, 2023 + +[NuGet package for WebView2 SDK 1.0.2194-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2194-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 120.0.2194.0 or higher. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + +* Support for browser extensions in WebView2: + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2BrowserExtension Class](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension?view=webview2-dotnet-1.0.2194-prerelease&preserve-view=true) +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.AreBrowserExtensionsEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.arebrowserextensionsenabled?view=webview2-dotnet-1.0.2194-prerelease&preserve-view=true) +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AddBrowserExtensionAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.addbrowserextensionasync?view=webview2-dotnet-1.0.2194-prerelease&preserve-view=true) + * [CoreWebView2Profile.GetBrowserExtensionsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getbrowserextensionsasync?view=webview2-dotnet-1.0.2194-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2BrowserExtension Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.2194-prerelease&preserve-view=true) +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.AreBrowserExtensionsEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2194-prerelease&preserve-view=true#arebrowserextensionsenabled) +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AddBrowserExtensionAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.2194-prerelease&preserve-view=true#addbrowserextensionasync) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2BrowserExtension](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2194-prerelease&preserve-view=true) + * [ICoreWebView2BrowserExtension::get_Id](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2194-prerelease&preserve-view=true#get_id) + * [ICoreWebView2BrowserExtension::get_Name](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2194-prerelease&preserve-view=true#get_name) + * [ICoreWebView2BrowserExtension::Remove](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2194-prerelease&preserve-view=true#remove) + * [ICoreWebView2BrowserExtension::get_IsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2194-prerelease&preserve-view=true#get_isenabled) + * [ICoreWebView2BrowserExtension::Enable](/microsoft-edge/webview2/reference/win32/icorewebview2browserextension?view=webview2-1.0.2194-prerelease&preserve-view=true#enable) +* [ICoreWebView2BrowserExtensionEnableCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionenablecompletedhandler?view=webview2-1.0.2194-prerelease&preserve-view=true) +* [ICoreWebView2BrowserExtensionRemoveCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionremovecompletedhandler?view=webview2-1.0.2194-prerelease&preserve-view=true) +* [ICoreWebView2BrowserExtensionList](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionlist?view=webview2-1.0.2194-prerelease&preserve-view=true) + * [ICoreWebView2BrowserExtensionList::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionlist?view=webview2-1.0.2194-prerelease&preserve-view=true#get_count) + * [ICoreWebView2BrowserExtensionList::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2browserextensionlist?view=webview2-1.0.2194-prerelease&preserve-view=true#getvalueatindex) +* [ICoreWebView2EnvironmentOptions6](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions6?view=webview2-1.0.2194-prerelease&preserve-view=true) + * [ICoreWebView2EnvironmentOptions6::get_AreBrowserExtensionsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions6?view=webview2-1.0.2194-prerelease&preserve-view=true#get_arebrowserextensionsenabled) + * [ICoreWebView2EnvironmentOptions6::put_AreBrowserExtensionsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions6?view=webview2-1.0.2194-prerelease&preserve-view=true#put_arebrowserextensionsenabled) +* [ICoreWebView2Profile7](/microsoft-edge/webview2/reference/win32/icorewebview2profile7?view=webview2-1.0.2194-prerelease&preserve-view=true) + * [ICoreWebView2Profile7::AddBrowserExtension](/microsoft-edge/webview2/reference/win32/icorewebview2profile7?view=webview2-1.0.2194-prerelease&preserve-view=true#addbrowserextension) + * [ICoreWebView2Profile7::GetBrowserExtensions](/microsoft-edge/webview2/reference/win32/icorewebview2profile7?view=webview2-1.0.2194-prerelease&preserve-view=true#getbrowserextensions) +* [ICoreWebView2ProfileAddBrowserExtensionCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2profileaddbrowserextensioncompletedhandler?view=webview2-1.0.2194-prerelease&preserve-view=true) +* [ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2profilegetbrowserextensionscompletedhandler?view=webview2-1.0.2194-prerelease&preserve-view=true) + +--- + + + +#### Bug fixes + +* Fixed an issue where WebView2 would sometimes render blurry content or no content after changing monitor scale or switching between RDP and docking modes. (Runtime-only) + +* Fixed an issue in `TextServicesFoundation` causing a crash when a WebView2 instance was destroyed. (Runtime-only) + +* Fixes a memory leak in .NET when web messages are sent from WebView2, but aren't read from the application side. (Runtime and SDK) ([Issue #3794](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3794)) + +* Fixed an issue causing the `ScaleFactor` setting to not work properly for all WebView2 Print APIs. (Runtime-only) ([Issue #4082](https://github.com/MicrosoftEdge/WebView2Feedback/issues/4082)) + + + + + +## Prerelease SDK 1.0.2164-prerelease, for Runtime 120 (Oct. 18, 2023) + +Release Date: Oct. 18, 2023 + +[NuGet package for WebView2 SDK 1.0.2164-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2164-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 120.0.2164.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +* Added the `FailureSourceModulePath` property to the `ProcessFailedEventArgs` type, to specify the full path of the module that caused the crash in cases of Windows code integrity failures - that is, when a process exited with `STATUS_INVALID_IMAGE_HASH`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ProcessFailedEventArgs` Class: + * [CoreWebView2ProcessFailedEventArgs.FailureSourceModulePath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processfailedeventargs.failuresourcemodulepath?view=webview2-dotnet-1.0.2164-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ProcessFailedEventArgs` Class: + * [CoreWebView2ProcessFailedEventArgs.FailureSourceModulePath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processfailedeventargs?view=webview2-winrt-1.0.2164-prerelease&preserve-view=true#failuresourcemodulepath) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalProcessFailedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessfailedeventargs?view=webview2-1.0.2164-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProcessFailedEventArgs::get_FailureSourceModulePath](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessfailedeventargs?view=webview2-1.0.2164-prerelease&preserve-view=true#get_failuresourcemodulepath) + +--- + + + +#### Bug fixes + +* Added support for additional page settings (`PageRange` and `PagesPerSheet`) in the PrintToPDF API. (Runtime-only) ([Issue #3719](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3719)) + +* Navigation to an Extension Resource file was not handled correctly, and has now been fixed with the correct handling method. (Runtime-only) ([Issue #3728](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3728)) + +* Fixed an issue causing some UWP apps to be unable to input text. (Runtime-only) ([Issue #3805](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3805)) + +* Fixed an initialization failure for apps that were using the Windows `PerProcessSystemDPIForceOff` compatibility setting. (Runtime-only) ([Issue #3692](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3692)) + +* Removed monitors that were collecting data when the system default browser setting changes. (Runtime-only) + +* Fixed a Dialog Position Offset bug in WebView2. (Runtime-only) ([Issue #3763](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3763)) + +* Fixed a crash in the `NewWindowRequested` event if the `NewWindow` is set to `null`. (Runtime-only) + + + + + +## Release SDK 1.0.2151.40, for Runtime 119 (Nov. 6, 2023) + +Release Date: Nov. 6, 2023 + +[NuGet package for WebView2 SDK 1.0.2151.40](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2151.40) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 119.0.2151.40 or higher. + + + +#### General Availability + +> [!IMPORTANT] +> **Announcement**: Xbox WebView2 SDK is now Generally Available (GA) and is available on Xbox Oct. 2310 version (231018-2200). For more details, see [WebView2 for Xbox announcement](https://blogs.windows.com/msedgedev/2023/11/01/webview2-for-xbox-announcement/). + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + +* Added source frame info to the `NewWindowRequested` event arguments, to identify the source of the request: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2NewWindowRequestedEventArgs` Class: + * [CoreWebView2NewWindowRequestedEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2newwindowrequestedeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.2151.40&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2NewWindowRequestedEventArgs` Class: + * [CoreWebView2NewWindowRequestedEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2newwindowrequestedeventargs?view=webview2-winrt-1.0.2151.40&preserve-view=true#originalsourceframeinfo) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2NewWindowRequestedEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2newwindowrequestedeventargs3?view=webview2-1.0.2151.40&preserve-view=true) + * [ICoreWebView2NewWindowRequestedEventArgs3::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2newwindowrequestedeventargs3?view=webview2-1.0.2151.40&preserve-view=true#get_originalsourceframeinfo) + +--- + +* For WinRT, options have been added to manage custom scheme registration when creating a `CoreWebView2Environment`: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2CustomSchemeRegistration` Class: + * [CoreWebView2CustomSchemeRegistration.AllowedOrigins Property](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration.allowedorigins?view=webview2-dotnet-1.0.2151.40&preserve-view=true) + * [CoreWebView2CustomSchemeRegistration.SchemeName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration.schemename?view=webview2-dotnet-1.0.2151.40&preserve-view=true) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.customschemeregistrations?view=webview2-dotnet-1.0.2151.40&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2CustomSchemeRegistration` Class: + * [CoreWebView2CustomSchemeRegistration.AllowedOrigins Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2customschemeregistration?view=webview2-winrt-1.0.2151.40&preserve-view=true#allowedorigins) + * [CoreWebView2CustomSchemeRegistration.SchemeName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2customschemeregistration?view=webview2-winrt-1.0.2151.40&preserve-view=true#schemename) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2151.40&preserve-view=true#customschemeregistrations) + +##### [Win32/C++](#tab/win32cpp) + +* `ICoreWebView2CustomSchemeRegistration`: + * [ICoreWebView2CustomSchemeRegistration::get_SchemeName](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.2151.40&preserve-view=true#get_schemename) + * [ICoreWebView2CustomSchemeRegistration::GetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.2151.40&preserve-view=true#getallowedorigins) + * [ICoreWebView2CustomSchemeRegistration::SetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.2151.40&preserve-view=true#setallowedorigins) + +* [ICoreWebView2EnvironmentOptions4](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.2151.40&preserve-view=true) + * [ICoreWebView2EnvironmentOptions4::GetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.2151.40&preserve-view=true#getcustomschemeregistrations) + * [ICoreWebView2EnvironmentOptions4::SetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.2151.40&preserve-view=true#setcustomschemeregistrations) + +--- + + + +#### Bug fixes + +* Fixed a reliability issue where multiple WebView creations could lead to a crash. (Runtime-only) ([Issue #3793](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3793)) + + + + + +## Prerelease SDK 1.0.2106-prerelease, for Runtime 119 (Sep. 20, 2023) + +Release Date: Sep. 20, 2023 + +[NuGet package for WebView2 SDK 1.0.2106-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2106-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 119.0.2106.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +* The Frame Process Info API, including `GetProcessExtendedInfos`, provides a snapshot collection of all frames that are actively running in the associated renderer process. This API enables the host application to detect which part of WebView2 is consuming resources such as memory or CPU usage: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessExtendedInfosAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.getprocessextendedinfosasync?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + +* `CoreWebView2FrameKind` Enum: + * [CoreWebView2FrameKind.Embed Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2framekind?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2FrameKind.Object Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2framekind?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2FrameKind.Unknown Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2framekind?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + +* [CoreWebView2ProcessExtendedInfo Class](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo.associatedframeinfos?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2ProcessExtendedInfo.ProcessInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processextendedinfo.processinfo?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessExtendedInfosAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#getprocessextendedinfosasync) + +* `CoreWebView2FrameKind` Enum: + * [CoreWebView2FrameKind.Unknown Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2framekind?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2FrameKind.Embed Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2framekind?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2FrameKind.Object Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2framekind?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true) + +* [CoreWebView2ProcessExtendedInfo Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#associatedframeinfos) + * [CoreWebView2ProcessExtendedInfo.ProcessInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processextendedinfo?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#processinfo) + + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalEnvironment13](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment13?view=webview2-1.0.2106-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironment13::GetProcessExtendedInfos](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment13?view=webview2-1.0.2106-prerelease&preserve-view=true#getprocessextendedinfos) + +* [ICoreWebView2ExperimentalGetProcessExtendedInfosCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgetprocessextendedinfoscompletedhandler?view=webview2-1.0.2106-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalProcessExtendedInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessextendedinfo?view=webview2-1.0.2106-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProcessExtendedInfo::get_AssociatedFrameInfos](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessextendedinfo?view=webview2-1.0.2106-prerelease&preserve-view=true#get_associatedframeinfos) + * [ICoreWebView2ExperimentalProcessExtendedInfo::get_ProcessInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessextendedinfo?view=webview2-1.0.2106-prerelease&preserve-view=true#get_processinfo) + +* [ICoreWebView2ExperimentalProcessExtendedInfoCollection](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessextendedinfocollection?view=webview2-1.0.2106-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProcessExtendedInfoCollection::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessextendedinfocollection?view=webview2-1.0.2106-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalProcessExtendedInfoCollection::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessextendedinfocollection?view=webview2-1.0.2106-prerelease&preserve-view=true#getvalueatindex) + +* `COREWEBVIEW2_FRAME_KIND` enum: + * [COREWEBVIEW2_FRAME_KIND_UNKNOWN](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2106-prerelease&preserve-view=true#corewebview2_frame_kind) + * [COREWEBVIEW2_FRAME_KIND_EMBED](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2106-prerelease&preserve-view=true#corewebview2_frame_kind) + * [COREWEBVIEW2_FRAME_KIND_OBJECT](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.2106-prerelease&preserve-view=true#corewebview2_frame_kind) + +--- + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* For WinRT, options have been added to manage custom scheme registration when creating a `CoreWebView2Environment`: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2CustomSchemeRegistration` Class: + * [CoreWebView2CustomSchemeRegistration.AllowedOrigins Property](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration.allowedorigins?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + * [CoreWebView2CustomSchemeRegistration.SchemeName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration.schemename?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.customschemeregistrations?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2CustomSchemeRegistration` Class: + * [CoreWebView2CustomSchemeRegistration.AllowedOrigins Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2customschemeregistration?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#allowedorigins) + * [CoreWebView2CustomSchemeRegistration.SchemeName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2customschemeregistration?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#schemename) + +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#customschemeregistrations) + +##### [Win32/C++](#tab/win32cpp) + +* `ICoreWebView2CustomSchemeRegistration`: + * [ICoreWebView2CustomSchemeRegistration::get_SchemeName](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.2106-prerelease&preserve-view=true#get_schemename) + * [ICoreWebView2CustomSchemeRegistration::GetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.2106-prerelease&preserve-view=true#getallowedorigins) + * [ICoreWebView2CustomSchemeRegistration::SetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.2106-prerelease&preserve-view=true#setallowedorigins) + +* [ICoreWebView2EnvironmentOptions4](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.2106-prerelease&preserve-view=true) + * [ICoreWebView2EnvironmentOptions4::GetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.2106-prerelease&preserve-view=true#getcustomschemeregistrations) + * [ICoreWebView2EnvironmentOptions4::SetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.2106-prerelease&preserve-view=true#setcustomschemeregistrations) + +--- + + + +* Added source frame info to the `NewWindowRequested` event arguments, to identify the source of the request: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2NewWindowRequestedEventArgs` Class: + * [CoreWebView2NewWindowRequestedEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2newwindowrequestedeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.2106-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2NewWindowRequestedEventArgs` Class: + * [CoreWebView2NewWindowRequestedEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2newwindowrequestedeventargs?view=webview2-winrt-1.0.2106-prerelease&preserve-view=true#originalsourceframeinfo) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2NewWindowRequestedEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2newwindowrequestedeventargs3?view=webview2-1.0.2106-prerelease&preserve-view=true) + * [ICoreWebView2NewWindowRequestedEventArgs3::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2newwindowrequestedeventargs3?view=webview2-1.0.2106-prerelease&preserve-view=true#get_originalsourceframeinfo) + +--- + + + +#### Bug fixes + + + +###### Runtime + +* Updated the Screen Capture UI to remove mention of tabs. (Runtime-only) + +* Fixed a bug where `PrintAsync` doesn't print using the default DPI on the printer. (Runtime-only) ([Issue #3709](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3709)) + +* Fix a WebView creation failure when app is running as a different admin user. (Runtime-only) ([Issue #3738](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3738)) + +* Fixed a bug that prevented setting an automation name for the WebView2 control on WinUI 3. (Runtime-only) + +* Enabled the new inter-process communication implementation for apps that are using very old SDKs. (Runtime-only) + + + +###### SDK + +* Fixed a bug where the `CoreWebView2EnvironmentOptions.Language` property doesn't change the `accept-language` HTTP header. (SDK-only) ([Issue #3635](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3635)) + +* Added support for longer runtime installation paths. (SDK-only) + +* The custom URI scheme registration API now works in WinRT. For API names and links, in the **Promotions** section above, see the "custom scheme registration" entry. (SDK-only) + + + +###### Runtime and SDK + +* Fixed a bug where the Runtime exits unexpectedly when calling `SetPermissionState` with an invalid enum value. (Runtime and SDK) + + + + + +## Release SDK 1.0.2088.41, for Runtime 118 (Oct. 16, 2023) + +Release Date: Oct. 16, 2023 + +[NuGet package for WebView2 SDK 1.0.2088.41](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2088.41) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 118.0.2088.41 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +* Fixed an issue causing some UWP apps to be unable to input text. (Runtime-only) ([Issue #3805](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3805)) + +* Fixed an initialization failure for apps that were using the Windows `PerProcessSystemDPIForceOff` compatibility setting. (Runtime-only) ([Issue #3692](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3692)) + +* Fixed a Dialog Position Offset bug in WebView2. (Runtime-only) ([Issue #3763](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3763)) + + + + + +## Prerelease SDK 1.0.2065-prerelease, for Runtime 118 (Aug. 30, 2023) + +Release Date: Aug. 30, 2023 + +[NuGet package for WebView2 SDK 1.0.2065-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2065-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 118.0.2065.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +* Added source frame info to `NewWindowRequested`, to support identifying the source: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2NewWindowRequestedEventArgs` Class + * [CoreWebView2NewWindowRequestedEventArgs.OriginalSourceFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2newwindowrequestedeventargs.originalsourceframeinfo?view=webview2-dotnet-1.0.2065-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2NewWindowRequestedEventArgs` Class + * [CoreWebView2NewWindowRequestedEventArgs.OriginalSourceFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2newwindowrequestedeventargs?view=webview2-winrt-1.0.2065-prerelease&preserve-view=true#originalsourceframeinfo) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalNewWindowRequestedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnewwindowrequestedeventargs2?view=webview2-1.0.2065-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalNewWindowRequestedEventArgs2::get_OriginalSourceFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnewwindowrequestedeventargs2?view=webview2-1.0.2065-prerelease&preserve-view=true#get_originalsourceframeinfo) + +--- + + + +#### Bug fixes + +* Disabled installing CRX in WebView2. (Runtime-only) + +* Fixed an initialization failure when the app has a DPI awareness compatibility setting applied. (Runtime-only) ([Issue #3008](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3008)) + +* Fixed a bug where visual hosted owned windows couldn't take character input. (Runtime-only) + + + + + +## Release SDK 1.0.2045.28, for Runtime 117 (Sep. 18, 2023) + +Release Date: Sep. 18, 2023 + +[NuGet package for WebView2 SDK 1.0.2045.28](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.2045.28) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 117.0.2045.28 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +* Disabled the Mouse Gesture feature by default. (Runtime-only) ([Issue #3737](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3737)) + +* Fixed a bug where mouse wheel scrolling was intermittently broken for visual hosting. (Runtime-only) + +* Fixed a bug where downloading APK files in WebView2 crashes the WebView2 browser process. (Runtime-only) ([Issue #3569](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3569)) + + + + + +## Prerelease SDK 1.0.1988-prerelease, for Runtime 117 (Jul. 24, 2023) + +Release Date: Jul. 24, 2023 + +[NuGet package for WebView2 SDK 1.0.1988-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1988-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 117.0.1988.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + + +* Supports desktop notifications through WebView2: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.NotificationReceived Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.notificationreceived?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* [CoreWebView2Notification Class](/dotnet/api/microsoft.web.webview2.core.corewebview2notification?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* [CoreWebView2NotificationReceivedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2notificationreceivedeventargs?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.NotificationReceived Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#notificationreceived) +* [CoreWebView2Notification Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notification?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true) +* [CoreWebView2NotificationReceivedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2notificationreceivedeventargs?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental22](/microsoft-edge/webview2/reference/win32/icorewebview2experimental22?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2Experimental22::add_NotificationReceived event](/microsoft-edge/webview2/reference/win32/icorewebview2experimental22?view=webview2-1.0.1988-prerelease&preserve-view=true#add_notificationreceived) + * [ICoreWebView2Experimental22::remove_NotificationReceived event](/microsoft-edge/webview2/reference/win32/icorewebview2experimental22?view=webview2-1.0.1988-prerelease&preserve-view=true#remove_notificationreceived) +* [ICoreWebView2ExperimentalNotification](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnotification?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalNotificationCloseRequestedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnotificationcloserequestedeventhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalNotificationReceivedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnotificationreceivedeventargs?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalNotificationReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnotificationreceivedeventhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) + +--- + + + +* Supports monitoring iframe's runtime memory usage by getting process info details of iframes. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.frameid?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessInfosWithDetailsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.getprocessinfoswithdetailsasync?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.frameid?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* `CoreWebView2FrameInfo` Class: + * [CoreWebView2FrameInfo.FrameId Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.frameid?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + * [CoreWebView2FrameInfo.FrameKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.framekind?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + * [CoreWebView2FrameInfo.ParentFrameInfo Property](/dotnet/api/microsoft.web.webview2.core.corewebview2frameinfo.parentframeinfo?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* [CoreWebView2FrameKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2framekind?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + * `Iframe` + * `MainFrame` + * `Other` +* `CoreWebView2ProcessInfo` Class: + * [CoreWebView2ProcessInfo.AssociatedFrameInfos Property](/dotnet/api/microsoft.web.webview2.core.corewebview2processinfo.associatedframeinfos?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#frameid) +* `CoreWebView2Environment` Class: + * [CoreWebView2Environment.GetProcessInfosWithDetailsAsync Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#getprocessinfoswithdetailsasync) +* `CoreWebView2Frame` Class: + * [CoreWebView2Frame.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#frameid) +* `CoreWebView2FrameInfo` Class: + * [CoreWebView2FrameInfo.FrameId Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#frameid) + * [CoreWebView2FrameInfo.FrameKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#framekind) + * [CoreWebView2FrameInfo.ParentFrameInfo Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frameinfo?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#parentframeinfo) +* [CoreWebView2FrameKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2framekind?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true) + * `Other` + * `MainFrame` + * `Iframe` +* `CoreWebView2ProcessInfo` Class: + * [CoreWebView2ProcessInfo.AssociatedFrameInfos Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2processinfo?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#associatedframeinfos) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental23](/microsoft-edge/webview2/reference/win32/icorewebview2experimental23?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2Experimental23::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2experimental23?view=webview2-1.0.1988-prerelease&preserve-view=true#get_frameid) + +* [ICoreWebView2ExperimentalEnvironment11](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment11?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironment11::GetProcessInfosWithDetails](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment11?view=webview2-1.0.1988-prerelease&preserve-view=true#getprocessinfoswithdetails) + +* [ICoreWebView2ExperimentalFrame5](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe5?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFrame5::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe5?view=webview2-1.0.1988-prerelease&preserve-view=true#get_frameid) + +* [ICoreWebView2ExperimentalFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframeinfo?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2FrameInfo::get_FrameId](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframeinfo?view=webview2-1.0.1988-prerelease&preserve-view=true#get_frameid) + * [ICoreWebView2FrameInfo::get_FrameKind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframeinfo?view=webview2-1.0.1988-prerelease&preserve-view=true#get_framekind) + * [ICoreWebView2FrameInfo::get_ParentFrameInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframeinfo?view=webview2-1.0.1988-prerelease&preserve-view=true#get_parentframeinfo) + +* [COREWEBVIEW2_FRAME_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.1988-prerelease&preserve-view=true#corewebview2_frame_kind) + * `COREWEBVIEW2_FRAME_KIND_OTHER` + * `COREWEBVIEW2_FRAME_KIND_MAIN_FRAME` + * `COREWEBVIEW2_FRAME_KIND_IFRAME` + +* [ICoreWebView2ExperimentalGetProcessInfosWithDetailsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgetprocessinfoswithdetailscompletedhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) + +* [ICoreWebView2ExperimentalProcessInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessinfo?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProcessInfo::get_AssociatedFrameInfos](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessinfo?view=webview2-1.0.1988-prerelease&preserve-view=true#get_associatedframeinfos) + +--- + + + +* Supports extensions in WebView2. + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2BrowserExtension Class](/dotnet/api/microsoft.web.webview2.core.corewebview2browserextension?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.AreBrowserExtensionsEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.arebrowserextensionsenabled?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AddBrowserExtensionAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.addbrowserextensionasync?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + * [CoreWebView2Profile.GetBrowserExtensionsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getbrowserextensionsasync?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2BrowserExtension Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browserextension?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true) +* `CoreWebView2EnvironmentOptions` Class: + * [CoreWebView2EnvironmentOptions.AreBrowserExtensionsEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#arebrowserextensionsenabled) +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.AddBrowserExtensionAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true#addbrowserextensionasync) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalBrowserExtension](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalbrowserextension?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalBrowserExtension::get_IsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalbrowserextension?view=webview2-1.0.1988-prerelease&preserve-view=true#get_isenabled) + * [ICoreWebView2ExperimentalBrowserExtension::get_Name](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalbrowserextension?view=webview2-1.0.1988-prerelease&preserve-view=true#get_name) +* [ICoreWebView2ExperimentalBrowserExtensionEnableCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalbrowserextensionenablecompletedhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalBrowserExtensionList](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalbrowserextensionlist?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalBrowserExtensionRemoveCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalbrowserextensionremovecompletedhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalEnvironmentOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironmentOptions::get_AreBrowserExtensionsEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.1988-prerelease&preserve-view=true#get_arebrowserextensionsenabled) + * [ICoreWebView2ExperimentalEnvironmentOptions::put_AreBrowserExtensionsEnabled property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.1988-prerelease&preserve-view=true#put_arebrowserextensionsenabled) +* [ICoreWebView2ExperimentalProfile12](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile12?view=webview2-1.0.1988-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile12::AddBrowserExtension](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile12?view=webview2-1.0.1988-prerelease&preserve-view=true#addbrowserextension) + * [ICoreWebView2ExperimentalProfile12::GetBrowserExtensions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile12?view=webview2-1.0.1988-prerelease&preserve-view=true#getbrowserextensions) +* [ICoreWebView2ExperimentalProfileAddBrowserExtensionCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofileaddbrowserextensioncompletedhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalProfileGetBrowserExtensionsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofilegetbrowserextensionscompletedhandler?view=webview2-1.0.1988-prerelease&preserve-view=true) + +--- + + + +* The `TextDirectionKind` enum specifies the text direction as left to right or right to left. + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2TextDirectionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2textdirectionkind?view=webview2-dotnet-1.0.1988-prerelease&preserve-view=true) + * `Default` + * `LeftToRight` + * `RightToLeft` + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2TextDirectionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2textdirectionkind?view=webview2-winrt-1.0.1988-prerelease&preserve-view=true) + * `Default` + * `LeftToRight` + * `RightToLeft` + +##### [Win32/C++](#tab/win32cpp) + +* [COREWEBVIEW2_TEXT_DIRECTION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.1988-prerelease&preserve-view=true#corewebview2_text_direction_kind) + * `COREWEBVIEW2_TEXT_DIRECTION_KIND_DEFAULT` + * `COREWEBVIEW2_TEXT_DIRECTION_KIND_LEFT_TO_RIGHT` + * `COREWEBVIEW2_TEXT_DIRECTION_KIND_RIGHT_TO_LEFT` + +--- + + + +#### Bug fixes + +* Fixed a `CoreWebView2Frame.ExecuteScriptAsync` hang that occurred when a frame was destroyed during script execution. [Issue 3124](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3124) + +* Fixed a `COMException` when reading `WebResourceResponse` content after a redirect. [Issue 3229](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3229) + +* Fixed a regression where calling `CoreWebView2.AddHostObjectToScript` twice for the same name hangs. (Runtime-only) [Issue 3539](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3539) + +* Fixed an issue where `PrintAsync` fails when `PrinterName` contains Chinese characters. [Issue 3379](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3379) + +* Fixed an issue to disable the context menu in print pages when `AreDefaultContextMenusEnabled` is set to `false`. [Issue 3548](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3548) + +* Removed visual search from the web capture context menu. (Runtime-only) [Issue 3426](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3426) + +* Fixed an issue that caused `PrintAsync` and `PrintToPdfStreamAsync` to fail when print settings are `null`. + +* Removed the **Launch game** button from the default **No Internet Connection** error page. (Runtime-only) + +* Fixed an issue to ensure that `WebVivew2Loader` can be loaded from a UNC path. [Issue 3465](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3465) + +* Fixed invalid `CoreWebView2PdfToolbarItems.FullScreen` and `CoreWebView2PdfToolbarItems.MoreSettings`. + +* Added a lock for host object access from multithread. (Runtime-only) + +* Fixed configuration options that (`CoreWebView2PdfToolbarItems.MoreSettings`, `CoreWebView2PdfToolbarItems.FullScreen`) are not valid in PDF preview mode. [Issue 3324](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3324) + +* Removed the **Hide all annotations** option in PDF **Settings and more**. (Runtime-only) + +* Removed the **Show all saved passwords** context menu item. (Runtime-only) + + + + + +## Release SDK 1.0.1938.49, for Runtime 116 (Aug. 28, 2023) + +Release Date: Aug. 28, 2023 + +[NuGet package for WebView2 SDK 1.0.1938.49](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1938.49) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 116.0.1938.49 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +No additional APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, in this Release SDK. + + + +#### Bug fixes + +* Fixed a handle tracking bug where `TextureStream` API usage could fail. (Runtime-only) + +* Fixed a bug where a WebView2 created in a background thread doesn't come to the foreground when created. (Runtime-only) ([Issue #3584](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3584)) + +* Fixed a bug where the WebView2 content sometimes renders at the incorrect size after changing the display configuration (such as laptop sleeping; remoting; or connecting or disconnecting an external display). (Runtime-only) ([Issue 3429](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3429)) + +* Fixed a bug where a bluescreen happens when using WebView2 apps on certain hardware configurations. (Runtime-only) ([Issue #3679](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3679)) + + + + + +## Prerelease SDK 1.0.1905-prerelease, for Runtime 116 (Jun. 12, 2023) + +Release Date: Jun. 12, 2023 + +[NuGet package for WebView2 SDK 1.0.1905-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1905-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 116.0.1905.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* `NavigationKind` gets the navigation kind of each navigation, such as Back/Forward, Reload, or navigation to a new document. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2NavigationStartingEventArgs` Class: + * [CoreWebView2NavigationStartingEventArgs.NavigationKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2navigationstartingeventargs.navigationkind?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) +* [CoreWebView2NavigationKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2navigationkind?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2NavigationStartingEventArgs` Class: + * [CoreWebView2NavigationStartingEventArgs.NavigationKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2navigationstartingeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#navigationkind) +* [CoreWebView2NavigationKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2navigationkind?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2NavigationStartingEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs3?view=webview2-1.0.1905-prerelease&preserve-view=true) + * [ICoreWebView2NavigationStartingEventArgs3::get_NavigationKind property](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs3?view=webview2-1.0.1905-prerelease&preserve-view=true#get_navigationkind) +* [COREWEBVIEW2_NAVIGATION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1905-prerelease&preserve-view=true#corewebview2_navigation_kind) + +--- + + + +* The `ServiceWorkers` enum value in the `BrowsingDataKinds` enum specifies service workers that are registered for an origin. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2BrowsingDataKinds` Enum: + * [CoreWebView2BrowsingDataKinds.ServiceWorkers Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2browsingdatakinds?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2BrowsingDataKinds` Enum: + * [CoreWebView2BrowsingDataKinds.ServiceWorkers Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browsingdatakinds?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* `COREWEBVIEW2_BROWSING_DATA_KINDS` enum: + * [COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1905-prerelease&preserve-view=true#corewebview2_browsing_data_kinds) + +--- + + + +* The `LaunchingExternalUriScheme` event is raised when there's an attempt to launch a URI scheme that is registered with the OS (an external URI scheme). + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.LaunchingExternalUriScheme Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.launchingexternalurischeme?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) +* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.cancel?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.isuserinitiated?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.uri?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.getdeferral?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.LaunchingExternalUriScheme Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#launchingexternalurischeme) +* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#cancel) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#initiatingorigin) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#isuserinitiated) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#uri) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_18](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1905-prerelease&preserve-view=true) + * [ICoreWebView2_18::add_LaunchingExternalUriScheme event](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1905-prerelease&preserve-view=true#add_launchingexternalurischeme) + * [ICoreWebView2_18::remove_LaunchingExternalUriScheme event](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1905-prerelease&preserve-view=true#remove_launchingexternalurischeme) +* [ICoreWebView2LaunchingExternalUriSchemeEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventhandler?view=webview2-1.0.1905-prerelease&preserve-view=true) +* [ICoreWebView2LaunchingExternalUriSchemeEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Cancel property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_cancel) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_initiatingorigin) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_IsUserInitiated property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_isuserinitiated) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Uri property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#get_uri) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::put_Cancel property](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1905-prerelease&preserve-view=true#put_cancel) + +--- + + + +* `MemoryUsageTargetLevel` specifies memory consumption levels, such as `low` or `normal`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.MemoryUsageTargetLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.memoryusagetargetlevel?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) +* [CoreWebView2MemoryUsageTargetLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2memoryusagetargetlevel?view=webview2-dotnet-1.0.1905-prerelease&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.MemoryUsageTargetLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true#memoryusagetargetlevel) +* [CoreWebView2MemoryUsageTargetLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2memoryusagetargetlevel?view=webview2-winrt-1.0.1905-prerelease&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_19](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1905-prerelease&preserve-view=true) + * [ICoreWebView2_19::get_MemoryUsageTargetLevel property](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1905-prerelease&preserve-view=true#get_memoryusagetargetlevel) + * [ICoreWebView2_19::put_MemoryUsageTargetLevel property](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1905-prerelease&preserve-view=true#put_memoryusagetargetlevel) +* [COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1905-prerelease&preserve-view=true#corewebview2_memory_usage_target_level) + +--- + + + +#### Bug fixes + +* Using `wv2winrt webhosthidden` entered an infinite loop when enumerating some `webhosthidden` types. (SDK-only) + +* In code that's generated by the **wv2winrt** tool, when calling an async method, it would crash if it succeeded but returned `null` instead of an `IAsyncAction`. (SDK-only) + + + + + +## Release SDK 1.0.1901.177, for Runtime 115 (Jul. 24, 2023) + +Release Date: Jul. 24, 2023 + +[NuGet package for WebView2 SDK 1.0.1901.177](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1901.177) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 115.0.1901.177 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* `NavigationKind` gets the navigation kind of each navigation, such as Back/Forward, Reload, or navigation to a new document. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2NavigationStartingEventArgs` Class: + * [CoreWebView2NavigationStartingEventArgs.NavigationKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2navigationstartingeventargs.navigationkind?view=webview2-dotnet-1.0.1901.177&preserve-view=true) +* [CoreWebView2NavigationKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2navigationkind?view=webview2-dotnet-1.0.1901.177&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2NavigationStartingEventArgs` Class: + * [CoreWebView2NavigationStartingEventArgs.NavigationKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2navigationstartingeventargs?view=webview2-winrt-1.0.1901.177&preserve-view=true#navigationkind) +* [CoreWebView2NavigationKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2navigationkind?view=webview2-winrt-1.0.1901.177&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2NavigationStartingEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs3?view=webview2-1.0.1901.177&preserve-view=true) + * [ICoreWebView2NavigationStartingEventArgs3::get_NavigationKind](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs3?view=webview2-1.0.1901.177&preserve-view=true#get_navigationkind) +* [COREWEBVIEW2_NAVIGATION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1901.177&preserve-view=true#corewebview2_navigation_kind) + +--- + + + +* The `ServiceWorkers` enum value in the `BrowsingDataKinds` enum specifies service workers that are registered for an origin. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2BrowsingDataKinds` Enum: + * [CoreWebView2BrowsingDataKinds.ServiceWorkers Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2browsingdatakinds?view=webview2-dotnet-1.0.1901.177&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2BrowsingDataKinds` Enum: + * [CoreWebView2BrowsingDataKinds.ServiceWorkers Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2browsingdatakinds?view=webview2-winrt-1.0.1901.177&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* `COREWEBVIEW2_BROWSING_DATA_KINDS` enum: + * [COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1901.177&preserve-view=true#corewebview2_browsing_data_kinds) + +--- + + + +#### Bug fixes + +* Fixed a bug where the entire toolbar is blank when hiding the Bookmarks, Search, and PageSelector buttons simultaneously. (Runtime-only) [Issue 2866](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2866) + + + + + +## Prerelease SDK 1.0.1829-prerelease, for Runtime 115 (May 8, 2023) + +Release Date: May 8, 2023 + +[NuGet package for WebView2 SDK 1.0.1829-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1829-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 115.0.1829.0 or higher. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* Enhanced support for multiple profiles, to allow configuring General Autofill and Password Autosave settings for different profiles. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.isgeneralautofillenabled?view=webview2-dotnet-1.0.1829-prerelease&preserve-view=true) + * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.ispasswordautosaveenabled?view=webview2-dotnet-1.0.1829-prerelease&preserve-view=true) + + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1829-prerelease&preserve-view=true#isgeneralautofillenabled) + * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1829-prerelease&preserve-view=true#ispasswordautosaveenabled) + + +##### [Win32/C++](#tab/win32cpp) + +* `ICoreWebView2Profile6` interface: + * [ICoreWebView2Profile6::get_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#get_ispasswordautosaveenabled) + * [ICoreWebView2Profile6::put_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#put_ispasswordautosaveenabled) + * [ICoreWebView2Profile6::get_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#get_isgeneralautofillenabled) + * [ICoreWebView2Profile6::put_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1829-prerelease&preserve-view=true#put_isgeneralautofillenabled) + +--- + + + +#### Bug fixes + +* Disabled the Chrome Web Store info banner that displays the option to allow extensions installation. ([Issue #3312](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3312)) + +* Fixed an issue where a custom menu item wasn't firing. ([Issue #3300](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3300)) + +* Fixed a crash during initialization when creating a WebView2 using WPF and SDK version 1.0.1722.32, which is now deprecated. (See [SDK 1.0.1722.32 is deprecated](#sdk-10172232-is-deprecated) below.) ([Issue #3375](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3375)) + +* Fixed a bug in `PostSharedBufferToScript` that stops after about 32000x1MB buffers are posted. (Runtime-only) ([Issue #3360](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3360)) + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postsharedbuffertoscript) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2#postsharedbuffertoscript) + +##### [Win32/C++](#tab/win32cpp) + +* `ICoreWebView2_17` interface: + * [ICoreWebView2_17::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2_17#postsharedbuffertoscript) + +--- + +* Fixed an issue where navigation will always take place within a `ScriptDialogOpening` event callback. (Runtime-only) ([Issue #3355](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3355)) + +* Fixed an issue to support the `BackForwardCache` flag. (Runtime-only) + +* Fixed an issue with visual hosted owned windows, where clicking into the Find bar from outside the window didn't activate the Find bar. + + + + + +## Release SDK 1.0.1823.32, for Runtime 114 (Jun. 5, 2023) + +Release Date: Jun. 5, 2023 + +[NuGet package for WebView2 SDK 1.0.1823.32](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1823.32) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 114.0.1823.32 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* The `LaunchingExternalUriScheme` event is raised when there's an attempt to launch a URI scheme that is registered with the OS (an external URI scheme). + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.LaunchingExternalUriScheme Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.launchingexternalurischeme?view=webview2-dotnet-1.0.1823.32&preserve-view=true) +* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.cancel?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.isuserinitiated?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.uri?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.getdeferral?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.LaunchingExternalUriScheme Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1823.32&preserve-view=true#launchingexternalurischeme) +* [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#cancel) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#initiatingorigin) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#isuserinitiated) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#uri) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1823.32&preserve-view=true#getdeferral) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_18](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1823.32&preserve-view=true) + * [ICoreWebView2_18::add_LaunchingExternalUriScheme](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1823.32&preserve-view=true#add_launchingexternalurischeme) + * [ICoreWebView2_18::remove_LaunchingExternalUriScheme](/microsoft-edge/webview2/reference/win32/icorewebview2_18?view=webview2-1.0.1823.32&preserve-view=true#remove_launchingexternalurischeme) +* [ICoreWebView2LaunchingExternalUriSchemeEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventhandler?view=webview2-1.0.1823.32&preserve-view=true) +* [ICoreWebView2LaunchingExternalUriSchemeEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_cancel) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_initiatingorigin) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_IsUserInitiated](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_isuserinitiated) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::get_Uri](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#get_uri) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#getdeferral) + * [ICoreWebView2LaunchingExternalUriSchemeEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2launchingexternalurischemeeventargs?view=webview2-1.0.1823.32&preserve-view=true#put_cancel) + +--- + + + +* `MemoryUsageTargetLevel` specifies memory consumption levels, such as `low` or `normal`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.MemoryUsageTargetLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.memoryusagetargetlevel?view=webview2-dotnet-1.0.1823.32&preserve-view=true) +* [CoreWebView2MemoryUsageTargetLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2memoryusagetargetlevel?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class: + * [CoreWebView2.MemoryUsageTargetLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2#memoryusagetargetlevel?view=webview2-winrt-1.0.1823.32&preserve-view=true) +* [CoreWebView2MemoryUsageTargetLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2memoryusagetargetlevel?view=webview2-winrt-1.0.1823.32&preserve-view=true) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_19](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1823.32&preserve-view=true) + * [ICoreWebView2_19::get_MemoryUsageTargetLevel](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1823.32&preserve-view=true#get_memoryusagetargetlevel) + * [ICoreWebView2_19::put_MemoryUsageTargetLevel](/microsoft-edge/webview2/reference/win32/icorewebview2_19?view=webview2-1.0.1823.32&preserve-view=true#put_memoryusagetargetlevel) +* [COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1823.32&preserve-view=true#corewebview2_memory_usage_target_level) + +--- + + + +* Enhanced support for multiple profiles, to allow configuring General Autofill and Password Autosave settings for different profiles. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.isgeneralautofillenabled?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.ispasswordautosaveenabled?view=webview2-dotnet-1.0.1823.32&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.IsGeneralAutofillEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1823.32&preserve-view=true#isgeneralautofillenabled) + * [CoreWebView2Profile.IsPasswordAutosaveEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1823.32&preserve-view=true#ispasswordautosaveenabled) + +##### [Win32/C++](#tab/win32cpp) + +* `ICoreWebView2Profile6`: + * [ICoreWebView2Profile6::get_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#get_isgeneralautofillenabled) + * [ICoreWebView2Profile6::get_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#get_ispasswordautosaveenabled) + * [ICoreWebView2Profile6::put_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#put_isgeneralautofillenabled) + * [ICoreWebView2Profile6::put_IsPasswordAutosaveEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2profile6?view=webview2-1.0.1823.32&preserve-view=true#put_ispasswordautosaveenabled) + +--- + + + + + +## Prerelease SDK 1.0.1777-prerelease, for Runtime 114 (Apr. 10, 2023) + +Release Date: Apr. 10, 2023 + +[NuGet package for WebView2 SDK 1.0.1777-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1777-prerelease) + +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 114.0.1777.0 or higher. + + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +No Experimental APIs have been added in this Prerelease SDK. + + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + + + +* The File API allows accessing a DOM `File` object passed via `WebMessage`. + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2File](/dotnet/api/microsoft.web.webview2.core.corewebview2file?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true) + * [CoreWebView2File.path property](/dotnet/api/microsoft.web.webview2.core.corewebview2file.path?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2file-path) + +* `CoreWebView2WebMessageReceivedEventArgs` + * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects property](/dotnet/api/microsoft.web.webview2.core.corewebview2webmessagereceivedeventargs.additionalobjects?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2webmessagereceivedeventargs-additionalobjects) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2File](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true) + * [CoreWebView2File.path property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true#path) + +* `CoreWebView2WebMessageReceivedEventArgs` + * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webmessagereceivedeventargs?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true#additionalobjects) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2File](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1777-prerelease&preserve-view=true) + * [ICoreWebView2File::get_path](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1777-prerelease&preserve-view=true#get_path) + +* [ICoreWebView2WebMessageReceivedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1777-prerelease&preserve-view=true) + * [ICoreWebView2WebMessageReceivedEventArgs2::get_AdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1777-prerelease&preserve-view=true#get_AdditionalObjects) + +* [ICoreWebView2ObjectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1777-prerelease&preserve-view=true) + * [ICoreWebView2ObjectCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1777-prerelease&preserve-view=true#get_Count) + * [ICoreWebView2ObjectCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1777-prerelease&preserve-view=true#GetValueAtIndex) + +--- + + + +* The Profile Cookie Manager API supports profile management. The `CookieManager` property enables the host app to get the cookie manager for the profile. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Profile` + * [CoreWebView2Profile.CookieManager property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.cookiemanager?view=webview2-dotnet-1.0.1777-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2profile-cookiemanager) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Profile` + * [CoreWebView2Profile.CookieManager property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1777-prerelease&preserve-view=true#cookiemanager) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Profile5](/microsoft-edge/webview2/reference/win32/icorewebview2profile5?view=webview2-1.0.1777-prerelease&preserve-view=true) + * [ICoreWebView2Profile5::get_CookieManager](/microsoft-edge/webview2/reference/win32/icorewebview2profile5?view=webview2-1.0.1777-prerelease&preserve-view=true#get_cookiemanager) + +--- + + + +#### Bug fixes + +* Fixed a crash when releasing the WebView from a different thread. (Runtime-only) ([Issue #3062](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3062)) + +* Fixed a bug where focus was trapped inside the WebView2 control when wrapped in a `ContainerControl`. ([Issue #2835](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2835)) + +* Fixed the issue by disabling the editable `.pdf` temporary cached data recovery function in WebView2. ([Issue #3274](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3274)) + +* Disabled the Chrome Web Store info banner that displays the option to allow extensions installation. ([Issue #3312](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3312)) + +* Fixed an issue with new download items not getting called out by screen readers. + +* Fixed a bug where visual hosted owned windows didn't map mouse pointer input correctly. + +* Fixed a bug where `DownloadStarting` was getting raised for a canceled **Save As** dialog. (Runtime-only) + + + + + +## Release SDK 1.0.1774.30, for Runtime 113 (May 8, 2023) -* `CoreWebView2Profile` Class - * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getnondefaultpermissionsettingsasync?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +Release Date: May 8, 2023 -##### [WinRT/C#](#tab/winrtcsharp) +[NuGet package for WebView2 SDK 1.0.1774.30](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1774.30) -* `CoreWebView2PermissionKind` Enum - * [CoreWebView2PermissionKind.MidiSystemExclusiveMessages Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.1661.34&preserve-view=true) +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 113.0.1774.30 or higher. -* `CoreWebView2PermissionRequestedEventArgs` Event - * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionrequestedeventargs?view=webview2-winrt-1.0.1661.34&preserve-view=true#savesinprofile) -* [CoreWebView2PermissionSetting Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true#permissionkind) - * [CoreWebView2PermissionSetting.PermissionOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true#permissionorigin) - * [CoreWebView2PermissionSetting.PermissionState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true#permissionstate) + +#### Promotions to Phase 3 (Stable in Release) -* `CoreWebView2Profile` Class - * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1661.34&preserve-view=true#getnondefaultpermissionsettingsasync) - * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1661.34&preserve-view=true#setpermissionstateasync) +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2getnondefaultpermissionsettingscompletedhandler?view=webview2-1.0.1661.34&preserve-view=true) + +* The File API allows accessing a DOM `File` object passed via `WebMessage`. -* [ICoreWebView2PermissionRequestedEventArgs3 interface](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs3?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2PermissionRequestedEventArgs3::get_SavesInProfile](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs3?view=webview2-1.0.1661.34&preserve-view=true#get_savesinprofile) - * [ICoreWebView2PermissionRequestedEventArgs3::put_SavesInProfile](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs3?view=webview2-1.0.1661.34&preserve-view=true#put_savesinprofile) +##### [.NET/C#](#tab/dotnetcsharp) -* [ICoreWebView2PermissionSetting interface](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2PermissionSetting::get_PermissionKind method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true#get_permissionkind) - * [ICoreWebView2PermissionSetting::get_PermissionOrigin method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true#get_permissionorigin) - * [ICoreWebView2PermissionSetting::get_PermissionState method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true#get_permissionstate) +* [CoreWebView2File Class](/dotnet/api/microsoft.web.webview2.core.corewebview2file?view=webview2-dotnet-1.0.1774.30&preserve-view=true) + * [CoreWebView2File.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2file.path?view=webview2-dotnet-1.0.1774.30&preserve-view=true) +* `CoreWebView2WebMessageReceivedEventArgs` Class: + * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webmessagereceivedeventargs.additionalobjects?view=webview2-dotnet-1.0.1774.30&preserve-view=true) -* [ICoreWebView2PermissionSettingCollectionView interface](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2PermissionSettingCollectionView::GetValueAtIndex method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1661.34&preserve-view=true#getvalueatindex) - * [ICoreWebView2PermissionSettingCollectionView::get_Count method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1661.34&preserve-view=true#get_count) +##### [WinRT/C#](#tab/winrtcsharp) -* [ICoreWebView2Profile4 interface](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2Profile4::GetNonDefaultPermissionSettings method](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1661.34&preserve-view=true#getnondefaultpermissionsettings) - * [ICoreWebView2Profile4::SetPermissionState method](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1661.34&preserve-view=true#setpermissionstate) +* [CoreWebView2File Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1774.30&preserve-view=true) + * [CoreWebView2File.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1774.30&preserve-view=true#path) +* `CoreWebView2WebMessageReceivedEventArgs` Class: + * [CoreWebView2WebMessageReceivedEventArgs.AdditionalObjects Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webmessagereceivedeventargs?view=webview2-winrt-1.0.1774.30&preserve-view=true#additionalobjects) -* [ICoreWebView2SetPermissionStateCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2setpermissionstatecompletedhandler?view=webview2-1.0.1661.34&preserve-view=true) +##### [Win32/C++](#tab/win32cpp) -* `COREWEBVIEW2_PERMISSION_KIND` Enum - * [COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGES enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1661.34&preserve-view=true#corewebview2_permission_kind) +* [ICoreWebView2File](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1774.30&preserve-view=true) + * [ICoreWebView2File::get_Path](/microsoft-edge/webview2/reference/win32/icorewebview2file?view=webview2-1.0.1774.30&preserve-view=true#get_path) +* [ICoreWebView2ObjectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1774.30&preserve-view=true) + * [ICoreWebView2ObjectCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1774.30&preserve-view=true#get_count) + * [ICoreWebView2ObjectCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2objectcollectionview?view=webview2-1.0.1774.30&preserve-view=true#getvalueatindex) +* [ICoreWebView2WebMessageReceivedEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1774.30&preserve-view=true) + * [ICoreWebView2WebMessageReceivedEventArgs2::get_AdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2webmessagereceivedeventargs2?view=webview2-1.0.1774.30&preserve-view=true#get_additionalobjects) --- -APIs for managing tracking prevention: +* The Profile Cookie Manager API supports profile management. The `CookieManager` property enables the host app to get the cookie manager for the profile. ##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2EnvironmentOptions` Class - * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.enabletrackingprevention?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - -* `CoreWebView2Profile` Class - * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.preferredtrackingpreventionlevel?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - -* [CoreWebView2TrackingPreventionLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2trackingpreventionlevel?view=webview2-dotnet-1.0.1661.34&preserve-view=true) - * `None` - * `Basic` - * `Balanced` - * `Strict` +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.CookieManager Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.cookiemanager?view=webview2-dotnet-1.0.1774.30&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2EnvironmentOptions` Class - * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1661.34&preserve-view=true#enabletrackingprevention) - -* `CoreWebView2Profile` Class - * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1661.34&preserve-view=true#preferredtrackingpreventionlevel) - -* [CoreWebView2TrackingPreventionLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2trackingpreventionlevel?view=webview2-winrt-1.0.1661.34&preserve-view=true) - * `None` - * `Basic` - * `Balanced` - * `Strict` +* `CoreWebView2Profile` Class: + * [CoreWebView2Profile.CookieManager Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1774.30&preserve-view=true#cookiemanager) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2EnvironmentOptions5 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention property (get](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1661.34&preserve-view=true#get_enabletrackingprevention), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1661.34&preserve-view=true#put_enabletrackingprevention) - -* [ICoreWebView2Profile3 interface](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2Profile3::PreferredTrackingPreventionLevel property (get](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1661.34&preserve-view=true#get_preferredtrackingpreventionlevel), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1661.34&preserve-view=true#put_preferredtrackingpreventionlevel) - -* [COREWEBVIEW2_TRACKING_PREVENTION_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1661.34&preserve-view=true#corewebview2_tracking_prevention_level) - * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE` - * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BASIC` - * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BALANCED` - * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_STRICT` +* `ICoreWebView2Profile5`: + * [ICoreWebView2Profile5::get_CookieManager](/microsoft-edge/webview2/reference/win32/icorewebview2profile5?view=webview2-1.0.1774.30&preserve-view=true#get_cookiemanager) --- -* APIs to manage the value of the controller's script locale: +#### Bug fixes + +* Fixed an issue to allow an app to inject initial scripts by calling `AddScriptToExecuteOnDocumentCreated` before a new window is created. ([Issue #2491](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2491)) ##### [.NET/C#](#tab/dotnetcsharp) -* `CoreWebView2ControllerOptions` Class - * [CoreWebView2ControllerOptions.ScriptLocale Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.scriptlocale?view=webview2-dotnet-1.0.1661.34&preserve-view=true) +* `CoreWebView2` Class: + * [CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.addscripttoexecuteondocumentcreatedasync) ##### [WinRT/C#](#tab/winrtcsharp) -* `CoreWebView2ControllerOptions` Class - * [CoreWebView2ControllerOptions.ScriptLocale Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.1661.34&preserve-view=true#scriptlocale) +* `CoreWebView2` Class: + * [CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2#addscripttoexecuteondocumentcreatedasync) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ControllerOptions2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1661.34&preserve-view=true) - * [ICoreWebView2ControllerOptions2::get_ScriptLocale method](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1661.34&preserve-view=true#get_scriptlocale) - * [ICoreWebView2ControllerOptions2::put_ScriptLocale method](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1661.34&preserve-view=true#put_scriptlocale) +* `ICoreWebView2`: + * [ICoreWebView2::AddScriptToExecuteOnDocumentCreated](/microsoft-edge/webview2/reference/win32/icorewebview2#addscripttoexecuteondocumentcreated) --- +* Fixed an issue that was causing the `X-Edge-Shopping-Flag` header to be added to web requests that are coming from WebView2. (Runtime-only) ([Issue #3365](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3365)) + + + -## 1.0.1724-prerelease +## Prerelease SDK 1.0.1724-prerelease, for Runtime 113 (Mar. 20, 2023) -Release Date: March 20, 2023 +Release Date: Mar. 20, 2023 [NuGet package for WebView2 SDK 1.0.1724-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1724-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 113.0.1724.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 113.0.1724.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) - -###### Experimental Features +The following Experimental APIs have been added in this Prerelease SDK. -* Added AdditionalObjects for WebMessage received: +* Added `AdditionalObjects` for WebMessage received: ##### [.NET/C#](#tab/dotnetcsharp) @@ -952,7 +7911,7 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalWebMessageReceivedEventArgs::get_AdditionalObjects method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebmessagereceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_additionalobjects) +* [ICoreWebView2ExperimentalWebMessageReceivedEventArgs::get_AdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebmessagereceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_additionalobjects) --- @@ -970,7 +7929,7 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT Enum Value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1724-prerelease&preserve-view=true#corewebview2_permission_kind) +* [COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1724-prerelease&preserve-view=true#corewebview2_permission_kind) --- @@ -983,22 +7942,22 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft * [CoreWebView2.LaunchingExternalUriScheme Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.launchingexternalurischeme?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) * [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.cancel?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.getdeferral?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.isuserinitiated?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.uri?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.cancel?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.getdeferral?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.initiatingorigin?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.isuserinitiated?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2launchingexternalurischemeeventargs.uri?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2.LaunchingExternalUriScheme Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#launchingexternalurischeme) * [CoreWebView2LaunchingExternalUriSchemeEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#cancel) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#getdeferral) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#initiatingorigin) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#isuserinitiated) - * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#uri) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Cancel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#cancel) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.GetDeferral Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#getdeferral) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.InitiatingOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#initiatingorigin) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.IsUserInitiated Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#isuserinitiated) + * [CoreWebView2LaunchingExternalUriSchemeEventArgs.Uri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2launchingexternalurischemeeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#uri) ##### [Win32/C++](#tab/win32cpp) @@ -1007,15 +7966,15 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft * [ICoreWebView2Experimental21::remove_LaunchingExternalUriScheme](/microsoft-edge/webview2/reference/win32/icorewebview2experimental21?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_launchingexternalurischeme) * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler::Invoke](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true#invoke) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventHandler::Invoke](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true#invoke) * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_Uri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_uri) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_initiatingorigin) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_IsUserInitiated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_isuserinitiated) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_cancel) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#put_cancel) - * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#getdeferral) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_Uri](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_uri) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_InitiatingOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_initiatingorigin) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_IsUserInitiated](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_isuserinitiated) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::get_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_cancel) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::put_Cancel](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#put_cancel) + * [ICoreWebView2ExperimentalLaunchingExternalUriSchemeEventArgs::GetDeferral](/microsoft-edge/webview2/reference/win32/icorewebview2experimentallaunchingexternalurischemeeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#getdeferral) --- @@ -1049,8 +8008,8 @@ The `TextureStream` interface: ErrorReceivedEventArgs: * [CoreWebView2TextureStreamErrorReceivedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorreceivedeventargs?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorReceivedEventArgs.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorreceivedeventargs.kind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorReceivedEventArgs.texture Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorreceivedeventargs.texture?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorReceivedEventArgs.Kind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorreceivedeventargs.kind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorReceivedEventArgs.texture Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorreceivedeventargs.texture?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) WebTextureReceivedEventArgs: * [CoreWebView2TextureStreamWebTextureReceivedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamwebtexturereceivedeventargs?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) @@ -1058,21 +8017,21 @@ WebTextureReceivedEventArgs: TextureStream error kind enum: * [CoreWebView2TextureStreamErrorKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorNoVideoTrackStarted Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureError Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureInUse Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorNoVideoTrackStarted Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureError Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureInUse Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2texturestreamerrorkind?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) The `Texture` interface that the host writes to so that the Renderer will render on it: * [CoreWebView2Texture Class](/dotnet/api/microsoft.web.webview2.core.corewebview2texture?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2Texture.Handle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texture.handle?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2Texture.Resource Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texture.resource?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2Texture.Timestamp Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texture.timestamp?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2Texture.Handle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texture.handle?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2Texture.Resource Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texture.resource?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2Texture.Timestamp Property](/dotnet/api/microsoft.web.webview2.core.corewebview2texture.timestamp?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) The received `WebTexture` interface that the Renderer writes to so that the host will read on it: * [CoreWebView2WebTexture Class](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2WebTexture.Handle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture.handle?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2WebTexture.Resource Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture.resource?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2WebTexture.Timestamp Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture.timestamp?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2WebTexture.Handle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture.handle?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2WebTexture.Resource Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture.resource?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2WebTexture.Timestamp Property](/dotnet/api/microsoft.web.webview2.core.corewebview2webtexture.timestamp?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) @@ -1100,88 +8059,88 @@ The `TextureStream` interface: ErrorReceivedEventArgs: * [CoreWebView2TextureStreamErrorReceivedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorreceivedeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorReceivedEventArgs.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorreceivedeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#kind) + * [CoreWebView2TextureStreamErrorReceivedEventArgs.Kind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorreceivedeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#kind) WebTextureReceivedEventArgs: * [CoreWebView2TextureStreamWebTextureReceivedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamwebtexturereceivedeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamWebTextureReceivedEventArgs.WebTexture Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamwebtexturereceivedeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#webtexture) + * [CoreWebView2TextureStreamWebTextureReceivedEventArgs.WebTexture Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamwebtexturereceivedeventargs?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#webtexture) TextureStream error kind enum: * [CoreWebView2TextureStreamErrorKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorNoVideoTrackStarted Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureError Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureInUse Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorNoVideoTrackStarted Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureError Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2TextureStreamErrorKind.CoreWebView2TextureStreamErrorTextureInUse Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texturestreamerrorkind?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) The `Texture` interface that the host writes to so that the Renderer will render on it: * [CoreWebView2Texture Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2Texture.Resource Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#resource) - * [CoreWebView2Texture.Timestamp Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#timestamp) + * [CoreWebView2Texture.Resource Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#resource) + * [CoreWebView2Texture.Timestamp Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2texture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#timestamp) The received `WebTexture` interface that the Renderer writes to so that the host will read on it: * [CoreWebView2WebTexture Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webtexture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2WebTexture.Resource Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webtexture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#resource) - * [CoreWebView2WebTexture.Timestamp Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webtexture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#timestamp) + * [CoreWebView2WebTexture.Resource Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webtexture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#resource) + * [CoreWebView2WebTexture.Timestamp Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webtexture?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#timestamp) ##### [Win32/C++](#tab/win32cpp) The `Environment` interface that returns the `TextureStream` interface: -* [ICoreWebView2ExperimentalEnvironment12 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalEnvironment12::CreateTextureStream](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true#createtexturestream) - * [ICoreWebView2ExperimentalEnvironment12::RenderAdapterLUID (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true#get_renderadapterluid) - * [ICoreWebView2ExperimentalEnvironment12::RenderAdapterLUIDChanged (add, remove)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true#add_renderadapterluidchanged) +* [ICoreWebView2ExperimentalEnvironment12](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironment12::CreateTextureStream](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true#createtexturestream) + * [ICoreWebView2ExperimentalEnvironment12::RenderAdapterLUID (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true#get_renderadapterluid) + * [ICoreWebView2ExperimentalEnvironment12::RenderAdapterLUIDChanged (add, remove)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment12?view=webview2-1.0.1724-prerelease&preserve-view=true#add_renderadapterluidchanged) The `TextureStream` interface: -* [ICoreWebView2ExperimentalTextureStream interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalTextureStream::add_ErrorReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_errorreceived) - * [ICoreWebView2ExperimentalTextureStream::add_StartRequested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_startrequested) - * [ICoreWebView2ExperimentalTextureStream::add_Stopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_stopped) - * [ICoreWebView2ExperimentalTextureStream::add_WebTextureReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_webtexturereceived) - * [ICoreWebView2ExperimentalTextureStream::add_WebTextureStreamStopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_webtexturestreamstopped) - * [ICoreWebView2ExperimentalTextureStream::AddAllowedOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#addallowedorigin) - * [ICoreWebView2ExperimentalTextureStream::CloseTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#closetexture) - * [ICoreWebView2ExperimentalTextureStream::CreateTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#createtexture) - * [ICoreWebView2ExperimentalTextureStream::get_Id](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#get_id) - * [ICoreWebView2ExperimentalTextureStream::GetAvailableTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#getavailabletexture) - * [ICoreWebView2ExperimentalTextureStream::PresentTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#presenttexture) - * [ICoreWebView2ExperimentalTextureStream::remove_ErrorReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_errorreceived) - * [ICoreWebView2ExperimentalTextureStream::remove_StartRequested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_startrequested) - * [ICoreWebView2ExperimentalTextureStream::remove_Stopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_stopped) - * [ICoreWebView2ExperimentalTextureStream::remove_WebTextureReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_webtexturereceived) - * [ICoreWebView2ExperimentalTextureStream::remove_WebTextureStreamStopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_webtexturestreamstopped) - * [ICoreWebView2ExperimentalTextureStream::RemoveAllowedOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#removeallowedorigin) - * [ICoreWebView2ExperimentalTextureStream::SetD3DDevice](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#setd3ddevice) - * [ICoreWebView2ExperimentalTextureStream::Stop](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#stop) +* [ICoreWebView2ExperimentalTextureStream](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalTextureStream::add_ErrorReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_errorreceived) + * [ICoreWebView2ExperimentalTextureStream::add_StartRequested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_startrequested) + * [ICoreWebView2ExperimentalTextureStream::add_Stopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_stopped) + * [ICoreWebView2ExperimentalTextureStream::add_WebTextureReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_webtexturereceived) + * [ICoreWebView2ExperimentalTextureStream::add_WebTextureStreamStopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#add_webtexturestreamstopped) + * [ICoreWebView2ExperimentalTextureStream::AddAllowedOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#addallowedorigin) + * [ICoreWebView2ExperimentalTextureStream::CloseTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#closetexture) + * [ICoreWebView2ExperimentalTextureStream::CreateTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#createtexture) + * [ICoreWebView2ExperimentalTextureStream::get_Id](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#get_id) + * [ICoreWebView2ExperimentalTextureStream::GetAvailableTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#getavailabletexture) + * [ICoreWebView2ExperimentalTextureStream::PresentTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#presenttexture) + * [ICoreWebView2ExperimentalTextureStream::remove_ErrorReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_errorreceived) + * [ICoreWebView2ExperimentalTextureStream::remove_StartRequested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_startrequested) + * [ICoreWebView2ExperimentalTextureStream::remove_Stopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_stopped) + * [ICoreWebView2ExperimentalTextureStream::remove_WebTextureReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_webtexturereceived) + * [ICoreWebView2ExperimentalTextureStream::remove_WebTextureStreamStopped](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_webtexturestreamstopped) + * [ICoreWebView2ExperimentalTextureStream::RemoveAllowedOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#removeallowedorigin) + * [ICoreWebView2ExperimentalTextureStream::SetD3DDevice](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#setd3ddevice) + * [ICoreWebView2ExperimentalTextureStream::Stop](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestream?view=webview2-1.0.1724-prerelease&preserve-view=true#stop) Supplemental `TextureStream*` interfaces: -* [ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamstartrequestedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalTextureStreamStoppedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamstoppedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_kind) - * [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs::get_Texture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_texture) -* [ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturereceivedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturereceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs::get_WebTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturereceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_webtexture) -* [ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturestreamstoppedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalTextureStreamStartRequestedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamstartrequestedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalTextureStreamStoppedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamstoppedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs::get_Kind](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_kind) + * [ICoreWebView2ExperimentalTextureStreamErrorReceivedEventArgs::get_Texture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamerrorreceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_texture) +* [ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturereceivedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturereceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalTextureStreamWebTextureReceivedEventArgs::get_WebTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturereceivedeventargs?view=webview2-1.0.1724-prerelease&preserve-view=true#get_webtexture) +* [ICoreWebView2ExperimentalTextureStreamWebTextureStreamStoppedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexturestreamwebtexturestreamstoppedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) TextureStream error kind enum: -* [COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND Enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.1724-prerelease&preserve-view=true#corewebview2_texture_stream_error_kind) +* [COREWEBVIEW2_TEXTURE_STREAM_ERROR_KIND enum](/microsoft-edge/webview2/reference/win32/webview2experimental-idl?view=webview2-1.0.1724-prerelease&preserve-view=true#corewebview2_texture_stream_error_kind) Other interfaces (`RenderAdapter`): -* [ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalrenderadapterluidchangedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalRenderAdapterLUIDChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalrenderadapterluidchangedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) The `Texture` interface that the host writes to so that the Renderer will render on it: -* [ICoreWebView2ExperimentalTexture interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalTexture::get_Handle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_handle) - * [ICoreWebView2ExperimentalTexture::get_Resource](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_resource) - * [ICoreWebView2ExperimentalTexture::get_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_timestamp) - * [ICoreWebView2ExperimentalTexture::put_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#put_timestamp) +* [ICoreWebView2ExperimentalTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalTexture::get_Handle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_handle) + * [ICoreWebView2ExperimentalTexture::get_Resource](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_resource) + * [ICoreWebView2ExperimentalTexture::get_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_timestamp) + * [ICoreWebView2ExperimentalTexture::put_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2experimentaltexture?view=webview2-1.0.1724-prerelease&preserve-view=true#put_timestamp) The received `WebTexture` interface that the Renderer writes to so that the host will read on it: -* [ICoreWebView2ExperimentalWebTexture interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalWebTexture::get_Handle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_handle) - * [ICoreWebView2ExperimentalWebTexture::get_Resource](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_resource) - * [ICoreWebView2ExperimentalWebTexture::get_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_timestamp) +* [ICoreWebView2ExperimentalWebTexture](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalWebTexture::get_Handle](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_handle) + * [ICoreWebView2ExperimentalWebTexture::get_Resource](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_resource) + * [ICoreWebView2ExperimentalWebTexture::get_Timestamp](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebtexture?view=webview2-1.0.1724-prerelease&preserve-view=true#get_timestamp) --- @@ -1218,31 +8177,31 @@ Add support for managing profile deletion: ##### [Win32/C++](#tab/win32cpp) Added support for custom data partition: -* [ICoreWebView2Experimental20 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimental20?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2Experimental20::get_CustomDataPartitionId](/microsoft-edge/webview2/reference/win32/icorewebview2experimental20?view=webview2-1.0.1724-prerelease&preserve-view=true#get_customdatapartitionid) - * [ICoreWebView2Experimental20::put_CustomDataPartitionId](/microsoft-edge/webview2/reference/win32/icorewebview2experimental20?view=webview2-1.0.1724-prerelease&preserve-view=true#put_customdatapartitionid) -* [ICoreWebView2ExperimentalProfile7 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile7?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalProfile7::ClearCustomDataPartition](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile7?view=webview2-1.0.1724-prerelease&preserve-view=true#clearcustomdatapartition) -* [ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalclearcustomdatapartitioncompletedhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2Experimental20](/microsoft-edge/webview2/reference/win32/icorewebview2experimental20?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2Experimental20::get_CustomDataPartitionId](/microsoft-edge/webview2/reference/win32/icorewebview2experimental20?view=webview2-1.0.1724-prerelease&preserve-view=true#get_customdatapartitionid) + * [ICoreWebView2Experimental20::put_CustomDataPartitionId](/microsoft-edge/webview2/reference/win32/icorewebview2experimental20?view=webview2-1.0.1724-prerelease&preserve-view=true#put_customdatapartitionid) +* [ICoreWebView2ExperimentalProfile7](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile7?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile7::ClearCustomDataPartition](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile7?view=webview2-1.0.1724-prerelease&preserve-view=true#clearcustomdatapartition) +* [ICoreWebView2ExperimentalClearCustomDataPartitionCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalclearcustomdatapartitioncompletedhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) Added support for cookie manager: -* [ICoreWebView2ExperimentalProfile8 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile8?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalProfile8::get_CookieManager](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile8?view=webview2-1.0.1724-prerelease&preserve-view=true#get_cookiemanager) +* [ICoreWebView2ExperimentalProfile8](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile8?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile8::get_CookieManager](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile8?view=webview2-1.0.1724-prerelease&preserve-view=true#get_cookiemanager) Add support for managing profile deletion: -* [ICoreWebView2ExperimentalProfile10 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalProfile10::Delete](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true#delete) - * [ICoreWebView2ExperimentalProfile10::add_Deleted](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true#add_deleted) - * [ICoreWebView2ExperimentalProfile10::remove_Deleted](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_deleted) -* [ICoreWebView2ExperimentalProfileDeletedEventHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofiledeletedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalProfile10](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile10::Delete](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true#delete) + * [ICoreWebView2ExperimentalProfile10::add_Deleted](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true#add_deleted) + * [ICoreWebView2ExperimentalProfile10::remove_Deleted](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile10?view=webview2-1.0.1724-prerelease&preserve-view=true#remove_deleted) +* [ICoreWebView2ExperimentalProfileDeletedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofiledeletedeventhandler?view=webview2-1.0.1724-prerelease&preserve-view=true) --- -###### Promotions +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. @@ -1251,136 +8210,157 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2Settings Class](/dotnet/api/microsoft.web.webview2.core.corewebview2settings?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2Settings.IsReputationCheckingRequired Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isreputationcheckingrequired?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) + * [CoreWebView2Settings.IsReputationCheckingRequired Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isreputationcheckingrequired?view=webview2-dotnet-1.0.1724-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2Settings Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true) - * [CoreWebView2Settings.IsReputationCheckingRequired Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#isreputationcheckingrequired) + * [CoreWebView2Settings.IsReputationCheckingRequired Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.1724-prerelease&preserve-view=true#isreputationcheckingrequired) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2Settings8 interface](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1724-prerelease&preserve-view=true) - * [ICoreWebView2Settings8::get_IsReputationCheckingRequired](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1724-prerelease&preserve-view=true#get_isreputationcheckingrequired) - * [ICoreWebView2Settings8::put_IsReputationCheckingRequired](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1724-prerelease&preserve-view=true#put_isreputationcheckingrequired) +* [ICoreWebView2Settings8](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1724-prerelease&preserve-view=true) + * [ICoreWebView2Settings8::get_IsReputationCheckingRequired](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1724-prerelease&preserve-view=true#get_isreputationcheckingrequired) + * [ICoreWebView2Settings8::put_IsReputationCheckingRequired](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1724-prerelease&preserve-view=true#put_isreputationcheckingrequired) --- -###### Bug fixes +#### Bug fixes * Fixed a bug in `PrintAsync` and `PrintToPdfStreamAsync` that throws an exception when print settings are null. + * Improved handling of apps running elevated. (Runtime-only) -* Added support for window management permission kind. (SDK and Runtime) + +* Added support for window management permission kind. (Runtime and SDK) + * Reliability improvement. (Runtime-only) + + -## 1.0.1587.40 +## Release SDK 1.0.1722.45, for Runtime 112 (Apr. 13, 2023) -Release Date: February 15, 2023 +Release Date: Apr. 13, 2023 -[NuGet package for WebView2 SDK 1.0.1587.40](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1587.40) +[NuGet package for WebView2 SDK 1.0.1722.45](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1722.45) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 112.0.1722.45 or higher. -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 110.0.1587.40 or higher. + + +#### SDK 1.0.1722.32 is deprecated + +WebView2 SDK 1.0.1722.32 is deprecated, and that package has been removed from the listing at NuGet. Discontinue development with package 1.0.1722.32. If your WebView2 app uses that package, we recommend that you move to a newer package, such as WebView2 SDK 1.0.1722.45 or later. -#### General +#### Promotions to Phase 3 (Stable in Release) +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. - -###### Promotions -The following APIs have been promoted to Stable and are now included in this Release SDK. + +* The Managing SmartScreen API controls whether SmartScreen is enabled. + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2Settings` + * [CoreWebView2Settings.IsReputationCheckingRequired Property](/dotnet/api/microsoft.web.webview2.core.corewebview2settings.isreputationcheckingrequired?view=webview2-dotnet-1.0.1722.45&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2Settings` + * [CoreWebView2Settings.IsReputationCheckingRequired Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2settings?view=webview2-winrt-1.0.1722.45&preserve-view=true#isreputationcheckingrequired) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Settings8](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1722.45&preserve-view=true) + * [ICoreWebView2Settings8::get_IsReputationCheckingRequired](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1722.45&preserve-view=true#get_isreputationcheckingrequired) + * [ICoreWebView2Settings8::put_IsReputationCheckingRequired](/microsoft-edge/webview2/reference/win32/icorewebview2settings8?view=webview2-1.0.1722.45&preserve-view=true#put_isreputationcheckingrequired) + +--- -* Additional options used to create a WebView2 Environment to manage custom scheme registration: +* The `PermissionKind.WindowManagement` API indicates the kind of a permission request. ##### [.NET/C#](#tab/dotnetcsharp) -* [CoreWebView2CustomSchemeRegistration Class](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration?view=webview2-dotnet-1.0.1587.40&preserve-view=true) -* [CoreWebView2EnvironmentOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions?view=webview2-dotnet-1.0.1587.40&preserve-view=true) - * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.customschemeregistrations?view=webview2-dotnet-1.0.1587.40&preserve-view=true) +* `CoreWebView2PermissionKind` Enum + * [CoreWebView2PermissionKind.WindowManagement Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.1722.45&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* [CoreWebView2CustomSchemeRegistration Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2customschemeregistration?view=webview2-winrt-1.0.1587.40&preserve-view=true) -* [CoreWebView2EnvironmentOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1587.40&preserve-view=true) +* `CoreWebView2PermissionKind` Enum + * [CoreWebView2PermissionKind.WindowManagement Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.1722.45&preserve-view=true) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2CustomSchemeRegistration interface](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true) - * [ICoreWebView2CustomSchemeRegistration::GetAllowedOrigins method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#getallowedorigins) - * [ICoreWebView2CustomSchemeRegistration::SetAllowedOrigins method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#setallowedorigins) - * [ICoreWebView2CustomSchemeRegistration::get_HasAuthorityComponent method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#get_hasauthoritycomponent) - * [ICoreWebView2CustomSchemeRegistration::put_HasAuthorityComponent method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#put_hasauthoritycomponent) - * [ICoreWebView2CustomSchemeRegistration::get_SchemeName method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#get_schemename) - * [ICoreWebView2CustomSchemeRegistration::get_TreatAsSecure method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#get_treatassecure) - * [ICoreWebView2CustomSchemeRegistration::put_TreatAsSecure method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#put_treatassecure) -* [ICoreWebView2EnvironmentOptions4 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1587.40&preserve-view=true) - * [ICoreWebView2EnvironmentOptions4::GetCustomSchemeRegistrations method](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1587.40&preserve-view=true#getcustomschemeregistrations) - * [ICoreWebView2EnvironmentOptions4::SetCustomSchemeRegistrations method](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1587.40&preserve-view=true#setcustomschemeregistrations) +* `COREWEBVIEW2_PERMISSION_KIND` Enum + * [COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1722.45&preserve-view=true#corewebview2_permission_kind) --- + + -## 1.0.1671-prerelease +## Prerelease SDK 1.0.1671-prerelease, for Runtime 112 (Feb. 15, 2023) -Release Date: February 15, 2023 +Release Date: Feb. 15, 2023 [NuGet package for WebView2 SDK 1.0.1671-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1671-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 112.0.1671.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 112.0.1671.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) +The following Experimental APIs have been added in this Prerelease SDK. - -###### Experimental features + * Added support for the Experimental File API: ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2File Class](/dotnet/api/microsoft.web.webview2.core.corewebview2file?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2File.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2file.path?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2File.Path Property](/dotnet/api/microsoft.web.webview2.core.corewebview2file.path?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) * [CoreWebView2WebMessageReceivedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2webmessagereceivedeventargs?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2File Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2File.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#path) + * [CoreWebView2File.Path Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2file?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#path) * [CoreWebView2WebMessageReceivedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webmessagereceivedeventargs?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalFile interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfile?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalFile::get_Path method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfile?view=webview2-1.0.1671-prerelease&preserve-view=true#get_path) -* [ICoreWebView2ExperimentalWebMessageReceivedEventArgs interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebmessagereceivedeventargs?view=webview2-1.0.1671-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalFile](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfile?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalFile::get_Path](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalfile?view=webview2-1.0.1671-prerelease&preserve-view=true#get_path) +* [ICoreWebView2ExperimentalWebMessageReceivedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebmessagereceivedeventargs?view=webview2-1.0.1671-prerelease&preserve-view=true) Also added support for Experimental Object Collection View API: -* [ICoreWebView2ExperimentalObjectCollectionView interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalObjectCollectionView::get_Count method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#get_count) - * [ICoreWebView2ExperimentalObjectCollectionView::GetValueAtIndex method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#getvalueatindex) +* [ICoreWebView2ExperimentalObjectCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalObjectCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalObjectCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalobjectcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#getvalueatindex) The above interface is currently being used for: -* [ICoreWebView2ExperimentalWebMessageReceivedEventArgs::get_AdditionalObjects method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebmessagereceivedeventargs?view=webview2-1.0.1671-prerelease&preserve-view=true#get_additionalobjects) +* [ICoreWebView2ExperimentalWebMessageReceivedEventArgs::get_AdditionalObjects](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebmessagereceivedeventargs?view=webview2-1.0.1671-prerelease&preserve-view=true#get_additionalobjects) --- - -###### Promotions + +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. @@ -1389,46 +8369,46 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2 Class](/dotnet/api/microsoft.web.webview2.core.corewebview2?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postsharedbuffertoscript?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postsharedbuffertoscript?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) * [CoreWebView2Environment Class](/dotnet/api/microsoft.web.webview2.core.corewebview2environment?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2Environment.CreateSharedBuffer Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createsharedbuffer?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2Environment.CreateSharedBuffer Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createsharedbuffer?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) * [CoreWebView2Frame Class](/dotnet/api/microsoft.web.webview2.core.corewebview2frame?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2Frame.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.postsharedbuffertoscript?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2Frame.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.postsharedbuffertoscript?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) * [CoreWebView2SharedBuffer Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2SharedBuffer.Buffer Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.buffer?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2SharedBuffer.FileMappingHandle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.filemappinghandle?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2SharedBuffer.Size Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.size?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2SharedBuffer.Close Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.close?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2SharedBuffer.OpenStream Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.openstream?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2SharedBuffer.Buffer Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.buffer?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2SharedBuffer.FileMappingHandle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.filemappinghandle?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2SharedBuffer.Size Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.size?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2SharedBuffer.Close Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.close?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2SharedBuffer.OpenStream Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.openstream?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2 Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) + * [CoreWebView2.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) * [CoreWebView2Environment Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2Environment.CreateSharedBuffer Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#createsharedbuffer) + * [ICoreWebView2Environment.CreateSharedBuffer Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#createsharedbuffer) * [CoreWebView2Frame Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2Frame.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) + * [CoreWebView2Frame.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) * [CoreWebView2SharedBuffer Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2SharedBuffer.Buffer Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#buffer) - * [CoreWebView2SharedBuffer.Size Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#size) - * [CoreWebView2SharedBuffer.Close Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#close) - * [CoreWebView2SharedBuffer.OpenStream Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#openstream) + * [CoreWebView2SharedBuffer.Buffer Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#buffer) + * [CoreWebView2SharedBuffer.Size Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#size) + * [CoreWebView2SharedBuffer.Close Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#close) + * [CoreWebView2SharedBuffer.OpenStream Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#openstream) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2_17 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2_17::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) -* [ICoreWebView2Environment12 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2Environment12::CreateSharedBuffer method](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1671-prerelease&preserve-view=true#createsharedbuffer) -* [ICoreWebView2Frame4 interface](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2Frame4::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) -* [ICoreWebView2SharedBuffer interface](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2SharedBuffer::OpenStream method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#openstream) - * [ICoreWebView2SharedBuffer::Close method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#close) - * [ICoreWebView2SharedBuffer::get_Size method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#get_size) - * [ICoreWebView2SharedBuffer::get_Buffer method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#get_buffer) - * [ICoreWebView2SharedBuffer::get_FileMappingHandle method](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#get_filemappinghandle) +* [ICoreWebView2_17](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2_17::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) +* [ICoreWebView2Environment12](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2Environment12::CreateSharedBuffer](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1671-prerelease&preserve-view=true#createsharedbuffer) +* [ICoreWebView2Frame4](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2Frame4::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1671-prerelease&preserve-view=true#postsharedbuffertoscript) +* [ICoreWebView2SharedBuffer](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2SharedBuffer::OpenStream](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#openstream) + * [ICoreWebView2SharedBuffer::Close](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#close) + * [ICoreWebView2SharedBuffer::get_Size](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#get_size) + * [ICoreWebView2SharedBuffer::get_Buffer](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#get_buffer) + * [ICoreWebView2SharedBuffer::get_FileMappingHandle](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1671-prerelease&preserve-view=true#get_filemappinghandle) --- @@ -1439,37 +8419,37 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2PermissionSetting Class](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionkind?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionorigin?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionstate?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionkind?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionorigin?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionstate?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) * [CoreWebView2Profile Class](/dotnet/api/microsoft.web.webview2.core.corewebview2profile?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getnondefaultpermissionsettingsasync?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getnondefaultpermissionsettingsasync?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2PermissionSetting Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#permissionkind) - * [CoreWebView2PermissionSetting.PermissionOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#permissionorigin) - * [CoreWebView2PermissionSetting.PermissionState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#permissionstate) + * [CoreWebView2PermissionSetting.PermissionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#permissionkind) + * [CoreWebView2PermissionSetting.PermissionOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#permissionorigin) + * [CoreWebView2PermissionSetting.PermissionState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#permissionstate) * [CoreWebView2Profile Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#getnondefaultpermissionsettingsasync) - * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#setpermissionstateasync) + * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#getnondefaultpermissionsettingsasync) + * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#setpermissionstateasync) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2getnondefaultpermissionsettingscompletedhandler?view=webview2-1.0.1671-prerelease&preserve-view=true) -* [ICoreWebView2PermissionSetting interface](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2PermissionSetting::get_PermissionKind method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true#get_permissionkind) - * [ICoreWebView2PermissionSetting::get_PermissionOrigin method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true#get_permissionorigin) - * [ICoreWebView2PermissionSetting::get_PermissionState method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true#get_permissionstate) -* [ICoreWebView2PermissionSettingCollectionView interface](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2PermissionSettingCollectionView::GetValueAtIndex method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#getvalueatindex) - * [ICoreWebView2PermissionSettingCollectionView::get_Count method](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#get_count) -* [ICoreWebView2Profile4 interface](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2Profile4::SetPermissionState method](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1671-prerelease&preserve-view=true#setpermissionstate) - * [ICoreWebView2Profile4::GetNonDefaultPermissionSettings method](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1671-prerelease&preserve-view=true#getnondefaultpermissionsettings) -* [ICoreWebView2SetPermissionStateCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2setpermissionstatecompletedhandler?view=webview2-1.0.1671-prerelease&preserve-view=true) +* [ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2getnondefaultpermissionsettingscompletedhandler?view=webview2-1.0.1671-prerelease&preserve-view=true) +* [ICoreWebView2PermissionSetting](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2PermissionSetting::get_PermissionKind](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true#get_permissionkind) + * [ICoreWebView2PermissionSetting::get_PermissionOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true#get_permissionorigin) + * [ICoreWebView2PermissionSetting::get_PermissionState](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1671-prerelease&preserve-view=true#get_permissionstate) +* [ICoreWebView2PermissionSettingCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2PermissionSettingCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#getvalueatindex) + * [ICoreWebView2PermissionSettingCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1671-prerelease&preserve-view=true#get_count) +* [ICoreWebView2Profile4](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2Profile4::SetPermissionState](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1671-prerelease&preserve-view=true#setpermissionstate) + * [ICoreWebView2Profile4::GetNonDefaultPermissionSettings](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1671-prerelease&preserve-view=true#getnondefaultpermissionsettings) +* [ICoreWebView2SetPermissionStateCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2setpermissionstatecompletedhandler?view=webview2-1.0.1671-prerelease&preserve-view=true) --- @@ -1480,7 +8460,7 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2ControllerOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2ControllerOptions.ScriptLocale Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.scriptlocale?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) + * [CoreWebView2ControllerOptions.ScriptLocale Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.scriptlocale?view=webview2-dotnet-1.0.1671-prerelease&preserve-view=true) Previous name in 1619-prerelease: * [CoreWebView2ControllerOptions.LocaleRegion Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.localeregion?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) @@ -1488,149 +8468,290 @@ Previous name in 1619-prerelease: ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2ControllerOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true) - * [CoreWebView2ControllerOptions.ScriptLocale Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#scriptlocale) + * [CoreWebView2ControllerOptions.ScriptLocale Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.1671-prerelease&preserve-view=true#scriptlocale) Previous name in 1619-prerelease: * [CoreWebView2ControllerOptions.LocaleRegion Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#localeregion) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ControllerOptions2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1671-prerelease&preserve-view=true) - * [ICoreWebView2ControllerOptions2::get_ScriptLocale method](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1671-prerelease&preserve-view=true#get_scriptlocale) - * [ICoreWebView2ControllerOptions2::put_ScriptLocale method](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1671-prerelease&preserve-view=true#put_scriptlocale) +* [ICoreWebView2ControllerOptions2](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1671-prerelease&preserve-view=true) + * [ICoreWebView2ControllerOptions2::get_ScriptLocale](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1671-prerelease&preserve-view=true#get_scriptlocale) + * [ICoreWebView2ControllerOptions2::put_ScriptLocale](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1671-prerelease&preserve-view=true#put_scriptlocale) Previous name in 1619-prerelease: -* [ICoreWebView2ExperimentalControllerOptions::get_LocaleRegion method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1619-prerelease&preserve-view=true#get_localeregion) -* [ICoreWebView2ExperimentalControllerOptions::put_LocaleRegion method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1619-prerelease&preserve-view=true#put_localeregion) +* [ICoreWebView2ExperimentalControllerOptions::get_LocaleRegion](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1619-prerelease&preserve-view=true#get_localeregion) +* [ICoreWebView2ExperimentalControllerOptions::put_LocaleRegion](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1619-prerelease&preserve-view=true#put_localeregion) --- - -###### Bug fixes + +#### Bug fixes * Fixed a bug where WebView2 was not closing properly when a `BeforeUnload` event was received. (Runtime-only) ([Issue #2677](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2677)) + * In the `DownloadStarting` event, the `ResultFilePath` previously wasn't showing the correct download location for UWP applications when the `DownloadStarting` event handler was attached. This has been fixed; the correct `ResultFilePath` is now shown. + * Fixed a bug where `System.ArgumentException` was thrown when a call to the `HostObject` method returns a non-generic task. ([Issue #2787](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2787)) + * Fixed an issue in the `SharedBuffer` API where the stream object didn't work well with `StreamWriter`. (Runtime-only) ([Issue #3108](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3108)) + * DOM speech-synthesis APIs, such as `SpeechSynthesis.getVoices()`, will now work in UWP apps. (Runtime-only) + * Fixed a crash that occurred on frame destruction. (Runtime-only) ([Issue #3062](https://github.com/MicrosoftEdge/WebView2Feedback/issues/3062)) + * Fixed a bug where the app crashes when trying to call `CreateWebResourceResponse` with a `null` `reason` phrase. (Runtime-only) + * The `CoreWebView2.AddHostObjectToScript` option `chrome.webview.hostObjects.options.ignoreMemberNotFoundError` now works in non-English locales. (Runtime-only) + * Fully enabled **Open file** dialog support for elevated apps on Windows 7. + * Fixed a bug where owned windows were not appearing for UWP. + + -## 1.0.1518.46 +## Release SDK 1.0.1661.34, for Runtime 111 (Mar. 20, 2023) -Release Date: January 17, 2023 +Release Date: Mar. 20, 2023 -[NuGet package for WebView2 SDK 1.0.1518.46](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1518.46) +[NuGet package for WebView2 SDK 1.0.1661.34](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1661.34) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 109.0.1518.46 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 111.0.1661.34 or higher. -#### General +#### Promotions to Phase 3 (Stable in Release) +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. - -###### Promotions -The following APIs have been promoted to Stable and are now included in this Release SDK. + +* The SharedBuffer API: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2` Class + * [CoreWebView2.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.postsharedbuffertoscript?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* `CoreWebView2Environment` Class + * [ICoreWebView2Environment.CreateSharedBuffer Method](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.createsharedbuffer?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* `CoreWebView2Frame` Class + * [CoreWebView2Frame.PostSharedBufferToScript Method](/dotnet/api/microsoft.web.webview2.core.corewebview2frame.postsharedbuffertoscript?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* [CoreWebView2SharedBuffer Class](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.Buffer Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.buffer?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.FileMappingHandle Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.filemappinghandle?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.Size Property](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.size?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.Close Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.close?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.Dispose Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.dispose?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.OpenStream Method](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbuffer.openstream?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* [CoreWebView2SharedBufferAccess Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2sharedbufferaccess?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2` Class + * [CoreWebView2.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) + +* `CoreWebView2Environment` Class + * [ICoreWebView2Environment.CreateSharedBuffer Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1661.34&preserve-view=true#createsharedbuffer) + +* `CoreWebView2Frame` Class + * [CoreWebView2Frame.PostSharedBufferToScript Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2frame?view=webview2-winrt-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) + +* [CoreWebView2SharedBuffer Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true) + * [CoreWebView2SharedBuffer.Buffer Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#buffer) + * [CoreWebView2SharedBuffer.Size Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#size) + * [CoreWebView2SharedBuffer.Close Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#close) + * [CoreWebView2SharedBuffer.OpenStream Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbuffer?view=webview2-winrt-1.0.1661.34&preserve-view=true#openstream) + +* [CoreWebView2SharedBufferAccess Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2sharedbufferaccess?view=webview2-winrt-1.0.1661.34&preserve-view=true) + * `ReadOnly` + * `ReadWrite` + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_17](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2_17::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2_17?view=webview2-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) + +* [ICoreWebView2Environment12](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2Environment12::CreateSharedBuffer](/microsoft-edge/webview2/reference/win32/icorewebview2environment12?view=webview2-1.0.1661.34&preserve-view=true#createsharedbuffer) + +* [ICoreWebView2Frame4](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2Frame4::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2frame4?view=webview2-1.0.1661.34&preserve-view=true#postsharedbuffertoscript) + +* [ICoreWebView2SharedBuffer](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2SharedBuffer::OpenStream](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#openstream) + * [ICoreWebView2SharedBuffer::Close](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#close) + * [ICoreWebView2SharedBuffer::get_Size](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#get_size) + * [ICoreWebView2SharedBuffer::get_Buffer](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#get_buffer) + * [ICoreWebView2SharedBuffer::get_FileMappingHandle](/microsoft-edge/webview2/reference/win32/icorewebview2sharedbuffer?view=webview2-1.0.1661.34&preserve-view=true#get_filemappinghandle) + +* [COREWEBVIEW2_SHARED_BUFFER_ACCESS enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1661.34&preserve-view=true#corewebview2_shared_buffer_access) + * `COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY` + * `COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_WRITE` + +--- -* The Print API: +* APIs for managing permissions: ##### [.NET/C#](#tab/dotnetcsharp) -* [CoreWebView2.PrintAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.printasync?view=webview2-dotnet-1.0.1518.46&preserve-view=true) -* [CoreWebView2.PrintToPdfStreamAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.printtopdfstreamasync?view=webview2-dotnet-1.0.1518.46&preserve-view=true) -* [CoreWebView2.ShowPrintUI Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showprintui?view=webview2-dotnet-1.0.1518.46&preserve-view=true) -* [CoreWebView2PrintSettings Class](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.Collation Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.collation?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.ColorMode Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.colormode?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.Copies Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.copies?view=webview2-dotnet-1.0.1518.46&preserve-view=true#microsoft-web-webview2-core-corewebview2printsettings-copies) - * [CoreWebView2PrintSettings.Duplex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.duplex?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.MediaSize Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.mediasize?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.PageRanges Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pageranges?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.PagesPerSide Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pagesperside?view=webview2-dotnet-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.PrinterName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.printername?view=webview2-dotnet-1.0.1518.46&preserve-view=true) +* `CoreWebView2PermissionKind` Enum + * [CoreWebView2PermissionKind.MidiSystemExclusiveMessages Enum Value](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* `CoreWebView2PermissionRequestedEventArgs` Event + * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionrequestedeventargs.savesinprofile?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* [CoreWebView2PermissionSetting Class](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionkind?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionorigin?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionstate?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getnondefaultpermissionsettingsasync?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.1661.34&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* [CoreWebView2.PrintAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1518.46&preserve-view=true#printasync) -* [CoreWebView2.PrintToPdfStreamAsync](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1518.46&preserve-view=true#printtopdfstreamasync) -* [CoreWebView2.ShowPrintUI Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1518.46&preserve-view=true#showprintui) -* [CoreWebView2PrintSettings Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true) - * [CoreWebView2PrintSettings.Collation Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#collation) - * [CoreWebView2PrintSettings.ColorMode Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#colormode) - * [CoreWebView2PrintSettings.Copies Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#copies) - * [CoreWebView2PrintSettings.Duplex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#duplex) - * [CoreWebView2PrintSettings.MediaSize Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#mediasize) - * [CoreWebView2PrintSettings.PageRanges Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#pageranges) - * [CoreWebView2PrintSettings.PagesPerSide Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#pagesperside) - * [CoreWebView2PrintSettings.PrinterName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#printername) +* `CoreWebView2PermissionKind` Enum + * [CoreWebView2PermissionKind.MidiSystemExclusiveMessages Enum Value](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.1661.34&preserve-view=true) + +* `CoreWebView2PermissionRequestedEventArgs` Event + * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionrequestedeventargs?view=webview2-winrt-1.0.1661.34&preserve-view=true#savesinprofile) + +* [CoreWebView2PermissionSetting Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true#permissionkind) + * [CoreWebView2PermissionSetting.PermissionOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true#permissionorigin) + * [CoreWebView2PermissionSetting.PermissionState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1661.34&preserve-view=true#permissionstate) + +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1661.34&preserve-view=true#getnondefaultpermissionsettingsasync) + * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1661.34&preserve-view=true#setpermissionstateasync) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2_16 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true) - * [ICoreWebView2_16::Print method](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true#print) - * [ICoreWebView2_16::PrintToPdfStream method](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true#printtopdfstream) - * [ICoreWebView2_16::ShowPrintUI method](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true#showprintui) -* [ICoreWebView2PrintCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2printcompletedhandler?view=webview2-1.0.1518.46&preserve-view=true) -* [ICoreWebView2PrintToPdfStreamCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2printtopdfstreamcompletedhandler?view=webview2-1.0.1518.46&preserve-view=true) -* [ICoreWebView2PrintSettings2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true) - * [ICoreWebView2PrintSettings2::Collation property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_collation), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_collation) - * [ICoreWebView2PrintSettings2::ColorMode property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_colormode), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_colormode) - * [ICoreWebView2PrintSettings2::Copies property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_copies), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_copies) - * [ICoreWebView2PrintSettings2::Duplex property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_duplex), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_duplex) - * [ICoreWebView2PrintSettings2::MediaSize property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_mediasize), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_mediasize) - * [ICoreWebView2PrintSettings2::PageRanges property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_pageranges), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_pageranges) - * [ICoreWebView2PrintSettings2::PagesPerSide property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_pagesperside), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_pagesperside) - * [ICoreWebView2PrintSettings2::PrinterName property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_printername), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_printername) +* [ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2getnondefaultpermissionsettingscompletedhandler?view=webview2-1.0.1661.34&preserve-view=true) + +* [ICoreWebView2PermissionRequestedEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs3?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2PermissionRequestedEventArgs3::get_SavesInProfile](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs3?view=webview2-1.0.1661.34&preserve-view=true#get_savesinprofile) + * [ICoreWebView2PermissionRequestedEventArgs3::put_SavesInProfile](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs3?view=webview2-1.0.1661.34&preserve-view=true#put_savesinprofile) + +* [ICoreWebView2PermissionSetting](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2PermissionSetting::get_PermissionKind](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true#get_permissionkind) + * [ICoreWebView2PermissionSetting::get_PermissionOrigin](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true#get_permissionorigin) + * [ICoreWebView2PermissionSetting::get_PermissionState](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsetting?view=webview2-1.0.1661.34&preserve-view=true#get_permissionstate) + +* [ICoreWebView2PermissionSettingCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2PermissionSettingCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1661.34&preserve-view=true#getvalueatindex) + * [ICoreWebView2PermissionSettingCollectionView::get_Count](/microsoft-edge/webview2/reference/win32/icorewebview2permissionsettingcollectionview?view=webview2-1.0.1661.34&preserve-view=true#get_count) + +* [ICoreWebView2Profile4](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2Profile4::GetNonDefaultPermissionSettings](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1661.34&preserve-view=true#getnondefaultpermissionsettings) + * [ICoreWebView2Profile4::SetPermissionState](/microsoft-edge/webview2/reference/win32/icorewebview2profile4?view=webview2-1.0.1661.34&preserve-view=true#setpermissionstate) + +* [ICoreWebView2SetPermissionStateCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2setpermissionstatecompletedhandler?view=webview2-1.0.1661.34&preserve-view=true) + +* `COREWEBVIEW2_PERMISSION_KIND` enum: + * [COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGES enum value](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1661.34&preserve-view=true#corewebview2_permission_kind) --- -* The Custom Crash Reporting API: +* APIs for managing tracking prevention: ##### [.NET/C#](#tab/dotnetcsharp) -* [CoreWebView2EnvironmentOptions.IsCustomCrashReportingEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.iscustomcrashreportingenabled?view=webview2-dotnet-1.0.1518.46&preserve-view=true) -* [CoreWebView2Environment.FailureReportFolderPath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.failurereportfolderpath?view=webview2-dotnet-1.0.1518.46&preserve-view=true#microsoft-web-webview2-core-corewebview2environment-failurereportfolderpath) +* `CoreWebView2EnvironmentOptions` Class + * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.enabletrackingprevention?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.preferredtrackingpreventionlevel?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +* [CoreWebView2TrackingPreventionLevel Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2trackingpreventionlevel?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + * `None` + * `Basic` + * `Balanced` + * `Strict` ##### [WinRT/C#](#tab/winrtcsharp) -* [CoreWebView2EnvironmentOptions.IsCustomCrashReportingEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1518.46&preserve-view=true#iscustomcrashreportingenabled) -* [CoreWebView2Environment.FailureReportFolderPath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1518.46&preserve-view=true#failurereportfolderpath) +* `CoreWebView2EnvironmentOptions` Class + * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1661.34&preserve-view=true#enabletrackingprevention) + +* `CoreWebView2Profile` Class + * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1661.34&preserve-view=true#preferredtrackingpreventionlevel) + +* [CoreWebView2TrackingPreventionLevel Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2trackingpreventionlevel?view=webview2-winrt-1.0.1661.34&preserve-view=true) + * `None` + * `Basic` + * `Balanced` + * `Strict` ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2EnvironmentOptions3::IsCustomCrashReportingEnabled property (get](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions3?view=webview2-1.0.1518.46&preserve-view=true#get_iscustomcrashreportingenabled), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions3?view=webview2-1.0.1518.46&preserve-view=true#put_iscustomcrashreportingenabled) -* [ICoreWebView2Environment11::FailureReportFolderPath property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2environment11?view=webview2-1.0.1518.46&preserve-view=true#get_failurereportfolderpath) +* [ICoreWebView2EnvironmentOptions5](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention property (get](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1661.34&preserve-view=true#get_enabletrackingprevention), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1661.34&preserve-view=true#put_enabletrackingprevention) + +* [ICoreWebView2Profile3](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2Profile3::PreferredTrackingPreventionLevel property (get](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1661.34&preserve-view=true#get_preferredtrackingpreventionlevel), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1661.34&preserve-view=true#put_preferredtrackingpreventionlevel) + +* [COREWEBVIEW2_TRACKING_PREVENTION_LEVEL enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1661.34&preserve-view=true#corewebview2_tracking_prevention_level) + * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE` + * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BASIC` + * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BALANCED` + * `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_STRICT` + +--- + + + +* APIs to manage the value of the controller's script locale: + +##### [.NET/C#](#tab/dotnetcsharp) + +* `CoreWebView2ControllerOptions` Class + * [CoreWebView2ControllerOptions.ScriptLocale Property](/dotnet/api/microsoft.web.webview2.core.corewebview2controlleroptions.scriptlocale?view=webview2-dotnet-1.0.1661.34&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* `CoreWebView2ControllerOptions` Class + * [CoreWebView2ControllerOptions.ScriptLocale Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2controlleroptions?view=webview2-winrt-1.0.1661.34&preserve-view=true#scriptlocale) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ControllerOptions2](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1661.34&preserve-view=true) + * [ICoreWebView2ControllerOptions2::get_ScriptLocale](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1661.34&preserve-view=true#get_scriptlocale) + * [ICoreWebView2ControllerOptions2::put_ScriptLocale](/microsoft-edge/webview2/reference/win32/icorewebview2controlleroptions2?view=webview2-1.0.1661.34&preserve-view=true#put_scriptlocale) --- + + -## 1.0.1619-prerelease +## Prerelease SDK 1.0.1619-prerelease, for Runtime 111 (Jan. 19, 2023) -Release Date: January 19, 2023 +Release Date: Jan. 19, 2023 [NuGet package for WebView2 SDK 1.0.1619-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1619-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 111.0.1619.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 111.0.1619.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) - -###### Experimental features +The following Experimental APIs have been added in this Prerelease SDK. @@ -1638,62 +8759,62 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [.NET/C#](#tab/dotnetcsharp) -* [CoreWebView2PermissionRequestedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionrequestedeventargs?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true&preserve-view=true) - * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionrequestedeventargs.savesinprofile?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) +* [CoreWebView2PermissionRequestedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionrequestedeventargs?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionrequestedeventargs.savesinprofile?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) * [CoreWebView2Profile Class](/dotnet/api/microsoft.web.webview2.core.corewebview2profile?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getnondefaultpermissionsettingsasync?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.getnondefaultpermissionsettingsasync?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2Profile.SetPermissionStateAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.setpermissionstateasync?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) * [CoreWebView2PermissionSetting Class](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionkind?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2PermissionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * `MultipleAutomaticDownloads` - * `FileReadWrite` - * `Autoplay` - * `LocalFonts` - * `MidiSystemExclusiveMessageAccess` - * [CoreWebView2PermissionSetting.PermissionOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionorigin?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionstate?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionKind Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionkind?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2PermissionKind Enum](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionkind?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * `MultipleAutomaticDownloads` + * `FileReadWrite` + * `Autoplay` + * `LocalFonts` + * `MidiSystemExclusiveMessageAccess` + * [CoreWebView2PermissionSetting.PermissionOrigin Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionorigin?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2PermissionSetting.PermissionState Property](/dotnet/api/microsoft.web.webview2.core.corewebview2permissionsetting.permissionstate?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2PermissionRequestedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionrequestedeventargs?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionrequestedeventargs?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#savesinprofile) + * [CoreWebView2PermissionRequestedEventArgs.SavesInProfile Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionrequestedeventargs?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#savesinprofile) * [CoreWebView2Profile Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#getnondefaultpermissionsettingsasync) - * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#setpermissionstateasync) + * [CoreWebView2Profile.GetNonDefaultPermissionSettingsAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#getnondefaultpermissionsettingsasync) + * [CoreWebView2Profile.SetPermissionStateAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#setpermissionstateasync) * [CoreWebView2PermissionSetting Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2PermissionSetting.PermissionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#permissionkind) - * [CoreWebView2PermissionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) - * `MultipleAutomaticDownloads` - * `FileReadWrite` - * `Autoplay` - * `LocalFonts` - * `MidiSystemExclusiveMessageAccess` - * [CoreWebView2PermissionSetting.PermissionOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#permissionorigin) - * [CoreWebView2PermissionSetting.PermissionState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#permissionstate) - -##### [Win32/C++](#tab/win32cpp) - -* [ICoreWebView2ExperimentalPermissionRequestedEventArgs3 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionrequestedeventargs3?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalPermissionRequestedEventArgs3::SavesInProfile property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionrequestedeventargs3?view=webview2-1.0.1619-prerelease&preserve-view=true#get_savesinprofile), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionrequestedeventargs3?view=webview2-1.0.1619-prerelease&preserve-view=true#put_savesinprofile) -* [ICoreWebView2ExperimentalSetPermissionStateCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsetpermissionstatecompletedhandler?view=webview2-1.0.1619-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgetnondefaultpermissionsettingscompletedhandler?view=webview2-1.0.1619-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalProfile6 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile6?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalProfile6::GetNonDefaultPermissionSettings method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile6?view=webview2-1.0.1619-prerelease&preserve-view=true#getnondefaultpermissionsettings) - * [ICoreWebView2ExperimentalProfile6::SetPermissionState method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile6?view=webview2-1.0.1619-prerelease&preserve-view=true#setpermissionstate) -* [ICoreWebView2ExperimentalPermissionSettingCollectionView interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsettingcollectionview?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalPermissionSettingCollectionView::Count property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsettingcollectionview?view=webview2-1.0.1619-prerelease&preserve-view=true#get_count) - * [ICoreWebView2ExperimentalPermissionSettingCollectionView::GetValueAtIndex method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsettingcollectionview?view=webview2-1.0.1619-prerelease&preserve-view=true#getvalueatindex) -* [ICoreWebView2ExperimentalPermissionSetting interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalPermissionSetting::PermissionKind property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true#get_permissionkind) - * [COREWEBVIEW2_PERMISSION_KIND Enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1619-prerelease&preserve-view=true#corewebview2_permission_kind) - * `COREWEBVIEW2_PERMISSION_KIND_MULTIPLE_AUTOMATIC_DOWNLOADS` - * `COREWEBVIEW2_PERMISSION_KIND_FILE_READ_WRITE` - * `COREWEBVIEW2_PERMISSION_KIND_AUTOPLAY` - * `COREWEBVIEW2_PERMISSION_KIND_LOCAL_FONTS` - * `COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGE_ACCESS` - * [ICoreWebView2ExperimentalPermissionSetting::PermissionOrigin property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true#get_permissionorigin) - * [ICoreWebView2ExperimentalPermissionSetting::PermissionState property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true#get_permissionstate) + * [CoreWebView2PermissionSetting.PermissionKind Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#permissionkind) + * [CoreWebView2PermissionKind Enum](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionkind?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) + * `MultipleAutomaticDownloads` + * `FileReadWrite` + * `Autoplay` + * `LocalFonts` + * `MidiSystemExclusiveMessageAccess` + * [CoreWebView2PermissionSetting.PermissionOrigin Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#permissionorigin) + * [CoreWebView2PermissionSetting.PermissionState Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2permissionsetting?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#permissionstate) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2ExperimentalPermissionRequestedEventArgs3](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionrequestedeventargs3?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalPermissionRequestedEventArgs3::SavesInProfile property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionrequestedeventargs3?view=webview2-1.0.1619-prerelease&preserve-view=true#get_savesinprofile), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionrequestedeventargs3?view=webview2-1.0.1619-prerelease&preserve-view=true#put_savesinprofile) +* [ICoreWebView2ExperimentalSetPermissionStateCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsetpermissionstatecompletedhandler?view=webview2-1.0.1619-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalGetNonDefaultPermissionSettingsCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalgetnondefaultpermissionsettingscompletedhandler?view=webview2-1.0.1619-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalProfile6](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile6?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile6::GetNonDefaultPermissionSettings](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile6?view=webview2-1.0.1619-prerelease&preserve-view=true#getnondefaultpermissionsettings) + * [ICoreWebView2ExperimentalProfile6::SetPermissionState](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile6?view=webview2-1.0.1619-prerelease&preserve-view=true#setpermissionstate) +* [ICoreWebView2ExperimentalPermissionSettingCollectionView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsettingcollectionview?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalPermissionSettingCollectionView::Count property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsettingcollectionview?view=webview2-1.0.1619-prerelease&preserve-view=true#get_count) + * [ICoreWebView2ExperimentalPermissionSettingCollectionView::GetValueAtIndex](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsettingcollectionview?view=webview2-1.0.1619-prerelease&preserve-view=true#getvalueatindex) +* [ICoreWebView2ExperimentalPermissionSetting](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalPermissionSetting::PermissionKind property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true#get_permissionkind) + * [COREWEBVIEW2_PERMISSION_KIND enum](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-1.0.1619-prerelease&preserve-view=true#corewebview2_permission_kind) + * `COREWEBVIEW2_PERMISSION_KIND_MULTIPLE_AUTOMATIC_DOWNLOADS` + * `COREWEBVIEW2_PERMISSION_KIND_FILE_READ_WRITE` + * `COREWEBVIEW2_PERMISSION_KIND_AUTOPLAY` + * `COREWEBVIEW2_PERMISSION_KIND_LOCAL_FONTS` + * `COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGE_ACCESS` + * [ICoreWebView2ExperimentalPermissionSetting::PermissionOrigin property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true#get_permissionorigin) + * [ICoreWebView2ExperimentalPermissionSetting::PermissionState property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpermissionsetting?view=webview2-1.0.1619-prerelease&preserve-view=true#get_permissionstate) --- @@ -1711,15 +8832,15 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalNavigationStartingEventArgs2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnavigationstartingeventargs2?view=webview2-1.0.1619-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalNavigationStartingEventArgs2](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnavigationstartingeventargs2?view=webview2-1.0.1619-prerelease&preserve-view=true) --- - -###### Promotions + +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. @@ -1728,7 +8849,7 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2EnvironmentOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.customschemeregistrations?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.customschemeregistrations?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) * [CoreWebView2CustomSchemeRegistration Class](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) @@ -1738,15 +8859,15 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2EnvironmentOptions4 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2EnvironmentOptions4::GetCustomSchemeRegistrations method](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1619-prerelease&preserve-view=true#getcustomschemeregistrations) - * [ICoreWebView2EnvironmentOptions4::SetCustomSchemeRegistrations method](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1619-prerelease&preserve-view=true#setcustomschemeregistrations) -* [ICoreWebView2CustomSchemeRegistration interface](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2CustomSchemeRegistration::GetAllowedOrigins method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#getallowedorigins) - * [ICoreWebView2CustomSchemeRegistration::SetAllowedOrigins method](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#setallowedorigins) - * [ICoreWebView2CustomSchemeRegistration::HasAuthorityComponent property (get](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#get_hasauthoritycomponent), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#put_hasauthoritycomponent) - * [ICoreWebView2CustomSchemeRegistration::SchemeName property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#get_schemename) - * [ICoreWebView2CustomSchemeRegistration::TreatAsSecure property (get](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#get_treatassecure), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#put_treatassecure) +* [ICoreWebView2EnvironmentOptions4](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2EnvironmentOptions4::GetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1619-prerelease&preserve-view=true#getcustomschemeregistrations) + * [ICoreWebView2EnvironmentOptions4::SetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1619-prerelease&preserve-view=true#setcustomschemeregistrations) +* [ICoreWebView2CustomSchemeRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2CustomSchemeRegistration::GetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#getallowedorigins) + * [ICoreWebView2CustomSchemeRegistration::SetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#setallowedorigins) + * [ICoreWebView2CustomSchemeRegistration::HasAuthorityComponent property (get](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#get_hasauthoritycomponent), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#put_hasauthoritycomponent) + * [ICoreWebView2CustomSchemeRegistration::SchemeName property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#get_schemename) + * [ICoreWebView2CustomSchemeRegistration::TreatAsSecure property (get](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#get_treatassecure), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1619-prerelease&preserve-view=true#put_treatassecure) --- @@ -1757,72 +8878,115 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2EnvironmentOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.enabletrackingprevention?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.enabletrackingprevention?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) * [CoreWebView2Profile Class](/dotnet/api/microsoft.web.webview2.core.corewebview2profile?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.preferredtrackingpreventionlevel?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) + * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/dotnet/api/microsoft.web.webview2.core.corewebview2profile.preferredtrackingpreventionlevel?view=webview2-dotnet-1.0.1619-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2EnvironmentOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#enabletrackingprevention) + * [CoreWebView2EnvironmentOptions.EnableTrackingPrevention Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#enabletrackingprevention) * [CoreWebView2Profile Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true) - * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#preferredtrackingpreventionlevel) + * [CoreWebView2Profile.PreferredTrackingPreventionLevel Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2profile?view=webview2-winrt-1.0.1619-prerelease&preserve-view=true#preferredtrackingpreventionlevel) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2EnvironmentOptions5 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention property (get](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1619-prerelease&preserve-view=true#get_enabletrackingprevention), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1619-prerelease&preserve-view=true#put_enabletrackingprevention) -* [ICoreWebView2Profile3 interface](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1619-prerelease&preserve-view=true) - * [ICoreWebView2Profile3::PreferredTrackingPreventionLevel property (get](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1619-prerelease&preserve-view=true#get_preferredtrackingpreventionlevel), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1619-prerelease&preserve-view=true#put_preferredtrackingpreventionlevel) +* [ICoreWebView2EnvironmentOptions5](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention property (get](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1619-prerelease&preserve-view=true#get_enabletrackingprevention), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions5?view=webview2-1.0.1619-prerelease&preserve-view=true#put_enabletrackingprevention) +* [ICoreWebView2Profile3](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1619-prerelease&preserve-view=true) + * [ICoreWebView2Profile3::PreferredTrackingPreventionLevel property (get](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1619-prerelease&preserve-view=true#get_preferredtrackingpreventionlevel), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2profile3?view=webview2-1.0.1619-prerelease&preserve-view=true#put_preferredtrackingpreventionlevel) --- - -###### Bug fixes + +#### Bug fixes * Disabled **Open link as Profile** in the WebView2 context menu. + * Fixed post data missing in form submit with Ctrl-click. ([Issue #2652](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2652)) + * Fixed a bug where the user is not able to get the custom context menu on PDF Viewer. ([Issue #2607](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2607)) + * Fixed a bug where the entire toolbar is blank when simultaneously hiding the **Bookmarks**, **Search**, and **PageSelector** buttons. ([Issue #2866](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2866)) + * Fixed a bug where the app crashes when trying to move focus to WebView2 when it is disabled. + * Fixed drag and drop within the WebView2 for composition-hosted WebViews. -* Removed read-aloud icon in address bar in a WebView2 popup window. + +* Removed read-aloud icon in Address bar in a WebView2 popup window. + * Fixed unexpected items in the context menu of popup windows in WebView2. + + + + +## Release SDK 1.0.1587.40, for Runtime 110 (Feb. 15, 2023) + +Release Date: Feb. 15, 2023 + +[NuGet package for WebView2 SDK 1.0.1587.40](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1587.40) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 110.0.1587.40 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* Additional options used to create a WebView2 Environment to manage custom scheme registration: + +##### [.NET/C#](#tab/dotnetcsharp) - -## 1.0.1462.37 +* [CoreWebView2CustomSchemeRegistration Class](/dotnet/api/microsoft.web.webview2.core.corewebview2customschemeregistration?view=webview2-dotnet-1.0.1587.40&preserve-view=true) +* [CoreWebView2EnvironmentOptions Class](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions?view=webview2-dotnet-1.0.1587.40&preserve-view=true) + * [CoreWebView2EnvironmentOptions.CustomSchemeRegistrations Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.customschemeregistrations?view=webview2-dotnet-1.0.1587.40&preserve-view=true) -Release Date: December 12, 2022 +##### [WinRT/C#](#tab/winrtcsharp) -[NuGet package for WebView2 SDK 1.0.1462.37](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1462.37) +* [CoreWebView2CustomSchemeRegistration Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2customschemeregistration?view=webview2-winrt-1.0.1587.40&preserve-view=true) +* [CoreWebView2EnvironmentOptions Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1587.40&preserve-view=true) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 108.0.1462.37 or higher. +##### [Win32/C++](#tab/win32cpp) +* [ICoreWebView2CustomSchemeRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true) + * [ICoreWebView2CustomSchemeRegistration::GetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#getallowedorigins) + * [ICoreWebView2CustomSchemeRegistration::SetAllowedOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#setallowedorigins) + * [ICoreWebView2CustomSchemeRegistration::get_HasAuthorityComponent](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#get_hasauthoritycomponent) + * [ICoreWebView2CustomSchemeRegistration::put_HasAuthorityComponent](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#put_hasauthoritycomponent) + * [ICoreWebView2CustomSchemeRegistration::get_SchemeName](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#get_schemename) + * [ICoreWebView2CustomSchemeRegistration::get_TreatAsSecure](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#get_treatassecure) + * [ICoreWebView2CustomSchemeRegistration::put_TreatAsSecure](/microsoft-edge/webview2/reference/win32/icorewebview2customschemeregistration?view=webview2-1.0.1587.40&preserve-view=true#put_treatassecure) +* [ICoreWebView2EnvironmentOptions4](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1587.40&preserve-view=true) + * [ICoreWebView2EnvironmentOptions4::GetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1587.40&preserve-view=true#getcustomschemeregistrations) + * [ICoreWebView2EnvironmentOptions4::SetCustomSchemeRegistrations](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions4?view=webview2-1.0.1587.40&preserve-view=true#setcustomschemeregistrations) - -#### General +--- -This WebView2 SDK release has the same bug fixes as [Bug fixes for 1.0.1466-prerelease](#bug-fixes-for-101466-prerelease). + -## 1.0.1549-prerelease +## Prerelease SDK 1.0.1549-prerelease, for Runtime 110 (Dec. 12, 2022) -Release Date: December 12, 2022 +Release Date: Dec. 12, 2022 [NuGet package for WebView2 SDK 1.0.1549-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1549-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 110.0.1549.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 110.0.1549.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. - -###### Experimental features + * Added support for the Locale Region API: ##### [.NET/C#](#tab/dotnetcsharp) @@ -1835,12 +8999,13 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalControllerOptions interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1549-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalControllerOptions::LocaleRegion property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1549-prerelease&preserve-view=true#get_localeregion), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1549-prerelease&preserve-view=true#put_localeregion) +* [ICoreWebView2ExperimentalControllerOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1549-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalControllerOptions::LocaleRegion property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1549-prerelease&preserve-view=true#get_localeregion), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontrolleroptions?view=webview2-1.0.1549-prerelease&preserve-view=true#put_localeregion) --- + * Added support for the tracking prevention API: ##### [.NET/C#](#tab/dotnetcsharp) @@ -1855,18 +9020,18 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalEnvironmentOptions2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions2?view=webview2-1.0.1549-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalEnvironmentOptions2::EnableTrackingPrevention property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_enabletrackingprevention), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_enabletrackingprevention) -* [ICoreWebView2ExperimentalProfile5 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile5?view=webview2-1.0.1549-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalProfile5::PreferredTrackingPreventionLevel property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile5?view=webview2-1.0.1549-prerelease&preserve-view=true#get_preferredtrackingpreventionlevel), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile5?view=webview2-1.0.1549-prerelease&preserve-view=true#put_preferredtrackingpreventionlevel) +* [ICoreWebView2ExperimentalEnvironmentOptions2](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions2?view=webview2-1.0.1549-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalEnvironmentOptions2::EnableTrackingPrevention property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_enabletrackingprevention), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_enabletrackingprevention) +* [ICoreWebView2ExperimentalProfile5](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile5?view=webview2-1.0.1549-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalProfile5::PreferredTrackingPreventionLevel property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile5?view=webview2-1.0.1549-prerelease&preserve-view=true#get_preferredtrackingpreventionlevel), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile5?view=webview2-1.0.1549-prerelease&preserve-view=true#put_preferredtrackingpreventionlevel) --- - -###### Promotions + +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. @@ -1878,14 +9043,14 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * [CoreWebView2.PrintToPdfStreamAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.printtopdfstreamasync?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) * [CoreWebView2.ShowPrintUI Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showprintui?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) * [CoreWebView2PrintSettings Class](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.Collation Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.collation?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.ColorMode Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.colormode?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.Copies Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.copies?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2printsettings-copies) - * [CoreWebView2PrintSettings.Duplex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.duplex?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.MediaSize Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.mediasize?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.PageRanges Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pageranges?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.PagesPerSide Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pagesperside?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.PrinterName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.printername?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.Collation Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.collation?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.ColorMode Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.colormode?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.Copies Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.copies?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2printsettings-copies) + * [CoreWebView2PrintSettings.Duplex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.duplex?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.MediaSize Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.mediasize?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.PageRanges Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pageranges?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.PagesPerSide Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pagesperside?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.PrinterName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.printername?view=webview2-dotnet-1.0.1549-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) @@ -1893,32 +9058,32 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * [CoreWebView2.PrintToPdfStreamAsync](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#printtopdfstreamasync) * [CoreWebView2.ShowPrintUI Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#showprintui) * [CoreWebView2PrintSettings Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.Collation Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#collation) - * [CoreWebView2PrintSettings.ColorMode Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#colormode) - * [CoreWebView2PrintSettings.Copies Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#copies) - * [CoreWebView2PrintSettings.Duplex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#duplex) - * [CoreWebView2PrintSettings.MediaSize Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#mediasize) - * [CoreWebView2PrintSettings.PageRanges Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#pageranges) - * [CoreWebView2PrintSettings.PagesPerSide Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#pagesperside) - * [CoreWebView2PrintSettings.PrinterName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#printername) - -##### [Win32/C++](#tab/win32cpp) - -* [ICoreWebView2_16 interface](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true) - * [ICoreWebView2_16::Print method](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true#print) - * [ICoreWebView2_16::PrintToPdfStream method](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true#printtopdfstream) - * [ICoreWebView2_16::ShowPrintUI method](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true#showprintui) -* [ICoreWebView2PrintCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2printcompletedhandler?view=webview2-1.0.1549-prerelease&preserve-view=true) -* [ICoreWebView2PrintToPdfStreamCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2printtopdfstreamcompletedhandler?view=webview2-1.0.1549-prerelease&preserve-view=true) -* [ICoreWebView2PrintSettings2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true) - * [ICoreWebView2PrintSettings2::Collation property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_collation), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_collation) - * [ICoreWebView2PrintSettings2::ColorMode property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_colormode), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_colormode) - * [ICoreWebView2PrintSettings2::Copies property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_copies), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_copies) - * [ICoreWebView2PrintSettings2::Duplex property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_duplex), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_duplex) - * [ICoreWebView2PrintSettings2::MediaSize property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_mediasize), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_mediasize) - * [ICoreWebView2PrintSettings2::PageRanges property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_pageranges), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_pageranges) - * [ICoreWebView2PrintSettings2::PagesPerSide property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_pagesperside), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_pagesperside) - * [ICoreWebView2PrintSettings2::PrinterName property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_printername), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_printername) + * [CoreWebView2PrintSettings.Collation Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#collation) + * [CoreWebView2PrintSettings.ColorMode Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#colormode) + * [CoreWebView2PrintSettings.Copies Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#copies) + * [CoreWebView2PrintSettings.Duplex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#duplex) + * [CoreWebView2PrintSettings.MediaSize Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#mediasize) + * [CoreWebView2PrintSettings.PageRanges Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#pageranges) + * [CoreWebView2PrintSettings.PagesPerSide Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#pagesperside) + * [CoreWebView2PrintSettings.PrinterName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1549-prerelease&preserve-view=true#printername) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_16](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true) + * [ICoreWebView2_16::Print](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true#print) + * [ICoreWebView2_16::PrintToPdfStream](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true#printtopdfstream) + * [ICoreWebView2_16::ShowPrintUI](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1549-prerelease&preserve-view=true#showprintui) +* [ICoreWebView2PrintCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2printcompletedhandler?view=webview2-1.0.1549-prerelease&preserve-view=true) +* [ICoreWebView2PrintToPdfStreamCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2printtopdfstreamcompletedhandler?view=webview2-1.0.1549-prerelease&preserve-view=true) +* [ICoreWebView2PrintSettings2](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true) + * [ICoreWebView2PrintSettings2::Collation property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_collation), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_collation) + * [ICoreWebView2PrintSettings2::ColorMode property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_colormode), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_colormode) + * [ICoreWebView2PrintSettings2::Copies property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_copies), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_copies) + * [ICoreWebView2PrintSettings2::Duplex property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_duplex), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_duplex) + * [ICoreWebView2PrintSettings2::MediaSize property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_mediasize), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_mediasize) + * [ICoreWebView2PrintSettings2::PageRanges property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_pageranges), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_pageranges) + * [ICoreWebView2PrintSettings2::PagesPerSide property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_pagesperside), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_pagesperside) + * [ICoreWebView2PrintSettings2::PrinterName property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#get_printername), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1549-prerelease&preserve-view=true#put_printername) --- @@ -1942,53 +9107,140 @@ The following APIs have been promoted from Experimental to Stable in this Prerel --- - -###### Bug fixes + +#### Bug fixes * Fixed some nullptr issues where now some public APIs which take nullptr as input parameters do not crash the WebView2. + * Disabled "Open link as Profile" in the WebView2 context menu. + * Fixed bug where the whole tool bar will be blank when hiding Bookmarks, Search, and PageSelector buttons simultaneously. ([Issue #2866](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2866)) + * Fix post data missing in form submit with control click. ([Issue #2652](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2652)) + * Fixed a bug where the user is not able to get the custom context menu on PDF Viewer. ([Issue #2607](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2607)) + * Fix drag/drop within the WebView2 for composition hosted WebViews. + * Fixed a bug where the app crashes when trying to move focus to WebView2 when it is disabled. -* Remove read aloud icon in address bar in a WebView2 popup window. + +* Remove read aloud icon in Address bar in a WebView2 popup window. + * Fixed an issue where context menu shows unexpected items in WebView2 popup window. + + -## 1.0.1418.22 +## Release SDK 1.0.1518.46, for Runtime 109 (Jan. 17, 2023) -Release Date: October 31, 2022 +Release Date: Jan. 17, 2023 -[NuGet package for WebView2 SDK 1.0.1418.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1418.22) +[NuGet package for WebView2 SDK 1.0.1518.46](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1518.46) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 107.0.1418.22 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 109.0.1518.46 or higher. -#### General +#### Promotions to Phase 3 (Stable in Release) -This WebView2 SDK release has the same bug fixes as [Bug fixes for 1.0.1414-prerelease](#bug-fixes-for-101414-prerelease). +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* The Print API: + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2.PrintAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.printasync?view=webview2-dotnet-1.0.1518.46&preserve-view=true) +* [CoreWebView2.PrintToPdfStreamAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.printtopdfstreamasync?view=webview2-dotnet-1.0.1518.46&preserve-view=true) +* [CoreWebView2.ShowPrintUI Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showprintui?view=webview2-dotnet-1.0.1518.46&preserve-view=true) +* [CoreWebView2PrintSettings Class](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.Collation Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.collation?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.ColorMode Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.colormode?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.Copies Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.copies?view=webview2-dotnet-1.0.1518.46&preserve-view=true#microsoft-web-webview2-core-corewebview2printsettings-copies) + * [CoreWebView2PrintSettings.Duplex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.duplex?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.MediaSize Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.mediasize?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.PageRanges Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pageranges?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.PagesPerSide Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pagesperside?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.PrinterName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.printername?view=webview2-dotnet-1.0.1518.46&preserve-view=true) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2.PrintAsync Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1518.46&preserve-view=true#printasync) +* [CoreWebView2.PrintToPdfStreamAsync](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1518.46&preserve-view=true#printtopdfstreamasync) +* [CoreWebView2.ShowPrintUI Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1518.46&preserve-view=true#showprintui) +* [CoreWebView2PrintSettings Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true) + * [CoreWebView2PrintSettings.Collation Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#collation) + * [CoreWebView2PrintSettings.ColorMode Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#colormode) + * [CoreWebView2PrintSettings.Copies Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#copies) + * [CoreWebView2PrintSettings.Duplex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#duplex) + * [CoreWebView2PrintSettings.MediaSize Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#mediasize) + * [CoreWebView2PrintSettings.PageRanges Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#pageranges) + * [CoreWebView2PrintSettings.PagesPerSide Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#pagesperside) + * [CoreWebView2PrintSettings.PrinterName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1518.46&preserve-view=true#printername) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_16](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true) + * [ICoreWebView2_16::Print](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true#print) + * [ICoreWebView2_16::PrintToPdfStream](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true#printtopdfstream) + * [ICoreWebView2_16::ShowPrintUI](/microsoft-edge/webview2/reference/win32/icorewebview2_16?view=webview2-1.0.1518.46&preserve-view=true#showprintui) +* [ICoreWebView2PrintCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2printcompletedhandler?view=webview2-1.0.1518.46&preserve-view=true) +* [ICoreWebView2PrintToPdfStreamCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2printtopdfstreamcompletedhandler?view=webview2-1.0.1518.46&preserve-view=true) +* [ICoreWebView2PrintSettings2](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true) + * [ICoreWebView2PrintSettings2::Collation property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_collation), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_collation) + * [ICoreWebView2PrintSettings2::ColorMode property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_colormode), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_colormode) + * [ICoreWebView2PrintSettings2::Copies property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_copies), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_copies) + * [ICoreWebView2PrintSettings2::Duplex property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_duplex), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_duplex) + * [ICoreWebView2PrintSettings2::MediaSize property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_mediasize), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_mediasize) + * [ICoreWebView2PrintSettings2::PageRanges property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_pageranges), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_pageranges) + * [ICoreWebView2PrintSettings2::PagesPerSide property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_pagesperside), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_pagesperside) + * [ICoreWebView2PrintSettings2::PrinterName property (get](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#get_printername), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2printsettings2?view=webview2-1.0.1518.46&preserve-view=true#put_printername) + +--- + + + +* The Custom Crash Reporting API: + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2EnvironmentOptions.IsCustomCrashReportingEnabled Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environmentoptions.iscustomcrashreportingenabled?view=webview2-dotnet-1.0.1518.46&preserve-view=true) +* [CoreWebView2Environment.FailureReportFolderPath Property](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.failurereportfolderpath?view=webview2-dotnet-1.0.1518.46&preserve-view=true#microsoft-web-webview2-core-corewebview2environment-failurereportfolderpath) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [CoreWebView2EnvironmentOptions.IsCustomCrashReportingEnabled Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environmentoptions?view=webview2-winrt-1.0.1518.46&preserve-view=true#iscustomcrashreportingenabled) +* [CoreWebView2Environment.FailureReportFolderPath Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2environment?view=webview2-winrt-1.0.1518.46&preserve-view=true#failurereportfolderpath) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2EnvironmentOptions3::IsCustomCrashReportingEnabled property (get](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions3?view=webview2-1.0.1518.46&preserve-view=true#get_iscustomcrashreportingenabled), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions3?view=webview2-1.0.1518.46&preserve-view=true#put_iscustomcrashreportingenabled) +* [ICoreWebView2Environment11::FailureReportFolderPath property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2environment11?view=webview2-1.0.1518.46&preserve-view=true#get_failurereportfolderpath) + +--- + + -## 1.0.1466-prerelease +## Prerelease SDK 1.0.1466-prerelease, for Runtime 109 (Oct. 31, 2022) -Release Date: October 31, 2022 +Release Date: Oct. 31, 2022 [NuGet package for WebView2 SDK 1.0.1466-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1466-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 109.0.1466.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 109.0.1466.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) +The following Experimental APIs have been added in this Prerelease SDK. - -###### Experimental features + * Added support for creating a shared memory based buffer with a specified size: ##### [.NET/C#](#tab/dotnetcsharp) @@ -2011,7 +9263,7 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalSharedBuffer interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedbuffer?view=webview2-1.0.1466-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalSharedBuffer](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsharedbuffer?view=webview2-1.0.1466-prerelease&preserve-view=true) * `Close` * `get_Buffer` * `get_FileMappingHandle` @@ -2034,8 +9286,8 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2Experimental18::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2experimental18?view=webview2-1.0.1466-prerelease&preserve-view=true#postsharedbuffertoscript) -* [ICoreWebView2ExperimentalFrame4::PostSharedBufferToScript method](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe4?view=webview2-1.0.1466-prerelease&preserve-view=true#postsharedbuffertoscript) +* [ICoreWebView2Experimental18::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2experimental18?view=webview2-1.0.1466-prerelease&preserve-view=true#postsharedbuffertoscript) +* [ICoreWebView2ExperimentalFrame4::PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe4?view=webview2-1.0.1466-prerelease&preserve-view=true#postsharedbuffertoscript) --- @@ -2044,106 +9296,105 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [.NET/C#](#tab/dotnetcsharp) * [CoreWebView2ScriptException Class](/dotnet/api/microsoft.web.webview2.core.corewebview2scriptexception?view=webview2-dotnet-1.0.1466-prerelease&preserve-view=true) - * `ColumnNumber` - * `LineNumber` - * `Message` - * `Name` - * `ToJson` + * `ColumnNumber` + * `LineNumber` + * `Message` + * `Name` + * `ToJson` ##### [WinRT/C#](#tab/winrtcsharp) * [CoreWebView2ScriptException Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2scriptexception?view=webview2-winrt-1.0.1466-prerelease&preserve-view=true) - * `ColumnNumber` - * `LineNumber` - * `Message` - * `Name` - * `ToJson` + * `ColumnNumber` + * `LineNumber` + * `Message` + * `Name` + * `ToJson` ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalScriptException interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscriptexception?view=webview2-1.0.1466-prerelease&preserve-view=true) - * `get_ColumnNumber` - * `get_LineNumber` - * `get_Message` - * `get_Name` - * `get_ToJson` +* [ICoreWebView2ExperimentalScriptException](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalscriptexception?view=webview2-1.0.1466-prerelease&preserve-view=true) + * `get_ColumnNumber` + * `get_LineNumber` + * `get_Message` + * `get_Name` + * `get_ToJson` --- + +#### Bug fixes for 1.0.1466-prerelease -###### Bug fixes for 1.0.1466-prerelease * Fixed a bug in which the custom header title in print settings could be wrong. ([Issue #2093](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2093)) + * Display `AllowedCertificateAuthorities` in `add_ClientCertificateRequested` event as a `Base64` string. (Runtime-only) ([Issue #2346](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2346)) + * Fixed a bug in which the default footer URI in print settings is missing. ([Issue #2851](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2851)) + * Fixed a bug that produces a null pointer exception that's related to print settings. (Runtime-only) ([Issue #2858](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2858)) + * Fixed a bug that reports navigation failure when redirecting to a server that has been configured with Client Certificate Authentication and when the `WebResourceRequested` event is subscribed to. (Runtime-only) + * Fixed an `AddHostObjectToScript` bug in which, when JavaScript calls an async method and then a synchronous method, the async method call might fail. + + -## 1.0.1370.28 +## Release SDK 1.0.1462.37, for Runtime 108 (Dec. 12, 2022) -Release Date: October 11, 2022 +Release Date: Dec. 12, 2022 -[NuGet package for WebView2 SDK 1.0.1370.28](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1370.28) +[NuGet package for WebView2 SDK 1.0.1462.37](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1462.37) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 106.0.1370.28 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 108.0.1462.37 or higher. -#### General - +#### Bug fixes - -###### Promotions +This WebView2 SDK release has the same bug fixes as [Bug fixes for 1.0.1466-prerelease](#bug-fixes-for-101466-prerelease). -The following APIs have been promoted to Stable and are now included in this Release SDK. + - -* The drag and drop API: + +## Release SDK 1.0.1418.22, for Runtime 107 (Oct. 31, 2022) -##### [.NET/C#](#tab/dotnetcsharp) +Release Date: Oct. 31, 2022 -* [CoreWebView2CompositionController.DragLeave Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.dragleave?view=webview2-dotnet-1.0.1370.28&preserve-view=true#microsoft-web-webview2-core-corewebview2compositioncontroller-dragleave) +[NuGet package for WebView2 SDK 1.0.1418.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1418.22) -##### [WinRT/C#](#tab/winrtcsharp) +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 107.0.1418.22 or higher. -* [ICoreWebView2CompositionControllerInterop2.DragEnter Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragenter) -* [ICoreWebView2CompositionControllerInterop2.DragLeave Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragleave) -* [ICoreWebView2CompositionControllerInterop2.DragOver Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragover) -* [ICoreWebView2CompositionControllerInterop2.Drop Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#drop) -* [CoreWebView2CompositionController.DragLeave Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragleave) -##### [Win32/C++](#tab/win32cpp) + +#### Bug fixes -* [ICoreWebView2CompositionController3::DragEnter method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#dragenter) -* [ICoreWebView2CompositionController3::DragLeave method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#dragleave) -* [ICoreWebView2CompositionController3::DragOver method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#dragover) -* [ICoreWebView2CompositionController3::Drop method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#drop) +This WebView2 SDK release has the same bug fixes as [Bug fixes for 1.0.1414-prerelease](#bug-fixes-for-101414-prerelease). ---- + -## 1.0.1414-prerelease +## Prerelease SDK 1.0.1414-prerelease, for Runtime 107 (Oct. 11, 2022) -Release Date: October 11, 2022 +Release Date: Oct. 11, 2022 [NuGet package for WebView2 SDK 1.0.1414-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1414-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 107.0.1414.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 107.0.1414.0 or higher. -#### General +#### Experimental APIs (Phase 1: Experimental in Prerelease) +The following Experimental APIs have been added in this Prerelease SDK. - -###### Experimental features + * Added support for the Print API: ##### [.NET/C#](#tab/dotnetcsharp) @@ -2152,14 +9403,14 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft * [CoreWebView2.PrintToPdfStreamAsync Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.printtopdfstreamasync?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) * [CoreWebView2.ShowPrintUI Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.showprintui?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) * [CoreWebView2PrintSettings Class](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.Collation Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.collation?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.ColorMode Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.colormode?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.Copies Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.copies?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2printsettings-copies) - * [CoreWebView2PrintSettings.Duplex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.duplex?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.MediaSize Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.mediasize?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.PageRanges Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pageranges?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.PagesPerSide Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pagesperside?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.PrinterName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.printername?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.Collation Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.collation?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.ColorMode Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.colormode?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.Copies Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.copies?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2printsettings-copies) + * [CoreWebView2PrintSettings.Duplex Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.duplex?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.MediaSize Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.mediasize?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.PageRanges Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pageranges?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.PagesPerSide Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.pagesperside?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) + * [CoreWebView2PrintSettings.PrinterName Property](/dotnet/api/microsoft.web.webview2.core.corewebview2printsettings.printername?view=webview2-dotnet-1.0.1414-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) @@ -2167,31 +9418,31 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft * [CoreWebView2.PrintToPdfStreamAsync](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#printtopdfstreamasync) * [CoreWebView2.ShowPrintUI Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#showprintui) * [CoreWebView2PrintSettings Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true) - * [CoreWebView2PrintSettings.Collation Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#collation) - * [CoreWebView2PrintSettings.ColorMode Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#colormode) - * [CoreWebView2PrintSettings.Copies Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#copies) - * [CoreWebView2PrintSettings.Duplex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#duplex) - * [CoreWebView2PrintSettings.MediaSize Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#mediasize) - * [CoreWebView2PrintSettings.PageRanges Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#pageranges) - * [CoreWebView2PrintSettings.PagesPerSide Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#pagesperside) - * [CoreWebView2PrintSettings.PrinterName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#printername) - -##### [Win32/C++](#tab/win32cpp) - -* [ICoreWebView2Experimental17::Print method](/microsoft-edge/webview2/reference/win32/icorewebview2experimental17?view=webview2-1.0.1414-prerelease&preserve-view=true#print) -* [ICoreWebView2Experimental17::PrintToPdfStream method](/microsoft-edge/webview2/reference/win32/icorewebview2experimental17?view=webview2-1.0.1414-prerelease&preserve-view=true#printtopdfstream) -* [ICoreWebView2Experimental17::ShowPrintUI method](/microsoft-edge/webview2/reference/win32/icorewebview2experimental17?view=webview2-1.0.1414-prerelease&preserve-view=true#showprintui) -* [ICoreWebView2ExperimentalPrintCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintcompletedhandler?view=webview2-1.0.1414-prerelease&preserve-view=true) -* [ICorewebView2ExperimentalPrintToPdfStreamCompletedHandler interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprinttopdfstreamcompletedhandler?view=webview2-1.0.1414-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalPrintSettings2 interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true) - * [ICoreWebView2ExperimentalPrintSettings2::Collation property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_collation), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_collation) - * [ICoreWebView2ExperimentalPrintSettings2::ColorMode property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_colormode), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_colormode) - * [ICoreWebView2ExperimentalPrintSettings2::Copies property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_copies), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_copies) - * [ICoreWebView2ExperimentalPrintSettings2::Duplex property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_duplex), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_duplex) - * [ICoreWebView2ExperimentalPrintSettings2::MediaSize property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_mediasize), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_mediasize) - * [ICoreWebView2ExperimentalPrintSettings2::PageRanges property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_pageranges), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_pageranges) - * [ICoreWebView2ExperimentalPrintSettings2::PagesPerSide property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_pagesperside), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_pagesperside) - * [ICoreWebView2ExperimentalPrintSettings2::PrinterName property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_printername), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_printername) + * [CoreWebView2PrintSettings.Collation Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#collation) + * [CoreWebView2PrintSettings.ColorMode Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#colormode) + * [CoreWebView2PrintSettings.Copies Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#copies) + * [CoreWebView2PrintSettings.Duplex Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#duplex) + * [CoreWebView2PrintSettings.MediaSize Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#mediasize) + * [CoreWebView2PrintSettings.PageRanges Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#pageranges) + * [CoreWebView2PrintSettings.PagesPerSide Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#pagesperside) + * [CoreWebView2PrintSettings.PrinterName Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2printsettings?view=webview2-winrt-1.0.1414-prerelease&preserve-view=true#printername) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2Experimental17::Print](/microsoft-edge/webview2/reference/win32/icorewebview2experimental17?view=webview2-1.0.1414-prerelease&preserve-view=true#print) +* [ICoreWebView2Experimental17::PrintToPdfStream](/microsoft-edge/webview2/reference/win32/icorewebview2experimental17?view=webview2-1.0.1414-prerelease&preserve-view=true#printtopdfstream) +* [ICoreWebView2Experimental17::ShowPrintUI](/microsoft-edge/webview2/reference/win32/icorewebview2experimental17?view=webview2-1.0.1414-prerelease&preserve-view=true#showprintui) +* [ICoreWebView2ExperimentalPrintCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintcompletedhandler?view=webview2-1.0.1414-prerelease&preserve-view=true) +* [ICorewebView2ExperimentalPrintToPdfStreamCompletedHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprinttopdfstreamcompletedhandler?view=webview2-1.0.1414-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalPrintSettings2](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true) + * [ICoreWebView2ExperimentalPrintSettings2::Collation property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_collation), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_collation) + * [ICoreWebView2ExperimentalPrintSettings2::ColorMode property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_colormode), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_colormode) + * [ICoreWebView2ExperimentalPrintSettings2::Copies property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_copies), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_copies) + * [ICoreWebView2ExperimentalPrintSettings2::Duplex property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_duplex), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_duplex) + * [ICoreWebView2ExperimentalPrintSettings2::MediaSize property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_mediasize), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_mediasize) + * [ICoreWebView2ExperimentalPrintSettings2::PageRanges property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_pageranges), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_pageranges) + * [ICoreWebView2ExperimentalPrintSettings2::PagesPerSide property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_pagesperside), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_pagesperside) + * [ICoreWebView2ExperimentalPrintSettings2::PrinterName property (get](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#get_printername), [put)](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprintsettings2?view=webview2-1.0.1414-prerelease&preserve-view=true#put_printername) --- @@ -2233,49 +9484,78 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft --- + +#### Bug fixes for 1.0.1414-prerelease -###### Bug fixes for 1.0.1414-prerelease * Removed three-dot menu with a broken link from the downloads page. (Runtime-only) ([Issue #2753](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2753)) + * Fixed a bug in the WebView2 WinRT JS Projection tool (wv2winrt) where C++20 projects failed to compile. ([Issue #2768](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2768)) + * Fixed a crash which could occur with the WebView2 WinRT API while closing down WebView2 if you subscribed to any events, especially the `CoreWebView2.GetDevToolsEventReceiver` event. (SDK-only) + * Fixed a bug where it wasn't possible to dismiss the download popup after minimizing the window. (Runtime-only) + + -## 1.0.1343.22 +## Release SDK 1.0.1370.28, for Runtime 106 (Oct. 11, 2022) -Release Date: September 6, 2022 +Release Date: Oct. 11, 2022 -[NuGet package for WebView2 SDK 1.0.1343.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1343.22) +[NuGet package for WebView2 SDK 1.0.1370.28](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1370.28) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 105.0.1343.22 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 106.0.1370.28 or higher. -#### General +#### Promotions to Phase 3 (Stable in Release) -This WebView2 SDK release has the same bug fixes as [Bug fixes for 1.0.1369-prerelease](#bug-fixes-for-101369-prerelease). +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + + +* The drag and drop API: + +##### [.NET/C#](#tab/dotnetcsharp) + +* [CoreWebView2CompositionController.DragLeave Method](/dotnet/api/microsoft.web.webview2.core.corewebview2compositioncontroller.dragleave?view=webview2-dotnet-1.0.1370.28&preserve-view=true#microsoft-web-webview2-core-corewebview2compositioncontroller-dragleave) + +##### [WinRT/C#](#tab/winrtcsharp) + +* [ICoreWebView2CompositionControllerInterop2.DragEnter Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragenter) +* [ICoreWebView2CompositionControllerInterop2.DragLeave Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragleave) +* [ICoreWebView2CompositionControllerInterop2.DragOver Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragover) +* [ICoreWebView2CompositionControllerInterop2.Drop Method](/microsoft-edge/webview2/reference/winrt/interop/icorewebview2compositioncontrollerinterop2?view=webview2-winrt-1.0.1370.28&preserve-view=true#drop) +* [CoreWebView2CompositionController.DragLeave Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2compositioncontroller?view=webview2-winrt-1.0.1370.28&preserve-view=true#dragleave) + +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2CompositionController3::DragEnter](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#dragenter) +* [ICoreWebView2CompositionController3::DragLeave](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#dragleave) +* [ICoreWebView2CompositionController3::DragOver](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#dragover) +* [ICoreWebView2CompositionController3::Drop](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1370.28&preserve-view=true#drop) + +--- + + -## 1.0.1369-prerelease +## Prerelease SDK 1.0.1369-prerelease, for Runtime 106 (Sep. 6, 2022) -Release Date: September 6, 2022 +Release Date: Sep. 6, 2022 [NuGet package for WebView2 SDK 1.0.1369-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1369-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 106.0.1369.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 106.0.1369.0 or higher. -#### General - +#### Promotions to Phase 2 (Stable in Prerelease) - -###### Promotions - -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * The drag and drop API: @@ -2294,96 +9574,85 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2CompositionController3::DragEnter method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#dragenter) -* [ICoreWebView2CompositionController3::DragLeave method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#dragleave) -* [ICoreWebView2CompositionController3::DragOver method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#dragover) -* [ICoreWebView2CompositionController3::Drop method](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#drop) +* [ICoreWebView2CompositionController3::DragEnter](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#dragenter) +* [ICoreWebView2CompositionController3::DragLeave](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#dragleave) +* [ICoreWebView2CompositionController3::DragOver](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#dragover) +* [ICoreWebView2CompositionController3::Drop](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller3?view=webview2-1.0.1369-prerelease&preserve-view=true#drop) --- + +#### Bug fixes for 1.0.1369-prerelease -###### Bug fixes for 1.0.1369-prerelease -* Fixed a bug where WPF apps would crash when windows with WebView2 were closed. ([Issue #640](https://github.com/MicrosoftEdge/WebView2Feedback/issues/640)) +* Fixed a bug where WPF apps would crash when windows with WebView2 were closed. ([Issue #640](https://github.com/MicrosoftEdge/WebView2Feedback/issues/640)) -* Fixed a bug that produced simultaneous WebView creation failure. (Runtime-only) [Issue #2703](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2703) +* Fixed a bug that produced simultaneous WebView creation failure. (Runtime-only) ([Issue #2703](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2703)) * Fixed print settings paper size to support dimensions as small as 0.01 inches. (Runtime-only) -* Fixed a bug where the WebView2 print dialog reset the **Scale** setting to **Fit to printable area** every time. ([Issue #2523](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2523)) +* Fixed a bug where the WebView2 print dialog reset the **Scale** setting to **Fit to printable area** every time. ([Issue #2523](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2523)) * Fixed a bug in the **wv2winrt** tool where a WinMD file wasn't referenced in some projects. - - -## 1.0.1293.44 - -Release Date: August 8, 2022 - -[NuGet package for WebView2 SDK 1.0.1293.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1293.44) - -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 104.0.1293.44 or higher. - -#### General - -###### Promotions - -The following APIs have been promoted to Stable and are now included in this Release SDK. + -* The Favicon API: + +## Release SDK 1.0.1343.22, for Runtime 105 (Sep. 6, 2022) -##### [.NET/C#](#tab/dotnetcsharp) +Release Date: Sep. 6, 2022 -* [CoreWebView2.FaviconChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.faviconchanged?view=webview2-dotnet-1.0.1293.44&preserve-view=true) -* [CoreWebView2.FaviconUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.faviconuri?view=webview2-dotnet-1.0.1293.44&preserve-view=true) +[NuGet package for WebView2 SDK 1.0.1343.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1343.22) -##### [WinRT/C#](#tab/winrtcsharp) +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 105.0.1343.22 or higher. -* [CoreWebView2.FaviconChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1293.44&preserve-view=true#faviconchanged) -* [CoreWebView2.FaviconUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1293.44&preserve-view=true#faviconuri) -##### [Win32/C++](#tab/win32cpp) + +#### Bug fixes -* [ICoreWebView2_15::FaviconChanged event (add](/microsoft-edge/webview2/reference/win32/icorewebview2_15?view=webview2-1.0.1293.44&preserve-view=true#add_faviconchanged), [remove)](/microsoft-edge/webview2/reference/win32/icorewebview2_15?view=webview2-1.0.1293.44&preserve-view=true#remove_faviconchanged) -* [ICoreWebView2_15::FaviconUri property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2_15?view=webview2-1.0.1293.44&preserve-view=true#get_faviconuri) +This WebView2 SDK release has the same bug fixes as [Bug fixes for 1.0.1369-prerelease](#bug-fixes-for-101369-prerelease). ---- + -## 1.0.1340-prerelease +## Prerelease SDK 1.0.1340-prerelease, for Runtime 105 (Aug. 8, 2022) -Release Date: August 8, 2022 +Release Date: Aug. 8, 2022 [NuGet package for WebView2 SDK 1.0.1340-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1340-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 105.0.1340.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 105.0.1340.0 or higher. -#### General -###### Experimental features + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. + + * Added support for `WebResourceRequested` for workers which allows setting filters in order to receive `WebResourceRequested` events for service workers, shared workers, and different origin iframes. ##### [.NET/C#](#tab/dotnetcsharp) -* [CoreWebView2.AddWebResourceRequestedFilter(RequestSourceKinds) Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.addwebresourcerequestedfilter?view=webview2-dotnet-1.0.1340-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2-addwebresourcerequestedfilter(system-string-microsoft-web-webview2-core-corewebview2webresourcecontext-microsoft-web-webview2-core-corewebview2webresourcerequestsourcekinds)) -* [CoreWebView2.RemoveWebResourceRequestedFilter(RequestSourceKinds) Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.removewebresourcerequestedfilter?view=webview2-dotnet-1.0.1340-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2-removewebresourcerequestedfilter(system-string-microsoft-web-webview2-core-corewebview2webresourcecontext-microsoft-web-webview2-core-corewebview2webresourcerequestsourcekinds)) +* [CoreWebView2.AddWebResourceRequestedFilter(uri, resourceContext, requestSourceKinds) Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.addwebresourcerequestedfilter?view=webview2-dotnet-1.0.1340-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2-addwebresourcerequestedfilter(system-string-microsoft-web-webview2-core-corewebview2webresourcecontext-microsoft-web-webview2-core-corewebview2webresourcerequestsourcekinds)) +* [CoreWebView2.RemoveWebResourceRequestedFilter(uri, resourceContext, requestSourceKinds) Method](/dotnet/api/microsoft.web.webview2.core.corewebview2.removewebresourcerequestedfilter?view=webview2-dotnet-1.0.1340-prerelease&preserve-view=true#microsoft-web-webview2-core-corewebview2-removewebresourcerequestedfilter(system-string-microsoft-web-webview2-core-corewebview2webresourcecontext-microsoft-web-webview2-core-corewebview2webresourcerequestsourcekinds)) * [CoreWebView2WebResourceRequestedEventArgs Class](/dotnet/api/microsoft.web.webview2.core.corewebview2webresourcerequestedeventargs?view=webview2-dotnet-1.0.1340-prerelease&preserve-view=true) ##### [WinRT/C#](#tab/winrtcsharp) -* [CoreWebView2.AddWebResourceRequestedFilter(requestSourceKinds) Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1340-prerelease&preserve-view=true#addwebresourcerequestedfilter) -* [CoreWebView2.RemoveWebResourceRequestedFilter(requestSourceKinds) Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1340-prerelease&preserve-view=true#removewebresourcerequestedfilter) +* [CoreWebView2.AddWebResourceRequestedFilter(uri, resourceContext, requestSourceKinds) Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1340-prerelease&preserve-view=true#addwebresourcerequestedfilter) +* [CoreWebView2.RemoveWebResourceRequestedFilter(uri, resourceContext, requestSourceKinds) Method](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1340-prerelease&preserve-view=true#removewebresourcerequestedfilter) * [CoreWebView2WebResourceRequestedEventArgs Class](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2webresourcerequestedeventargs?view=webview2-winrt-1.0.1340-prerelease&preserve-view=true) ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2Experimental16.AddWebResourceRequestedFilterWithRequestSourceKinds method](/microsoft-edge/webview2/reference/win32/icorewebview2experimental16?view=webview2-1.0.1340-prerelease&preserve-view=true#addwebresourcerequestedfilterwithrequestsourcekinds) -* [ICoreWebView2Experimental16.RemoveWebResourceRequestedFilterWithRequestSourceKinds method](/microsoft-edge/webview2/reference/win32/icorewebview2experimental16?view=webview2-1.0.1340-prerelease&preserve-view=true#removewebresourcerequestedfilterwithrequestsourcekinds) -* [ICoreWebView2ExperimentalWebResourceRequestedEventArgs interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebresourcerequestedeventargs?view=webview2-1.0.1340-prerelease&preserve-view=true) +* [ICoreWebView2Experimental16.AddWebResourceRequestedFilterWithRequestSourceKinds](/microsoft-edge/webview2/reference/win32/icorewebview2experimental16?view=webview2-1.0.1340-prerelease&preserve-view=true#addwebresourcerequestedfilterwithrequestsourcekinds) +* [ICoreWebView2Experimental16.RemoveWebResourceRequestedFilterWithRequestSourceKinds](/microsoft-edge/webview2/reference/win32/icorewebview2experimental16?view=webview2-1.0.1340-prerelease&preserve-view=true#removewebresourcerequestedfilterwithrequestsourcekinds) +* [ICoreWebView2ExperimentalWebResourceRequestedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebresourcerequestedeventargs?view=webview2-1.0.1340-prerelease&preserve-view=true) --- @@ -2401,12 +9670,14 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2ExperimentalEnvironmentOptions interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.1340-prerelease&preserve-view=true) -* [ICoreWebView2ExperimentalCustomSchemeRegistration interface](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcustomschemeregistration?view=webview2-1.0.1340-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalEnvironmentOptions](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.1340-prerelease&preserve-view=true) +* [ICoreWebView2ExperimentalCustomSchemeRegistration](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcustomschemeregistration?view=webview2-1.0.1340-prerelease&preserve-view=true) --- -###### Bug fixes + + +#### Bug fixes * Added the ability for developers to explicitly specify the path from which to load the WebView2Loader.dll. ([Issue #767](https://github.com/MicrosoftEdge/WebView2Feedback/issues/767)) @@ -2430,54 +9701,23 @@ For full API compatibility, this version of the WebView2 SDK requires Microsoft * Fixed a bug where focus is not returned to the application after closing the find bar for windowed mode. ([Issue #1225](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1225)) - - -## 1.0.1264.42 - -Release Date: July 4, 2022 - -[NuGet package for WebView2 SDK 1.0.1264.42](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1264.42) - -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 103.0.1264.42 or higher. - -#### General - -###### Promotions - -The following APIs have been promoted to Stable and are now included in this Release SDK. - - -* Added `ContextMenuRequested`API to enable host app to create or modify their own context menu. - -##### [.NET/C#](#tab/dotnetcsharp) - -* [CoreWebView2.ContextMenuRequested Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.contextmenurequested?view=webview2-dotnet-1.0.1264.42&preserve-view=true) - -##### [WinRT/C#](#tab/winrtcsharp) - -* [CoreWebView2.ContextMenuRequested Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1264.42&preserve-view=true#contextmenurequested) - -##### [Win32/C++](#tab/win32cpp) - -* [ICoreWebView2_11::add_ContextMenuRequested event (add](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1264.42&preserve-view=true#add_contextmenurequested), [remove)](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1264.42&preserve-view=true#remove_contextmenurequested) - ---- + -## 1.0.1305-prerelease +## Prerelease SDK 1.0.1305-prerelease, for Runtime 105 (Jul. 4, 2022) -Release Date: July 4, 2022 +Release Date: Jul. 4, 2022 [NuGet package for WebView2 SDK 1.0.1305-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1305-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 105.0.1305.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 105.0.1305.0 or higher. -#### General -###### Promotions + +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * The Favicon API: @@ -2499,7 +9739,9 @@ The following APIs have been promoted from Experimental to Stable in this Prerel --- -###### Bug fixes + + +#### Bug fixes * Fixed an issue where `PrintToPdfAsync` may hang for long time. ([Issue #1974](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1974)) @@ -2513,95 +9755,118 @@ The following APIs have been promoted from Experimental to Stable in this Prerel ##### [Win32/C++](#tab/win32cpp) -* [ICoreWebView2_7::PrintToPdf method](/microsoft-edge/webview2/reference/win32/icorewebview2_7?view=webview2-1.0.1305-prerelease&preserve-view=true#printtopdf) +* [ICoreWebView2_7::PrintToPdf](/microsoft-edge/webview2/reference/win32/icorewebview2_7?view=webview2-1.0.1305-prerelease&preserve-view=true#printtopdf) --- * Fixed regression where WebView2 would steal focus from the app when the WebView2 was made visible. ([Issue #862](https://github.com/MicrosoftEdge/WebView2Feedback/issues/862)) + + -## 1.0.1245.22 +## Release SDK 1.0.1293.44, for Runtime 104 (Aug. 8, 2022) -Release Date: June 14, 2022 +Release Date: Aug. 8, 2022 -[NuGet package for WebView2 SDK 1.0.1245.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1245.22) +[NuGet package for WebView2 SDK 1.0.1293.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1293.44) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 102.0.1245.22 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 104.0.1293.44 or higher. -There is no corresponding prerelease package. -#### General + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -###### Promotions -The following APIs have been promoted to Stable and are now included in this Release SDK. +* The Favicon API: +##### [.NET/C#](#tab/dotnetcsharp) -* The [Server Certificate API](/microsoft-edge/webview2/reference/win32/icorewebview2_14?view=webview2-1.0.1245.22&preserve-view=true) which provides an option to trust the server's TLS certificate at the application level. It renders the page without prompting the user about TLS or providing the ability to cancel the web request. +* [CoreWebView2.FaviconChanged Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.faviconchanged?view=webview2-dotnet-1.0.1293.44&preserve-view=true) +* [CoreWebView2.FaviconUri Property](/dotnet/api/microsoft.web.webview2.core.corewebview2.faviconuri?view=webview2-dotnet-1.0.1293.44&preserve-view=true) -* The [ClearBrowsingData API](/microsoft-edge/webview2/reference/win32/icorewebview2profile2?view=webview2-1.0.1245.22&preserve-view=true) which allows developers to programmatically clear specific data types for a duration: - * `ClearBrowsingData` - * `ClearBrowsingDataAll` - * `ClearBrowsingDataInTimeRange` +##### [WinRT/C#](#tab/winrtcsharp) -* The [HttpStatusCode API](/microsoft-edge/webview2/reference/win32/icorewebview2navigationcompletedeventargs2?view=webview2-1.0.1245.22&preserve-view=true) which provides the HTTP status code for navigation requests in `NavigationCompleted` events. +* [CoreWebView2.FaviconChanged Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1293.44&preserve-view=true#faviconchanged) +* [CoreWebView2.FaviconUri Property](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1293.44&preserve-view=true#faviconuri) -###### Bug fixes +##### [Win32/C++](#tab/win32cpp) + +* [ICoreWebView2_15::FaviconChanged event (add](/microsoft-edge/webview2/reference/win32/icorewebview2_15?view=webview2-1.0.1293.44&preserve-view=true#add_faviconchanged), [remove)](/microsoft-edge/webview2/reference/win32/icorewebview2_15?view=webview2-1.0.1293.44&preserve-view=true#remove_faviconchanged) +* [ICoreWebView2_15::FaviconUri property (get)](/microsoft-edge/webview2/reference/win32/icorewebview2_15?view=webview2-1.0.1293.44&preserve-view=true#get_faviconuri) + +--- + + + + + +## Release SDK 1.0.1264.42, for Runtime 103 (Jul. 4, 2022) + +Release Date: Jul. 4, 2022 + +[NuGet package for WebView2 SDK 1.0.1264.42](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1264.42) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 103.0.1264.42 or higher. -* Fixed an issue with the on-screen keyboard in which the keyboard doesn't reappear after it's closed by clicking the **X** button. Also fixed an issue in which the keyboard gets dismissed when users switch from one edit control to another within WebView2. ([Issue #460](https://github.com/MicrosoftEdge/WebView2Feedback/issues/460)) -* Fixed an issue when using a proxy from `AddHostObjectToScript` in script. If you call `setHostProperty` and it failed, you could have received an internal error message structure rather than a JavaScript Error object. -* Fixed regression where WebView2 would steal focus from the app when the WebView2 was made visible. ([Issue #862](https://github.com/MicrosoftEdge/WebView2Feedback/issues/862)) -* Fixed a bug that caused increased memory usage with `WebResourceRequested` events using large data. ([Issue #2171](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2171)) -* Fixed `StatusBarTextChanged` regression. The [StatusBarText API](/microsoft-edge/webview2/reference/win32/icorewebview2_12?view=webview2-1.0.1245.22&preserve-view=true) was made compatible with previous versions again. ([Issue #2414](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2414)) -* Better support for apps running as admin. ([Issue #2356](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2356)) + +#### Promotions to Phase 3 (Stable in Release) - -## 1.0.1210.39 +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -Release Date: May 9, 2022 -[NuGet package for WebView2 SDK 1.0.1210.39](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1210.39) +* Added `ContextMenuRequested`API to enable host app to create or modify their own context menu. + +##### [.NET/C#](#tab/dotnetcsharp) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 101.0.1210.39 or higher. +* [CoreWebView2.ContextMenuRequested Event](/dotnet/api/microsoft.web.webview2.core.corewebview2.contextmenurequested?view=webview2-dotnet-1.0.1264.42&preserve-view=true) -#### General +##### [WinRT/C#](#tab/winrtcsharp) -###### Promotions +* [CoreWebView2.ContextMenuRequested Event](/microsoft-edge/webview2/reference/winrt/microsoft_web_webview2_core/corewebview2?view=webview2-winrt-1.0.1264.42&preserve-view=true#contextmenurequested) -The following APIs have been promoted to Stable and are now included in this Release SDK. +##### [Win32/C++](#tab/win32cpp) -* Support for [multiple user profiles](/microsoft-edge/webview2/reference/win32/icorewebview2environment10?view=webview2-1.0.1210.39&preserve-view=true) in WebView2. +* [ICoreWebView2_11::add_ContextMenuRequested event (add](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1264.42&preserve-view=true#add_contextmenurequested), [remove)](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1264.42&preserve-view=true#remove_contextmenurequested) -* [Theming API](/microsoft-edge/webview2/reference/win32/icorewebview2profile?view=webview2-1.0.1210.39&preserve-view=true) which provides a way to customize the WebView2 color theme as `light`, `dark`, or `system`. +--- + + -* [Default Download API](/microsoft-edge/webview2/reference/win32/icorewebview2profile?view=webview2-1.0.1210.39&preserve-view=true) which provides a way to customize the default download location. -## 1.0.1248-prerelease +## Prerelease SDK 1.0.1248-prerelease, for Runtime 102 (May 9, 2022) Release Date: May 9, 2022 [NuGet package for WebView2 SDK 1.0.1248-prelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1248-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 102.0.1248.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 102.0.1248.0 or higher. + -#### General + +#### General features * Added support for WinRT Object projection into JavaScript by adding WinRT JS Projection tool (**wv2winrt**) in NuGet package. For instructions about using the WinRT JS Projection tool see [Call native-side WinRT code from web-side code](/microsoft-edge/webview2/how-to/winrt-from-js). -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * The [Server Certificate API](/microsoft-edge/webview2/reference/win32/icorewebview2_14?view=webview2-1.0.1248-prerelease&preserve-view=true) which provides an option to trust the server's TLS certificate at the application level and render the page without prompting the user about TLS or providing the ability to cancel the web request. * The [ClearBrowsingData API](/microsoft-edge/webview2/reference/win32/icorewebview2profile2?view=webview2-1.0.1248-prerelease&preserve-view=true) which allows developers to programmatically clear specific data types for a duration: - * `clearBrowsingDataInTimeRange` - * `clearBrowsingDataAll` + * `clearBrowsingDataInTimeRange` + * `clearBrowsingDataAll` -###### Bug fixes + + +#### Bug fixes * Fixed an unavoidable crash that occurred in the WPF control's `OnWindowPositionChanged` event. ([Issue #1531](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1531)) @@ -2615,62 +9880,99 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * Fixed a bug where changes from Chromium broke WebView2 background color. + + -## 1.0.1185.39 +## Release SDK 1.0.1245.22, for Runtime 102 (Jun. 14, 2022) -Release Date: April 12, 2022 +Release Date: Jun. 14, 2022 -[NuGet package for WebView2 SDK 1.0.1185.39](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1185.39) +[NuGet package for WebView2 SDK 1.0.1245.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1245.22) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 100.0.1185.39 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 102.0.1245.22 or higher. -#### General +There is no corresponding prerelease package. -* Renamed `ICoreWebView2Certificate` to `ICoreWebView2ClientCertificate`. -###### Promotions + +#### Promotions to Phase 3 (Stable in Release) -The following APIs have been promoted to Stable and are now included in this Release SDK. +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -* The [CallDevToolsProtocolMethodForSession API](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1185.39&preserve-view=true#calldevtoolsprotocolmethodforsession) that supports `sessionId` for CDP method calls. -* The [StatusBarText API](/microsoft-edge/webview2/reference/win32/icorewebview2_12?view=webview2-1.0.1185.39&preserve-view=true): - * `add_StatusBarTextChanged` - * `get_StatusBarText` - * `remove_StatusBarTextChanged` +* The [Server Certificate API](/microsoft-edge/webview2/reference/win32/icorewebview2_14?view=webview2-1.0.1245.22&preserve-view=true) which provides an option to trust the server's TLS certificate at the application level. It renders the page without prompting the user about TLS or providing the ability to cancel the web request. -* The [AllowExternalDrop API](/microsoft-edge/webview2/reference/win32/icorewebview2controller4?view=webview2-1.0.1185.39&preserve-view=true) that supports enable/disable for external drop operations. +* The [ClearBrowsingData API](/microsoft-edge/webview2/reference/win32/icorewebview2profile2?view=webview2-1.0.1245.22&preserve-view=true) which allows developers to programmatically clear specific data types for a duration: + * `ClearBrowsingData` + * `ClearBrowsingDataAll` + * `ClearBrowsingDataInTimeRange` -* The [HiddenPdfToolbarItems API](/microsoft-edge/webview2/reference/win32/icorewebview2settings7?view=webview2-1.0.1185.39&preserve-view=true) is available to customize PDF toolbar items. +* The [HttpStatusCode API](/microsoft-edge/webview2/reference/win32/icorewebview2navigationcompletedeventargs2?view=webview2-1.0.1245.22&preserve-view=true) which provides the HTTP status code for navigation requests in `NavigationCompleted` events. -* The [ExclusiveUserDataFolderAccess API](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions2?view=webview2-1.0.1185.39&preserve-view=true) allows control of whether or not other processes can create WebView2 from `WebView2Environment` created with the same user data folder and therefore sharing the same WebView browser process instance. -* The [permission requested support for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2frame3?view=webview2-1.0.1185.39&preserve-view=true): - * `add_PermissionRequested` - * `remove_PermissionRequested` + +#### Bug fixes + +* Fixed an issue with the on-screen keyboard in which the keyboard doesn't reappear after it's closed by clicking the **X** button. Also fixed an issue in which the keyboard gets dismissed when users switch from one edit control to another within WebView2. ([Issue #460](https://github.com/MicrosoftEdge/WebView2Feedback/issues/460)) + +* Fixed an issue when using a proxy from `AddHostObjectToScript` in script. If you call `setHostProperty` and it failed, you could have received an internal error message structure rather than a JavaScript Error object. + +* Fixed regression where WebView2 would steal focus from the app when the WebView2 was made visible. ([Issue #862](https://github.com/MicrosoftEdge/WebView2Feedback/issues/862)) + +* Fixed a bug that caused increased memory usage with `WebResourceRequested` events using large data. ([Issue #2171](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2171)) + +* Fixed `StatusBarTextChanged` regression. The [StatusBarText API](/microsoft-edge/webview2/reference/win32/icorewebview2_12?view=webview2-1.0.1245.22&preserve-view=true) was made compatible with previous versions again. ([Issue #2414](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2414)) + +* Better support for apps running as admin. ([Issue #2356](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2356)) + + + + + +## Prerelease SDK 1.0.1243-prerelease, for Runtime 102 (May 2, 2022) + + +This SDK was last updated May 2, 2022. + +[NuGet package for WebView2 SDK 1.0.1243-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1243-prerelease) + +This package has been deprecated, because it has critical bugs. See [Issue 2414](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2414). + + -## 1.0.1222-prerelease +## Prerelease SDK 1.0.1222-prerelease, for Runtime 102 (Apr. 12, 2022) -Release Date: April 12, 2022 +Release Date: Apr. 12, 2022 [NuGet package for WebView2 SDK 1.0.1222-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1222-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 102.0.1222.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 102.0.1222.0 or higher. + -#### General + +#### Experimental APIs for 1.0.1222-prerelease + + -###### Experimental features +The following Experimental APIs have been added in this Prerelease SDK. * Added the [Server Certificate API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental15?view=webview2-1.0.1222-prerelease&preserve-view=true) which provides an option to trust the server's TLS certificate at the application level and render the page without prompting the user about TLS or providing the ability to cancel the web request. * Added the [Favicon API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental12?view=webview2-1.0.1222-prerelease&preserve-view=true) which provides a way to get the favicon when it changes or is set at a website. -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * Support for [multiple user profiles](/microsoft-edge/webview2/reference/win32/icorewebview2environment10?view=webview2-1.0.1222-prerelease&preserve-view=true) in WebView2. @@ -2678,7 +9980,9 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * [Default Download API](/microsoft-edge/webview2/reference/win32/icorewebview2profile?view=webview2-1.0.1222-prerelease&viewFallbackFrom=webview2-1.0.1185.39&preserve-view=true) which provides a way to customize the default download location. -###### Bug fixes + + +#### Bug fixes * Fixed `ZoomFactor` issue that incorrectly sets `ZoomFactor` value to the maximum value when it is out of bounds. @@ -2688,49 +9992,78 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * Fixed log in issue caused by a password regression in WebView2. ([Issue #2291](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2291)) -* Fixed a failure caused when a user opens a new app window and the web page does not have a navigation entry assigned. +* Fixed a failure caused when a user opens a new app window and the webpage does not have a navigation entry assigned. * Made a runtime change to fix a bug in WinUI 2 (UWP) in which owned windows were not showing up. * Fixed `ICoreWebView2Frame::PostWebMessage` functionality after source update. ([Issue #2267](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2267)) + + -## 1.0.1150.38 +## Release SDK 1.0.1210.39, for Runtime 101 (May 9, 2022) + +Release Date: May 9, 2022 + +[NuGet package for WebView2 SDK 1.0.1210.39](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1210.39) -Release Date: March 10, 2022 +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 101.0.1210.39 or higher. -[NuGet package for WebView2 SDK 1.0.1150.38](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1150.38) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 99.0.1150.38 or higher. + +#### Promotions to Phase 3 (Stable in Release) -#### General +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -###### Promotions +* Support for [multiple user profiles](/microsoft-edge/webview2/reference/win32/icorewebview2environment10?view=webview2-1.0.1210.39&preserve-view=true) in WebView2. -The following APIs have been promoted to Stable and are now included in this Release SDK. +* [Theming API](/microsoft-edge/webview2/reference/win32/icorewebview2profile?view=webview2-1.0.1210.39&preserve-view=true) which provides a way to customize the WebView2 color theme as `light`, `dark`, or `system`. -* The [BasicAuthentication API](/microsoft-edge/webview2/reference/win32/icorewebview2_10?view=webview2-1.0.1150.38&preserve-view=true) that enables developers to handle Basic HTTP Authentication request and response. +* [Default Download API](/microsoft-edge/webview2/reference/win32/icorewebview2profile?view=webview2-1.0.1210.39&preserve-view=true) which provides a way to customize the default download location. + + + + + +## Release SDK 1.0.1210.30, for Runtime 101 (May 5, 2022) + + +This SDK was last updated May 5, 2022. + +[NuGet package for WebView2 SDK 1.0.1210.30](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1210.30) + +This package has been deprecated, because it has critical bugs. See [Issue 2414](https://github.com/MicrosoftEdge/WebView2Feedback/issues/2414). + + -## 1.0.1189-prerelease +## Prerelease SDK 1.0.1189-prerelease, for Runtime 100 (Mar. 10, 2022) -Release Date: March 10, 2022 +Release Date: Mar. 10, 2022 [NuGet package for WebView2 SDK 1.0.1189-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1189-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 100.0.1189.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 100.0.1189.0 or higher. + -#### General + +#### Experimental APIs (Phase 1: Experimental in Prerelease) -###### Experimental features +The following Experimental APIs have been added in this Prerelease SDK. * Added [ContextMenuRequested API](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1189-prerelease&preserve-view=true) to enable host app to create or modify their own context menu. -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * The [CallDevToolsProtocolMethodForSession API](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1189-prerelease&preserve-view=true#calldevtoolsprotocolmethodforsession) that supports sessionId for CDP method calls. * The [StatusBarText API](/microsoft-edge/webview2/reference/win32/icorewebview2_12?view=webview2-1.0.1189-prerelease&preserve-view=true): @@ -2741,456 +10074,670 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * The [HiddenPdfToolbarItems API](/microsoft-edge/webview2/reference/win32/icorewebview2settings7?view=webview2-1.0.1189-prerelease&preserve-view=true) is available to customize the PDF toolbar items. * The [ExclusiveUserDataFolderAccess API](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions2?view=webview2-1.0.1189-prerelease&preserve-view=true) allows control of whether or not other processes can create WebView2 using the same user data folder. -###### Bug fixes + + +#### Bug fixes * Fixed a bug where WebView2 app gets stuck occasionally with UWP. + * Fixed a bug where focus is not returned to the application after closing the **Find** bar for windowed mode. + * Fixed bug in which the `DocumentTitleChanged` event was not being raised for backward/forward navigation in single-page apps. + * Fixed bug in which the `HistoryChanged` event was not being raised for Iframe navigation. + + -## 1.0.1108.44 +## Release SDK 1.0.1185.39, for Runtime 100 (Apr. 12, 2022) -Release Date: February 6, 2022 +Release Date: Apr. 12, 2022 -[NuGet package for WebView2 SDK 1.0.1108.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1108.44) +[NuGet package for WebView2 SDK 1.0.1185.39](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1185.39) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 98.0.1108.44 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 100.0.1185.39 or higher. -#### General -###### Promotions + +#### General features -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Renamed `ICoreWebView2Certificate` to `ICoreWebView2ClientCertificate`. -* The [AdditionalAllowedFrameAncestors API](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs2?view=webview2-1.0.1108.44&preserve-view=true) that enable developers to provide additional allowed frame ancestors. -* The [ProcessInfo APIs](/microsoft-edge/webview2/reference/win32/icorewebview2processinfo?view=webview2-1.0.1108.44&preserve-view=true) provide more information about WebView2 processes and process collections. + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + +* The [CallDevToolsProtocolMethodForSession API](/microsoft-edge/webview2/reference/win32/icorewebview2_11?view=webview2-1.0.1185.39&preserve-view=true#calldevtoolsprotocolmethodforsession) that supports `sessionId` for CDP method calls. + +* The [StatusBarText API](/microsoft-edge/webview2/reference/win32/icorewebview2_12?view=webview2-1.0.1185.39&preserve-view=true): + * `add_StatusBarTextChanged` + * `get_StatusBarText` + * `remove_StatusBarTextChanged` + +* The [AllowExternalDrop API](/microsoft-edge/webview2/reference/win32/icorewebview2controller4?view=webview2-1.0.1185.39&preserve-view=true) that supports enable/disable for external drop operations. -* New [APIs for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2frame2?view=webview2-1.0.1108.44&preserve-view=true&preserve-view=true): - * `add_NavigationStarting` - * `remove_NavigationStarting` - * `add_ContentLoading` - * `remove_ContentLoading` - * `add_NavigationCompleted` - * `remove_NavigationCompleted` - * `add_DOMContentLoaded` - * `remove_DOMContentLoaded` - * `ExecuteScript` - * `PostWebMessageAsJson` - * `PostWebMessageAsString` - * `add_WebMessageReceived` - * `remove_WebMessageReceived` +* The [HiddenPdfToolbarItems API](/microsoft-edge/webview2/reference/win32/icorewebview2settings7?view=webview2-1.0.1185.39&preserve-view=true) is available to customize PDF toolbar items. + +* The [ExclusiveUserDataFolderAccess API](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions2?view=webview2-1.0.1185.39&preserve-view=true) allows control of whether or not other processes can create WebView2 from `WebView2Environment` created with the same user data folder and therefore sharing the same WebView browser process instance. + +* The [permission requested support for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2frame3?view=webview2-1.0.1185.39&preserve-view=true): + * `add_PermissionRequested` + * `remove_PermissionRequested` + + -## 1.0.1158-prerelease +## Prerelease SDK 1.0.1158-prerelease, for Runtime 100 (Feb. 6, 2022) -Release Date: February 6, 2022 +Release Date: Feb. 6, 2022 [NuGet package for WebView2 SDK 1.0.1158-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1158-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 100.0.1158.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 100.0.1158.0 or higher. -#### General -###### Experimental features + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. * Added [Status bar API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental13?view=webview2-1.0.1158-prerelease&preserve-view=true) to provide info when webiew is showing status message, URL, or empty string. + * Added [CDP API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental14?view=webview2-1.0.1158-prerelease&preserve-view=true) to provide possibility for developers have multiple `DevToolsProtocol` targets in WebView2. -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * Rename ICoreWebView2ClientCertificate to [ICoreWebView2Certificate](/microsoft-edge/webview2/reference/win32/icorewebview2certificate?view=webview2-1.0.1158-prerelease&preserve-view=true). * New [APIs for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2frame3?view=webview2-1.0.1158-prerelease&preserve-view=true): - * `add_PermissionRequested` - * `remove_PermissionRequested` + * `add_PermissionRequested` + * `remove_PermissionRequested` -###### Bug fixes + + +#### Bug fixes * Fixed an issue causing erroneous warnings in the Visual Studio Error List window. ([Issue #1722](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1722)) + * Fixed a bug where NewWindowRequested was not getting raised when opening PDF downloads. + * Resolved a bug in WinUI 3 where select dropdowns would not show up. ([Issue #1693](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1693)) + * Added the ability to toggle WebView2 mute state, even when there is no audio playing. + + -## 1.0.1072.54 +## Release SDK 1.0.1150.38, for Runtime 99 (Mar. 10, 2022) -Release Date: January 13, 2022 +Release Date: Mar. 10, 2022 -[NuGet package for WebView2 SDK 1.0.1072.54](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1072.54) +[NuGet package for WebView2 SDK 1.0.1150.38](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1150.38) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 97.0.1072.54 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 99.0.1150.38 or higher. -#### General -###### Promotions + +#### Promotions to Phase 3 (Stable in Release) -The following APIs have been promoted to Stable and are now included in this Release SDK. +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -* The [Media API](/microsoft-edge/webview2/reference/win32/icorewebview2_8?view=webview2-1.0.1072.54&preserve-view=true#summary) that enables developers to mute/unmute media within WebView2. +* The [BasicAuthentication API](/microsoft-edge/webview2/reference/win32/icorewebview2_10?view=webview2-1.0.1150.38&preserve-view=true) that enables developers to handle Basic HTTP Authentication request and response. -* The [Download Positioning and Anchoring API](/microsoft-edge/webview2/reference/win32/icorewebview2_9?view=webview2-1.0.1072.54&preserve-view=true) enables: - * Changing the position of the download dialog, relative to the WebView2 bounds. You can anchor the download dialog to the **Download** button, instead of the default position, which is the top-right corner. - * Programmatically open and close the default download dialog. - * Making changes in response to the dialog opening and closing. + -## 1.0.1133-prerelease +## Prerelease SDK 1.0.1133-prerelease, for Runtime 99 (Jan. 13, 2022) -Release Date: January 13, 2022 +Release Date: Jan. 13, 2022 [NuGet package for WebView2 SDK 1.0.1133-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1133-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 99.0.1133.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 99.0.1133.0 or higher. + -#### General + +#### Experimental APIs (Phase 1: Experimental in Prerelease) -###### Experimental features +The following Experimental APIs have been added in this Prerelease SDK. * Added support for [theming](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile2?view=webview2-1.0.1133-prerelease&preserve-view=true) (overall color scheme - light, dark, system) of WebView2. + * Added a way to set [default download path](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile3?view=webview2-1.0.1133-prerelease&preserve-view=true). + * Added support for [clearing browser data](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprofile4?view=webview2-1.0.1133-prerelease&preserve-view=true). + * Added [permission requested](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe3?view=webview2-1.0.1133-prerelease&preserve-view=true) support for iframes. -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * New [APIs for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe2?view=webview2-1.0.1133-prerelease&preserve-view=true): - * `PostWebMessageAsJson` - * `PostWebMessageAsString` - * `add_WebMessageReceived` - * `remove_WebMessageReceived` + * `PostWebMessageAsJson` + * `PostWebMessageAsString` + * `add_WebMessageReceived` + * `remove_WebMessageReceived` * The ProcessInfo APIs provides more information about WebView2 [processes](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessinfo?view=webview2-1.0.1133-prerelease&preserve-view=true) and [process collections](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessinfocollection?view=webview2-1.0.1133-prerelease&preserve-view=true). * The [HTTP Authentication API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental10?view=webview2-1.0.1133-prerelease&preserve-view=true). -###### Bug fixes + + +#### Bug fixes * Fixed a bug that prevented `Set-Cookies` header from showing up in the `WebResourceResponseReceived` event. + * Resolved a bug where pop-ups and owned windows would jump to a different position before closing instead of closing - along with the app window. This bug was only active for a very short window of time. +along with the app window. This bug was only active for a very short window of time. + * Fixed focus issue after closing file picker dialog. + * Fixed bug where Find on Page UI visibility did not change with WebView2 visibility. + * Fixed bug where `GetAvailableBrowserVersionString()` fails to locate/load `WebView2Loader.dll`. ([Issue #1236](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1236)) + * Fixed size and position of the new window created with `window.open` when `NewWindowRequested` event was not - handled. ([Issue #1343](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1343)) +handled. ([Issue #1343](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1343)) + * Fixed bug where mini menu was still displaying on selected text when context menus were disabled. This change is Runtime-specific. ([Issue #1345](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1345)) + * Fixed bug where focus returns to wrong location after switching apps in WinForms. + + + + +## Release SDK 1.0.1108.44, for Runtime 98 (Feb. 6, 2022) + +Release Date: Feb. 6, 2022 + +[NuGet package for WebView2 SDK 1.0.1108.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1108.44) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 98.0.1108.44 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + +* The [AdditionalAllowedFrameAncestors API](/microsoft-edge/webview2/reference/win32/icorewebview2navigationstartingeventargs2?view=webview2-1.0.1108.44&preserve-view=true) that enable developers to provide additional allowed frame ancestors. + +* The [ProcessInfo APIs](/microsoft-edge/webview2/reference/win32/icorewebview2processinfo?view=webview2-1.0.1108.44&preserve-view=true) provide more information about WebView2 processes and process collections. + +* New [APIs for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2frame2?view=webview2-1.0.1108.44&preserve-view=true): + * `add_NavigationStarting` + * `remove_NavigationStarting` + * `add_ContentLoading` + * `remove_ContentLoading` + * `add_NavigationCompleted` + * `remove_NavigationCompleted` + * `add_DOMContentLoaded` + * `remove_DOMContentLoaded` + * `ExecuteScript` + * `PostWebMessageAsJson` + * `PostWebMessageAsString` + * `add_WebMessageReceived` + * `remove_WebMessageReceived` + + + -## 1.0.1083-prerelease +## Prerelease SDK 1.0.1083-prerelease, for Runtime 97 (Nov. 29, 2021) -Release Date: November 29, 2021 +Release Date: Nov. 29, 2021 [NuGet package for WebView2 SDK 1.0.1083-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1083-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 97.0.1083.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 97.0.1083.0 or higher. -#### Experimental features + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. * Added the following [APIs for iframes](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe2?view=webview2-1.0.1083-prerelease&preserve-view=true) in WebView2: - * `PostWebMessageAsJson` - * `PostWebMessageAsString` - * `add_WebMessageReceived` - * `remove_WebMessageReceived` + * `PostWebMessageAsJson` + * `PostWebMessageAsString` + * `add_WebMessageReceived` + * `remove_WebMessageReceived` * Added ProcessInfo APIs to provide more information about WebView2 [processes](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessinfo?view=webview2-1.0.1083-prerelease&preserve-view=true) and [process collections](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprocessinfocollection?view=webview2-1.0.1083-prerelease&preserve-view=true). -#### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * The [Media API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental9?view=webview2-1.0.1083-prerelease&preserve-view=true#summary) that enables developers to mute/unmute media within WebView2. * The [Download Positioning and Anchoring API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental11?view=webview2-1.0.1083-prerelease&preserve-view=true). This API enables: - * Changing the position of the download dialog, relative to the WebView2 bounds. You can anchor the download dialog to the **Download** button, instead of the default position, which is the top-right corner. - * Programmatically opening and closing the default download dialog. - * Making changes in response to the dialog opening and closing. + * Changing the position of the download dialog, relative to the WebView2 bounds. You can anchor the download dialog to the **Download** button, instead of the default position, which is the top-right corner. + * Programmatically opening and closing the default download dialog. + * Making changes in response to the dialog opening and closing. + + #### Bug fixes * Fixed a focus issue after closing the file picker dialog. + * Fixed a bug where WebView2 doesn't receive spatial input on initial launch. + * Fixed an issue that prevented single sign-on in WebView2. + * Resolved a bug where the download dialog was not moving with the window on WPF and WinForms. + * Updated compatible command line check to prevent needing a version check for optional switches. + * Fixed an error that was causing "Microsoft Edge" branding to appear in the accessibility tree. + + -## 1.0.1054.31 +## Release SDK 1.0.1072.54, for Runtime 97 (Jan. 13, 2022) -Release Date: November 29, 2021 +Release Date: Jan. 13, 2022 -[NuGet package for WebView2 SDK 1.0.1054.31](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1054.31) +[NuGet package for WebView2 SDK 1.0.1072.54](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1072.54) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 96.0.1054.31 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 97.0.1072.54 or higher. -#### General -* General reliability fixes. + +#### Promotions to Phase 3 (Stable in Release) -#### Bug fixes +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -* Turned off the Control-flow Enforcement Technology (CET) Shadow Stack feature for v96 WebView2 Runtime. -* Fixed an issue that was causing slow startup times when launching in a .NET single-file application. ([Issue #1909](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1909)) -* Fixed a crash caused by Microsoft Edge browser policies getting incorrectly applied to WebView2 as well. ([Issue #1860](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1860)) -* Fixed a crash that occurred when a pop-up window with a download dialog was closed. ([Issue #1765](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1765)) & ([Issue #1723](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1723)) +* The [Media API](/microsoft-edge/webview2/reference/win32/icorewebview2_8?view=webview2-1.0.1072.54&preserve-view=true#summary) that enables developers to mute/unmute media within WebView2. + +* The [Download Positioning and Anchoring API](/microsoft-edge/webview2/reference/win32/icorewebview2_9?view=webview2-1.0.1072.54&preserve-view=true) enables: + * Changing the position of the download dialog, relative to the WebView2 bounds. You can anchor the download dialog to the **Download** button, instead of the default position, which is the top-right corner. + * Programmatically open and close the default download dialog. + * Making changes in response to the dialog opening and closing. + + -## 1.0.1056-prerelease +## Prerelease SDK 1.0.1056-prerelease, for Runtime 97 (Oct. 29, 2021) -Release Date: October 29, 2021 +Release Date: Oct. 29, 2021 [NuGet package for WebView2 SDK 1.0.1056-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1056-prerelease) -For full API compatibility, this version of the WebView2 SDK requires Microsoft Edge version 97.0.1056.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires the WebView2 Runtime that ships with Microsoft Edge version 97.0.1056.0 or higher. -#### General -* General reliability improvements. + +#### Experimental APIs (Phase 1: Experimental in Prerelease) -###### Experimental features +The following Experimental APIs have been added in this Prerelease SDK. + + * The [Download Positioning and Anchoring API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental11?view=webview2-1.0.1056-prerelease&preserve-view=true). This API enables: - * Changing the position of the download dialog, relative to the WebView2 bounds. You can anchor the download dialog to the **Download** button, instead of the default position, which is the top-right corner. - * Programmatically opening and closing the default download dialog. - * Making changes in response to the dialog opening and closing. + * Changing the position of the download dialog, relative to the WebView2 bounds. You can anchor the download dialog to the **Download** button, instead of the default position, which is the top-right corner. + * Programmatically opening and closing the default download dialog. + * Making changes in response to the dialog opening and closing. + + + * The [HTTP Authentication API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental10?view=webview2-1.0.1056-prerelease&preserve-view=true). -###### Bug fixes + + +#### Bug fixes + +* General reliability improvements. * The real process exit code is now provided as `ExitCode` in `ICoreWebView2ProcessFailedEventArgs2` for `COREWEBVIEW2_PROCESS_FAILED_KIND_BROWSER_PROCESS_EXITED` process failure. + * The `--js-flags` switch is now honored in the `AdditionalBrowserArguments` that are provided in `CoreWebView2EnvironmentOptions`. + * Fixed access to the `name` property for host objects in JavaScript. ([Issue #641](https://github.com/MicrosoftEdge/WebView2Feedback/issues/641)) + * Fixed an `InvalidCastException` in the WPF control when it's implicitly initialized prior to the event loop starting. ([Issue #1577](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1577)) + + -## 1.0.1020.30 +## Release SDK 1.0.1054.31, for Runtime 96 (Nov. 29, 2021) -Release Date: October 25, 2021 +Release Date: Nov. 29, 2021 -[NuGet package for WebView2 SDK 1.0.1020.30](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1020.30) +[NuGet package for WebView2 SDK 1.0.1054.31](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1054.31) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 95.0.1020.30 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 96.0.1054.31 or higher. -#### General -###### Bug fixes + +#### Bug fixes -* Updated `EnsureCoreWebView2Async` to not throw exceptions when the WPF source property is set. ([Issue #1781](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1781)) -* Fixed a bug where WebView2 crashes after interacting with multiple windows that show a download UI. ([Issue #1723](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1723)) +* General reliability fixes. + +* Turned off the Control-flow Enforcement Technology (CET) Shadow Stack feature for v96 WebView2 Runtime. -###### Promotions +* Fixed an issue that was causing slow startup times when launching in a .NET single-file application. ([Issue #1909](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1909)) -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Fixed a crash caused by Microsoft Edge browser policies getting incorrectly applied to WebView2 as well. ([Issue #1860](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1860)) -* [PrintToPdf API](/microsoft-edge/webview2/reference/win32/icorewebview2_7?view=webview2-1.0.1020.30&preserve-view=true#printtopdf). +* Fixed a crash that occurred when a pop-up window with a download dialog was closed. ([Issue #1765](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1765)) & ([Issue #1723](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1723)) + + -## 1.0.992.28 +## Release SDK 1.0.1020.30, for Runtime 95 (Oct. 25, 2021) -Release Date: September 27, 2021 +Release Date: Oct. 25, 2021 -[NuGet package for WebView2 SDK 1.0.992.28](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.992.28) +[NuGet package for WebView2 SDK 1.0.1020.30](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1020.30) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 95.0.1020.30 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 94.0.992.31 or higher. +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -#### General +* [PrintToPdf API](/microsoft-edge/webview2/reference/win32/icorewebview2_7?view=webview2-1.0.1020.30&preserve-view=true#printtopdf). -###### Bug fixes -* Fixed missing WebView2 DLLs (which led to initialization failure) when `PlatformTarget` isn't set in the user's .NET project. ([Issue #1061](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1061)) + +#### Bug fixes -###### Promotions +* Updated `EnsureCoreWebView2Async` to not throw exceptions when the WPF source property is set. ([Issue #1781](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1781)) -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Fixed a bug where WebView2 crashes after interacting with multiple windows that show a download UI. ([Issue #1723](https://github.com/MicrosoftEdge/WebView2Feedback/issues/1723)) -* [OpenTaskManagerWindow API](/microsoft-edge/webview2/reference/win32/icorewebview2_6?view=webview2-1.0.992.28&preserve-view=true#summary). -* [isSwipeNavigationEnabled property](/microsoft-edge/webview2/reference/win32/icorewebview2settings6?view=webview2-1.0.992.28&preserve-view=true#summary). -* [BrowserProcessExited API](/microsoft-edge/webview2/reference/win32/icorewebview2browserprocessexitedeventargs?view=webview2-1.0.992.28&preserve-view=true#summary). -* [get_Name property](/microsoft-edge/webview2/reference/win32/icorewebview2newwindowrequestedeventargs2?view=webview2-1.0.992.28#get_name&preserve-view=true#summary) on `ICoreWebView2NewWindowRequestedEventArgs2` interface. + -## 1.0.1018-prerelease +## Prerelease SDK 1.0.1018-prerelease, for Runtime 95 (Sep. 20, 2021) -Release Date: September 20, 2021 +Release Date: Sep. 20, 2021 [NuGet package for WebView2 SDK 1.0.1018-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1018-prerelease) -For full API compatibility, this prerelease version of the WebView2 SDK requires Microsoft Edge version 95.0.1018.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires Microsoft Edge version 95.0.1018.0 or higher. + -#### General + +#### Experimental APIs (Phase 1: Experimental in Prerelease) -###### Experimental features +The following Experimental APIs have been added in this Prerelease SDK. * Added a [media API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental9?view=webview2-1.0.1018-prerelease&preserve-view=true#summary) that enables developers to mute/unmute media within WebView2. + * Added support for [multiple user profiles](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment8?view=webview2-1.0.1018-prerelease&preserve-view=true) with WebView2. -###### Bug fixes + + +#### Bug fixes * Fixed a bug where WebView2 stops rendering when the app is spanning monitors and the monitor scale changes. -* Fixed a bug where closing the download UI crashes WebView2 when multiple download windows are open. ([Issue #1723](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1723)) -* Fixed a build/initialization error when PlatformTarget isn't set in the user's .NET project. ([Issue #730](https://github.com/MicrosoftEdge/WebViewFeedback/issues/730) and [Issue #1548](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1548)) + +* Fixed a bug where closing the download UI crashes WebView2 when multiple download windows are open. ([Issue #1723](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1723)) + +* Fixed a build/initialization error when PlatformTarget isn't set in the user's .NET project. ([Issue #730](https://github.com/MicrosoftEdge/WebViewFeedback/issues/730) and [Issue #1548](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1548)) + + -## 1.0.1010-prerelease +## Prerelease SDK 1.0.1010-prerelease, for Runtime 95 (Sep. 14, 2021) -Release Date: September 14, 2021 +Release Date: Sep. 14, 2021 [NuGet package for WebView2 SDK 1.0.1010-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.1010-prerelease) -For full API compatibility, this prerelease version of the WebView2 SDK requires Microsoft Edge version 95.0.1010.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires Microsoft Edge version 95.0.1010.0 or higher. + + + +#### General features -#### General * WebView2 performance improvements. -* Reliability fixes. ([Issue #1605](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1605) and [Issue #1678](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1678)) +* Reliability fixes. ([Issue #1605](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1605) and [Issue #1678](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1678)) * Added performance improvements during startup and when the host app is in the foreground. -###### Experimental features + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. * Removed silent failures by using `EnsureCoreWebView2Async`, which throws an `ArgumentException` when called multiple times with incompatible parameters. + * Changed default handling of the [UserDataFolder](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment5?view=webview2-1.0.1010-prerelease&preserve-view=true#get_userdatafolder) property in the environment object. > [!CAUTION] > **Breaking Change**: The default handling for the user data folder, if the developer doesn't specify where to put it, will be changing. See [Announcement: User directory folder default handling updates](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1410). * Added [navigation & script APIs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe?view=webview2-1.0.1010-prerelease&preserve-view=true) for iframes. + * Added [MemoryUsageTargetLevel](/microsoft-edge/webview2/reference/win32/icorewebview2experimental5?view=webview2-1.0.1010-prerelease&preserve-view=true) which allows developers to specify memory consumption levels, such as low, or normal. + * Added [ExclusiveUserDataFolderAccess](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-1.0.1010-prerelease&preserve-view=true) to environment options. + * Added [HiddenPdfToolbarItems](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings6?view=webview2-1.0.1010-prerelease&preserve-view=true) to customize PDF toolbar items. + * Added [PrintToPdf](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalprinttopdfcompletedhandler?view=webview2-1.0.1010-prerelease&preserve-view=true), which allows printing the current page to PDF. Also, you can use optional custom settings with this new API. * Added [AllowExternalDrop](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller3?view=webview2-1.0.1010-prerelease&preserve-view=true) property to allow the dragging and dropping of objects from outside a WebView2 control into it. + * Added [ContextMenu APIs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontextmenuitem?view=webview2-1.0.1010-prerelease&preserve-view=true) which allow customization of the WebView2 context menu. -###### Bug fixes + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + +* `IsSwipeNavigationEnabled` +* `BrowserProcessExited` +* `OpenBrowserTaskManager` + + + +#### Bug fixes * Improved how host objects exceptions are caught in your JavaScript code. + * Replaced WebView2 icon with a generic icon in DevTools windows. + * Turn on the Tab screen sharing option when `MediaDevices.getDisplayMedia()` is used. ([Issue #1566](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1566)) + * Fixed a bug in the Client Certificate API, when the correct certificate was not selected. This is a Runtime change. ([Issue #1666](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1666)) + * Fixed bug where `window.chrome.webview` was unavailable in new windows in the same parent domain. This change is Runtime-specific. ([Issue #1144](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1144)) + * Fixed a bug where dropdown menus or lists were displayed behind the window that has focus. ([Issue #411](https://github.com/MicrosoftEdge/WebViewFeedback/issues/411)) + * Fixed focus issues when using `put_IsVisible(false)`. ([Issue #238](https://github.com/MicrosoftEdge/WebViewFeedback/issues/238)) + * Fixed a bug to apply `SetVirtualHostNameToFolderMapping` to pop-up windows. + * Fixed bugs where an `IDispatch` objects were returned as `IUnknown`. -###### Promotions + -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. -* `IsSwipeNavigationEnabled` -* `BrowserProcessExited` -* `OpenBrowserTaskManager` + +## Release SDK 1.0.992.28, for Runtime 94 (Sep. 27, 2021) + +Release Date: Sep. 27, 2021 + +[NuGet package for WebView2 SDK 1.0.992.28](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.992.28) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 94.0.992.31 or higher. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + +* [OpenTaskManagerWindow API](/microsoft-edge/webview2/reference/win32/icorewebview2_6?view=webview2-1.0.992.28&preserve-view=true#summary). +* [isSwipeNavigationEnabled property](/microsoft-edge/webview2/reference/win32/icorewebview2settings6?view=webview2-1.0.992.28&preserve-view=true#summary). +* [BrowserProcessExited API](/microsoft-edge/webview2/reference/win32/icorewebview2browserprocessexitedeventargs?view=webview2-1.0.992.28&preserve-view=true#summary). +* [get_Name property](/microsoft-edge/webview2/reference/win32/icorewebview2newwindowrequestedeventargs2?view=webview2-1.0.992.28#get_name&preserve-view=true#summary) on `ICoreWebView2NewWindowRequestedEventArgs2` interface. + + + +#### Bug fixes + +* Fixed missing WebView2 DLLs (which led to initialization failure) when `PlatformTarget` isn't set in the user's .NET project. ([Issue #1061](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1061)) + + -## 1.0.961.33 +## Release SDK 1.0.961.33, for Runtime 93 (Sep. 8, 2021) -Release Date: September 8, 2021 +Release Date: Sep. 8, 2021 [NuGet package for WebView2 SDK 1.0.961.33](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.961.33) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 93.0.961.44 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 93.0.961.44 or higher. -#### General -###### Bug fixes + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + +* [Client Certificate API](/microsoft-edge/webview2/reference/win32/icorewebview2_5?view=webview2-1.0.961.33&preserve-view=true#add_clientcertificaterequested). + + + +#### Bug fixes + * Fixed a bug that caused `ERR_SSL_CLIENT_AUTH_CERT_NEEDED` errors. This is a Runtime change. + * Fixed a bug that special browser keys like **Refresh**, **Home**, **Back**, and so on can't be turned off using `AreBrowserAcceleratorKeysEnabled`. This change is Runtime-specific. + * Fixed a bug where the transparent background color isn't rendered. + * Fixed a bug that caused a white flicker when loading WebView2. -* Fixed a bug in WebView2 .NET controls where WebView2 windows were blank when created in the background. ([Issue #1077](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1077)) -* Fixed a bug where settings were not updated when the user navigated to or a new window displayed `about:blank` pages. This is a Runtime change. -###### Promotions +* Fixed a bug in WebView2 .NET controls where WebView2 windows were blank when created in the background. ([Issue #1077](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1077)) -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Fixed a bug where settings were not updated when the user navigated to or a new window displayed `about:blank` pages. This is a Runtime change. -* [Client Certificate API](/microsoft-edge/webview2/reference/win32/icorewebview2_5?view=webview2-1.0.961.33&preserve-view=true#add_clientcertificaterequested). + -## 1.0.955-prerelease +## Prerelease SDK 1.0.955-prerelease, for Runtime 93 (Jul. 26, 2021) -Release Date: July 26, 2021 +Release Date: Jul. 26, 2021 [NuGet package for WebView2 SDK 1.0.955-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.955-prerelease) -For full API compatibility, this prerelease version of the WebView2 SDK requires Microsoft Edge version 93.0.967.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires Microsoft Edge version 93.0.967.0 or higher. + + + +#### General features -#### General * WebView2 performance improvements. * Added partial Event Tracing for Windows (ETW) support. * Removed Microsoft branding from `edge://history`. * New default Download UI. -###### Experimental features + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) * Added [OpenTaskManagerWindow](/microsoft-edge/webview2/reference/win32/icorewebview2experimental4?view=webview2-1.0.955-prerelease&preserve-view=true#opentaskmanagerwindow) to launch a WebView2 browser task manager. + * Added [NewWindowRequestedEventArgs](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnewwindowrequestedeventargs?view=webview2-1.0.955-prerelease&preserve-view=true#get_name). -* Added support for virtual host name mapping to work with service Workers. + +* Added support for virtual host name mapping to work with service workers. + * Added [HiddenPdfToolbarItems](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings6?view=webview2-1.0.955-prerelease&preserve-view=true#get_hiddenpdftoolbaritems) to customize the PDF toolbar items. -###### Bug fixes + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + +* [add_ClientCertificateRequested](/microsoft-edge/webview2/reference/win32/icorewebview2_5?view=webview2-1.0.955-prerelease&preserve-view=true#add_clientcertificaterequested) + + + +#### Bug fixes * Fixed bug that broke the `edge://downloads` and `edge://history` pages. This change is Runtime-specific. + * Fixed bugs to improve reliability in the WebView2Loader.dll. + * Fixed bug in which `NewWindowRequested` event handler launched two windows when handling links that use `target=_blank`. + * Fixed a bug in WebView2 visual hosting that flickered before startup. + * Fixed bug when `add_WebResourceRequested` didn't work on WebView2 controls created using `add_NewWindowRequested`. ([Issue #616](https://github.com/MicrosoftEdge/WebViewFeedback/issues/616)) + * Allow the host app to set foreground on a different application in response to events including `NavigationStarting`, `AddHostObjectToScript` methods, `WebMessageReceived`, and `NewWindowRequested`. ([Issue #1092](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1092)) + * Fix bug to trigger the `PermissionRequested` event for the microphone. This change is Runtime-specific.([Issue #1462](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1462)) + * Fixed bug when `ExecuteScriptAsync` blocked after several successful runs. This change is Runtime-specific. ([Issue #1348](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1348)) -* Fixed bug preventing non-ASCII filenames from being used in `ResultFilePath` in `DownloadStartingEventArgs`. ([Issue #1428](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1428)) -* Fixed bug where the title bar on the default pop-up wasn't displayed completely. This change is Runtime-specific. ([Issue #1016](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1016)) -###### Promotions +* Fixed bug preventing non-ASCII file names from being used in `ResultFilePath` in `DownloadStartingEventArgs`. ([Issue #1428](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1428)) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +* Fixed bug where the title bar on the default pop-up wasn't displayed completely. This change is Runtime-specific. ([Issue #1016](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1016)) -* [add_ClientCertificateRequested](/microsoft-edge/webview2/reference/win32/icorewebview2_5?view=webview2-1.0.955-prerelease&preserve-view=true#add_clientcertificaterequested) + #### .NET + + ###### Bug fixes + * Fixed an issue in WebView2 .NET API reference documentation that caused only the first exception to be displayed. + * .NET core libraries are now built in release mode. To debug, ensure you clear the **Just my code** checkbox. + * Fixed a bug that crashed WebView2 on forms with child forms. The child form, with the find in page bar open, caused WebView2 to crash when the child form was closed. ([Issue #1097](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1097)) + + -## 1.0.902.49 +## Release SDK 1.0.902.49, for Runtime 92 (Jul. 26, 2021) -Release Date: July 26, 2021 +Release Date: Jul. 26, 2021 [NuGet package for WebView2 SDK 1.0.902.49](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.902.49) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 92.0.902.49 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 92.0.902.49 or higher. -#### General - -###### Bug fixes -* Fix bug that broke the `IsBuiltInErrorPageEnabled` property, which turned off the error page that's displayed when there's a navigation failure or render process failure. This change is Runtime-specific. ([Issue #634](https://github.com/MicrosoftEdge/WebViewFeedback/issues/634)) -* Fixed an issue where WebView2 controls took focus away from the user's focus. -* Fixed bug when `AddScriptToExecuteOnDocumentCreated` didn't work on child windows. ([Issue #935](https://github.com/MicrosoftEdge/WebViewFeedback/issues/935)) -* Fixed a bug that caused inactive tabs to be automatically discarded. ([Issue #637](https://github.com/MicrosoftEdge/WebViewFeedback/issues/637)) -* Fixed a bug when a navigation event was interrupted by another navigation event resulting in the Navigation ID of `NavigationCompleted` events to be incorrect. ([Issue #1142](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1142)) -###### Promotions + +#### Promotions to Phase 3 (Stable in Release) -The following APIs have been promoted to Stable and are now included in this Release SDK. +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. * [add_FrameCreated](/microsoft-edge/webview2/reference/win32/icorewebview2_4?view=webview2-1.0.902.49&preserve-view=true#add_framecreated). * [get_IsGeneralAutofillEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings4?view=webview2-1.0.902.49&preserve-view=true#get_isgeneralautofillenabled). @@ -3199,44 +10746,54 @@ The following APIs have been promoted to Stable and are now included in this Rel * [AddHostObjectToScriptWithOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2frame?view=webview2-1.0.902-prerelease&preserve-view=true#addhostobjecttoscriptwithorigins) API with iframe element support. + +#### Bug fixes + +* Fix bug that broke the `IsBuiltInErrorPageEnabled` property, which turned off the error page that's displayed when there's a navigation failure or render process failure. This change is Runtime-specific. ([Issue #634](https://github.com/MicrosoftEdge/WebViewFeedback/issues/634)) + +* Fixed an issue where WebView2 controls took focus away from the user's focus. + +* Fixed bug when `AddScriptToExecuteOnDocumentCreated` didn't work on child windows. ([Issue #935](https://github.com/MicrosoftEdge/WebViewFeedback/issues/935)) + +* Fixed a bug that caused inactive tabs to be automatically discarded. ([Issue #637](https://github.com/MicrosoftEdge/WebViewFeedback/issues/637)) + +* Fixed a bug when a navigation event was interrupted by another navigation event resulting in the Navigation ID of `NavigationCompleted` events to be incorrect. ([Issue #1142](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1142)) + + + + -## 1.0.902-prerelease +## Prerelease SDK 1.0.902-prerelease, for Runtime 92 (Jun. 1, 2021) -Release Date: June 1, 2021 +Release Date: Jun. 1, 2021 [NuGet package for WebView2 SDK 1.0.902-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.902-prerelease) -For full API compatibility, this prerelease version of the WebView2 SDK requires Microsoft Edge version 92.0.902.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires Microsoft Edge version 92.0.902.0 or higher. + -#### General + +#### General features * Improved WebView2 startup performance and disk footprint. -###### Experimental features + + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. * Added [IsSwipeNavigationEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings5?view=webview2-1.0.902-prerelease&preserve-view=true#get_isswipenavigationenabled) property to enable or disable the ability of the end user to use swiping gesture on touch input-enabled devices to navigate in WebView2. + * Added [BrowserProcessExited](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment4?view=webview2-1.0.902-prerelease&preserve-view=true#add_browserprocessexited) event. -* Added [add_ClientCertificateRequested API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental3?view=webview2-1.0.902-prerelease&preserve-view=true#add_clientcertificaterequested). It allows showing a client certificate dialog prompt if desired and enables access to required metadata to replace default client certificate dialog prompt. -###### Bug fixes +* Added [add_ClientCertificateRequested API](/microsoft-edge/webview2/reference/win32/icorewebview2experimental3?view=webview2-1.0.902-prerelease&preserve-view=true#add_clientcertificaterequested). It allows showing a client certificate dialog prompt if desired and enables access to required metadata to replace default client certificate dialog prompt. -* Fix a bug where mouse left click doesn't dismiss context menu. This change is Runtime-specific. -* Fixed a bug where WebView2 creation fails when exe files for apps sharing the same user data folder have inconsistent version info. -* Fixed a bug where special browser keys such as `Refresh`, `Home`, and `Back` can't be disabled by `AreBrowserAcceleratorKeysEnabled`. This change is Runtime-specific. -* Fixed a bug in WebView2 .NET controls, where WebView2 windows are blank when created in the background. ([Issue #1077](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1077)). -* Dismissing a file picker dialog by pressing **Enter** or **Esc** no longer crashes WPF applications using WebView2 control. ([Issue #1099](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1099)). -* Fixed a bug that [AllowSingleSignOnUsingOSPrimaryAccount](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions#get_allowsinglesignonusingosprimaryaccount) doesn't work properly with WebView2 when a `WebResourceRequested` event handler is attached. This change is Runtime-specific. ([Issue #1183](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1183)). -* Downloading a file no longer breaks WebView2 `DefaultBackgroundColor` transparency. This change is Runtime-specific. ([Issue #1108](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1108)). -* Removed screen sharing media picker message that contains Microsoft branding. ([Issue #940](https://github.com/MicrosoftEdge/WebViewFeedback/issues/940)). -* Fixed a bug in WebView2 WinForm control where hiding the parent form doesn't hide the WebView2 control ([Issue #828](https://github.com/MicrosoftEdge/WebViewFeedback/issues/828) and [Issue #1079](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1079)). -* Added static WS_CLIPCHILDREN style to WebView2's WPF windows. ([Issue #1013](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1013)). -* Fixed a bug where right-clicking a link crashes the WebView2 host app. This change is Runtime-specific. -* Fixed a reliability bug that could crash the host app process when moving to a newer Edge WebView2 Runtime version. -* **DEPRECATION**: Officially deprecated the `DefaultBackgroundColor` API for Windows 7. -###### Promotions + +#### Promotions to Phase 2 (Stable in Prerelease) -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * [Download API](/microsoft-edge/webview2/reference/win32/icorewebview2_4?view=webview2-1.0.902-prerelease&preserve-view=true#add_downloadstarting). * [PinchZoom API](/microsoft-edge/webview2/reference/win32/icorewebview2settings5?view=webview2-1.0.902-prerelease&preserve-view=true#get_ispinchzoomenabled). @@ -3246,198 +10803,267 @@ The following APIs have been promoted from Experimental to Stable in this Prerel > [!NOTE] > There is no current API to delete the locally stored general autofill and password autosave information. Please provide a control to delete the data, which will involve deleting the entire user data folder. -#### .NET -###### Bug fixes + +#### Bug fixes + +* Fix a bug where mouse left click doesn't dismiss context menu. This change is Runtime-specific. -* Fixed a bug in WebView2 WinForm control where WebView2 window visibility isn't updated properly after parent window is disposed. ([Issue #1282](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1282) and [Issue #828](https://github.com/MicrosoftEdge/WebViewFeedback/issues/828)). -* Fixed a bug in WebView2 WPF control that Source property binding in WPF OneWay binding mode isn't working properly. ([Issue #619](https://github.com/MicrosoftEdge/WebViewFeedback/issues/619) and [Issue #608](https://github.com/MicrosoftEdge/WebViewFeedback/issues/608)). +* Fixed a bug where WebView2 creation fails when exe files for apps sharing the same user data folder have inconsistent version info. +* Fixed a bug where special browser keys such as `Refresh`, `Home`, and `Back` can't be disabled by `AreBrowserAcceleratorKeysEnabled`. This change is Runtime-specific. - -## 1.0.864.35 +* Fixed a bug in WebView2 .NET controls, where WebView2 windows are blank when created in the background. ([Issue #1077](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1077)) -Release Date: May 31, 2021 +* Dismissing a file picker dialog by pressing **Enter** or **Esc** no longer crashes WPF applications using WebView2 control. ([Issue #1099](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1099)) -[NuGet package for WebView2 SDK 1.0.864.35](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.864.35) +* Fixed a bug that [AllowSingleSignOnUsingOSPrimaryAccount](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions#get_allowsinglesignonusingosprimaryaccount) doesn't work properly with WebView2 when a `WebResourceRequested` event handler is attached. This change is Runtime-specific. ([Issue #1183](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1183)) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 91.0.864.35 or higher. +* Downloading a file no longer breaks WebView2 `DefaultBackgroundColor` transparency. This change is Runtime-specific. ([Issue #1108](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1108)) -#### General +* Removed screen sharing media picker message that contains Microsoft branding. ([Issue #940](https://github.com/MicrosoftEdge/WebViewFeedback/issues/940)) -###### Bug fixes +* Fixed a bug in WebView2 WinForm control where hiding the parent form doesn't hide the WebView2 control. ([Issue #828](https://github.com/MicrosoftEdge/WebViewFeedback/issues/828) and [Issue #1079](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1079)) -* Fixed a reliability bug that could crash the host app process when moving to a newer Edge WebView2 Runtime version. -* Fixed a bug that prevented memory purge in some situations. This change is Runtime-specific. -* Fixed error in 818 SDK release package where project couldn't find the `WebView2.h` file. ([Issue #1209](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1209)). -* Fixed a bug which caused WebResourceRequested event to be dropped for some requests with binary bodies. -* Improve `NewWindowRequested` documentation. ([Issue #448](https://github.com/MicrosoftEdge/WebViewFeedback/issues/448)). +* Added static WS_CLIPCHILDREN style to WebView2's WPF windows. ([Issue #1013](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1013)). -###### Promotions +* Fixed a bug where right-clicking a link crashes the WebView2 host app. This change is Runtime-specific. -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Fixed a reliability bug that could crash the host app process when moving to a newer Edge WebView2 Runtime version. + +* **DEPRECATION**: Officially deprecated the `DefaultBackgroundColor` API for Windows 7. -* [UserAgent API](/microsoft-edge/webview2/reference/win32/icorewebview2settings2?view=webview2-1.0.864.35&preserve-view=true#get_useragent) -* [AreBrowserkeysenabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings3?view=webview2-1.0.864.35&preserve-view=true#get_arebrowseracceleratorkeysenabled) + #### .NET + + ###### Bug fixes -* Fixed a bug in WebView2 .NET controls that first header is missing when iterating `CoreWebView2WebResourceRequest` headers collection. ([Issue #1123](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1123)). +* Fixed a bug in WebView2 WinForm control where WebView2 window visibility isn't updated properly after parent window is disposed. ([Issue #1282](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1282) and [Issue #828](https://github.com/MicrosoftEdge/WebViewFeedback/issues/828)) + +* Fixed a bug in WebView2 WPF control that Source property binding in WPF OneWay binding mode isn't working properly. ([Issue #619](https://github.com/MicrosoftEdge/WebViewFeedback/issues/619) and [Issue #608](https://github.com/MicrosoftEdge/WebViewFeedback/issues/608)) + + -## 1.0.865-prerelease +## Prerelease SDK 1.0.865-prerelease, for Runtime 91 (Apr. 26, 2021) -Release Date: April 26, 2021 +Release Date: Apr. 26, 2021 [NuGet package for WebView2 SDK 1.0.865-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.865-prerelease) -For full API compatibility, this prerelease version of the WebView2 SDK requires Microsoft Edge version 91.0.865.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires Microsoft Edge version 91.0.865.0 or higher. -#### General -###### Experimental features + +#### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs have been added in this Prerelease SDK. * Added [IsPinchZoomEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings4?view=webview2-1.0.865-prerelease&preserve-view=true#ispinchzoomenabled) setting. It allows you to turn on or off page scale zoom control in a setting. + * Added Custom [add_DownloadStarting](/microsoft-edge/webview2/reference/win32/icorewebview2experimental2?view=webview2-1.0.865-prerelease&preserve-view=true#add_downloadstarting) API. It allows you to block downloads, save to a different path, and access the required metadata to build custom download UI. + * Added `iframe` element support from [AddHostObjectToScriptWithOrigins](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalframe?view=webview2-1.0.865-prerelease&preserve-view=true#addhostobjecttoscriptwithorigins). + * Added sample code for [WPF sample app](https://github.com/MicrosoftEdge/WebView2Samples/tree/main/SampleApps/WebView2WpfBrowser) to use the API to turn off browser function keys. + * Added the [UpdateRuntime](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironment3?view=webview2-1.0.865-prerelease&preserve-view=true#updateruntime) API, to easily update the WebView2 Runtime. -###### Bug fixes -* Fixed handler for a `Chromium DevTools Protocol` message with `POST` binary data in WebView2. -* Turned off the `OpenSaveAsAwareness` download UI, because it included links to `edge://settings`. ([Issue #1120](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1120)). -* Removed branding from screen share dialog. ([Issue #940](https://github.com/MicrosoftEdge/WebViewFeedback/issues/940)). -* Fixed bug where the [SetWindowDisplayAffinity](/windows/win32/api/winuser/nf-winuser-setwindowdisplayaffinity) function broke WebView2 when it stopped screen capture in an WebView2 app. ([Issue #841](https://github.com/MicrosoftEdge/WebViewFeedback/issues/841)). -* Fixed bug for composition hosting where mouse input stopped working if any pen input was sent to WebView2. -* Fixed bug that broke mouse input after any pen input. This change is Runtime-specific. + +#### Bug fixes + +* Fixed handler for a `Chromium DevTools Protocol` message with `POST` binary data in WebView2. + +* Turned off the `OpenSaveAsAwareness` download UI, because it included links to `edge://settings`. ([Issue #1120](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1120)). + +* Removed branding from screen share dialog. ([Issue #940](https://github.com/MicrosoftEdge/WebViewFeedback/issues/940)). + +* Fixed bug where the [SetWindowDisplayAffinity](/windows/win32/api/winuser/nf-winuser-setwindowdisplayaffinity) function broke WebView2 when it stopped screen capture in an WebView2 app. ([Issue #841](https://github.com/MicrosoftEdge/WebViewFeedback/issues/841)). + +* Fixed bug for composition hosting where mouse input stopped working if any pen input was sent to WebView2. + +* Fixed bug that broke mouse input after any pen input. This change is Runtime-specific. + + + +#### .NET + + + +###### Experimental APIs (Phase 1: Experimental in Prerelease) + +The following Experimental APIs for .NET have been added in this Prerelease SDK. + +* Added WebView2 designer tool to WPF Toolbox. ([Issue #210](https://github.com/MicrosoftEdge/WebViewFeedback/issues/210)). + +* Added WebView2 UI element in .NET Designer Mode. + + + +###### Bug fixes + +* Improved COM Exception descriptions by wrapping each in a more detailed .NET exception. ([Issue #338](https://github.com/MicrosoftEdge/WebViewFeedback/issues/338)). This change is Runtime-specific. + +* Fixed bug caused when you select **Tab** to shift focus caused WebView2 control to crash in Microsoft Visual Studio Tools for Office. ([Issue #589](https://github.com/MicrosoftEdge/WebViewFeedback/issues/589) and [Issue #933](https://github.com/MicrosoftEdge/WebViewFeedback/issues/933)). This change is Runtime-specific. + +* Improved .NET framework loader down level to be more robust. ([Issue #946](https://github.com/MicrosoftEdge/WebViewFeedback/issues/946)) + +* Fixed bug that caused crash when you try to refresh before first navigation completed. ([Issue #1011](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1011)) + +* Fixed initialization so navigation occurs during `CoreWebView2InitializationCompleted`. ([Issue #1050](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1050)) + +* Improved .NET browser process crash error handling. You can now recreate controls after you handle a `ProcessFailed` event, without a crash. ([Issue #996](https://github.com/MicrosoftEdge/WebViewFeedback/issues/996)) + + + + + +## Release SDK 1.0.864.35, for Runtime 91 (May 31, 2021) + +Release Date: May 31, 2021 + +[NuGet package for WebView2 SDK 1.0.864.35](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.864.35) + +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 91.0.864.35 or higher. + + + +#### Bug fixes + +* Fixed a reliability bug that could crash the host app process when moving to a newer Edge WebView2 Runtime version. -#### .NET +* Fixed a bug that prevented memory purge in some situations. This change is Runtime-specific. -###### Experimental features +* Fixed error in 818 SDK release package where project couldn't find the `WebView2.h` file. ([Issue #1209](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1209)). -* Added WebView2 designer tool to WPF Toolbox. ([Issue #210](https://github.com/MicrosoftEdge/WebViewFeedback/issues/210)). -* Added WebView2 UI element in .NET Designer Mode. +* Fixed a bug which caused WebResourceRequested event to be dropped for some requests with binary bodies. -###### Bug fixes +* Improve `NewWindowRequested` documentation. ([Issue #448](https://github.com/MicrosoftEdge/WebViewFeedback/issues/448)). -* Improved COM Exception descriptions by wrapping each in a more detailed .NET exception. ([Issue #338](https://github.com/MicrosoftEdge/WebViewFeedback/issues/338)). This change is Runtime-specific. -* Fixed bug caused when you select **Tab** to shift focus caused WebView2 control to crash in Microsoft Visual Studio Tools for Office. ([Issue #589](https://github.com/MicrosoftEdge/WebViewFeedback/issues/589) and [Issue #933](https://github.com/MicrosoftEdge/WebViewFeedback/issues/933)). This change is Runtime-specific. -* Improved .NET framework loader down level to be more robust. ([Issue #946](https://github.com/MicrosoftEdge/WebViewFeedback/issues/946)). -* Fixed bug that caused crash when you try to refresh before first navigation completed. ([Issue #1011](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1011)). -* Fixed initialization so navigation occurs during `CoreWebView2InitializationCompleted`. ([Issue #1050](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1050)). -* Improved .NET browser process crash error handling. You can now recreate controls after you handle a `ProcessFailed` event, without a crash. ([Issue #996](https://github.com/MicrosoftEdge/WebViewFeedback/issues/996)). + +#### Promotions to Phase 3 (Stable in Release) - -## 1.0.818.41 +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -Release Date: April 21, 2021 +* [UserAgent API](/microsoft-edge/webview2/reference/win32/icorewebview2settings2?view=webview2-1.0.864.35&preserve-view=true#get_useragent) +* [AreBrowserkeysenabled](/microsoft-edge/webview2/reference/win32/icorewebview2settings3?view=webview2-1.0.864.35&preserve-view=true#get_arebrowseracceleratorkeysenabled) -[NuGet package for WebView2 SDK 1.0.818.41](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.818.41) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 90.0.818.41 or higher. + +#### .NET -#### General -###### Features + +###### Bug fixes -* Extended the `ProcessFailed` event. It now raises for non-renderer child processes and frame renderers. -* Added `iframe` element support for `AddScriptToExecuteOnDocumentCreated`. -* Improved WebView2 code to be more resilient to `.exe` application files with malformatted version information. ([Issue #850](https://github.com/MicrosoftEdge/WebViewFeedback/issues/850)). -* Removed `--winhttp-proxy-resolver` from WebView2 browser process command-line, turned on other proxy command-line options for WebView2. +* Fixed a bug in WebView2 .NET controls that first header is missing when iterating `CoreWebView2WebResourceRequest` headers collection. ([Issue #1123](https://github.com/MicrosoftEdge/WebViewFeedback/issues/1123)). + + -## 1.0.824-prerelease +## Prerelease SDK 1.0.824-prerelease, for Runtime 91 (Mar. 8, 2021) -Release Date: March 8, 2021 +Release Date: Mar. 8, 2021 [NuGet package for WebView2 SDK 1.0.824-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.824-prerelease) -For full API compatibility, this prerelease version of the WebView2 SDK requires Microsoft Edge version 91.0.824.0 or higher. +For full API compatibility, this Prerelease version of the WebView2 SDK requires Microsoft Edge version 91.0.824.0 or higher. -#### General -###### Features + +#### Features * Extended the `ProcessFailed` event. It now raises for non-renderer child processes and frame renderers. * Added experimental [AreBrowserAcceleratorKeysEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalsettings2?view=webview2-1.0.824&preserve-view=true#get_arebrowseracceleratorkeysenabled) setting. You can prevent the browser from responding to keyboard shortcuts related to navigation, printing, saving, and other browser-specific functions. * Added `iframe` element support for `AddScriptToExecuteOnDocumentCreated`. -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * [UserAgent](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_webresourceresponsereceived). * Rasterization Scale APIs: - * [RasterizationScale property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_rasterizationscale) - * [RasterizationScaleChanged event](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#add_rasterizationscalechanged) - * [BoundsMode property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_boundsmode) - * [ShouldDetectMonitorScaleChanges property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_shoulddetectmonitorscalechanges) + * [RasterizationScale property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_rasterizationscale) + * [RasterizationScaleChanged event](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#add_rasterizationscalechanged) + * [BoundsMode property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_boundsmode) + * [ShouldDetectMonitorScaleChanges property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_shoulddetectmonitorscalechanges) -###### Bug fixes + + +#### Bug fixes * Expanded supported C++ and .NET project types such as MFC and ATL. ([Issue #506](https://github.com/MicrosoftEdge/WebViewFeedback/issues/506), [Issue #669](https://github.com/MicrosoftEdge/WebViewFeedback/issues/669), and [Issue #851](https://github.com/MicrosoftEdge/WebViewFeedback/issues/851)). + * Fixed a bug that Evergreen WebView2 Runtime leaks Inbound firewall entry. + * Fixed setting Response during `WebResourceRequested` event. ([Issue #568](https://github.com/MicrosoftEdge/WebViewFeedback/issues/568)). + * Fixed a bug that navigating to `edge://` causes browser process to exit. ([Issue #604](https://github.com/MicrosoftEdge/WebViewFeedback/issues/604)). + * Fixed a bug that limited WebView2 bounds to size of screen in Visual Hosting mode. + + -## 1.0.774.44 +## Release SDK 1.0.818.41, for Runtime 90 (Apr. 21, 2021) -Release Date: March 8, 2021 +Release Date: Apr. 21, 2021 -[NuGet package for WebView2 SDK 1.0.774.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.774.44) +[NuGet package for WebView2 SDK 1.0.818.41](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.818.41) -For full API compatibility, this version of the WebView2 SDK requires WebView2 Runtime version 89.0.774.44 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 90.0.818.41 or higher. -#### General -###### Features + +#### Features -* Turned off various Microsoft Edge browser services in WebView2. -* Visual Hosting APIs are now Generally Available. +* Extended the `ProcessFailed` event. It now raises for non-renderer child processes and frame renderers. +* Added `iframe` element support for `AddScriptToExecuteOnDocumentCreated`. +* Improved WebView2 code to be more resilient to `.exe` application files with malformatted version information. ([Issue #850](https://github.com/MicrosoftEdge/WebViewFeedback/issues/850)). +* Removed `--winhttp-proxy-resolver` from WebView2 browser process command-line, turned on other proxy command-line options for WebView2. -###### Promotions + -The following APIs have been promoted to Stable and are now included in this Release SDK. -* [DPI support](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.774.44&preserve-view=true#add_webresourceresponsereceived) related APIs -* Visual hosting APIs -* [SetVirtualHostNameToFolderMapping](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.774.44&preserve-view=true#setvirtualhostnametofoldermapping) -* [TrySuspend and Resume](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.774.44&preserve-view=true#trysuspend) -* [DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2controller2?view=webview2-1.0.774.44&preserve-view=true#get_defaultbackgroundcolor) + +## Prerelease SDK 1.0.790-prerelease, for Runtime 86 (Feb. 10, 2021) -###### Bug fixes +Release Date: Feb. 10, 2021 -* Fixed a bug that limited WebView2 bounds to size of screen in Visual Hosting mode. +[NuGet package for WebView2 SDK 1.0.790-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.790-prerelease) +This Prerelease version of the WebView2 SDK requires Microsoft Edge version 86.0.616.0 or higher. - -## 1.0.790-prerelease -Release Date: February 10, 2021 + +#### Breaking changes -[NuGet package for WebView2 SDK 1.0.790-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.790-prerelease) -This prerelease version of the WebView2 SDK requires Microsoft Edge version 86.0.616.0 or higher. + +###### Prerelease package 1.0.781 is deprecated -#### General +WebView2 prerelease package 1.0.781 is deprecated. Discontinue development with package 1.0.781. -> [!IMPORTANT] -> **Breaking Change**: WebView2 prerelease package 1.0.781 is deprecated. Discontinue development with package 1.0.781. -> [!IMPORTANT] -> WebView2 prerelease package 0.9.430 is deprecated, and is removed with the next release. If your WebView2 app uses the package, the WebView2 team recommends that you move to a newer package. + +###### Prerelease package 0.9.430 is deprecated + +WebView2 prerelease package 0.9.430 is deprecated, and is removed with the next release. If your WebView2 app uses the package, the WebView2 team recommends that you move to a newer package. -###### Features + + +#### Features * Added [TrySuspend and Resume](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.790-prerelease&preserve-view=true#trysuspend) method to suspend and resume WebViews. * Added [SetVirtualHostNameToFolderMapping](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.790-prerelease&preserve-view=true#setvirtualhostnametofoldermapping) method that maps a virtual host name to a directory path. ([Issue #37](https://github.com/MicrosoftEdge/WebViewFeedback/issues/37), [Issue #161](https://github.com/MicrosoftEdge/WebViewFeedback/issues/161), and [Issue #212](https://github.com/MicrosoftEdge/WebViewFeedback/issues/212)). @@ -3446,75 +11072,116 @@ This prerelease version of the WebView2 SDK requires Microsoft Edge version 86.0 * Replaced the `CreateCookieWithCookie` method with the `CopyCookie` method. * Added visual hosting support using the [ICoreWebView2CompositionController](/microsoft-edge/webview2/reference/win32/icorewebview2compositioncontroller?view=webview2-1.0.790-prerelease&preserve-view=true) interface, which is created using the new `CreateCoreWebView2CompositionController` method from `ICoreWebView2Environment3`. -###### Bug fixes + + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. + +* Visual Hosting APIs +* [SetVirtualHostNameToFolderMapping](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.790-prerelease&preserve-view=true#setvirtualhostnametofoldermapping) + + + +#### Bug fixes * Turned off the Microsoft Edge Shopping feature in WebView2. + * Turned off the context menu in the PDF viewer when `AreDefaultContextMenusEnabled` is `false`. ([Issue #605](https://github.com/MicrosoftEdge/WebViewFeedback/issues/605)). + * Fixed a bug that returned `E_NOINTERFACE` when querying `ICoreWebView2` for `ICoreWebView2Experimental`. ([Issue #691](https://github.com/MicrosoftEdge/WebViewFeedback/issues/691)). + * Fixed a bug that allowed navigation with malformed URIs when `CoreWebView2NavigationStartingEventArgs.Cancel` is set to `false`. ([Issue #400](https://github.com/MicrosoftEdge/WebViewFeedback/issues/400)). + * Fixed a bug that blocked `window.print()` on pop-up windows with event handlers attached to `NewWindowRequested` events. ([Issue #409](https://github.com/MicrosoftEdge/WebViewFeedback/issues/409)). + * Fixed Dynamic DPI issue when moving apps between different monitors. ([Issue #58](https://github.com/MicrosoftEdge/WebViewFeedback/issues/58)) + * Improved the `HRESULT` instances passed by [ICoreWebView2WebResourceResponseViewGetContentCompletedHandler::Invoke](/microsoft-edge/webview2/reference/win32/icorewebview2webresourceresponseviewgetcontentcompletedhandler?view=webview2-1.0.790-prerelease&preserve-view=true#invoke). + * Turned off autofill manage button. ([Issue #585](https://github.com/MicrosoftEdge/WebViewFeedback/issues/585)). + * Fixed Visual Studio crashes while you run `WebView2.Dispose` when hosted in multiple windows. ([Issue #816](https://github.com/MicrosoftEdge/WebViewFeedback/issues/816)) and [Issue #442](https://github.com/MicrosoftEdge/WebViewFeedback/issues/442)). + * Fixed bug to display WebView2 control in Visual Studio Toolbox. ([Issue #210](https://github.com/MicrosoftEdge/WebViewFeedback/issues/210)). -* Reduced high CPU usage issues. ([Issue #878](https://github.com/MicrosoftEdge/WebViewFeedback/issues/878)). -* Fixed issues with deprecated 1.0.781-prerelease package. ([Issue #875](https://github.com/MicrosoftEdge/WebViewFeedback/issues/875) and [Issue #878](https://github.com/MicrosoftEdge/WebViewFeedback/issues/878)). -###### Promotions +* Reduced high CPU usage issues. ([Issue #878](https://github.com/MicrosoftEdge/WebViewFeedback/issues/878)). -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. +* Fixed issues with deprecated 1.0.781-prerelease package. ([Issue #875](https://github.com/MicrosoftEdge/WebViewFeedback/issues/875) and [Issue #878](https://github.com/MicrosoftEdge/WebViewFeedback/issues/878)). -* Visual Hosting APIs -* [SetVirtualHostNameToFolderMapping](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.790-prerelease&preserve-view=true#setvirtualhostnametofoldermapping) + #### .NET + + ###### Bug fixes * Fixed bug that crashed WebView2 apps that use the WPF SDK. The crash occurred when pressing **F4** to close a window. ([Issue #399](https://github.com/MicrosoftEdge/WebViewFeedback/issues/399)). + * The WebView2 initialization screen is now transparent, instead of gray. ([Issue #196](https://github.com/MicrosoftEdge/WebViewFeedback/issues/196)). + + -## 1.0.705.50 +## Release SDK 1.0.774.44, for Runtime 89 (Mar. 8, 2021) -Release Date: January 25, 2021 +Release Date: Mar. 8, 2021 -[NuGet package for WebView2 SDK 1.0.705.50](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.705.50) +[NuGet package for WebView2 SDK 1.0.774.44](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.774.44) -This version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. +For full API compatibility, this Release version of the WebView2 SDK requires WebView2 Runtime version 89.0.774.44 or higher. -#### General -###### Promotions + +#### Features -The following APIs have been promoted to Stable and are now included in this Release SDK. +* Turned off various Microsoft Edge browser services in WebView2. +* Visual Hosting APIs are now Generally Available. + + + +#### Promotions to Phase 3 (Stable in Release) + +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. + + * [DPI support](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.774.44&preserve-view=true#add_webresourceresponsereceived) related APIs + * Visual hosting APIs + * [SetVirtualHostNameToFolderMapping](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.774.44&preserve-view=true#setvirtualhostnametofoldermapping) + * [TrySuspend and Resume](/microsoft-edge/webview2/reference/win32/icorewebview2_3?view=webview2-1.0.774.44&preserve-view=true#trysuspend) + * [DefaultBackgroundColor](/microsoft-edge/webview2/reference/win32/icorewebview2controller2?view=webview2-1.0.774.44&preserve-view=true#get_defaultbackgroundcolor) -* [WebResourceResponseReceived API](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_webresourceresponsereceived) -* [NavigateWithWebResourceRequest API](/microsoft-edge/webview2/reference/win32/icorewebview2environment2?view=webview2-1.0.721-prerelease&preserve-view=true#createwebresourcerequest) -* [Cookie management API](/microsoft-edge/webview2/reference/win32/icorewebview2cookiemanager?view=webview2-1.0.721-prerelease&preserve-view=true) -* [DOMContentLoaded API](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_domcontentloaded) -* [Environment property](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#get_environment) + + +#### Bug fixes + +* Fixed a bug that limited WebView2 bounds to size of screen in Visual Hosting mode. + + -## 1.0.721-prerelease +## Prerelease SDK 1.0.721-prerelease, for Runtime 86 (Dec. 8, 2020) -Release Date: December 8, 2020 +Release Date: Dec. 8, 2020 [NuGet package for WebView2 SDK 1.0.721-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.721-prerelease) -This prerelease version of the WebView2 SDK requires Microsoft Edge version 86.0.616.0 or higher. +This Prerelease version of the WebView2 SDK requires Microsoft Edge version 86.0.616.0 or higher. -#### General + + +#### Breaking changes > [!IMPORTANT] > **Breaking Change**: WebView2 prerelease package 1.0.707 and package 0.9.628 are deprecated. Discontinue development with package 1.0.707 and package0.9.628. -###### Features -* Added [WebView2 Group Policies](/deployedge/microsoft-edge-webview-policies). For best practices, see [group policies for WebView2](concepts/enterprise.md#group-policies-for-webview2). + +#### Features + +* Added [WebView2 Group Policies](/deployedge/microsoft-edge-webview-policies). For best practices, see [group policies for WebView2](../concepts/enterprise.md#group-policies-for-webview2). * > [!IMPORTANT] > **Breaking Change**: Deprecated the old registry location. > @@ -3524,14 +11191,16 @@ This prerelease version of the WebView2 SDK requires Microsoft Edge version 86.0 * Added support for [Drag and Drop](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller3?view=webview2-1.0.721-prerelease&preserve-view=true) in WebView2. * Added APIs to handle DPI support. - * Added [RasterizationScale](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_rasterizationscale) property to change the DPI scale for WebView2 content and UI pop-ups, and associated [RasterizationScaleChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#add_rasterizationscalechanged) event. - * Added [ShouldDetectMonitorScaleChanges](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_shoulddetectmonitorscalechanges) property to automatically update `RasterizationScale` property if needed. - * Added [BoundsMode property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_boundsmode) to specify that the bounds are logic pixels and allow WebView2 to use `RasterizationScale` for WebView2 pixel display, and WebView2 use the `RasterizationScale` with the `Bounds` to get the physical size. + * Added [RasterizationScale](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_rasterizationscale) property to change the DPI scale for WebView2 content and UI pop-ups, and associated [RasterizationScaleChanged](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#add_rasterizationscalechanged) event. + * Added [ShouldDetectMonitorScaleChanges](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_shoulddetectmonitorscalechanges) property to automatically update `RasterizationScale` property if needed. + * Added [BoundsMode property](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcontroller?view=webview2-1.0.721-prerelease&preserve-view=true#get_boundsmode) to specify that the bounds are logic pixels and allow WebView2 to use `RasterizationScale` for WebView2 pixel display, and WebView2 use the `RasterizationScale` with the `Bounds` to get the physical size. * Updated `NewWindowRequested` event to handle **Ctrl+click** and **Shift+click**. ([Issue #168](https://github.com/MicrosoftEdge/WebViewFeedback/issues/168) and [Issue #371](https://github.com/MicrosoftEdge/WebViewFeedback/issues/371)). -###### Promotions -The following APIs have been promoted from Experimental to Stable in this Prerelease SDK. + +#### Promotions to Phase 2 (Stable in Prerelease) + +The following APIs have been promoted from Phase 1: Experimental in Prerelease, to Phase 2: Stable in Prerelease, and are included in this Prerelease SDK. * [WebResourceResponseReceived API](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_webresourceresponsereceived) * [NavigateWithWebResourceRequest API](/microsoft-edge/webview2/reference/win32/icorewebview2environment2?view=webview2-1.0.721-prerelease&preserve-view=true#createwebresourcerequest) @@ -3539,57 +11208,67 @@ The following APIs have been promoted from Experimental to Stable in this Prerel * [DOMContentLoaded API](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_domcontentloaded) * [Environment property](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#get_environment) + + #### .NET + + ###### Features * Turned on WinForms designer in .NET Core 3.1+ and .NET 5. * Improved .NET cookie management. ([Issue #611](https://github.com/MicrosoftEdge/WebViewFeedback/issues/611)). * Replaced `CoreWebView2Ready` with [CoreWebView2InitializationCompleted](/dotnet/api/microsoft.web.webview2.core.corewebview2initializationcompletedeventargs). + + ###### Bug fixes * Added [AcceleratorKeyPressed](/dotnet/api/microsoft.web.webview2.wpf.webview2.acceleratorkeypressed) event to support `AcceleratorKey` select in WebView2. ([Issue #288](https://github.com/MicrosoftEdge/WebViewFeedback/issues/288)). + * Removed unnecessary files from being output to WebView2 folders. ([Issue #461](https://github.com/MicrosoftEdge/WebViewFeedback/issues/461)). -* Improved host object API. ([Issue #335](https://github.com/MicrosoftEdge/WebViewFeedback/issues/335) and [Issue #525](https://github.com/MicrosoftEdge/WebViewFeedback/issues/525)). +* Improved host object API. ([Issue #335](https://github.com/MicrosoftEdge/WebViewFeedback/issues/335) and [Issue #525](https://github.com/MicrosoftEdge/WebViewFeedback/issues/525)). - -## 1.0.664.37 + -Release Date: November 20, 2020 -[NuGet package for WebView2 SDK 1.0.664.37](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.664.37) + +## Release SDK 1.0.705.50, for Runtime 86 (Jan. 25, 2021) -This version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. +Release Date: Jan. 25, 2021 -#### General +[NuGet package for WebView2 SDK 1.0.705.50](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.705.50) -> [!IMPORTANT] -> **Announcement**: .NET WPF/WinForms WebView2 SDKs are now Generally Available (GA). Starting with this release, Release SDKs are forward-compatible. For more details, see [GA announcement blog post](https://devblogs.microsoft.com/dotnet/announcing-general-availability-for-microsoft-edge-webview2-for-net-and-fixed-distribution-method). +This Release version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. -###### Features -* .NET WPF/WinForms WebView2 is now Generally Available (GA). -* Fixed Distribution (Bring-your-own) mode reached GA. + +#### Promotions to Phase 3 (Stable in Release) -#### .NET +The following APIs have been promoted from Phase 2: Stable in Prerelease, to Phase 3: Stable in Release, and are now included in this Release SDK. -###### Bug fixes + * [WebResourceResponseReceived API](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_webresourceresponsereceived) + * [NavigateWithWebResourceRequest API](/microsoft-edge/webview2/reference/win32/icorewebview2environment2?view=webview2-1.0.721-prerelease&preserve-view=true#createwebresourcerequest) + * [Cookie management API](/microsoft-edge/webview2/reference/win32/icorewebview2cookiemanager?view=webview2-1.0.721-prerelease&preserve-view=true) + * [DOMContentLoaded API](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#add_domcontentloaded) + * [Environment property](/microsoft-edge/webview2/reference/win32/icorewebview2_2?view=webview2-1.0.721-prerelease&preserve-view=true#get_environment) -* `CoreWebView2NewWindowRequestedEventArgs.Handled` prevents new window from being opened. ([Issue #549](https://github.com/MicrosoftEdge/WebViewFeedback/issues/549) and [Issue #560](https://github.com/MicrosoftEdge/WebViewFeedback/issues/560)). + -## 1.0.674-prerelease +## Prerelease SDK 1.0.674-prerelease, for Runtime 86 (Oct. 19, 2020) -Release Date: October 19, 2020 +Release Date: Oct. 19, 2020 [NuGet package for WebView2 SDK 1.0.674-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.674-prerelease) -This prerelease version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. +This Prerelease version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. + -#### General + +#### General features * Added [NavigateWithWebResourceRequest](/microsoft-edge/webview2/reference/win32/icorewebview2experimental?view=webview2-1.0.674-prerelease&preserve-view=true#navigatewithwebresourcerequest) method to provide post data or other request headers during navigation. * Added [DOMContentLoaded](/microsoft-edge/webview2/reference/win32/icorewebview2experimental?view=webview2-1.0.674-prerelease&preserve-view=true#add_domcontentloaded) event that runs when the initial HTML document is loaded and parsed. @@ -3598,9 +11277,11 @@ This prerelease version of the WebView2 SDK requires WebView2 Runtime version 86 * Updated the [WebResourceResponseReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimental?view=webview2-1.0.674-prerelease&preserve-view=true#add_webresourceresponsereceived) event, and added immutable [WebResourceResponseView](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebresourceresponseview?view=webview2-1.0.674-prerelease&preserve-view=true) and [WebResourceResponseReceivedEventArgs::PopulateResponseContent](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebresourceresponsereceivedeventargs?view=webview2-0.9.628-prerelease&preserve-view=true#populateresponsecontent) to [WebResourceResponseView::GetContent](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwebresourceresponseview?view=webview2-1.0.674-prerelease&preserve-view=true#getcontent). * Turned off [Microsoft Defender Application Guard (WDAG)](/windows/security/threat-protection/microsoft-defender-application-guard/md-app-guard-overview) in WebView2. * Added [SystemCursorId](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller2?view=webview2-1.0.674-prerelease&preserve-view=true#get_systemcursorid) for Visual Hosting. -* Added bug fixed for InputWidget Method in Visual Hosting. +* Added bug fixed for Input Method in Visual Hosting. * Removed include requirement for `version.lib` when using WebView2 static library. + + #### .NET * Updated [CoreWebView2](/dotnet/api/microsoft.web.webview2.core.corewebview2) class to expose the `CoreWebView2Environment` variable. @@ -3613,36 +11294,72 @@ This prerelease version of the WebView2 SDK requires WebView2 Runtime version 86 * Updated .NET Loader base to load on process bit instead of operating system architecture. ([Issue #431](https://github.com/MicrosoftEdge/WebViewFeedback/issues/431)). * Renamed `EdgeNotFoundException` to [WebView2RuntimeNotFoundException](/dotnet/api/microsoft.web.webview2.core.webview2runtimenotfoundexception). + + -## 1.0.622.22 +## Release SDK 1.0.664.37, for Runtime 86 (Nov. 20, 2020) -Release Date: October 19, 2020 +Release Date: Nov. 20, 2020 + +[NuGet package for WebView2 SDK 1.0.664.37](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.664.37) + +This Release version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. + + + +#### General Availability + +> [!IMPORTANT] +> **Announcement**: .NET WPF/WinForms WebView2 SDKs are now Generally Available (GA). Starting with this release, Release SDKs are forward-compatible. For more details, see [GA announcement blog post](https://devblogs.microsoft.com/dotnet/announcing-general-availability-for-microsoft-edge-webview2-for-net-and-fixed-distribution-method). + + + +#### Features + +* .NET WPF/WinForms WebView2 is now Generally Available (GA). +* Fixed Distribution (Bring-your-own) mode reached GA. -[NuGet package for WebView2 SDK 1.0.622.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.622.22) -This version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. + +#### .NET + + + +###### Bug fixes + +* `CoreWebView2NewWindowRequestedEventArgs.Handled` prevents new window from being opened. ([Issue #549](https://github.com/MicrosoftEdge/WebViewFeedback/issues/549) and [Issue #560](https://github.com/MicrosoftEdge/WebViewFeedback/issues/560)). -#### General + + + + +## Release SDK 1.0.622.22, for Runtime 86 (Oct. 19, 2020) + +Release Date: Oct. 19, 2020 + +[NuGet package for WebView2 SDK 1.0.622.22](https://www.nuget.org/packages/Microsoft.Web.WebView2/1.0.622.22) + +This Release version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. > [!IMPORTANT] > **Announcement**: Win32 C/C++ WebView2 is now Generally Available (GA). Starting this release, Release SDKs are forward-compatible. See [GA announcement blog post](https://blogs.windows.com/msedgedev/edge-webview2-general-availability). * The Evergreen WebView2 Runtime and installer are GA. The bootstrapper, the downlink link for the Bootstrapper, and the Standalone Installer for the Evergreen WebView2 Runtime are available on [Microsoft Edge WebView2](https://developer.microsoft.com/microsoft-edge/webview2/). Sample code for the installation workflow is also available in the [WebView2Samples repo](https://github.com/MicrosoftEdge/WebView2Samples). -For more information about the Runtime, Evergreen distribution, and Fixed Version distribution, see [Distribute your app and the WebView2 Runtime](concepts/distribution.md). +For more information about the Runtime, Evergreen distribution, and Fixed Version distribution, see [Distribute your app and the WebView2 Runtime](../concepts/distribution.md). + + -## 0.9.622.11 +## Release SDK 0.9.622.11, for Runtime 86 (Sep. 10, 2020) -Release Date: September 10, 2020 +Release Date: Sep. 10, 2020 [NuGet package for WebView2 SDK 0.9.622.11](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.622.11) -This version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. - -#### General +This Release version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or higher. * > [!IMPORTANT] > **Announcement**: This SDK is the Release Candidate for WebView2 Win32 C/C++ GA. The GA version is expected to use the same API interface and functionality. @@ -3654,29 +11371,33 @@ This version of the WebView2 SDK requires WebView2 Runtime version 86.0.616.0 or * Updated NewWindowRequested event to handle `window.open()` request without parameters. ([Issue #293](https://github.com/MicrosoftEdge/WebViewFeedback/issues/293)). * [AdditionalBrowserArguments](/microsoft-edge/webview2/reference/win32/icorewebview2environmentoptions?view=webview2-0.9.622&preserve-view=true#put_additionalbrowserarguments) specified with `ICoreWebView2EnvironmentOptions` aren't overridden with environment variables or registry values. See [CreateCoreWebView2EnvironmentWithOptions](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-0.9.622&preserve-view=true#createcorewebview2environmentwithoptions). + + -## 0.9.579 +## Release SDK 0.9.579, for Runtime 86 (Jul. 20, 2020) -Release Date: July 20, 2020 +Release Date: Jul. 20, 2020 [NuGet package for WebView2 SDK 0.9.579](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.579) -This version of the WebView2 SDK requires Microsoft Edge version 86.0.579.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 86.0.579.0 or higher. -#### General + + +#### All platforms * > [!IMPORTANT] - > **Announcement**: Evergreen WebView2 Runtime and installer is released for preview. See [Distribute your app and the WebView2 Runtime](concepts/distribution.md). + > **Announcement**: Evergreen WebView2 Runtime and installer is released for preview. See [Distribute your app and the WebView2 Runtime](../concepts/distribution.md). * > [!IMPORTANT] > **Announcement**: The following WebView2 SDK Versions are no longer supported after the next SDK release: > - > * [0.8.190](#08190) - > * [0.8.230](#08230) - > * [0.8.270](#08270) - > * [0.8.314](#08314) - > * [0.8.355](#08355) + > * [Release SDK 0.8.190, for Runtime 77 (Jun. 17, 2019)](#release-sdk-08190-for-runtime-77-jun-17-2019) + > * [Release SDK 0.8.230, for Runtime 77 (Jul. 29, 2019)](#release-sdk-08230-for-runtime-77-jul-29-2019) + > * [Release SDK 0.8.270, for Runtime 78 (Sep. 10, 2019)](#release-sdk-08270-for-runtime-78-sep-10-2019) + > * [Release SDK 0.8.314, for Runtime 80 (Oct. 28, 2019)](#release-sdk-08314-for-runtime-80-oct-28-2019) + > * [Release SDK 0.8.355, for Runtime 80 (Dec. 9, 2019)](#release-sdk-08355-for-runtime-80-dec-9-2019) > > The WebView2 SDK Versions are also marked deprecated on nuget.org. WebView2 recommends staying up to date with the latest version of WebView2. @@ -3687,24 +11408,49 @@ This version of the WebView2 SDK requires Microsoft Edge version 86.0.579.0 or h * Added experimental [IsSingleSignOnUsingOSPrimaryAccountEnabled](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalenvironmentoptions?view=webview2-0.9.538-prerelease&preserve-view=true#get_issinglesignonusingosprimaryaccountenabled) property on WebView2 environment options to turn on conditional access for WebView2. * Added experimental [WebResourceResponseReceived](/microsoft-edge/webview2/reference/win32/icorewebview2experimental?view=webview2-0.9.538-prerelease&preserve-view=true#add_webresourceresponsereceived) event that runs after the WebView2 receives and processes the response from a WebResource request. Authentication headers, if any, are included in the response object. + + #### .NET * Improved WPF focus handling. ([Issue #185](https://github.com/MicrosoftEdge/WebViewFeedback/issues/185)). * Added `ZoomFactor` property on WPF Webview2 Controller. + + + + +## Prerelease SDK 0.9.579-prerelease, for Runtime 85 (Jul. 20, 2020) + + +This SDK was last updated Jul. 20, 2020. + +[NuGet package for WebView2 SDK 0.9.579-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.579-prerelease) + + + -## 0.9.538 +## Release SDK 0.9.538, for Runtime 85 (Jun. 8, 2020) + +Release Date: Jun. 8, 2020 [NuGet package for WebView2 SDK 0.9.538](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.538) -This version of the WebView2 SDK requires Microsoft Edge version 85.0.538.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 85.0.538.0 or higher. -#### General -* Dropping support for WebView2 SDK Version [0.8.149](#08149). WebView2 recommends staying up to date with the latest version of WebView2. + +#### All platforms + +* Dropping support for WebView2 [Release SDK 0.8.149, for Runtime 76 (May 6, 2019)](#release-sdk-08149-for-runtime-76-may-6-2019). We recommend staying up to date with the latest version of WebView2. * Updated group policy to account for when the profile path of the Microsoft Edge browser is modified ([#179](https://github.com/MicrosoftEdge/WebViewFeedback/issues/179)). + + #### Win32 C/C++ * Added [ICoreWebView2ExperimentalNewWindowRequestedEventArgs::get_WindowFeatures](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalnewwindowrequestedeventargs?view=webview2-0.9.538-prerelease&preserve-view=true#get_windowfeatures), which fires when `window.open()` is run and associated with [ICoreWebView2ExperimentalWindowFeatures](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalwindowfeatures?view=webview2-0.9.538-prerelease&preserve-view=true) ([#70](https://github.com/MicrosoftEdge/WebViewFeedback/issues/70)). @@ -3718,28 +11464,49 @@ This version of the WebView2 SDK requires Microsoft Edge version 85.0.538.0 or h * Updated [AddHostObjectToScript](/microsoft-edge/webview2/reference/win32/icorewebview2?view=webview2-0.9.538&preserve-view=true#addhostobjecttoscript). The original host object serializer markers are now set to the proxy objects. Then host object serializer markers are serialized back as a host object when passed as a parameter in the JavaScript callback ([#148](https://github.com/MicrosoftEdge/WebViewFeedback/issues/148)). + + #### .NET (0.9.538 prerelease) * Released WinForms and WPF WebView2API Samples, which are comprehensive guides of the WebView2 SDK. See [Samples Repo](https://github.com/MicrosoftEdge/WebView2Samples). -* Added support for visual hosting and window features [experimental APIs](concepts/versioning.md#experimental-apis). +* Added support for visual hosting and window features, as [experimental APIs](../concepts/versioning.md#experimental-apis). * > [!IMPORTANT] - > **Breaking Change**: The following deferrals now implement IDisposable: [ScriptDialogOpening](/dotnet/api/microsoft.web.webview2.core.corewebview2.scriptdialogopening), [NewWindowRequested](/dotnet/api/microsoft.web.webview2.core.corewebview2.newwindowrequested), [WebResourceRequested](/dotnet/api/microsoft.web.webview2.core.corewebview2.webresourcerequested), and [PermissionRequested](/dotnet/api/microsoft.web.webview2.core.corewebview2.permissionrequested). + > **Breaking Change**: The following deferrals now implement `IDisposable`: [ScriptDialogOpening](/dotnet/api/microsoft.web.webview2.core.corewebview2.scriptdialogopening), [NewWindowRequested](/dotnet/api/microsoft.web.webview2.core.corewebview2.newwindowrequested), [WebResourceRequested](/dotnet/api/microsoft.web.webview2.core.corewebview2.webresourcerequested), and [PermissionRequested](/dotnet/api/microsoft.web.webview2.core.corewebview2.permissionrequested). * Added [GetAvailableBrowserVersionString](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.getavailablebrowserversionstring) and [CompareBrowserVersions](/dotnet/api/microsoft.web.webview2.core.corewebview2environment.comparebrowserversions) as [CoreWebView2Environment](/dotnet/api/microsoft.web.webview2.core.corewebview2environment) statics. + + + + +## Prerelease SDK 0.9.538-prerelease, for Runtime 85 (Jun. 8, 2020) + + +This SDK was last updated Jun. 8, 2020. + +[NuGet package for WebView2 SDK 0.9.538-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.538-prerelease) + + + -## 0.9.515-prerelease +## Prerelease SDK 0.9.515-prerelease, for Runtime 84 (May 14, 2020) + +Release Date: May 14, 2020 [NuGet package for WebView2 SDK 0.9.515-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.515-prerelease) -This prerelease version of the WebView2 SDK requires Microsoft Edge version 84.0.515.0 or higher. +This Prerelease version of the WebView2 SDK requires Microsoft Edge version 84.0.515.0 or higher. * > [!IMPORTANT] > **Announcement**: WebView2 now supports Windows Forms and WPF on .NET Framework 4.6.2 or later and .NET Core 3.0 or later in the **prerelease package**. -* For more information about building WPF apps, see [Get started with WebView2 in WPF apps](get-started/wpf.md) and the WebView2 [WPF Reference](/dotnet/api/microsoft.web.webview2.wpf) for WPF-specific APIs. -* For more information about building Windows Forms apps, see [Get started with WebView2 in WinForms apps](get-started/winforms.md) and the WebView2 [Windows Forms Reference](/dotnet/api/microsoft.web.webview2.winforms) for Windows Forms specific APIs. +* For more information about building WPF apps, see [Get started with WebView2 in WPF apps](../get-started/wpf.md) and the WebView2 [WPF Reference](/dotnet/api/microsoft.web.webview2.wpf) for WPF-specific APIs. +* For more information about building Windows Forms apps, see [Get started with WebView2 in WinForms apps](../get-started/winforms.md) and the WebView2 [Windows Forms Reference](/dotnet/api/microsoft.web.webview2.winforms) for Windows Forms specific APIs. * For more information about the CoreWebView2 APIs, see [.NET Reference](/dotnet/api/microsoft.web.webview2.core). * > [!CAUTION] > **Known Issues**: The WebView2 team is aware of some issues in the prerelease that are being resolved in future releases. @@ -3747,23 +11514,27 @@ This prerelease version of the WebView2 SDK requires Microsoft Edge version 84.0 > * **DPI Awareness**: WebView2 for WPF is currently not DPI aware. When initializing WebView2 on high DPI monitors, there is a known issue where the WebView2 control at first initializes as a fraction of the window until the window is resized. > * **WPF Designer**: The WPF designer isn't currently supported. Add the WebView2 control in your app by directly modifying the appropriate XAML in a text editor. + + -## 0.9.488 +## Release SDK 0.9.488, for Runtime 84 (Apr. 20, 2020) + +Release Date: Apr. 20, 2020 [NuGet package for WebView2 SDK 0.9.488](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.488) -This version of the WebView2 SDK requires Microsoft Edge version 84.0.488.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 84.0.488.0 or higher. * > [!IMPORTANT] - > **Announcement**: Starting with the upcoming Microsoft Edge version 83, Evergreen WebView2 no longer targets the Stable browser channel. Instead, it targets another set of binaries, branded Evergreen WebView2 Runtime, that you can chain-install through an installer that the WebView2 team is currently developing. See [Distribute your app and the WebView2 Runtime](concepts/distribution.md). + > **Announcement**: Starting with the upcoming Microsoft Edge version 83, Evergreen WebView2 no longer targets the Stable browser channel. Instead, it targets another set of binaries, branded Evergreen WebView2 Runtime, that you can chain-install through an installer that the WebView2 team is currently developing. See [Distribute your app and the WebView2 Runtime](../concepts/distribution.md). * > [!IMPORTANT] > **Announcement**: Moving forward, the WebView2 team releases two packages: > * A Prerelease SDK package containing Experimental APIs (for you to try out), and also APIs that have been promoted to Stable status. > * A Release SDK package that consists entirely of APIs that have reached Stable status (for your confidence). > - > To learn about the differences, see [Understanding browser versions and WebView2](concepts/versioning.md). + > To learn about the differences, see [Prerelease and Release SDKs for WebView2](../concepts/versioning.md). * > [!IMPORTANT] > **Breaking Change**: In order to ensure the WebView2 API aligns with the Windows API naming conventions, the WebView2 team updated the names of the following interfaces. @@ -3793,17 +11564,39 @@ This version of the WebView2 SDK requires Microsoft Edge version 84.0.488.0 or h * Updated Remote Object Injection to support .NET `IDispatch` implementations ([#113](https://github.com/MicrosoftEdge/WebViewFeedback/issues/113)). * Updated [NewWindowRequested](/microsoft-edge/webview2/reference/win32/icorewebview2?view=webview2-0.9.488&preserve-view=true#add_newwindowrequested) event to handle requests from context menus ([#108](https://github.com/MicrosoftEdge/WebViewFeedback/issues/108)). * Released the first separate WebView2 prerelease package where you can access visual hosting APIs. The WebView2 team updated [APISample](https://github.com/MicrosoftEdge/WebView2Samples) to include the new experimental APIs. - * Added [ICoreWebView2ExperimentalCompositionController](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller?view=webview2-0.9.488-prerelease&preserve-view=true) interface, to connect to a composition tree and provide input for the WebView2 control. - * Added [ICoreWebView2ExperimentalPointerInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpointerinfo?view=webview2-0.9.488-prerelease&preserve-view=true), which contains all the information from a `POINTER_INFO`. This object is passed to SendPointerInput to inject pointer input into the WebView2. - * Added [ICoreWebView2ExperimentalCursorChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcursorchangedeventhandler?view=webview2-0.9.488-prerelease&preserve-view=true), which tells the app when the mouse cursor over the WebView2 control should be changed. When mouse is over a text box in the WebView2, the cursor changes from the arrow to the selector. The `cursor` property on the `CompositionController` tells the app what the mouse cursor should currently be for the WebView2. + * Added [ICoreWebView2ExperimentalCompositionController](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcompositioncontroller?view=webview2-0.9.488-prerelease&preserve-view=true) interface, to connect to a composition tree and provide input for the WebView2 control. + * Added [ICoreWebView2ExperimentalPointerInfo](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalpointerinfo?view=webview2-0.9.488-prerelease&preserve-view=true), which contains all the information from a `POINTER_INFO`. This object is passed to SendPointerInput to inject pointer input into the WebView2. + * Added [ICoreWebView2ExperimentalCursorChangedEventHandler](/microsoft-edge/webview2/reference/win32/icorewebview2experimentalcursorchangedeventhandler?view=webview2-0.9.488-prerelease&preserve-view=true), which tells the app when the mouse cursor over the WebView2 control should be changed. When mouse is over a text box in the WebView2, the cursor changes from the arrow to the selector. The `cursor` property on the `CompositionController` tells the app what the mouse cursor should currently be for the WebView2. + + + + + +## Prerelease SDK 0.9.488-prerelease, for Runtime 83 (Apr. 20, 2020) + +This SDK was last updated Apr. 20, 2020. + +[NuGet package for WebView2 SDK 0.9.488-prerelease](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.488-prerelease) + + + + + -## 0.9.430 +## Release SDK 0.9.430, for Runtime 82 (Feb. 24, 2020) + +Release Date: Feb. 24, 2020 [NuGet package for WebView2 SDK 0.9.430](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.9.430) -This version of the WebView2 SDK requires Microsoft Edge version 82.0.430.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 82.0.430.0 or higher. The WebView2 SDK is the official Win32 C++ Beta version, which incorporates several feature requests from feedback. The WebView2 team tries to limit the number of releases with breaking changes. As general availability approaches, several major breaking changes are incorporated in the Beta release. @@ -3814,7 +11607,7 @@ The WebView2 SDK is the official Win32 C++ Beta version, which incorporates seve > **Breaking Change**: Split [DocumentStateChanged](/microsoft-edge/webview2/reference/win32/iwebview2webview?view=webview2-0.8.355&preserve-view=true#add_documentstatechanged) into three components: [SourceChanged](/microsoft-edge/webview2/reference/win32/icorewebview2?view=webview2-0.9.430&preserve-view=true#add_sourcechanged), [ContentLoading](/microsoft-edge/webview2/reference/win32/icorewebview2?view=webview2-0.9.430&preserve-view=true#add_contentloading), and [HistoryChanged](/microsoft-edge/webview2/reference/win32/icorewebview2?view=webview2-0.9.430&preserve-view=true#add_historychanged). Now, when the source URL changes the `SourceChanged` event is run. When the history state is changed the `HistoryChanged` event is run. The `ContentLoading` event is run before the initial script when a new document is being loaded. * Added support for ARM64 architecture. -* Added Soft InputWidget Panel (SIP) support for touch screen devices. +* Added Soft Input Panel (SIP) support for touch screen devices. * Added support for Windows Server 2008 R2, Windows Server 2012, Windows Server 2012 R2, and Windows Server 2016. * Added [NotifyParentWindowPositionChanged](/microsoft-edge/webview2/reference/win32/icorewebview2host?view=webview2-0.9.430&preserve-view=true#notifyparentwindowpositionchanged) for the status bar to follow the window in windowed mode. Also, implement the change in windowless mode in order for accessibility features to work. * Added [AreRemoteObjectsAllowed](/microsoft-edge/webview2/reference/win32/icorewebview2settings?view=webview2-0.9.430&preserve-view=true#get_areremoteobjectsallowed) setting to globally control whether a webpage can be accessed by any remote objects. By default, `AreRemoteObjectsAllowed` is turned on, so remote objects added by [AddRemoteObject](/microsoft-edge/webview2/reference/win32/icorewebview2?view=webview2-0.9.430&preserve-view=true#addremoteobject) are accessible from the webpage. When `AreRemoteObjectsAllowed` is turned off, the objects aren't accessible from the webpage. Changes are applied on the next navigation event. @@ -3834,13 +11627,17 @@ The WebView2 SDK is the official Win32 C++ Beta version, which incorporates seve * > [!IMPORTANT] > **Breaking Change**: Changed `AcceleratorKeyPressedEventArgs` [Handle](/microsoft-edge/webview2/reference/win32/iwebview2acceleratorkeypressedeventargs?view=webview2-0.8.355&preserve-view=true#handle) method to a [get_Handled](/microsoft-edge/webview2/reference/win32/icorewebview2acceleratorkeypressedeventargs?view=webview2-0.9.430&preserve-view=true#get_handled) property. + + -## 0.8.355 +## Release SDK 0.8.355, for Runtime 80 (Dec. 9, 2019) + +Release Date: Dec. 9, 2019 [NuGet package for WebView2 SDK 0.8.355](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.8.355) -This version of the WebView2 SDK requires Microsoft Edge version 80.0.355.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 80.0.355.0 or higher. * Released WebView2API Sample, a comprehensive guide of the WebView2 SDK. See [API Sample](https://github.com/MicrosoftEdge/WebView2Samples/tree/main/SampleApps/WebView2APISample). * Added IME support for all languages besides English ([#30](https://github.com/MicrosoftEdge/WebViewFeedback/issues/30)). @@ -3848,18 +11645,24 @@ This version of the WebView2 SDK requires Microsoft Edge version 80.0.355.0 or h * > [!IMPORTANT] > **Breaking Change**: Modified fullscreen behavior. Deprecated [IsFullScreenAllowed](/microsoft-edge/webview2/reference/win32/iwebview2settings?view=webview2-0.8.355&preserve-view=true#get_isfullscreenallowed_deprecated). Now, by default, if an element in a WebView2 control (such as a video) is set to full screen, it fills the bounds of the WebView2 control. Use the [ContainsFullScreenElementChanged](/microsoft-edge/webview2/reference/win32/iwebview2containsfullscreenelementchangedeventhandler?view=webview2-0.8.355&preserve-view=true) event and [get_ContainsFullScreenElement](/microsoft-edge/webview2/reference/win32/iwebview2webview5?view=webview2-0.8.355&preserve-view=true#get_containsfullscreenelement) to specify how the app should resize the WebView2 control if an element wants to enter fullscreen mode. + + -## 0.8.314 +## Release SDK 0.8.314, for Runtime 80 (Oct. 28, 2019) + +Release Date: Oct. 28, 2019 [NuGet package for WebView2 SDK 0.8.314](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.8.314) -This version of the WebView2 SDK requires Microsoft Edge version 80.0.314.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 80.0.314.0 or higher. + + #### Changes -* Added support for Windows 7, Windows 8, and Windows 8.1. See [Supported platforms](./index.md#supported-platforms) in _Introduction to Microsoft Edge WebView2_. -* Added Visual Studio and Visual Studio Code debug support for WebView2. Now, debug your script in the WebView2 right from your IDE. See [How to debug when developing with WebView2 controls](how-to/debug.md). +* Added support for Windows 7, Windows 8, and Windows 8.1. See [Supported Windows versions](../index.md#supported-windows-versions) in _Introduction to Microsoft Edge WebView2_. +* Added Visual Studio and Visual Studio Code debug support for WebView2. Now, debug your script in the WebView2 right from your IDE. See [How to debug when developing with WebView2 controls](../how-to/debug.md). * Added `Native Object Injection` for the running script in WebView2 to access an IDispatch object from the Win32 component of the app and access the properties of the IDispatch object. See [AddRemoteObject](/microsoft-edge/webview2/reference/win32/iwebview2webview4?view=webview2-0.8.355&preserve-view=true#addremoteobject) ([#17](https://github.com/MicrosoftEdge/WebViewFeedback/issues/17)). * Added `AcceleratorKeyPressed` event. See [add_AcceleratorKeyPressed](/microsoft-edge/webview2/reference/win32/iwebview2webview4?view=webview2-0.8.355&preserve-view=true#add_acceleratorkeypressed) ([#57](https://github.com/MicrosoftEdge/WebViewFeedback/issues/57)). * Turned off the `Context Menus`. See [put_AreDefaultContextMenusEnabled](/microsoft-edge/webview2/reference/win32/iwebview2settings2?view=webview2-0.8.355&preserve-view=true#put_aredefaultcontextmenusenabled) ([#57](https://github.com/MicrosoftEdge/WebViewFeedback/issues/57)). @@ -3870,14 +11673,20 @@ This version of the WebView2 SDK requires Microsoft Edge version 80.0.314.0 or h * Updated `Notification Change Behavior` so WebView2 automatically rejects notification permission requests prompted by web content hosted in the WebView2 control. + + -## 0.8.270 +## Release SDK 0.8.270, for Runtime 78 (Sep. 10, 2019) + +Release Date: Sep. 10, 2019 [NuGet package for WebView2 SDK 0.8.270](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.8.270) -This version of the WebView2 SDK requires Microsoft Edge version 78.0.270.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 78.0.270.0 or higher. + + #### Changes * Added `DocumentTitleChanged` event to indicate document title change ([Issue #27](https://github.com/MicrosoftEdge/WebViewFeedback/issues/27)). @@ -3890,31 +11699,41 @@ This version of the WebView2 SDK requires Microsoft Edge version 78.0.270.0 or h During the channel search, the WebView2 team skips any previous channel version that isn't compatible with the WebView2 SDK. - The WebView2 team selects the more stable channel to ensure the most consistent behaviors for the end user. When you test with the latest Canary build, you should create a script to set the `WEBVIEW2_RELEASE_CHANNEL_PREFERENCE` environment variable to `1` before launching the app. See [Test upcoming APIs and features](how-to/set-preview-channel.md). + The WebView2 team selects the more stable channel to ensure the most consistent behaviors for the end user. When you test with the latest Canary build, you should create a script to set the `WEBVIEW2_RELEASE_CHANNEL_PREFERENCE` environment variable to `1` before launching the app. See [Test upcoming APIs and features](../how-to/set-preview-channel.md). * Updated the `CreateWebView2EnvironmentWithDetails` function with logic for selecting `userDataFolder` when not specified. For more information about the `CreateWebView2EnvironmentWithDetails` function, see [CreateWebView2EnvironmentWithDetails](/microsoft-edge/webview2/reference/win32/webview2-idl?view=webview2-0.8.355&preserve-view=true#createwebview2environmentwithdetails). If you previously used the default `userDataFolder` location, when you switch to the new SDK the default `userDataFolder` is reset (set to a new location in the host code directory) and your state is also reset. If the host process doesn't have permission to write to the specified directory, the `CreateWebView2EnvironmentWithDetails` function might fail. You can copy the data from the old `user data folder` to the new directory. + + -## 0.8.230 +## Release SDK 0.8.230, for Runtime 77 (Jul. 29, 2019) + +Release Date: Jul. 29, 2019 [NuGet package for WebView2 SDK 0.8.230](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.8.230) -This version of the WebView2 SDK requires Microsoft Edge version 77.0.230.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 77.0.230.0 or higher. + + #### Changes * Added `Stop` API to stop all navigation and pending resource fetches ([Issue #28](https://github.com/MicrosoftEdge/WebViewFeedback/issues/28)). * Added `.tlb` file to the NuGet package ([Issue #22](https://github.com/MicrosoftEdge/WebViewFeedback/issues/22)). * Added .NET projects to the installer list in the NuGet package ([Issue #32](https://github.com/MicrosoftEdge/WebViewFeedback/issues/32)). + + -## 0.8.190 +## Release SDK 0.8.190, for Runtime 77 (Jun. 17, 2019) + +Release Date: Jun. 17, 2019 [NuGet package for WebView2 SDK 0.8.190](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.8.190) -This version of the WebView2 SDK requires Microsoft Edge version 77.0.190.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 77.0.190.0 or higher. * Added `get_AreDevToolsEnabled`/`put_AreDevToolsEnabled` to control if users can open DevTools ([Issue #16](https://github.com/MicrosoftEdge/WebViewFeedback/issues/16)). * Added `get_IsStatusBarEnabled`/`put_IsStatusBarEnabled` to control if the status bar is displayed ([Issue #19](https://github.com/MicrosoftEdge/WebViewFeedback/issues/19)). @@ -3926,19 +11745,27 @@ This version of the WebView2 SDK requires Microsoft Edge version 77.0.190.0 or h * Added include path, linking, and autocopying of DLL files to NuGet `TARGET` file in SDK. * Turned on requesting `window.open()` in script. + + -## 0.8.149 +## Release SDK 0.8.149, for Runtime 76 (May 6, 2019) + +Release Date: May 6, 2019 [NuGet package for WebView2 SDK 0.8.149](https://www.nuget.org/packages/Microsoft.Web.WebView2/0.8.149) -This version of the WebView2 SDK requires Microsoft Edge version 76.0.149.0 or higher. +This Release version of the WebView2 SDK requires Microsoft Edge version 76.0.149.0 or higher. Initial developer preview release. + + ## See also -* [Overview of WebView2 features and APIs](./concepts/overview-features-apis.md) - outlines many of the APIs, by feature area, that are in Release SDK packages. -* [Contacting the Microsoft Edge WebView2 team](contact.md) \ No newline at end of file +* [About release notes for the WebView2 SDK](./about.md) +* [Release notes for the WebView2 SDK](./index.md) +* [Overview of WebView2 APIs](../concepts/overview-features-apis.md) - outlines many of the APIs, by feature area, that are in Release SDK packages. +* [Contacting the Microsoft Edge WebView2 team](../contact.md) From 9948fd536f8e173c6e412206712f7994ed117e52 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Wed, 13 May 2026 08:59:16 +1000 Subject: [PATCH 10/13] chore(webview2): regenerate bindings against SDK 1.0.3967.48 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Re-run `webview2gen download --version 1.0.3967.48 && webview2gen generate && webview2gen capabilities` against the latest stable WebView2 SDK (~1000-build jump from the cached 1.0.2903.40). The generator handled the full SDK delta without surfacing any of the 6 fixed bugs and without any new parser gaps; `GOOS=windows go vet ./pkg/webview2/` and `webview2gen verify` both pass. Delta: - 14 new interface bindings (Find API, DragStarting, DedicatedWorker, ICoreWebView2_28, ControllerOptions3/4, Environment15, Frame7, CompositionController5) - 2 enums extended (COREWEBVIEW2_PERMISSION_KIND, COREWEBVIEW2_PROCESS_FAILED_REASON) - capabilities.go: 23 → 98 interface→minimum-version entries (the archive fetch added historical SDKs back to 1.0.622) - WebView2.1.0.3967.48.idl cached in scripts/ --- .../webview2/COREWEBVIEW2_PERMISSION_KIND.go | 1 + .../COREWEBVIEW2_PROCESS_FAILED_REASON.go | 3 + .../ICoreWebView2CompositionController5.go | 72 + .../ICoreWebView2ControllerOptions3.go | 71 + .../ICoreWebView2ControllerOptions4.go | 78 + .../ICoreWebView2DragStartingEventArgs.go | 123 + .../ICoreWebView2DragStartingEventHandler.go | 63 + .../webview2/ICoreWebView2Environment15.go | 57 + webview2/pkg/webview2/ICoreWebView2Find.go | 171 + ...FindActiveMatchIndexChangedEventHandler.go | 63 + ...bView2FindMatchCountChangedEventHandler.go | 63 + .../pkg/webview2/ICoreWebView2FindOptions.go | 209 + .../ICoreWebView2FindStartCompletedHandler.go | 63 + webview2/pkg/webview2/ICoreWebView2Frame7.go | 72 + ...View2FrameChildFrameCreatedEventHandler.go | 63 + webview2/pkg/webview2/ICoreWebView2_28.go | 57 + webview2/pkg/webview2/capabilities.go | 150 + webview2/scripts/WebView2.1.0.3967.48.idl | 11204 ++++++++++++++++ 18 files changed, 12583 insertions(+) create mode 100644 webview2/pkg/webview2/ICoreWebView2CompositionController5.go create mode 100644 webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go create mode 100644 webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go create mode 100644 webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go create mode 100644 webview2/pkg/webview2/ICoreWebView2DragStartingEventHandler.go create mode 100644 webview2/pkg/webview2/ICoreWebView2Environment15.go create mode 100644 webview2/pkg/webview2/ICoreWebView2Find.go create mode 100644 webview2/pkg/webview2/ICoreWebView2FindActiveMatchIndexChangedEventHandler.go create mode 100644 webview2/pkg/webview2/ICoreWebView2FindMatchCountChangedEventHandler.go create mode 100644 webview2/pkg/webview2/ICoreWebView2FindOptions.go create mode 100644 webview2/pkg/webview2/ICoreWebView2FindStartCompletedHandler.go create mode 100644 webview2/pkg/webview2/ICoreWebView2Frame7.go create mode 100644 webview2/pkg/webview2/ICoreWebView2FrameChildFrameCreatedEventHandler.go create mode 100644 webview2/pkg/webview2/ICoreWebView2_28.go create mode 100644 webview2/scripts/WebView2.1.0.3967.48.idl diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go b/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go index f932c0f90e7..80dc0c18e29 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PERMISSION_KIND.go @@ -18,4 +18,5 @@ const ( COREWEBVIEW2_PERMISSION_KIND_LOCAL_FONTS = 10 COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGES = 11 COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT = 12 + COREWEBVIEW2_PERMISSION_KIND_PERSISTENT_STORAGE = 13 ) diff --git a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go index b1b21b1965f..042c8e38cf3 100644 --- a/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go +++ b/webview2/pkg/webview2/COREWEBVIEW2_PROCESS_FAILED_REASON.go @@ -12,4 +12,7 @@ const ( COREWEBVIEW2_PROCESS_FAILED_REASON_LAUNCH_FAILED = 4 COREWEBVIEW2_PROCESS_FAILED_REASON_OUT_OF_MEMORY = 5 COREWEBVIEW2_PROCESS_FAILED_REASON_PROFILE_DELETED = 6 + COREWEBVIEW2_PROCESS_FAILED_REASON_NORMAL_EXIT = 7 + COREWEBVIEW2_PROCESS_FAILED_REASON_ABNORMAL_EXIT = 8 + COREWEBVIEW2_PROCESS_FAILED_REASON_INTEGRITY_FAILURE = 9 ) diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController5.go b/webview2/pkg/webview2/ICoreWebView2CompositionController5.go new file mode 100644 index 00000000000..c70a13e74dc --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController5.go @@ -0,0 +1,72 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2CompositionController5Vtbl struct { + IUnknownVtbl + AddDragStarting ComProc + RemoveDragStarting ComProc +} + +type ICoreWebView2CompositionController5 struct { + Vtbl *ICoreWebView2CompositionController5Vtbl +} + +func (i *ICoreWebView2CompositionController5) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2CompositionController5) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2CompositionController5() (*ICoreWebView2CompositionController5, error) { + var result *ICoreWebView2CompositionController5 + + iidICoreWebView2CompositionController5 := NewGUID("{8d0f82eb-7c33-5a4c-9108-84ca28ccc3b4}") + hr, _, _ := i.Vtbl.QueryInterface.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(iidICoreWebView2CompositionController5)), + uintptr(unsafe.Pointer(&result))) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil +} + + +func (i *ICoreWebView2CompositionController5) AddDragStarting(eventHandler *ICoreWebView2DragStartingEventHandler) (EventRegistrationToken, error) { + + var token EventRegistrationToken + + hr, _, err := i.Vtbl.AddDragStarting.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(eventHandler)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return EventRegistrationToken{}, syscall.Errno(hr) + } + return token, err +} + +func (i *ICoreWebView2CompositionController5) RemoveDragStarting(token EventRegistrationToken) error { + + + hr, _, err := i.Vtbl.RemoveDragStarting.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go new file mode 100644 index 00000000000..0cb8913000d --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go @@ -0,0 +1,71 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2ControllerOptions3Vtbl struct { + IUnknownVtbl + GetDefaultBackgroundColor ComProc + PutDefaultBackgroundColor ComProc +} + +type ICoreWebView2ControllerOptions3 struct { + Vtbl *ICoreWebView2ControllerOptions3Vtbl +} + +func (i *ICoreWebView2ControllerOptions3) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2ControllerOptions3) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2ControllerOptions3() (*ICoreWebView2ControllerOptions3, error) { + var result *ICoreWebView2ControllerOptions3 + + iidICoreWebView2ControllerOptions3 := NewGUID("{b32b191a-8998-57ca-b7cb-e04617e4ce4a}") + hr, _, _ := i.Vtbl.QueryInterface.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(iidICoreWebView2ControllerOptions3)), + uintptr(unsafe.Pointer(&result))) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil +} + + +func (i *ICoreWebView2ControllerOptions3) GetDefaultBackgroundColor() (COREWEBVIEW2_COLOR, error) { + + var value COREWEBVIEW2_COLOR + + hr, _, err := i.Vtbl.GetDefaultBackgroundColor.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return COREWEBVIEW2_COLOR{}, syscall.Errno(hr) + } + return value, err +} + +func (i *ICoreWebView2ControllerOptions3) PutDefaultBackgroundColor(value COREWEBVIEW2_COLOR) error { + + + hr, _, err := i.Vtbl.PutDefaultBackgroundColor.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go new file mode 100644 index 00000000000..7dbdea6cd20 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go @@ -0,0 +1,78 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2ControllerOptions4Vtbl struct { + IUnknownVtbl + GetAllowHostInputProcessing ComProc + PutAllowHostInputProcessing ComProc +} + +type ICoreWebView2ControllerOptions4 struct { + Vtbl *ICoreWebView2ControllerOptions4Vtbl +} + +func (i *ICoreWebView2ControllerOptions4) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2ControllerOptions4) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2ControllerOptions4() (*ICoreWebView2ControllerOptions4, error) { + var result *ICoreWebView2ControllerOptions4 + + iidICoreWebView2ControllerOptions4 := NewGUID("{21eb052f-ad39-555e-824a-c87b091d4d36}") + hr, _, _ := i.Vtbl.QueryInterface.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(iidICoreWebView2ControllerOptions4)), + uintptr(unsafe.Pointer(&result))) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil +} + + +func (i *ICoreWebView2ControllerOptions4) GetAllowHostInputProcessing() (bool, error) { + // Create int32 to hold bool result + var _value int32 + + hr, _, err := i.Vtbl.GetAllowHostInputProcessing.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return false, syscall.Errno(hr) + } + // Get result and cleanup + value := _value != 0 + return value, err +} + +func (i *ICoreWebView2ControllerOptions4) PutAllowHostInputProcessing(value bool) error { + + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutAllowHostInputProcessing.Call( + uintptr(unsafe.Pointer(i)), + uintptr(_value), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} diff --git a/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go new file mode 100644 index 00000000000..d5dc28a3b9b --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go @@ -0,0 +1,123 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2DragStartingEventArgsVtbl struct { + IUnknownVtbl + GetAllowedDropEffects ComProc + GetData ComProc + GetHandled ComProc + PutHandled ComProc + GetPosition ComProc + GetDeferral ComProc +} + +type ICoreWebView2DragStartingEventArgs struct { + Vtbl *ICoreWebView2DragStartingEventArgsVtbl +} + +func (i *ICoreWebView2DragStartingEventArgs) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2DragStartingEventArgs) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2DragStartingEventArgs) GetAllowedDropEffects() (uint32, error) { + + var value uint32 + + hr, _, err := i.Vtbl.GetAllowedDropEffects.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return 0, syscall.Errno(hr) + } + return value, err +} + +func (i *ICoreWebView2DragStartingEventArgs) GetData() (*IDataObject, error) { + + var value *IDataObject + + hr, _, err := i.Vtbl.GetData.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return value, err +} + +func (i *ICoreWebView2DragStartingEventArgs) GetHandled() (bool, error) { + // Create int32 to hold bool result + var _value int32 + + hr, _, err := i.Vtbl.GetHandled.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return false, syscall.Errno(hr) + } + // Get result and cleanup + value := _value != 0 + return value, err +} + +func (i *ICoreWebView2DragStartingEventArgs) PutHandled(value bool) error { + + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutHandled.Call( + uintptr(unsafe.Pointer(i)), + uintptr(_value), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2DragStartingEventArgs) GetPosition() (POINT, error) { + + var value POINT + + hr, _, err := i.Vtbl.GetPosition.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return POINT{}, syscall.Errno(hr) + } + return value, err +} + +func (i *ICoreWebView2DragStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { + + var value *ICoreWebView2Deferral + + hr, _, err := i.Vtbl.GetDeferral.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return value, err +} diff --git a/webview2/pkg/webview2/ICoreWebView2DragStartingEventHandler.go b/webview2/pkg/webview2/ICoreWebView2DragStartingEventHandler.go new file mode 100644 index 00000000000..99d09abf01e --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2DragStartingEventHandler.go @@ -0,0 +1,63 @@ +//go:build windows + +package webview2 +import ( + "unsafe" +) + +type ICoreWebView2DragStartingEventHandlerVtbl struct { + IUnknownVtbl + Invoke ComProc +} + +type ICoreWebView2DragStartingEventHandler struct { + Vtbl *ICoreWebView2DragStartingEventHandlerVtbl + impl ICoreWebView2DragStartingEventHandlerImpl +} + +func (i *ICoreWebView2DragStartingEventHandler) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2DragStartingEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func ICoreWebView2DragStartingEventHandlerIUnknownQueryInterface(this *ICoreWebView2DragStartingEventHandler, refiid, object uintptr) uintptr { + return this.impl.QueryInterface(refiid, object) +} + +func ICoreWebView2DragStartingEventHandlerIUnknownAddRef(this *ICoreWebView2DragStartingEventHandler) uintptr { + return uintptr(this.impl.AddRef()) +} + +func ICoreWebView2DragStartingEventHandlerIUnknownRelease(this *ICoreWebView2DragStartingEventHandler) uintptr { + return uintptr(this.impl.Release()) +} + +func ICoreWebView2DragStartingEventHandlerInvoke(this *ICoreWebView2DragStartingEventHandler, sender *ICoreWebView2CompositionController, args *ICoreWebView2DragStartingEventArgs) uintptr { + return this.impl.DragStarting(sender, args) +} + +type ICoreWebView2DragStartingEventHandlerImpl interface { + IUnknownImpl + DragStarting(sender *ICoreWebView2CompositionController, args *ICoreWebView2DragStartingEventArgs) uintptr +} + +var ICoreWebView2DragStartingEventHandlerFn = ICoreWebView2DragStartingEventHandlerVtbl{ + IUnknownVtbl { + NewComProc(ICoreWebView2DragStartingEventHandlerIUnknownQueryInterface), + NewComProc(ICoreWebView2DragStartingEventHandlerIUnknownAddRef), + NewComProc(ICoreWebView2DragStartingEventHandlerIUnknownRelease), + }, + NewComProc(ICoreWebView2DragStartingEventHandlerInvoke), +} + +func NewICoreWebView2DragStartingEventHandler(impl ICoreWebView2DragStartingEventHandlerImpl) *ICoreWebView2DragStartingEventHandler { + return &ICoreWebView2DragStartingEventHandler{ + Vtbl: &ICoreWebView2DragStartingEventHandlerFn, + impl: impl, + } +} diff --git a/webview2/pkg/webview2/ICoreWebView2Environment15.go b/webview2/pkg/webview2/ICoreWebView2Environment15.go new file mode 100644 index 00000000000..99ac15b5b68 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2Environment15.go @@ -0,0 +1,57 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2Environment15Vtbl struct { + IUnknownVtbl + CreateFindOptions ComProc +} + +type ICoreWebView2Environment15 struct { + Vtbl *ICoreWebView2Environment15Vtbl +} + +func (i *ICoreWebView2Environment15) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2Environment15) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2Environment15() (*ICoreWebView2Environment15, error) { + var result *ICoreWebView2Environment15 + + iidICoreWebView2Environment15 := NewGUID("{2ac5ebfb-e654-5961-a667-7971885c7b27}") + hr, _, _ := i.Vtbl.QueryInterface.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(iidICoreWebView2Environment15)), + uintptr(unsafe.Pointer(&result))) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil +} + + +func (i *ICoreWebView2Environment15) CreateFindOptions() (*ICoreWebView2FindOptions, error) { + + var value *ICoreWebView2FindOptions + + hr, _, err := i.Vtbl.CreateFindOptions.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return value, err +} diff --git a/webview2/pkg/webview2/ICoreWebView2Find.go b/webview2/pkg/webview2/ICoreWebView2Find.go new file mode 100644 index 00000000000..4f901067101 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2Find.go @@ -0,0 +1,171 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2FindVtbl struct { + IUnknownVtbl + GetActiveMatchIndex ComProc + GetMatchCount ComProc + AddActiveMatchIndexChanged ComProc + RemoveActiveMatchIndexChanged ComProc + AddMatchCountChanged ComProc + RemoveMatchCountChanged ComProc + Start ComProc + FindNext ComProc + FindPrevious ComProc + Stop ComProc +} + +type ICoreWebView2Find struct { + Vtbl *ICoreWebView2FindVtbl +} + +func (i *ICoreWebView2Find) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2Find) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2Find) GetActiveMatchIndex() (int32, error) { + + var value int32 + + hr, _, err := i.Vtbl.GetActiveMatchIndex.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return 0, syscall.Errno(hr) + } + return value, err +} + +func (i *ICoreWebView2Find) GetMatchCount() (int32, error) { + + var value int32 + + hr, _, err := i.Vtbl.GetMatchCount.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return 0, syscall.Errno(hr) + } + return value, err +} + +func (i *ICoreWebView2Find) AddActiveMatchIndexChanged(eventHandler *ICoreWebView2FindActiveMatchIndexChangedEventHandler) (EventRegistrationToken, error) { + + var token EventRegistrationToken + + hr, _, err := i.Vtbl.AddActiveMatchIndexChanged.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(eventHandler)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return EventRegistrationToken{}, syscall.Errno(hr) + } + return token, err +} + +func (i *ICoreWebView2Find) RemoveActiveMatchIndexChanged(token EventRegistrationToken) error { + + + hr, _, err := i.Vtbl.RemoveActiveMatchIndexChanged.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2Find) AddMatchCountChanged(eventHandler *ICoreWebView2FindMatchCountChangedEventHandler) (EventRegistrationToken, error) { + + var token EventRegistrationToken + + hr, _, err := i.Vtbl.AddMatchCountChanged.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(eventHandler)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return EventRegistrationToken{}, syscall.Errno(hr) + } + return token, err +} + +func (i *ICoreWebView2Find) RemoveMatchCountChanged(token EventRegistrationToken) error { + + + hr, _, err := i.Vtbl.RemoveMatchCountChanged.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2Find) Start(options *ICoreWebView2FindOptions, handler *ICoreWebView2FindStartCompletedHandler) error { + + + hr, _, err := i.Vtbl.Start.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(options)), + uintptr(unsafe.Pointer(handler)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2Find) FindNext() error { + + + hr, _, err := i.Vtbl.FindNext.Call( + uintptr(unsafe.Pointer(i)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2Find) FindPrevious() error { + + + hr, _, err := i.Vtbl.FindPrevious.Call( + uintptr(unsafe.Pointer(i)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2Find) Stop() error { + + + hr, _, err := i.Vtbl.Stop.Call( + uintptr(unsafe.Pointer(i)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} diff --git a/webview2/pkg/webview2/ICoreWebView2FindActiveMatchIndexChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FindActiveMatchIndexChangedEventHandler.go new file mode 100644 index 00000000000..e42a8fae32b --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2FindActiveMatchIndexChangedEventHandler.go @@ -0,0 +1,63 @@ +//go:build windows + +package webview2 +import ( + "unsafe" +) + +type ICoreWebView2FindActiveMatchIndexChangedEventHandlerVtbl struct { + IUnknownVtbl + Invoke ComProc +} + +type ICoreWebView2FindActiveMatchIndexChangedEventHandler struct { + Vtbl *ICoreWebView2FindActiveMatchIndexChangedEventHandlerVtbl + impl ICoreWebView2FindActiveMatchIndexChangedEventHandlerImpl +} + +func (i *ICoreWebView2FindActiveMatchIndexChangedEventHandler) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2FindActiveMatchIndexChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func ICoreWebView2FindActiveMatchIndexChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FindActiveMatchIndexChangedEventHandler, refiid, object uintptr) uintptr { + return this.impl.QueryInterface(refiid, object) +} + +func ICoreWebView2FindActiveMatchIndexChangedEventHandlerIUnknownAddRef(this *ICoreWebView2FindActiveMatchIndexChangedEventHandler) uintptr { + return uintptr(this.impl.AddRef()) +} + +func ICoreWebView2FindActiveMatchIndexChangedEventHandlerIUnknownRelease(this *ICoreWebView2FindActiveMatchIndexChangedEventHandler) uintptr { + return uintptr(this.impl.Release()) +} + +func ICoreWebView2FindActiveMatchIndexChangedEventHandlerInvoke(this *ICoreWebView2FindActiveMatchIndexChangedEventHandler, sender *ICoreWebView2Find, args *IUnknown) uintptr { + return this.impl.FindActiveMatchIndexChanged(sender, args) +} + +type ICoreWebView2FindActiveMatchIndexChangedEventHandlerImpl interface { + IUnknownImpl + FindActiveMatchIndexChanged(sender *ICoreWebView2Find, args *IUnknown) uintptr +} + +var ICoreWebView2FindActiveMatchIndexChangedEventHandlerFn = ICoreWebView2FindActiveMatchIndexChangedEventHandlerVtbl{ + IUnknownVtbl { + NewComProc(ICoreWebView2FindActiveMatchIndexChangedEventHandlerIUnknownQueryInterface), + NewComProc(ICoreWebView2FindActiveMatchIndexChangedEventHandlerIUnknownAddRef), + NewComProc(ICoreWebView2FindActiveMatchIndexChangedEventHandlerIUnknownRelease), + }, + NewComProc(ICoreWebView2FindActiveMatchIndexChangedEventHandlerInvoke), +} + +func NewICoreWebView2FindActiveMatchIndexChangedEventHandler(impl ICoreWebView2FindActiveMatchIndexChangedEventHandlerImpl) *ICoreWebView2FindActiveMatchIndexChangedEventHandler { + return &ICoreWebView2FindActiveMatchIndexChangedEventHandler{ + Vtbl: &ICoreWebView2FindActiveMatchIndexChangedEventHandlerFn, + impl: impl, + } +} diff --git a/webview2/pkg/webview2/ICoreWebView2FindMatchCountChangedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FindMatchCountChangedEventHandler.go new file mode 100644 index 00000000000..b531a739274 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2FindMatchCountChangedEventHandler.go @@ -0,0 +1,63 @@ +//go:build windows + +package webview2 +import ( + "unsafe" +) + +type ICoreWebView2FindMatchCountChangedEventHandlerVtbl struct { + IUnknownVtbl + Invoke ComProc +} + +type ICoreWebView2FindMatchCountChangedEventHandler struct { + Vtbl *ICoreWebView2FindMatchCountChangedEventHandlerVtbl + impl ICoreWebView2FindMatchCountChangedEventHandlerImpl +} + +func (i *ICoreWebView2FindMatchCountChangedEventHandler) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2FindMatchCountChangedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func ICoreWebView2FindMatchCountChangedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FindMatchCountChangedEventHandler, refiid, object uintptr) uintptr { + return this.impl.QueryInterface(refiid, object) +} + +func ICoreWebView2FindMatchCountChangedEventHandlerIUnknownAddRef(this *ICoreWebView2FindMatchCountChangedEventHandler) uintptr { + return uintptr(this.impl.AddRef()) +} + +func ICoreWebView2FindMatchCountChangedEventHandlerIUnknownRelease(this *ICoreWebView2FindMatchCountChangedEventHandler) uintptr { + return uintptr(this.impl.Release()) +} + +func ICoreWebView2FindMatchCountChangedEventHandlerInvoke(this *ICoreWebView2FindMatchCountChangedEventHandler, sender *ICoreWebView2Find, args *IUnknown) uintptr { + return this.impl.FindMatchCountChanged(sender, args) +} + +type ICoreWebView2FindMatchCountChangedEventHandlerImpl interface { + IUnknownImpl + FindMatchCountChanged(sender *ICoreWebView2Find, args *IUnknown) uintptr +} + +var ICoreWebView2FindMatchCountChangedEventHandlerFn = ICoreWebView2FindMatchCountChangedEventHandlerVtbl{ + IUnknownVtbl { + NewComProc(ICoreWebView2FindMatchCountChangedEventHandlerIUnknownQueryInterface), + NewComProc(ICoreWebView2FindMatchCountChangedEventHandlerIUnknownAddRef), + NewComProc(ICoreWebView2FindMatchCountChangedEventHandlerIUnknownRelease), + }, + NewComProc(ICoreWebView2FindMatchCountChangedEventHandlerInvoke), +} + +func NewICoreWebView2FindMatchCountChangedEventHandler(impl ICoreWebView2FindMatchCountChangedEventHandlerImpl) *ICoreWebView2FindMatchCountChangedEventHandler { + return &ICoreWebView2FindMatchCountChangedEventHandler{ + Vtbl: &ICoreWebView2FindMatchCountChangedEventHandlerFn, + impl: impl, + } +} diff --git a/webview2/pkg/webview2/ICoreWebView2FindOptions.go b/webview2/pkg/webview2/ICoreWebView2FindOptions.go new file mode 100644 index 00000000000..c2fcb4bbf5f --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2FindOptions.go @@ -0,0 +1,209 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2FindOptionsVtbl struct { + IUnknownVtbl + GetFindTerm ComProc + PutFindTerm ComProc + GetIsCaseSensitive ComProc + PutIsCaseSensitive ComProc + GetShouldHighlightAllMatches ComProc + PutShouldHighlightAllMatches ComProc + GetShouldMatchWord ComProc + PutShouldMatchWord ComProc + GetSuppressDefaultFindDialog ComProc + PutSuppressDefaultFindDialog ComProc +} + +type ICoreWebView2FindOptions struct { + Vtbl *ICoreWebView2FindOptionsVtbl +} + +func (i *ICoreWebView2FindOptions) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2FindOptions) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2FindOptions) GetFindTerm() (string, error) { + // Create *uint16 to hold result + var _value *uint16 + + + hr, _, err := i.Vtbl.GetFindTerm.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return "", syscall.Errno(hr) + } + // Get result and cleanup + value := UTF16PtrToString(_value) + CoTaskMemFree(unsafe.Pointer(_value)) + return value, err +} + +func (i *ICoreWebView2FindOptions) PutFindTerm(value string) error { + + // Convert string 'value' to *uint16 + _value, err := UTF16PtrFromString(value) + if err != nil { + return err + } + + hr, _, err := i.Vtbl.PutFindTerm.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2FindOptions) GetIsCaseSensitive() (bool, error) { + // Create int32 to hold bool result + var _value int32 + + hr, _, err := i.Vtbl.GetIsCaseSensitive.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return false, syscall.Errno(hr) + } + // Get result and cleanup + value := _value != 0 + return value, err +} + +func (i *ICoreWebView2FindOptions) PutIsCaseSensitive(value bool) error { + + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutIsCaseSensitive.Call( + uintptr(unsafe.Pointer(i)), + uintptr(_value), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2FindOptions) GetShouldHighlightAllMatches() (bool, error) { + // Create int32 to hold bool result + var _value int32 + + hr, _, err := i.Vtbl.GetShouldHighlightAllMatches.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return false, syscall.Errno(hr) + } + // Get result and cleanup + value := _value != 0 + return value, err +} + +func (i *ICoreWebView2FindOptions) PutShouldHighlightAllMatches(value bool) error { + + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutShouldHighlightAllMatches.Call( + uintptr(unsafe.Pointer(i)), + uintptr(_value), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2FindOptions) GetShouldMatchWord() (bool, error) { + // Create int32 to hold bool result + var _value int32 + + hr, _, err := i.Vtbl.GetShouldMatchWord.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return false, syscall.Errno(hr) + } + // Get result and cleanup + value := _value != 0 + return value, err +} + +func (i *ICoreWebView2FindOptions) PutShouldMatchWord(value bool) error { + + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutShouldMatchWord.Call( + uintptr(unsafe.Pointer(i)), + uintptr(_value), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} + +func (i *ICoreWebView2FindOptions) GetSuppressDefaultFindDialog() (bool, error) { + // Create int32 to hold bool result + var _value int32 + + hr, _, err := i.Vtbl.GetSuppressDefaultFindDialog.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&_value)), + ) + if windows.Handle(hr) != windows.S_OK { + return false, syscall.Errno(hr) + } + // Get result and cleanup + value := _value != 0 + return value, err +} + +func (i *ICoreWebView2FindOptions) PutSuppressDefaultFindDialog(value bool) error { + + // Convert Go bool to COM BOOL (int32) + var _value int32 + if value { + _value = 1 + } + + hr, _, err := i.Vtbl.PutSuppressDefaultFindDialog.Call( + uintptr(unsafe.Pointer(i)), + uintptr(_value), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} diff --git a/webview2/pkg/webview2/ICoreWebView2FindStartCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2FindStartCompletedHandler.go new file mode 100644 index 00000000000..a381ada55b3 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2FindStartCompletedHandler.go @@ -0,0 +1,63 @@ +//go:build windows + +package webview2 +import ( + "unsafe" +) + +type ICoreWebView2FindStartCompletedHandlerVtbl struct { + IUnknownVtbl + Invoke ComProc +} + +type ICoreWebView2FindStartCompletedHandler struct { + Vtbl *ICoreWebView2FindStartCompletedHandlerVtbl + impl ICoreWebView2FindStartCompletedHandlerImpl +} + +func (i *ICoreWebView2FindStartCompletedHandler) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2FindStartCompletedHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func ICoreWebView2FindStartCompletedHandlerIUnknownQueryInterface(this *ICoreWebView2FindStartCompletedHandler, refiid, object uintptr) uintptr { + return this.impl.QueryInterface(refiid, object) +} + +func ICoreWebView2FindStartCompletedHandlerIUnknownAddRef(this *ICoreWebView2FindStartCompletedHandler) uintptr { + return uintptr(this.impl.AddRef()) +} + +func ICoreWebView2FindStartCompletedHandlerIUnknownRelease(this *ICoreWebView2FindStartCompletedHandler) uintptr { + return uintptr(this.impl.Release()) +} + +func ICoreWebView2FindStartCompletedHandlerInvoke(this *ICoreWebView2FindStartCompletedHandler, errorCode uintptr) uintptr { + return this.impl.FindStartCompleted(errorCode) +} + +type ICoreWebView2FindStartCompletedHandlerImpl interface { + IUnknownImpl + FindStartCompleted(errorCode uintptr) uintptr +} + +var ICoreWebView2FindStartCompletedHandlerFn = ICoreWebView2FindStartCompletedHandlerVtbl{ + IUnknownVtbl { + NewComProc(ICoreWebView2FindStartCompletedHandlerIUnknownQueryInterface), + NewComProc(ICoreWebView2FindStartCompletedHandlerIUnknownAddRef), + NewComProc(ICoreWebView2FindStartCompletedHandlerIUnknownRelease), + }, + NewComProc(ICoreWebView2FindStartCompletedHandlerInvoke), +} + +func NewICoreWebView2FindStartCompletedHandler(impl ICoreWebView2FindStartCompletedHandlerImpl) *ICoreWebView2FindStartCompletedHandler { + return &ICoreWebView2FindStartCompletedHandler{ + Vtbl: &ICoreWebView2FindStartCompletedHandlerFn, + impl: impl, + } +} diff --git a/webview2/pkg/webview2/ICoreWebView2Frame7.go b/webview2/pkg/webview2/ICoreWebView2Frame7.go new file mode 100644 index 00000000000..c332deb51c3 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2Frame7.go @@ -0,0 +1,72 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2Frame7Vtbl struct { + IUnknownVtbl + AddFrameCreated ComProc + RemoveFrameCreated ComProc +} + +type ICoreWebView2Frame7 struct { + Vtbl *ICoreWebView2Frame7Vtbl +} + +func (i *ICoreWebView2Frame7) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2Frame7) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2Frame7() (*ICoreWebView2Frame7, error) { + var result *ICoreWebView2Frame7 + + iidICoreWebView2Frame7 := NewGUID("{3598cfa2-d85d-5a9f-9228-4dde1f59ec64}") + hr, _, _ := i.Vtbl.QueryInterface.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(iidICoreWebView2Frame7)), + uintptr(unsafe.Pointer(&result))) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil +} + + +func (i *ICoreWebView2Frame7) AddFrameCreated(eventHandler *ICoreWebView2FrameChildFrameCreatedEventHandler) (EventRegistrationToken, error) { + + var token EventRegistrationToken + + hr, _, err := i.Vtbl.AddFrameCreated.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(eventHandler)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return EventRegistrationToken{}, syscall.Errno(hr) + } + return token, err +} + +func (i *ICoreWebView2Frame7) RemoveFrameCreated(token EventRegistrationToken) error { + + + hr, _, err := i.Vtbl.RemoveFrameCreated.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&token)), + ) + if windows.Handle(hr) != windows.S_OK { + return syscall.Errno(hr) + } + return err +} diff --git a/webview2/pkg/webview2/ICoreWebView2FrameChildFrameCreatedEventHandler.go b/webview2/pkg/webview2/ICoreWebView2FrameChildFrameCreatedEventHandler.go new file mode 100644 index 00000000000..0ae256d6d10 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2FrameChildFrameCreatedEventHandler.go @@ -0,0 +1,63 @@ +//go:build windows + +package webview2 +import ( + "unsafe" +) + +type ICoreWebView2FrameChildFrameCreatedEventHandlerVtbl struct { + IUnknownVtbl + Invoke ComProc +} + +type ICoreWebView2FrameChildFrameCreatedEventHandler struct { + Vtbl *ICoreWebView2FrameChildFrameCreatedEventHandlerVtbl + impl ICoreWebView2FrameChildFrameCreatedEventHandlerImpl +} + +func (i *ICoreWebView2FrameChildFrameCreatedEventHandler) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2FrameChildFrameCreatedEventHandler) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func ICoreWebView2FrameChildFrameCreatedEventHandlerIUnknownQueryInterface(this *ICoreWebView2FrameChildFrameCreatedEventHandler, refiid, object uintptr) uintptr { + return this.impl.QueryInterface(refiid, object) +} + +func ICoreWebView2FrameChildFrameCreatedEventHandlerIUnknownAddRef(this *ICoreWebView2FrameChildFrameCreatedEventHandler) uintptr { + return uintptr(this.impl.AddRef()) +} + +func ICoreWebView2FrameChildFrameCreatedEventHandlerIUnknownRelease(this *ICoreWebView2FrameChildFrameCreatedEventHandler) uintptr { + return uintptr(this.impl.Release()) +} + +func ICoreWebView2FrameChildFrameCreatedEventHandlerInvoke(this *ICoreWebView2FrameChildFrameCreatedEventHandler, sender *ICoreWebView2Frame, args *ICoreWebView2FrameCreatedEventArgs) uintptr { + return this.impl.FrameChildFrameCreated(sender, args) +} + +type ICoreWebView2FrameChildFrameCreatedEventHandlerImpl interface { + IUnknownImpl + FrameChildFrameCreated(sender *ICoreWebView2Frame, args *ICoreWebView2FrameCreatedEventArgs) uintptr +} + +var ICoreWebView2FrameChildFrameCreatedEventHandlerFn = ICoreWebView2FrameChildFrameCreatedEventHandlerVtbl{ + IUnknownVtbl { + NewComProc(ICoreWebView2FrameChildFrameCreatedEventHandlerIUnknownQueryInterface), + NewComProc(ICoreWebView2FrameChildFrameCreatedEventHandlerIUnknownAddRef), + NewComProc(ICoreWebView2FrameChildFrameCreatedEventHandlerIUnknownRelease), + }, + NewComProc(ICoreWebView2FrameChildFrameCreatedEventHandlerInvoke), +} + +func NewICoreWebView2FrameChildFrameCreatedEventHandler(impl ICoreWebView2FrameChildFrameCreatedEventHandlerImpl) *ICoreWebView2FrameChildFrameCreatedEventHandler { + return &ICoreWebView2FrameChildFrameCreatedEventHandler{ + Vtbl: &ICoreWebView2FrameChildFrameCreatedEventHandlerFn, + impl: impl, + } +} diff --git a/webview2/pkg/webview2/ICoreWebView2_28.go b/webview2/pkg/webview2/ICoreWebView2_28.go new file mode 100644 index 00000000000..f90e3848065 --- /dev/null +++ b/webview2/pkg/webview2/ICoreWebView2_28.go @@ -0,0 +1,57 @@ +//go:build windows + +package webview2 +import ( + "unsafe" + "syscall" + "golang.org/x/sys/windows" +) + +type ICoreWebView2_28Vtbl struct { + IUnknownVtbl + GetFind ComProc +} + +type ICoreWebView2_28 struct { + Vtbl *ICoreWebView2_28Vtbl +} + +func (i *ICoreWebView2_28) AddRef() uint32 { + refCounter, _, _ := i.Vtbl.AddRef.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + +func (i *ICoreWebView2_28) Release() uint32 { + refCounter, _, _ := i.Vtbl.Release.Call(uintptr(unsafe.Pointer(i))) + return uint32(refCounter) +} + + +func (i *ICoreWebView2) GetICoreWebView2_28() (*ICoreWebView2_28, error) { + var result *ICoreWebView2_28 + + iidICoreWebView2_28 := NewGUID("{62e50381-5bf5-51a8-aae0-f20a3a9c8a90}") + hr, _, _ := i.Vtbl.QueryInterface.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(iidICoreWebView2_28)), + uintptr(unsafe.Pointer(&result))) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return result, nil +} + + +func (i *ICoreWebView2_28) GetFind() (*ICoreWebView2Find, error) { + + var value *ICoreWebView2Find + + hr, _, err := i.Vtbl.GetFind.Call( + uintptr(unsafe.Pointer(i)), + uintptr(unsafe.Pointer(&value)), + ) + if windows.Handle(hr) != windows.S_OK { + return nil, syscall.Errno(hr) + } + return value, err +} diff --git a/webview2/pkg/webview2/capabilities.go b/webview2/pkg/webview2/capabilities.go index 565512063ed..87a94ff4502 100644 --- a/webview2/pkg/webview2/capabilities.go +++ b/webview2/pkg/webview2/capabilities.go @@ -14,6 +14,7 @@ import ( // minimum WebView2 SDK version that introduced it. Use SupportsInterface // to compare against a runtime version. var InterfaceMinimumVersion = map[string]string{ + "ICoreWebView2WindowFeatures": "0.9.622.11", "ICoreWebView2PrintCompletedHandler": "1.0.1518.46", "ICoreWebView2PrintSettings2": "1.0.1518.46", "ICoreWebView2PrintToPdfStreamCompletedHandler": "1.0.1518.46", @@ -33,10 +34,84 @@ var InterfaceMinimumVersion = map[string]string{ "ICoreWebView2SetPermissionStateCompletedHandler": "1.0.1661.34", "ICoreWebView2SharedBuffer": "1.0.1661.34", "ICoreWebView2_17": "1.0.1661.34", + "ICoreWebView2Settings8": "1.0.1722.45", "ICoreWebView2File": "1.0.1774.30", "ICoreWebView2ObjectCollectionView": "1.0.1774.30", "ICoreWebView2WebMessageReceivedEventArgs2": "1.0.1774.30", + "ICoreWebView2LaunchingExternalUriSchemeEventArgs": "1.0.1823.32", + "ICoreWebView2LaunchingExternalUriSchemeEventHandler": "1.0.1823.32", + "ICoreWebView2_18": "1.0.1823.32", "ICoreWebView2_19": "1.0.1823.32", + "ICoreWebView2NavigationStartingEventArgs3": "1.0.1901.177", + "ICoreWebView2NewWindowRequestedEventArgs3": "1.0.2151.40", + "ICoreWebView2AcceleratorKeyPressedEventArgs2": "1.0.2210.55", + "ICoreWebView2BrowserExtension": "1.0.2210.55", + "ICoreWebView2BrowserExtensionEnableCompletedHandler": "1.0.2210.55", + "ICoreWebView2BrowserExtensionList": "1.0.2210.55", + "ICoreWebView2BrowserExtensionRemoveCompletedHandler": "1.0.2210.55", + "ICoreWebView2Environment13": "1.0.2210.55", + "ICoreWebView2EnvironmentOptions6": "1.0.2210.55", + "ICoreWebView2Frame5": "1.0.2210.55", + "ICoreWebView2FrameInfo2": "1.0.2210.55", + "ICoreWebView2GetProcessExtendedInfosCompletedHandler": "1.0.2210.55", + "ICoreWebView2ProcessExtendedInfo": "1.0.2210.55", + "ICoreWebView2ProcessExtendedInfoCollection": "1.0.2210.55", + "ICoreWebView2Profile7": "1.0.2210.55", + "ICoreWebView2Profile8": "1.0.2210.55", + "ICoreWebView2ProfileAddBrowserExtensionCompletedHandler": "1.0.2210.55", + "ICoreWebView2ProfileDeletedEventHandler": "1.0.2210.55", + "ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler": "1.0.2210.55", + "ICoreWebView2_20": "1.0.2210.55", + "ICoreWebView2ExecuteScriptResult": "1.0.2277.86", + "ICoreWebView2ExecuteScriptWithResultCompletedHandler": "1.0.2277.86", + "ICoreWebView2ScriptException": "1.0.2277.86", + "ICoreWebView2_21": "1.0.2277.86", + "ICoreWebView2WebResourceRequestedEventArgs2": "1.0.2365.46", + "ICoreWebView2_22": "1.0.2365.46", + "ICoreWebView2CompositionController4": "1.0.2420.47", + "ICoreWebView2NonClientRegionChangedEventArgs": "1.0.2420.47", + "ICoreWebView2NonClientRegionChangedEventHandler": "1.0.2420.47", + "ICoreWebView2ProcessFailedEventArgs3": "1.0.2420.47", + "ICoreWebView2RegionRectCollectionView": "1.0.2420.47", + "ICoreWebView2Settings9": "1.0.2420.47", + "ICoreWebView2EnvironmentOptions7": "1.0.2478.35", + "ICoreWebView2EnvironmentOptions8": "1.0.2535.41", + "ICoreWebView2Environment14": "1.0.2651.64", + "ICoreWebView2FileSystemHandle": "1.0.2651.64", + "ICoreWebView2ObjectCollection": "1.0.2651.64", + "ICoreWebView2_23": "1.0.2651.64", + "ICoreWebView2Notification": "1.0.2739.15", + "ICoreWebView2NotificationCloseRequestedEventHandler": "1.0.2739.15", + "ICoreWebView2NotificationReceivedEventArgs": "1.0.2739.15", + "ICoreWebView2NotificationReceivedEventHandler": "1.0.2739.15", + "ICoreWebView2SaveAsUIShowingEventArgs": "1.0.2739.15", + "ICoreWebView2SaveAsUIShowingEventHandler": "1.0.2739.15", + "ICoreWebView2ShowSaveAsUICompletedHandler": "1.0.2739.15", + "ICoreWebView2_24": "1.0.2739.15", + "ICoreWebView2_25": "1.0.2739.15", + "ICoreWebView2SaveFileSecurityCheckStartingEventArgs": "1.0.2849.39", + "ICoreWebView2SaveFileSecurityCheckStartingEventHandler": "1.0.2849.39", + "ICoreWebView2_26": "1.0.2849.39", + "ICoreWebView2Frame6": "1.0.2903.40", + "ICoreWebView2FrameScreenCaptureStartingEventHandler": "1.0.2903.40", + "ICoreWebView2ScreenCaptureStartingEventArgs": "1.0.2903.40", + "ICoreWebView2ScreenCaptureStartingEventHandler": "1.0.2903.40", + "ICoreWebView2_27": "1.0.2903.40", + "ICoreWebView2Frame7": "1.0.3240.44", + "ICoreWebView2FrameChildFrameCreatedEventHandler": "1.0.3240.44", + "ICoreWebView2ControllerOptions3": "1.0.3296.44", + "ICoreWebView2ControllerOptions4": "1.0.3351.48", + "ICoreWebView2Environment15": "1.0.3405.78", + "ICoreWebView2Find": "1.0.3405.78", + "ICoreWebView2FindActiveMatchIndexChangedEventHandler": "1.0.3405.78", + "ICoreWebView2FindMatchCountChangedEventHandler": "1.0.3405.78", + "ICoreWebView2FindOptions": "1.0.3405.78", + "ICoreWebView2FindStartCompletedHandler": "1.0.3405.78", + "ICoreWebView2_28": "1.0.3405.78", + "ICoreWebView2CompositionController5": "1.0.3719.77", + "ICoreWebView2CompositionControllerInterop3": "1.0.3719.77", + "ICoreWebView2DragStartingEventArgs": "1.0.3719.77", + "ICoreWebView2DragStartingEventHandler": "1.0.3719.77", } // SupportsInterface reports whether the given runtime version is at least @@ -76,6 +151,7 @@ type Capability struct { // AllCapabilities lists every known interface as a Capability. var AllCapabilities = []Capability{ + {Name: "ICoreWebView2WindowFeatures", Description: "Requires interface ICoreWebView2WindowFeatures", Interface: "ICoreWebView2WindowFeatures"}, {Name: "ICoreWebView2PrintCompletedHandler", Description: "Requires interface ICoreWebView2PrintCompletedHandler", Interface: "ICoreWebView2PrintCompletedHandler"}, {Name: "ICoreWebView2PrintSettings2", Description: "Requires interface ICoreWebView2PrintSettings2", Interface: "ICoreWebView2PrintSettings2"}, {Name: "ICoreWebView2PrintToPdfStreamCompletedHandler", Description: "Requires interface ICoreWebView2PrintToPdfStreamCompletedHandler", Interface: "ICoreWebView2PrintToPdfStreamCompletedHandler"}, @@ -95,10 +171,84 @@ var AllCapabilities = []Capability{ {Name: "ICoreWebView2SetPermissionStateCompletedHandler", Description: "Requires interface ICoreWebView2SetPermissionStateCompletedHandler", Interface: "ICoreWebView2SetPermissionStateCompletedHandler"}, {Name: "ICoreWebView2SharedBuffer", Description: "Requires interface ICoreWebView2SharedBuffer", Interface: "ICoreWebView2SharedBuffer"}, {Name: "ICoreWebView2_17", Description: "Requires interface ICoreWebView2_17", Interface: "ICoreWebView2_17"}, + {Name: "ICoreWebView2Settings8", Description: "Requires interface ICoreWebView2Settings8", Interface: "ICoreWebView2Settings8"}, {Name: "ICoreWebView2File", Description: "Requires interface ICoreWebView2File", Interface: "ICoreWebView2File"}, {Name: "ICoreWebView2ObjectCollectionView", Description: "Requires interface ICoreWebView2ObjectCollectionView", Interface: "ICoreWebView2ObjectCollectionView"}, {Name: "ICoreWebView2WebMessageReceivedEventArgs2", Description: "Requires interface ICoreWebView2WebMessageReceivedEventArgs2", Interface: "ICoreWebView2WebMessageReceivedEventArgs2"}, + {Name: "ICoreWebView2LaunchingExternalUriSchemeEventArgs", Description: "Requires interface ICoreWebView2LaunchingExternalUriSchemeEventArgs", Interface: "ICoreWebView2LaunchingExternalUriSchemeEventArgs"}, + {Name: "ICoreWebView2LaunchingExternalUriSchemeEventHandler", Description: "Requires interface ICoreWebView2LaunchingExternalUriSchemeEventHandler", Interface: "ICoreWebView2LaunchingExternalUriSchemeEventHandler"}, + {Name: "ICoreWebView2_18", Description: "Requires interface ICoreWebView2_18", Interface: "ICoreWebView2_18"}, {Name: "ICoreWebView2_19", Description: "Requires interface ICoreWebView2_19", Interface: "ICoreWebView2_19"}, + {Name: "ICoreWebView2NavigationStartingEventArgs3", Description: "Requires interface ICoreWebView2NavigationStartingEventArgs3", Interface: "ICoreWebView2NavigationStartingEventArgs3"}, + {Name: "ICoreWebView2NewWindowRequestedEventArgs3", Description: "Requires interface ICoreWebView2NewWindowRequestedEventArgs3", Interface: "ICoreWebView2NewWindowRequestedEventArgs3"}, + {Name: "ICoreWebView2AcceleratorKeyPressedEventArgs2", Description: "Requires interface ICoreWebView2AcceleratorKeyPressedEventArgs2", Interface: "ICoreWebView2AcceleratorKeyPressedEventArgs2"}, + {Name: "ICoreWebView2BrowserExtension", Description: "Requires interface ICoreWebView2BrowserExtension", Interface: "ICoreWebView2BrowserExtension"}, + {Name: "ICoreWebView2BrowserExtensionEnableCompletedHandler", Description: "Requires interface ICoreWebView2BrowserExtensionEnableCompletedHandler", Interface: "ICoreWebView2BrowserExtensionEnableCompletedHandler"}, + {Name: "ICoreWebView2BrowserExtensionList", Description: "Requires interface ICoreWebView2BrowserExtensionList", Interface: "ICoreWebView2BrowserExtensionList"}, + {Name: "ICoreWebView2BrowserExtensionRemoveCompletedHandler", Description: "Requires interface ICoreWebView2BrowserExtensionRemoveCompletedHandler", Interface: "ICoreWebView2BrowserExtensionRemoveCompletedHandler"}, + {Name: "ICoreWebView2Environment13", Description: "Requires interface ICoreWebView2Environment13", Interface: "ICoreWebView2Environment13"}, + {Name: "ICoreWebView2EnvironmentOptions6", Description: "Requires interface ICoreWebView2EnvironmentOptions6", Interface: "ICoreWebView2EnvironmentOptions6"}, + {Name: "ICoreWebView2Frame5", Description: "Requires interface ICoreWebView2Frame5", Interface: "ICoreWebView2Frame5"}, + {Name: "ICoreWebView2FrameInfo2", Description: "Requires interface ICoreWebView2FrameInfo2", Interface: "ICoreWebView2FrameInfo2"}, + {Name: "ICoreWebView2GetProcessExtendedInfosCompletedHandler", Description: "Requires interface ICoreWebView2GetProcessExtendedInfosCompletedHandler", Interface: "ICoreWebView2GetProcessExtendedInfosCompletedHandler"}, + {Name: "ICoreWebView2ProcessExtendedInfo", Description: "Requires interface ICoreWebView2ProcessExtendedInfo", Interface: "ICoreWebView2ProcessExtendedInfo"}, + {Name: "ICoreWebView2ProcessExtendedInfoCollection", Description: "Requires interface ICoreWebView2ProcessExtendedInfoCollection", Interface: "ICoreWebView2ProcessExtendedInfoCollection"}, + {Name: "ICoreWebView2Profile7", Description: "Requires interface ICoreWebView2Profile7", Interface: "ICoreWebView2Profile7"}, + {Name: "ICoreWebView2Profile8", Description: "Requires interface ICoreWebView2Profile8", Interface: "ICoreWebView2Profile8"}, + {Name: "ICoreWebView2ProfileAddBrowserExtensionCompletedHandler", Description: "Requires interface ICoreWebView2ProfileAddBrowserExtensionCompletedHandler", Interface: "ICoreWebView2ProfileAddBrowserExtensionCompletedHandler"}, + {Name: "ICoreWebView2ProfileDeletedEventHandler", Description: "Requires interface ICoreWebView2ProfileDeletedEventHandler", Interface: "ICoreWebView2ProfileDeletedEventHandler"}, + {Name: "ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler", Description: "Requires interface ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler", Interface: "ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler"}, + {Name: "ICoreWebView2_20", Description: "Requires interface ICoreWebView2_20", Interface: "ICoreWebView2_20"}, + {Name: "ICoreWebView2ExecuteScriptResult", Description: "Requires interface ICoreWebView2ExecuteScriptResult", Interface: "ICoreWebView2ExecuteScriptResult"}, + {Name: "ICoreWebView2ExecuteScriptWithResultCompletedHandler", Description: "Requires interface ICoreWebView2ExecuteScriptWithResultCompletedHandler", Interface: "ICoreWebView2ExecuteScriptWithResultCompletedHandler"}, + {Name: "ICoreWebView2ScriptException", Description: "Requires interface ICoreWebView2ScriptException", Interface: "ICoreWebView2ScriptException"}, + {Name: "ICoreWebView2_21", Description: "Requires interface ICoreWebView2_21", Interface: "ICoreWebView2_21"}, + {Name: "ICoreWebView2WebResourceRequestedEventArgs2", Description: "Requires interface ICoreWebView2WebResourceRequestedEventArgs2", Interface: "ICoreWebView2WebResourceRequestedEventArgs2"}, + {Name: "ICoreWebView2_22", Description: "Requires interface ICoreWebView2_22", Interface: "ICoreWebView2_22"}, + {Name: "ICoreWebView2CompositionController4", Description: "Requires interface ICoreWebView2CompositionController4", Interface: "ICoreWebView2CompositionController4"}, + {Name: "ICoreWebView2NonClientRegionChangedEventArgs", Description: "Requires interface ICoreWebView2NonClientRegionChangedEventArgs", Interface: "ICoreWebView2NonClientRegionChangedEventArgs"}, + {Name: "ICoreWebView2NonClientRegionChangedEventHandler", Description: "Requires interface ICoreWebView2NonClientRegionChangedEventHandler", Interface: "ICoreWebView2NonClientRegionChangedEventHandler"}, + {Name: "ICoreWebView2ProcessFailedEventArgs3", Description: "Requires interface ICoreWebView2ProcessFailedEventArgs3", Interface: "ICoreWebView2ProcessFailedEventArgs3"}, + {Name: "ICoreWebView2RegionRectCollectionView", Description: "Requires interface ICoreWebView2RegionRectCollectionView", Interface: "ICoreWebView2RegionRectCollectionView"}, + {Name: "ICoreWebView2Settings9", Description: "Requires interface ICoreWebView2Settings9", Interface: "ICoreWebView2Settings9"}, + {Name: "ICoreWebView2EnvironmentOptions7", Description: "Requires interface ICoreWebView2EnvironmentOptions7", Interface: "ICoreWebView2EnvironmentOptions7"}, + {Name: "ICoreWebView2EnvironmentOptions8", Description: "Requires interface ICoreWebView2EnvironmentOptions8", Interface: "ICoreWebView2EnvironmentOptions8"}, + {Name: "ICoreWebView2Environment14", Description: "Requires interface ICoreWebView2Environment14", Interface: "ICoreWebView2Environment14"}, + {Name: "ICoreWebView2FileSystemHandle", Description: "Requires interface ICoreWebView2FileSystemHandle", Interface: "ICoreWebView2FileSystemHandle"}, + {Name: "ICoreWebView2ObjectCollection", Description: "Requires interface ICoreWebView2ObjectCollection", Interface: "ICoreWebView2ObjectCollection"}, + {Name: "ICoreWebView2_23", Description: "Requires interface ICoreWebView2_23", Interface: "ICoreWebView2_23"}, + {Name: "ICoreWebView2Notification", Description: "Requires interface ICoreWebView2Notification", Interface: "ICoreWebView2Notification"}, + {Name: "ICoreWebView2NotificationCloseRequestedEventHandler", Description: "Requires interface ICoreWebView2NotificationCloseRequestedEventHandler", Interface: "ICoreWebView2NotificationCloseRequestedEventHandler"}, + {Name: "ICoreWebView2NotificationReceivedEventArgs", Description: "Requires interface ICoreWebView2NotificationReceivedEventArgs", Interface: "ICoreWebView2NotificationReceivedEventArgs"}, + {Name: "ICoreWebView2NotificationReceivedEventHandler", Description: "Requires interface ICoreWebView2NotificationReceivedEventHandler", Interface: "ICoreWebView2NotificationReceivedEventHandler"}, + {Name: "ICoreWebView2SaveAsUIShowingEventArgs", Description: "Requires interface ICoreWebView2SaveAsUIShowingEventArgs", Interface: "ICoreWebView2SaveAsUIShowingEventArgs"}, + {Name: "ICoreWebView2SaveAsUIShowingEventHandler", Description: "Requires interface ICoreWebView2SaveAsUIShowingEventHandler", Interface: "ICoreWebView2SaveAsUIShowingEventHandler"}, + {Name: "ICoreWebView2ShowSaveAsUICompletedHandler", Description: "Requires interface ICoreWebView2ShowSaveAsUICompletedHandler", Interface: "ICoreWebView2ShowSaveAsUICompletedHandler"}, + {Name: "ICoreWebView2_24", Description: "Requires interface ICoreWebView2_24", Interface: "ICoreWebView2_24"}, + {Name: "ICoreWebView2_25", Description: "Requires interface ICoreWebView2_25", Interface: "ICoreWebView2_25"}, + {Name: "ICoreWebView2SaveFileSecurityCheckStartingEventArgs", Description: "Requires interface ICoreWebView2SaveFileSecurityCheckStartingEventArgs", Interface: "ICoreWebView2SaveFileSecurityCheckStartingEventArgs"}, + {Name: "ICoreWebView2SaveFileSecurityCheckStartingEventHandler", Description: "Requires interface ICoreWebView2SaveFileSecurityCheckStartingEventHandler", Interface: "ICoreWebView2SaveFileSecurityCheckStartingEventHandler"}, + {Name: "ICoreWebView2_26", Description: "Requires interface ICoreWebView2_26", Interface: "ICoreWebView2_26"}, + {Name: "ICoreWebView2Frame6", Description: "Requires interface ICoreWebView2Frame6", Interface: "ICoreWebView2Frame6"}, + {Name: "ICoreWebView2FrameScreenCaptureStartingEventHandler", Description: "Requires interface ICoreWebView2FrameScreenCaptureStartingEventHandler", Interface: "ICoreWebView2FrameScreenCaptureStartingEventHandler"}, + {Name: "ICoreWebView2ScreenCaptureStartingEventArgs", Description: "Requires interface ICoreWebView2ScreenCaptureStartingEventArgs", Interface: "ICoreWebView2ScreenCaptureStartingEventArgs"}, + {Name: "ICoreWebView2ScreenCaptureStartingEventHandler", Description: "Requires interface ICoreWebView2ScreenCaptureStartingEventHandler", Interface: "ICoreWebView2ScreenCaptureStartingEventHandler"}, + {Name: "ICoreWebView2_27", Description: "Requires interface ICoreWebView2_27", Interface: "ICoreWebView2_27"}, + {Name: "ICoreWebView2Frame7", Description: "Requires interface ICoreWebView2Frame7", Interface: "ICoreWebView2Frame7"}, + {Name: "ICoreWebView2FrameChildFrameCreatedEventHandler", Description: "Requires interface ICoreWebView2FrameChildFrameCreatedEventHandler", Interface: "ICoreWebView2FrameChildFrameCreatedEventHandler"}, + {Name: "ICoreWebView2ControllerOptions3", Description: "Requires interface ICoreWebView2ControllerOptions3", Interface: "ICoreWebView2ControllerOptions3"}, + {Name: "ICoreWebView2ControllerOptions4", Description: "Requires interface ICoreWebView2ControllerOptions4", Interface: "ICoreWebView2ControllerOptions4"}, + {Name: "ICoreWebView2Environment15", Description: "Requires interface ICoreWebView2Environment15", Interface: "ICoreWebView2Environment15"}, + {Name: "ICoreWebView2Find", Description: "Requires interface ICoreWebView2Find", Interface: "ICoreWebView2Find"}, + {Name: "ICoreWebView2FindActiveMatchIndexChangedEventHandler", Description: "Requires interface ICoreWebView2FindActiveMatchIndexChangedEventHandler", Interface: "ICoreWebView2FindActiveMatchIndexChangedEventHandler"}, + {Name: "ICoreWebView2FindMatchCountChangedEventHandler", Description: "Requires interface ICoreWebView2FindMatchCountChangedEventHandler", Interface: "ICoreWebView2FindMatchCountChangedEventHandler"}, + {Name: "ICoreWebView2FindOptions", Description: "Requires interface ICoreWebView2FindOptions", Interface: "ICoreWebView2FindOptions"}, + {Name: "ICoreWebView2FindStartCompletedHandler", Description: "Requires interface ICoreWebView2FindStartCompletedHandler", Interface: "ICoreWebView2FindStartCompletedHandler"}, + {Name: "ICoreWebView2_28", Description: "Requires interface ICoreWebView2_28", Interface: "ICoreWebView2_28"}, + {Name: "ICoreWebView2CompositionController5", Description: "Requires interface ICoreWebView2CompositionController5", Interface: "ICoreWebView2CompositionController5"}, + {Name: "ICoreWebView2CompositionControllerInterop3", Description: "Requires interface ICoreWebView2CompositionControllerInterop3", Interface: "ICoreWebView2CompositionControllerInterop3"}, + {Name: "ICoreWebView2DragStartingEventArgs", Description: "Requires interface ICoreWebView2DragStartingEventArgs", Interface: "ICoreWebView2DragStartingEventArgs"}, + {Name: "ICoreWebView2DragStartingEventHandler", Description: "Requires interface ICoreWebView2DragStartingEventHandler", Interface: "ICoreWebView2DragStartingEventHandler"}, } func compareVersions(a, b string) (int, error) { diff --git a/webview2/scripts/WebView2.1.0.3967.48.idl b/webview2/scripts/WebView2.1.0.3967.48.idl new file mode 100644 index 00000000000..eae774a12cb --- /dev/null +++ b/webview2/scripts/WebView2.1.0.3967.48.idl @@ -0,0 +1,11204 @@ +// Copyright (C) Microsoft Corporation. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + + +import "objidl.idl"; +import "oaidl.idl"; +import "EventToken.idl"; + +[uuid(26d34152-879f-4065-bea2-3daa2cfadfb8), version(1.0)] +library WebView2 { + +// Interface forward declarations + + +interface ICoreWebView2; +interface ICoreWebView2ContainsFullScreenElementChangedEventHandler; +interface ICoreWebView2ContentLoadingEventHandler; +interface ICoreWebView2DocumentTitleChangedEventHandler; +// Skipping ICoreWebView2NavigationCompletedEventHandler forward declaration +// Skipping ICoreWebView2NavigationStartingEventHandler forward declaration +interface ICoreWebView2HistoryChangedEventHandler; +interface ICoreWebView2NavigationCompletedEventHandler; +interface ICoreWebView2NavigationStartingEventHandler; +interface ICoreWebView2NewWindowRequestedEventHandler; +interface ICoreWebView2PermissionRequestedEventHandler; +interface ICoreWebView2ProcessFailedEventHandler; +interface ICoreWebView2ScriptDialogOpeningEventHandler; +interface ICoreWebView2SourceChangedEventHandler; +interface ICoreWebView2WebMessageReceivedEventHandler; +interface ICoreWebView2WebResourceRequestedEventHandler; +interface ICoreWebView2WindowCloseRequestedEventHandler; +interface ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler; +interface ICoreWebView2ExecuteScriptCompletedHandler; +interface ICoreWebView2CapturePreviewCompletedHandler; +interface ICoreWebView2CallDevToolsProtocolMethodCompletedHandler; +interface ICoreWebView2_2; +interface ICoreWebView2DOMContentLoadedEventHandler; +interface ICoreWebView2WebResourceResponseReceivedEventHandler; +interface ICoreWebView2_3; +interface ICoreWebView2TrySuspendCompletedHandler; +interface ICoreWebView2_4; +interface ICoreWebView2DownloadStartingEventHandler; +interface ICoreWebView2FrameCreatedEventHandler; +interface ICoreWebView2_5; +interface ICoreWebView2ClientCertificateRequestedEventHandler; +interface ICoreWebView2_6; +interface ICoreWebView2_7; +interface ICoreWebView2PrintToPdfCompletedHandler; +interface ICoreWebView2_8; +interface ICoreWebView2IsDocumentPlayingAudioChangedEventHandler; +interface ICoreWebView2IsMutedChangedEventHandler; +interface ICoreWebView2_9; +interface ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler; +interface ICoreWebView2_10; +interface ICoreWebView2BasicAuthenticationRequestedEventHandler; +interface ICoreWebView2_11; +interface ICoreWebView2ContextMenuRequestedEventHandler; +// Skipping ICoreWebView2CallDevToolsProtocolMethodCompletedHandler forward declaration +interface ICoreWebView2_12; +interface ICoreWebView2StatusBarTextChangedEventHandler; +interface ICoreWebView2_13; +interface ICoreWebView2_14; +interface ICoreWebView2ServerCertificateErrorDetectedEventHandler; +interface ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler; +interface ICoreWebView2_15; +interface ICoreWebView2FaviconChangedEventHandler; +interface ICoreWebView2GetFaviconCompletedHandler; +interface ICoreWebView2_16; +interface ICoreWebView2PrintCompletedHandler; +interface ICoreWebView2PrintToPdfStreamCompletedHandler; +interface ICoreWebView2_17; +interface ICoreWebView2_18; +interface ICoreWebView2LaunchingExternalUriSchemeEventHandler; +interface ICoreWebView2_19; +interface ICoreWebView2_20; +interface ICoreWebView2_21; +interface ICoreWebView2ExecuteScriptWithResultCompletedHandler; +interface ICoreWebView2_22; +interface ICoreWebView2_23; +interface ICoreWebView2_24; +interface ICoreWebView2NotificationReceivedEventHandler; +interface ICoreWebView2_25; +interface ICoreWebView2SaveAsUIShowingEventHandler; +interface ICoreWebView2ShowSaveAsUICompletedHandler; +interface ICoreWebView2_26; +interface ICoreWebView2SaveFileSecurityCheckStartingEventHandler; +interface ICoreWebView2_27; +interface ICoreWebView2ScreenCaptureStartingEventHandler; +interface ICoreWebView2_28; +interface ICoreWebView2AcceleratorKeyPressedEventArgs; +interface ICoreWebView2AcceleratorKeyPressedEventArgs2; +interface ICoreWebView2BasicAuthenticationRequestedEventArgs; +interface ICoreWebView2BasicAuthenticationResponse; +interface ICoreWebView2BrowserExtension; +interface ICoreWebView2BrowserExtensionRemoveCompletedHandler; +interface ICoreWebView2BrowserExtensionEnableCompletedHandler; +interface ICoreWebView2BrowserProcessExitedEventArgs; +interface ICoreWebView2Certificate; +interface ICoreWebView2ClientCertificate; +interface ICoreWebView2ClientCertificateRequestedEventArgs; +interface ICoreWebView2StringCollection; +interface ICoreWebView2ClientCertificateCollection; +interface ICoreWebView2CompositionController; +interface ICoreWebView2CursorChangedEventHandler; +interface ICoreWebView2CompositionController2; +interface ICoreWebView2CompositionController3; +interface ICoreWebView2CompositionController4; +interface ICoreWebView2NonClientRegionChangedEventHandler; +interface ICoreWebView2RegionRectCollectionView; +interface ICoreWebView2CompositionController5; +interface ICoreWebView2DragStartingEventHandler; +interface ICoreWebView2ContentLoadingEventArgs; +interface ICoreWebView2ContextMenuItem; +interface ICoreWebView2CustomItemSelectedEventHandler; +interface ICoreWebView2ContextMenuItemCollection; +interface ICoreWebView2ContextMenuRequestedEventArgs; +interface ICoreWebView2ContextMenuTarget; +interface ICoreWebView2Controller; +interface ICoreWebView2AcceleratorKeyPressedEventHandler; +interface ICoreWebView2FocusChangedEventHandler; +// Skipping ICoreWebView2FocusChangedEventHandler forward declaration +interface ICoreWebView2MoveFocusRequestedEventHandler; +interface ICoreWebView2ZoomFactorChangedEventHandler; +interface ICoreWebView2Controller2; +interface ICoreWebView2Controller3; +interface ICoreWebView2RasterizationScaleChangedEventHandler; +interface ICoreWebView2Controller4; +interface ICoreWebView2ControllerOptions; +interface ICoreWebView2ControllerOptions2; +interface ICoreWebView2ControllerOptions3; +interface ICoreWebView2ControllerOptions4; +interface ICoreWebView2Cookie; +interface ICoreWebView2CookieManager; +interface ICoreWebView2GetCookiesCompletedHandler; +interface ICoreWebView2CookieList; +interface ICoreWebView2CustomSchemeRegistration; +interface ICoreWebView2DOMContentLoadedEventArgs; +interface ICoreWebView2Deferral; +interface ICoreWebView2DevToolsProtocolEventReceivedEventArgs; +interface ICoreWebView2DevToolsProtocolEventReceivedEventArgs2; +interface ICoreWebView2DevToolsProtocolEventReceiver; +interface ICoreWebView2DevToolsProtocolEventReceivedEventHandler; +interface ICoreWebView2DownloadOperation; +interface ICoreWebView2BytesReceivedChangedEventHandler; +interface ICoreWebView2EstimatedEndTimeChangedEventHandler; +interface ICoreWebView2StateChangedEventHandler; +interface ICoreWebView2DownloadStartingEventArgs; +interface ICoreWebView2DragStartingEventArgs; +interface ICoreWebView2Environment; +interface ICoreWebView2NewBrowserVersionAvailableEventHandler; +interface ICoreWebView2CreateCoreWebView2ControllerCompletedHandler; +interface ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler; +// Skipping ICoreWebView2CreateCoreWebView2EnvironmentWithOptionsCompletedHandler forward declaration +interface ICoreWebView2Environment2; +interface ICoreWebView2Environment3; +interface ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler; +interface ICoreWebView2Environment4; +interface ICoreWebView2Environment5; +interface ICoreWebView2BrowserProcessExitedEventHandler; +interface ICoreWebView2Environment6; +interface ICoreWebView2Environment7; +interface ICoreWebView2Environment8; +interface ICoreWebView2ProcessInfosChangedEventHandler; +interface ICoreWebView2ProcessInfoCollection; +interface ICoreWebView2Environment9; +interface ICoreWebView2Environment10; +// Skipping ICoreWebView2CreateCoreWebView2ControllerCompletedHandler forward declaration +// Skipping ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler forward declaration +interface ICoreWebView2Environment11; +interface ICoreWebView2Environment12; +interface ICoreWebView2Environment13; +interface ICoreWebView2GetProcessExtendedInfosCompletedHandler; +interface ICoreWebView2ProcessExtendedInfoCollection; +interface ICoreWebView2Environment14; +interface ICoreWebView2Environment15; +interface ICoreWebView2EnvironmentOptions; +interface ICoreWebView2EnvironmentOptions2; +interface ICoreWebView2EnvironmentOptions3; +interface ICoreWebView2EnvironmentOptions4; +interface ICoreWebView2EnvironmentOptions5; +interface ICoreWebView2EnvironmentOptions6; +interface ICoreWebView2EnvironmentOptions7; +interface ICoreWebView2EnvironmentOptions8; +interface ICoreWebView2ExecuteScriptResult; +interface ICoreWebView2File; +interface ICoreWebView2FileSystemHandle; +interface ICoreWebView2Find; +interface ICoreWebView2FindActiveMatchIndexChangedEventHandler; +interface ICoreWebView2FindMatchCountChangedEventHandler; +interface ICoreWebView2FindStartCompletedHandler; +interface ICoreWebView2FindOptions; +interface ICoreWebView2Frame; +interface ICoreWebView2FrameDestroyedEventHandler; +interface ICoreWebView2FrameNameChangedEventHandler; +interface ICoreWebView2Frame2; +interface ICoreWebView2FrameContentLoadingEventHandler; +interface ICoreWebView2FrameDOMContentLoadedEventHandler; +interface ICoreWebView2FrameNavigationCompletedEventHandler; +interface ICoreWebView2FrameNavigationStartingEventHandler; +interface ICoreWebView2FrameWebMessageReceivedEventHandler; +// Skipping ICoreWebView2ExecuteScriptCompletedHandler forward declaration +interface ICoreWebView2Frame3; +interface ICoreWebView2FramePermissionRequestedEventHandler; +interface ICoreWebView2Frame4; +interface ICoreWebView2Frame5; +interface ICoreWebView2Frame6; +interface ICoreWebView2FrameScreenCaptureStartingEventHandler; +interface ICoreWebView2Frame7; +interface ICoreWebView2FrameChildFrameCreatedEventHandler; +interface ICoreWebView2FrameCreatedEventArgs; +interface ICoreWebView2FrameInfo; +interface ICoreWebView2FrameInfo2; +interface ICoreWebView2FrameInfoCollection; +interface ICoreWebView2FrameInfoCollectionIterator; +interface ICoreWebView2HttpHeadersCollectionIterator; +interface ICoreWebView2HttpRequestHeaders; +interface ICoreWebView2HttpResponseHeaders; +interface ICoreWebView2LaunchingExternalUriSchemeEventArgs; +interface ICoreWebView2MoveFocusRequestedEventArgs; +interface ICoreWebView2NavigationCompletedEventArgs; +interface ICoreWebView2NavigationCompletedEventArgs2; +interface ICoreWebView2NavigationStartingEventArgs; +interface ICoreWebView2NavigationStartingEventArgs2; +interface ICoreWebView2NavigationStartingEventArgs3; +interface ICoreWebView2NewWindowRequestedEventArgs; +interface ICoreWebView2NewWindowRequestedEventArgs2; +interface ICoreWebView2NewWindowRequestedEventArgs3; +interface ICoreWebView2NonClientRegionChangedEventArgs; +interface ICoreWebView2Notification; +interface ICoreWebView2NotificationCloseRequestedEventHandler; +interface ICoreWebView2NotificationReceivedEventArgs; +interface ICoreWebView2ObjectCollectionView; +interface ICoreWebView2ObjectCollection; +interface ICoreWebView2PermissionRequestedEventArgs; +interface ICoreWebView2PermissionRequestedEventArgs2; +interface ICoreWebView2PermissionRequestedEventArgs3; +interface ICoreWebView2PermissionSetting; +interface ICoreWebView2PointerInfo; +interface ICoreWebView2PrintSettings; +interface ICoreWebView2PrintSettings2; +interface ICoreWebView2ProcessExtendedInfo; +interface ICoreWebView2ProcessFailedEventArgs; +interface ICoreWebView2ProcessFailedEventArgs2; +interface ICoreWebView2ProcessFailedEventArgs3; +interface ICoreWebView2ProcessInfo; +interface ICoreWebView2Profile; +interface ICoreWebView2Profile2; +interface ICoreWebView2ClearBrowsingDataCompletedHandler; +// Skipping ICoreWebView2ClearBrowsingDataCompletedHandler forward declaration +// Skipping ICoreWebView2ClearBrowsingDataCompletedHandler forward declaration +interface ICoreWebView2Profile3; +interface ICoreWebView2Profile4; +interface ICoreWebView2SetPermissionStateCompletedHandler; +interface ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler; +interface ICoreWebView2Profile5; +interface ICoreWebView2Profile6; +interface ICoreWebView2Profile7; +interface ICoreWebView2ProfileAddBrowserExtensionCompletedHandler; +interface ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler; +interface ICoreWebView2BrowserExtensionList; +interface ICoreWebView2Profile8; +interface ICoreWebView2ProfileDeletedEventHandler; +interface ICoreWebView2SaveAsUIShowingEventArgs; +interface ICoreWebView2SaveFileSecurityCheckStartingEventArgs; +interface ICoreWebView2ScreenCaptureStartingEventArgs; +interface ICoreWebView2ScriptDialogOpeningEventArgs; +interface ICoreWebView2ScriptException; +interface ICoreWebView2ServerCertificateErrorDetectedEventArgs; +interface ICoreWebView2Settings; +interface ICoreWebView2Settings2; +interface ICoreWebView2Settings3; +interface ICoreWebView2Settings4; +interface ICoreWebView2Settings5; +interface ICoreWebView2Settings6; +interface ICoreWebView2Settings7; +interface ICoreWebView2Settings8; +interface ICoreWebView2Settings9; +interface ICoreWebView2SharedBuffer; +interface ICoreWebView2SourceChangedEventArgs; +interface ICoreWebView2WebMessageReceivedEventArgs; +interface ICoreWebView2WebMessageReceivedEventArgs2; +interface ICoreWebView2WebResourceRequest; +interface ICoreWebView2WebResourceRequestedEventArgs; +interface ICoreWebView2WebResourceRequestedEventArgs2; +interface ICoreWebView2WebResourceResponse; +interface ICoreWebView2WebResourceResponseReceivedEventArgs; +interface ICoreWebView2WebResourceResponseView; +interface ICoreWebView2WebResourceResponseViewGetContentCompletedHandler; +interface ICoreWebView2WindowFeatures; + +// Enums and structs + + +/// Mode for how the Bounds property is interpreted in relation to the RasterizationScale property. +[v1_enum] +typedef enum COREWEBVIEW2_BOUNDS_MODE { + /// Bounds property represents raw pixels. Physical size of Webview is not impacted by RasterizationScale. + COREWEBVIEW2_BOUNDS_MODE_USE_RAW_PIXELS, + /// Bounds property represents logical pixels and the RasterizationScale property is used to get the physical size of the WebView. + COREWEBVIEW2_BOUNDS_MODE_USE_RASTERIZATION_SCALE, +} COREWEBVIEW2_BOUNDS_MODE; + +/// Specifies the browser process exit type used in the +/// `ICoreWebView2BrowserProcessExitedEventArgs` interface. +[v1_enum] +typedef enum COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND { + /// Indicates that the browser process ended normally. + COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND_NORMAL, + /// Indicates that the browser process ended unexpectedly. + /// A `ProcessFailed` event will also be sent to listening WebViews from the + /// `ICoreWebView2Environment` associated to the failed process. + COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND_FAILED, +} COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND; + +/// Specifies the datatype for the +/// `ICoreWebView2Profile2::ClearBrowsingData` method. +[v1_enum] +typedef enum COREWEBVIEW2_BROWSING_DATA_KINDS { + /// Specifies file systems data. + COREWEBVIEW2_BROWSING_DATA_KINDS_FILE_SYSTEMS = 0x1, + /// Specifies data stored by the IndexedDB DOM feature. + COREWEBVIEW2_BROWSING_DATA_KINDS_INDEXED_DB = 0x2, + /// Specifies data stored by the localStorage DOM API. + COREWEBVIEW2_BROWSING_DATA_KINDS_LOCAL_STORAGE = 0x4, + /// Specifies data stored by the Web SQL database DOM API. + COREWEBVIEW2_BROWSING_DATA_KINDS_WEB_SQL = 0x8, + /// Specifies data stored by the CacheStorage DOM API. + COREWEBVIEW2_BROWSING_DATA_KINDS_CACHE_STORAGE = 0x10, + /// Specifies DOM storage data, now and future. This browsing data kind is + /// inclusive of COREWEBVIEW2_BROWSING_DATA_KINDS_FILE_SYSTEMS, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_INDEXED_DB, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_LOCAL_STORAGE, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_WEB_SQL, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_CACHE_STORAGE, + /// and some other data kinds not listed yet to keep consistent with + /// [DOM-accessible storage](https://www.w3.org/TR/clear-site-data/#storage). + COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_DOM_STORAGE = 0x20, + /// Specifies HTTP cookies data. + COREWEBVIEW2_BROWSING_DATA_KINDS_COOKIES = 0x40, + /// Specifies all site data, now and future. This browsing data kind + /// is inclusive of COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_DOM_STORAGE and + /// COREWEBVIEW2_BROWSING_DATA_KINDS_COOKIES. New site data types + /// may be added to this data kind in the future. + COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_SITE = 0x80, + /// Specifies disk cache. + COREWEBVIEW2_BROWSING_DATA_KINDS_DISK_CACHE = 0x100, + /// Specifies download history data. + COREWEBVIEW2_BROWSING_DATA_KINDS_DOWNLOAD_HISTORY = 0x200, + /// Specifies general autofill form data. + /// This excludes password information and includes information like: + /// names, street and email addresses, phone numbers, and arbitrary input. + /// This also includes payment data. + COREWEBVIEW2_BROWSING_DATA_KINDS_GENERAL_AUTOFILL = 0x400, + /// Specifies password autosave data. + COREWEBVIEW2_BROWSING_DATA_KINDS_PASSWORD_AUTOSAVE = 0x800, + /// Specifies browsing history data. + COREWEBVIEW2_BROWSING_DATA_KINDS_BROWSING_HISTORY = 0x1000, + /// Specifies settings data. + COREWEBVIEW2_BROWSING_DATA_KINDS_SETTINGS = 0x2000, + /// Specifies profile data that should be wiped to make it look like a new profile. + /// This does not delete account-scoped data like passwords but will remove access + /// to account-scoped data by signing the user out. + /// Specifies all profile data, now and future. New profile data types may be added + /// to this data kind in the future. + /// This browsing data kind is inclusive of COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_SITE, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_DISK_CACHE, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_DOWNLOAD_HISTORY, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_GENERAL_AUTOFILL, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_PASSWORD_AUTOSAVE, + /// COREWEBVIEW2_BROWSING_DATA_KINDS_BROWSING_HISTORY, and + /// COREWEBVIEW2_BROWSING_DATA_KINDS_SETTINGS. + COREWEBVIEW2_BROWSING_DATA_KINDS_ALL_PROFILE = 0x4000, + /// Specifies service workers registered for an origin, and clear will result in + /// termination and deregistration of them. + COREWEBVIEW2_BROWSING_DATA_KINDS_SERVICE_WORKERS = 0x8000, +} COREWEBVIEW2_BROWSING_DATA_KINDS; +cpp_quote("DEFINE_ENUM_FLAG_OPERATORS(COREWEBVIEW2_BROWSING_DATA_KINDS)") + +/// Specifies the image format for the `ICoreWebView2::CapturePreview` method. +[v1_enum] +typedef enum COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT { + /// Indicates that the PNG image format is used. + COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT_PNG, + /// Indicates the JPEG image format is used. + COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT_JPEG, +} COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT; + +/// The channel search kind determines the order that release channels are +/// searched for during environment creation. The default behavior is to search +/// for and use the most stable channel found on the device. The order from most +/// to least stable is: WebView2 Runtime -> Beta -> Dev -> Canary. Switch the +/// order to prefer the least stable channel in order to perform pre-release +/// testing. See `COREWEBVIEW2_RELEASE_CHANNELS` for descriptions of channels. +[v1_enum] +typedef enum COREWEBVIEW2_CHANNEL_SEARCH_KIND { + /// Search for a release channel from most to least stable: + /// WebView2 Runtime -> Beta -> Dev -> Canary. This is the default behavior. + COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE, + /// Search for a release channel from least to most stable: + /// Canary -> Dev -> Beta -> WebView2 Runtime. + COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE, +} COREWEBVIEW2_CHANNEL_SEARCH_KIND; + +/// Specifies the client certificate kind. +[v1_enum] +typedef enum COREWEBVIEW2_CLIENT_CERTIFICATE_KIND { + /// Specifies smart card certificate. + COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_SMART_CARD, + /// Specifies PIN certificate. + COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_PIN, + /// Specifies other certificate. + COREWEBVIEW2_CLIENT_CERTIFICATE_KIND_OTHER, +} COREWEBVIEW2_CLIENT_CERTIFICATE_KIND; + +/// Specifies the menu item kind +/// for the `ICoreWebView2ContextMenuItem::get_Kind` method +[v1_enum] +typedef enum COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND { + /// Specifies a command menu item kind. + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_COMMAND, + /// Specifies a check box menu item kind. `ContextMenuItem` objects of this kind + /// will need the `IsChecked` property to determine current state of the check box. + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_CHECK_BOX, + /// Specifies a radio button menu item kind. `ContextMenuItem` objects of this kind + /// will need the `IsChecked` property to determine current state of the radio button. + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_RADIO, + /// Specifies a separator menu item kind. `ContextMenuItem` objects of this kind + /// are used to signal a visual separator with no functionality. + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_SEPARATOR, + /// Specifies a submenu menu item kind. `ContextMenuItem` objects of this kind will contain + /// a `ContextMenuItemCollection` of its children `ContextMenuItem` objects. + COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND_SUBMENU, +} COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND; + +/// Indicates the kind of context for which the context menu was created +/// for the `ICoreWebView2ContextMenuTarget::get_Kind` method. +/// This enum will always represent the active element that caused the context menu request. +/// If there is a selection with multiple images, audio and text, for example, the element that +/// the end user right clicks on within this selection will be the option represented by this enum. +[v1_enum] +typedef enum COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND { + /// Indicates that the context menu was created for the page without any additional content. + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_PAGE, + /// Indicates that the context menu was created for an image element. + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_IMAGE, + /// Indicates that the context menu was created for selected text. + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_SELECTED_TEXT, + /// Indicates that the context menu was created for an audio element. + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_AUDIO, + /// Indicates that the context menu was created for a video element. + COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND_VIDEO, +} COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND; + +/// Kind of cookie SameSite status used in the ICoreWebView2Cookie interface. +/// These fields match those as specified in https://developer.mozilla.org/docs/Web/HTTP/Cookies#. +/// Learn more about SameSite cookies here: https://tools.ietf.org/html/draft-west-first-party-cookies-07 +[v1_enum] +typedef enum COREWEBVIEW2_COOKIE_SAME_SITE_KIND { + /// None SameSite type. No restrictions on cross-site requests. + COREWEBVIEW2_COOKIE_SAME_SITE_KIND_NONE, + /// Lax SameSite type. The cookie will be sent with "same-site" requests, and with "cross-site" top level navigation. + COREWEBVIEW2_COOKIE_SAME_SITE_KIND_LAX, + /// Strict SameSite type. The cookie will only be sent along with "same-site" requests. + COREWEBVIEW2_COOKIE_SAME_SITE_KIND_STRICT, +} COREWEBVIEW2_COOKIE_SAME_SITE_KIND; + +/// The default download dialog can be aligned to any of the WebView corners +/// by setting the `DefaultDownloadDialogCornerAlignment` property. The default +/// position is top-right corner. +[v1_enum] +typedef enum COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT { + /// Top-left corner of the WebView. + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_TOP_LEFT, + /// Top-right corner of the WebView. + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_TOP_RIGHT, + /// Bottom-left corner of the WebView. + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_BOTTOM_LEFT, + /// Bottom-right corner of the WebView. + COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT_BOTTOM_RIGHT, +} COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT; + +/// Reason why a download was interrupted. +[v1_enum] +typedef enum COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON { + /// + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NONE, + /// Generic file error. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_FAILED, + /// Access denied due to security restrictions. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_ACCESS_DENIED, + /// Disk full. User should free some space or choose a different location to + /// store the file. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_NO_SPACE, + /// Result file path with file name is too long. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_NAME_TOO_LONG, + /// File is too large for file system. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_LARGE, + /// Microsoft Defender Smartscreen detected a virus in the file. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_MALICIOUS, + /// File was in use, too many files opened, or out of memory. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TRANSIENT_ERROR, + /// File blocked by local policy. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_BLOCKED_BY_POLICY, + /// Security check failed unexpectedly. Microsoft Defender SmartScreen could + /// not scan this file. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_SECURITY_CHECK_FAILED, + /// Seeking past the end of a file in opening a file, as part of resuming an + /// interrupted download. The file did not exist or was not as large as + /// expected. Partially downloaded file was truncated or deleted, and download + /// will be restarted automatically. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_SHORT, + /// Partial file did not match the expected hash and was deleted. Download + /// will be restarted automatically. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_HASH_MISMATCH, + /// Generic network error. User can retry the download manually. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_FAILED, + /// Network operation timed out. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_TIMEOUT, + /// Network connection lost. User can retry the download manually. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_DISCONNECTED, + /// Server has gone down. User can retry the download manually. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_SERVER_DOWN, + /// Network request invalid because original or redirected URI is invalid, has + /// an unsupported scheme, or is disallowed by network policy. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_NETWORK_INVALID_REQUEST, + /// Generic server error. User can retry the download manually. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_FAILED, + /// Server does not support range requests. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_NO_RANGE, + /// Server does not have the requested data. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_BAD_CONTENT, + /// Server did not authorize access to resource. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_UNAUTHORIZED, + /// Server certificate problem. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CERTIFICATE_PROBLEM, + /// Server access forbidden. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_FORBIDDEN, + /// Unexpected server response. Responding server may not be intended server. + /// User can retry the download manually. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_UNEXPECTED_RESPONSE, + /// Server sent fewer bytes than the Content-Length header. Content-length + /// header may be invalid or connection may have closed. Download is treated + /// as complete unless there are + /// [strong validators](https://tools.ietf.org/html/rfc7232#section-2) present + /// to interrupt the download. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CONTENT_LENGTH_MISMATCH, + /// Unexpected cross-origin redirect. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_CROSS_ORIGIN_REDIRECT, + /// User canceled the download. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_CANCELED, + /// User shut down the WebView. Resuming downloads that were interrupted + /// during shutdown is not yet supported. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_SHUTDOWN, + /// User paused the download. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_PAUSED, + /// WebView crashed. + COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_DOWNLOAD_PROCESS_CRASHED, +} COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON; + +/// State of the download operation. +[v1_enum] +typedef enum COREWEBVIEW2_DOWNLOAD_STATE { + /// The download is in progress. + COREWEBVIEW2_DOWNLOAD_STATE_IN_PROGRESS, + /// The connection with the file host was broken. The `InterruptReason` property + /// can be accessed from `ICoreWebView2DownloadOperation`. See + /// `COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON` for descriptions of kinds of + /// interrupt reasons. Host can check whether an interrupted download can be + /// resumed with the `CanResume` property on the `ICoreWebView2DownloadOperation`. + /// Once resumed, a download is in the `COREWEBVIEW2_DOWNLOAD_STATE_IN_PROGRESS` state. + COREWEBVIEW2_DOWNLOAD_STATE_INTERRUPTED, + /// The download completed successfully. + COREWEBVIEW2_DOWNLOAD_STATE_COMPLETED, +} COREWEBVIEW2_DOWNLOAD_STATE; + +/// Specifies the image format to use for favicon. +[v1_enum] +typedef enum COREWEBVIEW2_FAVICON_IMAGE_FORMAT { + /// Indicates that the PNG image format is used. + COREWEBVIEW2_FAVICON_IMAGE_FORMAT_PNG, + /// Indicates the JPEG image format is used. + COREWEBVIEW2_FAVICON_IMAGE_FORMAT_JPEG, +} COREWEBVIEW2_FAVICON_IMAGE_FORMAT; + +/// Kind of CoreWebView2FileSystemHandle as described in +/// [FileSystemHandle.kind](https://developer.mozilla.org/docs/Web/API/FileSystemHandle/kind). +[v1_enum] +typedef enum COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND { + /// FileSystemHandle is for a file + /// [FileSystemFileHandle](https://developer.mozilla.org/docs/Web/API/FileSystemFileHandle). + COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_FILE, + /// FileSystemHandle is for a directory + /// [FileSystemDirectoryHandle](https://developer.mozilla.org/docs/Web/API/FileSystemDirectoryHandle). + COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND_DIRECTORY, +} COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND; + +/// Allowed permissions of a CoreWebView2FileSystemHandle as described in +/// [FileSystemHandle.requestPermission()](https://developer.mozilla.org/docs/Web/API/FileSystemHandle/requestPermission). +[v1_enum] +typedef enum COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION { + /// Read-only permission for FileSystemHandle. + COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY, + /// Read and write permissions for FileSystemHandle. + COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_WRITE, +} COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION; + +/// Indicates the frame type used in the `ICoreWebView2FrameInfo` interface. +[v1_enum] +typedef enum COREWEBVIEW2_FRAME_KIND { + /// Indicates that the frame is an unknown type frame. We may extend this enum + /// type to identify more frame kinds in the future. + COREWEBVIEW2_FRAME_KIND_UNKNOWN, + /// Indicates that the frame is a primary main frame(webview). + COREWEBVIEW2_FRAME_KIND_MAIN_FRAME, + /// Indicates that the frame is an iframe. + COREWEBVIEW2_FRAME_KIND_IFRAME, + /// Indicates that the frame is an embed element. + COREWEBVIEW2_FRAME_KIND_EMBED, + /// Indicates that the frame is an object element. + COREWEBVIEW2_FRAME_KIND_OBJECT, +} COREWEBVIEW2_FRAME_KIND; + +/// Kind of cross origin resource access allowed for host resources during download. +/// Note that other normal access checks like same origin DOM access check and [Content +/// Security Policy](https://developer.mozilla.org/docs/Web/HTTP/CSP) still apply. +/// +/// The following table illustrates the host resource cross origin access according to +/// access context and `COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND`. +/// +/// Cross Origin Access Context | DENY | ALLOW | DENY_CORS +/// --- | --- | --- | --- +/// From DOM like src of img, script or iframe element| Deny | Allow | Allow +/// From Script like Fetch or XMLHttpRequest| Deny | Allow | Deny +[v1_enum] +typedef enum COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND { + /// All cross origin resource access is denied, including normal sub resource access + /// as src of a script or image element. + COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY, + /// All cross origin resource access is allowed, including accesses that are + /// subject to Cross-Origin Resource Sharing(CORS) check. The behavior is similar to + /// a web site sends back http header Access-Control-Allow-Origin: *. + COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_ALLOW, + /// Cross origin resource access is allowed for normal sub resource access like + /// as src of a script or image element, while any access that subjects to CORS check + /// will be denied. + /// See [Cross-Origin Resource Sharing](https://developer.mozilla.org/docs/Web/HTTP/CORS) + /// for more information. + COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY_CORS, +} COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND; + +/// Specifies the key event type that triggered an `AcceleratorKeyPressed` +/// event. +[v1_enum] +typedef enum COREWEBVIEW2_KEY_EVENT_KIND { + /// Specifies that the key event type corresponds to window message + /// `WM_KEYDOWN`. + COREWEBVIEW2_KEY_EVENT_KIND_KEY_DOWN, + /// Specifies that the key event type corresponds to window message + /// `WM_KEYUP`. + COREWEBVIEW2_KEY_EVENT_KIND_KEY_UP, + /// Specifies that the key event type corresponds to window message + /// `WM_SYSKEYDOWN`. + COREWEBVIEW2_KEY_EVENT_KIND_SYSTEM_KEY_DOWN, + /// Specifies that the key event type corresponds to window message + /// `WM_SYSKEYUP`. + COREWEBVIEW2_KEY_EVENT_KIND_SYSTEM_KEY_UP, +} COREWEBVIEW2_KEY_EVENT_KIND; + +/// Specifies memory usage target level of WebView. +[v1_enum] +typedef enum COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL { + /// Specifies normal memory usage target level. + COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_NORMAL, + /// Specifies low memory usage target level. + /// Used for inactivate WebView for reduced memory consumption. + COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_LOW, +} COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL; + +/// Mouse event type used by SendMouseInput to convey the type of mouse event +/// being sent to WebView. The values of this enum align with the matching +/// WM_* window messages. +[v1_enum] +typedef enum COREWEBVIEW2_MOUSE_EVENT_KIND { + /// Mouse horizontal wheel scroll event, WM_MOUSEHWHEEL. + COREWEBVIEW2_MOUSE_EVENT_KIND_HORIZONTAL_WHEEL = 526, + /// Left button double click mouse event, WM_LBUTTONDBLCLK. + COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_DOUBLE_CLICK = 515, + /// Left button down mouse event, WM_LBUTTONDOWN. + COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_DOWN = 513, + /// Left button up mouse event, WM_LBUTTONUP. + COREWEBVIEW2_MOUSE_EVENT_KIND_LEFT_BUTTON_UP = 514, + /// Mouse leave event, WM_MOUSELEAVE. + COREWEBVIEW2_MOUSE_EVENT_KIND_LEAVE = 675, + /// Middle button double click mouse event, WM_MBUTTONDBLCLK. + COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_DOUBLE_CLICK = 521, + /// Middle button down mouse event, WM_MBUTTONDOWN. + COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_DOWN = 519, + /// Middle button up mouse event, WM_MBUTTONUP. + COREWEBVIEW2_MOUSE_EVENT_KIND_MIDDLE_BUTTON_UP = 520, + /// Mouse move event, WM_MOUSEMOVE. + COREWEBVIEW2_MOUSE_EVENT_KIND_MOVE = 512, + /// Right button double click mouse event, WM_RBUTTONDBLCLK. + COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_DOUBLE_CLICK = 518, + /// Right button down mouse event, WM_RBUTTONDOWN. + COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_DOWN = 516, + /// Right button up mouse event, WM_RBUTTONUP. + COREWEBVIEW2_MOUSE_EVENT_KIND_RIGHT_BUTTON_UP = 517, + /// Mouse wheel scroll event, WM_MOUSEWHEEL. + COREWEBVIEW2_MOUSE_EVENT_KIND_WHEEL = 522, + /// First or second X button double click mouse event, WM_XBUTTONDBLCLK. + COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOUBLE_CLICK = 525, + /// First or second X button down mouse event, WM_XBUTTONDOWN. + COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOWN = 523, + /// First or second X button up mouse event, WM_XBUTTONUP. + COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_UP = 524, + /// Mouse Right Button Down event over a nonclient area, WM_NCRBUTTONDOWN. + COREWEBVIEW2_MOUSE_EVENT_KIND_NON_CLIENT_RIGHT_BUTTON_DOWN = 164, + /// Mouse Right Button up event over a nonclient area, WM_NCRBUTTONUP. + COREWEBVIEW2_MOUSE_EVENT_KIND_NON_CLIENT_RIGHT_BUTTON_UP = 165, +} COREWEBVIEW2_MOUSE_EVENT_KIND; + +/// Mouse event virtual keys associated with a COREWEBVIEW2_MOUSE_EVENT_KIND for +/// SendMouseInput. These values can be combined into a bit flag if more than +/// one virtual key is pressed for the event. The values of this enum align +/// with the matching MK_* mouse keys. +[v1_enum] +typedef enum COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS { + /// No additional keys pressed. + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_NONE = 0x0, + /// Left mouse button is down, MK_LBUTTON. + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_LEFT_BUTTON = 0x1, + /// Right mouse button is down, MK_RBUTTON. + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_RIGHT_BUTTON = 0x2, + /// SHIFT key is down, MK_SHIFT. + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_SHIFT = 0x4, + /// CTRL key is down, MK_CONTROL. + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_CONTROL = 0x8, + /// Middle mouse button is down, MK_MBUTTON. + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_MIDDLE_BUTTON = 0x10, + /// First X button is down, MK_XBUTTON1 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_X_BUTTON1 = 0x20, + /// Second X button is down, MK_XBUTTON2 + COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS_X_BUTTON2 = 0x40, +} COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS; +cpp_quote("DEFINE_ENUM_FLAG_OPERATORS(COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS)") + +/// Specifies the reason for moving focus. +[v1_enum] +typedef enum COREWEBVIEW2_MOVE_FOCUS_REASON { + /// Specifies that the code is setting focus into WebView. + COREWEBVIEW2_MOVE_FOCUS_REASON_PROGRAMMATIC, + /// Specifies that the focus is moving due to Tab traversal forward. + COREWEBVIEW2_MOVE_FOCUS_REASON_NEXT, + /// Specifies that the focus is moving due to Tab traversal backward. + COREWEBVIEW2_MOVE_FOCUS_REASON_PREVIOUS, +} COREWEBVIEW2_MOVE_FOCUS_REASON; + +/// Specifies the navigation kind of each navigation. +[v1_enum] +typedef enum COREWEBVIEW2_NAVIGATION_KIND { + /// A navigation caused by `CoreWebView2.Reload()`, `location.reload()`, the end user + /// using F5 or other UX, or other reload mechanisms to reload the current document + /// without modifying the navigation history. + COREWEBVIEW2_NAVIGATION_KIND_RELOAD, + /// A navigation back or forward to a different entry in the session navigation history, + /// like via `CoreWebView2.Back()`, `location.back()`, the end user pressing Alt+Left + /// or other UX, or other mechanisms to navigate back or forward in the current + /// session navigation history. + COREWEBVIEW2_NAVIGATION_KIND_BACK_OR_FORWARD, + /// A navigation to another document, which can be caused by `CoreWebView2.Navigate()`, + /// `window.location.href = ...`, or other WebView2 or DOM APIs that navigate to a new URI. + COREWEBVIEW2_NAVIGATION_KIND_NEW_DOCUMENT, +} COREWEBVIEW2_NAVIGATION_KIND; + +/// This enum contains values representing possible regions a given +/// point lies within. The values of this enum align with the +/// matching WM_NCHITTEST* window message return values. +[v1_enum] +typedef enum COREWEBVIEW2_NON_CLIENT_REGION_KIND { + /// A hit test region out of bounds of the WebView2. + /// This has the same value as the Win32 HTNOWHERE + COREWEBVIEW2_NON_CLIENT_REGION_KIND_NOWHERE = 0, + /// A hit test region in the WebView2 which does not have the CSS style + /// `-webkit-app-region: drag` set. This is normal web content that should not be + /// considered part of the app window's title bar. This has the same value + /// as the Win32 HTCLIENT constant. + COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLIENT = 1, + /// A hit test region in the WebView2 which has the CSS style + /// `-webkit-app-region: drag` set. Web content should use this CSS + /// style to identify regions that should be treated like the app + /// window's title bar. This has the same value as the Win32 HTCAPTION + /// constant. + COREWEBVIEW2_NON_CLIENT_REGION_KIND_CAPTION = 2, + /// A hit test region in the Webview2 which corresponds to the minimize + /// window control button. + COREWEBVIEW2_NON_CLIENT_REGION_KIND_MINIMIZE = 8, + /// A hit test region in the Webview2 which corresponds to the maximize + /// window control button. + COREWEBVIEW2_NON_CLIENT_REGION_KIND_MAXIMIZE = 9, + /// A hit test region in the Webview2 which corresponds to the close + /// window control button. + COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLOSE = 20, +} COREWEBVIEW2_NON_CLIENT_REGION_KIND; + +/// Specifies the PDF toolbar item types used for the `ICoreWebView2Settings::put_HiddenPdfToolbarItems` method. +[v1_enum] +typedef enum COREWEBVIEW2_PDF_TOOLBAR_ITEMS { + /// No item. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_NONE = 0x0, + /// The save button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SAVE = 0x1, + /// The print button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PRINT = 0x2, + /// The save as button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SAVE_AS = 0x4, + /// The zoom in button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ZOOM_IN = 0x8, + /// The zoom out button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ZOOM_OUT = 0x10, + /// The rotate button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_ROTATE = 0x20, + /// The fit page button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_FIT_PAGE = 0x40, + /// The page layout button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PAGE_LAYOUT = 0x80, + /// The bookmarks button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_BOOKMARKS = 0x100, + /// The page select button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_PAGE_SELECTOR = 0x200, + /// The search button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_SEARCH = 0x400, + /// The full screen button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_FULL_SCREEN = 0x800, + /// The more settings button. + COREWEBVIEW2_PDF_TOOLBAR_ITEMS_MORE_SETTINGS = 0x1000, +} COREWEBVIEW2_PDF_TOOLBAR_ITEMS; +cpp_quote("DEFINE_ENUM_FLAG_OPERATORS(COREWEBVIEW2_PDF_TOOLBAR_ITEMS)") + +/// Indicates the type of a permission request. +[v1_enum] +typedef enum COREWEBVIEW2_PERMISSION_KIND { + /// Indicates an unknown permission. + COREWEBVIEW2_PERMISSION_KIND_UNKNOWN_PERMISSION, + /// Indicates permission to capture audio. + COREWEBVIEW2_PERMISSION_KIND_MICROPHONE, + /// Indicates permission to capture video. + COREWEBVIEW2_PERMISSION_KIND_CAMERA, + /// Indicates permission to access geolocation. + COREWEBVIEW2_PERMISSION_KIND_GEOLOCATION, + /// Indicates permission to send web notifications. Apps that would like to + /// show notifications should handle `PermissionRequested` events + /// and no browser permission prompt will be shown for notification requests. + /// Note that push notifications are currently unavailable in WebView2. + COREWEBVIEW2_PERMISSION_KIND_NOTIFICATIONS, + /// Indicates permission to access generic sensor. Generic Sensor covering + /// ambient-light-sensor, accelerometer, gyroscope, and magnetometer. + COREWEBVIEW2_PERMISSION_KIND_OTHER_SENSORS, + /// Indicates permission to read the system clipboard without a user gesture. + COREWEBVIEW2_PERMISSION_KIND_CLIPBOARD_READ, + /// Indicates permission to automatically download multiple files. Permission + /// is requested when multiple downloads are triggered in quick succession. + COREWEBVIEW2_PERMISSION_KIND_MULTIPLE_AUTOMATIC_DOWNLOADS, + /// Indicates permission to read and write to files or folders on the device. + /// Permission is requested when developers use the [File System Access API](https://developer.mozilla.org/docs/Web/API/File_System_Access_API) + /// to show the file or folder picker to the end user, and then request + /// "readwrite" permission for the user's selection. + COREWEBVIEW2_PERMISSION_KIND_FILE_READ_WRITE, + /// Indicates permission to play audio and video automatically on sites. This + /// permission affects the autoplay attribute and play method of the audio and + /// video HTML elements, and the start method of the Web Audio API. See the + /// [Autoplay guide for media and Web Audio APIs](https://developer.mozilla.org/docs/Web/Media/Autoplay_guide) for details. + COREWEBVIEW2_PERMISSION_KIND_AUTOPLAY, + /// Indicates permission to use fonts on the device. Permission is requested + /// when developers use the [Local Font Access API](https://wicg.github.io/local-font-access/) + /// to query the system fonts available for styling web content. + COREWEBVIEW2_PERMISSION_KIND_LOCAL_FONTS, + /// Indicates permission to send and receive system exclusive messages to/from MIDI + /// (Musical Instrument Digital Interface) devices. Permission is requested + /// when developers use the [Web MIDI API](https://developer.mozilla.org/docs/Web/API/Web_MIDI_API) + /// to request access to system exclusive MIDI messages. + COREWEBVIEW2_PERMISSION_KIND_MIDI_SYSTEM_EXCLUSIVE_MESSAGES, + /// Indicates permission to open and place windows on the screen. Permission is + /// requested when developers use the [Multi-Screen Window Placement API](https://www.w3.org/TR/window-placement/) + /// to get screen details. + COREWEBVIEW2_PERMISSION_KIND_WINDOW_MANAGEMENT, + /// Indicates permission to persist storage created by the Storage APIs, + /// service workers, etc. If the persistent storage permission is granted, + /// the browser will not evict data in case of low disk space. Permission + /// for a site can be checked using + /// [Storage Manager API](https://developer.mozilla.org/en-US/docs/Web/API/StorageManager/persisted). + COREWEBVIEW2_PERMISSION_KIND_PERSISTENT_STORAGE, +} COREWEBVIEW2_PERMISSION_KIND; + +/// Specifies the response to a permission request. +[v1_enum] +typedef enum COREWEBVIEW2_PERMISSION_STATE { + /// Specifies that the default browser behavior is used, which normally + /// prompt users for decision. + COREWEBVIEW2_PERMISSION_STATE_DEFAULT, + /// Specifies that the permission request is granted. + COREWEBVIEW2_PERMISSION_STATE_ALLOW, + /// Specifies that the permission request is denied. + COREWEBVIEW2_PERMISSION_STATE_DENY, +} COREWEBVIEW2_PERMISSION_STATE; + +/// Pointer event type used by SendPointerInput to convey the type of pointer +/// event being sent to WebView. The values of this enum align with the +/// matching WM_POINTER* window messages. +[v1_enum] +typedef enum COREWEBVIEW2_POINTER_EVENT_KIND { + /// Corresponds to WM_POINTERACTIVATE. + COREWEBVIEW2_POINTER_EVENT_KIND_ACTIVATE = 587, + /// Corresponds to WM_POINTERDOWN. + COREWEBVIEW2_POINTER_EVENT_KIND_DOWN = 582, + /// Corresponds to WM_POINTERENTER. + COREWEBVIEW2_POINTER_EVENT_KIND_ENTER = 585, + /// Corresponds to WM_POINTERLEAVE. + COREWEBVIEW2_POINTER_EVENT_KIND_LEAVE = 586, + /// Corresponds to WM_POINTERUP. + COREWEBVIEW2_POINTER_EVENT_KIND_UP = 583, + /// Corresponds to WM_POINTERUPDATE. + COREWEBVIEW2_POINTER_EVENT_KIND_UPDATE = 581, +} COREWEBVIEW2_POINTER_EVENT_KIND; + +/// An enum to represent the options for WebView2 color scheme: auto, light, or dark. +[v1_enum] +typedef enum COREWEBVIEW2_PREFERRED_COLOR_SCHEME { + /// Auto color scheme. + COREWEBVIEW2_PREFERRED_COLOR_SCHEME_AUTO, + /// Light color scheme. + COREWEBVIEW2_PREFERRED_COLOR_SCHEME_LIGHT, + /// Dark color scheme. + COREWEBVIEW2_PREFERRED_COLOR_SCHEME_DARK, +} COREWEBVIEW2_PREFERRED_COLOR_SCHEME; + +/// Specifies the collation for a print. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_COLLATION { + /// The default collation for a printer. + COREWEBVIEW2_PRINT_COLLATION_DEFAULT, + /// Indicate that the collation has been selected for the printed output. + COREWEBVIEW2_PRINT_COLLATION_COLLATED, + /// Indicate that the collation has not been selected for the printed output. + COREWEBVIEW2_PRINT_COLLATION_UNCOLLATED, +} COREWEBVIEW2_PRINT_COLLATION; + +/// Specifies the color mode for a print. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_COLOR_MODE { + /// The default color mode for a printer. + COREWEBVIEW2_PRINT_COLOR_MODE_DEFAULT, + /// Indicate that the printed output will be in color. + COREWEBVIEW2_PRINT_COLOR_MODE_COLOR, + /// Indicate that the printed output will be in shades of gray. + COREWEBVIEW2_PRINT_COLOR_MODE_GRAYSCALE, +} COREWEBVIEW2_PRINT_COLOR_MODE; + +/// Specifies the print dialog kind. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_DIALOG_KIND { + /// Opens the browser print preview dialog. + COREWEBVIEW2_PRINT_DIALOG_KIND_BROWSER, + /// Opens the system print dialog. + COREWEBVIEW2_PRINT_DIALOG_KIND_SYSTEM, +} COREWEBVIEW2_PRINT_DIALOG_KIND; + +/// Specifies the duplex option for a print. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_DUPLEX { + /// The default duplex for a printer. + COREWEBVIEW2_PRINT_DUPLEX_DEFAULT, + /// Print on only one side of the sheet. + COREWEBVIEW2_PRINT_DUPLEX_ONE_SIDED, + /// Print on both sides of the sheet, flipped along the long edge. + COREWEBVIEW2_PRINT_DUPLEX_TWO_SIDED_LONG_EDGE, + /// Print on both sides of the sheet, flipped along the short edge. + COREWEBVIEW2_PRINT_DUPLEX_TWO_SIDED_SHORT_EDGE, +} COREWEBVIEW2_PRINT_DUPLEX; + +/// Specifies the media size for a print. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_MEDIA_SIZE { + /// The default media size for a printer. + COREWEBVIEW2_PRINT_MEDIA_SIZE_DEFAULT, + /// Indicate custom media size that is specific to the printer. + COREWEBVIEW2_PRINT_MEDIA_SIZE_CUSTOM, +} COREWEBVIEW2_PRINT_MEDIA_SIZE; + +/// The orientation for printing, used by the `Orientation` property on +/// `ICoreWebView2PrintSettings`. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_ORIENTATION { + /// Print the page(s) in portrait orientation. + COREWEBVIEW2_PRINT_ORIENTATION_PORTRAIT, + /// Print the page(s) in landscape orientation. + COREWEBVIEW2_PRINT_ORIENTATION_LANDSCAPE, +} COREWEBVIEW2_PRINT_ORIENTATION; + +/// Indicates the status for printing. +[v1_enum] +typedef enum COREWEBVIEW2_PRINT_STATUS { + /// Indicates that the print operation is succeeded. + COREWEBVIEW2_PRINT_STATUS_SUCCEEDED, + /// Indicates that the printer is not available. + COREWEBVIEW2_PRINT_STATUS_PRINTER_UNAVAILABLE, + /// Indicates that the print operation is failed. + COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR, +} COREWEBVIEW2_PRINT_STATUS; + +/// Specifies the process failure type used in the +/// `ICoreWebView2ProcessFailedEventArgs` interface. The values in this enum +/// make reference to the process kinds in the Chromium architecture. For more +/// information about what these processes are and what they do, see +/// [Browser Architecture - Inside look at modern web browser](https://developers.google.com/web/updates/2018/09/inside-browser-part1). +[v1_enum] +typedef enum COREWEBVIEW2_PROCESS_FAILED_KIND { + /// Indicates that the browser process ended unexpectedly. The WebView + /// automatically moves to the Closed state. The app has to recreate a new + /// WebView to recover from this failure. + COREWEBVIEW2_PROCESS_FAILED_KIND_BROWSER_PROCESS_EXITED, + /// Indicates that the main frame's render process ended unexpectedly. Any + /// subframes in the WebView will be gone too. A new render process is + /// created automatically and navigated to an error page. You can use the + /// `Reload` method to try to recover from this failure. Alternatively, you + /// can `Close` and recreate the WebView. + COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_EXITED, + /// Indicates that the main frame's render process is unresponsive. Renderer + /// process unresponsiveness can happen for the following reasons: + /// There is a **long-running script** being executed. For example, the + /// web content in your WebView might be performing a synchronous XHR, or have + /// entered an infinite loop. Or, the **system is busy**. + /// The `ProcessFailed` event will continue to be raised every few seconds + /// until the renderer process has become responsive again. The application + /// can consider taking action if the event keeps being raised. For example, + /// the application might show UI for the user to decide to keep waiting or + /// reload the page, or navigate away. + COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_UNRESPONSIVE, + /// Indicates that a frame-only render process ended unexpectedly. The process + /// exit does not affect the top-level document, only a subset of the + /// subframes within it. The content in these frames is replaced with an error + /// page in the frame. Your application can communicate with the main frame to + /// recover content in the impacted frames, using + /// `ICoreWebView2ProcessFailedEventArgs2::FrameInfosForFailedProcess` to get + /// information about the impacted frames. + COREWEBVIEW2_PROCESS_FAILED_KIND_FRAME_RENDER_PROCESS_EXITED, + /// Indicates that a utility process ended unexpectedly. The failed process + /// is recreated automatically. Your application does **not** need to handle + /// recovery for this event, but can use `ICoreWebView2ProcessFailedEventArgs` + /// and `ICoreWebView2ProcessFailedEventArgs2` to collect information about + /// the failure, including `ProcessDescription`. + COREWEBVIEW2_PROCESS_FAILED_KIND_UTILITY_PROCESS_EXITED, + /// Indicates that a sandbox helper process ended unexpectedly. This failure + /// is not fatal. Your application does **not** need to handle recovery for + /// this event, but can use `ICoreWebView2ProcessFailedEventArgs` and + /// `ICoreWebView2ProcessFailedEventArgs2` to collect information about + /// the failure. + COREWEBVIEW2_PROCESS_FAILED_KIND_SANDBOX_HELPER_PROCESS_EXITED, + /// Indicates that the GPU process ended unexpectedly. The failed process + /// is recreated automatically. Your application does **not** need to handle + /// recovery for this event, but can use `ICoreWebView2ProcessFailedEventArgs` + /// and `ICoreWebView2ProcessFailedEventArgs2` to collect information about + /// the failure. + COREWEBVIEW2_PROCESS_FAILED_KIND_GPU_PROCESS_EXITED, + /// Indicates that a PPAPI plugin process ended unexpectedly. This failure + /// is not fatal. Your application does **not** need to handle recovery for + /// this event, but can use `ICoreWebView2ProcessFailedEventArgs` and + /// `ICoreWebView2ProcessFailedEventArgs2` to collect information about + /// the failure, including `ProcessDescription`. + COREWEBVIEW2_PROCESS_FAILED_KIND_PPAPI_PLUGIN_PROCESS_EXITED, + /// Indicates that a PPAPI plugin broker process ended unexpectedly. This failure + /// is not fatal. Your application does **not** need to handle recovery for + /// this event, but can use `ICoreWebView2ProcessFailedEventArgs` and + /// `ICoreWebView2ProcessFailedEventArgs2` to collect information about + /// the failure. + COREWEBVIEW2_PROCESS_FAILED_KIND_PPAPI_BROKER_PROCESS_EXITED, + /// Indicates that a process of unspecified kind ended unexpectedly. Your + /// application can use `ICoreWebView2ProcessFailedEventArgs` and + /// `ICoreWebView2ProcessFailedEventArgs2` to collect information about + /// the failure. + COREWEBVIEW2_PROCESS_FAILED_KIND_UNKNOWN_PROCESS_EXITED, +} COREWEBVIEW2_PROCESS_FAILED_KIND; + +/// Specifies the process failure reason used in the +/// `ICoreWebView2ProcessFailedEventArgs` interface. For process failures where +/// a process has exited, it indicates the type of issue that produced the +/// process exit. +[v1_enum] +typedef enum COREWEBVIEW2_PROCESS_FAILED_REASON { + /// An unexpected process failure occurred. + COREWEBVIEW2_PROCESS_FAILED_REASON_UNEXPECTED, + /// The process became unresponsive. + /// This only applies to the main frame's render process. + COREWEBVIEW2_PROCESS_FAILED_REASON_UNRESPONSIVE, + /// The process was terminated. For example, from Task Manager. + COREWEBVIEW2_PROCESS_FAILED_REASON_TERMINATED, + /// The process crashed. Most crashes will generate dumps in the location + /// indicated by `ICoreWebView2Environment11::get_FailureReportFolderPath`. + COREWEBVIEW2_PROCESS_FAILED_REASON_CRASHED, + /// The process failed to launch. + COREWEBVIEW2_PROCESS_FAILED_REASON_LAUNCH_FAILED, + /// The process terminated due to running out of memory. + COREWEBVIEW2_PROCESS_FAILED_REASON_OUT_OF_MEMORY, + /// Deprecated. This value is unused. + COREWEBVIEW2_PROCESS_FAILED_REASON_PROFILE_DELETED, + /// The process exited normally (exit code 0). This typically indicates + /// a clean or transparent process shutdown. + COREWEBVIEW2_PROCESS_FAILED_REASON_NORMAL_EXIT, + /// The process exited abnormally (non-zero exit code). This indicates + /// an unexpected termination that is not a crash or kill. + COREWEBVIEW2_PROCESS_FAILED_REASON_ABNORMAL_EXIT, + /// The OS terminated the process due to a code integrity failure. + /// This indicates a DLL failed Windows Code Integrity verification. + COREWEBVIEW2_PROCESS_FAILED_REASON_INTEGRITY_FAILURE, +} COREWEBVIEW2_PROCESS_FAILED_REASON; + +/// Indicates the process type used in the ICoreWebView2ProcessInfo interface. +[v1_enum] +typedef enum COREWEBVIEW2_PROCESS_KIND { + /// Indicates the browser process kind. + COREWEBVIEW2_PROCESS_KIND_BROWSER, + /// Indicates the render process kind. + COREWEBVIEW2_PROCESS_KIND_RENDERER, + /// Indicates the utility process kind. + COREWEBVIEW2_PROCESS_KIND_UTILITY, + /// Indicates the sandbox helper process kind. + COREWEBVIEW2_PROCESS_KIND_SANDBOX_HELPER, + /// Indicates the GPU process kind. + COREWEBVIEW2_PROCESS_KIND_GPU, + /// Indicates the PPAPI plugin process kind. + COREWEBVIEW2_PROCESS_KIND_PPAPI_PLUGIN, + /// Indicates the PPAPI plugin broker process kind. + COREWEBVIEW2_PROCESS_KIND_PPAPI_BROKER, +} COREWEBVIEW2_PROCESS_KIND; + +/// The WebView2 release channels. Use `ReleaseChannels` and `ChannelSearchKind` +/// on `ICoreWebView2EnvironmentOptions` to control which channel is searched +/// for during environment creation. +/// +/// |Channel|Primary purpose|How often updated with new features| +/// |:---:|---|:---:| +/// |Stable (WebView2 Runtime)|Broad Deployment|Monthly| +/// |Beta|Flighting with inner rings, automated testing|Monthly| +/// |Dev|Automated testing, selfhosting to test new APIs and features|Weekly| +/// |Canary|Automated testing, selfhosting to test new APIs and features|Daily| +[v1_enum] +typedef enum COREWEBVIEW2_RELEASE_CHANNELS { + /// No release channel. Passing only this value to `ReleaseChannels` results + /// in HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND). + COREWEBVIEW2_RELEASE_CHANNELS_NONE = 0x0, + /// The stable WebView2 Runtime that is released every 4 weeks. + COREWEBVIEW2_RELEASE_CHANNELS_STABLE = 0x1, + /// The Beta release channel that is released every 4 weeks, a week before the + /// stable release. + COREWEBVIEW2_RELEASE_CHANNELS_BETA = 0x2, + /// The Dev release channel that is released weekly. + COREWEBVIEW2_RELEASE_CHANNELS_DEV = 0x4, + /// The Canary release channel that is released daily. + COREWEBVIEW2_RELEASE_CHANNELS_CANARY = 0x8, +} COREWEBVIEW2_RELEASE_CHANNELS; +cpp_quote("DEFINE_ENUM_FLAG_OPERATORS(COREWEBVIEW2_RELEASE_CHANNELS)") + +/// Specifies Save As kind selection options for +/// `ICoreWebView2SaveAsUIShowingEventArgs`. +/// +/// For HTML documents, we support 3 Save As kinds: HTML_ONLY, SINGLE_FILE and +/// COMPLETE. For non-HTML documents, you must use DEFAULT. MIME types of `text/html` and +/// `application/xhtml+xml` are considered HTML documents. +[v1_enum] +typedef enum COREWEBVIEW2_SAVE_AS_KIND { + /// Default kind to save non-HTML content. If this kind is selected for an HTML + /// page, the behavior is the same as the `HTML_ONLY` kind. + COREWEBVIEW2_SAVE_AS_KIND_DEFAULT, + /// Save the page as HTML. Only the top-level document is saved, excluding + /// subresources. + COREWEBVIEW2_SAVE_AS_KIND_HTML_ONLY, + /// Save the page as [MHTML](https://en.wikipedia.org/wiki/MHTML). + COREWEBVIEW2_SAVE_AS_KIND_SINGLE_FILE, + /// Save the page as HTML and download the page-related source files + /// (for example: CSS, JavaScript, images, etc.) in a directory with + /// the same filename prefix. + COREWEBVIEW2_SAVE_AS_KIND_COMPLETE, +} COREWEBVIEW2_SAVE_AS_KIND; + +/// Status of a programmatic Save As call. Indicates the result +/// of the `ShowSaveAsUI` method. +[v1_enum] +typedef enum COREWEBVIEW2_SAVE_AS_UI_RESULT { + /// The ShowSaveAsUI method call completed successfully. By default, the system + /// Save As dialog opens. If `SuppressDefaultDialog` is set to TRUE, the system + /// dialog is skipped. + COREWEBVIEW2_SAVE_AS_UI_RESULT_SUCCESS, + /// Could not perform Save As because the destination file path is an invalid path. + /// + /// The path is invalid when it is empty, a relative path, or a directory, + /// or when the parent path does not exist. + COREWEBVIEW2_SAVE_AS_UI_RESULT_INVALID_PATH, + /// Could not perform Save As because the destination file path already exists and + /// replacing files was not allowed by the `AllowReplace` property. + COREWEBVIEW2_SAVE_AS_UI_RESULT_FILE_ALREADY_EXISTS, + /// Could not perform Save As because the `Kind` property selection is not + /// supported due to content MIME type or system limits. + /// + /// See the `COREWEBVIEW2_SAVE_AS_KIND` enum for MIME type limits. + /// + /// System limits include when the `HTML_ONLY` kind is selected for an error page + /// at child mode, or when the `COMPLETE` kind is selected and the WebView is + /// running in an App Container. + COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED, + /// Did not perform Save As because the end user cancelled or the + /// `Cancel` property on `ICoreWebView2SaveAsUIShowingEventArgs` was set to TRUE. + COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED, +} COREWEBVIEW2_SAVE_AS_UI_RESULT; + +/// Specifies the JavaScript dialog type used in the +/// `ICoreWebView2ScriptDialogOpeningEventHandler` interface. +[v1_enum] +typedef enum COREWEBVIEW2_SCRIPT_DIALOG_KIND { + /// Indicates that the dialog uses the `window.alert` JavaScript function. + COREWEBVIEW2_SCRIPT_DIALOG_KIND_ALERT, + /// Indicates that the dialog uses the `window.confirm` JavaScript function. + COREWEBVIEW2_SCRIPT_DIALOG_KIND_CONFIRM, + /// Indicates that the dialog uses the `window.prompt` JavaScript function. + COREWEBVIEW2_SCRIPT_DIALOG_KIND_PROMPT, + /// Indicates that the dialog uses the `beforeunload` JavaScript event. + COREWEBVIEW2_SCRIPT_DIALOG_KIND_BEFOREUNLOAD, +} COREWEBVIEW2_SCRIPT_DIALOG_KIND; + +/// Set ScrollBar style on `ICoreWebView2EnvironmentOptions` during environment creation. +[v1_enum] +typedef enum COREWEBVIEW2_SCROLLBAR_STYLE { + /// Browser default ScrollBar style + COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT, + /// Window style fluent overlay scroll bar + /// Please see [Fluent UI](https://developer.microsoft.com/fluentui#/) + /// for more details on fluent UI. + COREWEBVIEW2_SCROLLBAR_STYLE_FLUENT_OVERLAY, +} COREWEBVIEW2_SCROLLBAR_STYLE; + +/// Specifies the action type when server certificate error is detected to be +/// used in the `ICoreWebView2ServerCertificateErrorDetectedEventArgs` +/// interface. +[v1_enum] +typedef enum COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION { + /// Indicates to ignore the warning and continue the request with the TLS + /// certificate. This decision is cached for the RequestUri's host and the + /// server certificate in the session. + COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_ALWAYS_ALLOW, + /// Indicates to reject the certificate and cancel the request. + COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_CANCEL, + /// Indicates to display the default TLS interstitial error page to user for + /// page navigations. + /// For others TLS certificate is rejected and the request is cancelled. + COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_DEFAULT, +} COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION; + +/// Specifies the desired access from script to `CoreWebView2SharedBuffer`. +[v1_enum] +typedef enum COREWEBVIEW2_SHARED_BUFFER_ACCESS { + /// Script from web page only has read access to the shared buffer. + COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY, + /// Script from web page has read and write access to the shared buffer. + COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_WRITE, +} COREWEBVIEW2_SHARED_BUFFER_ACCESS; + +/// Indicates the text direction of the notification. +[v1_enum] +typedef enum COREWEBVIEW2_TEXT_DIRECTION_KIND { + /// Indicates that the notification text direction adopts the browser's language setting behavior. + COREWEBVIEW2_TEXT_DIRECTION_KIND_DEFAULT, + /// Indicates that the notification text is left-to-right. + COREWEBVIEW2_TEXT_DIRECTION_KIND_LEFT_TO_RIGHT, + /// Indicates that the notification text is right-to-left. + COREWEBVIEW2_TEXT_DIRECTION_KIND_RIGHT_TO_LEFT, +} COREWEBVIEW2_TEXT_DIRECTION_KIND; + +/// Tracking prevention levels. +[v1_enum] +typedef enum COREWEBVIEW2_TRACKING_PREVENTION_LEVEL { + /// Tracking prevention is turned off. + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE, + /// The least restrictive level of tracking prevention. Set to this level to + /// protect against malicious trackers but allows most other trackers and + /// personalize content and ads. + /// + /// See [Current tracking prevention + /// behavior](/microsoft-edge/web-platform/tracking-prevention#current-tracking-prevention-behavior) + /// for fine-grained information on what is being blocked with this level and + /// can change with different Edge versions. + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BASIC, + /// The default level of tracking prevention. Set to this level to + /// protect against social media tracking on top of malicious trackers. + /// Content and ads will likely be less personalized. + /// + /// See [Current tracking prevention + /// behavior](/microsoft-edge/web-platform/tracking-prevention#current-tracking-prevention-behavior) + /// for fine-grained information on what is being blocked with this level and + /// can change with different Edge versions. + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BALANCED, + /// The most restrictive level of tracking prevention. Set to this level to + /// protect + /// against malicious trackers and most trackers across sites. Content and ads + /// will likely have minimal personalization. + /// + /// This level blocks the most trackers but could cause some websites to not + /// behave as expected. + /// + /// See [Current tracking prevention + /// behavior](/microsoft-edge/web-platform/tracking-prevention#current-tracking-prevention-behavior) + /// for fine-grained information on what is being blocked with this level and + /// can change with different Edge versions. + COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_STRICT, +} COREWEBVIEW2_TRACKING_PREVENTION_LEVEL; + +/// Indicates the error status values for web navigations. +[v1_enum] +typedef enum COREWEBVIEW2_WEB_ERROR_STATUS { + /// Indicates that an unknown error occurred. + COREWEBVIEW2_WEB_ERROR_STATUS_UNKNOWN, + /// Indicates that the SSL certificate common name does not match the web + /// address. + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_COMMON_NAME_IS_INCORRECT, + /// Indicates that the SSL certificate has expired. + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_EXPIRED, + /// Indicates that the SSL client certificate contains errors. + COREWEBVIEW2_WEB_ERROR_STATUS_CLIENT_CERTIFICATE_CONTAINS_ERRORS, + /// Indicates that the SSL certificate has been revoked. + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_REVOKED, + /// Indicates that the SSL certificate is not valid. The certificate may not + /// match the public key pins for the host name, the certificate is signed + /// by an untrusted authority or using a weak sign algorithm, the certificate + /// claimed DNS names violate name constraints, the certificate contains a + /// weak key, the validity period of the certificate is too long, lack of + /// revocation information or revocation mechanism, non-unique host name, + /// lack of certificate transparency information, or the certificate is + /// chained to a + /// [legacy Symantec root](https://security.googleblog.com/2018/03/distrust-of-symantec-pki-immediate.html). + COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_IS_INVALID, + /// Indicates that the host is unreachable. + COREWEBVIEW2_WEB_ERROR_STATUS_SERVER_UNREACHABLE, + /// Indicates that the connection has timed out. + COREWEBVIEW2_WEB_ERROR_STATUS_TIMEOUT, + /// Indicates that the server returned an invalid or unrecognized response. + COREWEBVIEW2_WEB_ERROR_STATUS_ERROR_HTTP_INVALID_SERVER_RESPONSE, + /// Indicates that the connection was stopped. + COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_ABORTED, + /// Indicates that the connection was reset. + COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_RESET, + /// Indicates that the Internet connection has been lost. + COREWEBVIEW2_WEB_ERROR_STATUS_DISCONNECTED, + /// Indicates that a connection to the destination was not established. + COREWEBVIEW2_WEB_ERROR_STATUS_CANNOT_CONNECT, + /// Indicates that the provided host name was not able to be resolved. + COREWEBVIEW2_WEB_ERROR_STATUS_HOST_NAME_NOT_RESOLVED, + /// Indicates that the operation was canceled. This status code is also used + /// in the following cases: 1) when the app cancels a navigation via NavigationStarting event. + /// 2) For original navigation if the app navigates the WebView2 in a rapid succession + /// away after the load for original navigation commenced, but before it completed. + COREWEBVIEW2_WEB_ERROR_STATUS_OPERATION_CANCELED, + /// Indicates that the request redirect failed. + COREWEBVIEW2_WEB_ERROR_STATUS_REDIRECT_FAILED, + /// Indicates that an unexpected error occurred. + COREWEBVIEW2_WEB_ERROR_STATUS_UNEXPECTED_ERROR, + /// Indicates that user is prompted with a login, waiting on user action. + /// Initial navigation to a login site will always return this even if app provides + /// credential using BasicAuthenticationRequested. + /// HTTP response status code in this case is 401. + /// See status code reference here: https://developer.mozilla.org/docs/Web/HTTP/Status. + COREWEBVIEW2_WEB_ERROR_STATUS_VALID_AUTHENTICATION_CREDENTIALS_REQUIRED, + /// Indicates that user lacks proper authentication credentials for a proxy server. + /// HTTP response status code in this case is 407. + /// See status code reference here: https://developer.mozilla.org/docs/Web/HTTP/Status. + COREWEBVIEW2_WEB_ERROR_STATUS_VALID_PROXY_AUTHENTICATION_REQUIRED, +} COREWEBVIEW2_WEB_ERROR_STATUS; + +/// Specifies the web resource request contexts. +[v1_enum] +typedef enum COREWEBVIEW2_WEB_RESOURCE_CONTEXT { + /// Specifies all resources. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_ALL, + /// Specifies a document resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_DOCUMENT, + /// Specifies a CSS resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_STYLESHEET, + /// Specifies an image resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_IMAGE, + /// Specifies another media resource such as a video. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_MEDIA, + /// Specifies a font resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_FONT, + /// Specifies a script resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_SCRIPT, + /// Specifies an XML HTTP request, Fetch and EventSource API communication. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_XML_HTTP_REQUEST, + /// Specifies a Fetch API communication. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_FETCH, + /// Specifies a TextTrack resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_TEXT_TRACK, + /// Specifies an EventSource API communication. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_EVENT_SOURCE, + /// Specifies a WebSocket API communication. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_WEBSOCKET, + /// Specifies a Web App Manifest. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_MANIFEST, + /// Specifies a Signed HTTP Exchange. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_SIGNED_EXCHANGE, + /// Specifies a Ping request. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_PING, + /// Specifies a CSP Violation Report. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_CSP_VIOLATION_REPORT, + /// Specifies an other resource. + COREWEBVIEW2_WEB_RESOURCE_CONTEXT_OTHER, +} COREWEBVIEW2_WEB_RESOURCE_CONTEXT; + +/// Specifies the source of `WebResourceRequested` event. +[v1_enum] +typedef enum COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS { + /// + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_NONE = 0x0, + /// Indicates that web resource is requested from main page including dedicated workers, + /// iframes and main script for shared workers. + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_DOCUMENT = 0x1, + /// Indicates that web resource is requested from shared worker. + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SHARED_WORKER = 0x2, + /// Indicates that web resource is requested from service worker. + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SERVICE_WORKER = 0x4, + /// Indicates that web resource is requested from any supported source. + COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_ALL = 0xFFFFFFFF, +} COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS; +cpp_quote("DEFINE_ENUM_FLAG_OPERATORS(COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS)") + + +/// A value representing RGBA color (Red, Green, Blue, Alpha) for WebView2. +/// Each component takes a value from 0 to 255, with 0 being no intensity +/// and 255 being the highest intensity. +typedef struct COREWEBVIEW2_COLOR { + /// Specifies the intensity of the Alpha ie. opacity value. 0 is transparent, + /// 255 is opaque. + BYTE A; + /// Specifies the intensity of the Red color. + BYTE R; + /// Specifies the intensity of the Green color. + BYTE G; + /// Specifies the intensity of the Blue color. + BYTE B; +} COREWEBVIEW2_COLOR; + +/// Contains the information packed into the `LPARAM` sent to a Win32 key +/// event. For more information about `WM_KEYDOWN`, navigate to +/// [WM_KEYDOWN message](/windows/win32/inputdev/wm-keydown). +typedef struct COREWEBVIEW2_PHYSICAL_KEY_STATUS { + /// Specifies the repeat count for the current message. + UINT32 RepeatCount; + /// Specifies the scan code. + UINT32 ScanCode; + /// Indicates that the key is an extended key. + BOOL IsExtendedKey; + /// Indicates that a menu key is held down (context code). + BOOL IsMenuKeyDown; + /// Indicates that the key was held down. + BOOL WasKeyDown; + /// Indicates that the key was released. + BOOL IsKeyReleased; +} COREWEBVIEW2_PHYSICAL_KEY_STATUS; + + +// End of enums and structs + + +/// Receives the result of the `AddScriptToExecuteOnDocumentCreated` method. +[uuid(b99369f3-9b11-47b5-bc6f-8e7895fcea17), object, pointer_default(unique)] +interface ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] LPCWSTR result); +} +/// Receives the result of the `ExecuteScript` method. +[uuid(49511172-cc67-4bca-9923-137112f4c4cc), object, pointer_default(unique)] +interface ICoreWebView2ExecuteScriptCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] LPCWSTR result); +} +/// Receives the result of the `CapturePreview` method. +[uuid(697e05e9-3d8f-45fa-96f4-8ffe1ededaf5), object, pointer_default(unique)] +interface ICoreWebView2CapturePreviewCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} +/// Receives the result of the `CallDevToolsProtocolMethod` method. +[uuid(5c4889f0-5ef6-4c5a-952c-d8f1b92d0574), object, pointer_default(unique)] +interface ICoreWebView2CallDevToolsProtocolMethodCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] LPCWSTR result); +} + +/// Receives `ContainsFullScreenElementChanged` events. +[uuid(e45d98b1-afef-45be-8baf-6c7728867f73), object, pointer_default(unique)] +interface ICoreWebView2ContainsFullScreenElementChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} +/// Receives `ContentLoading` events. +[uuid(364471e7-f2be-4910-bdba-d72077d51c4b), object, pointer_default(unique)] +interface ICoreWebView2ContentLoadingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ContentLoadingEventArgs* args); +} +/// Receives `DocumentTitleChanged` events. +[uuid(f5f2b923-953e-4042-9f95-f3a118e1afd4), object, pointer_default(unique)] +interface ICoreWebView2DocumentTitleChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} +// Skipping ICoreWebView2NavigationCompletedEventHandler redefinition + +// Skipping ICoreWebView2NavigationStartingEventHandler redefinition + +/// Receives `HistoryChanged` events. +[uuid(c79a420c-efd9-4058-9295-3e8b4bcab645), object, pointer_default(unique)] +interface ICoreWebView2HistoryChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} +/// Receives `NavigationCompleted` events. +[uuid(d33a35bf-1c49-4f98-93ab-006e0533fe1c), object, pointer_default(unique)] +interface ICoreWebView2NavigationCompletedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2NavigationCompletedEventArgs* args); +} +/// Receives `NavigationStarting` events. +[uuid(9adbe429-f36d-432b-9ddc-f8881fbd76e3), object, pointer_default(unique)] +interface ICoreWebView2NavigationStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2NavigationStartingEventArgs* args); +} +/// Receives `NewWindowRequested` events. +[uuid(d4c185fe-c81c-4989-97af-2d3fa7ab5651), object, pointer_default(unique)] +interface ICoreWebView2NewWindowRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2NewWindowRequestedEventArgs* args); +} +/// Receives `PermissionRequested` events. +[uuid(15e1c6a3-c72a-4df3-91d7-d097fbec6bfd), object, pointer_default(unique)] +interface ICoreWebView2PermissionRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2PermissionRequestedEventArgs* args); +} +/// Receives `ProcessFailed` events. +[uuid(79e0aea4-990b-42d9-aa1d-0fcc2e5bc7f1), object, pointer_default(unique)] +interface ICoreWebView2ProcessFailedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ProcessFailedEventArgs* args); +} +/// Receives `ScriptDialogOpening` events. +[uuid(ef381bf9-afa8-4e37-91c4-8ac48524bdfb), object, pointer_default(unique)] +interface ICoreWebView2ScriptDialogOpeningEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ScriptDialogOpeningEventArgs* args); +} +/// Receives `SourceChanged` events. +[uuid(3c067f9f-5388-4772-8b48-79f7ef1ab37c), object, pointer_default(unique)] +interface ICoreWebView2SourceChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2SourceChangedEventArgs* args); +} +/// Receives `WebMessageReceived` events. +[uuid(57213f19-00e6-49fa-8e07-898ea01ecbd2), object, pointer_default(unique)] +interface ICoreWebView2WebMessageReceivedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2WebMessageReceivedEventArgs* args); +} +/// Receives `WebResourceRequested` events. +[uuid(ab00b74c-15f1-4646-80e8-e76341d25d71), object, pointer_default(unique)] +interface ICoreWebView2WebResourceRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2WebResourceRequestedEventArgs* args); +} +/// Receives `WindowCloseRequested` events. +[uuid(5c19e9e0-092f-486b-affa-ca8231913039), object, pointer_default(unique)] +interface ICoreWebView2WindowCloseRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} + +/// Receives `DOMContentLoaded` events. +[uuid(4bac7e9c-199e-49ed-87ed-249303acf019), object, pointer_default(unique)] +interface ICoreWebView2DOMContentLoadedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2DOMContentLoadedEventArgs* args); +} +/// Receives `WebResourceResponseReceived` events. +[uuid(7de9898a-24f5-40c3-a2de-d4f458e69828), object, pointer_default(unique)] +interface ICoreWebView2WebResourceResponseReceivedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2WebResourceResponseReceivedEventArgs* args); +} + +/// Receives the result of the `TrySuspend` method. +[uuid(00f206a7-9d17-4605-91f6-4e8e4de192e3), object, pointer_default(unique)] +interface ICoreWebView2TrySuspendCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] BOOL result); +} + +/// Receives `DownloadStarting` events. +[uuid(efedc989-c396-41ca-83f7-07f845a55724), object, pointer_default(unique)] +interface ICoreWebView2DownloadStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2DownloadStartingEventArgs* args); +} +/// Receives `FrameCreated` events. +[uuid(38059770-9baa-11eb-a8b3-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2FrameCreatedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2FrameCreatedEventArgs* args); +} + +/// Receives `IsDocumentPlayingAudioChanged` events. +[uuid(5def109a-2f4b-49fa-b7f6-11c39e513328), object, pointer_default(unique)] +interface ICoreWebView2IsDocumentPlayingAudioChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} +/// Receives `IsMutedChanged` events. +[uuid(57d90347-cd0e-4952-a4a2-7483a2756f08), object, pointer_default(unique)] +interface ICoreWebView2IsMutedChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} + +/// Receives `IsDefaultDownloadDialogOpenChanged` events. +[uuid(3117da26-ae13-438d-bd46-edbeb2c4ce81), object, pointer_default(unique)] +interface ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} + +/// Receives `ContextMenuRequested` events. +[uuid(04d3fe1d-ab87-42fb-a898-da241d35b63c), object, pointer_default(unique)] +interface ICoreWebView2ContextMenuRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ContextMenuRequestedEventArgs* args); +} + +/// Receives `StatusBarTextChanged` events. +[uuid(a5e3b0d0-10df-4156-bfad-3b43867acac6), object, pointer_default(unique)] +interface ICoreWebView2StatusBarTextChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} + +/// Receives the result of the `GetFavicon` method. +[uuid(a2508329-7da8-49d7-8c05-fa125e4aee8d), object, pointer_default(unique)] +interface ICoreWebView2GetFaviconCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] IStream* result); +} + +/// Receives `FaviconChanged` events. +[uuid(2913da94-833d-4de0-8dca-900fc524a1a4), object, pointer_default(unique)] +interface ICoreWebView2FaviconChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] IUnknown* args); +} + +/// Receives the result of the `Print` method. +[uuid(8fd80075-ed08-42db-8570-f5d14977461e), object, pointer_default(unique)] +interface ICoreWebView2PrintCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] COREWEBVIEW2_PRINT_STATUS result); +} +/// Receives the result of the `PrintToPdfStream` method. +[uuid(4c9f8229-8f93-444f-a711-2c0dfd6359d5), object, pointer_default(unique)] +interface ICoreWebView2PrintToPdfStreamCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] IStream* result); +} + +/// Receives `CursorChanged` events. +[uuid(9da43ccc-26e1-4dad-b56c-d8961c94c571), object, pointer_default(unique)] +interface ICoreWebView2CursorChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2CompositionController* sender, + [in] IUnknown* args); +} + +/// Receives `NonClientRegionChanged` events. +[uuid(4a794e66-aa6c-46bd-93a3-382196837680), object, pointer_default(unique)] +interface ICoreWebView2NonClientRegionChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2CompositionController* sender, + [in] ICoreWebView2NonClientRegionChangedEventArgs* args); +} + +/// A collection of RECT. +[uuid(333353b8-48bf-4449-8fcc-22697faf5753), object, pointer_default(unique)] +interface ICoreWebView2RegionRectCollectionView : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] RECT* value); +} + +/// Receives `AcceleratorKeyPressed` events. +[uuid(b29c7e28-fa79-41a8-8e44-65811c76dcb2), object, pointer_default(unique)] +interface ICoreWebView2AcceleratorKeyPressedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Controller* sender, + [in] ICoreWebView2AcceleratorKeyPressedEventArgs* args); +} +/// Receives `GotFocus` events. +[uuid(05ea24bd-6452-4926-9014-4b82b498135d), object, pointer_default(unique)] +interface ICoreWebView2FocusChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Controller* sender, + [in] IUnknown* args); +} +// Skipping ICoreWebView2FocusChangedEventHandler redefinition + +/// Receives `MoveFocusRequested` events. +[uuid(69035451-6dc7-4cb8-9bce-b2bd70ad289f), object, pointer_default(unique)] +interface ICoreWebView2MoveFocusRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Controller* sender, + [in] ICoreWebView2MoveFocusRequestedEventArgs* args); +} +/// Receives `ZoomFactorChanged` events. +[uuid(b52d71d6-c4df-4543-a90c-64a3e60f38cb), object, pointer_default(unique)] +interface ICoreWebView2ZoomFactorChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Controller* sender, + [in] IUnknown* args); +} + +/// Receives `RasterizationScaleChanged` events. +[uuid(9c98c8b1-ac53-427e-a345-3049b5524bbe), object, pointer_default(unique)] +interface ICoreWebView2RasterizationScaleChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Controller* sender, + [in] IUnknown* args); +} + +/// Receives the result of the `CreateCoreWebView2Controller` method. +[uuid(6c4819f3-c9b7-4260-8127-c9f5bde7f68c), object, pointer_default(unique)] +interface ICoreWebView2CreateCoreWebView2ControllerCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2Controller* result); +} + +/// Receives `NewBrowserVersionAvailable` events. +[uuid(f9a2976e-d34e-44fc-adee-81b6b57ca914), object, pointer_default(unique)] +interface ICoreWebView2NewBrowserVersionAvailableEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Environment* sender, + [in] IUnknown* args); +} + +/// Receives the result of the `Remove` method. +[uuid(8e41909a-9b18-4bb1-8cdf-930f467a50be), object, pointer_default(unique)] +interface ICoreWebView2BrowserExtensionRemoveCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} +/// Receives the result of the `Enable` method. +[uuid(30c186ce-7fad-421f-a3bc-a8eaf071ddb8), object, pointer_default(unique)] +interface ICoreWebView2BrowserExtensionEnableCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} + +/// A collection of LPCWSTR. +[uuid(f41f3f8a-bcc3-11eb-8529-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2StringCollection : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] LPWSTR* value); +} + +/// A collection of ICoreWebView2ClientCertificate. +[uuid(ef5674d2-bcc3-11eb-8529-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2ClientCertificateCollection : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] ICoreWebView2ClientCertificate** value); +} + +/// Receives `CustomItemSelected` events. +[uuid(49e1d0bc-fe9e-4481-b7c2-32324aa21998), object, pointer_default(unique)] +interface ICoreWebView2CustomItemSelectedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2ContextMenuItem* sender, + [in] IUnknown* args); +} + +/// Receives the result of the `GetCookies` method. +[uuid(5a4f5069-5c15-47c3-8646-f4de1c116670), object, pointer_default(unique)] +interface ICoreWebView2GetCookiesCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2CookieList* result); +} + +/// A collection of ICoreWebView2Cookie. +[uuid(f7f6f714-5d2a-43c6-9503-346ece02d186), object, pointer_default(unique)] +interface ICoreWebView2CookieList : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] ICoreWebView2Cookie** value); +} + +/// Receives `BytesReceivedChanged` events. +[uuid(828e8ab6-d94c-4264-9cef-5217170d6251), object, pointer_default(unique)] +interface ICoreWebView2BytesReceivedChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2DownloadOperation* sender, + [in] IUnknown* args); +} +/// Receives `EstimatedEndTimeChanged` events. +[uuid(28f0d425-93fe-4e63-9f8d-2aeec6d3ba1e), object, pointer_default(unique)] +interface ICoreWebView2EstimatedEndTimeChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2DownloadOperation* sender, + [in] IUnknown* args); +} +/// Receives `StateChanged` events. +[uuid(81336594-7ede-4ba9-bf71-acf0a95b58dd), object, pointer_default(unique)] +interface ICoreWebView2StateChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2DownloadOperation* sender, + [in] IUnknown* args); +} + +/// Receives `Destroyed` events. +[uuid(59dd7b4c-9baa-11eb-a8b3-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2FrameDestroyedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] IUnknown* args); +} +/// Receives `NameChanged` events. +[uuid(435c7dc8-9baa-11eb-a8b3-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2FrameNameChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] IUnknown* args); +} + +/// Receives `ContentLoading` events. +[uuid(0d6156f2-d332-49a7-9e03-7d8f2feeee54), object, pointer_default(unique)] +interface ICoreWebView2FrameContentLoadingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2ContentLoadingEventArgs* args); +} +/// Receives `DOMContentLoaded` events. +[uuid(38d9520d-340f-4d1e-a775-43fce9753683), object, pointer_default(unique)] +interface ICoreWebView2FrameDOMContentLoadedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2DOMContentLoadedEventArgs* args); +} +/// Receives `NavigationCompleted` events. +[uuid(609302ad-0e36-4f9a-a210-6a45272842a9), object, pointer_default(unique)] +interface ICoreWebView2FrameNavigationCompletedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2NavigationCompletedEventArgs* args); +} +/// Receives `NavigationStarting` events. +[uuid(e79908bf-2d5d-4968-83db-263fea2c1da3), object, pointer_default(unique)] +interface ICoreWebView2FrameNavigationStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2NavigationStartingEventArgs* args); +} +/// Receives `WebMessageReceived` events. +[uuid(e371e005-6d1d-4517-934b-a8f1629c62a5), object, pointer_default(unique)] +interface ICoreWebView2FrameWebMessageReceivedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2WebMessageReceivedEventArgs* args); +} + +/// Receives `Deleted` events. +[uuid(df35055d-772e-4dbe-b743-5fbf74a2b258), object, pointer_default(unique)] +interface ICoreWebView2ProfileDeletedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Profile* sender, + [in] IUnknown* args); +} + +/// Receives the result of the `GetContent` method. +[uuid(875738e1-9fa2-40e3-8b74-2e8972dd6fe7), object, pointer_default(unique)] +interface ICoreWebView2WebResourceResponseViewGetContentCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] IStream* result); +} + +/// Receives `CloseRequested` events. +[uuid(47c32d23-1e94-4733-85f1-d9bf4acd0974), object, pointer_default(unique)] +interface ICoreWebView2NotificationCloseRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Notification* sender, + [in] IUnknown* args); +} + +/// WebView2 enables you to host web content using the latest Microsoft Edge +/// browser and web technology. + +[uuid(76eceacb-0462-4d94-ac83-423a6793775e), object, pointer_default(unique)] +interface ICoreWebView2 : IUnknown { + + /// The `ICoreWebView2Settings` object contains various modifiable settings + /// for the running WebView. + + [propget] HRESULT Settings([out, retval] ICoreWebView2Settings** settings); + + /// The URI of the current top level document. This value potentially + /// changes as a part of the `SourceChanged` event that runs for some cases + /// such as navigating to a different site or fragment navigations. It + /// remains the same for other types of navigations such as page refreshes + /// or `history.pushState` with the same URL as the current page. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + /// + /// \snippet ControlComponent.cpp SourceChanged + [propget] HRESULT Source([out, retval] LPWSTR* uri); + + /// Cause a navigation of the top-level document to run to the specified URI. + /// For more information, navigate to [Navigation + /// events](/microsoft-edge/webview2/concepts/navigation-events). + /// + /// \> [!NOTE]\n\> This operation starts a navigation and the corresponding + /// `NavigationStarting` event triggers sometime after `Navigate` runs. + /// + /// \snippet ControlComponent.cpp Navigate + HRESULT Navigate([in] LPCWSTR uri); + + /// Initiates a navigation to htmlContent as source HTML of a new document. + /// The `htmlContent` parameter may not be larger than 2 MB (2 * 1024 * 1024 bytes) in total size. + /// The origin of the new page is `about:blank`. + /// + /// ```cpp + /// SetVirtualHostNameToFolderMapping( + /// L"appassets.example", L"assets", + /// COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY); + /// + /// WCHAR c_navString[] = LR" + /// + /// + /// + ///

Click me

+ /// "; + /// m_webView->NavigateToString(c_navString); + /// ``` + /// \snippet SettingsComponent.cpp NavigateToString + HRESULT NavigateToString([in] LPCWSTR htmlContent); + + /// Add an event handler for the `NavigationStarting` event. + /// `NavigationStarting` runs when the WebView main frame is requesting + /// permission to navigate to a different URI. Redirects trigger this + /// operation as well, and the navigation id is the same as the original + /// one. + /// + /// Navigations will be blocked until all `NavigationStarting` event handlers + /// return. + /// + /// \snippet SettingsComponent.cpp NavigationStarting + HRESULT add_NavigationStarting( + [in] ICoreWebView2NavigationStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_NavigationStarting`. + HRESULT remove_NavigationStarting( + [in] EventRegistrationToken token); + + /// Add an event handler for the `ContentLoading` event. `ContentLoading` + /// triggers before any content is loaded, including scripts added with + /// `AddScriptToExecuteOnDocumentCreated`. `ContentLoading` does not trigger + /// if a same page navigation occurs (such as through `fragment` + /// navigations or `history.pushState` navigations). This operation + /// follows the `NavigationStarting` and `SourceChanged` events and precedes + /// the `HistoryChanged` and `NavigationCompleted` events. + HRESULT add_ContentLoading( + [in] ICoreWebView2ContentLoadingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_ContentLoading`. + HRESULT remove_ContentLoading( + [in] EventRegistrationToken token); + + /// Add an event handler for the `SourceChanged` event. `SourceChanged` + /// triggers when the `Source` property changes. `SourceChanged` runs when + /// navigating to a different site or fragment navigations. It does not + /// trigger for other types of navigations such as page refreshes or + /// `history.pushState` with the same URL as the current page. + /// `SourceChanged` runs before `ContentLoading` for navigation to a new + /// document. + /// + /// \snippet ControlComponent.cpp SourceChanged + HRESULT add_SourceChanged( + [in] ICoreWebView2SourceChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_SourceChanged`. + HRESULT remove_SourceChanged( + [in] EventRegistrationToken token); + + /// Add an event handler for the `HistoryChanged` event. `HistoryChanged` is + /// raised for changes to joint session history, which consists of top-level + /// and manual frame navigations. Use `HistoryChanged` to verify that the + /// `CanGoBack` or `CanGoForward` value has changed. `HistoryChanged` also + /// runs for using `GoBack` or `GoForward`. `HistoryChanged` runs after + /// `SourceChanged` and `ContentLoading`. `CanGoBack` is false for + /// navigations initiated through ICoreWebView2Frame APIs if there has not yet + /// been a user gesture. + /// + /// \snippet ControlComponent.cpp HistoryChanged + HRESULT add_HistoryChanged( + [in] ICoreWebView2HistoryChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_HistoryChanged`. + HRESULT remove_HistoryChanged( + [in] EventRegistrationToken token); + + /// Add an event handler for the `NavigationCompleted` event. + /// `NavigationCompleted` runs when the WebView has completely loaded + /// (concurrently when `body.onload` runs) or loading stopped with error. + /// + /// \snippet ControlComponent.cpp NavigationCompleted + HRESULT add_NavigationCompleted( + [in] ICoreWebView2NavigationCompletedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_NavigationCompleted`. + HRESULT remove_NavigationCompleted( + [in] EventRegistrationToken token); + + /// Add an event handler for the `FrameNavigationStarting` event. + /// `FrameNavigationStarting` triggers when a child frame in the WebView + /// requests permission to navigate to a different URI. Redirects trigger + /// this operation as well, and the navigation id is the same as the original + /// one. + /// + /// Navigations will be blocked until all `FrameNavigationStarting` event + /// handlers return. + /// + /// \snippet SettingsComponent.cpp FrameNavigationStarting + HRESULT add_FrameNavigationStarting( + [in] ICoreWebView2NavigationStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with + /// `add_FrameNavigationStarting`. + HRESULT remove_FrameNavigationStarting( + [in] EventRegistrationToken token); + + /// Add an event handler for the `FrameNavigationCompleted` event. + /// `FrameNavigationCompleted` triggers when a child frame has completely + /// loaded (concurrently when `body.onload` has triggered) or loading stopped with error. + /// + /// \snippet ControlComponent.cpp FrameNavigationCompleted + HRESULT add_FrameNavigationCompleted( + [in] ICoreWebView2NavigationCompletedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with + /// `add_FrameNavigationCompleted`. + HRESULT remove_FrameNavigationCompleted( + [in] EventRegistrationToken token); + + /// Add an event handler for the `ScriptDialogOpening` event. + /// `ScriptDialogOpening` runs when a JavaScript dialog (`alert`, `confirm`, + /// `prompt`, or `beforeunload`) displays for the webview. This event only + /// triggers if the `ICoreWebView2Settings::AreDefaultScriptDialogsEnabled` + /// property is set to `FALSE`. The `ScriptDialogOpening` event suppresses + /// dialogs or replaces default dialogs with custom dialogs. + /// + /// If a deferral is not taken on the event args, the subsequent scripts are + /// blocked until the event handler returns. If a deferral is taken, the + /// scripts are blocked until the deferral is completed. + /// + /// \snippet SettingsComponent.cpp ScriptDialogOpening + HRESULT add_ScriptDialogOpening( + [in] ICoreWebView2ScriptDialogOpeningEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_ScriptDialogOpening`. + HRESULT remove_ScriptDialogOpening( + [in] EventRegistrationToken token); + + /// Add an event handler for the `PermissionRequested` event. + /// `PermissionRequested` runs when content in a WebView requests permission + /// to access some privileged resources. + /// + /// If a deferral is not taken on the event args, the subsequent scripts are + /// blocked until the event handler returns. If a deferral is taken, the + /// scripts are blocked until the deferral is completed. + /// + /// \snippet SettingsComponent.cpp PermissionRequested0 + /// \snippet SettingsComponent.cpp PermissionRequested1 + HRESULT add_PermissionRequested( + [in] ICoreWebView2PermissionRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_PermissionRequested`. + HRESULT remove_PermissionRequested( + [in] EventRegistrationToken token); + + /// Add an event handler for the `ProcessFailed` event. + /// `ProcessFailed` runs when any of the processes in the + /// [WebView2 Process Group](/microsoft-edge/webview2/concepts/process-model?tabs=csharp#processes-in-the-webview2-runtime) + /// encounters one of the following conditions: + /// + /// Condition | Details + /// ---|--- + /// Unexpected exit | The process indicated by the event args has exited unexpectedly (usually due to a crash). The failure might or might not be recoverable and some failures are auto-recoverable. + /// Unresponsiveness | The process indicated by the event args has become unresponsive to user input. This is only reported for renderer processes, and will run every few seconds until the process becomes responsive again. + /// + /// \> [!NOTE]\n\> When the failing process is the browser process, a + /// `ICoreWebView2Environment5::BrowserProcessExited` event will run too. + /// + /// Your application can use `ICoreWebView2ProcessFailedEventArgs` and + /// `ICoreWebView2ProcessFailedEventArgs2` to identify which condition and + /// process the event is for, and to collect diagnostics and handle recovery + /// if necessary. For more details about which cases need to be handled by + /// your application, see `COREWEBVIEW2_PROCESS_FAILED_KIND`. + /// + /// \snippet ProcessComponent.cpp ProcessFailed + HRESULT add_ProcessFailed( + [in] ICoreWebView2ProcessFailedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_ProcessFailed`. + HRESULT remove_ProcessFailed( + [in] EventRegistrationToken token); + + /// Add the provided JavaScript to a list of scripts that should be run after + /// the global object has been created, but before the HTML document has + /// been parsed and before any other script included by the HTML document is + /// run. This method injects a script that runs on all top-level document + /// and child frame page navigations. This method runs asynchronously, and + /// you must wait for the completion handler to finish before the injected + /// script is ready to run. When this method completes, the `Invoke` method + /// of the handler is run with the `id` of the injected script. `id` is a + /// string. To remove the injected script, use + /// `RemoveScriptToExecuteOnDocumentCreated`. + /// + /// If the method is run in add_NewWindowRequested handler it should be called + /// before the new window is set. If called after setting the NewWindow property, the initial script + /// may or may not apply to the initial navigation and may only apply to the subsequent navigation. + /// For more details see `ICoreWebView2NewWindowRequestedEventArgs::put_NewWindow`. + /// + /// \> [!NOTE]\n\> If an HTML document is running in a sandbox of some kind using + /// [sandbox](https://developer.mozilla.org/docs/Web/HTML/Element/iframe#attr-sandbox) + /// properties or the + /// [Content-Security-Policy](https://developer.mozilla.org/docs/Web/HTTP/Headers/Content-Security-Policy) + /// HTTP header affects the script that runs. For example, if the + /// `allow-modals` keyword is not set then requests to run the `alert` + /// function are ignored. + /// + /// \snippet ScriptComponent.cpp AddScriptToExecuteOnDocumentCreated + HRESULT AddScriptToExecuteOnDocumentCreated( + [in] LPCWSTR javaScript, + [in] ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler* handler); + + /// Remove the corresponding JavaScript added using + /// `AddScriptToExecuteOnDocumentCreated` with the specified script ID. The + /// script ID should be the one returned by the `AddScriptToExecuteOnDocumentCreated`. + /// Both use `AddScriptToExecuteOnDocumentCreated` and this method in `NewWindowRequested` + /// event handler at the same time sometimes causes trouble. Since invalid scripts will + /// be ignored, the script IDs you got may not be valid anymore. + HRESULT RemoveScriptToExecuteOnDocumentCreated([in] LPCWSTR id); + + /// Run JavaScript code from the javascript parameter in the current + /// top-level document rendered in the WebView. The result of evaluating + /// the provided JavaScript is used in this parameter. The result value is + /// a JSON encoded string. If the result is undefined, contains a reference + /// cycle, or otherwise is not able to be encoded into JSON, then the result + /// is considered to be null, which is encoded in JSON as the string "null". + /// + /// \> [!NOTE]\n\> A function that has no explicit return value returns undefined. If the + /// script that was run throws an unhandled exception, then the result is + /// also "null". This method is applied asynchronously. If the method is + /// run after the `NavigationStarting` event during a navigation, the script + /// runs in the new document when loading it, around the time + /// `ContentLoading` is run. This operation executes the script even if + /// `ICoreWebView2Settings::IsScriptEnabled` is set to `FALSE`. + /// + /// \snippet ScriptComponent.cpp ExecuteScript + HRESULT ExecuteScript( + [in] LPCWSTR javaScript, + [in] ICoreWebView2ExecuteScriptCompletedHandler* handler); + + /// Capture an image of what WebView is displaying. Specify the format of + /// the image with the `imageFormat` parameter. The resulting image binary + /// data is written to the provided `imageStream` parameter. When + /// `CapturePreview` finishes writing to the stream, the `Invoke` method on + /// the provided `handler` parameter is run. This method fails if called + /// before the first ContentLoading event. For example if this is called in + /// the NavigationStarting event for the first navigation it will fail. + /// For subsequent navigations, the method may not fail, but will not capture + /// an image of a given webpage until the ContentLoading event has been fired + /// for it. Any call to this method prior to that will result in a capture of + /// the page being navigated away from. + /// + /// \snippet FileComponent.cpp CapturePreview + HRESULT CapturePreview( + [in] COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT imageFormat, + [in] IStream* imageStream, + [in] ICoreWebView2CapturePreviewCompletedHandler* handler); + + /// Reload the current page. This is similar to navigating to the URI of + /// current top level document including all navigation events firing and + /// respecting any entries in the HTTP cache. But, the back or forward + /// history are not modified. + HRESULT Reload(); + + /// Post the specified webMessage to the top level document in this WebView. + /// The main page receives the message by subscribing to the `message` event of the + /// `window.chrome.webview` of the page document. + /// + /// ```cpp + /// window.chrome.webview.addEventListener('message', handler) + /// window.chrome.webview.removeEventListener('message', handler) + /// ``` + /// + /// The event args is an instance of `MessageEvent`. The + /// `ICoreWebView2Settings::IsWebMessageEnabled` setting must be `TRUE` or + /// the web message will not be sent. The `data` property of the event + /// arg is the `webMessage` string parameter parsed as a JSON string into a + /// JavaScript object. The `source` property of the event arg is a reference + /// to the `window.chrome.webview` object. For information about sending + /// messages from the HTML document in the WebView to the host, navigate to + /// [add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2#add_webmessagereceived). + /// The message is delivered asynchronously. If a navigation occurs before + /// the message is posted to the page, the message is discarded. + /// + /// \snippet ScenarioWebMessage.cpp WebMessageReceived + HRESULT PostWebMessageAsJson([in] LPCWSTR webMessageAsJson); + + /// Posts a message that is a simple string rather than a JSON string + /// representation of a JavaScript object. This behaves in exactly the same + /// manner as `PostWebMessageAsJson`, but the `data` property of the event + /// arg of the `window.chrome.webview` message is a string with the same + /// value as `webMessageAsString`. Use this instead of + /// `PostWebMessageAsJson` if you want to communicate using simple strings + /// rather than JSON objects. + HRESULT PostWebMessageAsString([in] LPCWSTR webMessageAsString); + + /// Add an event handler for the `WebMessageReceived` event. + /// `WebMessageReceived` runs when the + /// `ICoreWebView2Settings::IsWebMessageEnabled` setting is set and the + /// top-level document of the WebView runs + /// `window.chrome.webview.postMessage`. The `postMessage` function is + /// `void postMessage(object)` where object is any object supported by JSON + /// conversion. + /// + /// \snippet assets\ScenarioWebMessage.html chromeWebView + /// + /// When the page calls `postMessage`, the object parameter is converted to a + /// JSON string and is posted asynchronously to the host process. This will + /// result in the handler's `Invoke` method being called with the JSON string + /// as a parameter. + /// + /// \snippet ScenarioWebMessage.cpp WebMessageReceived + /// + /// If the same page calls `postMessage` multiple times, the corresponding + /// `WebMessageReceived` events are guaranteed to be fired in the same order. + /// However, if multiple frames call `postMessage`, there is no guaranteed + /// order. In addition, `WebMessageReceived` events caused by calls to + /// `postMessage` are not guaranteed to be sequenced with events caused by DOM + /// APIs. For example, if the page runs + /// + /// ```javascript + /// chrome.webview.postMessage("message"); + /// window.open(); + /// ``` + /// + /// then the `NewWindowRequested` event might be fired before the + /// `WebMessageReceived` event. If you need the `WebMessageReceived` event + /// to happen before anything else, then in the `WebMessageReceived` handler + /// you can post a message back to the page and have the page wait until it + /// receives that message before continuing. + HRESULT add_WebMessageReceived( + [in] ICoreWebView2WebMessageReceivedEventHandler* handler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_WebMessageReceived`. + HRESULT remove_WebMessageReceived( + [in] EventRegistrationToken token); + + /// Runs an asynchronous `DevToolsProtocol` method. For more information + /// about available methods, navigate to + /// [DevTools Protocol Viewer](https://chromedevtools.github.io/devtools-protocol/tot) + /// . The `methodName` parameter is the full name of the method in the + /// `{domain}.{method}` format. The `parametersAsJson` parameter is a JSON + /// formatted string containing the parameters for the corresponding method. + /// The `Invoke` method of the `handler` is run when the method + /// asynchronously completes. `Invoke` is run with the return object of the + /// method as a JSON string. This function returns E_INVALIDARG if the `methodName` is + /// unknown or the `parametersAsJson` has an error. In the case of such an error, the + /// `returnObjectAsJson` parameter of the handler will include information + /// about the error. + /// Note even though WebView2 dispatches the CDP messages in the order called, + /// CDP method calls may be processed out of order. + /// If you require CDP methods to run in a particular order, you should wait + /// for the previous method's completed handler to run before calling the + /// next method. + + /// If the method is to run in add_NewWindowRequested handler it should be called + /// before the new window is set if the cdp message should affect the initial navigation. If + /// called after setting the NewWindow property, the cdp messages + /// may or may not apply to the initial navigation and may only apply to the subsequent navigation. + /// For more details see `ICoreWebView2NewWindowRequestedEventArgs::put_NewWindow`. + /// + /// \snippet ScriptComponent.cpp CallDevToolsProtocolMethod + HRESULT CallDevToolsProtocolMethod( + [in] LPCWSTR methodName, + [in] LPCWSTR parametersAsJson, + [in] ICoreWebView2CallDevToolsProtocolMethodCompletedHandler* handler); + + /// The process ID of the browser process that hosts the WebView. + [propget] HRESULT BrowserProcessId([out, retval] UINT32* value); + + /// `TRUE` if the WebView is able to navigate to a previous page in the + /// navigation history. If `CanGoBack` changes value, the `HistoryChanged` + /// event runs. + [propget] HRESULT CanGoBack([out, retval] BOOL* canGoBack); + + /// `TRUE` if the WebView is able to navigate to a next page in the + /// navigation history. If `CanGoForward` changes value, the + /// `HistoryChanged` event runs. + [propget] HRESULT CanGoForward([out, retval] BOOL* canGoForward); + + /// Navigates the WebView to the previous page in the navigation history. + HRESULT GoBack(); + + /// Navigates the WebView to the next page in the navigation history. + HRESULT GoForward(); + + /// Get a DevTools Protocol event receiver that allows you to subscribe to a + /// DevTools Protocol event. The `eventName` parameter is the full name of + /// the event in the format `{domain}.{event}`. For more information about + /// DevTools Protocol events description and event args, navigate to + /// [DevTools Protocol Viewer](https://chromedevtools.github.io/devtools-protocol/tot). + /// + /// \snippet ScriptComponent.cpp DevToolsProtocolEventReceived + HRESULT GetDevToolsProtocolEventReceiver( + [in] LPCWSTR eventName, + [out, retval] ICoreWebView2DevToolsProtocolEventReceiver** receiver); + + /// Stop all navigations and pending resource fetches. Does not stop scripts. + HRESULT Stop(); + + /// Add an event handler for the `NewWindowRequested` event. + /// `NewWindowRequested` runs when content inside the WebView requests to + /// open a new window, such as through `window.open`. The app can pass a + /// target WebView that is considered the opened window or mark the event as + /// `Handled`, in which case WebView2 does not open a window. + /// If either `Handled` or `NewWindow` properties are not set, the target + /// content will be opened on a popup window. + /// + /// If a deferral is not taken on the event args, scripts that resulted in the + /// new window that are requested are blocked until the event handler returns. + /// If a deferral is taken, then scripts are blocked until the deferral is + /// completed or new window is set. + /// + /// For more details and considerations on the target WebView to be supplied + /// at the opened window, see `ICoreWebView2NewWindowRequestedEventArgs::put_NewWindow`. + /// + /// \snippet AppWindow.cpp NewWindowRequested + HRESULT add_NewWindowRequested( + [in] ICoreWebView2NewWindowRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_NewWindowRequested`. + HRESULT remove_NewWindowRequested( + [in] EventRegistrationToken token); + + /// Add an event handler for the `DocumentTitleChanged` event. + /// `DocumentTitleChanged` runs when the `DocumentTitle` property of the + /// WebView changes and may run before or after the `NavigationCompleted` + /// event. + /// + /// \snippet FileComponent.cpp DocumentTitleChanged + HRESULT add_DocumentTitleChanged( + [in] ICoreWebView2DocumentTitleChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_DocumentTitleChanged`. + HRESULT remove_DocumentTitleChanged( + [in] EventRegistrationToken token); + + /// The title for the current top-level document. If the document has no + /// explicit title or is otherwise empty, a default that may or may not match + /// the URI of the document is used. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT DocumentTitle([out, retval] LPWSTR* title); + + /// Add the provided host object to script running in the WebView with the + /// specified name. Host objects are exposed as host object proxies using + /// `window.chrome.webview.hostObjects.{name}`. Host object proxies are + /// promises and resolves to an object representing the host object. The + /// promise is rejected if the app has not added an object with the name. + /// When JavaScript code access a property or method of the object, a promise + /// is return, which resolves to the value returned from the host for the + /// property or method, or rejected in case of error, for example, no + /// property or method on the object or parameters are not valid. + /// + /// \> [!NOTE]\n\> While simple types, `IDispatch` and array are supported, and + /// `IUnknown` objects that also implement `IDispatch` are treated as `IDispatch`, + /// generic `IUnknown`, `VT_DECIMAL`, or `VT_RECORD` variant is not supported. + /// Remote JavaScript objects like callback functions are represented as an + /// `VT_DISPATCH` `VARIANT` with the object implementing `IDispatch`. The + /// JavaScript callback method may be invoked using `DISPID_VALUE` for the + /// `DISPID`. Such callback method invocations will return immediately and will + /// not wait for the JavaScript function to run and so will not provide the return + /// value of the JavaScript function. + /// Nested arrays are supported up to a depth of 3. Arrays of by + /// reference types are not supported. `VT_EMPTY` and `VT_NULL` are mapped + /// into JavaScript as `null`. In JavaScript, `null` and undefined are + /// mapped to `VT_EMPTY`. + /// + /// Additionally, all host objects are exposed as + /// `window.chrome.webview.hostObjects.sync.{name}`. Here the host objects + /// are exposed as synchronous host object proxies. These are not promises + /// and function runtimes or property access synchronously block running + /// script waiting to communicate cross process for the host code to run. + /// Accordingly the result may have reliability issues and it is recommended + /// that you use the promise-based asynchronous + /// `window.chrome.webview.hostObjects.{name}` API. + /// + /// Synchronous host object proxies and asynchronous host object proxies may + /// both use a proxy to the same host object. Remote changes made by one + /// proxy propagates to any other proxy of that same host object whether + /// the other proxies and synchronous or asynchronous. + /// + /// While JavaScript is blocked on a synchronous run to native code, that + /// native code is unable to run back to JavaScript. Attempts to do so fail + /// with `HRESULT_FROM_WIN32(ERROR_POSSIBLE_DEADLOCK)`. + /// + /// Host object proxies are JavaScript Proxy objects that intercept all + /// property get, property set, and method invocations. Properties or methods + /// that are a part of the Function or Object prototype are run locally. + /// Additionally any property or method in the + /// `chrome.webview.hostObjects.options.forceLocalProperties` + /// array are also run locally. This defaults to including optional methods + /// that have meaning in JavaScript like `toJSON` and `Symbol.toPrimitive`. + /// Add more to the array as required. + /// + /// The `chrome.webview.hostObjects.cleanupSome` method performs a best + /// effort garbage collection on host object proxies. + /// + /// The `chrome.webview.hostObjects.options` object provides the ability to + /// change some functionality of host objects. + /// + /// Options property | Details + /// ---|--- + /// `forceLocalProperties` | This is an array of host object property names that will be run locally, instead of being called on the native host object. This defaults to `then`, `toJSON`, `Symbol.toString`, and `Symbol.toPrimitive`. You can add other properties to specify that they should be run locally on the javascript host object proxy. + /// `log` | This is a callback that will be called with debug information. For example, you can set this to `console.log.bind(console)` to have it print debug information to the console to help when troubleshooting host object usage. By default this is null. + /// `shouldSerializeDates` | By default this is false, and javascript Date objects will be sent to host objects as a string using `JSON.stringify`. You can set this property to true to have Date objects properly serialize as a `VT_DATE` when sending to the native host object, and have `VT_DATE` properties and return values create a javascript Date object. + /// `defaultSyncProxy` | When calling a method on a synchronous proxy, the result should also be a synchronous proxy. But in some cases, the sync/async context is lost (for example, when providing to native code a reference to a function, and then calling that function in native code). In these cases, the proxy will be asynchronous, unless this property is set. + /// `forceAsyncMethodMatches ` | This is an array of regular expressions. When calling a method on a synchronous proxy, the method call will be performed asynchronously if the method name matches a string or regular expression in this array. Setting this value to `Async` will make any method that ends with Async be an asynchronous method call. If an async method doesn't match here and isn't forced to be asynchronous, the method will be invoked synchronously, blocking execution of the calling JavaScript and then returning the resolution of the promise, rather than returning a promise. + /// `ignoreMemberNotFoundError` | By default, an exception is thrown when attempting to get the value of a proxy property that doesn't exist on the corresponding native class. Setting this property to `true` switches the behavior to match Chakra WinRT projection (and general JavaScript) behavior of returning `undefined` with no error. + /// `shouldPassTypedArraysAsArrays` | By default, typed arrays are passed to the host as `IDispatch`. To instead pass typed arrays to the host as `array`, set this to `true`. + /// + /// Host object proxies additionally have the following methods which run + /// locally. + /// + /// Method name | Details + /// ---|--- + ///`applyHostFunction`, `getHostProperty`, `setHostProperty` | Perform a method invocation, property get, or property set on the host object. Use the methods to explicitly force a method or property to run remotely if a conflicting local method or property exists. For instance, `proxy.toString()` runs the local `toString` method on the proxy object. But proxy.applyHostFunction('toString') runs `toString` on the host proxied object instead. + ///`getLocalProperty`, `setLocalProperty` | Perform property get, or property set locally. Use the methods to force getting or setting a property on the host object proxy rather than on the host object it represents. For instance, `proxy.unknownProperty` gets the property named `unknownProperty` from the host proxied object. But proxy.getLocalProperty('unknownProperty') gets the value of the property `unknownProperty` on the proxy object. + ///`sync` | Asynchronous host object proxies expose a sync method which returns a promise for a synchronous host object proxy for the same host object. For example, `chrome.webview.hostObjects.sample.methodCall()` returns an asynchronous host object proxy. Use the `sync` method to obtain a synchronous host object proxy instead: `const syncProxy = await chrome.webview.hostObjects.sample.methodCall().sync()`. + ///`async` | Synchronous host object proxies expose an async method which blocks and returns an asynchronous host object proxy for the same host object. For example, `chrome.webview.hostObjects.sync.sample.methodCall()` returns a synchronous host object proxy. Running the `async` method on this blocks and then returns an asynchronous host object proxy for the same host object: `const asyncProxy = chrome.webview.hostObjects.sync.sample.methodCall().async()`. + ///`then` | Asynchronous host object proxies have a `then` method. Allows proxies to be awaitable. `then` returns a promise that resolves with a representation of the host object. If the proxy represents a JavaScript literal, a copy of that is returned locally. If the proxy represents a function, a non-awaitable proxy is returned. If the proxy represents a JavaScript object with a mix of literal properties and function properties, the a copy of the object is returned with some properties as host object proxies. + /// + /// All other property and method invocations (other than the above Remote + /// object proxy methods, `forceLocalProperties` list, and properties on + /// Function and Object prototypes) are run remotely. Asynchronous host + /// object proxies return a promise representing asynchronous completion of + /// remotely invoking the method, or getting the property. The promise + /// resolves after the remote operations complete and the promises resolve to + /// the resulting value of the operation. Synchronous host object proxies + /// work similarly, but block running JavaScript and wait for the remote + /// operation to complete. + /// + /// Setting a property on an asynchronous host object proxy works slightly + /// differently. The set returns immediately and the return value is the + /// value that is set. This is a requirement of the JavaScript Proxy object. + /// If you need to asynchronously wait for the property set to complete, use + /// the `setHostProperty` method which returns a promise as described above. + /// Synchronous object property set property synchronously blocks until the + /// property is set. + /// + /// For example, suppose you have a COM object with the following interface. + /// + /// \snippet HostObjectSample.idl AddHostObjectInterface + /// + /// Add an instance of this interface into your JavaScript with + /// `AddHostObjectToScript`. In this case, name it `sample`. + /// + /// \snippet ScenarioAddHostObject.cpp AddHostObjectToScript + /// + /// In the HTML document, use the COM object using + /// `chrome.webview.hostObjects.sample`. + /// Note that `CoreWebView2.AddHostObjectToScript` only applies to the + /// top-level document and not to frames. To add host objects to frames use + /// `CoreWebView2Frame.AddHostObjectToScript`. + /// + /// \snippet assets\ScenarioAddHostObject.html HostObjectUsage + /// + /// Exposing host objects to script has security risk. For more information + /// about best practices, navigate to + /// [Best practices for developing secure WebView2 applications](/microsoft-edge/webview2/concepts/security). + HRESULT AddHostObjectToScript([in] LPCWSTR name, [in] VARIANT* object); + + /// Remove the host object specified by the name so that it is no longer + /// accessible from JavaScript code in the WebView. While new access + /// attempts are denied, if the object is already obtained by JavaScript code + /// in the WebView, the JavaScript code continues to have access to that + /// object. Run this method for a name that is already removed or never + /// added fails. + HRESULT RemoveHostObjectFromScript([in] LPCWSTR name); + + /// Opens the DevTools window for the current document in the WebView. Does + /// nothing if run when the DevTools window is already open. + HRESULT OpenDevToolsWindow(); + + /// Add an event handler for the `ContainsFullScreenElementChanged` event. + /// `ContainsFullScreenElementChanged` triggers when the + /// `ContainsFullScreenElement` property changes. An HTML element inside the + /// WebView may enter fullscreen to the size of the WebView or leave + /// fullscreen. This event is useful when, for example, a video element + /// requests to go fullscreen. The listener of + /// `ContainsFullScreenElementChanged` may resize the WebView in response. + /// + /// \snippet AppWindow.cpp ContainsFullScreenElementChanged + HRESULT add_ContainsFullScreenElementChanged( + [in] ICoreWebView2ContainsFullScreenElementChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with + /// `add_ContainsFullScreenElementChanged`. + HRESULT remove_ContainsFullScreenElementChanged( + [in] EventRegistrationToken token); + + /// Indicates if the WebView contains a fullscreen HTML element. + [propget] HRESULT ContainsFullScreenElement( + [out, retval] BOOL* containsFullScreenElement); + + /// Add an event handler for the `WebResourceRequested` event. + /// `WebResourceRequested` runs when the WebView is performing a URL request + /// to a matching URL and resource context and source kind filter that was + /// added with `AddWebResourceRequestedFilterWithRequestSourceKinds`. + /// At least one filter must be added for the event to run. + /// + /// The web resource requested may be blocked until the event handler returns + /// if a deferral is not taken on the event args. If a deferral is taken, + /// then the web resource requested is blocked until the deferral is + /// completed. + /// + /// If this event is subscribed in the add_NewWindowRequested handler it should be called + /// after the new window is set. For more details see `ICoreWebView2NewWindowRequestedEventArgs::put_NewWindow`. + /// + /// This event is by default raised for file, http, and https URI schemes. + /// This is also raised for registered custom URI schemes. For more details + /// see `ICoreWebView2CustomSchemeRegistration`. + /// + /// \snippet SettingsComponent.cpp WebResourceRequested0 + /// \snippet SettingsComponent.cpp WebResourceRequested1 + HRESULT add_WebResourceRequested( + [in] ICoreWebView2WebResourceRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_WebResourceRequested`. + HRESULT remove_WebResourceRequested( + [in] EventRegistrationToken token); + + /// Warning: This method is deprecated and does not behave as expected for + /// iframes. It will cause the WebResourceRequested event to fire only for the + /// main frame and its same-origin iframes. Please use + /// `AddWebResourceRequestedFilterWithRequestSourceKinds` + /// instead, which will let the event to fire for all iframes on the + /// document. + /// + /// Adds a URI and resource context filter for the `WebResourceRequested` + /// event. A web resource request with a resource context that matches this + /// filter's resource context and a URI that matches this filter's URI + /// wildcard string will be raised via the `WebResourceRequested` event. + /// + /// The `uri` parameter value is a wildcard string matched against the URI + /// of the web resource request. This is a glob style + /// wildcard string in which a `*` matches zero or more characters and a `?` + /// matches exactly one character. + /// These wildcard characters can be escaped using a backslash just before + /// the wildcard character in order to represent the literal `*` or `?`. + /// + /// The matching occurs over the URI as a whole string and not limiting + /// wildcard matches to particular parts of the URI. + /// The wildcard filter is compared to the URI after the URI has been + /// normalized, any URI fragment has been removed, and non-ASCII hostnames + /// have been converted to punycode. + /// + /// Specifying a `nullptr` for the uri is equivalent to an empty string which + /// matches no URIs. + /// + /// For more information about resource context filters, navigate to + /// [COREWEBVIEW2_WEB_RESOURCE_CONTEXT](/microsoft-edge/webview2/reference/win32/webview2-idl#corewebview2_web_resource_context). + /// + /// | URI Filter String | Request URI | Match | Notes | + /// | ---- | ---- | ---- | ---- | + /// | `*` | `https://contoso.com/a/b/c` | Yes | A single * will match all URIs | + /// | `*://contoso.com/*` | `https://contoso.com/a/b/c` | Yes | Matches everything in contoso.com across all schemes | + /// | `*://contoso.com/*` | `https://example.com/?https://contoso.com/` | Yes | But also matches a URI with just the same text anywhere in the URI | + /// | `example` | `https://contoso.com/example` | No | The filter does not perform partial matches | + /// | `*example` | `https://contoso.com/example` | Yes | The filter matches across URI parts | + /// | `*example` | `https://contoso.com/path/?example` | Yes | The filter matches across URI parts | + /// | `*example` | `https://contoso.com/path/?query#example` | No | The filter is matched against the URI with no fragment | + /// | `*example` | `https://example` | No | The URI is normalized before filter matching so the actual URI used for comparison is `https://example/` | + /// | `*example/` | `https://example` | Yes | Just like above, but this time the filter ends with a / just like the normalized URI | + /// | `https://xn--qei.example/` | `https://❤.example/` | Yes | Non-ASCII hostnames are normalized to punycode before wildcard comparison | + /// | `https://❤.example/` | `https://xn--qei.example/` | No | Non-ASCII hostnames are normalized to punycode before wildcard comparison | + HRESULT AddWebResourceRequestedFilter( + [in] LPCWSTR const uri, + [in] COREWEBVIEW2_WEB_RESOURCE_CONTEXT const resourceContext); + + /// Warning: This method and `AddWebResourceRequestedFilter` are deprecated. + /// Please use `AddWebResourceRequestedFilterWithRequestSourceKinds` and + /// `RemoveWebResourceRequestedFilterWithRequestSourceKinds` instead. + /// + /// Removes a matching WebResource filter that was previously added for the + /// `WebResourceRequested` event. If the same filter was added multiple + /// times, then it must be removed as many times as it was added for the + /// removal to be effective. Returns `E_INVALIDARG` for a filter that was + /// never added. + HRESULT RemoveWebResourceRequestedFilter( + [in] LPCWSTR const uri, + [in] COREWEBVIEW2_WEB_RESOURCE_CONTEXT const resourceContext); + + /// Add an event handler for the `WindowCloseRequested` event. + /// `WindowCloseRequested` triggers when content inside the WebView + /// requested to close the window, such as after `window.close` is run. The + /// app should close the WebView and related app window if that makes sense + /// to the app. After the first window.close() call, this event may not fire + /// for any immediate back to back window.close() calls. + /// + /// \snippet AppWindow.cpp WindowCloseRequested + HRESULT add_WindowCloseRequested( + [in] ICoreWebView2WindowCloseRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_WindowCloseRequested`. + HRESULT remove_WindowCloseRequested( + [in] EventRegistrationToken token); +} + +/// A continuation of the ICoreWebView2 interface. +[uuid(9E8F0CF8-E670-4B5E-B2BC-73E061E3184C), object, pointer_default(unique)] +interface ICoreWebView2_2 : ICoreWebView2 { + /// Add an event handler for the WebResourceResponseReceived event. + /// WebResourceResponseReceived is raised when the WebView receives the + /// response for a request for a web resource (any URI resolution performed by + /// the WebView; such as HTTP/HTTPS, file and data requests from redirects, + /// navigations, declarations in HTML, implicit favicon lookups, and fetch API + /// usage in the document). The host app can use this event to view the actual + /// request and response for a web resource. There is no guarantee about the + /// order in which the WebView processes the response and the host app's + /// handler runs. The app's handler will not block the WebView from processing + /// the response. + /// \snippet ScenarioAuthentication.cpp WebResourceResponseReceived + HRESULT add_WebResourceResponseReceived( + [in] ICoreWebView2WebResourceResponseReceivedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + /// Remove an event handler previously added with + /// add_WebResourceResponseReceived. + HRESULT remove_WebResourceResponseReceived( + [in] EventRegistrationToken token); + + /// Navigates using a constructed WebResourceRequest object. This lets you + /// provide post data or additional request headers during navigation. + /// The headers in the WebResourceRequest override headers + /// added by WebView2 runtime except for Cookie headers. + /// Method can only be either "GET" or "POST". Provided post data will only + /// be sent only if the method is "POST" and the uri scheme is HTTP(S). + /// \snippet ScenarioNavigateWithWebResourceRequest.cpp NavigateWithWebResourceRequest + HRESULT NavigateWithWebResourceRequest([in] ICoreWebView2WebResourceRequest* request); + + /// Add an event handler for the DOMContentLoaded event. + /// DOMContentLoaded is raised when the initial html document has been parsed. + /// This aligns with the document's DOMContentLoaded event in html. + /// + /// \snippet ScenarioDOMContentLoaded.cpp DOMContentLoaded + HRESULT add_DOMContentLoaded( + [in] ICoreWebView2DOMContentLoadedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with add_DOMContentLoaded. + HRESULT remove_DOMContentLoaded( + [in] EventRegistrationToken token); + + /// Gets the cookie manager object associated with this ICoreWebView2. + /// See ICoreWebView2CookieManager. + /// + /// \snippet ScenarioCookieManagement.cpp CookieManager + [propget] HRESULT CookieManager([out, retval] ICoreWebView2CookieManager** cookieManager); + + /// Exposes the CoreWebView2Environment used to create this CoreWebView2. + [propget] HRESULT Environment([out, retval] ICoreWebView2Environment** environment); +} + +/// A continuation of the ICoreWebView2_2 interface. +[uuid(A0D6DF20-3B92-416D-AA0C-437A9C727857), object, pointer_default(unique)] +interface ICoreWebView2_3 : ICoreWebView2_2 { + /// An app may call the `TrySuspend` API to have the WebView2 consume less memory. + /// This is useful when a Win32 app becomes invisible, or when a Universal Windows + /// Platform app is being suspended, during the suspended event handler before completing + /// the suspended event. + /// The CoreWebView2Controller's IsVisible property must be false when the API is called. + /// Otherwise, the API fails with `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)`. + /// Suspending is similar to putting a tab to sleep in the Edge browser. Suspending pauses + /// WebView script timers and animations, minimizes CPU usage for the associated + /// browser renderer process and allows the operating system to reuse the memory that was + /// used by the renderer process for other processes. + /// Note that Suspend is best effort and considered completed successfully once the request + /// is sent to browser renderer process. If there is a running script, the script will continue + /// to run and the renderer process will be suspended after that script is done. + /// See [Sleeping Tabs FAQ](https://techcommunity.microsoft.com/t5/articles/sleeping-tabs-faq/m-p/1705434) + /// for conditions that might prevent WebView from being suspended. In those situations, + /// the completed handler will be invoked with isSuccessful as false and errorCode as S_OK. + /// The WebView will be automatically resumed when it becomes visible. Therefore, the + /// app normally does not have to call `Resume` explicitly. + /// The app can call `Resume` and then `TrySuspend` periodically for an invisible WebView so that + /// the invisible WebView can sync up with latest data and the page ready to show fresh content + /// when it becomes visible. + /// All WebView APIs can still be accessed when a WebView is suspended. Some APIs like Navigate + /// will auto resume the WebView. To avoid unexpected auto resume, check `IsSuspended` property + /// before calling APIs that might change WebView state. + /// + /// \snippet ViewComponent.cpp ToggleIsVisibleOnMinimize + /// + /// \snippet ViewComponent.cpp Suspend + HRESULT TrySuspend([in] ICoreWebView2TrySuspendCompletedHandler* handler); + + /// Resumes the WebView so that it resumes activities on the web page. + /// This API can be called while the WebView2 controller is invisible. + /// The app can interact with the WebView immediately after `Resume`. + /// WebView will be automatically resumed when it becomes visible. + /// + /// \snippet ViewComponent.cpp ToggleIsVisibleOnMinimize + /// + /// \snippet ViewComponent.cpp Resume + HRESULT Resume(); + + /// Whether WebView is suspended. + /// `TRUE` when WebView is suspended, from the time when TrySuspend has completed + /// successfully until WebView is resumed. + [propget] HRESULT IsSuspended([out, retval] BOOL* isSuspended); + + /// Sets a mapping between a virtual host name and a folder path to make available to web sites + /// via that host name. + /// + /// After setting the mapping, documents loaded in the WebView can use HTTP or HTTPS URLs at + /// the specified host name specified by hostName to access files in the local folder specified + /// by folderPath. + /// + /// This mapping applies to both top-level document and iframe navigations as well as subresource + /// references from a document. This also applies to web workers including dedicated/shared worker + /// and service worker, for loading either worker scripts or subresources + /// (importScripts(), fetch(), XHR, etc.) issued from within a worker. + /// For virtual host mapping to work with service worker, please keep the virtual host name + /// mappings consistent among all WebViews sharing the same browser instance. As service worker + /// works independently of WebViews, we merge mappings from all WebViews when resolving virtual + /// host name, inconsistent mappings between WebViews would lead unexpected behavior. + /// + /// Due to a current implementation limitation, media files accessed using virtual host name can be + /// very slow to load. + /// As the resource loaders for the current page might have already been created and running, + /// changes to the mapping might not be applied to the current page and a reload of the page is + /// needed to apply the new mapping. + /// + /// Both absolute and relative paths are supported for folderPath. Relative paths are interpreted + /// as relative to the folder where the exe of the app is in. + /// + /// Note that the folderPath length must not exceed the Windows MAX_PATH limit. + /// + /// accessKind specifies the level of access to resources under the virtual host from other sites. + /// + /// For example, after calling + /// ```cpp + /// SetVirtualHostNameToFolderMapping( + /// L"appassets.example", L"assets", + /// COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY); + /// ``` + /// navigating to `https://appassets.example/my-local-file.html` will + /// show the content from my-local-file.html in the assets subfolder located on disk under + /// the same path as the app's executable file. + /// + /// DOM elements that want to reference local files will have their host reference virtual host in the source. + /// If there are multiple folders being used, define one unique virtual host per folder. + /// For example, you can embed a local image like this + /// ```cpp + /// WCHAR c_navString[] = L""; + /// m_webView->NavigateToString(c_navString); + /// ``` + /// The example above shows the image wv2.png by resolving the folder mapping above. + /// + /// You should typically choose virtual host names that are never used by real sites. + /// If you own a domain such as example.com, another option is to use a subdomain reserved for + /// the app (like my-app.example.com). + /// + /// [RFC 6761](https://tools.ietf.org/html/rfc6761) has reserved several special-use domain + /// names that are guaranteed to not be used by real sites (for example, .example, .test, and + /// .invalid.) + /// + /// Note that using `.local` as the top-level domain name will work but can cause a delay + /// during navigations. You should avoid using `.local` if you can. + /// + /// Apps should use distinct domain names when mapping folder from different sources that + /// should be isolated from each other. For instance, the app might use app-file.example for + /// files that ship as part of the app, and book1.example might be used for files containing + /// books from a less trusted source that were previously downloaded and saved to the disk by + /// the app. + /// + /// The host name used in the APIs is canonicalized using Chromium's host name parsing logic + /// before being used internally. For more information see [HTML5 2.6 URLs](https://dev.w3.org/html5/spec-LC/urls.html). + /// + /// All host names that are canonicalized to the same string are considered identical. + /// For example, `EXAMPLE.COM` and `example.com` are treated as the same host name. + /// An international host name and its Punycode-encoded host name are considered the same host + /// name. There is no DNS resolution for host name and the trailing '.' is not normalized as + /// part of canonicalization. + /// + /// Therefore `example.com` and `example.com.` are treated as different host names. Similarly, + /// `virtual-host-name` and `virtual-host-name.example.com` are treated as different host names + /// even if the machine has a DNS suffix of `example.com`. + /// + /// Specify the minimal cross-origin access necessary to run the app. If there is not a need to + /// access local resources from other origins, use COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND_DENY. + /// + /// \snippet AppWindow.cpp AddVirtualHostNameToFolderMapping + /// + /// \snippet AppWindow.cpp LocalUrlUsage + HRESULT SetVirtualHostNameToFolderMapping( + [in] LPCWSTR hostName, + [in] LPCWSTR folderPath, + [in] COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND accessKind); + + /// Clears a host name mapping for local folder that was added by `SetVirtualHostNameToFolderMapping`. + HRESULT ClearVirtualHostNameToFolderMapping( + [in] LPCWSTR hostName); +} + +/// A continuation of the ICoreWebView2_3 interface to support FrameCreated and +/// DownloadStarting events. +[uuid(20d02d59-6df2-42dc-bd06-f98a694b1302), object, pointer_default(unique)] +interface ICoreWebView2_4 : ICoreWebView2_3 { + /// Raised when a new iframe is created. + /// Handle this event to get access to ICoreWebView2Frame objects. + /// Use ICoreWebView2Frame.add_Destroyed to listen for when this iframe goes + /// away. + HRESULT add_FrameCreated( + [in] ICoreWebView2FrameCreatedEventHandler * eventHandler, + [out] EventRegistrationToken * token); + + /// Remove an event handler previously added with add_FrameCreated. + HRESULT remove_FrameCreated([in] EventRegistrationToken token); + + /// Add an event handler for the `DownloadStarting` event. This event is + /// raised when a download has begun, blocking the default download dialog, + /// but not blocking the progress of the download. + /// + /// The host can choose to cancel a download, change the result file path, + /// and hide the default download dialog. + /// If the host chooses to cancel the download, the download is not saved, no + /// dialog is shown, and the state is changed to + /// COREWEBVIEW2_DOWNLOAD_STATE_INTERRUPTED with interrupt reason + /// COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_CANCELED. Otherwise, the + /// download is saved to the default path after the event completes, + /// and default download dialog is shown if the host did not choose to hide it. + /// The host can change the visibility of the download dialog using the + /// `Handled` property. If the event is not handled, downloads complete + /// normally with the default dialog shown. + /// + /// \snippet ScenarioCustomDownloadExperience.cpp DownloadStarting + HRESULT add_DownloadStarting( + [in] ICoreWebView2DownloadStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_DownloadStarting`. + HRESULT remove_DownloadStarting( + [in] EventRegistrationToken token); +} + +/// This interface is an extension of `ICoreWebView2_7` that supports media features. +[uuid(E9632730-6E1E-43AB-B7B8-7B2C9E62E094), object, pointer_default(unique)] +interface ICoreWebView2_8 : ICoreWebView2_7 { + /// Adds an event handler for the `IsMutedChanged` event. + /// `IsMutedChanged` is raised when the IsMuted property changes value. + /// + /// \snippet AudioComponent.cpp IsMutedChanged + HRESULT add_IsMutedChanged( + [in] ICoreWebView2IsMutedChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_IsMutedChanged`. + HRESULT remove_IsMutedChanged( + [in] EventRegistrationToken token); + + /// Indicates whether all audio output from this CoreWebView2 is muted or not. + /// + /// \snippet AudioComponent.cpp ToggleIsMuted + [propget] HRESULT IsMuted([out, retval] BOOL* value); + + /// Sets the `IsMuted` property. + /// + /// \snippet AudioComponent.cpp ToggleIsMuted + [propput] HRESULT IsMuted([in] BOOL value); + + /// Adds an event handler for the `IsDocumentPlayingAudioChanged` event. + /// `IsDocumentPlayingAudioChanged` is raised when the IsDocumentPlayingAudio property changes value. + /// + /// \snippet AudioComponent.cpp IsDocumentPlayingAudioChanged + HRESULT add_IsDocumentPlayingAudioChanged( + [in] ICoreWebView2IsDocumentPlayingAudioChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_IsDocumentPlayingAudioChanged`. + HRESULT remove_IsDocumentPlayingAudioChanged( + [in] EventRegistrationToken token); + + /// Indicates whether any audio output from this CoreWebView2 is playing. + /// This property will be true if audio is playing even if IsMuted is true. + /// + /// \snippet AudioComponent.cpp IsDocumentPlayingAudio + [propget] HRESULT IsDocumentPlayingAudio([out, retval] BOOL* value); +} + +/// This interface is an extension of `ICoreWebView2_8` that default download +/// dialog positioning and anchoring. +[uuid(4d7b2eab-9fdc-468d-b998-a9260b5ed651), object, pointer_default(unique)] +interface ICoreWebView2_9 : ICoreWebView2_8 { + /// Raised when the `IsDefaultDownloadDialogOpen` property changes. This event + /// comes after the `DownloadStarting` event. Setting the `Handled` property + /// on the `DownloadStartingEventArgs` disables the default download dialog + /// and ensures that this event is never raised. + HRESULT add_IsDefaultDownloadDialogOpenChanged( + [in] ICoreWebView2IsDefaultDownloadDialogOpenChangedEventHandler* handler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with + /// `add_IsDefaultDownloadDialogOpenChanged`. + HRESULT remove_IsDefaultDownloadDialogOpenChanged( + [in] EventRegistrationToken token); + + /// `TRUE` if the default download dialog is currently open. The value of this + /// property changes only when the default download dialog is explicitly + /// opened or closed. Hiding the WebView implicitly hides the dialog, but does + /// not change the value of this property. + [propget] HRESULT IsDefaultDownloadDialogOpen([out, retval] BOOL* value); + + /// Open the default download dialog. If the dialog is opened before there + /// are recent downloads, the dialog shows all past downloads for the + /// current profile. Otherwise, the dialog shows only the recent downloads + /// with a "See more" button for past downloads. Calling this method raises + /// the `IsDefaultDownloadDialogOpenChanged` event if the dialog was closed. + /// No effect if the dialog is already open. + /// + /// \snippet ViewComponent.cpp ToggleDefaultDownloadDialog + HRESULT OpenDefaultDownloadDialog(); + + /// Close the default download dialog. Calling this method raises the + /// `IsDefaultDownloadDialogOpenChanged` event if the dialog was open. No + /// effect if the dialog is already closed. + HRESULT CloseDefaultDownloadDialog(); + + /// Get the default download dialog corner alignment. + [propget] HRESULT DefaultDownloadDialogCornerAlignment( + [out, retval] COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT* value); + + /// Set the default download dialog corner alignment. The dialog can be + /// aligned to any of the WebView corners (see + /// COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT). When the WebView + /// or dialog changes size, the dialog keeps its position relative to the + /// corner. The dialog may become partially or completely outside of the + /// WebView bounds if the WebView is small enough. Set the margin relative to + /// the corner with the `DefaultDownloadDialogMargin` property. The corner + /// alignment and margin should be set during initialization to ensure that + /// they are correctly applied when the layout is first computed, otherwise + /// they will not take effect until the next time the WebView position or size + /// is updated. + /// + /// \snippet ViewComponent.cpp SetDefaultDownloadDialogPosition + [propput] HRESULT DefaultDownloadDialogCornerAlignment( + [in] COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT value); + + /// Get the default download dialog margin. + [propget] HRESULT DefaultDownloadDialogMargin([out, retval] POINT* value); + + /// Set the default download dialog margin relative to the WebView corner + /// specified by `DefaultDownloadDialogCornerAlignment`. The margin is a + /// point that describes the vertical and horizontal distances between the + /// chosen WebView corner and the default download dialog corner nearest to + /// it. Positive values move the dialog towards the center of the WebView from + /// the chosen WebView corner, and negative values move the dialog away from + /// it. Use (0, 0) to align the dialog to the WebView corner with no margin. + /// The corner alignment and margin should be set during initialization to + /// ensure that they are correctly applied when the layout is first computed, + /// otherwise they will not take effect until the next time the WebView + /// position or size is updated. + [propput] HRESULT DefaultDownloadDialogMargin([in] POINT value); +} + +/// This interface is an extension of `ICoreWebView2_10` that supports sessionId +/// for CDP method calls and ContextMenuRequested event. +[uuid(0be78e56-c193-4051-b943-23b460c08bdb), object, pointer_default(unique)] +interface ICoreWebView2_11 : ICoreWebView2_10 { + /// Runs an asynchronous `DevToolsProtocol` method for a specific session of + /// an attached target. + /// There could be multiple `DevToolsProtocol` targets in a WebView. + /// Besides the top level page, iframes from different origin and web workers + /// are also separate targets. Attaching to these targets allows interaction with them. + /// When the DevToolsProtocol is attached to a target, the connection is identified + /// by a sessionId. + /// To use this API, you must set the `flatten` parameter to true when calling + /// `Target.attachToTarget` or `Target.setAutoAttach` `DevToolsProtocol` method. + /// Using `Target.setAutoAttach` is recommended as that would allow you to attach + /// to dedicated worker targets, which are not discoverable via other APIs like + /// `Target.getTargets`. + /// For more information about targets and sessions, navigate to + /// [DevTools Protocol Viewer](https://chromedevtools.github.io/devtools-protocol/tot/Target). + /// For more information about available methods, navigate to + /// [DevTools Protocol Viewer](https://chromedevtools.github.io/devtools-protocol/tot) + /// The `sessionId` parameter is the sessionId for an attached target. + /// nullptr or empty string is treated as the session for the default target for the top page. + /// The `methodName` parameter is the full name of the method in the + /// `{domain}.{method}` format. The `parametersAsJson` parameter is a JSON + /// formatted string containing the parameters for the corresponding method. + /// The `Invoke` method of the `handler` is run when the method + /// asynchronously completes. `Invoke` is run with the return object of the + /// method as a JSON string. This function returns E_INVALIDARG if the `methodName` is + /// unknown or the `parametersAsJson` has an error. In the case of such an error, the + /// `returnObjectAsJson` parameter of the handler will include information + /// about the error. + /// + /// \snippet ScriptComponent.cpp DevToolsProtocolMethodMultiSession + /// + /// \snippet ScriptComponent.cpp CallDevToolsProtocolMethodForSession + HRESULT CallDevToolsProtocolMethodForSession( + [in] LPCWSTR sessionId, + [in] LPCWSTR methodName, + [in] LPCWSTR parametersAsJson, + [in] ICoreWebView2CallDevToolsProtocolMethodCompletedHandler* handler); + + /// Add an event handler for the `ContextMenuRequested` event. + /// `ContextMenuRequested` event is raised when a context menu is requested by the user + /// and the content inside WebView hasn't disabled context menus. + /// The host has the option to create their own context menu with the information provided in + /// the event or can add items to or remove items from WebView context menu. + /// If the host doesn't handle the event, WebView will display the default context menu. + /// + /// \snippet SettingsComponent.cpp EnableCustomMenu + HRESULT add_ContextMenuRequested( + [in] ICoreWebView2ContextMenuRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_ContextMenuRequested`. + HRESULT remove_ContextMenuRequested( + [in] EventRegistrationToken token); +} + +/// This interface is an extension of `ICoreWebView2_11` that supports +/// StatusBarTextChanged event. +[uuid(35D69927-BCFA-4566-9349-6B3E0D154CAC), object, pointer_default(unique)] +interface ICoreWebView2_12 : ICoreWebView2_11 { + /// Add an event handler for the `StatusBarTextChanged` event. + /// `StatusBarTextChanged` fires when the WebView is showing a status message, + /// a URL, or an empty string (an indication to hide the status bar). + /// \snippet SettingsComponent.cpp StatusBarTextChanged + HRESULT add_StatusBarTextChanged( + [in] ICoreWebView2StatusBarTextChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_StatusBarTextChanged`. + HRESULT remove_StatusBarTextChanged([in] EventRegistrationToken token); + + /// The status message text. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT StatusBarText([out, retval] LPWSTR* value); +} + +/// This interface is an extension of `ICoreWebView2_14` that supports status Favicons. +[uuid(517B2D1D-7DAE-4A66-A4F4-10352FFB9518), object, pointer_default(unique)] +interface ICoreWebView2_15 : ICoreWebView2_14 { + /// Add an event handler for the `FaviconChanged` event. + /// The `FaviconChanged` event is raised when the + /// [favicon](https://developer.mozilla.org/docs/Glossary/Favicon) + /// had a different URL then the previous URL. + /// The FaviconChanged event will be raised for first navigating to a new + /// document, whether or not a document declares a Favicon in HTML if the + /// favicon is different from the previous fav icon. The event will + /// be raised again if a favicon is declared in its HTML or has script + /// to set its favicon. The favicon information can then be retrieved with + /// `GetFavicon` and `FaviconUri`. + HRESULT add_FaviconChanged( + [in] ICoreWebView2FaviconChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove the event handler for `FaviconChanged` event. + HRESULT remove_FaviconChanged( + [in] EventRegistrationToken token); + + /// Get the current Uri of the favicon as a string. + /// If the value is null, then the return value is `E_POINTER`, otherwise it is `S_OK`. + /// If a page has no favicon then the value is an empty string. + [propget] HRESULT FaviconUri([out, retval] LPWSTR* value); + + /// Async function for getting the actual image data of the favicon. + /// The image is copied to the `imageStream` object in `ICoreWebView2GetFaviconCompletedHandler`. + /// If there is no image then no data would be copied into the imageStream. + /// The `format` is the file format to return the image stream. + /// `completedHandler` is executed at the end of the operation. + /// + /// \snippet SettingsComponent.cpp FaviconChanged + HRESULT GetFavicon( + [in] COREWEBVIEW2_FAVICON_IMAGE_FORMAT format, + [in] ICoreWebView2GetFaviconCompletedHandler* completedHandler); +} + +/// A continuation of the `ICoreWebView2` interface to support printing. +[uuid(0EB34DC9-9F91-41E1-8639-95CD5943906B), object, pointer_default(unique)] +interface ICoreWebView2_16 : ICoreWebView2_15 { + /// Print the current web page asynchronously to the specified printer with the provided settings. + /// See `ICoreWebView2PrintSettings` for description of settings. Passing + /// nullptr for `printSettings` results in default print settings used. + /// + /// The handler will return `errorCode` as `S_OK` and `printStatus` as COREWEBVIEW2_PRINT_STATUS_PRINTER_UNAVAILABLE + /// if `printerName` doesn't match with the name of any installed printers on the user OS. The handler + /// will return `errorCode` as `E_INVALIDARG` and `printStatus` as COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR + /// if the caller provides invalid settings for a given printer. + /// + /// The async `Print` operation completes when it finishes printing to the printer. + /// At this time the `ICoreWebView2PrintCompletedHandler` is invoked. + /// Only one `Printing` operation can be in progress at a time. If `Print` is called while a `Print` or `PrintToPdf` + /// or `PrintToPdfStream` or `ShowPrintUI` job is in progress, the completed handler is immediately invoked + /// with `E_ABORT` and `printStatus` is COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR. + /// This is only for printing operation on one webview. + /// + /// | errorCode | printStatus | Notes | + /// | --- | --- | --- | + /// | S_OK | COREWEBVIEW2_PRINT_STATUS_SUCCEEDED | Print operation succeeded. | + /// | S_OK | COREWEBVIEW2_PRINT_STATUS_PRINTER_UNAVAILABLE | If specified printer is not found or printer status is not available, offline or error state. | + /// | S_OK | COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR | Print operation is failed. | + /// | E_INVALIDARG | COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR | If the caller provides invalid settings for the specified printer. | + /// | E_ABORT | COREWEBVIEW2_PRINT_STATUS_OTHER_ERROR | Print operation is failed as printing job already in progress. | + /// + /// \snippet AppWindow.cpp PrintToPrinter + HRESULT Print( + [in] ICoreWebView2PrintSettings* printSettings, + [in] ICoreWebView2PrintCompletedHandler* handler); + + /// Opens the print dialog to print the current web page. See `COREWEBVIEW2_PRINT_DIALOG_KIND` + /// for descriptions of print dialog kinds. + /// + /// Invoking browser or system print dialog doesn't open new print dialog if + /// it is already open. + /// + /// \snippet AppWindow.cpp ShowPrintUI + HRESULT ShowPrintUI([in] COREWEBVIEW2_PRINT_DIALOG_KIND printDialogKind); + + /// Provides the Pdf data of current web page asynchronously for the provided settings. + /// Stream will be rewound to the start of the pdf data. + /// + /// See `ICoreWebView2PrintSettings` for description of settings. Passing + /// nullptr for `printSettings` results in default print settings used. + /// + /// The async `PrintToPdfStream` operation completes when it finishes + /// writing to the stream. At this time the `ICoreWebView2PrintToPdfStreamCompletedHandler` + /// is invoked. Only one `Printing` operation can be in progress at a time. If + /// `PrintToPdfStream` is called while a `PrintToPdfStream` or `PrintToPdf` or `Print` + /// or `ShowPrintUI` job is in progress, the completed handler is immediately invoked with `E_ABORT`. + /// This is only for printing operation on one webview. + /// + /// \snippet AppWindow.cpp PrintToPdfStream + HRESULT PrintToPdfStream([in] ICoreWebView2PrintSettings* printSettings, + [in] ICoreWebView2PrintToPdfStreamCompletedHandler* handler); +} + +/// Defines properties that enable, disable, or modify WebView features. +/// Changes to `IsGeneralAutofillEnabled` and `IsPasswordAutosaveEnabled` +/// apply immediately, while other setting changes made after `NavigationStarting` +/// event do not apply until the next top-level navigation. + +[uuid(e562e4f0-d7fa-43ac-8d71-c05150499f00), object, pointer_default(unique)] +interface ICoreWebView2Settings : IUnknown { + + /// Controls if running JavaScript is enabled in all future navigations in + /// the WebView. This only affects scripts in the document. Scripts + /// injected with `ExecuteScript` runs even if script is disabled. + /// The default value is `TRUE`. + /// + /// \snippet SettingsComponent.cpp IsScriptEnabled + [propget] HRESULT IsScriptEnabled( + [out, retval] BOOL* isScriptEnabled); + + /// Sets the `IsScriptEnabled` property. + [propput] HRESULT IsScriptEnabled([in] BOOL isScriptEnabled); + + /// The `IsWebMessageEnabled` property is used when loading a new HTML + /// document. If set to `TRUE`, communication from the host to the top-level + /// HTML document of the WebView is allowed using `PostWebMessageAsJson`, + /// `PostWebMessageAsString`, and message event of `window.chrome.webview`. + /// For more information, navigate to PostWebMessageAsJson. Communication + /// from the top-level HTML document of the WebView to the host is allowed + /// using the postMessage function of `window.chrome.webview` and + /// `add_WebMessageReceived` method. For more information, navigate to + /// [add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2#add_webmessagereceived). + /// If set to false, then communication is disallowed. `PostWebMessageAsJson` + /// and `PostWebMessageAsString` fails with `E_ACCESSDENIED` and + /// `window.chrome.webview.postMessage` fails by throwing an instance of an + /// `Error` object. The default value is `TRUE`. + /// + /// \snippet ScenarioWebMessage.cpp IsWebMessageEnabled + [propget] HRESULT IsWebMessageEnabled( + [out, retval] BOOL* isWebMessageEnabled); + + /// Sets the `IsWebMessageEnabled` property. + [propput] HRESULT IsWebMessageEnabled([in] BOOL isWebMessageEnabled); + + /// `AreDefaultScriptDialogsEnabled` is used when loading a new HTML + /// document. If set to `FALSE`, WebView2 does not render the default JavaScript + /// dialog box (Specifically those displayed by the JavaScript alert, + /// confirm, prompt functions and `beforeunload` event). Instead, if an + /// event handler is set using `add_ScriptDialogOpening`, WebView sends an + /// event that contains all of the information for the dialog and allow the + /// host app to show a custom UI. + /// The default value is `TRUE`. + [propget] HRESULT AreDefaultScriptDialogsEnabled( + [out, retval] BOOL* areDefaultScriptDialogsEnabled); + + /// Sets the `AreDefaultScriptDialogsEnabled` property. + [propput] HRESULT AreDefaultScriptDialogsEnabled( + [in] BOOL areDefaultScriptDialogsEnabled); + + /// `IsStatusBarEnabled` controls whether the status bar is displayed. The + /// status bar is usually displayed in the lower left of the WebView and + /// shows things such as the URI of a link when the user hovers over it and + /// other information. + /// The default value is `TRUE`. + /// The status bar UI can be altered by web content and should not be considered secure. + [propget] HRESULT IsStatusBarEnabled([out, retval] BOOL* isStatusBarEnabled); + + /// Sets the `IsStatusBarEnabled` property. + [propput] HRESULT IsStatusBarEnabled([in] BOOL isStatusBarEnabled); + + /// `AreDevToolsEnabled` controls whether the user is able to use the context + /// menu or keyboard shortcuts to open the DevTools window. + /// The default value is `TRUE`. + [propget] HRESULT AreDevToolsEnabled([out, retval] BOOL* areDevToolsEnabled); + + /// Sets the `AreDevToolsEnabled` property. + [propput] HRESULT AreDevToolsEnabled([in] BOOL areDevToolsEnabled); + + /// The `AreDefaultContextMenusEnabled` property is used to prevent default + /// context menus from being shown to user in WebView. + /// The default value is `TRUE`. + /// + /// \snippet SettingsComponent.cpp DisableContextMenu + [propget] HRESULT AreDefaultContextMenusEnabled([out, retval] BOOL* enabled); + + /// Sets the `AreDefaultContextMenusEnabled` property. + [propput] HRESULT AreDefaultContextMenusEnabled([in] BOOL enabled); + + /// The `AreHostObjectsAllowed` property is used to control whether host + /// objects are accessible from the page in WebView. + /// The default value is `TRUE`. + /// + /// \snippet SettingsComponent.cpp HostObjectsAccess + [propget] HRESULT AreHostObjectsAllowed([out, retval] BOOL* allowed); + + /// Sets the `AreHostObjectsAllowed` property. + + [propput] HRESULT AreHostObjectsAllowed([in] BOOL allowed); + + /// The `IsZoomControlEnabled` property is used to prevent the user from + /// impacting the zoom of the WebView. When disabled, the user is not able + /// to zoom using Ctrl++, Ctrl+-, or Ctrl+mouse wheel, but the zoom + /// is set using `ZoomFactor` API. The default value is `TRUE`. + /// + /// \snippet SettingsComponent.cpp DisableZoomControl + + [propget] HRESULT IsZoomControlEnabled([out, retval] BOOL* enabled); + + /// Sets the `IsZoomControlEnabled` property. + + [propput] HRESULT IsZoomControlEnabled([in] BOOL enabled); + + /// The `IsBuiltInErrorPageEnabled` property is used to disable built in + /// error page for navigation failure and render process failure. When + /// disabled, a blank page is displayed when the related error happens. + /// The default value is `TRUE`. + /// + /// \snippet SettingsComponent.cpp BuiltInErrorPageEnabled + [propget] HRESULT IsBuiltInErrorPageEnabled([out, retval] BOOL* enabled); + + /// Sets the `IsBuiltInErrorPageEnabled` property. + [propput] HRESULT IsBuiltInErrorPageEnabled([in] BOOL enabled); +} + +/// A continuation of the ICoreWebView2Settings interface to manage autofill. +[uuid(cb56846c-4168-4d53-b04f-03b6d6796ff2), object, pointer_default(unique)] +interface ICoreWebView2Settings4 : ICoreWebView2Settings3 { + /// IsPasswordAutosaveEnabled controls whether autosave for password + /// information is enabled. The IsPasswordAutosaveEnabled property behaves + /// independently of the IsGeneralAutofillEnabled property. When IsPasswordAutosaveEnabled is + /// false, no new password data is saved and no Save/Update Password prompts are displayed. + /// However, if there was password data already saved before disabling this setting, + /// then that password information is auto-populated, suggestions are shown and clicking on + /// one will populate the fields. + /// When IsPasswordAutosaveEnabled is true, password information is auto-populated, + /// suggestions are shown and clicking on one will populate the fields, new data + /// is saved, and a Save/Update Password prompt is displayed. + /// It will take effect immediately after setting. + /// The default value is `FALSE`. + /// This property has the same value as + /// `CoreWebView2Profile.IsPasswordAutosaveEnabled`, and changing one will + /// change the other. All `CoreWebView2`s with the same `CoreWebView2Profile` + /// will share the same value for this property, so for the `CoreWebView2`s + /// with the same profile, their + /// `CoreWebView2Settings.IsPasswordAutosaveEnabled` and + /// `CoreWebView2Profile.IsPasswordAutosaveEnabled` will always have the same + /// value. + /// + /// \snippet SettingsComponent.cpp PasswordAutosaveEnabled + [propget] HRESULT IsPasswordAutosaveEnabled([out, retval] BOOL* value); + + /// Set the IsPasswordAutosaveEnabled property. + [propput] HRESULT IsPasswordAutosaveEnabled([in] BOOL value); + + /// IsGeneralAutofillEnabled controls whether autofill for information + /// like names, street and email addresses, phone numbers, and arbitrary input + /// is enabled. This excludes password and credit card information. When + /// IsGeneralAutofillEnabled is false, no suggestions appear, and no new information + /// is saved. When IsGeneralAutofillEnabled is true, information is saved, suggestions + /// appear and clicking on one will populate the form fields. + /// It will take effect immediately after setting. + /// The default value is `TRUE`. + /// This property has the same value as + /// `CoreWebView2Profile.IsGeneralAutofillEnabled`, and changing one will + /// change the other. All `CoreWebView2`s with the same `CoreWebView2Profile` + /// will share the same value for this property, so for the `CoreWebView2`s + /// with the same profile, their + /// `CoreWebView2Settings.IsGeneralAutofillEnabled` and + /// `CoreWebView2Profile.IsGeneralAutofillEnabled` will always have the same + /// value. + /// + /// \snippet SettingsComponent.cpp GeneralAutofillEnabled + [propget] HRESULT IsGeneralAutofillEnabled([out, retval] BOOL* value); + + /// Set the IsGeneralAutofillEnabled property. + [propput] HRESULT IsGeneralAutofillEnabled([in] BOOL value); +} + +/// The owner of the `CoreWebView2` object that provides support for resizing, +/// showing and hiding, focusing, and other functionality related to +/// windowing and composition. The `CoreWebView2Controller` owns the +/// `CoreWebView2`, and if all references to the `CoreWebView2Controller` go +/// away, the WebView is closed. +[uuid(4d00c0d1-9434-4eb6-8078-8697a560334f), object, pointer_default(unique)] +interface ICoreWebView2Controller : IUnknown { + + /// The `IsVisible` property determines whether to show or hide the WebView2. + /// If `IsVisible` is set to `FALSE`, the WebView2 is transparent and is + /// not rendered. However, this does not affect the window containing the + /// WebView2 (the `HWND` parameter that was passed to + /// `CreateCoreWebView2Controller`). If you want that window to disappear + /// too, run `ShowWindow` on it directly in addition to modifying the + /// `IsVisible` property. WebView2 as a child window does not get window + /// messages when the top window is minimized or restored. For performance + /// reasons, developers should set the `IsVisible` property of the WebView to + /// `FALSE` when the app window is minimized and back to `TRUE` when the app + /// window is restored. The app window does this by handling + /// `SIZE_MINIMIZED and SIZE_RESTORED` command upon receiving `WM_SIZE` + /// message. + /// + /// There are CPU and memory benefits when the page is hidden. For instance, + /// Chromium has code that throttles activities on the page like animations + /// and some tasks are run less frequently. Similarly, WebView2 will + /// purge some caches to reduce memory usage. + /// + /// \snippet ViewComponent.cpp ToggleIsVisible + [propget] HRESULT IsVisible([out, retval] BOOL* isVisible); + + /// Sets the `IsVisible` property. + /// + /// \snippet ViewComponent.cpp ToggleIsVisibleOnMinimize + [propput] HRESULT IsVisible([in] BOOL isVisible); + + /// The WebView bounds. Bounds are relative to the parent `HWND`. The app + /// has two ways to position a WebView. + /// + /// * Create a child `HWND` that is the WebView parent `HWND`. Position + /// the window where the WebView should be. Use `(0, 0)` for the + /// top-left corner (the offset) of the `Bounds` of the WebView. + /// * Use the top-most window of the app as the WebView parent HWND. For + /// example, to position WebView correctly in the app, set the top-left + /// corner of the Bound of the WebView. + /// + /// The values of `Bounds` are limited by the coordinate space of the host. + + [propget] HRESULT Bounds([out, retval] RECT* bounds); + + /// Sets the `Bounds` property. + /// + /// \snippet ViewComponent.cpp ResizeWebView + + [propput] HRESULT Bounds([in] RECT bounds); + + /// The zoom factor for the WebView. + /// + /// \> [!NOTE]\n\> Changing zoom factor may cause `window.innerWidth`, + /// `window.innerHeight`, both, and page layout to change. A zoom factor + /// that is applied by the host by running `ZoomFactor` becomes the new + /// default zoom for the WebView. The zoom factor applies across navigations + /// and is the zoom factor WebView is returned to when the user chooses + /// Ctrl+0. When the zoom factor is changed by the user (resulting in + /// the app receiving `ZoomFactorChanged`), that zoom applies only for the + /// current page. Any user applied zoom is only for the current page and is + /// reset on a navigation. Specifying a `zoomFactor` less than or equal to + /// `0` is not allowed. WebView also has an internal supported zoom factor + /// range. When a specified zoom factor is out of that range, it is + /// normalized to be within the range, and a `ZoomFactorChanged` event is + /// triggered for the real applied zoom factor. When the range normalization + /// happens, the `ZoomFactor` property reports the zoom factor specified + /// during the previous modification of the `ZoomFactor` property until the + /// `ZoomFactorChanged` event is received after WebView applies the + /// normalized zoom factor. + + [propget] HRESULT ZoomFactor([out, retval] double* zoomFactor); + + /// Sets the `ZoomFactor` property. + + [propput] HRESULT ZoomFactor([in] double zoomFactor); + + /// Adds an event handler for the `ZoomFactorChanged` event. + /// `ZoomFactorChanged` runs when the `ZoomFactor` property of the WebView + /// changes. The event may run because the `ZoomFactor` property was + /// modified, or due to the user manually modifying the zoom. When it is + /// modified using the `ZoomFactor` property, the internal zoom factor is + /// updated immediately and no `ZoomFactorChanged` event is triggered. + /// WebView associates the last used zoom factor for each site. It is + /// possible for the zoom factor to change when navigating to a different + /// page. When the zoom factor changes due to a navigation change, the + /// `ZoomFactorChanged` event runs right after the `ContentLoading` event. + /// + /// \snippet ViewComponent.cpp ZoomFactorChanged + + HRESULT add_ZoomFactorChanged( + [in] ICoreWebView2ZoomFactorChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_ZoomFactorChanged`. + + HRESULT remove_ZoomFactorChanged( + [in] EventRegistrationToken token); + + /// Updates `Bounds` and `ZoomFactor` properties at the same time. This + /// operation is atomic from the perspective of the host. After returning + /// from this function, the `Bounds` and `ZoomFactor` properties are both + /// updated if the function is successful, or neither is updated if the + /// function fails. If `Bounds` and `ZoomFactor` are both updated by the + /// same scale (for example, `Bounds` and `ZoomFactor` are both doubled), + /// then the page does not display a change in `window.innerWidth` or + /// `window.innerHeight` and the WebView renders the content at the new size + /// and zoom without intermediate renderings. This function also updates + /// just one of `ZoomFactor` or `Bounds` by passing in the new value for one + /// and the current value for the other. + /// + /// \snippet ViewComponent.cpp SetBoundsAndZoomFactor + + HRESULT SetBoundsAndZoomFactor([in] RECT bounds, [in] double zoomFactor); + + /// Moves focus into WebView. WebView gets focus and focus is set to + /// correspondent element in the page hosted in the WebView. For + /// Programmatic reason, focus is set to previously focused element or the + /// default element if no previously focused element exists. For `Next` + /// reason, focus is set to the first element. For `Previous` reason, focus + /// is set to the last element. WebView changes focus through user + /// interaction including selecting into a WebView or Tab into it. For + /// tabbing, the app runs MoveFocus with Next or Previous to align with Tab + /// and Shift+Tab respectively when it decides the WebView is the next + /// element that may exist in a tab. Or, the app runs `IsDialogMessage` + /// as part of the associated message loop to allow the platform to auto + /// handle tabbing. The platform rotates through all windows with + /// `WS_TABSTOP`. When the WebView gets focus from `IsDialogMessage`, it is + /// internally put the focus on the first or last element for tab and + /// Shift+Tab respectively. + /// + /// \snippet App.cpp MoveFocus0 + /// + /// \snippet ControlComponent.cpp MoveFocus1 + /// + /// \snippet ControlComponent.cpp MoveFocus2 + + HRESULT MoveFocus([in] COREWEBVIEW2_MOVE_FOCUS_REASON reason); + + /// Adds an event handler for the `MoveFocusRequested` event. + /// `MoveFocusRequested` runs when user tries to tab out of the WebView. The + /// focus of the WebView has not changed when this event is run. + /// + /// \snippet ControlComponent.cpp MoveFocusRequested + + HRESULT add_MoveFocusRequested( + [in] ICoreWebView2MoveFocusRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_MoveFocusRequested`. + + HRESULT remove_MoveFocusRequested( + [in] EventRegistrationToken token); + + /// Adds an event handler for the `GotFocus` event. `GotFocus` runs when + /// WebView has focus. + + HRESULT add_GotFocus( + [in] ICoreWebView2FocusChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_GotFocus`. + + HRESULT remove_GotFocus( + [in] EventRegistrationToken token); + + /// Adds an event handler for the `LostFocus` event. `LostFocus` runs when + /// WebView loses focus. In the case where `MoveFocusRequested` event is + /// run, the focus is still on WebView when `MoveFocusRequested` event runs. + /// `LostFocus` only runs afterwards when code of the app or default action + /// of `MoveFocusRequested` event set focus away from WebView. + + HRESULT add_LostFocus( + [in] ICoreWebView2FocusChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_LostFocus`. + + HRESULT remove_LostFocus( + [in] EventRegistrationToken token); + + /// Adds an event handler for the `AcceleratorKeyPressed` event. + /// `AcceleratorKeyPressed` runs when an accelerator key or key combo is + /// pressed or released while the WebView is focused. A key is considered an + /// accelerator if either of the following conditions are true. + /// + /// * Ctrl or Alt is currently being held. + /// * The pressed key does not map to a character. + /// + /// A few specific keys are never considered accelerators, such as Shift. + /// The `Escape` key is always considered an accelerator. + /// + /// Auto-repeated key events caused by holding the key down also triggers + /// this event. Filter out the auto-repeated key events by verifying the + /// `KeyEventLParam` or `PhysicalKeyStatus` event args. + /// + /// In windowed mode, the event handler is run synchronously. Until you + /// run `Handled()` on the event args or the event handler returns, the + /// browser process is blocked and outgoing cross-process COM requests fail + /// with `RPC_E_CANTCALLOUT_ININPUTSYNCCALL`. All `CoreWebView2` API methods + /// work, however. + /// + /// In windowless mode, the event handler is run asynchronously. Further + /// input do not reach the browser until the event handler returns or + /// `Handled()` is run, but the browser process is not blocked, and outgoing + /// COM requests work normally. + /// + /// It is recommended to run `Handled(TRUE)` as early as are able to know + /// that you want to handle the accelerator key. + /// + /// \snippet ControlComponent.cpp AcceleratorKeyPressed + + HRESULT add_AcceleratorKeyPressed( + [in] ICoreWebView2AcceleratorKeyPressedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with + /// `add_AcceleratorKeyPressed`. + + HRESULT remove_AcceleratorKeyPressed( + [in] EventRegistrationToken token); + + /// The parent window provided by the app that this WebView is using to + /// render content. This API initially returns the window passed into + /// `CreateCoreWebView2Controller`. + + [propget] HRESULT ParentWindow([out, retval] HWND* parentWindow); + + /// Sets the parent window for the WebView. This causes the WebView to + /// re-parent the main WebView window to the newly provided window. + + [propput] HRESULT ParentWindow([in] HWND parentWindow); + + /// This is a notification separate from `Bounds` that tells WebView that the + /// main WebView parent (or any ancestor) `HWND` moved. This is needed + /// for accessibility and certain dialogs in WebView to work correctly. + /// + /// \snippet ViewComponent.cpp NotifyParentWindowPositionChanged + + HRESULT NotifyParentWindowPositionChanged(); + + /// Closes the WebView and cleans up the underlying browser instance. + /// Cleaning up the browser instance releases the resources powering the + /// WebView. The browser instance is shut down if no other WebViews are + /// using it. + /// + /// After running `Close`, most methods will fail and event handlers stop + /// running. Specifically, the WebView releases the associated references to + /// any associated event handlers when `Close` is run. + /// + /// `Close` is implicitly run when the `CoreWebView2Controller` loses the + /// final reference and is destructed. But it is best practice to + /// explicitly run `Close` to avoid any accidental cycle of references + /// between the WebView and the app code. Specifically, if you capture a + /// reference to the WebView in an event handler you create a reference cycle + /// between the WebView and the event handler. Run `Close` to break the + /// cycle by releasing all event handlers. But to avoid the situation, it is + /// best to both explicitly run `Close` on the WebView and to not capture a + /// reference to the WebView to ensure the WebView is cleaned up correctly. + /// `Close` is synchronous and won't trigger the `beforeunload` event. + /// + /// \snippet AppWindow.cpp Close + HRESULT Close(); + + /// Gets the `CoreWebView2` associated with this `CoreWebView2Controller`. + + [propget] HRESULT CoreWebView2([out, retval] ICoreWebView2** coreWebView2); +} + +/// A continuation of the ICoreWebView2Controller2 interface. +[uuid(f9614724-5d2b-41dc-aef7-73d62b51543b), object, pointer_default(unique)] +interface ICoreWebView2Controller3 : ICoreWebView2Controller2 { + /// The rasterization scale for the WebView. The rasterization scale is the + /// combination of the monitor DPI scale and text scaling set by the user. + /// This value should be updated when the DPI scale of the app's top level + /// window changes (i.e. monitor DPI scale changes or window changes monitor) + /// or when the text scale factor of the system changes. + /// + /// \snippet AppWindow.cpp DPIChanged + /// + /// \snippet AppWindow.cpp TextScaleChanged1 + /// + /// \snippet AppWindow.cpp TextScaleChanged2 + /// + /// Rasterization scale applies to the WebView content, as well as + /// popups, context menus, scroll bars, and so on. Normal app scaling + /// scenarios should use the ZoomFactor property or SetBoundsAndZoomFactor + /// API which only scale the rendered HTML content and not popups, context + /// menus, scroll bars, and so on. + /// + /// \snippet ViewComponent.cpp RasterizationScale + [propget] HRESULT RasterizationScale([out, retval] double* scale); + /// Set the rasterization scale property. + [propput] HRESULT RasterizationScale([in] double scale); + + /// ShouldDetectMonitorScaleChanges property determines whether the WebView + /// attempts to track monitor DPI scale changes. When true, the WebView will + /// track monitor DPI scale changes, update the RasterizationScale property, + /// and raises RasterizationScaleChanged event. When false, the WebView will + /// not track monitor DPI scale changes, and the app must update the + /// RasterizationScale property itself. RasterizationScaleChanged event will + /// never raise when ShouldDetectMonitorScaleChanges is false. Apps that want + /// to set their own rasterization scale should set this property to false to + /// avoid the WebView2 updating the RasterizationScale property to match the + /// monitor DPI scale. + [propget] HRESULT ShouldDetectMonitorScaleChanges([out, retval] BOOL* value); + /// Set the ShouldDetectMonitorScaleChanges property. + [propput] HRESULT ShouldDetectMonitorScaleChanges([in] BOOL value); + + /// Add an event handler for the RasterizationScaleChanged event. + /// The event is raised when the WebView detects that the monitor DPI scale + /// has changed, ShouldDetectMonitorScaleChanges is true, and the WebView has + /// changed the RasterizationScale property. + /// + /// \snippet ViewComponent.cpp RasterizationScaleChanged + HRESULT add_RasterizationScaleChanged( + [in] ICoreWebView2RasterizationScaleChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + /// Remove an event handler previously added with + /// add_RasterizationScaleChanged. + HRESULT remove_RasterizationScaleChanged( + [in] EventRegistrationToken token); + + /// BoundsMode affects how setting the Bounds and RasterizationScale + /// properties work. Bounds mode can either be in COREWEBVIEW2_BOUNDS_MODE_USE_RAW_PIXELS + /// mode or COREWEBVIEW2_BOUNDS_MODE_USE_RASTERIZATION_SCALE mode. + /// + /// When the mode is in COREWEBVIEW2_BOUNDS_MODE_USE_RAW_PIXELS, setting the bounds + /// property will set the size of the WebView in raw screen pixels. Changing + /// the rasterization scale in this mode won't change the raw pixel size of + /// the WebView and will only change the rasterization scale. + /// + /// When the mode is in COREWEBVIEW2_BOUNDS_MODE_USE_RASTERIZATION_SCALE, setting the + /// bounds property will change the logical size of the WebView which can be + /// described by the following equation: + /// ```text + /// Logical size * rasterization scale = Raw Pixel size + /// ``` + /// In this case, changing the rasterization scale will keep the logical size + /// the same and change the raw pixel size. + /// + /// \snippet ViewComponent.cpp BoundsMode + [propget] HRESULT BoundsMode( + [out, retval] COREWEBVIEW2_BOUNDS_MODE* boundsMode); + /// Set the BoundsMode property. + [propput] HRESULT BoundsMode([in] COREWEBVIEW2_BOUNDS_MODE boundsMode); +} + +/// Represents the WebView2 Environment. WebViews created from an environment +/// run on the browser process specified with environment parameters and +/// objects created from an environment should be used in the same +/// environment. Using it in different environments are not guaranteed to be +/// compatible and may fail. + +[uuid(b96d755e-0319-4e92-a296-23436f46a1fc), object, pointer_default(unique)] +interface ICoreWebView2Environment : IUnknown { + + /// Asynchronously create a new WebView. + /// + /// `parentWindow` is the `HWND` in which the WebView should be displayed and + /// from which receive input. The WebView adds a child window to the + /// provided window before this function returns. Z-order and other things + /// impacted by sibling window order are affected accordingly. If you want to + /// move the WebView to a different parent after it has been created, you must + /// call put_ParentWindow to update tooltip positions, accessibility trees, + /// and such. + /// + /// HWND_MESSAGE is a valid parameter for `parentWindow` for an invisible + /// WebView for Windows 8 and above. In this case the window will never + /// become visible. You are not able to reparent the window after you have + /// created the WebView. This is not supported in Windows 7 or below. + /// Passing this parameter in Windows 7 or below will return + /// ERROR_INVALID_WINDOW_HANDLE in the controller callback. + /// + /// It is recommended that the app set Application User Model ID for the + /// process or the app window. If none is set, during WebView creation a + /// generated Application User Model ID is set to root window of + /// `parentWindow`. + /// + /// \snippet AppWindow.cpp CreateCoreWebView2Controller + /// + /// It is recommended that the app handles restart manager messages, to + /// gracefully restart it in the case when the app is using the WebView2 + /// Runtime from a certain installation and that installation is being + /// uninstalled. For example, if a user installs a version of the WebView2 + /// Runtime and opts to use another version of the WebView2 Runtime for + /// testing the app, and then uninstalls the 1st version of the WebView2 + /// Runtime without closing the app, the app restarts to allow + /// un-installation to succeed. + /// + /// \snippet AppWindow.cpp RestartManager + /// + /// The app should retry `CreateCoreWebView2Controller` upon failure, unless the + /// error code is `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)`. + /// When the app retries `CreateCoreWebView2Controller` upon failure, it is + /// recommended that the app restarts from creating a new WebView2 + /// Environment. If a WebView2 Runtime update happens, the version + /// associated with a WebView2 Environment may have been removed and causing + /// the object to no longer work. Creating a new WebView2 Environment works + /// since it uses the latest version. + /// + /// WebView creation fails with `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` if a + /// running instance using the same user data folder exists, and the Environment + /// objects have different `EnvironmentOptions`. For example, if a WebView was + /// created with one language, an attempt to create a WebView with a different + /// language using the same user data folder will fail. + /// + /// The creation will fail with `E_ABORT` if `parentWindow` is destroyed + /// before the creation is finished. If this is caused by a call to + /// `DestroyWindow`, the creation completed handler will be invoked before + /// `DestroyWindow` returns, so you can use this to cancel creation and clean + /// up resources synchronously when quitting a thread. + /// + /// In rare cases the creation can fail with `E_UNEXPECTED` if runtime does not have + /// permissions to the user data folder. + + HRESULT CreateCoreWebView2Controller( + HWND parentWindow, + ICoreWebView2CreateCoreWebView2ControllerCompletedHandler* handler); + + /// Create a new web resource response object. The `headers` parameter is + /// the raw response header string delimited by newline. It is also possible + /// to create this object with null headers string and then use the + /// `ICoreWebView2HttpResponseHeaders` to construct the headers line by line. + /// For more information about other parameters, navigate to + /// [ICoreWebView2WebResourceResponse](/microsoft-edge/webview2/reference/win32/icorewebview2webresourceresponse). + /// + /// \snippet SettingsComponent.cpp WebResourceRequested0 + /// \snippet SettingsComponent.cpp WebResourceRequested1 + HRESULT CreateWebResourceResponse( + [in] IStream* content, + [in] int statusCode, + [in] LPCWSTR reasonPhrase, + [in] LPCWSTR headers, + [out, retval] ICoreWebView2WebResourceResponse** response); + + /// The browser version info of the current `ICoreWebView2Environment`, + /// including channel name if it is not the WebView2 Runtime. It matches the + /// format of the `GetAvailableCoreWebView2BrowserVersionString` API. + /// Channel names are `beta`, `dev`, and `canary`. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + /// + /// \snippet AppWindow.cpp GetBrowserVersionString + [propget] HRESULT BrowserVersionString([out, retval] LPWSTR* versionInfo); + + /// Add an event handler for the `NewBrowserVersionAvailable` event. + /// `NewBrowserVersionAvailable` runs when a newer version of the WebView2 + /// Runtime is installed and available using WebView2. To use the newer + /// version of the browser you must create a new environment and WebView. + /// The event only runs for new version from the same WebView2 Runtime from + /// which the code is running. When not running with installed WebView2 + /// Runtime, no event is run. + /// + /// Because a user data folder is only able to be used by one browser + /// process at a time, if you want to use the same user data folder in the + /// WebView using the new version of the browser, you must close the + /// environment and instance of WebView that are using the older version of + /// the browser first. Or simply prompt the user to restart the app. + /// + /// \snippet AppWindow.cpp NewBrowserVersionAvailable + HRESULT add_NewBrowserVersionAvailable( + [in] ICoreWebView2NewBrowserVersionAvailableEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_NewBrowserVersionAvailable`. + HRESULT remove_NewBrowserVersionAvailable( + [in] EventRegistrationToken token); +} + +/// Options used to create WebView2 Environment. A default implementation is +/// provided in `WebView2EnvironmentOptions.h`. +/// +/// \snippet AppWindow.cpp CreateCoreWebView2EnvironmentWithOptions + +[uuid(2fde08a8-1e9a-4766-8c05-95a9ceb9d1c5), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions : IUnknown { + + /// Changes the behavior of the WebView. The arguments are passed to the + /// browser process as part of the command. For more information about + /// using command-line switches with Chromium browser processes, navigate to + /// [Run Chromium with Flags](https://www.chromium.org/developers/how-tos/run-chromium-with-flags). + /// The value appended to a switch is appended to the browser process, for + /// example, in `--edge-webview-switches=xxx` the value is `xxx`. If you + /// specify a switch that is important to WebView functionality, it is + /// ignored, for example, `--user-data-dir`. Specific features are disabled + /// internally and blocked from being enabled. If a switch is specified + /// multiple times, only the last instance is used. + /// + /// \> [!NOTE]\n\> A merge of the different values of the same switch is not attempted, + /// except for disabled and enabled features. The features specified by + /// `--enable-features` and `--disable-features` are merged with simple + /// logic.\n\> * The features is the union of the specified features + /// and built-in features. If a feature is disabled, it is removed from the + /// enabled features list. + /// + /// If you specify command-line switches and use the + /// `additionalBrowserArguments` parameter, the `--edge-webview-switches` + /// value takes precedence and is processed last. If a switch fails to + /// parse, the switch is ignored. The default state for the operation is + /// to run the browser process with no extra flags. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT AdditionalBrowserArguments([out, retval] LPWSTR* value); + + /// Sets the `AdditionalBrowserArguments` property. + /// + /// Please note that calling this API twice will replace the previous value + /// rather than appending to it. If there are multiple switches, there + /// should be a space in between them. The one exception is if multiple + /// features are being enabled/disabled for a single switch, in which + /// case the features should be comma-seperated. + /// Ex. "--disable-features=feature1,feature2 --some-other-switch --do-something" + [propput] HRESULT AdditionalBrowserArguments([in] LPCWSTR value); + + /// The default display language for WebView. It applies to browser UI such as + /// context menu and dialogs. It also applies to the `accept-languages` HTTP + /// header that WebView sends to websites. The intended locale value is in the + /// format of BCP 47 Language Tags. More information can be found from + /// [IETF BCP47](https://www.ietf.org/rfc/bcp/bcp47.html). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Language([out, retval] LPWSTR* value); + + /// Sets the `Language` property. + [propput] HRESULT Language([in] LPCWSTR value); + + /// Specifies the version of the WebView2 Runtime binaries required to be + /// compatible with your app. This defaults to the WebView2 Runtime version + /// that corresponds with the version of the SDK the app is using. The + /// format of this value is the same as the format of the + /// `BrowserVersionString` property and other `BrowserVersion` values. Only + /// the version part of the `BrowserVersion` value is respected. The channel + /// suffix, if it exists, is ignored. The version of the WebView2 Runtime + /// binaries actually used may be different from the specified + /// `TargetCompatibleBrowserVersion`. The binaries are only guaranteed to be + /// compatible. Verify the actual version on the `BrowserVersionString` + /// property on the `ICoreWebView2Environment`. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT TargetCompatibleBrowserVersion([out, retval] LPWSTR* value); + + /// Sets the `TargetCompatibleBrowserVersion` property. + [propput] HRESULT TargetCompatibleBrowserVersion([in] LPCWSTR value); + + /// The `AllowSingleSignOnUsingOSPrimaryAccount` property is used to enable + /// single sign on with Azure Active Directory (AAD) and personal Microsoft + /// Account (MSA) resources inside WebView. All AAD accounts, connected to + /// Windows and shared for all apps, are supported. For MSA, SSO is only enabled + /// for the account associated for Windows account login, if any. + /// Default is disabled. Universal Windows Platform apps must also declare + /// `enterpriseCloudSSO` + /// [Restricted capabilities](/windows/uwp/packaging/app-capability-declarations\#restricted-capabilities) + /// for the single sign on (SSO) to work. + [propget] HRESULT AllowSingleSignOnUsingOSPrimaryAccount([out, retval] BOOL* allow); + + /// Sets the `AllowSingleSignOnUsingOSPrimaryAccount` property. + [propput] HRESULT AllowSingleSignOnUsingOSPrimaryAccount([in] BOOL allow); +} + +/// Event args for the `AcceleratorKeyPressed` event. + +[uuid(9f760f8a-fb79-42be-9990-7b56900fa9c7), object, pointer_default(unique)] +interface ICoreWebView2AcceleratorKeyPressedEventArgs : IUnknown { + + /// The key event type that caused the event to run. + + [propget] HRESULT KeyEventKind([out, retval] COREWEBVIEW2_KEY_EVENT_KIND* keyEventKind); + + /// The Win32 virtual key code of the key that was pressed or released. It + /// is one of the Win32 virtual key constants such as `VK_RETURN` or an + /// (uppercase) ASCII value such as `A`. Verify whether Ctrl or Alt + /// are pressed by running `GetKeyState(VK_CONTROL)` or + /// `GetKeyState(VK_MENU)`. + + [propget] HRESULT VirtualKey([out, retval] UINT* virtualKey); + + /// The `LPARAM` value that accompanied the window message. For more + /// information, navigate to [WM_KEYDOWN](/windows/win32/inputdev/wm-keydown) + /// and [WM_KEYUP](/windows/win32/inputdev/wm-keyup). + + [propget] HRESULT KeyEventLParam([out, retval] INT* lParam); + + /// A structure representing the information passed in the `LPARAM` of the + /// window message. + + [propget] HRESULT PhysicalKeyStatus( + [out, retval] COREWEBVIEW2_PHYSICAL_KEY_STATUS* physicalKeyStatus); + + /// During `AcceleratorKeyPressedEvent` handler invocation the WebView is + /// blocked waiting for the decision of if the accelerator is handled by the + /// host (or not). If the `Handled` property is set to `TRUE` then this + /// prevents the WebView from performing the default action for this + /// accelerator key. Otherwise the WebView performs the default action for + /// the accelerator key. + + [propget] HRESULT Handled([out, retval] BOOL* handled); + + /// Sets the `Handled` property. + + [propput] HRESULT Handled([in] BOOL handled); +} + +/// Event args for the BasicAuthenticationRequested event. Will contain the +/// request that led to the HTTP authorization challenge, the challenge +/// and allows the host to provide authentication response or cancel the request. +[uuid(ef05516f-d897-4f9e-b672-d8e2307a3fb0), object, pointer_default(unique)] +interface ICoreWebView2BasicAuthenticationRequestedEventArgs : IUnknown { + /// The URI that led to the authentication challenge. For proxy authentication + /// requests, this will be the URI of the proxy server. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Uri([out, retval] LPWSTR* value); + + /// The authentication challenge string + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Challenge([out, retval] LPWSTR* challenge); + + /// Response to the authentication request with credentials. This object will be populated by the app + /// if the host would like to provide authentication credentials. + [propget] HRESULT Response([out, retval] ICoreWebView2BasicAuthenticationResponse** response); + + /// Cancel the authentication request. False by default. + /// If set to true, Response will be ignored. + [propget] HRESULT Cancel([out, retval] BOOL* cancel); + /// Set the Cancel property. + [propput] HRESULT Cancel([in] BOOL cancel); + + /// Returns an `ICoreWebView2Deferral` object. Use this deferral to + /// defer the decision to show the Basic Authentication dialog. + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// Represents a Basic HTTP authentication response that contains a user name +/// and a password as according to RFC7617 (https://tools.ietf.org/html/rfc7617) +[uuid(07023f7d-2d77-4d67-9040-6e7d428c6a40), object, pointer_default(unique)] +interface ICoreWebView2BasicAuthenticationResponse : IUnknown { + /// User name provided for authentication. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT UserName([out, retval] LPWSTR* userName); + /// Set user name property + [propput] HRESULT UserName([in] LPCWSTR userName); + + /// Password provided for authentication. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Password([out, retval] LPWSTR* password); + /// Set password property + [propput] HRESULT Password([in] LPCWSTR password); +} + +/// Provides a set of properties for managing an Extension, which includes +/// an ID, name, and whether it is enabled or not, and the ability to Remove +/// the Extension, and enable or disable it. +[uuid(7EF7FFA0-FAC5-462C-B189-3D9EDBE575DA), object, pointer_default(unique)] +interface ICoreWebView2BrowserExtension : IUnknown { + /// This is the browser extension's ID. This is the same browser extension ID returned by + /// the browser extension API [`chrome.runtime.id`](https://developer.mozilla.org/docs/Mozilla/Add-ons/WebExtensions/API/runtime/id). + /// Please see that documentation for more details on how the ID is generated. + /// After an extension is removed, calling `Id` will return the id of the extension that is removed. + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Id([out, retval] LPWSTR* value); + /// This is the browser extension's name. This value is defined in this browser extension's + /// manifest.json file. If manifest.json define extension's localized name, this value will + /// be the localized version of the name. + /// Please see [Manifest.json name](https://developer.mozilla.org/docs/Mozilla/Add-ons/WebExtensions/manifest.json/name) + /// for more details. + /// After an extension is removed, calling `Name` will return the name of the extension that is removed. + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Name([out, retval] LPWSTR* value); + /// Removes this browser extension from its WebView2 Profile. The browser extension is removed + /// immediately including from all currently running HTML documents associated with this + /// WebView2 Profile. The removal is persisted and future uses of this profile will not have this + /// extension installed. After an extension is removed, calling `Remove` again will cause an exception. + HRESULT Remove([in] ICoreWebView2BrowserExtensionRemoveCompletedHandler* handler); + /// If `isEnabled` is true then the Extension is enabled and running in WebView instances. + /// If it is false then the Extension is disabled and not running in WebView instances. + /// When a Extension is first installed, `IsEnable` are default to be `TRUE`. + /// `isEnabled` is persisted per profile. + /// After an extension is removed, calling `isEnabled` will return the value at the time it was removed. + [propget] HRESULT IsEnabled([out, retval] BOOL* value); + /// Sets whether this browser extension is enabled or disabled. This change applies immediately + /// to the extension in all HTML documents in all WebView2s associated with this profile. + /// After an extension is removed, calling `Enable` will not change the value of `IsEnabled`. + HRESULT Enable([in] BOOL isEnabled, [in] ICoreWebView2BrowserExtensionEnableCompletedHandler* handler); +} + +/// Provides access to the certificate metadata. +[uuid(C5FB2FCE-1CAC-4AEE-9C79-5ED0362EAAE0), object, pointer_default(unique)] +interface ICoreWebView2Certificate : IUnknown { + /// Subject of the certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Subject([out, retval] LPWSTR* value); + /// Name of the certificate authority that issued the certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Issuer([out, retval] LPWSTR* value); + /// The valid start date and time for the certificate as the number of seconds since + /// the UNIX epoch. + [propget] HRESULT ValidFrom([out, retval] double* value); + /// The valid expiration date and time for the certificate as the number of seconds since + /// the UNIX epoch. + [propget] HRESULT ValidTo([out, retval] double* value); + /// Base64 encoding of DER encoded serial number of the certificate. + /// Read more about DER at [RFC 7468 DER] + /// (https://tools.ietf.org/html/rfc7468#appendix-B). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT DerEncodedSerialNumber([out, retval] LPWSTR* value); + /// Display name for a certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings) + [propget] HRESULT DisplayName([out, retval] LPWSTR* value); + /// PEM encoded data for the certificate. + /// Returns Base64 encoding of DER encoded certificate. + /// Read more about PEM at [RFC 1421 Privacy Enhanced Mail] + /// (https://tools.ietf.org/html/rfc1421). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings) + HRESULT ToPemEncoding([out, retval] LPWSTR* pemEncodedData); + /// Collection of PEM encoded certificate issuer chain. + /// In this collection first element is the current certificate followed by + /// intermediate1, intermediate2...intermediateN-1. Root certificate is the + /// last element in collection. + [propget] HRESULT PemEncodedIssuerCertificateChain([out, retval] + ICoreWebView2StringCollection** value); +} + +/// Provides access to the client certificate metadata. +[uuid(e7188076-bcc3-11eb-8529-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2ClientCertificate : IUnknown { + /// Subject of the certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Subject([out, retval] LPWSTR* value); + /// Name of the certificate authority that issued the certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Issuer([out, retval] LPWSTR* value); + /// The valid start date and time for the certificate as the number of seconds since + /// the UNIX epoch. + [propget] HRESULT ValidFrom([out, retval] double* value); + /// The valid expiration date and time for the certificate as the number of seconds since + /// the UNIX epoch. + [propget] HRESULT ValidTo([out, retval] double* value); + /// Base64 encoding of DER encoded serial number of the certificate. + /// Read more about DER at [RFC 7468 DER] + /// (https://tools.ietf.org/html/rfc7468#appendix-B). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT DerEncodedSerialNumber([out, retval] LPWSTR* value); + /// Display name for a certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT DisplayName([out, retval] LPWSTR* value); + /// PEM encoded data for the certificate. + /// Returns Base64 encoding of DER encoded certificate. + /// Read more about PEM at [RFC 1421 Privacy Enhanced Mail] + /// (https://tools.ietf.org/html/rfc1421). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + HRESULT ToPemEncoding([out, retval] LPWSTR* pemEncodedData); + /// Collection of PEM encoded client certificate issuer chain. + /// In this collection first element is the current certificate followed by + /// intermediate1, intermediate2...intermediateN-1. Root certificate is the + /// last element in collection. + [propget] HRESULT PemEncodedIssuerCertificateChain([out, retval] + ICoreWebView2StringCollection** value); + /// Kind of a certificate (eg., smart card, pin, other). + [propget] HRESULT Kind([out, retval] + COREWEBVIEW2_CLIENT_CERTIFICATE_KIND* value); +} + +/// Event args for the `ClientCertificateRequested` event. +[uuid(bc59db28-bcc3-11eb-8529-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2ClientCertificateRequestedEventArgs : IUnknown { + /// Host name of the server that requested client certificate authentication. + /// Normalization rules applied to the hostname are: + /// * Convert to lowercase characters for ascii characters. + /// * Punycode is used for representing non ascii characters. + /// * Strip square brackets for IPV6 address. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Host([out, retval] LPWSTR* value); + + /// Port of the server that requested client certificate authentication. + [propget] HRESULT Port([out, retval] int* value); + + /// Returns true if the server that issued this request is an http proxy. + /// Returns false if the server is the origin server. + [propget] HRESULT IsProxy([out, retval] BOOL* value); + + /// Returns the `ICoreWebView2StringCollection`. + /// The collection contains Base64 encoding of DER encoded distinguished names of + /// certificate authorities allowed by the server. + [propget] HRESULT AllowedCertificateAuthorities([out, retval] + ICoreWebView2StringCollection** value); + + /// Returns the `ICoreWebView2ClientCertificateCollection` when client + /// certificate authentication is requested. The collection contains mutually + /// trusted CA certificates. + [propget] HRESULT MutuallyTrustedCertificates([out, retval] + ICoreWebView2ClientCertificateCollection** value); + + /// Returns the selected certificate. + [propget] HRESULT SelectedCertificate([out, retval] + ICoreWebView2ClientCertificate** value); + + /// Sets the certificate to respond to the server. + [propput] HRESULT SelectedCertificate( + [in] ICoreWebView2ClientCertificate* value); + + /// You may set this flag to cancel the certificate selection. If canceled, + /// the request is aborted regardless of the `Handled` property. By default the + /// value is `FALSE`. + [propget] HRESULT Cancel([out, retval] BOOL* value); + + /// Sets the `Cancel` property. + [propput] HRESULT Cancel([in] BOOL value); + + /// You may set this flag to `TRUE` to respond to the server with or + /// without a certificate. If this flag is `TRUE` with a `SelectedCertificate` + /// it responds to the server with the selected certificate otherwise respond to the + /// server without a certificate. By default the value of `Handled` and `Cancel` are `FALSE` + /// and display default client certificate selection dialog prompt to allow the user to + /// choose a certificate. The `SelectedCertificate` is ignored unless `Handled` is set `TRUE`. + [propget] HRESULT Handled([out, retval] BOOL* value); + + /// Sets the `Handled` property. + [propput] HRESULT Handled([in] BOOL value); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to + /// complete the event at a later time. + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// This interface is an extension of the ICoreWebView2Controller interface to +/// support visual hosting. An object implementing the +/// ICoreWebView2CompositionController interface will also implement +/// ICoreWebView2Controller. Callers are expected to use +/// ICoreWebView2Controller for resizing, visibility, focus, and so on, and +/// then use ICoreWebView2CompositionController to connect to a composition +/// tree and provide input meant for the WebView. +[uuid(3df9b733-b9ae-4a15-86b4-eb9ee9826469), object, pointer_default(unique)] +interface ICoreWebView2CompositionController : IUnknown { + /// The RootVisualTarget is a visual in the hosting app's visual tree. This + /// visual is where the WebView will connect its visual tree. The app uses + /// this visual to position the WebView within the app. The app still needs + /// to use the Bounds property to size the WebView. The RootVisualTarget + /// property can be an IDCompositionVisual or a + /// Windows::UI::Composition::ContainerVisual. WebView will connect its visual + /// tree to the provided visual before returning from the property setter. The + /// app needs to commit on its device setting the RootVisualTarget property. + /// The RootVisualTarget property supports being set to nullptr to disconnect + /// the WebView from the app's visual tree. + /// \snippet ViewComponent.cpp SetRootVisualTarget + /// \snippet ViewComponent.cpp BuildDCompTree + [propget] HRESULT RootVisualTarget([out, retval] IUnknown** target); + /// Set the RootVisualTarget property. + [propput] HRESULT RootVisualTarget([in] IUnknown* target); + + /// If eventKind is COREWEBVIEW2_MOUSE_EVENT_KIND_HORIZONTAL_WHEEL or + /// COREWEBVIEW2_MOUSE_EVENT_KIND_WHEEL, then mouseData specifies the amount of + /// wheel movement. A positive value indicates that the wheel was rotated + /// forward, away from the user; a negative value indicates that the wheel was + /// rotated backward, toward the user. One wheel click is defined as + /// WHEEL_DELTA, which is 120. + /// If eventKind is COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOUBLE_CLICK + /// COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_DOWN, or + /// COREWEBVIEW2_MOUSE_EVENT_KIND_X_BUTTON_UP, then mouseData specifies which X + /// buttons were pressed or released. This value should be 1 if the first X + /// button is pressed/released and 2 if the second X button is + /// pressed/released. + /// If eventKind is COREWEBVIEW2_MOUSE_EVENT_KIND_LEAVE, then virtualKeys, + /// mouseData, and point should all be zero. + /// If eventKind is any other value, then mouseData should be zero. + /// Point is expected to be in the client coordinate space of the WebView. + /// To track mouse events that start in the WebView and can potentially move + /// outside of the WebView and host application, calling SetCapture and + /// ReleaseCapture is recommended. + /// To dismiss hover popups, it is also recommended to send + /// COREWEBVIEW2_MOUSE_EVENT_KIND_LEAVE messages. + /// \snippet ViewComponent.cpp SendMouseInput + HRESULT SendMouseInput( + [in] COREWEBVIEW2_MOUSE_EVENT_KIND eventKind, + [in] COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS virtualKeys, + [in] UINT32 mouseData, + [in] POINT point); + + /// SendPointerInput accepts touch or pen pointer input of types defined in + /// COREWEBVIEW2_POINTER_EVENT_KIND. Any pointer input from the system must be + /// converted into an ICoreWebView2PointerInfo first. + HRESULT SendPointerInput( + [in] COREWEBVIEW2_POINTER_EVENT_KIND eventKind, + [in] ICoreWebView2PointerInfo* pointerInfo); + + /// The current cursor that WebView thinks it should be. The cursor should be + /// set in WM_SETCURSOR through \::SetCursor or set on the corresponding + /// parent/ancestor HWND of the WebView through \::SetClassLongPtr. The HCURSOR + /// can be freed so CopyCursor/DestroyCursor is recommended to keep your own + /// copy if you are doing more than immediately setting the cursor. + [propget] HRESULT Cursor([out, retval] HCURSOR* cursor); + + /// The current system cursor ID reported by the underlying rendering engine + /// for WebView. For example, most of the time, when the cursor is over text, + /// this will return the int value for IDC_IBEAM. The systemCursorId is only + /// valid if the rendering engine reports a default Windows cursor resource + /// value. Navigate to + /// [LoadCursorW](/windows/win32/api/winuser/nf-winuser-loadcursorw) for more + /// details. Otherwise, if custom CSS cursors are being used, this will return + /// 0. To actually use systemCursorId in LoadCursor or LoadImage, + /// MAKEINTRESOURCE must be called on it first. + /// + /// \snippet ViewComponent.cpp SystemCursorId + [propget] HRESULT SystemCursorId([out, retval] UINT32* systemCursorId); + + /// Add an event handler for the CursorChanged event. + /// The event is raised when WebView thinks the cursor should be changed. For + /// example, when the mouse cursor is currently the default cursor but is then + /// moved over text, it may try to change to the IBeam cursor. + /// + /// It is expected for the developer to send + /// COREWEBVIEW2_MOUSE_EVENT_KIND_LEAVE messages (in addition to + /// COREWEBVIEW2_MOUSE_EVENT_KIND_MOVE messages) through the SendMouseInput + /// API. This is to ensure that the mouse is actually within the WebView that + /// sends out CursorChanged events. + /// + /// \snippet ViewComponent.cpp CursorChanged + HRESULT add_CursorChanged( + [in] ICoreWebView2CursorChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + /// Remove an event handler previously added with add_CursorChanged. + HRESULT remove_CursorChanged( + [in] EventRegistrationToken token); +} + +/// This interface is the continuation of the +/// ICoreWebView2CompositionController2 interface to manage drag and drop. +[uuid(9570570e-4d76-4361-9ee1-f04d0dbdfb1e), object, pointer_default(unique)] +interface ICoreWebView2CompositionController3 : ICoreWebView2CompositionController2 { + /// This function corresponds to [IDropTarget::DragEnter](/windows/win32/api/oleidl/nf-oleidl-idroptarget-dragenter). + /// + /// This function has a dependency on AllowExternalDrop property of + /// CoreWebView2Controller and return E_FAIL to callers to indicate this + /// operation is not allowed if AllowExternalDrop property is set to false. + /// + /// The hosting application must register as an IDropTarget and implement + /// and forward DragEnter calls to this function. + /// + /// point parameter must be modified to include the WebView's offset and be in + /// the WebView's client coordinates (Similar to how SendMouseInput works). + /// + /// \snippet DropTarget.cpp DragEnter + HRESULT DragEnter( + [in] IDataObject* dataObject, + [in] DWORD keyState, + [in] POINT point, + [out, retval] DWORD* effect); + + /// This function corresponds to [IDropTarget::DragLeave](/windows/win32/api/oleidl/nf-oleidl-idroptarget-dragleave). + /// + /// This function has a dependency on AllowExternalDrop property of + /// CoreWebView2Controller and return E_FAIL to callers to indicate this + /// operation is not allowed if AllowExternalDrop property is set to false. + /// + /// The hosting application must register as an IDropTarget and implement + /// and forward DragLeave calls to this function. + /// + /// \snippet DropTarget.cpp DragLeave + HRESULT DragLeave(); + + /// This function corresponds to [IDropTarget::DragOver](/windows/win32/api/oleidl/nf-oleidl-idroptarget-dragover). + /// + /// This function has a dependency on AllowExternalDrop property of + /// CoreWebView2Controller and return E_FAIL to callers to indicate this + /// operation is not allowed if AllowExternalDrop property is set to false. + /// + /// The hosting application must register as an IDropTarget and implement + /// and forward DragOver calls to this function. + /// + /// point parameter must be modified to include the WebView's offset and be in + /// the WebView's client coordinates (Similar to how SendMouseInput works). + /// + /// \snippet DropTarget.cpp DragOver + HRESULT DragOver( + [in] DWORD keyState, + [in] POINT point, + [out, retval] DWORD* effect); + + /// This function corresponds to [IDropTarget::Drop](/windows/win32/api/oleidl/nf-oleidl-idroptarget-drop). + /// + /// This function has a dependency on AllowExternalDrop property of + /// CoreWebView2Controller and return E_FAIL to callers to indicate this + /// operation is not allowed if AllowExternalDrop property is set to false. + /// + /// The hosting application must register as an IDropTarget and implement + /// and forward Drop calls to this function. + /// + /// point parameter must be modified to include the WebView's offset and be in + /// the WebView's client coordinates (Similar to how SendMouseInput works). + /// + /// \snippet DropTarget.cpp Drop + HRESULT Drop( + [in] IDataObject* dataObject, + [in] DWORD keyState, + [in] POINT point, + [out, retval] DWORD* effect); +} + +/// This Interface includes an API which enables non-client hit-testing support for WebView2. +[uuid(7C367B9B-3D2B-450F-9E58-D61A20F486AA), object, pointer_default(unique)] +interface ICoreWebView2CompositionController4 : ICoreWebView2CompositionController3 { + /// If you are hosting a WebView2 using CoreWebView2CompositionController, you can call + /// this method in your Win32 WndProc to determine if the mouse is moving over or + /// clicking on WebView2 web content that should be considered part of a non-client region. + + /// The point parameter is expected to be in the client coordinate space of WebView2. + /// The method sets the out parameter value as follows: + /// - COREWEBVIEW2_NON_CLIENT_REGION_KIND_CAPTION when point corresponds to + /// a region (HTML element) within the WebView2 with + /// `-webkit-app-region: drag` CSS style set. + /// - COREWEBVIEW2_NON_CLIENT_REGION_KIND_CLIENT when point corresponds to + /// a region (HTML element) within the WebView2 without + /// `-webkit-app-region: drag` CSS style set. + /// - COREWEBVIEW2_NON_CLIENT_REGION_KIND_NOWHERE when point is not within the WebView2. + /// + /// NOTE: in order for WebView2 to properly handle the title bar system menu, + /// the app needs to send WM_NCRBUTTONDOWN and WM_NCRBUTTONUP to SendMouseInput. + /// See sample code below. + /// \snippet ViewComponent.cpp DraggableRegions2 + /// + /// \snippet ViewComponent.cpp DraggableRegions1 + HRESULT GetNonClientRegionAtPoint( + [in] POINT point, + [out, retval] COREWEBVIEW2_NON_CLIENT_REGION_KIND* value); + + /// This method is used to get the collection of rects that correspond + /// to a particular COREWEBVIEW2_NON_CLIENT_REGION_KIND. This is to be used in + /// the callback of add_NonClientRegionChanged whose event args object contains + /// a region property of type COREWEBVIEW2_NON_CLIENT_REGION_KIND. + /// + /// \snippet ScenarioNonClientRegionSupport.cpp AddChangeListener + HRESULT QueryNonClientRegion( + [in] COREWEBVIEW2_NON_CLIENT_REGION_KIND kind, + [out, retval] ICoreWebView2RegionRectCollectionView** rects); + + /// This method is used to add a listener for NonClientRegionChanged. + /// The event is fired when regions which are marked as non-client in the + /// app html have changed. So either when new regions have been marked, + /// or unmarked, or the region(s) have been changed to a different kind. + /// + /// \snippet ScenarioNonClientRegionSupport.cpp AddChangeListener + HRESULT add_NonClientRegionChanged( + [in] ICoreWebView2NonClientRegionChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// This method is used to remove an event handler previously added with + /// add_NonClientRegionChanged + HRESULT remove_NonClientRegionChanged([in] EventRegistrationToken token); +} + +/// Represents a context menu item of a context menu displayed by WebView. +[uuid(7aed49e3-a93f-497a-811c-749c6b6b6c65), object, pointer_default(unique)] +interface ICoreWebView2ContextMenuItem : IUnknown { + /// Gets the unlocalized name for the `ContextMenuItem`. Use this to + /// distinguish between context menu item types. This will be the English + /// label of the menu item in lower camel case. For example, the "Save as" + /// menu item will be "saveAs". Extension menu items will be "extension", + /// custom menu items will be "custom" and spellcheck items will be + /// "spellCheck". + /// Some example context menu item names are: + /// - "saveAs" + /// - "copyImage" + /// - "openLinkInNewWindow" + /// - "cut" + /// - "copy" + /// - "paste" + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Name([out, retval] LPWSTR* value); + + /// Gets the localized label for the `ContextMenuItem`. Will contain an + /// ampersand for characters to be used as keyboard accelerator. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Label([out, retval] LPWSTR* value); + + /// Gets the Command ID for the `ContextMenuItem`. Use this to report the + /// `SelectedCommandId` in `ContextMenuRequested` event. + [propget] HRESULT CommandId([out, retval] INT32* value); + + /// Gets the localized keyboard shortcut for this ContextMenuItem. It will be + /// the empty string if there is no keyboard shortcut. This is text intended + /// to be displayed to the end user to show the keyboard shortcut. For example + /// this property is Ctrl+Shift+I for the "Inspect" `ContextMenuItem`. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ShortcutKeyDescription([out, retval] LPWSTR* value); + + /// Gets the Icon for the `ContextMenuItem` in PNG, Bitmap or SVG formats in the form of an IStream. + /// Stream will be rewound to the start of the image data. + [propget] HRESULT Icon([out, retval] IStream** value); + + /// Gets the `ContextMenuItem` kind. + [propget] HRESULT Kind([out, retval] COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND* value); + + /// Sets the enabled property of the `ContextMenuItem`. Must only be used in the case of a + /// custom context menu item. The default value for this is `TRUE`. + [propput] HRESULT IsEnabled([in] BOOL value); + + /// Gets the enabled property of the `ContextMenuItem`. + [propget] HRESULT IsEnabled([out, retval] BOOL* value); + + /// Sets the checked property of the `ContextMenuItem`. Must only be used for custom context + /// menu items that are of kind Check box or Radio. + [propput] HRESULT IsChecked([in] BOOL value); + + /// Gets the checked property of the `ContextMenuItem`, used if the kind is Check box or Radio. + [propget] HRESULT IsChecked([out, retval] BOOL* value); + + /// Gets the list of children menu items through a `ContextMenuItemCollection` + /// if the kind is Submenu. If the kind is not submenu, will return null. + [propget] HRESULT Children([out, retval] ICoreWebView2ContextMenuItemCollection** value); + + /// Add an event handler for the `CustomItemSelected` event. + /// `CustomItemSelected` event is raised when the user selects this `ContextMenuItem`. + /// Will only be raised for end developer created context menu items + HRESULT add_CustomItemSelected( + [in] ICoreWebView2CustomItemSelectedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_CustomItemSelected`. + HRESULT remove_CustomItemSelected( + [in] EventRegistrationToken token); +} + +/// Represents the information regarding the context menu target. +/// Includes the context selected and the appropriate data used for the actions of a context menu. +[uuid(b8611d99-eed6-4f3f-902c-a198502ad472), object, pointer_default(unique)] +interface ICoreWebView2ContextMenuTarget : IUnknown { + /// Gets the kind of context that the user selected. + [propget] HRESULT Kind([out, retval] COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND* value); + + /// Returns TRUE if the context menu is requested on an editable component. + [propget] HRESULT IsEditable([out, retval] BOOL* value); + + /// Returns TRUE if the context menu was requested on the main frame and + /// FALSE if invoked on another frame. + [propget] HRESULT IsRequestedForMainFrame([out, retval] BOOL* value); + + /// Gets the uri of the page. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT PageUri([out, retval] LPWSTR* value); + + /// Gets the uri of the frame. Will match the PageUri if `IsRequestedForMainFrame` is TRUE. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FrameUri([out, retval] LPWSTR* value); + + /// Returns TRUE if the context menu is requested on HTML containing an anchor tag. + [propget] HRESULT HasLinkUri([out, retval] BOOL* value); + + /// Gets the uri of the link (if `HasLinkUri` is TRUE, null otherwise). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT LinkUri([out, retval] LPWSTR* value); + + /// Returns TRUE if the context menu is requested on text element that contains an anchor tag. + [propget] HRESULT HasLinkText([out, retval] BOOL* value); + + /// Gets the text of the link (if `HasLinkText` is TRUE, null otherwise). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT LinkText([out, retval] LPWSTR * value); + + /// Returns TRUE if the context menu is requested on HTML containing a source uri. + [propget] HRESULT HasSourceUri([out, retval] BOOL* value); + + /// Gets the active source uri of element (if `HasSourceUri` is TRUE, null otherwise). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT SourceUri([out, retval] LPWSTR* value); + + /// Returns TRUE if the context menu is requested on a selection. + [propget] HRESULT HasSelection([out, retval] BOOL* value); + + /// Gets the selected text (if `HasSelection` is TRUE, null otherwise). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT SelectionText([out, retval] LPWSTR* value); +} + +/// Event args for the `ContextMenuRequested` event. Will contain the selection information +/// and a collection of all of the default context menu items that the WebView +/// would show. Allows the app to draw its own context menu or add/remove +/// from the default context menu. +[uuid(a1d309ee-c03f-11eb-8529-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2ContextMenuRequestedEventArgs : IUnknown { + /// Gets the collection of `ContextMenuItem` objects. + /// See `ICoreWebView2ContextMenuItemCollection` for more details. + [propget] HRESULT MenuItems([out, retval] ICoreWebView2ContextMenuItemCollection** value); + + /// Gets the target information associated with the requested context menu. + /// See `ICoreWebView2ContextMenuTarget` for more details. + [propget] HRESULT ContextMenuTarget([out, retval] ICoreWebView2ContextMenuTarget** value); + + /// Gets the coordinates where the context menu request occurred in relation to the upper + /// left corner of the WebView bounds. + [propget] HRESULT Location([out, retval] POINT* value); + + /// Sets the selected context menu item's command ID. When this is set, + /// WebView will execute the selected command. This + /// value should always be obtained via the selected `ContextMenuItem`'s `CommandId` property. + /// The default value is -1 which means that no selection occurred. The app can + /// also report the selected command ID for a custom context menu item, which + /// will cause the `CustomItemSelected` event to be fired for the custom item, however + /// while command IDs for each custom context menu item is unique + /// during a ContextMenuRequested event, CoreWebView2 may reassign command ID + /// values of deleted custom ContextMenuItems to new objects and the command + /// ID assigned to the same custom item can be different between each app runtime. + [propput] HRESULT SelectedCommandId([in] INT32 value); + + /// Gets the selected CommandId. + [propget] HRESULT SelectedCommandId([out, retval] INT32* value); + + /// Sets whether the `ContextMenuRequested` event is handled by host after + /// the event handler completes or if there is a deferral then after the deferral is completed. + /// If `Handled` is set to TRUE then WebView will not display a context menu and will instead + /// use the `SelectedCommandId` property to indicate which, if any, context menu item command to invoke. + /// If after the event handler or deferral completes `Handled` is set to FALSE then WebView + /// will display a context menu based on the contents of the `MenuItems` property. + /// The default value is FALSE. + [propput] HRESULT Handled([in] BOOL value); + + /// Gets whether the `ContextMenuRequested` event is handled by host. + [propget] HRESULT Handled([out, retval] BOOL* value); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to + /// complete the event when the custom context menu is closed. + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// This interface is used to manage profile options that created by 'CreateCoreWebView2ControllerOptions'. +/// +/// \snippet AppWindow.cpp CreateControllerWithOptions +[uuid(12aae616-8ccb-44ec-bcb3-eb1831881635), object, pointer_default(unique)] +interface ICoreWebView2ControllerOptions : IUnknown { + /// `ProfileName` property is to specify a profile name, which is only allowed to contain + /// the following ASCII characters. It has a maximum length of 64 characters excluding the null-terminator. + /// It is ASCII case insensitive. + /// + /// * alphabet characters: a-z and A-Z + /// * digit characters: 0-9 + /// * and '#', '@', '$', '(', ')', '+', '-', '_', '~', '.', ' ' (space). + /// + /// Note: the text must not end with a period '.' or ' ' (space). And, although upper-case letters are + /// allowed, they're treated just as lower-case counterparts because the profile name will be mapped to + /// the real profile directory path on disk and Windows file system handles path names in a case-insensitive way. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ProfileName([out, retval] LPWSTR* value); + /// Sets the `ProfileName` property. + [propput] HRESULT ProfileName([in] LPCWSTR value); + + /// `IsInPrivateModeEnabled` property is to enable/disable InPrivate mode. + [propget] HRESULT IsInPrivateModeEnabled([out, retval] BOOL* value); + /// Sets the `IsInPrivateModeEnabled` property. + [propput] HRESULT IsInPrivateModeEnabled([in] BOOL value); +} + +/// Provides a set of properties that are used to manage an +/// ICoreWebView2Cookie. +/// +/// \snippet ScenarioCookieManagement.cpp CookieObject +[uuid(AD26D6BE-1486-43E6-BF87-A2034006CA21), object, pointer_default(unique)] +interface ICoreWebView2Cookie : IUnknown { + /// Cookie name. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Name([out, retval] LPWSTR* name); + + /// Cookie value. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Value([out, retval] LPWSTR* value); + /// Set the cookie value property. + [propput] HRESULT Value([in] LPCWSTR value); + + /// The domain for which the cookie is valid. + /// The default is the host that this cookie has been received from. + /// Note that, for instance, ".bing.com", "bing.com", and "www.bing.com" are + /// considered different domains. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Domain([out, retval] LPWSTR* domain); + + /// The path for which the cookie is valid. The default is "/", which means + /// this cookie will be sent to all pages on the Domain. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Path([out, retval] LPWSTR* path); + + /// The expiration date and time for the cookie as the number of seconds since the UNIX epoch. + /// The default is -1.0, which means cookies are session cookies by default. + [propget] HRESULT Expires([out, retval] double* expires); + /// Set the Expires property. Cookies are session cookies and will not be + /// persistent if Expires is set to -1.0. NaN, infinity, and any negative + /// value set other than -1.0 is disallowed. + [propput] HRESULT Expires([in] double expires); + + /// Whether this cookie is http-only. + /// True if a page script or other active content cannot access this + /// cookie. The default is false. + [propget] HRESULT IsHttpOnly([out, retval] BOOL* isHttpOnly); + /// Set the IsHttpOnly property. + [propput] HRESULT IsHttpOnly([in] BOOL isHttpOnly); + + /// SameSite status of the cookie which represents the enforcement mode of the cookie. + /// The default is COREWEBVIEW2_COOKIE_SAME_SITE_KIND_LAX. + [propget] HRESULT SameSite([out, retval] COREWEBVIEW2_COOKIE_SAME_SITE_KIND* sameSite); + /// Set the SameSite property. + [propput] HRESULT SameSite([in] COREWEBVIEW2_COOKIE_SAME_SITE_KIND sameSite); + + /// The security level of this cookie. True if the client is only to return + /// the cookie in subsequent requests if those requests use HTTPS. + /// The default is false. + /// Note that cookie that requests COREWEBVIEW2_COOKIE_SAME_SITE_KIND_NONE but + /// is not marked Secure will be rejected. + [propget] HRESULT IsSecure([out, retval] BOOL* isSecure); + /// Set the IsSecure property. + [propput] HRESULT IsSecure([in] BOOL isSecure); + + /// Whether this is a session cookie. The default is false. + [propget] HRESULT IsSession([out, retval] BOOL* isSession); +} + +/// Creates, adds or updates, gets, or or view the cookies. The changes would +/// apply to the context of the user profile. That is, other WebViews under the +/// same user profile could be affected. +[uuid(177CD9E7-B6F5-451A-94A0-5D7A3A4C4141), object, pointer_default(unique)] +interface ICoreWebView2CookieManager : IUnknown { + /// Create a cookie object with a specified name, value, domain, and path. + /// One can set other optional properties after cookie creation. + /// This only creates a cookie object and it is not added to the cookie + /// manager until you call AddOrUpdateCookie. + /// Leading or trailing whitespace(s), empty string, and special characters + /// are not allowed for name. + /// See ICoreWebView2Cookie for more details. + HRESULT CreateCookie( + [in] LPCWSTR name, + [in] LPCWSTR value, + [in] LPCWSTR domain, + [in] LPCWSTR path, + [out, retval] ICoreWebView2Cookie** cookie); + + /// Creates a cookie whose params matches those of the specified cookie. + HRESULT CopyCookie( + [in] ICoreWebView2Cookie* cookieParam, + [out, retval] ICoreWebView2Cookie** cookie); + + /// Gets a list of cookies matching the specific URI. + /// If uri is empty string or null, all cookies under the same profile are + /// returned. + /// You can modify the cookie objects by calling + /// ICoreWebView2CookieManager::AddOrUpdateCookie, and the changes + /// will be applied to the webview. + /// \snippet ScenarioCookieManagement.cpp GetCookies + HRESULT GetCookies( + [in] LPCWSTR uri, + [in] ICoreWebView2GetCookiesCompletedHandler* handler); + + /// Adds or updates a cookie with the given cookie data; may overwrite + /// cookies with matching name, domain, and path if they exist. + /// This method will fail if the domain of the given cookie is not specified. + /// \snippet ScenarioCookieManagement.cpp AddOrUpdateCookie + HRESULT AddOrUpdateCookie([in] ICoreWebView2Cookie* cookie); + + /// Deletes a cookie whose name and domain/path pair + /// match those of the specified cookie. + HRESULT DeleteCookie([in] ICoreWebView2Cookie* cookie); + + /// Deletes cookies with matching name and uri. + /// Cookie name is required. + /// All cookies with the given name where domain + /// and path match provided URI are deleted. + HRESULT DeleteCookies([in] LPCWSTR name, [in] LPCWSTR uri); + + /// Deletes cookies with matching name and domain/path pair. + /// Cookie name is required. + /// If domain is specified, deletes only cookies with the exact domain. + /// If path is specified, deletes only cookies with the exact path. + HRESULT DeleteCookiesWithDomainAndPath([in] LPCWSTR name, [in] LPCWSTR domain, [in] LPCWSTR path); + + /// Deletes all cookies under the same profile. + /// This could affect other WebViews under the same user profile. + HRESULT DeleteAllCookies(); +} + +/// Represents the registration of a custom scheme with the +/// CoreWebView2Environment. +/// This allows the WebView2 app to be able to handle WebResourceRequested +/// event for requests with the specified scheme and be able to navigate the +/// WebView2 to the custom scheme. Once the environment is created, the +/// registrations are valid and immutable throughout the lifetime of the +/// associated WebView2s' browser process and any WebView2 environments +/// sharing the browser process must be created with identical custom scheme +/// registrations, otherwise the environment creation will fail. +/// Any further attempts to register the same scheme will fail during environment creation. +/// The URIs of registered custom schemes will be treated similar to http +/// URIs for their origins. +/// They will have tuple origins for URIs with host and opaque origins for +/// URIs without host as specified in +/// [7.5 Origin - HTML Living Standard](https://html.spec.whatwg.org/multipage/origin.html) +/// +/// Example: +/// `custom-scheme-with-host://hostname/path/to/resource` has origin of +/// `custom-scheme-with-host://hostname`. +/// `custom-scheme-without-host:path/to/resource` has origin of +/// `custom-scheme-without-host:path/to/resource`. +/// For WebResourceRequested event, the cases of request URIs and filter URIs +/// with custom schemes will be normalized according to generic URI syntax +/// rules. Any non-ASCII characters will be preserved. +/// The registered custom schemes also participate in +/// [CORS](https://developer.mozilla.org/docs/Web/HTTP/CORS) and +/// adheres to [CSP](https://developer.mozilla.org/docs/Web/HTTP/CSP). +/// The app needs to set the appropriate access headers in its +/// WebResourceRequested event handler to allow CORS requests. +/// \snippet AppWindow.cpp CoreWebView2CustomSchemeRegistration +[uuid(d60ac92c-37a6-4b26-a39e-95cfe59047bb), object, pointer_default(unique)] +interface ICoreWebView2CustomSchemeRegistration : IUnknown { + /// The name of the custom scheme to register. + [propget] HRESULT SchemeName([out, retval] LPWSTR* schemeName); + + /// Whether the sites with this scheme will be treated as a + /// [Secure Context](https://developer.mozilla.org/docs/Web/Security/Secure_Contexts) + /// like an HTTPS site. This flag is only effective when HasAuthorityComponent + /// is also set to `true`. + /// `false` by default. + [propget] HRESULT TreatAsSecure([out, retval] BOOL* treatAsSecure); + /// Set if the scheme will be treated as a Secure Context. + [propput] HRESULT TreatAsSecure([in] BOOL value); + + /// List of origins that are allowed to issue requests with the custom + /// scheme, such as XHRs and subresource requests that have an Origin header. + /// The origin of any request (requests that have the + /// [Origin header](https://developer.mozilla.org/docs/Web/HTTP/Headers/Origin)) + /// to the custom scheme URI needs to be in this list. No-origin requests + /// are requests that do not have an Origin header, such as link + /// navigations, embedded images and are always allowed. + /// Note: POST requests always contain an Origin header, therefore + /// AllowedOrigins must be set for even for same origin POST requests. + /// Note that cross-origin restrictions still apply. + /// From any opaque origin (Origin header is null), no cross-origin requests + /// are allowed. + /// If the list is empty, no cross-origin request to this scheme is + /// allowed. + /// Origins are specified as a string in the format of + /// scheme://host:port. + /// The origins are string pattern matched with `*` (matches 0 or more + /// characters) and `?` (matches 0 or 1 character) wildcards just like + /// the URI matching in the + /// [AddWebResourceRequestedFilter API](/dotnet/api/microsoft.web.webview2.core.corewebview2.addwebresourcerequestedfilter). + /// For example, "http://*.example.com:80". + /// Here's a set of examples of what is allowed and not: + /// + /// | Request URI | Originating URL | AllowedOrigins | Allowed | + /// | -- | -- | -- | -- | + /// | `custom-scheme:request` | `https://www.example.com` | {"https://www.example.com"} | Yes | + /// | `custom-scheme:request` | `https://www.example.com` | {"https://*.example.com"} | Yes | + /// | `custom-scheme:request` | `https://www.example.com` | {"https://www.example2.com"} | No | + /// | `custom-scheme-with-authority://host/path` | `custom-scheme-with-authority://host2` | {""} | No | + /// | `custom-scheme-with-authority://host/path` | `custom-scheme-with-authority2://host` | {"custom-scheme-with-authority2://*"} | Yes | + /// | `custom-scheme-without-authority:path` | custom-scheme-without-authority:path2 | {"custom-scheme-without-authority:*"} | No | + /// | `custom-scheme-without-authority:path` | custom-scheme-without-authority:path2 | {"*"} | Yes | + /// + /// The returned strings and the array itself must be deallocated with + /// CoTaskMemFree. + HRESULT GetAllowedOrigins( + [out] UINT32* allowedOriginsCount, + [out] LPWSTR** allowedOrigins); + /// Set the array of origins that are allowed to use the scheme. + HRESULT SetAllowedOrigins( + [in] UINT32 allowedOriginsCount, + [in] LPCWSTR* allowedOrigins); + + /// Set this property to `true` if the URIs with this custom + /// scheme will have an authority component (a host for custom schemes). + /// Specifically, if you have a URI of the following form you should set the + /// `HasAuthorityComponent` value as listed. + /// + /// | URI | Recommended HasAuthorityComponent value | + /// | -- | -- | + /// | `custom-scheme-with-authority://host/path` | `true` | + /// | `custom-scheme-without-authority:path` | `false` | + /// + /// When this property is set to `true`, the URIs with this scheme will be + /// interpreted as having a + /// [scheme and host](https://html.spec.whatwg.org/multipage/origin.html#concept-origin-tuple) + /// origin similar to an http URI. Note that the port and user + /// information are never included in the computation of origins for + /// custom schemes. + /// If this property is set to `false`, URIs with this scheme will have an + /// [opaque origin](https://html.spec.whatwg.org/multipage/origin.html#concept-origin-opaque) + /// similar to a data URI. + /// This property is `false` by default. + /// + /// Note: For custom schemes registered as having authority component, + /// navigations to URIs without authority of such custom schemes will fail. + /// However, if the content inside WebView2 references + /// a subresource with a URI that does not have + /// an authority component, but of a custom scheme that is registered as + /// having authority component, the URI will be interpreted as a relative path + /// as specified in [RFC3986](https://www.rfc-editor.org/rfc/rfc3986). + /// For example, `custom-scheme-with-authority:path` will be interpreted + /// as `custom-scheme-with-authority://host/path`. + /// However, this behavior cannot be guaranteed to remain in future + /// releases so it is recommended not to rely on this behavior. + [propget] HRESULT HasAuthorityComponent([out, retval] BOOL* hasAuthorityComponent); + + /// Get has authority component. + [propput] HRESULT HasAuthorityComponent([in] BOOL hasAuthorityComponent); +} + +/// Represents a download operation. Gives access to the download's metadata +/// and supports a user canceling, pausing, or resuming the download. +[uuid(3d6b6cf2-afe1-44c7-a995-c65117714336), object, pointer_default(unique)] +interface ICoreWebView2DownloadOperation : IUnknown { + /// Add an event handler for the `BytesReceivedChanged` event. + /// + /// \snippet ScenarioCustomDownloadExperience.cpp BytesReceivedChanged + HRESULT add_BytesReceivedChanged( + [in] ICoreWebView2BytesReceivedChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_BytesReceivedChanged`. + HRESULT remove_BytesReceivedChanged( + [in] EventRegistrationToken token); + + /// Add an event handler for the `EstimatedEndTimeChanged` event. + HRESULT add_EstimatedEndTimeChanged( + [in] ICoreWebView2EstimatedEndTimeChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_EstimatedEndTimeChanged`. + HRESULT remove_EstimatedEndTimeChanged( + [in] EventRegistrationToken token); + + /// Add an event handler for the `StateChanged` event. + /// + /// \snippet ScenarioCustomDownloadExperience.cpp StateChanged + HRESULT add_StateChanged( + [in] ICoreWebView2StateChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_StateChanged`. + HRESULT remove_StateChanged( + [in] EventRegistrationToken token); + + /// The URI of the download. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Uri([out, retval] LPWSTR* uri); + + /// The Content-Disposition header value from the download's HTTP response. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ContentDisposition([out, retval] LPWSTR* contentDisposition); + + /// MIME type of the downloaded content. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT MimeType([out, retval] LPWSTR* mimeType); + + /// The expected size of the download in total number of bytes based on the + /// HTTP Content-Length header. Returns -1 if the size is unknown. + [propget] HRESULT TotalBytesToReceive([out, retval] INT64* totalBytesToReceive); + + /// The number of bytes that have been written to the download file. + [propget] HRESULT BytesReceived([out, retval] INT64* bytesReceived); + + /// The estimated end time in [ISO 8601 Date and Time Format](https://www.iso.org/iso-8601-date-and-time-format.html). + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT EstimatedEndTime([out, retval] LPWSTR* estimatedEndTime); + + /// The absolute path to the download file, including file name. Host can change + /// this from `ICoreWebView2DownloadStartingEventArgs`. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ResultFilePath([out, retval] LPWSTR* resultFilePath); + + /// The state of the download. A download can be in progress, interrupted, or + /// completed. See `COREWEBVIEW2_DOWNLOAD_STATE` for descriptions of states. + [propget] HRESULT State([out, retval] COREWEBVIEW2_DOWNLOAD_STATE* downloadState); + + /// The reason why connection with file host was broken. + [propget] HRESULT InterruptReason( + [out, retval] COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON* interruptReason); + + /// Cancels the download. If canceled, the default download dialog shows + /// that the download was canceled. Host should set the `Cancel` property from + /// `ICoreWebView2SDownloadStartingEventArgs` if the download should be + /// canceled without displaying the default download dialog. + HRESULT Cancel(); + + /// Pauses the download. If paused, the default download dialog shows that the + /// download is paused. No effect if download is already paused. Pausing a + /// download changes the state to `COREWEBVIEW2_DOWNLOAD_STATE_INTERRUPTED` + /// with `InterruptReason` set to `COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_USER_PAUSED`. + HRESULT Pause(); + + /// Resumes a paused download. May also resume a download that was interrupted + /// for another reason, if `CanResume` returns true. Resuming a download changes + /// the state from `COREWEBVIEW2_DOWNLOAD_STATE_INTERRUPTED` to + /// `COREWEBVIEW2_DOWNLOAD_STATE_IN_PROGRESS`. + HRESULT Resume(); + + /// Returns true if an interrupted download can be resumed. Downloads with + /// the following interrupt reasons may automatically resume without you + /// calling any methods: + /// `COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_SERVER_NO_RANGE`, + /// `COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_HASH_MISMATCH`, + /// `COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON_FILE_TOO_SHORT`. + /// In these cases download progress may be restarted with `BytesReceived` + /// reset to 0. + [propget] HRESULT CanResume([out, retval] BOOL* canResume); +} + +/// Event args for the `DownloadStarting` event. +[uuid(e99bbe21-43e9-4544-a732-282764eafa60), object, pointer_default(unique)] +interface ICoreWebView2DownloadStartingEventArgs : IUnknown { + /// Returns the `ICoreWebView2DownloadOperation` for the download that + /// has started. + [propget] HRESULT DownloadOperation( + [out, retval] ICoreWebView2DownloadOperation** downloadOperation); + + /// The host may set this flag to cancel the download. If canceled, the + /// download save dialog is not displayed regardless of the + /// `Handled` property. + [propget] HRESULT Cancel([out, retval] BOOL* cancel); + + /// Sets the `Cancel` property. + [propput] HRESULT Cancel([in] BOOL cancel); + + /// The path to the file. If setting the path, the host should ensure that it + /// is an absolute path, including the file name, and that the path does not + /// point to an existing file. If the path points to an existing file, the + /// file will be overwritten. If the directory does not exist, it is created. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ResultFilePath([out, retval] LPWSTR* resultFilePath); + + /// Sets the `ResultFilePath` property. + [propput] HRESULT ResultFilePath([in] LPCWSTR resultFilePath); + + /// The host may set this flag to `TRUE` to hide the default download dialog + /// for this download. The download will progress as normal if it is not + /// canceled, there will just be no default UI shown. By default the value is + /// `FALSE` and the default download dialog is shown. + [propget] HRESULT Handled([out, retval] BOOL* handled); + + /// Sets the `Handled` property. + [propput] HRESULT Handled([in] BOOL handled); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to + /// complete the event at a later time. + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// This is the result for ExecuteScriptWithResult. +[uuid(0CE15963-3698-4DF7-9399-71ED6CDD8C9F), object, pointer_default(unique)] +interface ICoreWebView2ExecuteScriptResult : IUnknown { + /// This property is true if ExecuteScriptWithResult successfully executed script with + /// no unhandled exceptions and the result is available in the ResultAsJson property + /// or via the TryGetResultAsString method. + /// If it is false then the script execution had an unhandled exception which you + /// can get via the Exception property. + [propget] HRESULT Succeeded([out, retval] BOOL* value); + /// A function that has no explicit return value returns undefined. If the + /// script that was run throws an unhandled exception, then the result is + /// also "null". This method is applied asynchronously. If the method is + /// run before `ContentLoading`, the script will not be executed + /// and the string "null" will be returned. + + /// The return value description is as follows + /// 1. S_OK: Execution succeeds. + /// 2. E_POINTER: When the `jsonResult` is nullptr. + [propget] HRESULT ResultAsJson([out, retval] LPWSTR* jsonResult); + /// If Succeeded is true and the result of script execution is a string, this method provides the value of the string result, + /// and we will get the `FALSE` var value when the js result is not string type. + + /// The return value description is as follows + /// 1. S_OK: Execution succeeds. + /// 2. E_POINTER: When the `stringResult` or `value` is nullptr. + /// NOTE: If the `value` returns `FALSE`, the `stringResult` will be set to a empty string. + HRESULT TryGetResultAsString([out] LPWSTR* stringResult, [out] BOOL* value); + /// If Succeeded is false, you can use this property to get the unhandled exception thrown by script execution + /// Note that due to the compatibility of the WinRT/.NET interface, + /// S_OK will be returned even if the acquisition fails. + /// We can determine whether the acquisition is successful by judging whether the `exception` is nullptr. + [propget] HRESULT Exception( + [out, retval] ICoreWebView2ScriptException** exception); +} + +/// ICoreWebView2Frame provides direct access to the iframes information. +/// You can get an ICoreWebView2Frame by handling the ICoreWebView2_4::add_FrameCreated event. +[uuid(f1131a5e-9ba9-11eb-a8b3-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2Frame : IUnknown { + /// The value of iframe's window.name property. The default value equals to + /// iframe html tag declaring it. You can access this property even if the + /// iframe is destroyed. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Name([ out, retval ] LPWSTR * name); + /// Raised when the iframe changes its window.name property. + HRESULT add_NameChanged( + [in] ICoreWebView2FrameNameChangedEventHandler * eventHandler, + [out] EventRegistrationToken * token); + /// Remove an event handler previously added with add_NameChanged. + HRESULT remove_NameChanged([in] EventRegistrationToken token); + + /// Add the provided host object to script running in the iframe with the + /// specified name for the list of the specified origins. The host object + /// will be accessible for this iframe only if the iframe's origin during + /// access matches one of the origins which are passed. The provided origins + /// will be normalized before comparing to the origin of the document. + /// So the scheme name is made lower case, the host will be punycode decoded + /// as appropriate, default port values will be removed, and so on. + /// This means the origin's host may be punycode encoded or not and will match + /// regardless. If list contains malformed origin the call will fail. + /// The method can be called multiple times in a row without calling + /// RemoveHostObjectFromScript for the same object name. It will replace + /// the previous object with the new object and new list of origins. + /// List of origins will be treated as following: + /// 1. empty list - call will succeed and object will be added for the iframe + /// but it will not be exposed to any origin; + /// 2. list with origins - during access to host object from iframe the + /// origin will be checked that it belongs to this list; + /// 3. list with "*" element - host object will be available for iframe for + /// all origins. We suggest not to use this feature without understanding + /// security implications of giving access to host object from from iframes + /// with unknown origins. + /// 4. list with "file://" element - host object will be available for iframes + /// loaded via file protocol. + /// Calling this method fails if it is called after the iframe is destroyed. + /// \snippet ScenarioAddHostObject.cpp AddHostObjectToScriptWithOrigins + /// For more information about host objects navigate to + /// ICoreWebView2::AddHostObjectToScript. + HRESULT AddHostObjectToScriptWithOrigins( + [in] LPCWSTR name, + [in] VARIANT * object, + [in] UINT32 originsCount, + [ in, size_is(originsCount) ] LPCWSTR * origins); + /// Remove the host object specified by the name so that it is no longer + /// accessible from JavaScript code in the iframe. While new access + /// attempts are denied, if the object is already obtained by JavaScript code + /// in the iframe, the JavaScript code continues to have access to that + /// object. Calling this method for a name that is already removed or was + /// never added fails. If the iframe is destroyed this method will return fail + /// also. + HRESULT RemoveHostObjectFromScript([in] LPCWSTR name); + + /// The Destroyed event is raised when the iframe corresponding + /// to this CoreWebView2Frame object is removed or the document + /// containing that iframe is destroyed. + HRESULT add_Destroyed( + [in] ICoreWebView2FrameDestroyedEventHandler * eventHandler, + [out] EventRegistrationToken * token); + /// Remove an event handler previously added with add_Destroyed. + HRESULT remove_Destroyed([in] EventRegistrationToken token); + /// Check whether a frame is destroyed. Returns true during + /// the Destroyed event. + HRESULT IsDestroyed([ out, retval ] BOOL * destroyed); +} + +/// A continuation of the ICoreWebView2Frame interface with navigation events, +/// executing script and posting web messages. +[uuid(7a6a5834-d185-4dbf-b63f-4a9bc43107d4), object, pointer_default(unique)] +interface ICoreWebView2Frame2 : ICoreWebView2Frame { + /// Add an event handler for the `NavigationStarting` event. + /// A frame navigation will raise a `NavigationStarting` event and + /// a `CoreWebView2.FrameNavigationStarting` event. All of the + /// `FrameNavigationStarting` event handlers for the current frame will be + /// run before the `NavigationStarting` event handlers. All of the event handlers + /// share a common `NavigationStartingEventArgs` object. Whichever event handler is + /// last to change the `NavigationStartingEventArgs.Cancel` property will + /// decide if the frame navigation will be cancelled. Redirects raise this + /// event as well, and the navigation id is the same as the original one. + /// + /// Navigations will be blocked until all `NavigationStarting` and + /// `CoreWebView2.FrameNavigationStarting` event handlers return. + HRESULT add_NavigationStarting( + [in] ICoreWebView2FrameNavigationStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_NavigationStarting`. + HRESULT remove_NavigationStarting( + [in] EventRegistrationToken token); + + /// Add an event handler for the `ContentLoading` event. `ContentLoading` + /// triggers before any content is loaded, including scripts added with + /// `AddScriptToExecuteOnDocumentCreated`. `ContentLoading` does not trigger + /// if a same page navigation occurs (such as through `fragment` + /// navigations or `history.pushState` navigations). This operation + /// follows the `NavigationStarting` and precedes `NavigationCompleted` events. + HRESULT add_ContentLoading( + [in] ICoreWebView2FrameContentLoadingEventHandler * eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_ContentLoading`. + HRESULT remove_ContentLoading( + [in] EventRegistrationToken token); + + /// Add an event handler for the `NavigationCompleted` event. + /// `NavigationCompleted` runs when the CoreWebView2Frame has completely + /// loaded (concurrently when `body.onload` runs) or loading stopped with error. + HRESULT add_NavigationCompleted( + [in] ICoreWebView2FrameNavigationCompletedEventHandler * + eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_NavigationCompleted`. + HRESULT remove_NavigationCompleted( + [in] EventRegistrationToken token); + + /// Add an event handler for the DOMContentLoaded event. + /// DOMContentLoaded is raised when the iframe html document has been parsed. + /// This aligns with the document's DOMContentLoaded event in html. + HRESULT add_DOMContentLoaded( + [in] ICoreWebView2FrameDOMContentLoadedEventHandler * eventHandler, + [out] EventRegistrationToken* token); + /// Remove an event handler previously added with add_DOMContentLoaded. + HRESULT remove_DOMContentLoaded( + [in] EventRegistrationToken token); + + /// Run JavaScript code from the javascript parameter in the current frame. + /// The result of evaluating the provided JavaScript is passed to the completion handler. + /// The result value is a JSON encoded string. If the result is undefined, + /// contains a reference cycle, or otherwise is not able to be encoded into + /// JSON, then the result is considered to be null, which is encoded + /// in JSON as the string "null". + /// + /// \> [!NOTE]\n\> A function that has no explicit return value returns undefined. If the + /// script that was run throws an unhandled exception, then the result is + /// also "null". This method is applied asynchronously. If the method is + /// run before `ContentLoading`, the script will not be executed + /// and the string "null" will be returned. + /// This operation executes the script even if `ICoreWebView2Settings::IsScriptEnabled` is + /// set to `FALSE`. + /// + /// \snippet ScenarioDOMContentLoaded.cpp ExecuteScriptFrame + HRESULT ExecuteScript( + [in] LPCWSTR javaScript, + [in] ICoreWebView2ExecuteScriptCompletedHandler* handler); + + /// Posts the specified webMessage to the frame. + /// The frame receives the message by subscribing to the `message` event of + /// the `window.chrome.webview` of the frame document. + /// + /// ```cpp + /// window.chrome.webview.addEventListener('message', handler) + /// window.chrome.webview.removeEventListener('message', handler) + /// ``` + /// + /// The event args is an instances of `MessageEvent`. The + /// `ICoreWebView2Settings::IsWebMessageEnabled` setting must be `TRUE` or + /// the message will not be sent. The `data` property of the event + /// args is the `webMessage` string parameter parsed as a JSON string into a + /// JavaScript object. The `source` property of the event args is a reference + /// to the `window.chrome.webview` object. For information about sending + /// messages from the HTML document in the WebView to the host, navigate to + /// [add_WebMessageReceived](/microsoft-edge/webview2/reference/win32/icorewebview2#add_webmessagereceived). + /// The message is delivered asynchronously. If a navigation occurs before the + /// message is posted to the page, the message is discarded. + HRESULT PostWebMessageAsJson([in] LPCWSTR webMessageAsJson); + + /// Posts a message that is a simple string rather than a JSON string + /// representation of a JavaScript object. This behaves in exactly the same + /// manner as `PostWebMessageAsJson`, but the `data` property of the event + /// args of the `window.chrome.webview` message is a string with the same + /// value as `webMessageAsString`. Use this instead of + /// `PostWebMessageAsJson` if you want to communicate using simple strings + /// rather than JSON objects. + HRESULT PostWebMessageAsString([in] LPCWSTR webMessageAsString); + + /// Add an event handler for the `WebMessageReceived` event. + /// `WebMessageReceived` runs when the + /// `ICoreWebView2Settings::IsWebMessageEnabled` setting is set and the + /// frame document runs `window.chrome.webview.postMessage`. + /// The `postMessage` function is `void postMessage(object)` + /// where object is any object supported by JSON conversion. + /// + /// \snippet assets\ScenarioWebMessage.html chromeWebView + /// + /// When the frame calls `postMessage`, the object parameter is converted to a + /// JSON string and is posted asynchronously to the host process. This will + /// result in the handlers `Invoke` method being called with the JSON string + /// as its parameter. + /// + /// \snippet ScenarioWebMessage.cpp WebMessageReceivedIFrame + HRESULT add_WebMessageReceived( + [in] ICoreWebView2FrameWebMessageReceivedEventHandler * + handler, + [out] EventRegistrationToken * token); + + /// Remove an event handler previously added with `add_WebMessageReceived`. + HRESULT remove_WebMessageReceived([in] EventRegistrationToken token); +} + +/// A continuation of the ICoreWebView2FrameInfo interface that provides +/// `ParentFrameInfo`, `FrameId` and `FrameKind` properties. +[uuid(56f85cfa-72c4-11ee-b962-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2FrameInfo2 : ICoreWebView2FrameInfo { + /// This parent frame's `FrameInfo`. `ParentFrameInfo` will only be + /// populated when obtained via calling + /// `CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos`. + /// `CoreWebView2FrameInfo` objects obtained via `CoreWebView2.ProcessFailed` will + /// always have a `null ParentFrameInfo`. This property is also `null` for the + /// main frame in the WebView2 which has no parent frame. + /// Note that this `ParentFrameInfo` could be out of date as it's a snapshot. + [propget] HRESULT ParentFrameInfo([out, retval] ICoreWebView2FrameInfo** frameInfo); + /// The unique identifier of the frame associated with the current `FrameInfo`. + /// It's the same kind of ID as with the `FrameId` in `CoreWebView2` and via + /// `CoreWebView2Frame`. `FrameId` will only be populated (non-zero) when obtained + /// calling `CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos`. + /// `CoreWebView2FrameInfo` objects obtained via `CoreWebView2.ProcessFailed` will + /// always have an invalid frame Id 0. + /// Note that this `FrameId` could be out of date as it's a snapshot. + /// If there's WebView2 created or destroyed or `FrameCreated/FrameDestroyed` events + /// after the asynchronous call `CoreWebView2Environment.GetProcessExtendedInfos` + /// starts, you may want to call asynchronous method again to get the updated `FrameInfo`s. + [propget] HRESULT FrameId([out, retval] UINT32* id); + /// The frame kind of the frame. `FrameKind` will only be populated when + /// obtained calling `CoreWebView2ProcessExtendedInfo.AssociatedFrameInfos`. + /// `CoreWebView2FrameInfo` objects obtained via `CoreWebView2.ProcessFailed` + /// will always have the default value `COREWEBVIEW2_FRAME_KIND_UNKNOWN`. + /// Note that this `FrameKind` could be out of date as it's a snapshot. + [propget] HRESULT FrameKind([out, retval] COREWEBVIEW2_FRAME_KIND* kind); +} + +/// Iterator for a collection of HTTP headers. For more information, navigate +/// to ICoreWebView2HttpRequestHeaders and ICoreWebView2HttpResponseHeaders. +/// +/// \snippet ScenarioWebViewEventMonitor.cpp HttpRequestHeaderIterator +[uuid(0702fc30-f43b-47bb-ab52-a42cb552ad9f), object, pointer_default(unique)] +interface ICoreWebView2HttpHeadersCollectionIterator : IUnknown { + + /// Get the name and value of the current HTTP header of the iterator. If + /// the previous `MoveNext` operation set the `hasNext` parameter to `FALSE`, + /// this method fails. + /// + /// The caller must free the returned strings with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + HRESULT GetCurrentHeader([out] LPWSTR* name, [out] LPWSTR* value); + + /// `TRUE` when the iterator has not run out of headers. If the collection + /// over which the iterator is iterating is empty or if the iterator has gone + /// past the end of the collection then this is `FALSE`. + + [propget] HRESULT HasCurrentHeader([out, retval] BOOL* hasCurrent); + + /// Move the iterator to the next HTTP header in the collection. + /// + /// \> [!NOTE]\n \> If no more HTTP headers exist, the `hasNext` parameter is set to + /// `FALSE`. After this occurs the `GetCurrentHeader` method fails. + + HRESULT MoveNext([out, retval] BOOL* hasNext); +} + +/// Event args for `LaunchingExternalUriScheme` event. +[uuid(07D1A6C3-7175-4BA1-9306-E593CA07E46C), object, pointer_default(unique)] +interface ICoreWebView2LaunchingExternalUriSchemeEventArgs: IUnknown { + /// The URI with the external URI scheme to be launched. + + [propget] HRESULT Uri([out, retval] LPWSTR* value); + + /// The origin initiating the external URI scheme launch. + /// The origin will be an empty string if the request is initiated by calling + /// `CoreWebView2.Navigate` on the external URI scheme. If a script initiates + /// the navigation, the `InitiatingOrigin` will be the top-level document's + /// `Source`, for example, if `window.location` is set to `"calculator://"`, the + /// `InitiatingOrigin` will be set to `calculator://`. If the request is initiated + /// from a child frame, the `InitiatingOrigin` will be the source of that child frame. + /// If the `InitiatingOrigin` is + /// [opaque](https://html.spec.whatwg.org/multipage/origin.html#concept-origin-opaque), + /// the `InitiatingOrigin` reported in the event args will be its precursor origin. + /// The precursor origin is the origin that created the opaque origin. For example, if + /// a frame on example.com opens a subframe with a different opaque origin, the subframe's + /// precursor origin is example.com. + [propget] HRESULT InitiatingOrigin([out, retval] LPWSTR* value); + + /// `TRUE` when the external URI scheme request was initiated through a user gesture. + /// + /// \> [!NOTE]\n\> Being initiated through a user gesture does not mean that user intended + /// to access the associated resource. + + [propget] HRESULT IsUserInitiated([out, retval] BOOL* value); + + /// The event handler may set this property to `TRUE` to cancel the external URI scheme + /// launch. If set to `TRUE`, the external URI scheme will not be launched, and the default + /// dialog is not displayed. This property can be used to replace the normal + /// handling of launching an external URI scheme. + /// The initial value of the `Cancel` property is `FALSE`. + + [propget] HRESULT Cancel([out, retval] BOOL* value); + + /// Sets the `Cancel` property. + + [propput] HRESULT Cancel([in] BOOL value); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to + /// complete the event at a later time. + + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** value); +} + +/// Event args for the `MoveFocusRequested` event. + +[uuid(2d6aa13b-3839-4a15-92fc-d88b3c0d9c9d), object, pointer_default(unique)] +interface ICoreWebView2MoveFocusRequestedEventArgs : IUnknown { + + /// The reason for WebView to run the `MoveFocusRequested` event. + + [propget] HRESULT Reason([out, retval] COREWEBVIEW2_MOVE_FOCUS_REASON* reason); + + /// Indicates whether the event has been handled by the app. If the app has + /// moved the focus to another desired location, it should set the `Handled` + /// property to `TRUE`. When the `Handled` property is `FALSE` after the + /// event handler returns, default action is taken. The default action is to + /// try to find the next tab stop child window in the app and try to move + /// focus to that window. If no other window exists to move focus, focus is + /// cycled within the web content of the WebView. + + [propget] HRESULT Handled([out, retval] BOOL* value); + + /// Sets the `Handled` property. + + [propput] HRESULT Handled([in] BOOL value); +} + +/// Event args for the `NavigationCompleted` event. +[uuid(30d68b7d-20d9-4752-a9ca-ec8448fbb5c1), object, pointer_default(unique)] +interface ICoreWebView2NavigationCompletedEventArgs : IUnknown { + + /// `TRUE` when the navigation is successful. `FALSE` for a navigation that + /// ended up in an error page (failures due to no network, DNS lookup + /// failure, HTTP server responds with 4xx), but may also be `FALSE` for + /// additional scenarios such as `window.stop()` run on navigated page. + /// Note that WebView2 will report the navigation as 'unsuccessful' if the load + /// for the navigation did not reach the expected completion for any reason. Such + /// reasons include potentially catastrophic issues such network and certificate + /// issues, but can also be the result of intended actions such as the app canceling a navigation or + /// navigating away before the original navigation completed. Applications should not + /// just rely on this flag, but also consider the reported WebErrorStatus to + /// determine whether the failure is indeed catastrophic in their context. + /// WebErrorStatuses that may indicate a non-catastrophic failure include: + /// - COREWEBVIEW2_WEB_ERROR_STATUS_OPERATION_CANCELED + /// - COREWEBVIEW2_WEB_ERROR_STATUS_VALID_AUTHENTICATION_CREDENTIALS_REQUIRED + /// - COREWEBVIEW2_WEB_ERROR_STATUS_VALID_PROXY_AUTHENTICATION_REQUIRED + + [propget] HRESULT IsSuccess([out, retval] BOOL* isSuccess); + + /// The error code if the navigation failed. + + [propget] HRESULT WebErrorStatus([out, retval] COREWEBVIEW2_WEB_ERROR_STATUS* + webErrorStatus); + + /// The ID of the navigation. + + [propget] HRESULT NavigationId([out, retval] UINT64* navigationId); +} + +/// Event args for the `NavigationStarting` event. +[uuid(5b495469-e119-438a-9b18-7604f25f2e49), object, pointer_default(unique)] +interface ICoreWebView2NavigationStartingEventArgs : IUnknown { + + /// The uri of the requested navigation. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Uri([out, retval] LPWSTR* uri); + + /// `TRUE` when the navigation was initiated through a user gesture as + /// opposed to programmatic navigation by page script. Navigations initiated + /// via WebView2 APIs are considered as user initiated. + + [propget] HRESULT IsUserInitiated([out, retval] BOOL* isUserInitiated); + + /// `TRUE` when the navigation is redirected. + + [propget] HRESULT IsRedirected([out, retval] BOOL* isRedirected); + + /// The HTTP request headers for the navigation. + /// + /// \> [!NOTE]\n\> You are not able to modify the HTTP request headers in a + /// `NavigationStarting` event. + + [propget] HRESULT RequestHeaders([out, retval] ICoreWebView2HttpRequestHeaders** requestHeaders); + + /// The host may set this flag to cancel the navigation. If set, the + /// navigation is not longer present and the content of the current page is + /// intact. For performance reasons, `GET` HTTP requests may happen, while + /// the host is responding. You may set cookies and use part of a request + /// for the navigation. Navigations to about schemes are cancellable, unless + /// `msWebView2CancellableAboutNavigations` feature flag is disabled. + /// Cancellation of frame navigation to `srcdoc` is not supported and + /// wil be ignored. A cancelled navigation will fire a `NavigationCompleted` + /// event with a `WebErrorStatus` of + /// `COREWEBVIEW2_WEB_ERROR_STATUS_OPERATION_CANCELED`. + + [propget] HRESULT Cancel([out, retval] BOOL* cancel); + + /// Sets the `Cancel` property. + + [propput] HRESULT Cancel([in] BOOL cancel); + + /// The ID of the navigation. + + [propget] HRESULT NavigationId([out, retval] UINT64* navigationId); +} + +/// Event args for the `NewWindowRequested` event. The event is run when +/// content inside webview requested to a open a new window (through +/// `window.open()` and so on). +[uuid(34acb11c-fc37-4418-9132-f9c21d1eafb9), object, pointer_default(unique)] +interface ICoreWebView2NewWindowRequestedEventArgs : IUnknown { + + /// The target uri of the new window requested. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Uri([out, retval] LPWSTR* uri); + + /// Sets a CoreWebView2 as a result of the NewWindowRequested event. Provides + /// a WebView as the target for a `window.open()` from inside the + /// requesting WebView. If this is set, the top-level window of this WebView + /// is returned as the opened + /// [WindowProxy](https://developer.mozilla.org/docs/glossary/windowproxy) + /// to the opener script. If this is not set, then `Handled` is checked to + /// determine behavior for NewWindowRequested event. + /// CoreWebView2 provided in the `NewWindow` property must be on the same + /// Environment as the opener WebView and should not have been navigated + /// previously. Don't use methods that cause navigation or interact with the + /// DOM on this CoreWebView2 until the target content has loaded. Setting event + /// handlers, changing Settings properties, or other methods are fine to call. + /// Changes to settings should be made before `put_NewWindow` is called to + /// ensure that those settings take effect for the newly setup WebView. Once the + /// NewWindow is set the underlying web contents of this CoreWebView2 will be + /// replaced and navigated as appropriate for the new window. After setting + /// new window it cannot be changed and error will be return otherwise. + /// + /// The methods which should affect the new web contents like + /// AddScriptToExecuteOnDocumentCreated has to be called and completed before setting NewWindow. + /// Other methods which should affect the new web contents like add_WebResourceRequested have to be called after setting NewWindow. + /// It is best not to use RemoveScriptToExecuteOnDocumentCreated before setting NewWindow, otherwise it may not work for later added scripts. + /// + /// The new WebView must have the same profile as the opener WebView. + + [propput] HRESULT NewWindow([in] ICoreWebView2* newWindow); + + /// Gets the new window. + + [propget] HRESULT NewWindow([out, retval] ICoreWebView2** newWindow); + + /// Sets whether the `NewWindowRequested` event is handled by host. If this + /// is `FALSE` and no `NewWindow` is set, the WebView opens a popup window + /// and it returns as opened `WindowProxy`. If set to `TRUE` and no + /// `NewWindow` is set for `window.open`, the opened `WindowProxy` is for an + /// testing window object and no window loads. + /// The default value is `FALSE`. + + [propput] HRESULT Handled([in] BOOL handled); + + /// Gets whether the `NewWindowRequested` event is handled by host. + + [propget] HRESULT Handled([out, retval] BOOL* handled); + + /// `TRUE` when the new window request was initiated through a user gesture. + /// Examples of user initiated requests are: + /// + /// - Selecting an anchor tag with target + /// - Programmatic window open from a script that directly run as a result of + /// user interaction such as via onclick handlers. + /// + /// Non-user initiated requests are programmatic window opens from a script + /// that are not directly triggered by user interaction, such as those that + /// run while loading a new page or via timers. + /// The Microsoft Edge popup blocker is disabled for WebView so the app is + /// able to use this flag to block non-user initiated popups. + + [propget] HRESULT IsUserInitiated([out, retval] BOOL* isUserInitiated); + + /// Obtain an `ICoreWebView2Deferral` object and put the event into a + /// deferred state. Use the `ICoreWebView2Deferral` object to complete the + /// window open request at a later time. While this event is deferred the + /// opener window returns a `WindowProxy` to an un-navigated window, which + /// navigates when the deferral is complete. + + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); + + /// Window features specified by the `window.open`. The features should be + /// considered for positioning and sizing of new webview windows. + + [propget] HRESULT WindowFeatures([out, retval] ICoreWebView2WindowFeatures** value); +} + +/// Event args for the `PermissionRequested` event. +[uuid(973ae2ef-ff18-4894-8fb2-3c758f046810), object, pointer_default(unique)] +interface ICoreWebView2PermissionRequestedEventArgs : IUnknown { + + /// The origin of the web content that requests the permission. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Uri([out, retval] LPWSTR* uri); + + /// The type of the permission that is requested. + + [propget] HRESULT PermissionKind([out, retval] COREWEBVIEW2_PERMISSION_KIND* permissionKind); + + /// `TRUE` when the permission request was initiated through a user gesture. + /// + /// \> [!NOTE]\n\> Being initiated through a user gesture does not mean that user intended + /// to access the associated resource. + + [propget] HRESULT IsUserInitiated([out, retval] BOOL* isUserInitiated); + + /// The status of a permission request, (for example is the request is granted). + /// The default value is `COREWEBVIEW2_PERMISSION_STATE_DEFAULT`. + + [propget] HRESULT State([out, retval] COREWEBVIEW2_PERMISSION_STATE* state); + + /// Sets the `State` property. + + [propput] HRESULT State([in] COREWEBVIEW2_PERMISSION_STATE state); + + /// Gets an `ICoreWebView2Deferral` object. Use the deferral object to make + /// the permission decision at a later time. The deferral only applies to the + /// current request, and does not prevent the `PermissionRequested` event from + /// getting raised for new requests. However, for some permission kinds the + /// WebView will avoid creating a new request if there is a pending request of + /// the same kind. + + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// Read-only collection of `PermissionSetting`s (origin, kind, and state). Used to list +/// the nondefault permission settings on the profile that are persisted across +/// sessions. +[uuid(f5596f62-3de5-47b1-91e8-a4104b596b96), object, pointer_default(unique)] +interface ICoreWebView2PermissionSettingCollectionView : IUnknown { + /// Gets the `ICoreWebView2PermissionSetting` at the specified index. + HRESULT GetValueAtIndex( + [in] UINT32 index, + [out, retval] ICoreWebView2PermissionSetting** permissionSetting); + + /// The number of `ICoreWebView2PermissionSetting`s in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); +} + +/// This mostly represents a combined win32 +/// POINTER_INFO/POINTER_TOUCH_INFO/POINTER_PEN_INFO object. It takes fields +/// from all three and excludes some win32 specific data types like HWND and +/// HANDLE. Note, sourceDevice is taken out but we expect the PointerDeviceRect +/// and DisplayRect to cover the existing use cases of sourceDevice. +/// Another big difference is that any of the point or rect locations are +/// expected to be in WebView physical coordinates. That is, coordinates +/// relative to the WebView and no DPI scaling applied. +// +// The PointerId, PointerFlags, ButtonChangeKind, PenFlags, PenMask, TouchFlags, +// and TouchMask are all #defined flags or enums in the +// POINTER_INFO/POINTER_TOUCH_INFO/POINTER_PEN_INFO structure. We define those +// properties here as UINT32 or INT32 and expect the developer to know how to +// populate those values based on the Windows definitions. +[uuid(e6995887-d10d-4f5d-9359-4ce46e4f96b9), object, pointer_default(unique)] +interface ICoreWebView2PointerInfo : IUnknown { + /// Get the PointerKind of the pointer event. This corresponds to the + /// pointerKind property of the POINTER_INFO struct. The values are defined by + /// the POINTER_INPUT_KIND enum in the Windows SDK (winuser.h). Supports + /// PT_PEN and PT_TOUCH. + [propget] HRESULT PointerKind([out, retval] DWORD* pointerKind); + /// Set the PointerKind of the pointer event. This corresponds to the + /// pointerKind property of the POINTER_INFO struct. The values are defined by + /// the POINTER_INPUT_KIND enum in the Windows SDK (winuser.h). Supports + /// PT_PEN and PT_TOUCH. + [propput] HRESULT PointerKind([in] DWORD pointerKind); + + /// Get the PointerId of the pointer event. This corresponds to the pointerId + /// property of the POINTER_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT PointerId([out, retval] UINT32* pointerId); + /// Set the PointerId of the pointer event. This corresponds to the pointerId + /// property of the POINTER_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT PointerId([in] UINT32 pointerId); + + /// Get the FrameID of the pointer event. This corresponds to the frameId + /// property of the POINTER_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT FrameId([out, retval] UINT32* frameId); + /// Set the FrameID of the pointer event. This corresponds to the frameId + /// property of the POINTER_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT FrameId([in] UINT32 frameId); + + /// Get the PointerFlags of the pointer event. This corresponds to the + /// pointerFlags property of the POINTER_INFO struct. The values are defined + /// by the POINTER_FLAGS constants in the Windows SDK (winuser.h). + [propget] HRESULT PointerFlags([out, retval] UINT32* pointerFlags); + /// Set the PointerFlags of the pointer event. This corresponds to the + /// pointerFlags property of the POINTER_INFO struct. The values are defined + /// by the POINTER_FLAGS constants in the Windows SDK (winuser.h). + [propput] HRESULT PointerFlags([in] UINT32 pointerFlags); + + /// Get the PointerDeviceRect of the sourceDevice property of the + /// POINTER_INFO struct as defined in the Windows SDK (winuser.h). + [propget] HRESULT PointerDeviceRect([out, retval] RECT* pointerDeviceRect); + /// Set the PointerDeviceRect of the sourceDevice property of the + /// POINTER_INFO struct as defined in the Windows SDK (winuser.h). + [propput] HRESULT PointerDeviceRect([in] RECT pointerDeviceRect); + + /// Get the DisplayRect of the sourceDevice property of the POINTER_INFO + /// struct as defined in the Windows SDK (winuser.h). + [propget] HRESULT DisplayRect([out, retval] RECT* displayRect); + /// Set the DisplayRect of the sourceDevice property of the POINTER_INFO + /// struct as defined in the Windows SDK (winuser.h). + [propput] HRESULT DisplayRect([in] RECT displayRect); + + /// Get the PixelLocation of the pointer event. This corresponds to the + /// ptPixelLocation property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT PixelLocation([out, retval] POINT* pixelLocation); + /// Set the PixelLocation of the pointer event. This corresponds to the + /// ptPixelLocation property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT PixelLocation([in] POINT pixelLocation); + + /// Get the HimetricLocation of the pointer event. This corresponds to the + /// ptHimetricLocation property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT HimetricLocation([out, retval] POINT* himetricLocation); + /// Set the HimetricLocation of the pointer event. This corresponds to the + /// ptHimetricLocation property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT HimetricLocation([in] POINT himetricLocation); + + /// Get the PixelLocationRaw of the pointer event. This corresponds to the + /// ptPixelLocationRaw property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT PixelLocationRaw([out, retval] POINT* pixelLocationRaw); + /// Set the PixelLocationRaw of the pointer event. This corresponds to the + /// ptPixelLocationRaw property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT PixelLocationRaw([in] POINT pixelLocationRaw); + + /// Get the HimetricLocationRaw of the pointer event. This corresponds to the + /// ptHimetricLocationRaw property of the POINTER_INFO struct as defined in + /// the Windows SDK (winuser.h). + [propget] HRESULT HimetricLocationRaw([out, retval] POINT* himetricLocationRaw); + /// Set the HimetricLocationRaw of the pointer event. This corresponds to the + /// ptHimetricLocationRaw property of the POINTER_INFO struct as defined in + /// the Windows SDK (winuser.h). + [propput] HRESULT HimetricLocationRaw([in] POINT himetricLocationRaw); + + /// Get the Time of the pointer event. This corresponds to the dwTime property + /// of the POINTER_INFO struct as defined in the Windows SDK (winuser.h). + [propget] HRESULT Time([out, retval] DWORD* time); + /// Set the Time of the pointer event. This corresponds to the dwTime property + /// of the POINTER_INFO struct as defined in the Windows SDK (winuser.h). + [propput] HRESULT Time([in] DWORD time); + + /// Get the HistoryCount of the pointer event. This corresponds to the + /// historyCount property of the POINTER_INFO struct as defined in the Windows + /// SDK (winuser.h). + [propget] HRESULT HistoryCount([out, retval] UINT32* historyCount); + /// Set the HistoryCount of the pointer event. This corresponds to the + /// historyCount property of the POINTER_INFO struct as defined in the Windows + /// SDK (winuser.h). + [propput] HRESULT HistoryCount([in] UINT32 historyCount); + + /// Get the InputData of the pointer event. This corresponds to the InputData + /// property of the POINTER_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT InputData([out, retval] INT32* inputData); + /// Set the InputData of the pointer event. This corresponds to the InputData + /// property of the POINTER_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT InputData([in] INT32 inputData); + + /// Get the KeyStates of the pointer event. This corresponds to the + /// dwKeyStates property of the POINTER_INFO struct as defined in the Windows + /// SDK (winuser.h). + [propget] HRESULT KeyStates([out, retval] DWORD* keyStates); + /// Set the KeyStates of the pointer event. This corresponds to the + /// dwKeyStates property of the POINTER_INFO struct as defined in the Windows + /// SDK (winuser.h). + [propput] HRESULT KeyStates([in] DWORD keyStates); + + /// Get the PerformanceCount of the pointer event. This corresponds to the + /// PerformanceCount property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT PerformanceCount([out, retval] UINT64* performanceCount); + /// Set the PerformanceCount of the pointer event. This corresponds to the + /// PerformanceCount property of the POINTER_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT PerformanceCount([in] UINT64 performanceCount); + + /// Get the ButtonChangeKind of the pointer event. This corresponds to the + /// ButtonChangeKind property of the POINTER_INFO struct. The values are + /// defined by the POINTER_BUTTON_CHANGE_KIND enum in the Windows SDK + /// (winuser.h). + [propget] HRESULT ButtonChangeKind([out, retval] INT32* buttonChangeKind); + /// Set the ButtonChangeKind of the pointer event. This corresponds to the + /// ButtonChangeKind property of the POINTER_INFO struct. The values are + /// defined by the POINTER_BUTTON_CHANGE_KIND enum in the Windows SDK + /// (winuser.h). + [propput] HRESULT ButtonChangeKind([in] INT32 buttonChangeKind); + + // Pen specific attributes + + /// Get the PenFlags of the pointer event. This corresponds to the penFlags + /// property of the POINTER_PEN_INFO struct. The values are defined by the + /// PEN_FLAGS constants in the Windows SDK (winuser.h). + [propget] HRESULT PenFlags([out, retval] UINT32* penFLags); + /// Set the PenFlags of the pointer event. This corresponds to the penFlags + /// property of the POINTER_PEN_INFO struct. The values are defined by the + /// PEN_FLAGS constants in the Windows SDK (winuser.h). + [propput] HRESULT PenFlags([in] UINT32 penFLags); + + /// Get the PenMask of the pointer event. This corresponds to the penMask + /// property of the POINTER_PEN_INFO struct. The values are defined by the + /// PEN_MASK constants in the Windows SDK (winuser.h). + [propget] HRESULT PenMask([out, retval] UINT32* penMask); + /// Set the PenMask of the pointer event. This corresponds to the penMask + /// property of the POINTER_PEN_INFO struct. The values are defined by the + /// PEN_MASK constants in the Windows SDK (winuser.h). + [propput] HRESULT PenMask([in] UINT32 penMask); + + /// Get the PenPressure of the pointer event. This corresponds to the pressure + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT PenPressure([out, retval] UINT32* penPressure); + /// Set the PenPressure of the pointer event. This corresponds to the pressure + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT PenPressure([in] UINT32 penPressure); + + /// Get the PenRotation of the pointer event. This corresponds to the rotation + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT PenRotation([out, retval] UINT32* penRotation); + /// Set the PenRotation of the pointer event. This corresponds to the rotation + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT PenRotation([in] UINT32 penRotation); + + /// Get the PenTiltX of the pointer event. This corresponds to the tiltX + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT PenTiltX([out, retval] INT32* penTiltX); + /// Set the PenTiltX of the pointer event. This corresponds to the tiltX + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT PenTiltX([in] INT32 penTiltX); + + /// Get the PenTiltY of the pointer event. This corresponds to the tiltY + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propget] HRESULT PenTiltY([out, retval] INT32* penTiltY); + /// Set the PenTiltY of the pointer event. This corresponds to the tiltY + /// property of the POINTER_PEN_INFO struct as defined in the Windows SDK + /// (winuser.h). + [propput] HRESULT PenTiltY([in] INT32 penTiltY); + + // Touch specific attributes + + /// Get the TouchFlags of the pointer event. This corresponds to the + /// touchFlags property of the POINTER_TOUCH_INFO struct. The values are + /// defined by the TOUCH_FLAGS constants in the Windows SDK (winuser.h). + [propget] HRESULT TouchFlags([out, retval] UINT32* touchFlags); + /// Set the TouchFlags of the pointer event. This corresponds to the + /// touchFlags property of the POINTER_TOUCH_INFO struct. The values are + /// defined by the TOUCH_FLAGS constants in the Windows SDK (winuser.h). + [propput] HRESULT TouchFlags([in] UINT32 touchFlags); + + /// Get the TouchMask of the pointer event. This corresponds to the + /// touchMask property of the POINTER_TOUCH_INFO struct. The values are + /// defined by the TOUCH_MASK constants in the Windows SDK (winuser.h). + [propget] HRESULT TouchMask([out, retval] UINT32* touchMask); + /// Set the TouchMask of the pointer event. This corresponds to the + /// touchMask property of the POINTER_TOUCH_INFO struct. The values are + /// defined by the TOUCH_MASK constants in the Windows SDK (winuser.h). + [propput] HRESULT TouchMask([in] UINT32 touchMask); + + /// Get the TouchContact of the pointer event. This corresponds to the + /// rcContact property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT TouchContact([out, retval] RECT* touchContact); + /// Set the TouchContact of the pointer event. This corresponds to the + /// rcContact property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT TouchContact([in] RECT touchContact); + + /// Get the TouchContactRaw of the pointer event. This corresponds to the + /// rcContactRaw property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT TouchContactRaw([out, retval] RECT* touchContactRaw); + /// Set the TouchContactRaw of the pointer event. This corresponds to the + /// rcContactRaw property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT TouchContactRaw([in] RECT touchContactRaw); + + /// Get the TouchOrientation of the pointer event. This corresponds to the + /// orientation property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT TouchOrientation([out, retval] UINT32* touchOrientation); + /// Set the TouchOrientation of the pointer event. This corresponds to the + /// orientation property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT TouchOrientation([in] UINT32 touchOrientation); + + /// Get the TouchPressure of the pointer event. This corresponds to the + /// pressure property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propget] HRESULT TouchPressure([out, retval] UINT32* touchPressure); + /// Set the TouchPressure of the pointer event. This corresponds to the + /// pressure property of the POINTER_TOUCH_INFO struct as defined in the + /// Windows SDK (winuser.h). + [propput] HRESULT TouchPressure([in] UINT32 touchPressure); +} + +/// Settings used by the `PrintToPdf` method. +[uuid(377f3721-c74e-48ca-8db1-df68e51d60e2), object, pointer_default(unique)] +interface ICoreWebView2PrintSettings : IUnknown { + + /// The orientation can be portrait or landscape. The default orientation is + /// portrait. See `COREWEBVIEW2_PRINT_ORIENTATION`. + [propget] HRESULT Orientation( + [out, retval] COREWEBVIEW2_PRINT_ORIENTATION* orientation); + + /// Sets the `Orientation` property. + [propput] HRESULT Orientation( + [in] COREWEBVIEW2_PRINT_ORIENTATION orientation); + + /// The scale factor is a value between 0.1 and 2.0. The default is 1.0. + [propget] HRESULT ScaleFactor([out, retval] double* scaleFactor); + + /// Sets the `ScaleFactor` property. Returns `E_INVALIDARG` if an invalid + /// value is provided, and the current value is not changed. + [propput] HRESULT ScaleFactor([in] double scaleFactor); + + /// The page width in inches. The default width is 8.5 inches. + [propget] HRESULT PageWidth([out, retval] double* pageWidth); + + /// Sets the `PageWidth` property. Returns `E_INVALIDARG` if the page width is + /// less than or equal to zero, and the current value is not changed. + [propput] HRESULT PageWidth([in] double pageWidth); + + /// The page height in inches. The default height is 11 inches. + [propget] HRESULT PageHeight([out, retval] double* pageHeight); + + /// Sets the `PageHeight` property. Returns `E_INVALIDARG` if the page height + /// is less than or equal to zero, and the current value is not changed. + [propput] HRESULT PageHeight([in] double pageHeight); + + /// The top margin in inches. The default is 1 cm, or ~0.4 inches. + [propget] HRESULT MarginTop([out, retval] double* marginTop); + + /// Sets the `MarginTop` property. A margin cannot be less than zero. + /// Returns `E_INVALIDARG` if an invalid value is provided, and the current + /// value is not changed. + [propput] HRESULT MarginTop([in] double marginTop); + + /// The bottom margin in inches. The default is 1 cm, or ~0.4 inches. + [propget] HRESULT MarginBottom([out, retval] double* marginBottom); + + /// Sets the `MarginBottom` property. A margin cannot be less than zero. + /// Returns `E_INVALIDARG` if an invalid value is provided, and the current + /// value is not changed. + [propput] HRESULT MarginBottom([in] double marginBottom); + + /// The left margin in inches. The default is 1 cm, or ~0.4 inches. + [propget] HRESULT MarginLeft([out, retval] double* marginLeft); + + /// Sets the `MarginLeft` property. A margin cannot be less than zero. + /// Returns `E_INVALIDARG` if an invalid value is provided, and the current + /// value is not changed. + [propput] HRESULT MarginLeft([in] double marginLeft); + + /// The right margin in inches. The default is 1 cm, or ~0.4 inches. + [propget] HRESULT MarginRight([out, retval] double* marginRight); + + /// Set the `MarginRight` property.A margin cannot be less than zero. + /// Returns `E_INVALIDARG` if an invalid value is provided, and the current + /// value is not changed. + [propput] HRESULT MarginRight([in] double marginRight); + + /// `TRUE` if background colors and images should be printed. The default value + /// is `FALSE`. + [propget] HRESULT ShouldPrintBackgrounds( + [out, retval] BOOL* shouldPrintBackgrounds); + + /// Set the `ShouldPrintBackgrounds` property. + [propput] HRESULT ShouldPrintBackgrounds([in] BOOL shouldPrintBackgrounds); + + /// `TRUE` if only the current end user's selection of HTML in the document + /// should be printed. The default value is `FALSE`. + [propget] HRESULT ShouldPrintSelectionOnly( + [out, retval] BOOL* shouldPrintSelectionOnly); + + /// Set the `ShouldPrintSelectionOnly` property. + [propput] HRESULT ShouldPrintSelectionOnly( + [in] BOOL shouldPrintSelectionOnly); + + /// `TRUE` if header and footer should be printed. The default value is `FALSE`. + /// The header consists of the date and time of printing, and the title of the + /// page. The footer consists of the URI and page number. The height of the + /// header and footer is 0.5 cm, or ~0.2 inches. + [propget] HRESULT ShouldPrintHeaderAndFooter( + [out, retval] BOOL* shouldPrintHeaderAndFooter); + + /// Set the `ShouldPrintHeaderAndFooter` property. + [propput] HRESULT ShouldPrintHeaderAndFooter( + [in] BOOL shouldPrintHeaderAndFooter); + + /// The title in the header if `ShouldPrintHeaderAndFooter` is `TRUE`. The + /// default value is the title of the current document. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT HeaderTitle([out, retval] LPWSTR* headerTitle); + + /// Set the `HeaderTitle` property. If an empty string or null value is + /// provided, no title is shown in the header. + [propput] HRESULT HeaderTitle([in] LPCWSTR headerTitle); + + /// The URI in the footer if `ShouldPrintHeaderAndFooter` is `TRUE`. The + /// default value is the current URI. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FooterUri([out, retval] LPWSTR* footerUri); + + /// Set the `FooterUri` property. If an empty string or null value is + /// provided, no URI is shown in the footer. + [propput] HRESULT FooterUri([in] LPCWSTR footerUri); +} + +/// Settings used by the `Print` method. +[uuid(CA7F0E1F-3484-41D1-8C1A-65CD44A63F8D), object, pointer_default(unique)] +interface ICoreWebView2PrintSettings2 : ICoreWebView2PrintSettings { + /// Page range to print. Defaults to empty string, which means print all pages. + /// If the Page range is empty string or null, then it applies the default. + /// + /// The PageRanges property is a list of page ranges specifying one or more pages that + /// should be printed separated by commas. Any whitespace between page ranges is ignored. + /// A valid page range is either a single integer identifying the page to print, or a range + /// in the form `[start page]-[last page]` where `start page` and `last page` are integers + /// identifying the first and last inclusive pages respectively to print. + /// Every page identifier is an integer greater than 0 unless wildcards are used (see below examples). + /// The first page is 1. + /// + /// In a page range of the form `[start page]-[last page]` the start page number must be + /// larger than 0 and less than or equal to the document's total page count. + /// If the `start page` is not present, then 1 is used as the `start page`. + /// The `last page` must be larger than the `start page`. + /// If the `last page` is not present, then the document total page count is used as the `last page`. + /// + /// Repeating a page does not print it multiple times. To print multiple times, use the `Copies` property. + /// + /// The pages are always printed in ascending order, even if specified in non-ascending order. + /// + /// If page range is not valid or if a page is greater than document total page count, + /// `ICoreWebView2PrintCompletedHandler` or `ICoreWebView2PrintToPdfStreamCompletedHandler` + /// handler will return `E_INVALIDARG`. + /// + /// The following examples assume a document with 20 total pages. + /// + /// | Example | Result | Notes | + /// | --- | --- | --- | + /// | "2" | Page 2 | | + /// | "1-4, 9, 3-6, 10, 11" | Pages 1-6, 9-11 | | + /// | "1-4, -6" | Pages 1-6 | The "-6" is interpreted as "1-6". | + /// | "2-" | Pages 2-20 | The "2-" is interpreted as "pages 2 to the end of the document". | + /// | "4-2, 11, -6" | Invalid | "4-2" is an invalid range. | + /// | "-" | Pages 1-20 | The "-" is interpreted as "page 1 to the end of the document". | + /// | "1-4dsf, 11" | Invalid | | + /// | "2-2" | Page 2 | | + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings) + [propget] HRESULT PageRanges([out, retval] LPWSTR* value); + + /// Set the `PageRanges` property. + [propput] HRESULT PageRanges([in] LPCWSTR value); + + /// Prints multiple pages of a document on a single piece of paper. Choose from 1, 2, 4, 6, 9 or 16. + /// The default value is 1. + [propget] HRESULT PagesPerSide([out, retval] INT32* value); + + /// Set the `PagesPerSide` property. Returns `E_INVALIDARG` if an invalid value is + /// provided, and the current value is not changed. + /// + /// Below examples shows print output for PagesPerSide and Duplex. + /// + /// | PagesPerSide | Total pages | Two-sided printing | Result | + /// | --- | --- | --- | --- | + /// | 1 | 1 | - | 1 page on the front side. | + /// | 2 | 1 | Yes | 1 page on the front side. | + /// | 2 | 4 | - | 2 pages on the first paper and 2 pages on the next paper. | + /// | 2 | 4 | Yes | 2 pages on the front side and 2 pages on back side. | + /// | 4 | 4 | Yes | 4 pages on the front side. | + /// | 4 | 8 | Yes | 4 pages on the front side and 4 pages on the back side. | + [propput] HRESULT PagesPerSide([in] INT32 value); + + /// Number of copies to print. Minimum value is `1` and the maximum copies count is `999`. + /// The default value is 1. + /// + /// This value is ignored in PrintToPdfStream method. + [propget] HRESULT Copies([out, retval] INT32* value); + + /// Set the `Copies` property. Returns `E_INVALIDARG` if an invalid value is provided + /// and the current value is not changed. + [propput] HRESULT Copies([in] INT32 value); + + /// Printer collation. See `COREWEBVIEW2_PRINT_COLLATION` for descriptions of + /// collation. The default value is `COREWEBVIEW2_PRINT_COLLATION_DEFAULT`. + /// + /// Printing uses default value of printer's collation if an invalid value is provided + /// for the specific printer. + /// + /// This value is ignored in PrintToPdfStream method. + [propget] HRESULT Collation([out, retval] COREWEBVIEW2_PRINT_COLLATION* value); + + /// Set the `Collation` property. + [propput] HRESULT Collation([in] COREWEBVIEW2_PRINT_COLLATION value); + + /// Printer color mode. See `COREWEBVIEW2_PRINT_COLOR_MODE` for descriptions + /// of color modes. The default value is `COREWEBVIEW2_PRINT_COLOR_MODE_DEFAULT`. + /// + /// Printing uses default value of printer supported color if an invalid value is provided + /// for the specific printer. + [propget] HRESULT ColorMode([out, retval] COREWEBVIEW2_PRINT_COLOR_MODE* value); + + /// Set the `ColorMode` property. + [propput] HRESULT ColorMode([in] COREWEBVIEW2_PRINT_COLOR_MODE value); + + /// Printer duplex settings. See `COREWEBVIEW2_PRINT_DUPLEX` for descriptions of duplex. + /// The default value is `COREWEBVIEW2_PRINT_DUPLEX_DEFAULT`. + /// + /// Printing uses default value of printer's duplex if an invalid value is provided + /// for the specific printer. + /// + /// This value is ignored in PrintToPdfStream method. + [propget] HRESULT Duplex([out, retval] COREWEBVIEW2_PRINT_DUPLEX* value); + + /// Set the `Duplex` property. + [propput] HRESULT Duplex([in] COREWEBVIEW2_PRINT_DUPLEX value); + + /// Printer media size. See `COREWEBVIEW2_PRINT_MEDIA_SIZE` for descriptions of media size. + /// The default value is `COREWEBVIEW2_PRINT_MEDIA_SIZE_DEFAULT`. + /// + /// If media size is `COREWEBVIEW2_PRINT_MEDIA_SIZE_CUSTOM`, you should set the `PageWidth` + /// and `PageHeight`. + /// + /// Printing uses default value of printer supported media size if an invalid value is provided + /// for the specific printer. + /// + /// This value is ignored in PrintToPdfStream method. + [propget] HRESULT MediaSize([out, retval] COREWEBVIEW2_PRINT_MEDIA_SIZE* value); + + /// Set the `MediaSize` property. + [propput] HRESULT MediaSize([in] COREWEBVIEW2_PRINT_MEDIA_SIZE value); + + /// The name of the printer to use. Defaults to empty string. + /// If the printer name is empty string or null, then it prints to the default + /// printer on the user OS. + /// + /// This value is ignored in PrintToPdfStream method. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings) + [propget] HRESULT PrinterName([out, retval] LPWSTR* value); + + /// Set the `PrinterName` property. If provided printer name doesn't match + /// with the name of any installed printers on the user OS, + /// `ICoreWebView2PrintCompletedHandler` handler will return `errorCode` as + /// `S_OK` and `printStatus` as COREWEBVIEW2_PRINT_STATUS_PRINTER_UNAVAILABLE. + /// + /// Use [Enum Printers](/windows/win32/printdocs/enumprinters) + /// to enumerate available printers. + [propput] HRESULT PrinterName([in] LPCWSTR value); +} + +/// Provides process with associated extended information in the `ICoreWebView2Environment`. +[uuid(af4c4c2e-45db-11ee-be56-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2ProcessExtendedInfo : IUnknown { + /// The process info of the current process. + [propget] HRESULT ProcessInfo( + [out, retval] ICoreWebView2ProcessInfo** processInfo); + + /// The collection of associated `FrameInfo`s which are actively running + /// (showing or hiding UI elements) in this renderer process. `AssociatedFrameInfos` + /// will only be populated when this `CoreWebView2ProcessExtendedInfo` + /// corresponds to a renderer process. Non-renderer processes will always + /// have an empty `AssociatedFrameInfos`. The `AssociatedFrameInfos` may + /// also be empty for renderer processes that have no active frames. + /// + /// \snippet ProcessComponent.cpp AssociatedFrameInfos + [propget] HRESULT AssociatedFrameInfos( + [out, retval] ICoreWebView2FrameInfoCollection** frames); +} + +/// A continuation of the `ICoreWebView2ProcessFailedEventArgs` interface. +[uuid(4dab9422-46fa-4c3e-a5d2-41d2071d3680), object, pointer_default(unique)] +interface ICoreWebView2ProcessFailedEventArgs2 : ICoreWebView2ProcessFailedEventArgs { + + /// The reason for the process failure. Some of the reasons are only + /// applicable to specific values of + /// `ICoreWebView2ProcessFailedEventArgs::ProcessFailedKind`, and the + /// following `ProcessFailedKind` values always return the indicated reason + /// value: + /// + /// ProcessFailedKind | Reason + /// ---|--- + /// COREWEBVIEW2_PROCESS_FAILED_KIND_BROWSER_PROCESS_EXITED | COREWEBVIEW2_PROCESS_FAILED_REASON_UNEXPECTED + /// COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_UNRESPONSIVE | COREWEBVIEW2_PROCESS_FAILED_REASON_UNRESPONSIVE + /// + /// For other `ProcessFailedKind` values, the reason may be any of the reason + /// values. To learn about what these values mean, see + /// `COREWEBVIEW2_PROCESS_FAILED_REASON`. + [propget] HRESULT Reason( + [out, retval] COREWEBVIEW2_PROCESS_FAILED_REASON* reason); + + /// The exit code of the failing process, for telemetry purposes. The exit + /// code is always `STILL_ACTIVE` (`259`) when `ProcessFailedKind` is + /// `COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_UNRESPONSIVE`. + [propget] HRESULT ExitCode( + [out, retval] int* exitCode); + + /// Description of the process assigned by the WebView2 Runtime. This is a + /// technical English term appropriate for logging or development purposes, + /// and not localized for the end user. It applies to utility processes (for + /// example, "Audio Service", "Video Capture") and plugin processes (for + /// example, "Flash"). The returned `processDescription` is empty if the + /// WebView2 Runtime did not assign a description to the process. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ProcessDescription( + [out, retval] LPWSTR* processDescription); + + /// The collection of `FrameInfo`s for frames in the `ICoreWebView2` that were + /// being rendered by the failed process. The content in these frames is + /// replaced with an error page. + /// This is only available when `ProcessFailedKind` is + /// `COREWEBVIEW2_PROCESS_FAILED_KIND_FRAME_RENDER_PROCESS_EXITED`; + /// `frames` is `null` for all other process failure kinds, including the case + /// in which the failed process was the renderer for the main frame and + /// subframes within it, for which the failure kind is + /// `COREWEBVIEW2_PROCESS_FAILED_KIND_RENDER_PROCESS_EXITED`. + [propget] HRESULT FrameInfosForFailedProcess( + [out, retval] ICoreWebView2FrameInfoCollection** frames); +} + +/// Provides a set of properties for a process in the `ICoreWebView2Environment`. +[uuid(84FA7612-3F3D-4FBF-889D-FAD000492D72), object, pointer_default(unique)] +interface ICoreWebView2ProcessInfo : IUnknown { + + /// The process id of the process. + [propget] HRESULT ProcessId([out, retval] INT32* value); + + /// The kind of the process. + [propget] HRESULT Kind([out, retval] COREWEBVIEW2_PROCESS_KIND* kind); +} + +/// Provides a set of properties to configure a Profile object. +/// +/// \snippet AppWindow.cpp OnCreateCoreWebView2ControllerCompleted +[uuid(79110ad3-cd5d-4373-8bc3-c60658f17a5f), object, pointer_default(unique)] +interface ICoreWebView2Profile : IUnknown { + /// Name of the profile. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ProfileName([out, retval] LPWSTR* value); + + /// InPrivate mode is enabled or not. + [propget] HRESULT IsInPrivateModeEnabled([out, retval] BOOL* value); + + /// Full path of the profile directory. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ProfilePath([out, retval] LPWSTR* value); + + /// Gets the `DefaultDownloadFolderPath` property. The default value is the + /// system default download folder path for the user. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT DefaultDownloadFolderPath([out, retval] LPWSTR* value); + + /// Sets the `DefaultDownloadFolderPath` property. The default download folder + /// path is persisted in the user data folder across sessions. The value + /// should be an absolute path to a folder that the user and application can + /// write to. Returns `E_INVALIDARG` if the value is invalid, and the default + /// download folder path is not changed. Otherwise the path is changed + /// immediately. If the directory does not yet exist, it is created at the + /// time of the next download. If the host application does not have + /// permission to create the directory, then the user is prompted to provide a + /// new path through the Save As dialog. The user can override the default + /// download folder path for a given download by choosing a different path in + /// the Save As dialog. + [propput] HRESULT DefaultDownloadFolderPath([in] LPCWSTR value); + + /// The PreferredColorScheme property sets the overall color scheme of the + /// WebView2s associated with this profile. This sets the color scheme for + /// WebView2 UI like dialogs, prompts, and context menus by setting the + /// media feature `prefers-color-scheme` for websites to respond to. + /// + /// The default value for this is COREWEBVIEW2_PREFERRED_COLOR_AUTO, + /// which will follow whatever theme the OS is currently set to. + /// + /// \snippet ViewComponent.cpp SetPreferredColorScheme + /// Returns the value of the `PreferredColorScheme` property. + [propget] HRESULT PreferredColorScheme( + [out, retval] COREWEBVIEW2_PREFERRED_COLOR_SCHEME* value); + + /// Sets the `PreferredColorScheme` property. + [propput] HRESULT PreferredColorScheme( + [in] COREWEBVIEW2_PREFERRED_COLOR_SCHEME value); +} + +/// Interfaces in profile for managing password-autosave and general-autofill. +[uuid(BD82FA6A-1D65-4C33-B2B4-0393020CC61B), object, pointer_default(unique)] +interface ICoreWebView2Profile6 : ICoreWebView2Profile5 { + /// IsPasswordAutosaveEnabled controls whether autosave for password + /// information is enabled. The IsPasswordAutosaveEnabled property behaves + /// independently of the IsGeneralAutofillEnabled property. When IsPasswordAutosaveEnabled is + /// false, no new password data is saved and no Save/Update Password prompts are displayed. + /// However, if there was password data already saved before disabling this setting, + /// then that password information is auto-populated, suggestions are shown and clicking on + /// one will populate the fields. + /// When IsPasswordAutosaveEnabled is true, password information is auto-populated, + /// suggestions are shown and clicking on one will populate the fields, new data + /// is saved, and a Save/Update Password prompt is displayed. + /// It will take effect immediately after setting. + /// The default value is `FALSE`. + /// This property has the same value as + /// `CoreWebView2Settings.IsPasswordAutosaveEnabled`, and changing one will + /// change the other. All `CoreWebView2`s with the same `CoreWebView2Profile` + /// will share the same value for this property, so for the `CoreWebView2`s + /// with the same profile, their + /// `CoreWebView2Settings.IsPasswordAutosaveEnabled` and + /// `CoreWebView2Profile.IsPasswordAutosaveEnabled` will always have the same + /// value. + /// + /// \snippet SettingsComponent.cpp ToggleProfilePasswordAutosaveEnabled + [propget] HRESULT IsPasswordAutosaveEnabled([out, retval] BOOL* value); + + /// Set the IsPasswordAutosaveEnabled property. + [propput] HRESULT IsPasswordAutosaveEnabled([in] BOOL value); + + /// IsGeneralAutofillEnabled controls whether autofill for information + /// like names, street and email addresses, phone numbers, and arbitrary input + /// is enabled. This excludes password and credit card information. When + /// IsGeneralAutofillEnabled is false, no suggestions appear, and no new information + /// is saved. When IsGeneralAutofillEnabled is true, information is saved, suggestions + /// appear and clicking on one will populate the form fields. + /// It will take effect immediately after setting. + /// The default value is `TRUE`. + /// This property has the same value as + /// `CoreWebView2Settings.IsGeneralAutofillEnabled`, and changing one will + /// change the other. All `CoreWebView2`s with the same `CoreWebView2Profile` + /// will share the same value for this property, so for the `CoreWebView2`s + /// with the same profile, their + /// `CoreWebView2Settings.IsGeneralAutofillEnabled` and + /// `CoreWebView2Profile.IsGeneralAutofillEnabled` will always have the same + /// value. + /// + /// \snippet SettingsComponent.cpp ToggleProfileGeneralAutofillEnabled + [propget] HRESULT IsGeneralAutofillEnabled([out, retval] BOOL* value); + + /// Set the IsGeneralAutofillEnabled property. + [propput] HRESULT IsGeneralAutofillEnabled([in] BOOL value); +} + +/// This is the profile interface that manages profile +/// deletion. +[uuid(fbf70c2f-eb1f-4383-85a0-163e92044011), object, pointer_default(unique)] +interface ICoreWebView2Profile8 : ICoreWebView2Profile7 { + /// After the API is called, the profile will be marked for deletion. The + /// local profile's directory will be deleted at browser process exit. If it + /// fails to delete, because something else is holding the files open, + /// WebView2 will try to delete the profile at all future browser process + /// starts until successful. + /// The corresponding CoreWebView2s will be closed and the + /// CoreWebView2Profile.Deleted event will be raised. See + /// `CoreWebView2Profile.Deleted` for more information. + /// If you try to create a new profile with the same name as an existing + /// profile that has been marked as deleted but hasn't yet been deleted, + /// profile creation will fail with HRESULT_FROM_WIN32(ERROR_DELETE_PENDING). + /// + /// \snippet SettingsComponent.cpp DeleteProfile + HRESULT Delete(); + + /// Add an event handler for the `Deleted` event. The `Deleted` event is + /// raised when the profile is marked for deletion. When this event is + /// raised, the CoreWebView2Profile and its corresponding CoreWebView2s have + /// been closed, and cannot be used anymore. + /// + /// \snippet AppWindow.cpp ProfileDeleted + HRESULT add_Deleted( + [in] ICoreWebView2ProfileDeletedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_Deleted`. + HRESULT remove_Deleted( + [in] EventRegistrationToken token); +} + +/// Event args for the `ScriptDialogOpening` event. +[uuid(7390bb70-abe0-4843-9529-f143b31b03d6), object, pointer_default(unique)] +interface ICoreWebView2ScriptDialogOpeningEventArgs : IUnknown { + + /// The URI of the page that requested the dialog box. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Uri([out, retval] LPWSTR* uri); + + /// The kind of JavaScript dialog box. `alert`, `confirm`, `prompt`, or + /// `beforeunload`. + + [propget] HRESULT Kind([out, retval] COREWEBVIEW2_SCRIPT_DIALOG_KIND* kind); + + /// The message of the dialog box. From JavaScript this is the first + /// parameter passed to `alert`, `confirm`, and `prompt` and is empty for + /// `beforeunload`. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Message([out, retval] LPWSTR* message); + + /// The host may run this to respond with **OK** to `confirm`, `prompt`, and + /// `beforeunload` dialogs. Do not run this method to indicate cancel. + /// From JavaScript, this means that the `confirm` and `beforeunload` function + /// returns `TRUE` if `Accept` is run. And for the prompt function it returns + /// the value of `ResultText` if `Accept` is run and otherwise returns + /// `FALSE`. + + HRESULT Accept(); + + /// The second parameter passed to the JavaScript prompt dialog. + /// The result of the prompt JavaScript function uses this value as the + /// default value. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT DefaultText([out, retval] LPWSTR* defaultText); + + /// The return value from the JavaScript prompt function if `Accept` is run. + /// This value is ignored for dialog kinds other than prompt. If `Accept` + /// is not run, this value is ignored and `FALSE` is returned from prompt. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT ResultText([out, retval] LPWSTR* resultText); + + /// Sets the `ResultText` property. + + [propput] HRESULT ResultText([in] LPCWSTR resultText); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to + /// complete the event at a later time. + + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// This interface represents a JavaScript exception. +/// If the CoreWebView2.ExecuteScriptWithResult result has Succeeded as false, +/// you can use the result's Exception property to get the script exception. +[uuid(054DAE00-84A3-49FF-BC17-4012A90BC9FD), object, pointer_default(unique)] +interface ICoreWebView2ScriptException : IUnknown { + /// The line number of the source where the exception occurred. + /// In the JSON it is `exceptionDetail.lineNumber`. + /// Note that this position starts at 0. + [propget] HRESULT LineNumber([out, retval] UINT32* value); + + /// The column number of the source where the exception occurred. + /// In the JSON it is `exceptionDetail.columnNumber`. + /// Note that this position starts at 0. + [propget] HRESULT ColumnNumber([out, retval] UINT32* value); + /// The Name is the exception's class name. + /// In the JSON it is `exceptionDetail.exception.className`. + /// This is the empty string if the exception doesn't have a class name. + /// This can happen if the script throws a non-Error object such as `throw "abc";` + [propget] HRESULT Name([out, retval] LPWSTR* value); + /// The Message is the exception's message and potentially stack. + /// In the JSON it is exceptionDetail.exception.description. + /// This is the empty string if the exception doesn't have a description. + /// This can happen if the script throws a non-Error object such as throw "abc";. + [propget] HRESULT Message([out, retval] LPWSTR* value); + /// This will return all details of the exception as a JSON string. + /// In the case that script has thrown a non-Error object such as `throw "abc";` + /// or any other non-Error object, you can get object specific properties. + [propget] HRESULT ToJson([out, retval] LPWSTR* value); +} + +/// Event args for the `ServerCertificateErrorDetected` event. +[uuid(012193ED-7C13-48FF-969D-A84C1F432A14), object, pointer_default(unique)] +interface ICoreWebView2ServerCertificateErrorDetectedEventArgs : IUnknown { + /// The TLS error code for the invalid certificate. + [propget] HRESULT ErrorStatus([out, retval] COREWEBVIEW2_WEB_ERROR_STATUS* value); + + /// URI associated with the request for the invalid certificate. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT RequestUri([out, retval] LPWSTR* value); + + /// Returns the server certificate. + [propget] HRESULT ServerCertificate([out, retval] ICoreWebView2Certificate** value); + + /// The action of the server certificate error detection. + /// The default value is `COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_DEFAULT`. + [propget] HRESULT Action([out, retval] COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION* value); + + /// Sets the `Action` property. + [propput] HRESULT Action([in] COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION value); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to + /// complete the event at a later time. + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// The shared buffer object that is created by [CreateSharedBuffer](/microsoft-edge/webview2/reference/win32/icorewebview2environment12#createsharedbuffer). +/// The object is presented to script as ArrayBuffer when posted to script with +/// [PostSharedBufferToScript](/microsoft-edge/webview2/reference/win32/icorewebview2_17#postsharedbuffertoscript). +[uuid(B747A495-0C6F-449E-97B8-2F81E9D6AB43), object, pointer_default(unique)] +interface ICoreWebView2SharedBuffer : IUnknown { + /// The size of the shared buffer in bytes. + [propget] HRESULT Size([out, retval] UINT64* value); + + /// The memory address of the shared buffer. + [propget] HRESULT Buffer([out, retval] BYTE** value); + + /// Get an IStream object that can be used to access the shared buffer. + HRESULT OpenStream([out, retval] IStream** value); + + /// Returns a handle to the file mapping object that backs this shared buffer. + /// The returned handle is owned by the shared buffer object. You should not + /// call CloseHandle on it. + /// Normal app should use `Buffer` or `OpenStream` to get memory address + /// or IStream object to access the buffer. + /// For advanced scenarios, you could use file mapping APIs to obtain other views + /// or duplicate this handle to another application process and create a view from + /// the duplicated handle in that process to access the buffer from that separate process. + [propget] HRESULT FileMappingHandle([out, retval] HANDLE* value); + + /// Release the backing shared memory. The application should call this API when no + /// access to the buffer is needed any more, to ensure that the underlying resources + /// are released timely even if the shared buffer object itself is not released due to + /// some leaked reference. + /// After the shared buffer is closed, the buffer address and file mapping handle previously + /// obtained becomes invalid and cannot be used anymore. Accessing properties of the object + /// will fail with `RO_E_CLOSED`. Operations like Read or Write on the IStream objects returned + /// from `OpenStream` will fail with `RO_E_CLOSED`. `PostSharedBufferToScript` will also + /// fail with `RO_E_CLOSED`. + /// + /// The script code should call `chrome.webview.releaseBuffer` with + /// the shared buffer as the parameter to release underlying resources as soon + /// as it does not need access the shared buffer any more. + /// When script tries to access the buffer after calling `chrome.webview.releaseBuffer`, + /// JavaScript `TypeError` exception will be raised complaining about accessing a + /// detached ArrayBuffer, the same exception when trying to access a transferred ArrayBuffer. + /// + /// Closing the buffer object on native side doesn't impact access from Script and releasing + /// the buffer from script doesn't impact access to the buffer from native side. + /// The underlying shared memory will be released by the OS when both native and script side + /// release the buffer. + HRESULT Close(); +} + +/// An HTTP request used with the `WebResourceRequested` event. +[uuid(97055cd4-512c-4264-8b5f-e3f446cea6a5), object, pointer_default(unique)] +interface ICoreWebView2WebResourceRequest : IUnknown { + + /// The request URI. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Uri([out, retval] LPWSTR* uri); + + /// Sets the `Uri` property. + + [propput] HRESULT Uri([in] LPCWSTR uri); + + /// The HTTP request method. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT Method([out, retval] LPWSTR* method); + + /// Sets the `Method` property. + + [propput] HRESULT Method([in] LPCWSTR method); + + /// The HTTP request message body as stream. POST data should be here. If a + /// stream is set, which overrides the message body, the stream must have + /// all the content data available by the time the `WebResourceRequested` + /// event deferral of this response is completed. Stream should be agile or + /// be created from a background STA to prevent performance impact to the UI + /// thread. `Null` means no content data. `IStream` semantics apply + /// (return `S_OK` to `Read` runs until all data is exhausted). + + [propget] HRESULT Content([out, retval] IStream** content); + + /// Sets the `Content` property. + + [propput] HRESULT Content([in] IStream* content); + + /// The mutable HTTP request headers + + [propget] HRESULT Headers([out, retval] ICoreWebView2HttpRequestHeaders** headers); +} + +/// Event args for the `WebResourceRequested` event. +[uuid(453e667f-12c7-49d4-be6d-ddbe7956f57a), object, pointer_default(unique)] +interface ICoreWebView2WebResourceRequestedEventArgs : IUnknown { + + /// The Web resource request. The request object may be missing some headers + /// that are added by network stack at a later time. + + [propget] HRESULT Request([out, retval] ICoreWebView2WebResourceRequest** request); + + /// A placeholder for the web resource response object. If this object is + /// set, the web resource request is completed with the specified response. + + [propget] HRESULT Response([out, retval] ICoreWebView2WebResourceResponse** response); + + /// Sets the `Response` property. Create an empty web resource response + /// object with `CreateWebResourceResponse` and then modify it to construct + /// the response. + + [propput] HRESULT Response([in] ICoreWebView2WebResourceResponse* response); + + /// Obtain an `ICoreWebView2Deferral` object and put the event into a + /// deferred state. Use the `ICoreWebView2Deferral` object to complete the + /// request at a later time. + + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); + + /// The web resource request context. + + [propget] HRESULT ResourceContext([out, retval] COREWEBVIEW2_WEB_RESOURCE_CONTEXT* context); +} + +/// An HTTP response used with the `WebResourceRequested` event. +[uuid(aafcc94f-fa27-48fd-97df-830ef75aaec9), object, pointer_default(unique)] +interface ICoreWebView2WebResourceResponse : IUnknown { + + /// HTTP response content as stream. Stream must have all the content data + /// available by the time the `WebResourceRequested` event deferral of this + /// response is completed. Stream should be agile or be created from a + /// background thread to prevent performance impact to the UI thread. `Null` + /// means no content data. `IStream` semantics apply (return `S_OK` to + /// `Read` runs until all data is exhausted). + /// When providing the response data, you should consider relevant HTTP + /// request headers just like an HTTP server would do. For example, if the + /// request was for a video resource in a HTML video element, the request may + /// contain the [Range](https://developer.mozilla.org/docs/Web/HTTP/Headers/Range) + /// header to request only a part of the video that is streaming. In this + /// case, your response stream should be only the portion of the video + /// specified by the range HTTP request headers and you should set the + /// appropriate + /// [Content-Range](https://developer.mozilla.org/docs/Web/HTTP/Headers/Content-Range) + /// header in the response. + + [propget] HRESULT Content([out, retval] IStream** content); + + /// Sets the `Content` property. + + [propput] HRESULT Content([in] IStream* content); + + /// Overridden HTTP response headers. + + [propget] HRESULT Headers([out, retval] ICoreWebView2HttpResponseHeaders** headers); + + /// The HTTP response status code. + + [propget] HRESULT StatusCode([out, retval] int* statusCode); + + /// Sets the `StatusCode` property. + + [propput] HRESULT StatusCode([in] int statusCode); + + /// The HTTP response reason phrase. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + + [propget] HRESULT ReasonPhrase([out, retval] LPWSTR* reasonPhrase); + + /// Sets the `ReasonPhrase` property. + + [propput] HRESULT ReasonPhrase([in] LPCWSTR reasonPhrase); +} + +/// View of the HTTP representation for a web resource response. The properties +/// of this object are not mutable. This response view is used with the +/// WebResourceResponseReceived event. +[uuid(79701053-7759-4162-8F7D-F1B3F084928D), object, pointer_default(unique)] +interface ICoreWebView2WebResourceResponseView : IUnknown { + /// The HTTP response headers as received. + [propget] HRESULT Headers( + [out, retval] ICoreWebView2HttpResponseHeaders** headers); + /// The HTTP response status code. + [propget] HRESULT StatusCode([out, retval] int* statusCode); + /// The HTTP response reason phrase. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ReasonPhrase([out, retval] LPWSTR* reasonPhrase); + + /// Get the response content asynchronously. The handler will receive the + /// response content stream. + /// + /// This method returns null if content size is more than 123MB or for navigations that become downloads + /// or if response is downloadable content type (e.g., application/octet-stream). + /// See `add_DownloadStarting` event to handle the response. + /// + /// If this method is being called again before a first call has completed, + /// the handler will be invoked at the same time the handlers from prior calls + /// are invoked. + /// If this method is being called after a first call has completed, the + /// handler will be invoked immediately. + /// \snippet ScenarioWebViewEventMonitor.cpp GetContent + HRESULT GetContent( + [in] ICoreWebView2WebResourceResponseViewGetContentCompletedHandler* handler); +} + +/// The window features for a WebView popup window. The fields match the +/// `windowFeatures` passed to `window.open` as specified in +/// [Window features](https://developer.mozilla.org/docs/Web/API/Window/open#Window_features) +/// on MDN. +/// +/// There is no requirement for you to respect the values. If your app does +/// not have corresponding UI features (for example, no toolbar) or if all +/// instance of WebView are opened in tabs and do not have distinct size or +/// positions, then your app does not respect the values. You may want to +/// respect values, but perhaps only some apply to the UI of you app. +/// Accordingly, you may respect all, some, or none of the properties as +/// appropriate for your app. For all numeric properties, if the value that is +/// passed to `window.open` is outside the range of an unsigned 32bit int, the +/// resulting value is the absolute value of the maximum for unsigned 32bit +/// integer. If you are not able to parse the value an integer, it is +/// considered `0`. If the value is a floating point value, it is rounded down +/// to an integer. +/// +/// In runtime versions 98 or later, the values of `ShouldDisplayMenuBar`, +/// `ShouldDisplayStatus`, `ShouldDisplayToolbar`, and `ShouldDisplayScrollBars` +/// will not directly depend on the equivalent fields in the `windowFeatures` +/// string. Instead, they will all be false if the window is expected to be a +/// popup, and true if it is not. +[uuid(5eaf559f-b46e-4397-8860-e422f287ff1e), object, pointer_default(unique)] +interface ICoreWebView2WindowFeatures : IUnknown { + + /// Specifies left and top values. + + [propget] HRESULT HasPosition([out, retval] BOOL* value); + + /// Specifies height and width values. + + [propget] HRESULT HasSize([out, retval] BOOL* value); + + /// Specifies the left position of the window. If `HasPosition` is set to + /// `FALSE`, this field is ignored. + + [propget] HRESULT Left([out, retval] UINT32* value); + + /// Specifies the top position of the window. If `HasPosition` is set to + /// `FALSE`, this field is ignored. + + [propget] HRESULT Top([out, retval] UINT32* value); + + /// Specifies the height of the window. Minimum value is `100`. If + /// `HasSize` is set to `FALSE`, this field is ignored. + + [propget] HRESULT Height([out, retval] UINT32* value); + + /// Specifies the width of the window. Minimum value is `100`. If `HasSize` + /// is set to `FALSE`, this field is ignored. + + [propget] HRESULT Width([out, retval] UINT32* value); + + /// Indicates that the menu bar is displayed. + + [propget] HRESULT ShouldDisplayMenuBar([out, retval] BOOL* value); + + /// Indicates that the status bar is displayed. + + [propget] HRESULT ShouldDisplayStatus([out, retval] BOOL* value); + + /// Indicates that the browser toolbar is displayed. + + [propget] HRESULT ShouldDisplayToolbar([out, retval] BOOL* value); + + /// Indicates that the scroll bars are displayed. + + [propget] HRESULT ShouldDisplayScrollBars([out, retval] BOOL* value); +} + +/// Represents a collection of generic objects. Used to get, remove and add +/// objects at the specified index. +[uuid(5cfec11c-25bd-4e8d-9e1a-7acdaeeec047), object, pointer_default(unique)] +interface ICoreWebView2ObjectCollection : ICoreWebView2ObjectCollectionView { + /// Removes the object at the specified index. + HRESULT RemoveValueAtIndex( + [in] UINT32 index + ); + + /// Inserts the object at the specified index. + HRESULT InsertValueAtIndex( + [in] UINT32 index, + [in] IUnknown* value + ); +} + +/// This is the ICoreWebView2Notification that represents a [HTML Notification +/// object](https://developer.mozilla.org/docs/Web/API/Notification). +[uuid(B7434D98-6BC8-419D-9DA5-FB5A96D4DACD), object, pointer_default(unique)] +interface ICoreWebView2Notification : IUnknown { + /// Add an event handler for the `CloseRequested` event. This event is raised + /// when the notification is closed by the web code, such as through + /// `notification.close()`. You don't need to call `ReportClosed` since this is + /// coming from the web code. + HRESULT add_CloseRequested( + [in] ICoreWebView2NotificationCloseRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Remove an event handler previously added with `add_CloseRequested`. + HRESULT remove_CloseRequested( + [in] EventRegistrationToken token); + + /// The host may run this to report the notification has been displayed and it + /// will cause the + /// [show](https://developer.mozilla.org/docs/Web/API/Notification/show_event) + /// event to be raised for non-persistent notifications. You must not run this + /// unless you are handling the `NotificationReceived` event. Returns + /// `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` if `Handled` is `FALSE` when + /// this is called. + HRESULT ReportShown(); + + /// The host may run this to report the notification has been clicked, and it + /// will cause the + /// [click](https://developer.mozilla.org/docs/Web/API/Notification/click_event) + /// event to be raised for non-persistent notifications and the + /// [notificationclick](https://developer.mozilla.org/docs/Web/API/ServiceWorkerGlobalScope/notificationclick_event) + /// event for persistent notifications. Use `ReportClickedWithActionIndex` to + /// specify an action to activate a persistent notification. You must not run + /// this unless you are handling the `NotificationReceived` event. Returns + /// `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` if `Handled` is `FALSE` or + /// `ReportShown` has not been run when this is called. + HRESULT ReportClicked(); + + /// The host may run this to report the notification was dismissed, and it + /// will cause the + /// [close](https://developer.mozilla.org/docs/Web/API/Notification/close_event) + /// event to be raised for non-persistent notifications and the + /// [notificationclose](https://developer.mozilla.org/docs/Web/API/ServiceWorkerGlobalScope/notificationclose_event) + /// event for persistent notifications. You must not run this unless you are + /// handling the `NotificationReceived` event. Returns + /// `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` if `Handled` is `FALSE` or + /// `ReportShown` has not been run when this is called. + HRESULT ReportClosed(); + + /// A string representing the body text of the notification. + /// The default value is an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Body([out, retval] LPWSTR* value); + + /// The text direction in which to display the notification. + /// This corresponds to + /// [Notification.dir](https://developer.mozilla.org/docs/Web/API/Notification/dir) + /// DOM API. + /// The default value is `COREWEBVIEW2_TEXT_DIRECTION_KIND_DEFAULT`. + [propget] HRESULT Direction([out, retval] COREWEBVIEW2_TEXT_DIRECTION_KIND* value); + + /// The notification's language, as intended to be specified using a string + /// representing a language tag (such as `en-US`) according to + /// [BCP47](https://datatracker.ietf.org/doc/html/rfc5646). Note that no + /// validation is performed on this property and it can be any string the + /// notification sender specifies. + /// This corresponds to + /// [Notification.lang](https://developer.mozilla.org/docs/Web/API/Notification/lang) + /// DOM API. + /// The default value is an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Language([out, retval] LPWSTR* value); + + /// A string representing an identifying tag for the notification. + /// This corresponds to + /// [Notification.tag](https://developer.mozilla.org/docs/Web/API/Notification/tag) + /// DOM API. + /// The default value is an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Tag([out, retval] LPWSTR* value); + + /// A string containing the URI of an icon to be displayed in the + /// notification. + /// The default value is an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT IconUri([out, retval] LPWSTR* value); + + /// The title of the notification. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Title([out, retval] LPWSTR* value); + + /// A string containing the URI of the image used to represent the + /// notification when there isn't enough space to display the notification + /// itself. + /// The default value is an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT BadgeUri([out, retval] LPWSTR* value); + + /// A string containing the URI of an image to be displayed in the + /// notification. + /// The default value is an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT BodyImageUri([out, retval] LPWSTR* value); + + /// Indicates whether the user should be notified after a new notification + /// replaces an old one. + /// This corresponds to + /// [Notification.renotify](https://developer.mozilla.org/docs/Web/API/Notification/renotify) + /// DOM API. + /// The default value is `FALSE`. + [propget] HRESULT ShouldRenotify([out, retval] BOOL* value); + + /// A boolean value indicating that a notification should remain active until + /// the user clicks or dismisses it, rather than closing automatically. + /// This corresponds to + /// [Notification.requireInteraction](https://developer.mozilla.org/docs/Web/API/Notification/requireInteraction) + /// DOM API. Note that you may not be able to necessarily implement this due to native API limitations. + /// The default value is `FALSE`. + [propget] HRESULT RequiresInteraction([out, retval] BOOL* value); + + /// Indicates whether the notification should be silent -- i.e., no sounds or + /// vibrations should be issued, regardless of the device settings. + /// This corresponds to + /// [Notification.silent](https://developer.mozilla.org/docs/Web/API/Notification/silent) + /// DOM API. + /// The default value is `FALSE`. + [propget] HRESULT IsSilent([out, retval] BOOL* value); + + /// Indicates the time at which a notification is created or applicable (past, + /// present, or future) as the number of milliseconds since the UNIX epoch. + [propget] HRESULT Timestamp([out, retval] double* value); + + /// Gets the vibration pattern for devices with vibration hardware to emit. + /// The vibration pattern can be represented by an array of 64-bit unsigned integers + /// describing a pattern of vibrations and pauses. See [Vibration + /// API](https://developer.mozilla.org/docs/Web/API/Vibration_API) for more + /// information. + /// This corresponds to + /// [Notification.vibrate](https://developer.mozilla.org/docs/Web/API/Notification/vibrate) + /// DOM API. + /// An empty array is returned if no vibration patterns are + /// specified. + HRESULT GetVibrationPattern([out] UINT32* count, [out] UINT64** vibrationPattern); +} + +/// Event args for the `NotificationReceived` event. +/// \snippet ScenarioNotificationReceived.cpp NotificationReceived +[uuid(1512DD5B-5514-4F85-886E-21C3A4C9CFE6), object, pointer_default(unique)] +interface ICoreWebView2NotificationReceivedEventArgs : IUnknown { + /// The origin of the web content that sends the notification, such as + /// `https://example.com/` or `https://www.example.com/`. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT SenderOrigin([out, retval] LPWSTR* value); + + /// The notification that was received. You can access the + /// properties on the Notification object to show your own notification. + [propget] HRESULT Notification([out, retval] ICoreWebView2Notification** value); + + /// Sets whether the `NotificationReceived` event is handled by the host after + /// the event handler completes or if there is a deferral then after the + /// deferral is completed. + /// + /// If `Handled` is set to TRUE then WebView will not display the notification + /// with the default UI, and the host will be responsible for handling the + /// notification and for letting the web content know that the notification + /// has been displayed, clicked, or closed. You must set `Handled` to `TRUE` + /// before you call `ReportShown`, `ReportClicked`, + /// `ReportClickedWithActionIndex` and `ReportClosed`, otherwise they will + /// fail with `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)`. If after the event + /// handler or deferral completes `Handled` is set to FALSE then WebView will + /// display the default notification UI. Note that you cannot un-handle this + /// event once you have set `Handled` to be `TRUE`. The initial value is + /// FALSE. + [propput] HRESULT Handled([in] BOOL value); + + /// Gets whether the `NotificationReceived` event is handled by host. + [propget] HRESULT Handled([out, retval] BOOL* value); + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to complete + /// the event at a later time. + HRESULT GetDeferral([out, retval] ICoreWebView2Deferral** deferral); +} + +/// The event args for `SaveAsUIShowing` event. +[uuid(55902952-0e0d-5aaa-a7d0-e833cdb34f62), object, pointer_default(unique)] +interface ICoreWebView2SaveAsUIShowingEventArgs : IUnknown { + /// Get the Mime type of content to be saved. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ContentMimeType([out, retval] LPWSTR* value); + + /// Sets the `Cancel` property. Set this property to `TRUE` to cancel the Save As action + /// and prevent the download from starting. ShowSaveAsUI returns + /// `COREWEBVIEW2_SAVE_AS_UI_RESULT_CANCELLED` in this case. The default value is `FALSE`. + [propput] HRESULT Cancel([in] BOOL value); + + /// Gets the `Cancel` property. + [propget] HRESULT Cancel([out, retval] BOOL* value); + + /// Sets the `SuppressDefaultDialog` property, which indicates whether the system + /// default dialog is suppressed. When `SuppressDefaultDialog` is `FALSE`, the default + /// Save As dialog is shown and the values assigned through `SaveAsFilePath`, `AllowReplace` + /// and `Kind` are ignored when the event args invoke completed. + /// + /// Set `SuppressDefaultDialog` to `TRUE` to perform a silent Save As. When + /// `SuppressDefaultDialog` is `TRUE`, the system dialog is skipped and the + /// `SaveAsFilePath`, `AllowReplace` and `Kind` values are used. + /// + /// The default value is FALSE. + [propput] HRESULT SuppressDefaultDialog([in] BOOL value); + + /// Gets the `SuppressDefaultDialog` property. + [propget] HRESULT SuppressDefaultDialog([out, retval] BOOL* value); + + /// Returns an `ICoreWebView2Deferral` object. This will defer showing the + /// default Save As dialog and performing the Save As operation. + HRESULT GetDeferral( + [out, retval] ICoreWebView2Deferral** value + ); + + /// Set the `SaveAsFilePath` property for Save As. `SaveAsFilePath` is an absolute path + /// of the location. It includes the file name and extension. If `SaveAsFilePath` is not + /// valid (for example, the root drive does not exist), Save As is denied and + /// `COREWEBVIEW2_SAVE_AS_INVALID_PATH` is returned. + /// + /// If the associated download completes successfully, a target file is saved at + /// this location. If the Kind property is `COREWEBVIEW2_SAVE_AS_KIND_COMPLETE`, + /// there will be an additional directory with resources files. + /// + /// The default value is a system suggested path, based on users' local environment. + [propput] HRESULT SaveAsFilePath([in] LPCWSTR value); + + + /// Gets the `SaveAsFilePath` property. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT SaveAsFilePath([out, retval] LPWSTR* value); + + /// `AllowReplace` allows user to control what happens when a file already + /// exists in the file path to which the Save As operation is saving. + /// Setting this property to `TRUE` allows existing files to be replaced. + /// Setting this property to `FALSE` will not replace existing files and will return + /// `COREWEBVIEW2_SAVE_AS_UI_RESULT_FILE_ALREADY_EXISTS`. + /// + /// The default value is `FALSE`. + [propput] HRESULT AllowReplace([in] BOOL value); + + /// Gets the `AllowReplace` property. + [propget] HRESULT AllowReplace([out, retval] BOOL* value); + + /// Sets the `Kind` property to save documents of different kinds. See the + /// `COREWEBVIEW2_SAVE_AS_KIND` enum for a description of the different options. + /// If the kind is not allowed for the current document, ShowSaveAsUI returns + /// `COREWEBVIEW2_SAVE_AS_UI_RESULT_KIND_NOT_SUPPORTED`. + /// + /// The default value is `COREWEBVIEW2_SAVE_AS_KIND_DEFAULT`. + [propput] HRESULT Kind([in] COREWEBVIEW2_SAVE_AS_KIND value); + + /// Gets the `Kind` property. + [propget] HRESULT Kind([out, retval] COREWEBVIEW2_SAVE_AS_KIND* value); +} + + + +/// This is a continuation of the ICoreWebView2AcceleratorKeyPressedEventArgs interface. +[uuid(03b2c8c8-7799-4e34-bd66-ed26aa85f2bf), object, pointer_default(unique)] +interface ICoreWebView2AcceleratorKeyPressedEventArgs2 : ICoreWebView2AcceleratorKeyPressedEventArgs { + /// Gets the `IsBrowserAcceleratorKeyEnabled` property. + [propget] HRESULT IsBrowserAcceleratorKeyEnabled([out, retval] BOOL* value); + + + /// This property allows developers to enable or disable the browser from handling a specific + /// browser accelerator key such as Ctrl+P or F3, etc. + /// + /// Browser accelerator keys are the keys/key combinations that access features specific to + /// a web browser, including but not limited to: + /// - Ctrl-F and F3 for Find on Page + /// - Ctrl-P for Print + /// - Ctrl-R and F5 for Reload + /// - Ctrl-Plus and Ctrl-Minus for zooming + /// - Ctrl-Shift-C and F12 for DevTools + /// - Special keys for browser functions, such as Back, Forward, and Search + /// + /// This property does not disable accelerator keys related to movement and text editing, + /// such as: + /// - Home, End, Page Up, and Page Down + /// - Ctrl-X, Ctrl-C, Ctrl-V + /// - Ctrl-A for Select All + /// - Ctrl-Z for Undo + /// + /// The `CoreWebView2Settings.AreBrowserAcceleratorKeysEnabled` API is a convenient setting + /// for developers to disable all the browser accelerator keys together, and sets the default + /// value for the `IsBrowserAcceleratorKeyEnabled` property. + /// By default, `CoreWebView2Settings.AreBrowserAcceleratorKeysEnabled` is `TRUE` and + /// `IsBrowserAcceleratorKeyEnabled` is `TRUE`. + /// When developers change `CoreWebView2Settings.AreBrowserAcceleratorKeysEnabled` setting to `FALSE`, + /// this will change default value for `IsBrowserAcceleratorKeyEnabled` to `FALSE`. + /// If developers want specific keys to be handled by the browser after changing the + /// `CoreWebView2Settings.AreBrowserAcceleratorKeysEnabled` setting to `FALSE`, they need to enable + /// these keys by setting `IsBrowserAcceleratorKeyEnabled` to `TRUE`. + /// This API will give the event arg higher priority over the + /// `CoreWebView2Settings.AreBrowserAcceleratorKeysEnabled` setting when we handle the keys. + /// + /// For browser accelerator keys, when an accelerator key is pressed, the propagation and + /// processing order is: + /// 1. A CoreWebView2Controller.AcceleratorKeyPressed event is raised + /// 2. WebView2 browser feature accelerator key handling + /// 3. Web Content Handling: If the key combination isn't reserved for browser actions, + /// the key event propagates to the web content, where JavaScript event listeners can + /// capture and respond to it. + /// + /// `ICoreWebView2AcceleratorKeyPressedEventArgs` has a `Handled` property, that developers + /// can use to mark a key as handled. When the key is marked as handled anywhere along + /// the path, the event propagation stops, and web content will not receive the key. + /// With `IsBrowserAcceleratorKeyEnabled` property, if developers mark + /// `IsBrowserAcceleratorKeyEnabled` as `FALSE`, the browser will skip the WebView2 + /// browser feature accelerator key handling process, but the event propagation + /// continues, and web content will receive the key combination. + /// + /// \snippet ScenarioAcceleratorKeyPressed.cpp IsBrowserAcceleratorKeyEnabled + /// Gets the `IsBrowserAcceleratorKeyEnabled` property. + [propput] HRESULT IsBrowserAcceleratorKeyEnabled([in] BOOL value); + + + +} + + + +/// Event args for the `BrowserProcessExited` event. +[uuid(1f00663f-af8c-4782-9cdd-dd01c52e34cb), object, pointer_default(unique)] +interface ICoreWebView2BrowserProcessExitedEventArgs : IUnknown { + /// The kind of browser process exit that has occurred. + [propget] HRESULT BrowserProcessExitKind([out, retval] COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND* value); + + + /// The process ID of the browser process that has exited. + [propget] HRESULT BrowserProcessId([out, retval] UINT32* value); + + + +} + + + +/// A continuation of the ICoreWebView2CompositionController interface. +[uuid(0b6a3d24-49cb-4806-ba20-b5e0734a7b26), object, pointer_default(unique)] +interface ICoreWebView2CompositionController2 : ICoreWebView2CompositionController { + /// Returns the Automation Provider for the WebView. This object implements + /// IRawElementProviderSimple. + [propget] HRESULT AutomationProvider([out, retval] IUnknown** value); + + + +} + + +/// Receives `DragStarting` events. +[uuid(3b149321-83c3-5d1f-b03f-a42899bc1c15), object, pointer_default(unique)] +interface ICoreWebView2DragStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2CompositionController* sender, + [in] ICoreWebView2DragStartingEventArgs* args); +} + + +/// A continuation of the ICoreWebView2CompositionController4 interface. +/// This interface includes an API which exposes the DragStarting event. +[uuid(8d0f82eb-7c33-5a4c-9108-84ca28ccc3b4), object, pointer_default(unique)] +interface ICoreWebView2CompositionController5 : ICoreWebView2CompositionController4 { + /// Adds an event handler for the `DragStarting` event. + /// `DragStarting` is a deferrable event that is raised when the WebView2 + /// detects a drag started within the WebView2. + /// WebView2's default drag behavior is to synchronously call DoDragDrop when + /// it detects drag. This event's args expose the data WebView2 uses to call + /// DoDragDrop to allow users to implement their own drag logic and override + /// WebView2's. + /// Handlers of this event must set the `Handled` event to true in order to + /// override WebView2's default logic. When invoking drag logic asynchronously + /// using a deferral, handlers must take care to follow these steps in order: + /// * Invoke asynchronous drag logic + /// * Set the event args `Handled` property true + /// * Complete the deferral + /// In the asynchronous case, WebView2 decides whether or not to invoke its + /// default drag logic when the deferral completes. So the event args' + /// `Handled` property must be true when the deferral is completed. + /// \snippet ScenarioDragDropOverride.cpp DragStarting + HRESULT add_DragStarting( + [in] ICoreWebView2DragStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_DragStarting`. + HRESULT remove_DragStarting( + [in] EventRegistrationToken token); + + +} + + + +/// Event args for the `ContentLoading` event. +[uuid(0c8a1275-9b6b-4901-87ad-70df25bafa6e), object, pointer_default(unique)] +interface ICoreWebView2ContentLoadingEventArgs : IUnknown { + /// `TRUE` if the loaded content is an error page. + [propget] HRESULT IsErrorPage([out, retval] BOOL* value); + + + /// The ID of the navigation. + [propget] HRESULT NavigationId([out, retval] UINT64* value); + + + +} + + + +/// Represents a collection of `ContextMenuItem` objects. Used to get, remove and add +/// `ContextMenuItem` objects at the specified index. +[uuid(f562a2f5-c415-45cf-b909-d4b7c1e276d3), object, pointer_default(unique)] +interface ICoreWebView2ContextMenuItemCollection : IUnknown { + /// Gets the number of `ContextMenuItem` objects contained in the `ContextMenuItemCollection`. + [propget] HRESULT Count([out, retval] UINT32* value); + + + + /// Gets the `ContextMenuItem` at the specified index. + HRESULT GetValueAtIndex( + [in] UINT32 index + , [out, retval] ICoreWebView2ContextMenuItem** value); + + /// Removes the `ContextMenuItem` at the specified index. + HRESULT RemoveValueAtIndex( + [in] UINT32 index + ); + + /// Inserts the `ContextMenuItem` at the specified index. + HRESULT InsertValueAtIndex( + [in] UINT32 index, + [in] ICoreWebView2ContextMenuItem* value + ); + + +} + + + +/// A continuation of the ICoreWebView2Controller interface. +[uuid(c979903e-d4ca-4228-92eb-47ee3fa96eab), object, pointer_default(unique)] +interface ICoreWebView2Controller2 : ICoreWebView2Controller { + /// Gets the `DefaultBackgroundColor` property. + [propget] HRESULT DefaultBackgroundColor([out, retval] COREWEBVIEW2_COLOR* value); + + + /// The `DefaultBackgroundColor` property is the color WebView renders + /// underneath all web content. This means WebView renders this color when + /// there is no web content loaded such as before the initial navigation or + /// between navigations. This also means web pages with undefined css + /// background properties or background properties containing transparent + /// pixels will render their contents over this color. Web pages with defined + /// and opaque background properties that span the page will obscure the + /// `DefaultBackgroundColor` and display normally. The default value for this + /// property is white to resemble the native browser experience. + /// + /// The Color is specified by the COREWEBVIEW2_COLOR that represents an RGBA + /// value. The `A` represents an Alpha value, meaning + /// `DefaultBackgroundColor` can be transparent. In the case of a transparent + /// `DefaultBackgroundColor` WebView will render hosting app content as the + /// background. This Alpha value is not supported on Windows 7. Any `A` value + /// other than 255 will result in E_INVALIDARG on Windows 7. + /// It is supported on all other WebView compatible platforms. + /// + /// Semi-transparent colors are not currently supported by this API and + /// setting `DefaultBackgroundColor` to a semi-transparent color will fail + /// with E_INVALIDARG. The only supported alpha values are 0 and 255, all + /// other values will result in E_INVALIDARG. + /// `DefaultBackgroundColor` can only be an opaque color or transparent. + /// + /// This value may also be set by using the + /// `WEBVIEW2_DEFAULT_BACKGROUND_COLOR` environment variable. There is a + /// known issue with background color where setting the color by API can + /// still leave the app with a white flicker before the + /// `DefaultBackgroundColor` takes effect. Setting the color via environment + /// variable solves this issue. The value must be a hex value that can + /// optionally prepend a 0x. The value must account for the alpha value + /// which is represented by the first 2 digits. So any hex value fewer than 8 + /// digits will assume a prepended 00 to the hex value and result in a + /// transparent color. + /// `get_DefaultBackgroundColor` will return the result of this environment + /// variable if used. This environment variable can only set the + /// `DefaultBackgroundColor` once. Subsequent updates to background color + /// must be done through API call. + /// + /// \snippet ViewComponent.cpp DefaultBackgroundColor + [propput] HRESULT DefaultBackgroundColor([in] COREWEBVIEW2_COLOR value); + + + +} + + + +/// This is the ICoreWebView2Controller4 interface. +/// The ICoreWebView2Controller4 provides interface to enable/disable external drop. +[uuid(97d418d5-a426-4e49-a151-e1a10f327d9e), object, pointer_default(unique)] +interface ICoreWebView2Controller4 : ICoreWebView2Controller3 { + /// Gets the `AllowExternalDrop` property. + [propget] HRESULT AllowExternalDrop([out, retval] BOOL* value); + + + /// Gets the `AllowExternalDrop` property which is used to configure the + /// capability that dragging objects from outside the bounds of webview2 and + /// dropping into webview2 is allowed or disallowed. The default value is + /// TRUE. + /// + /// \snippet SettingsComponent.cpp ToggleAllowExternalDrop + [propput] HRESULT AllowExternalDrop([in] BOOL value); + + + +} + + + +/// This is the interface in ControllerOptions for ScriptLocale. +[uuid(06c991d8-9e7e-11ed-a8fc-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2ControllerOptions2 : ICoreWebView2ControllerOptions { + /// Gets the `ScriptLocale` property. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ScriptLocale([out, retval] LPWSTR* value); + + + /// The default locale for the WebView2. It sets the default locale for all + /// Intl JavaScript APIs and other JavaScript APIs that depend on it, namely + /// `Intl.DateTimeFormat()` which affects string formatting like + /// in the time/date formats. Example: `Intl.DateTimeFormat().format(new Date())` + /// The intended locale value is in the format of + /// BCP 47 Language Tags. More information can be found from + /// [IETF BCP47](https://www.ietf.org/rfc/bcp/bcp47.html). + /// + /// This property sets the locale for a CoreWebView2Environment used to create the + /// WebView2ControllerOptions object, which is passed as a parameter in + /// `CreateCoreWebView2ControllerWithOptions`. + /// + /// Changes to the ScriptLocale property apply to renderer processes created after + /// the change. Any existing renderer processes will continue to use the previous + /// ScriptLocale value. To ensure changes are applied to all renderer process, + /// close and restart the CoreWebView2Environment and all associated WebView2 objects. + /// + /// The default value for ScriptLocale will depend on the WebView2 language + /// and OS region. If the language portions of the WebView2 language and OS region + /// match, then it will use the OS region. Otherwise, it will use the WebView2 + /// language. + /// + /// | OS Region | WebView2 Language | Default WebView2 ScriptLocale | + /// |-----------|-------------------|-------------------------------| + /// | en-GB | en-US | en-GB | + /// | es-MX | en-US | en-US | + /// | en-US | en-GB | en-US | + /// + /// You can set the ScriptLocale to the empty string to get the default ScriptLocale value. + /// + /// Use OS specific APIs to determine the OS region to use with this property + /// if you want to match the OS. For example: + /// + /// Win32 C++: + /// ```cpp + /// wchar_t osLocale[LOCALE_NAME_MAX_LENGTH] = {0}; + /// GetUserDefaultLocaleName(osLocale, LOCALE_NAME_MAX_LENGTH); + /// ``` + /// \snippet AppWindow.cpp ScriptLocaleSetting + [propput] HRESULT ScriptLocale([in] LPCWSTR value); + + + +} + + + +/// Controller option used to expose the DefaultBackgroundColor property early in the loading process. +[uuid(b32b191a-8998-57ca-b7cb-e04617e4ce4a), object, pointer_default(unique)] +interface ICoreWebView2ControllerOptions3 : ICoreWebView2ControllerOptions2 { + /// Gets the `DefaultBackgroundColor` property. + [propget] HRESULT DefaultBackgroundColor([out, retval] COREWEBVIEW2_COLOR* value); + + + /// This property allows users to initialize the `DefaultBackgroundColor` early, + /// preventing a white flash that can occur while WebView2 is loading when + /// the background color is set to something other than white. With early + /// initialization, the color remains consistent from the start. After + /// initialization, `CoreWebView2Controller.DefaultBackgroundColor` will return the value set using this API. + /// + /// The `CoreWebView2Controller.DefaultBackgroundColor` can be set via the WEBVIEW2_DEFAULT_BACKGROUND_COLOR environment variable, + /// which will remain supported for cases where this solution is being used. + /// It is encouraged to transition away from the environment variable and use this API solution to + /// apply the property. It is important to highlight that when set, the enviroment variable overrides + /// ControllerOptions::DefaultBackgroundColor and becomes the initial value of Controller::DefaultBackgroundColor. + /// + /// The `DefaultBackgroundColor` is the color that renders underneath all web + /// content. This means WebView2 renders this color when there is no web + /// content loaded. When no background color is defined in WebView2, it uses + /// the `DefaultBackgroundColor` property to render the background. + /// By default, this color is set to white. + /// + /// This API only supports opaque colors and full transparency. It will + /// fail for colors with alpha values that don't equal 0 or 255. + /// When WebView2 is set to be fully transparent, it does not render a background, + /// allowing the content from windows behind it to be visible. + [propput] HRESULT DefaultBackgroundColor([in] COREWEBVIEW2_COLOR value); + + + +} + + + +/// Controller option used to allow user input pass through the browser and make +/// them received in the host app process. +[uuid(21eb052f-ad39-555e-824a-c87b091d4d36), object, pointer_default(unique)] +interface ICoreWebView2ControllerOptions4 : ICoreWebView2ControllerOptions3 { + /// Gets the `AllowHostInputProcessing` property. + [propget] HRESULT AllowHostInputProcessing([out, retval] BOOL* value); + + + /// `AllowHostInputProcessing` property is to enable/disable input passing through + /// the app before being delivered to the WebView2. This property is only applicable + /// to controllers created with `CoreWebView2Environment.CreateCoreWebView2ControllerAsync` and not + /// composition controllers created with `CoreWebView2Environment.CreateCoreWebView2CompositionControllerAsync`. + /// By default the value is `FALSE`. + /// Setting this property has no effect when using visual hosting. + /// \snippet AppWindow.cpp AllowHostInputProcessing + [propput] HRESULT AllowHostInputProcessing([in] BOOL value); + + + +} + + + +/// Event args for the DOMContentLoaded event. +[uuid(16b1e21a-c503-44f2-84c9-70aba5031283), object, pointer_default(unique)] +interface ICoreWebView2DOMContentLoadedEventArgs : IUnknown { + /// The ID of the navigation which corresponds to other navigation ID properties on other navigation events. + [propget] HRESULT NavigationId([out, retval] UINT64* value); + + + +} + + + +/// This interface is used to complete deferrals on event args that support +/// getting deferrals using the `GetDeferral` method. +[uuid(c10e7f7b-b585-46f0-a623-8befbf3e4ee0), object, pointer_default(unique)] +interface ICoreWebView2Deferral : IUnknown { + /// Completes the associated deferred event. Complete should only be run + /// once for each deferral taken. + HRESULT Complete( + ); + + +} + + + +/// Event args for the `DevToolsProtocolEventReceived` event. +[uuid(653c2959-bb3a-4377-8632-b58ada4e66c4), object, pointer_default(unique)] +interface ICoreWebView2DevToolsProtocolEventReceivedEventArgs : IUnknown { + /// The parameter object of the corresponding `DevToolsProtocol` event + /// represented as a JSON string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT ParameterObjectAsJson([out, retval] LPWSTR* value); + + + +} + + + +/// This is a continuation of the `ICoreWebView2DevToolsProtocolEventReceivedEventArgs` +/// interface that provides the session ID of the target where the event originates from. +[uuid(2dc4959d-1494-4393-95ba-bea4cb9ebd1b), object, pointer_default(unique)] +interface ICoreWebView2DevToolsProtocolEventReceivedEventArgs2 : ICoreWebView2DevToolsProtocolEventReceivedEventArgs { + /// The sessionId of the target where the event originates from. + /// Empty string is returned as sessionId if the event comes from the default + /// session for the top page. + /// + /// \snippet ScriptComponent.cpp DevToolsProtocolEventReceivedSessionId + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT SessionId([out, retval] LPWSTR* value); + + + +} + + +/// Receives `DevToolsProtocolEventReceived` events. +[uuid(e2fda4be-5456-406c-a261-3d452138362c), object, pointer_default(unique)] +interface ICoreWebView2DevToolsProtocolEventReceivedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2DevToolsProtocolEventReceivedEventArgs* args); +} + + +/// A Receiver is created for a particular DevTools Protocol event and allows +/// you to subscribe and unsubscribe from that event. Obtained from the +/// WebView object using `GetDevToolsProtocolEventReceiver`. +[uuid(b32ca51a-8371-45e9-9317-af021d080367), object, pointer_default(unique)] +interface ICoreWebView2DevToolsProtocolEventReceiver : IUnknown { + /// Adds an event handler for the `DevToolsProtocolEventReceived` event. + /// Subscribe to a `DevToolsProtocol` event. The `Invoke` method of the + /// `handler` runs whenever the corresponding `DevToolsProtocol` event runs. + /// `Invoke` runs with an event args object containing the parameter object + /// of the DevTools Protocol event as a JSON string. + /// + /// \snippet ScriptComponent.cpp DevToolsProtocolEventReceived + HRESULT add_DevToolsProtocolEventReceived( + [in] ICoreWebView2DevToolsProtocolEventReceivedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_DevToolsProtocolEventReceived`. + HRESULT remove_DevToolsProtocolEventReceived( + [in] EventRegistrationToken token); + + +} + + + +/// Event args for the `DragStarting` event. +[uuid(8b8d9c7e-2f1a-4e6b-9d5a-3c8f7b9e1a2d), object, pointer_default(unique)] +interface ICoreWebView2DragStartingEventArgs : IUnknown { + /// The [OLE DROPEFFECT](/windows/win32/com/dropeffect-constants) + /// values this drag data supports. + [propget] HRESULT AllowedDropEffects([out, retval] DWORD* value); + + + /// The data to be dragged. + [propget] HRESULT Data([out, retval] IDataObject** value); + + + /// Gets the `Handled` property. + [propget] HRESULT Handled([out, retval] BOOL* value); + + + /// Indicates whether this event has been handled by the app. If the + /// app handles this event, WebView2 will not initiate drag drop. If + /// the app does not handle the event, WebView2 will initiate its own + /// drag drop logic. + [propput] HRESULT Handled([in] BOOL value); + + + /// The position at which drag was detected given in WebView2 relative + /// coordinates + [propget] HRESULT Position([out, retval] POINT* value); + + + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to complete + /// the CoreWebView2DragStartingEventArgs. + /// + /// Until the deferral is completed, subsequent attempts to initiate drag + /// in the WebView2 will fail and if the cursor was changed as part of + /// drag it will not restore. + HRESULT GetDeferral( + [out, retval] ICoreWebView2Deferral** value); + + +} + + +// Skipping ICoreWebView2CreateCoreWebView2ControllerCompletedHandler redefinition + +// Skipping ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler redefinition + + + +/// This interface is used to create `ICoreWebView2ControllerOptions` object, which +/// can be passed as a parameter in `CreateCoreWebView2ControllerWithOptions` and +/// `CreateCoreWebView2CompositionControllerWithOptions` function for multiple profiles support. +/// The profile will be created on disk or opened when calling `CreateCoreWebView2ControllerWithOptions` or +/// `CreateCoreWebView2CompositionControllerWithOptions` no matter InPrivate mode is enabled or not, and +/// it will be released in memory when the corresponding controller is closed but still remain on disk. +/// If you create a WebView2Controller with {ProfileName="name", InPrivate=false} and then later create another +/// one with {ProfileName="name", InPrivate=true}, these two controllers using the same profile would be allowed to +/// run at the same time. +/// As WebView2 is built on top of Edge browser, it follows Edge's behavior pattern. To create an InPrivate WebView, +/// we gets an off-the-record profile (an InPrivate profile) from a regular profile, then create the WebView with the +/// off-the-record profile. +/// +/// \snippet AppWindow.cpp CreateControllerWithOptions +[uuid(ee0eb9df-6f12-46ce-b53f-3f47b9c928e0), object, pointer_default(unique)] +interface ICoreWebView2Environment10 : ICoreWebView2Environment9 { + /// Create a new ICoreWebView2ControllerOptions to be passed as a parameter of + /// CreateCoreWebView2ControllerWithOptions and CreateCoreWebView2CompositionControllerWithOptions. + /// The 'options' is settable and in it the default value for profile name is the empty string, + /// and the default value for IsInPrivateModeEnabled is false. + /// Also the profile name can be reused. + HRESULT CreateCoreWebView2ControllerOptions( + [out, retval] ICoreWebView2ControllerOptions** value); + + /// Create a new WebView with options. + HRESULT CreateCoreWebView2ControllerWithOptions( + [in] HWND ParentWindow, + [in] ICoreWebView2ControllerOptions* options + , [in] ICoreWebView2CreateCoreWebView2ControllerCompletedHandler* handler); + + /// Create a new WebView in visual hosting mode with options. + HRESULT CreateCoreWebView2CompositionControllerWithOptions( + [in] HWND ParentWindow, + [in] ICoreWebView2ControllerOptions* options + , [in] ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler* handler); + + +} + + + +/// A continuation of the ICoreWebView2Environment interface for +/// getting the crash dump folder path. +[uuid(f0913dc6-a0ec-42ef-9805-91dff3a2966a), object, pointer_default(unique)] +interface ICoreWebView2Environment11 : ICoreWebView2Environment10 { + /// `FailureReportFolderPath` returns the path of the folder where minidump files are written. + /// Whenever a WebView2 process crashes, a crash dump file will be created in the crash dump folder. + /// The crash dump format is minidump files. Please see + /// [Minidump Files documentation](/windows/win32/debug/minidump-files) for detailed information. + /// Normally when a single child process fails, a minidump will be generated and written to disk, + /// then the `ProcessFailed` event is raised. But for unexpected crashes, a minidump file might not be generated + /// at all, despite whether `ProcessFailed` event is raised. If there are multiple + /// process failures at once, multiple minidump files could be generated. Thus `FailureReportFolderPath` + /// could contain old minidump files that are not associated with a specific `ProcessFailed` event. + /// \snippet AppWindow.cpp GetFailureReportFolder + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FailureReportFolderPath([out, retval] LPWSTR* value); + + + +} + + + +/// A continuation of the ICoreWebView2Environment interface for creating shared buffer object. +[uuid(f503db9b-739f-48dd-b151-fdfcf253f54e), object, pointer_default(unique)] +interface ICoreWebView2Environment12 : ICoreWebView2Environment11 { + /// Create a shared memory based buffer with the specified size in bytes. + /// The buffer can be shared with web contents in WebView by calling + /// `PostSharedBufferToScript` on `CoreWebView2` or `CoreWebView2Frame` object. + /// Once shared, the same content of the buffer will be accessible from both + /// the app process and script in WebView. Modification to the content will be visible + /// to all parties that have access to the buffer. + /// The shared buffer is presented to the script as ArrayBuffer. All JavaScript APIs + /// that work for ArrayBuffer including Atomics APIs can be used on it. + /// There is currently a limitation that only size less than 2GB is supported. + HRESULT CreateSharedBuffer( + [in] UINT64 Size + , [out, retval] ICoreWebView2SharedBuffer** value); + + +} + + +/// Receives the result of the `GetProcessExtendedInfos` method. +[uuid(f45e55aa-3bc2-11ee-be56-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2GetProcessExtendedInfosCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2ProcessExtendedInfoCollection* result); +} + +/// A collection of ICoreWebView2ProcessExtendedInfo. +[uuid(32efa696-407a-11ee-be56-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2ProcessExtendedInfoCollection : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] ICoreWebView2ProcessExtendedInfo** value); +} + + +/// A continuation of the ICoreWebView2Environment interface for getting process +/// with associated information. +[uuid(af641f58-72b2-11ee-b962-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2Environment13 : ICoreWebView2Environment12 { + /// Gets a snapshot collection of `ProcessExtendedInfo`s corresponding to all + /// currently running processes associated with this `CoreWebView2Environment` + /// excludes crashpad process. + /// This provides the same list of `ProcessInfo`s as what's provided in + /// `GetProcessInfos`, but additionally provides a list of associated `FrameInfo`s + /// which are actively running (showing or hiding UI elements) in the renderer + /// process. See `AssociatedFrameInfos` for more information. + /// + /// \snippet ProcessComponent.cpp GetProcessExtendedInfos + HRESULT GetProcessExtendedInfos( + [in] ICoreWebView2GetProcessExtendedInfosCompletedHandler* handler); + + +} + + + +/// This is ICoreWebView2Environment14 that exposes new methods to +/// create Filesystem access related DOM objects. +[uuid(a5e9fad9-c875-59da-9bd7-473aa5ca1cef), object, pointer_default(unique)] +interface ICoreWebView2Environment14 : ICoreWebView2Environment13 { + /// Create a `ICoreWebView2FileSystemHandle` object from a path that represents a Web + /// [FileSystemFileHandle](https://developer.mozilla.org/docs/Web/API/FileSystemFileHandle). + /// + /// The `path` is the path pointed by the file and must be a syntactically correct fully qualified + /// path, but it is not checked here whether it currently points to a file. If an invalid path is + /// passed, an E_INVALIDARG will be returned and the object will fail to create. Any other state + /// validation will be done when this handle is accessed from web content + /// and will cause the DOM exceptions described in + /// [FileSystemFileHandle methods](https://developer.mozilla.org/docs/Web/API/FileSystemDirectoryHandle#instance_methods) + /// if access operations fail. + /// + /// `Permission` property is used to specify whether the Handle should be created with a Read-only or + /// Read-and-write web permission. For the `permission` value specified here, the DOM + /// [PermissionStatus](https://developer.mozilla.org/docs/Web/API/PermissionStatus) property + /// will be [granted](https://developer.mozilla.org/docs/Web/API/PermissionStatus/state) + /// and the unspecified permission will be + /// [prompt](https://developer.mozilla.org/docs/Web/API/PermissionStatus/state). Therefore, + /// the web content then does not need to call + /// [requestPermission](https://developer.mozilla.org/docs/Web/API/FileSystemHandle/requestPermission) + /// for the permission that was specified before attempting the permitted operation, + /// but if it does, the promise will immediately be resolved + /// with 'granted' PermissionStatus without firing the WebView2 + /// [PermissionRequested](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs) + /// event or prompting the user for permission. Otherwise, `requestPermission` will behave as the + /// status of permission is currently `prompt`, which means the `PermissionRequested` event will fire + /// or the user will be prompted. + /// Additionally, the app must have the same OS permissions that have propagated to the + /// [WebView2 browser process](/microsoft-edge/webview2/concepts/process-model) + /// for the path it wishes to give the web content to read/write the file. + /// Specifically, the WebView2 browser process will run in same user, package identity, and app + /// container of the app, but other means such as security context impersonations do not get + /// propagated, so such permissions that the app has, will not be effective in WebView2. + /// Note: An exception to this is, if there is a parent directory handle that + /// has broader permissions in the same page context than specified in here, the handle will automatically + /// inherit the most permissive permission of the parent handle when posted to that page context. + /// i.e. If there is already a `FileSystemDirectoryHandle` to `C:\example` that has write permission on + /// a page, even though a WebFileSystemHandle to file `C:\example\file.txt` is created with + /// `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY` permission, when posted to that page, write permission + /// will be automatically granted to the created handle. + /// + /// An app needs to be mindful that this object, when posted to the web content, provides it with unusual + /// access to OS file system via the Web FileSystem API! The app should therefore only post objects + /// for paths that it wants to allow access to the web content and it is not recommended that the web content + /// "asks" for this path. The app should also check the source property of the target to ensure + /// that it is sending to the web content of intended origin. + /// + /// Once the object is passed to web content, if the content is attempting a read, + /// the file must be existing and available to read similar to a file chosen by + /// [open file picker](https://developer.mozilla.org/docs/Web/API/Window/showOpenFilePicker), + /// otherwise the read operation will + /// [throw a DOM exception](https://developer.mozilla.org/docs/Web/API/FileSystemFileHandle/getFile#exceptions). + /// For write operations, the file does not need to exist as `FileSystemFileHandle` will behave + /// as a file path chosen by + /// [save file picker](https://developer.mozilla.org/docs/Web/API/Window/showSaveFilePicker) + /// and will create or overwrite the file, but the parent directory structure pointed + /// by the file must exist and an existing file must be available to write and delete + /// or the write operation will + /// [throw a DOM exception](https://developer.mozilla.org/docs/Web/API/FileSystemFileHandle/createWritable#exceptions). + HRESULT CreateWebFileSystemFileHandle( + [in] LPCWSTR path, + [in] COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION permission + , [out, retval] ICoreWebView2FileSystemHandle** value); + + /// Create a `ICoreWebView2FileSystemHandle` object from a path that represents a Web + /// [FileSystemDirectoryHandle](https://developer.mozilla.org/docs/Web/API/FileSystemDirectoryHandle). + /// + /// The `path` is the path pointed by the directory and must be a syntactically correct fully qualified + /// path, but it is not checked here whether it currently points to a directory. Any other state + /// validation will be done when this handle is accessed from web content + /// and will cause DOM exceptions if access operations fail. If an invalid path is + /// passed, an E_INVALIDARG will be returned and the object will fail to create. + /// + /// `Permission` property is used to specify whether the Handle should be created with a Read-only or + /// Read-and-write web permission. For the `permission` value specified here, the Web + /// [PermissionStatus](https://developer.mozilla.org/docs/Web/API/PermissionStatus) + /// will be [granted](https://developer.mozilla.org/docs/Web/API/PermissionStatus/state) + /// and the unspecified permission will be + /// [prompt](https://developer.mozilla.org/docs/Web/API/PermissionStatus/state). Therefore, + /// the web content then does not need to call + /// [requestPermission](https://developer.mozilla.org/docs/Web/API/FileSystemHandle/requestPermission) + /// for the permission that was specified before attempting the permitted operation, + /// but if it does, the promise will immediately be resolved + /// with 'granted' PermissionStatus without firing the WebView2 + /// [PermissionRequested](/microsoft-edge/webview2/reference/win32/icorewebview2permissionrequestedeventargs) + /// event or prompting the user for permission. Otherwise, `requestPermission` will behave as the + /// status of permission is currently `Prompt`, which means the `PermissionRequested` event will fire + /// or the user will be prompted. + /// Additionally, the app must have the same OS permissions that have propagated to the + /// [WebView2 browser process](/microsoft-edge/webview2/concepts/process-model) + /// for the path it wishes to give the web content to make any operations on the directory. + /// Specifically, the WebView2 browser process will run in same user, package identity, and app + /// container of the app, but other means such as security context impersonations do not get + /// propagated, so such permissions that the app has, will not be effective in WebView2. + /// Note: An exception to this is, if there is a parent directory handle that + /// has broader permissions in the same page context than specified in here, the handle will automatically + /// inherit the most permissive permission of the parent handle when posted to that page context. + /// i.e. If there is already a `FileSystemDirectoryHandle` to `C:\example` that has write permission on + /// a page, even though a WebFileSystemHandle to directory `C:\example\directory` is created with + /// `COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION_READ_ONLY` permission, when posted to that page, write permission + /// will be automatically granted to the created handle. + /// + /// An app needs to be mindful that this object, when posted to the web content, provides it with unusual + /// access to OS file system via the Web FileSystem API! The app should therefore only post objects + /// for paths that it wants to allow access to the web content and it is not recommended that the web content + /// "asks" for this path. The app should also check the source property of the target to ensure + /// that it is sending to the web content of intended origin. + /// + /// Once the object is passed to web content, the path must point to a directory as if it was chosen via + /// [directory picker](https://developer.mozilla.org/docs/Web/API/Window/showDirectoryPicker) + /// otherwise any IO operation done on the `FileSystemDirectoryHandle` will throw a DOM exception. + HRESULT CreateWebFileSystemDirectoryHandle( + [in] LPCWSTR path, + [in] COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION permission + , [out, retval] ICoreWebView2FileSystemHandle** value); + + /// Create a generic object collection. + HRESULT CreateObjectCollection( + [in] UINT32 length, + [in, size_is(length)] IUnknown** items, + [out, retval] ICoreWebView2ObjectCollection** objectCollection); + + +} + + + +/// Interface that provides methods related to the environment settings of CoreWebView2. +/// This interface allows for the creation of new `FindOptions` objects. +[uuid(2ac5ebfb-e654-5961-a667-7971885c7b27), object, pointer_default(unique)] +interface ICoreWebView2Environment15 : ICoreWebView2Environment14 { + /// Creates a new instance of a CoreWebView2FindOptions object. + /// This find options object can be used to define parameters for a find session. + /// Returns the newly created FindOptions object. + HRESULT CreateFindOptions( + [out, retval] ICoreWebView2FindOptions** value); + + +} + + + +/// A continuation of the ICoreWebView2Environment interface. +[uuid(41f3632b-5ef4-404f-ad82-2d606c5a9a21), object, pointer_default(unique)] +interface ICoreWebView2Environment2 : ICoreWebView2Environment { + /// Create a new web resource request object. + /// URI parameter must be absolute URI. + /// The headers string is the raw request header string delimited by CRLF + /// (optional in last header). + /// It's also possible to create this object with null headers string + /// and then use the ICoreWebView2HttpRequestHeaders to construct the headers + /// line by line. + /// For information on other parameters see ICoreWebView2WebResourceRequest. + /// + /// \snippet ScenarioNavigateWithWebResourceRequest.cpp NavigateWithWebResourceRequest + HRESULT CreateWebResourceRequest( + [in] LPCWSTR uri, + [in] LPCWSTR Method, + [in] IStream* postData, + [in] LPCWSTR Headers + , [out, retval] ICoreWebView2WebResourceRequest** value); + + +} + + +/// Receives the result of the `CreateCoreWebView2CompositionController` method. +[uuid(02fab84b-1428-4fb7-ad45-1b2e64736184), object, pointer_default(unique)] +interface ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2CompositionController* result); +} + + +/// A continuation of the ICoreWebView2Environment2 interface. +[uuid(80a22ae3-be7c-4ce2-afe1-5a50056cdeeb), object, pointer_default(unique)] +interface ICoreWebView2Environment3 : ICoreWebView2Environment2 { + /// Asynchronously create a new WebView for use with visual hosting. + /// + /// parentWindow is the HWND in which the app will connect the visual tree of + /// the WebView. This will be the HWND that the app will receive pointer/ + /// mouse input meant for the WebView (and will need to use SendMouseInput/ + /// SendPointerInput to forward). If the app moves the WebView visual tree to + /// underneath a different window, then it needs to call put_ParentWindow to + /// update the new parent HWND of the visual tree. + /// + /// HWND_MESSAGE is not a valid parameter for `parentWindow` for visual hosting. + /// The underlying implementation of supporting HWND_MESSAGE would break + /// accessibility for visual hosting. This is supported in windowed + /// WebViews - see CreateCoreWebView2Controller. + /// + /// Use put_RootVisualTarget on the created CoreWebView2CompositionController to + /// provide a visual to host the browser's visual tree. + /// + /// It is recommended that the application set Application User Model ID for + /// the process or the application window. If none is set, during WebView + /// creation a generated Application User Model ID is set to root window of + /// parentWindow. + /// \snippet AppWindow.cpp CreateCoreWebView2Controller + /// + /// It is recommended that the application handles restart manager messages + /// so that it can be restarted gracefully in the case when the app is using + /// Edge for WebView from a certain installation and that installation is + /// being uninstalled. For example, if a user installs Edge from Dev channel + /// and opts to use Edge from that channel for testing the app, and then + /// uninstalls Edge from that channel without closing the app, the app will + /// be restarted to allow uninstallation of the dev channel to succeed. + /// \snippet AppWindow.cpp RestartManager + /// + /// The app should retry `CreateCoreWebView2CompositionController` upon failure, + /// unless the error code is `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)`. + /// When the app retries `CreateCoreWebView2CompositionController` + /// upon failure, it is recommended that the app restarts from creating a new + /// WebView2 Environment. If a WebView2 Runtime update happens, the version + /// associated with a WebView2 Environment may have been removed and causing + /// the object to no longer work. Creating a new WebView2 Environment works + /// since it uses the latest version. + /// + /// WebView creation fails with `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` if a + /// running instance using the same user data folder exists, and the Environment + /// objects have different `EnvironmentOptions`. For example, if a WebView was + /// created with one language, an attempt to create a WebView with a different + /// language using the same user data folder will fail. + /// + /// The creation will fail with `E_ABORT` if `parentWindow` is destroyed + /// before the creation is finished. If this is caused by a call to + /// `DestroyWindow`, the creation completed handler will be invoked before + /// `DestroyWindow` returns, so you can use this to cancel creation and clean + /// up resources synchronously when quitting a thread. + /// + /// In rare cases the creation can fail with `E_UNEXPECTED` if runtime does not have + /// permissions to the user data folder. + /// + /// CreateCoreWebView2CompositionController is supported in the following versions of Windows: + /// + /// - Windows 11 + /// - Windows 10 + /// - Windows Server 2019 + /// - Windows Server 2016 + /// + HRESULT CreateCoreWebView2CompositionController( + [in] HWND ParentWindow + , [in] ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler* handler); + + /// Create an empty ICoreWebView2PointerInfo. The returned + /// ICoreWebView2PointerInfo needs to be populated with all of the relevant + /// info before calling SendPointerInput. + HRESULT CreateCoreWebView2PointerInfo( + [out, retval] ICoreWebView2PointerInfo** value); + + +} + + + +/// A continuation of the ICoreWebView2Environment3 interface. +[uuid(20944379-6dcf-41d6-a0a0-abc0fc50de0d), object, pointer_default(unique)] +interface ICoreWebView2Environment4 : ICoreWebView2Environment3 { + /// Returns the Automation Provider for the WebView that matches the provided + /// window. Host apps are expected to implement + /// IRawElementProviderHwndOverride. When GetOverrideProviderForHwnd is + /// called, the app can pass the HWND to GetAutomationProviderForWindow to + /// find the matching WebView Automation Provider. + HRESULT GetAutomationProviderForWindow( + [in] HWND hwnd + , [out, retval] IUnknown** value); + + +} + + +/// Receives `BrowserProcessExited` events. +[uuid(fa504257-a216-4911-a860-fe8825712861), object, pointer_default(unique)] +interface ICoreWebView2BrowserProcessExitedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Environment* sender, + [in] ICoreWebView2BrowserProcessExitedEventArgs* args); +} + + +/// A continuation of the `ICoreWebView2Environment4` interface that supports +/// the `BrowserProcessExited` event. +[uuid(319e423d-e0d7-4b8d-9254-ae9475de9b17), object, pointer_default(unique)] +interface ICoreWebView2Environment5 : ICoreWebView2Environment4 { + /// Adds an event handler for the `BrowserProcessExited` event. + /// Add an event handler for the `BrowserProcessExited` event. + /// The `BrowserProcessExited` event is raised when the collection of WebView2 + /// Runtime processes for the browser process of this environment terminate + /// due to browser process failure or normal shutdown (for example, when all + /// associated WebViews are closed), after all resources have been released + /// (including the user data folder). To learn about what these processes are, + /// go to [Process model](/microsoft-edge/webview2/concepts/process-model). + /// + /// A handler added with this method is called until removed with + /// `remove_BrowserProcessExited`, even if a new browser process is bound to + /// this environment after earlier `BrowserProcessExited` events are raised. + /// + /// Multiple app processes can share a browser process by creating their webviews + /// from a `ICoreWebView2Environment` with the same user data folder. When the entire + /// collection of WebView2Runtime processes for the browser process exit, all + /// associated `ICoreWebView2Environment` objects receive the `BrowserProcessExited` + /// event. Multiple processes sharing the same browser process need to coordinate + /// their use of the shared user data folder to avoid race conditions and + /// unnecessary waits. For example, one process should not clear the user data + /// folder at the same time that another process recovers from a crash by recreating + /// its WebView controls; one process should not block waiting for the event if + /// other app processes are using the same browser process (the browser process will + /// not exit until those other processes have closed their webviews too). + /// + /// Note this is an event from the `ICoreWebView2Environment3` interface, not + /// the `ICoreWebView2` one. The difference between `BrowserProcessExited` and + /// `ICoreWebView2`'s `ProcessFailed` is that `BrowserProcessExited` is + /// raised for any **browser process** exit (expected or unexpected, after all + /// associated processes have exited too), while `ProcessFailed` is raised for + /// **unexpected** process exits of any kind (browser, render, GPU, and all + /// other types), or for main frame **render process** unresponsiveness. To + /// learn more about the WebView2 Process Model, go to + /// [Process model](/microsoft-edge/webview2/concepts/process-model). + /// + /// In the case the browser process crashes, both `BrowserProcessExited` and + /// `ProcessFailed` events are raised, but the order is not guaranteed. These + /// events are intended for different scenarios. It is up to the app to + /// coordinate the handlers so they do not try to perform reliability recovery + /// while also trying to move to a new WebView2 Runtime version or remove the + /// user data folder. + /// + /// \snippet AppWindow.cpp Close + HRESULT add_BrowserProcessExited( + [in] ICoreWebView2BrowserProcessExitedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_BrowserProcessExited`. + HRESULT remove_BrowserProcessExited( + [in] EventRegistrationToken token); + + +} + + + +/// This interface is an extension of the ICoreWebView2Environment that supports +/// creating print settings for printing to PDF. +[uuid(e59ee362-acbd-4857-9a8e-d3644d9459a9), object, pointer_default(unique)] +interface ICoreWebView2Environment6 : ICoreWebView2Environment5 { + /// Creates the `ICoreWebView2PrintSettings` used by the `PrintToPdf` + /// method. + HRESULT CreatePrintSettings( + [out, retval] ICoreWebView2PrintSettings** value); + + +} + + + +/// This interface is an extension of the ICoreWebView2Environment. An object +/// implementing the ICoreWebView2Environment7 interface will also +/// implement ICoreWebView2Environment. +[uuid(43c22296-3bbd-43a4-9c00-5c0df6dd29a2), object, pointer_default(unique)] +interface ICoreWebView2Environment7 : ICoreWebView2Environment6 { + /// Returns the user data folder that all CoreWebView2's created from this + /// environment are using. + /// This could be either the value passed in by the developer when creating + /// the environment object or the calculated one for default handling. It + /// will always be an absolute path. + /// + /// \snippet AppWindow.cpp GetUserDataFolder + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT UserDataFolder([out, retval] LPWSTR* value); + + + +} + + +/// Receives `ProcessInfosChanged` events. +[uuid(f4af0c39-44b9-40e9-8b11-0484cfb9e0a1), object, pointer_default(unique)] +interface ICoreWebView2ProcessInfosChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Environment* sender, + [in] IUnknown* args); +} + +/// A collection of ICoreWebView2ProcessInfo. +[uuid(402b99cd-a0cc-4fa5-b7a5-51d86a1d2339), object, pointer_default(unique)] +interface ICoreWebView2ProcessInfoCollection : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] ICoreWebView2ProcessInfo** value); +} + + +/// A continuation of the `ICoreWebView2Environment7` interface that supports +/// the `ProcessInfosChanged` event. +[uuid(d6eb91dd-c3d2-45e5-bd29-6dc2bc4de9cf), object, pointer_default(unique)] +interface ICoreWebView2Environment8 : ICoreWebView2Environment7 { + /// Adds an event handler for the `ProcessInfosChanged` event. + /// Adds an event handler for the `ProcessInfosChanged` event. + /// + /// \snippet ProcessComponent.cpp ProcessInfosChanged + /// \snippet ProcessComponent.cpp ProcessInfosChanged1 + HRESULT add_ProcessInfosChanged( + [in] ICoreWebView2ProcessInfosChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_ProcessInfosChanged`. + HRESULT remove_ProcessInfosChanged( + [in] EventRegistrationToken token); + + + /// Returns the `ICoreWebView2ProcessInfoCollection` + /// Provide a list of all process using same user data folder except for crashpad process. + HRESULT GetProcessInfos( + [out, retval] ICoreWebView2ProcessInfoCollection** value); + + +} + + + +/// A continuation of the ICoreWebView2Environment interface for +/// creating CoreWebView2 ContextMenuItem objects. +[uuid(f06f41bf-4b5a-49d8-b9f6-fa16cd29f274), object, pointer_default(unique)] +interface ICoreWebView2Environment9 : ICoreWebView2Environment8 { + /// Create a custom `ContextMenuItem` object to insert into the WebView context menu. + /// CoreWebView2 will rewind the icon stream before decoding. + /// There is a limit of 1000 active custom context menu items at a given time. + /// Attempting to create more before deleting existing ones will fail with + /// ERROR_NOT_ENOUGH_QUOTA. + /// It is recommended to reuse ContextMenuItems across ContextMenuRequested events + /// for performance. + /// The returned ContextMenuItem object's `IsEnabled` property will default to `TRUE` + /// and `IsChecked` property will default to `FALSE`. A `CommandId` will be assigned + /// to the ContextMenuItem object that's unique across active custom context menu items, + /// but command ID values of deleted ContextMenuItems can be reassigned. + HRESULT CreateContextMenuItem( + [in] LPCWSTR Label, + [in] IStream* iconStream, + [in] COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND Kind + , [out, retval] ICoreWebView2ContextMenuItem** value); + + +} + + + +/// Additional options used to create WebView2 Environment. A default implementation is +/// provided in `WebView2EnvironmentOptions.h`. +/// +/// \snippet AppWindow.cpp CreateCoreWebView2EnvironmentWithOptions +[uuid(ff85c98a-1ba7-4a6b-90c8-2b752c89e9e2), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions2 : IUnknown { + /// Gets the `ExclusiveUserDataFolderAccess` property. + [propget] HRESULT ExclusiveUserDataFolderAccess([out, retval] BOOL* value); + + + /// Whether other processes can create WebView2 from WebView2Environment created with the + /// same user data folder and therefore sharing the same WebView browser process instance. + /// Default is FALSE. + [propput] HRESULT ExclusiveUserDataFolderAccess([in] BOOL value); + + + +} + + + +/// Additional options used to create WebView2 Environment to manage crash +/// reporting. +[uuid(4a5c436e-a9e3-4a2e-89c3-910d3513f5cc), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions3 : IUnknown { + /// Gets the `IsCustomCrashReportingEnabled` property. + [propget] HRESULT IsCustomCrashReportingEnabled([out, retval] BOOL* value); + + + /// When `IsCustomCrashReportingEnabled` is set to `TRUE`, Windows won't send crash data to Microsoft endpoint. + /// `IsCustomCrashReportingEnabled` is default to be `FALSE`, in this case, WebView will respect OS consent. + [propput] HRESULT IsCustomCrashReportingEnabled([in] BOOL value); + + + +} + + + +/// Additional options used to create WebView2 Environment that manages custom scheme registration. +[uuid(ac52d13f-0d38-475a-9dca-876580d6793e), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions4 : IUnknown { + /// Array of custom scheme registrations. The returned + /// ICoreWebView2CustomSchemeRegistration pointers must be released, and the + /// array itself must be deallocated with CoTaskMemFree. + HRESULT GetCustomSchemeRegistrations( + [out] UINT32* count, + [out] ICoreWebView2CustomSchemeRegistration*** schemeRegistrations + ); + + /// Set the array of custom scheme registrations to be used. + /// \snippet AppWindow.cpp CoreWebView2CustomSchemeRegistration + HRESULT SetCustomSchemeRegistrations( + [in] UINT32 count, + [in] ICoreWebView2CustomSchemeRegistration** schemeRegistrations + ); + + +} + + + +/// Additional options used to create WebView2 Environment to manage tracking +/// prevention. +[uuid(0ae35d64-c47f-4464-814e-259c345d1501), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions5 : IUnknown { + /// Gets the `EnableTrackingPrevention` property. + [propget] HRESULT EnableTrackingPrevention([out, retval] BOOL* value); + + + /// The `EnableTrackingPrevention` property is used to enable/disable tracking prevention + /// feature in WebView2. This property enable/disable tracking prevention for all the + /// WebView2's created in the same environment. By default this feature is enabled to block + /// potentially harmful trackers and trackers from sites that aren't visited before and set to + /// `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BALANCED` or whatever value was last changed/persisted + /// on the profile. + /// + /// You can set this property to false to disable the tracking prevention feature if the app only + /// renders content in the WebView2 that is known to be safe. Disabling this feature when creating + /// environment also improves runtime performance by skipping related code. + /// + /// You shouldn't disable this property if WebView2 is being used as a "full browser" with arbitrary + /// navigation and should protect end user privacy. + /// + /// There is `ICoreWebView2Profile3::PreferredTrackingPreventionLevel` property to control levels of + /// tracking prevention of the WebView2's associated with a same profile. However, you can also disable + /// tracking prevention later using `ICoreWebView2Profile3::PreferredTrackingPreventionLevel` property and + /// `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE` value but that doesn't improves runtime performance. + /// + /// See `ICoreWebView2Profile3::PreferredTrackingPreventionLevel` for more details. + /// + /// Tracking prevention protects users from online tracking by restricting the ability of trackers to + /// access browser-based storage as well as the network. See [Tracking prevention](/microsoft-edge/web-platform/tracking-prevention). + [propput] HRESULT EnableTrackingPrevention([in] BOOL value); + + + +} + + + +/// Additional options used to create WebView2 Environment to manage browser extensions. +[uuid(57d29cc3-c84f-42a0-b0e2-effbd5e179de), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions6 : IUnknown { + /// Gets the `AreBrowserExtensionsEnabled` property. + [propget] HRESULT AreBrowserExtensionsEnabled([out, retval] BOOL* value); + + + /// When `AreBrowserExtensionsEnabled` is set to `TRUE`, new extensions can be added to user + /// profile and used. `AreBrowserExtensionsEnabled` is default to be `FALSE`, in this case, + /// new extensions can't be installed, and already installed extension won't be + /// available to use in user profile. + /// If connecting to an already running environment with a different value for `AreBrowserExtensionsEnabled` + /// property, it will fail with `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)`. + /// See `ICoreWebView2BrowserExtension` for Extensions API details. + [propput] HRESULT AreBrowserExtensionsEnabled([in] BOOL value); + + + +} + + + +/// Additional options used to create WebView2 Environment. +[uuid(7c7ecf51-e918-5caf-853c-e9a2bcc27775), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions8 : IUnknown { + /// Gets the `ScrollBarStyle` property. + [propget] HRESULT ScrollBarStyle([out, retval] COREWEBVIEW2_SCROLLBAR_STYLE* value); + + + /// The ScrollBar style being set on the WebView2 Environment. + /// The default value is `COREWEBVIEW2_SCROLLBAR_STYLE_DEFAULT` + /// which specifies the default browser ScrollBar style. + /// The `color-scheme` CSS property needs to be set on the corresponding page + /// to allow ScrollBar to follow light or dark theme. Please see + /// [color-scheme](https://developer.mozilla.org/docs/Web/CSS/color-scheme#declaring_color_scheme_preferences) + /// for how `color-scheme` can be set. + /// CSS styles that modify the ScrollBar applied on top of native ScrollBar styling + /// that is selected with `ScrollBarStyle`. + [propput] HRESULT ScrollBarStyle([in] COREWEBVIEW2_SCROLLBAR_STYLE value); + + + +} + + + +/// Additional options used to create the WebView2 Environment that support +/// specifying the `ReleaseChannels` and `ChannelSearchKind`. +[uuid(c48d539f-e39f-441c-ae68-1f66e570bdc5), object, pointer_default(unique)] +interface ICoreWebView2EnvironmentOptions7 : IUnknown { + /// Gets the `ChannelSearchKind` property. + [propget] HRESULT ChannelSearchKind([out, retval] COREWEBVIEW2_CHANNEL_SEARCH_KIND* value); + + + /// The `ChannelSearchKind` property is `COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE` + /// by default; environment creation searches for a release channel on the machine + /// from most to least stable using the first channel found. The default search order is: + /// WebView2 Runtime -> Beta -> Dev -> Canary. Set `ChannelSearchKind` to + /// `COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE` to reverse the search order + /// so that environment creation searches for a channel from least to most stable. If + /// `ReleaseChannels` has been provided, the loader will only search + /// for channels in the set. See `COREWEBVIEW2_RELEASE_CHANNELS` for more details + /// on channels. + /// + /// This property can be overridden by the corresponding + /// registry key `ChannelSearchKind` or the environment variable + /// `WEBVIEW2_CHANNEL_SEARCH_KIND`. Set the value to `1` to set the search kind to + /// `COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE`. See + /// `CreateCoreWebView2EnvironmentWithOptions` for more details on overrides. + [propput] HRESULT ChannelSearchKind([in] COREWEBVIEW2_CHANNEL_SEARCH_KIND value); + + + /// Gets the `ReleaseChannels` property. + [propget] HRESULT ReleaseChannels([out, retval] COREWEBVIEW2_RELEASE_CHANNELS* value); + + + /// Sets the `ReleaseChannels`, which is a mask of one or more + /// `COREWEBVIEW2_RELEASE_CHANNELS` indicating which channels environment + /// creation should search for. OR operation(s) can be applied to multiple + /// `COREWEBVIEW2_RELEASE_CHANNELS` to create a mask. The default value is a + /// a mask of all the channels. By default, environment creation searches for + /// channels from most to least stable, using the first channel found on the + /// device. When `ReleaseChannels` is provided, environment creation will only + /// search for the channels specified in the set. Set `ChannelSearchKind` to + /// `COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE` to reverse the search order + /// so environment creation searches for least stable build first. See + /// `COREWEBVIEW2_RELEASE_CHANNELS` for descriptions of each channel. + /// + /// `CreateCoreWebView2EnvironmentWithOptions` fails with + /// `HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND)` if environment creation is unable + /// to find any channel from the `ReleaseChannels` installed on the device. + /// Use `GetAvailableCoreWebView2BrowserVersionStringWithOptions` on + /// `ICoreWebView2Environment` to verify which channel is used when this option + /// is set. + /// + /// Examples: + /// + /// | ReleaseChannels | Channel Search Kind: Most Stable (default) | Channel Search Kind: Least Stable | + /// | --- | --- | --- | + /// |COREWEBVIEW2_RELEASE_CHANNELS_BETA \\| COREWEBVIEW2_RELEASE_CHANNELS_STABLE| WebView2 Runtime -> Beta | Beta -> WebView2 Runtime| + /// |COREWEBVIEW2_RELEASE_CHANNELS_CANARY \\| COREWEBVIEW2_RELEASE_CHANNELS_DEV \\| COREWEBVIEW2_RELEASE_CHANNELS_BETA \\| COREWEBVIEW2_RELEASE_CHANNELS_STABLE| WebView2 Runtime -> Beta -> Dev -> Canary | Canary -> Dev -> Beta -> WebView2 Runtime | + /// |COREWEBVIEW2_RELEASE_CHANNELS_CANARY| Canary | Canary | + /// |COREWEBVIEW2_RELEASE_CHANNELS_BETA \\| COREWEBVIEW2_RELEASE_CHANNELS_CANARY \\| COREWEBVIEW2_RELEASE_CHANNELS_STABLE | WebView2 Runtime -> Beta -> Canary | Canary -> Beta -> WebView2 Runtime | + /// + /// If both `BrowserExecutableFolder` and `ReleaseChannels` are provided, the + /// `BrowserExecutableFolder` takes precedence, regardless of whether or not the + /// channel of `BrowserExecutableFolder` is included in the `ReleaseChannels`. + /// `ReleaseChannels` can be overridden by the corresponding registry override + /// `ReleaseChannels` or the environment variable `WEBVIEW2_RELEASE_CHANNELS`. + /// Set the value to a comma-separated string of integers, which map to the + /// following release channel values: Stable (0), Beta (1), Dev (2), and + /// Canary (3). For example, the values "0,2" and "2,0" indicate that environment + /// creation should only search for Dev channel and the WebView2 Runtime, using the + /// order indicated by `ChannelSearchKind`. Environment creation attempts to + /// interpret each integer and treats any invalid entry as Stable channel. See + /// `CreateCoreWebView2EnvironmentWithOptions` for more details on overrides. + [propput] HRESULT ReleaseChannels([in] COREWEBVIEW2_RELEASE_CHANNELS value); + + + +} + + +/// Receives the result of the `CreateCoreWebView2Environment` method. +[uuid(4e8a3389-c9d8-4bd2-b6b5-124fee6cc14d), object, pointer_default(unique)] +interface ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2Environment* result); +} +// Skipping ICoreWebView2CreateCoreWebView2EnvironmentWithOptionsCompletedHandler redefinition + + + +/// Creates an evergreen WebView2 Environment using the installed WebView2 +/// Runtime version. This is equivalent to running +/// `CreateCoreWebView2EnvironmentWithOptions` with `nullptr` for +/// `browserExecutableFolder`, `userDataFolder`, `additionalBrowserArguments`. +/// For more information, navigate to +/// `CreateCoreWebView2EnvironmentWithOptions`. +cpp_quote("STDAPI CreateCoreWebView2Environment(ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler* environmentCreatedHandler);") + +/// DLL export to create a WebView2 environment with a custom version of +/// WebView2 Runtime, user data folder, and with or without additional options. +/// +/// When WebView2 experimental APIs are used, make sure to provide a valid `environmentOptions` +/// so that WebView2 runtime knows which version of the SDK that the app is using. Otherwise, +/// WebView2 runtime assumes that the version of the SDK being used is the latest +/// version known to it, which might not be the version of the SDK being used. +/// This wrong SDK version assumption could result in some experimental APIs not being available. +/// +/// The WebView2 environment and all other WebView2 objects are single threaded +/// and have dependencies on Windows components that require COM to be +/// initialized for a single-threaded apartment. The app is expected to run +/// `CoInitializeEx` before running `CreateCoreWebView2EnvironmentWithOptions`. +/// +/// ```text +/// CoInitializeEx(nullptr, COINIT_APARTMENTTHREADED); +/// ``` +/// +/// If `CoInitializeEx` did not run or previously ran with +/// `COINIT_MULTITHREADED`, `CreateCoreWebView2EnvironmentWithOptions` fails +/// with one of the following errors. +/// +/// ```text +/// CO_E_NOTINITIALIZED - if CoInitializeEx was not called +/// RPC_E_CHANGED_MODE - if CoInitializeEx was previously called with +/// COINIT_MULTITHREADED +/// ``` +/// +/// +/// Use `browserExecutableFolder` to specify whether WebView2 controls use a +/// fixed or installed version of the WebView2 Runtime that exists on a user +/// machine. To use a fixed version of the WebView2 Runtime, pass the +/// folder path that contains the fixed version of the WebView2 Runtime to +/// `browserExecutableFolder`. BrowserExecutableFolder supports both relative +/// (to the application's executable) and absolute files paths. +/// To create WebView2 controls that use the +/// installed version of the WebView2 Runtime that exists on user machines, +/// pass a `null` or empty string to `browserExecutableFolder`. In this +/// scenario, the API tries to find a compatible version of the WebView2 +/// Runtime that is installed on the user machine (first at the machine level, +/// and then per user) using the selected channel preference. The path of +/// fixed version of the WebView2 Runtime should not contain +/// `\Edge\Application\`. When such a path is used, the API fails +/// with `HRESULT_FROM_WIN32(ERROR_NOT_SUPPORTED)`. +/// +/// By default, the channel search order is `COREWEBVIEW2_CHANNEL_SEARCH_KIND_MOST_STABLE`, +/// which means that environment creation searches for an installation in the following order: +/// the WebView2 Runtime, Beta, Dev, and Canary. The channel search order is reversed +/// when the `ChannelSearchKind` property on `ICoreWebView2EnvironmentOptions` is set to +/// `COREWEBVIEW2_CHANNEL_SEARCH_KIND_LEAST_STABLE`, or when the corresponding environment +/// variable or registry override is set to `1`. See below for descriptions of overrides. If +/// `ReleaseChannels` on `ICoreWebView2EnvironmentOptions` is provided, environment creation will +/// only consider channels in this set, following the `ChannelSearchKind` order. +/// +/// You may specify the `userDataFolder` to change the default user data +/// folder location for WebView2. The path is either an absolute file path +/// or a relative file path that is interpreted as relative to the compiled +/// code for the current process. For UWP apps, the default user data +/// folder is the app data folder for the package. For non-UWP apps, the +/// default user data (`{Executable File Name}.WebView2`) folder is +/// created in the same directory next to the compiled code for the app. +/// WebView2 creation fails if the compiled code is running in a directory in +/// which the process does not have permission to create a new directory. The +/// app is responsible to clean up the associated user data folder when it +/// is done. +/// +/// \> [!NOTE]\n\> As a browser process may be shared among WebViews, WebView creation fails +/// with `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` if the specified options +/// does not match the options of the WebViews that are currently running in +/// the shared browser process. +/// +/// `environmentCreatedHandler` is the handler result to the async operation +/// that contains the `WebView2Environment` that was created. +/// +/// The `browserExecutableFolder`, `channelSearchKind`, `releaseChannels`, +/// `userDataFolder` and `additionalBrowserArguments` of the `environmentOptions` +/// may be overridden by values either specified in environment variables or in +/// the registry. +/// +/// When creating a `WebView2Environment` the following environment variables +/// are verified. +/// +/// ```text +/// WEBVIEW2_BROWSER_EXECUTABLE_FOLDER +/// WEBVIEW2_USER_DATA_FOLDER +/// WEBVIEW2_ADDITIONAL_BROWSER_ARGUMENTS +/// WEBVIEW2_CHANNEL_SEARCH_KIND +/// WEBVIEW2_RELEASE_CHANNELS +/// ``` +/// +/// If you find an override environment variable, use the +/// `browserExecutableFolder` and `userDataFolder` values as replacements for +/// the corresponding values in `CreateCoreWebView2EnvironmentWithOptions` +/// parameters. If `additionalBrowserArguments` is specified in environment +/// variable or in the registry, it is appended to the corresponding values in +/// `CreateCoreWebView2EnvironmentWithOptions` parameters. See `ReleaseChannels` +/// on `ICoreWebView2EnvironmentOptions` for more details on how to construct the +/// registry key and environment variable values. +/// +/// While not strictly overrides, additional environment variables may be set. +/// +/// ```text +/// WEBVIEW2_WAIT_FOR_SCRIPT_DEBUGGER +/// ``` +/// +/// When found with a non-empty value, this indicates that the WebView is being +/// launched under a script debugger. In this case, the WebView issues a +/// `Page.waitForDebugger` CDP command that runs the script inside the WebView +/// to pause on launch, until a debugger issues a corresponding +/// `Runtime.runIfWaitingForDebugger` CDP command to resume the runtime. +/// +/// \> [!NOTE]\n\> The following environment variable does not have a registry key +/// equivalent: `WEBVIEW2_WAIT_FOR_SCRIPT_DEBUGGER`. +/// +/// When found with a non-empty value, it indicates that the WebView is being +/// launched under a script debugger that also supports host apps that use +/// multiple WebViews. The value is used as the identifier for a named pipe +/// that is opened and written to when a new WebView is created by the host +/// app. The payload should match the payload of the `remote-debugging-port` +/// JSON target and an external debugger may use it to attach to a specific +/// WebView instance. The format of the pipe created by the debugger should be +/// `\\.\pipe\WebView2\Debugger\{app_name}\{pipe_name}`, where the following +/// are true. +/// +/// * `{app_name}` is the host app exe file name, for example, +/// `WebView2Example.exe` +/// * `{pipe_name}` is the value set for `WEBVIEW2_PIPE_FOR_SCRIPT_DEBUGGER` +/// +/// To enable debugging of the targets identified by the JSON, you must set the +/// `WEBVIEW2_ADDITIONAL_BROWSER_ARGUMENTS` environment variable to send +/// `--remote-debugging-port={port_num}`, where the following is true. +/// +/// * `{port_num}` is the port on which the CDP server binds. +/// +/// \> [!WARNING]\n\> If you set both `WEBVIEW2_PIPE_FOR_SCRIPT_DEBUGGER` and +/// `WEBVIEW2_ADDITIONAL_BROWSER_ARGUMENTS` environment variables, the +/// WebViews hosted in your app and associated contents may exposed to 3rd +/// party apps such as debuggers. +/// +/// \> [!NOTE]\n\> The following environment variable does not have a registry key +/// equivalent: `WEBVIEW2_PIPE_FOR_SCRIPT_DEBUGGER`. +/// +/// If none of those environment variables exist, then the registry is examined +/// next. The following registry values are verified. +/// +/// ```text +/// [{Root}]\Software\Policies\Microsoft\Edge\WebView2\BrowserExecutableFolder +/// "{AppId}"="" +/// +/// [{Root}]\Software\Policies\Microsoft\Edge\WebView2\ChannelSearchKind +/// "{AppId}"="" +/// +/// [{Root}]\Software\Policies\Microsoft\Edge\WebView2\ReleaseChannels +/// "{AppId}"="" +/// +/// [{Root}]\Software\Policies\Microsoft\Edge\WebView2\AdditionalBrowserArguments +/// "{AppId}"="" +/// +/// [{Root}]\Software\Policies\Microsoft\Edge\WebView2\UserDataFolder +/// "{AppId}"="" +/// ``` +/// +/// You can use a group policy under **Administrative Templates** > +/// **Microsoft Edge WebView2** to configure `browserExecutableFolder`, +/// `channelSearchKind`, and `releaseChannels`. +/// +/// In the unlikely scenario where some instances of WebView are open during a +/// browser update, the deletion of the previous WebView2 Runtime may be +/// blocked. To avoid running out of disk space, a new WebView creation fails +/// with `HRESULT_FROM_WIN32(ERROR_DISK_FULL)` if it detects that too many +/// previous WebView2 Runtime versions exist. +/// +/// The default maximum number of WebView2 Runtime versions allowed is `20`. +/// To override the maximum number of the previous WebView2 Runtime versions +/// allowed, set the value of the following environment variable. +/// +/// ```text +/// COREWEBVIEW2_MAX_INSTANCES +/// ``` +/// +/// If the Webview depends upon an installed WebView2 Runtime version and it is +/// uninstalled, any subsequent creation fails with +/// `HRESULT_FROM_WIN32(ERROR_PRODUCT_UNINSTALLED)`. +/// +/// First verify with Root as `HKLM` and then `HKCU`. `AppId` is first set to +/// the Application User Model ID of the process, then if no corresponding +/// registry key, the `AppId` is set to the compiled code name of the process, +/// or if that is not a registry key then `*`. A registry setting with `*` as +/// the value name will apply to all WebView2 apps, and cannot be used for the +/// `userDataFolder` option. If an override registry key is found, use the +/// `browserExecutableFolder` and `userDataFolder` registry values as +/// replacements and append `additionalBrowserArguments` registry values for the +/// corresponding values in `CreateCoreWebView2EnvironmentWithOptions` parameters. +/// +/// The following summarizes the possible error values that can be returned from +/// `CreateCoreWebView2EnvironmentWithOptions` and a description of why these +/// errors occur. +/// +/// Error value | Description +/// ----------------------------------------------- | -------------------------- +/// `CO_E_NOTINITIALIZED` | CoInitializeEx was not called. +/// `RPC_E_CHANGED_MODE` | CoInitializeEx was previously called with COINIT_MULTITHREADED. +/// `HRESULT_FROM_WIN32(ERROR_NOT_SUPPORTED)` | *\\Edge\\Application* path used in browserExecutableFolder. +/// `HRESULT_FROM_WIN32(ERROR_INVALID_STATE)` | Specified options do not match the options of the WebViews that are currently running in the shared browser process. +/// `HRESULT_FROM_WIN32(ERROR_DISK_FULL)` | In the unlikely scenario where some instances of WebView are open during a browser update, the deletion of the previous WebView2 Runtime may be blocked. To avoid running out of disk space, a new WebView creation fails with `HRESULT_FROM_WIN32(ERROR_DISK_FULL)` if it detects that too many previous WebView2 Runtime versions exist. +/// `HRESULT_FROM_WIN32(ERROR_PRODUCT_UNINSTALLED)` | If the Webview depends upon an installed WebView2 Runtime version and it is uninstalled. +/// `HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND)` | Could not find Edge installation. +/// `HRESULT_FROM_WIN32(ERROR_FILE_EXISTS)` | User data folder cannot be created because a file with the same name already exists. +/// `E_ACCESSDENIED` | Unable to create user data folder, Access Denied. +/// `E_FAIL` | Edge runtime unable to start. +cpp_quote("STDAPI CreateCoreWebView2EnvironmentWithOptions(PCWSTR browserExecutableFolder, PCWSTR userDataFolder, ICoreWebView2EnvironmentOptions* environmentOptions, ICoreWebView2CreateCoreWebView2EnvironmentCompletedHandler* environmentCreatedHandler);") + +/// Get the browser version info including channel name if it is not the +/// WebView2 Runtime. Channel names are Beta, Dev, and Canary. +/// If an override exists for the `browserExecutableFolder` or the channel +/// preference, the override is used. If an override is not specified, then +/// the parameter value passed to +/// `GetAvailableCoreWebView2BrowserVersionString` is used. +/// Returns `HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND)` if it fails to find an +/// installed WebView2 runtime or non-stable Microsoft Edge installation. +/// +/// The caller must free the returned string with `CoTaskMemFree`. See +/// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). +cpp_quote("STDAPI GetAvailableCoreWebView2BrowserVersionString(PCWSTR browserExecutableFolder, LPWSTR* versionInfo);") + +/// This method is for anyone want to compare version correctly to determine +/// which version is newer, older or same. Use it to determine whether +/// to use webview2 or certain feature based upon version. Sets the value of +/// result to `-1`, `0` or `1` if `version1` is less than, equal or greater +/// than `version2` respectively. Returns `E_INVALIDARG` if it fails to parse +/// any of the version strings or any input parameter is `null`. Directly use +/// the `versionInfo` obtained from +/// `GetAvailableCoreWebView2BrowserVersionString` with input, channel +/// information is ignored. +cpp_quote("STDAPI CompareBrowserVersions(PCWSTR version1, PCWSTR version2, int* result);") + + + + + +/// This function will tell you the browser version info of the release channel +/// used when creating an environment with the same options. Browser version +/// info includes channel name if it is not the WebView2 Runtime. Channel names +/// are Beta, Dev, and Canary. The format of the return string matches the format of +/// `BrowserVersionString` on `ICoreWebView2Environment`. +/// +/// If an override exists for `browserExecutableFolder`, `releaseChannels`, +/// or `ChannelSearchKind`, the override is used. The presence of an override +/// can result in a different channel used than the one expected based on the +/// environment options object. `browserExecutableFolder` takes precedence over +/// the other options, regardless of whether or not its channel is included in +/// the `releaseChannels`. See `CreateCoreWebView2EnvironmentWithOptions` +/// for more details on overrides. If an override is not specified, then the +/// parameters passed to `GetAvailableCoreWebView2BrowserVersionStringWithOptions` +/// are used. Returns `HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND)` if it fails to find +/// an installed WebView2 Runtime or non-stable Microsoft Edge installation. Use +/// `GetAvailableCoreWebView2BrowserVersionString` to get the version info without +/// the environment options. +/// +/// The caller must free the returned string with `CoTaskMemFree`. See +/// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). +cpp_quote("STDAPI GetAvailableCoreWebView2BrowserVersionStringWithOptions(PCWSTR browserExecutableFolder, ICoreWebView2EnvironmentOptions* environmentOptions, LPWSTR* versionInfo);") + + + + + +/// Representation of a DOM +/// [File](https://developer.mozilla.org/docs/Web/API/File) object +/// passed via WebMessage. You can use this object to obtain the path of a +/// File dropped on WebView2. +/// \snippet ScenarioDragDrop.cpp DroppedFilePath +[uuid(f2c19559-6bc1-4583-a757-90021be9afec), object, pointer_default(unique)] +interface ICoreWebView2File : IUnknown { + /// Get the absolute file path. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Path([out, retval] LPWSTR* value); + + + +} + + + +/// Representation of a DOM +/// [FileSystemHandle](https://developer.mozilla.org/docs/Web/API/FileSystemHandle) +/// object. +[uuid(c65100ac-0de2-5551-a362-23d9bd1d0e1f), object, pointer_default(unique)] +interface ICoreWebView2FileSystemHandle : IUnknown { + /// The kind of the FileSystemHandle. It can either be a file or a directory. + [propget] HRESULT Kind([out, retval] COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND* value); + + + /// The path to the FileSystemHandle. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Path([out, retval] LPWSTR* value); + + + /// The permissions granted to the FileSystemHandle. + [propget] HRESULT Permission([out, retval] COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION* value); + + + +} + + +/// Receives the result of the `Start` method. +[uuid(6a90ecaf-44b0-5bd9-8f07-1967e17be9fb), object, pointer_default(unique)] +interface ICoreWebView2FindStartCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} + +/// Receives `ActiveMatchIndexChanged` events. +[uuid(0054f514-9a8e-5876-aed5-30b37f8c86a5), object, pointer_default(unique)] +interface ICoreWebView2FindActiveMatchIndexChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Find* sender, + [in] IUnknown* args); +} +/// Receives `MatchCountChanged` events. +[uuid(da0d6827-4254-5b10-a6d9-412076afc9f3), object, pointer_default(unique)] +interface ICoreWebView2FindMatchCountChangedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Find* sender, + [in] IUnknown* args); +} + + +/// Interface providing methods and properties for finding and navigating through text in the web view. +/// This interface allows for finding text, navigation between matches, and customization of the find UI. +[uuid(a3ec0f5f-ddbc-54ed-8546-af75a785b9a6), object, pointer_default(unique)] +interface ICoreWebView2Find : IUnknown { + /// Retrieves the index of the currently active match in the find session. Returns the index of the currently active match, or -1 if there is no active match. + /// The index starts at 1 for the first match. + /// + /// \snippet AppWindow.cpp ActiveMatchIndex + [propget] HRESULT ActiveMatchIndex([out, retval] INT32* value); + + + /// Gets the total count of matches found in the current document based on the last find sessions criteria. Returns the total count of matches. + /// + /// \snippet AppWindow.cpp MatchCount + [propget] HRESULT MatchCount([out, retval] INT32* value); + + + + /// Adds an event handler for the `ActiveMatchIndexChanged` event. + /// Registers an event handler for the ActiveMatchIndexChanged event. This event is raised when the index of the currently active match changes. + /// This can happen when the user navigates to a different match or when the active match is changed programmatically. + /// The parameter is the event handler to be added. Returns a token representing the added event handler. + /// This token can be used to unregister the event handler. + HRESULT add_ActiveMatchIndexChanged( + [in] ICoreWebView2FindActiveMatchIndexChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_ActiveMatchIndexChanged`. + HRESULT remove_ActiveMatchIndexChanged( + [in] EventRegistrationToken token); + + /// Adds an event handler for the `MatchCountChanged` event. + /// Registers an event handler for the MatchCountChanged event. + /// This event is raised when the total count of matches in the document changes due to a new find session or changes in the document. + /// The parameter is the event handler to be added. Returns a token representing the added event handler. This token can be used to unregister the event handler. + HRESULT add_MatchCountChanged( + [in] ICoreWebView2FindMatchCountChangedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_MatchCountChanged`. + HRESULT remove_MatchCountChanged( + [in] EventRegistrationToken token); + + + /// Initiates a find using the specified find options asynchronously. + /// Displays the Find bar and starts the find session. If a find session was already ongoing, it will be stopped and replaced with this new instance. + /// If called with an empty string, the Find bar is displayed but no finding occurs. Changing the FindOptions object after initiation won't affect the ongoing find session. + /// To change the ongoing find session, Start must be called again with a new or modified FindOptions object. + /// Start supports HTML and TXT document queries. In general, this API is designed for text-based find sessions. + /// If you start a find session programmatically on another file format that doesn't have text fields, the find session will try to execute but will fail to find any matches. (It will silently fail) + /// Note: The asynchronous action completes when the UI has been displayed with the find term in the UI bar, and the matches have populated on the counter on the find bar. + /// There may be a slight latency between the UI display and the matches populating in the counter. + /// The MatchCountChanged and ActiveMatchIndexChanged events are only raised after Start has completed; otherwise, they will have their default values (-1 for active match index and 0 for match count). + /// To start a new find session (beginning the search from the first match), call `Stop` before invoking `Start`. + /// If `Start` is called consecutively with the same options and without calling `Stop`, the find session + /// will continue from the current position in the existing session. + /// Calling `Start` without altering its parameters will behave either as `FindNext` or `FindPrevious`, depending on the most recent search action performed. + /// Start will default to forward if neither have been called. + /// However, calling Start again during an ongoing find session does not resume from the point + /// of the current active match. For example, given the text "1 1 A 1 1" and initiating a find session for "A", + /// then starting another find session for "1", it will start searching from the beginning of the document, + /// regardless of the previous active match. This behavior indicates that changing the find query initiates a + /// completely new find session, rather than continuing from the previous match index. + /// + /// \snippet AppWindow.cpp Start + HRESULT Start( + [in] ICoreWebView2FindOptions* options + , [in] ICoreWebView2FindStartCompletedHandler* handler); + + /// Navigates to the next match in the document. + /// If there are no matches to find, FindNext will wrap around to the first match's index. + /// If called when there is no find session active, FindNext will silently fail. + /// + /// \snippet AppWindow.cpp FindNext + HRESULT FindNext( + ); + + /// Navigates to the previous match in the document. + /// If there are no matches to find, FindPrevious will wrap around to the last match's index. + /// If called when there is no find session active, FindPrevious will silently fail. + /// + /// \snippet AppWindow.cpp FindPrevious + HRESULT FindPrevious( + ); + + /// Stops the current 'Find' session and hides the Find bar. + /// If called with no Find session active, it will silently do nothing. + /// + /// \snippet AppWindow.cpp Stop + HRESULT Stop( + ); + + +} + + + +/// Interface defining the find options. +/// This interface provides the necessary methods and properties to configure a find session. +[uuid(e82e3b2b-a4af-5bc6-94c6-18b44157a16c), object, pointer_default(unique)] +interface ICoreWebView2FindOptions : IUnknown { + /// Gets the `FindTerm` property. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FindTerm([out, retval] LPWSTR* value); + + + /// Gets or sets the word or phrase to be searched in the current page. + /// You can set `FindTerm` to any text you want to find on the page. + /// This will take effect the next time you call the `Start()` method. + /// + /// \snippet AppWindow.cpp FindTerm + [propput] HRESULT FindTerm([in] LPCWSTR value); + + + /// Gets the `IsCaseSensitive` property. + [propget] HRESULT IsCaseSensitive([out, retval] BOOL* value); + + + /// Determines if the find session is case sensitive. Returns TRUE if the find is case sensitive, FALSE otherwise. + /// When toggling case sensitivity, the behavior can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration + /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. + /// + /// \snippet AppWindow.cpp IsCaseSensitive + [propput] HRESULT IsCaseSensitive([in] BOOL value); + + + /// Gets the `ShouldHighlightAllMatches` property. + [propget] HRESULT ShouldHighlightAllMatches([out, retval] BOOL* value); + + + /// Gets or sets the state of whether all matches are highlighted. + /// Returns TRUE if all matches are highlighted, FALSE otherwise. + /// Note: Changes to this property take effect only when Start, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the Start function on the server-side is made. + /// Therefore, changes will not take effect until one of these functions is called. + /// + /// \snippet AppWindow.cpp ShouldHighlightAllMatches + [propput] HRESULT ShouldHighlightAllMatches([in] BOOL value); + + + /// Gets the `ShouldMatchWord` property. + [propget] HRESULT ShouldMatchWord([out, retval] BOOL* value); + + + /// Similar to case sensitivity, word matching also can vary by locale, which may be influenced by both the browser's UI locale and the document's language settings. The browser's UI locale + /// typically provides a default handling approach, while the document's language settings (e.g., specified using the HTML lang attribute) can override these defaults to apply locale-specific rules. This dual consideration + /// ensures that text is processed in a manner consistent with user expectations and the linguistic context of the content. + /// ShouldMatchWord determines if only whole words should be matched during the find session. Returns TRUE if only whole words should be matched, FALSE otherwise. + /// + /// \snippet AppWindow.cpp ShouldMatchWord + [propput] HRESULT ShouldMatchWord([in] BOOL value); + + + /// Gets the `SuppressDefaultFindDialog` property. + [propget] HRESULT SuppressDefaultFindDialog([out, retval] BOOL* value); + + + /// Sets this property to hide the default Find UI. + /// You can use this to hide the default UI so that you can show your own custom UI or programmatically interact with the Find API while showing no Find UI. + /// Returns TRUE if hiding the default Find UI and FALSE if using showing the default Find UI. + /// Note: Changes to this property take effect only when Start, FindNext, or FindPrevious is called. + /// Preferences for the session cannot be updated unless another call to the Start function on the server-side is made. + /// Therefore, changes will not take effect until one of these functions is called. + /// + /// \snippet AppWindow.cpp SuppressDefaultFindDialog + [propput] HRESULT SuppressDefaultFindDialog([in] BOOL value); + + + +} + + +/// Receives `PermissionRequested` events. +[uuid(845d0edd-8bd8-429b-9915-4821789f23e9), object, pointer_default(unique)] +interface ICoreWebView2FramePermissionRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2PermissionRequestedEventArgs2* args); +} + + +/// This is an extension of the ICoreWebView2Frame interface that supports PermissionRequested +[uuid(b50d82cc-cc28-481d-9614-cb048895e6a0), object, pointer_default(unique)] +interface ICoreWebView2Frame3 : ICoreWebView2Frame2 { + /// Adds an event handler for the `PermissionRequested` event. + /// Add an event handler for the `PermissionRequested` event. + /// `PermissionRequested` is raised when content in an iframe any of its + /// descendant iframes requests permission to privileged resources. + /// + /// This relates to the `PermissionRequested` event on the `CoreWebView2`. + /// Both these events will be raised in the case of an iframe requesting + /// permission. The `CoreWebView2Frame`'s event handlers will be invoked + /// before the event handlers on the `CoreWebView2`. If the `Handled` property + /// of the `PermissionRequestedEventArgs` is set to TRUE within the + /// `CoreWebView2Frame` event handler, then the event will not be + /// raised on the `CoreWebView2`, and it's event handlers will not be invoked. + /// + /// In the case of nested iframes, if the `PermissionRequested` event is handled + /// in the current nested iframe (i.e., the Handled property of the + /// `PermissionRequestedEventArgs` is set to TRUE), the event will not be raised + /// on the parent `CoreWebView2Frame`. However, if the `PermissionRequested` event is + /// not handled in that nested iframe, the event will be raised from its nearest + /// tracked parent `CoreWebView2Frame`. It will iterate through the parent frame + /// chain up to the main frame until a parent frame handles the request. + /// + /// If a deferral is not taken on the event args, the subsequent scripts are + /// blocked until the event handler returns. If a deferral is taken, the + /// scripts are blocked until the deferral is completed. + /// + /// \snippet ScenarioIFrameDevicePermission.cpp PermissionRequested0 + /// \snippet ScenarioIFrameDevicePermission.cpp PermissionRequested1 + HRESULT add_PermissionRequested( + [in] ICoreWebView2FramePermissionRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_PermissionRequested`. + HRESULT remove_PermissionRequested( + [in] EventRegistrationToken token); + + +} + + + +/// This is an extension of the ICoreWebView2Frame interface that supports shared buffer based on file mapping. +[uuid(188782dc-92aa-4732-ab3c-fcc59f6f68b9), object, pointer_default(unique)] +interface ICoreWebView2Frame4 : ICoreWebView2Frame3 { + /// Share a shared buffer object with script of the iframe in the WebView. + /// The script will receive a `sharedbufferreceived` event from chrome.webview. + /// The event arg for that event will have the following methods and properties: + /// `getBuffer()`: return an ArrayBuffer object with the backing content from the shared buffer. + /// `additionalData`: an object as the result of parsing `additionalDataAsJson` as JSON string. + /// This property will be `undefined` if `additionalDataAsJson` is nullptr or empty string. + /// `source`: with a value set as `chrome.webview` object. + /// If a string is provided as `additionalDataAsJson` but it is not a valid JSON string, + /// the API will fail with `E_INVALIDARG`. + /// If `access` is COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY, the script will only have read access to the buffer. + /// If the script tries to modify the content in a read only buffer, it will cause an access + /// violation in WebView renderer process and crash the renderer process. + /// If the shared buffer is already closed, the API will fail with `RO_E_CLOSED`. + /// + /// The script code should call `chrome.webview.releaseBuffer` with + /// the shared buffer as the parameter to release underlying resources as soon + /// as it does not need access to the shared buffer any more. + /// + /// The application can post the same shared buffer object to multiple web pages or iframes, or + /// post to the same web page or iframe multiple times. Each `PostSharedBufferToScript` will + /// create a separate ArrayBuffer object with its own view of the memory and is separately + /// released. The underlying shared memory will be released when all the views are released. + /// + /// For example, if we want to send data to script for one time read only consumption. + /// + /// \snippet ScenarioSharedBuffer.cpp OneTimeShareBuffer + /// + /// In the HTML document, + /// + /// \snippet assets\ScenarioSharedBuffer.html ShareBufferScriptCode_1 + /// + /// \snippet assets\ScenarioSharedBuffer.html ShareBufferScriptCode_2 + /// + /// Sharing a buffer to script has security risk. You should only share buffer with trusted site. + /// If a buffer is shared to a untrusted site, possible sensitive information could be leaked. + /// If a buffer is shared as modifiable by the script and the script modifies it in an unexpected way, + /// it could result in corrupted data that might even crash the application. + HRESULT PostSharedBufferToScript( + [in] ICoreWebView2SharedBuffer* sharedBuffer, + [in] COREWEBVIEW2_SHARED_BUFFER_ACCESS access, + [in] LPCWSTR additionalDataAsJson + ); + + +} + + + +/// This is an extension of the ICoreWebView2Frame interface that provides the `FrameId` property. +[uuid(99d199c4-7305-11ee-b962-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2Frame5 : ICoreWebView2Frame4 { + /// The unique identifier of the current frame. It's the same kind of ID as + /// with the `FrameId` in `CoreWebView2` and via `CoreWebView2FrameInfo`. + [propget] HRESULT FrameId([out, retval] UINT32* value); + + + +} + + +/// Receives `ScreenCaptureStarting` events. +[uuid(a6c1d8ad-bb80-59c5-895b-fba1698b9309), object, pointer_default(unique)] +interface ICoreWebView2FrameScreenCaptureStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2ScreenCaptureStartingEventArgs* args); +} + + +/// This is an extension of the ICoreWebView2Frame interface that supports ScreenCaptureStarting. +[uuid(0de611fd-31e9-5ddc-9d71-95eda26eff32), object, pointer_default(unique)] +interface ICoreWebView2Frame6 : ICoreWebView2Frame5 { + /// Adds an event handler for the `ScreenCaptureStarting` event. + /// Add an event handler for the `ScreenCaptureStarting` event. + /// `ScreenCaptureStarting` is raised when content in an iframe or any of its + /// descendant iframes requests permission to use the Screen Capture + /// API from getDisplayMedia(). + /// + /// This relates to the `ScreenCaptureStarting` event on the + /// `CoreWebView2`. + /// Both these events will be raised in the case of an iframe requesting + /// screen capture. The `CoreWebView2Frame`'s event handlers will be invoked + /// before the event handlers on the `CoreWebView2`. If the `Handled` + /// property of the `ScreenCaptureStartingEventArgs` is set to TRUE + /// within the`CoreWebView2Frame` event handler, then the event will not + /// be raised on the `CoreWebView2`, and its event handlers will not be + /// invoked. + /// + /// \snippet ScenarioScreenCapture.cpp ScreenCaptureStarting1 + HRESULT add_ScreenCaptureStarting( + [in] ICoreWebView2FrameScreenCaptureStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_ScreenCaptureStarting`. + HRESULT remove_ScreenCaptureStarting( + [in] EventRegistrationToken token); + + +} + + +/// Receives `FrameCreated` events. +[uuid(569e40e7-46b7-563d-83ae-1073155664d7), object, pointer_default(unique)] +interface ICoreWebView2FrameChildFrameCreatedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2Frame* sender, + [in] ICoreWebView2FrameCreatedEventArgs* args); +} + + +/// This is the `ICoreWebView2Frame` interface to support tracking +/// of nested iframes. +[uuid(3598cfa2-d85d-5a9f-9228-4dde1f59ec64), object, pointer_default(unique)] +interface ICoreWebView2Frame7 : ICoreWebView2Frame6 { + /// Adds an event handler for the `FrameCreated` event. + /// Raised when a new direct descendant iframe is created. + /// Handle this event to get access to ICoreWebView2Frame objects. + /// Use `ICoreWebView2Frame.add_Destroyed` to listen for when this + /// iframe goes away. + /// + /// \snippet ScenarioWebViewEventMonitor.cpp FrameCreated + HRESULT add_FrameCreated( + [in] ICoreWebView2FrameChildFrameCreatedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_FrameCreated`. + HRESULT remove_FrameCreated( + [in] EventRegistrationToken token); + + +} + + + +/// Event args for the `FrameCreated` events. +[uuid(4d6e7b5e-9baa-11eb-a8b3-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2FrameCreatedEventArgs : IUnknown { + /// The frame which was created. + [propget] HRESULT Frame([out, retval] ICoreWebView2Frame** value); + + + +} + + + +/// Provides a set of properties for a frame in the `ICoreWebView2`. +[uuid(da86b8a1-bdf3-4f11-9955-528cefa59727), object, pointer_default(unique)] +interface ICoreWebView2FrameInfo : IUnknown { + /// The value of iframe's window.name property. The default value equals to + /// iframe html tag declaring it, as in ``. + /// The returned string is empty when the frame has no name attribute and + /// no assigned value for window.name. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Name([out, retval] LPWSTR* value); + + + /// The URI of the document in the frame. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Source([out, retval] LPWSTR* value); + + + +} + + + +/// Collection of `FrameInfo`s (name and source). Used to list the affected +/// frames' info when a frame-only render process failure occurs in the +/// `ICoreWebView2`. +[uuid(8f834154-d38e-4d90-affb-6800a7272839), object, pointer_default(unique)] +interface ICoreWebView2FrameInfoCollection : IUnknown { + /// Gets an iterator over the collection of `FrameInfo`s. + HRESULT GetIterator( + [out, retval] ICoreWebView2FrameInfoCollectionIterator** value); + + +} + + + +/// Iterator for a collection of `FrameInfo`s. For more info, see +/// `ICoreWebView2ProcessFailedEventArgs2` and +/// `ICoreWebView2FrameInfoCollection`. +[uuid(1bf89e2d-1b2b-4629-b28f-05099b41bb03), object, pointer_default(unique)] +interface ICoreWebView2FrameInfoCollectionIterator : IUnknown { + /// `TRUE` when the iterator has not run out of `FrameInfo`s. If the + /// collection over which the iterator is iterating is empty or if the + /// iterator has gone past the end of the collection, then this is `FALSE`. + [propget] HRESULT HasCurrent([out, retval] BOOL* value); + + + + /// Get the current `ICoreWebView2FrameInfo` of the iterator. + /// Returns `HRESULT_FROM_WIN32(ERROR_INVALID_INDEX)` if HasCurrent is + /// `FALSE`. + HRESULT GetCurrent( + [out, retval] ICoreWebView2FrameInfo** value); + + /// Move the iterator to the next `FrameInfo` in the collection. + HRESULT MoveNext( + [out, retval] BOOL* value); + + +} + + + +/// HTTP request headers. Used to inspect the HTTP request on +/// `WebResourceRequested` event and `NavigationStarting` event. +/// +/// \> [!NOTE]\n\> It is possible to modify the HTTP request from a `WebResourceRequested` +/// event, but not from a `NavigationStarting` event. +[uuid(e86cac0e-5523-465c-b536-8fb9fc8c8c60), object, pointer_default(unique)] +interface ICoreWebView2HttpRequestHeaders : IUnknown { + /// Gets the header value matching the name. + HRESULT GetHeader( + [in] LPCWSTR name + , [out, retval] LPWSTR* value); + + /// Gets the header value matching the name using an iterator. + HRESULT GetHeaders( + [in] LPCWSTR name + , [out, retval] ICoreWebView2HttpHeadersCollectionIterator** value); + + /// Checks whether the headers contain an entry that matches the header name. + HRESULT Contains( + [in] LPCWSTR name + , [out, retval] BOOL* value); + + /// Adds or updates header that matches the name. + HRESULT SetHeader( + [in] LPCWSTR name, + [in] LPCWSTR value + ); + + /// Removes header that matches the name. + HRESULT RemoveHeader( + [in] LPCWSTR name + ); + + /// Gets an iterator over the collection of request headers. + HRESULT GetIterator( + [out, retval] ICoreWebView2HttpHeadersCollectionIterator** value); + + +} + + + +/// HTTP response headers. Used to construct a `WebResourceResponse` for the +/// `WebResourceRequested` event. +[uuid(03c5ff5a-9b45-4a88-881c-89a9f328619c), object, pointer_default(unique)] +interface ICoreWebView2HttpResponseHeaders : IUnknown { + /// Appends header line with name and value. + /// + HRESULT AppendHeader( + [in] LPCWSTR name, + [in] LPCWSTR value + ); + + /// Verifies that the headers contain entries that match the header name. + HRESULT Contains( + [in] LPCWSTR name + , [out, retval] BOOL* value); + + /// Gets the first header value in the collection matching the name. + /// + HRESULT GetHeader( + [in] LPCWSTR name + , [out, retval] LPWSTR* value); + + /// Gets the header values matching the name. + HRESULT GetHeaders( + [in] LPCWSTR name + , [out, retval] ICoreWebView2HttpHeadersCollectionIterator** value); + + /// Gets an iterator over the collection of entire response headers. + HRESULT GetIterator( + [out, retval] ICoreWebView2HttpHeadersCollectionIterator** value); + + +} + + + +/// This is an interface for the StatusCode property of +/// ICoreWebView2NavigationCompletedEventArgs +[uuid(fdf8b738-ee1e-4db2-a329-8d7d7b74d792), object, pointer_default(unique)] +interface ICoreWebView2NavigationCompletedEventArgs2 : ICoreWebView2NavigationCompletedEventArgs { + /// The HTTP status code of the navigation if it involved an HTTP request. + /// For instance, this will usually be 200 if the request was successful, 404 + /// if a page was not found, etc. See + /// https://developer.mozilla.org/docs/Web/HTTP/Status for a list of + /// common status codes. + /// + /// The `HttpStatusCode` property will be 0 in the following cases: + /// * The navigation did not involve an HTTP request. For instance, if it was + /// a navigation to a file:// URL, or if it was a same-document navigation. + /// * The navigation failed before a response was received. For instance, if + /// the hostname was not found, or if there was a network error. + /// + /// In those cases, you can get more information from the `IsSuccess` and + /// `WebErrorStatus` properties. + /// + /// If the navigation receives a successful HTTP response, but the navigated + /// page calls `window.stop()` before it finishes loading, then + /// `HttpStatusCode` may contain a success code like 200, but `IsSuccess` will + /// be FALSE and `WebErrorStatus` will be + /// `COREWEBVIEW2_WEB_ERROR_STATUS_CONNECTION_ABORTED`. + /// + /// Since WebView2 handles HTTP continuations and redirects automatically, it + /// is unlikely for `HttpStatusCode` to ever be in the 1xx or 3xx ranges. + [propget] HRESULT HttpStatusCode([out, retval] int* value); + + +} + + + +/// The AdditionalAllowedFrameAncestors API that enable developers to provide additional allowed frame ancestors. +[uuid(9086be93-91aa-472d-a7e0-579f2ba006ad), object, pointer_default(unique)] +interface ICoreWebView2NavigationStartingEventArgs2 : ICoreWebView2NavigationStartingEventArgs { + /// Gets the `AdditionalAllowedFrameAncestors` property. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT AdditionalAllowedFrameAncestors([out, retval] LPWSTR* value); + + + /// Additional allowed frame ancestors set by the host app. + /// + /// The app may set this property to allow a frame to be embedded by additional ancestors besides what is allowed by + /// http header [X-Frame-Options](https://developer.mozilla.org/docs/Web/HTTP/Headers/X-Frame-Options) + /// and [Content-Security-Policy frame-ancestors directive](https://developer.mozilla.org/docs/Web/HTTP/Headers/Content-Security-Policy/frame-ancestors). + /// If set, a frame ancestor is allowed if it is allowed by the additional allowed frame + /// ancestors or original http header from the site. + /// Whether an ancestor is allowed by the additional allowed frame ancestors is done the same way as if the site provided + /// it as the source list of the Content-Security-Policy frame-ancestors directive. + /// For example, if `https://example.com` and `https://www.example.com` are the origins of the top + /// page and intermediate iframes that embed a nested site-embedding iframe, and you fully trust + /// those origins, you should set this property to `https://example.com https://www.example.com`. + /// This property gives the app the ability to use iframe to embed sites that otherwise + /// could not be embedded in an iframe in trusted app pages. + /// This could potentially subject the embedded sites to [Clickjacking](https://en.wikipedia.org/wiki/Clickjacking) + /// attack from the code running in the embedding web page. Therefore, you should only + /// set this property with origins of fully trusted embedding page and any intermediate iframes. + /// Whenever possible, you should use the list of specific origins of the top and intermediate + /// frames instead of wildcard characters for this property. + /// This API is to provide limited support for app scenarios that used to be supported by + /// `` element in other solutions like JavaScript UWP apps and Electron. + /// You should limit the usage of this property to trusted pages, and specific navigation + /// target url, by checking the `Source` of the WebView2, and `Uri` of the event args. + /// + /// This property is ignored for top level document navigation. + /// + /// \snippet ScriptComponent.cpp AdditionalAllowedFrameAncestors_1 + /// + /// \snippet ScriptComponent.cpp AdditionalAllowedFrameAncestors_2 + [propput] HRESULT AdditionalAllowedFrameAncestors([in] LPCWSTR value); + + + +} + + + +/// The NavigationKind API that enables developers to get more information about +/// navigation type. +[uuid(ddffe494-4942-4bd2-ab73-35b8ff40e19f), object, pointer_default(unique)] +interface ICoreWebView2NavigationStartingEventArgs3 : ICoreWebView2NavigationStartingEventArgs2 { + /// Get the navigation kind of this navigation. + /// + [propget] HRESULT NavigationKind([out, retval] COREWEBVIEW2_NAVIGATION_KIND* value); + + + +} + + + +/// This is a continuation of the `ICoreWebView2NewWindowRequestedEventArgs` interface. +[uuid(bbc7baed-74c6-4c92-b63a-7f5aeae03de3), object, pointer_default(unique)] +interface ICoreWebView2NewWindowRequestedEventArgs2 : ICoreWebView2NewWindowRequestedEventArgs { + /// Gets the name of the new window. This window can be created via `window.open(url, windowName)`, + /// where the windowName parameter corresponds to `Name` property. + /// If no windowName is passed to `window.open`, then the `Name` property + /// will be set to an empty string. Additionally, if window is opened through other means, + /// such as `...` or ``, + /// then the `Name` property will be set accordingly. In the case of target=_blank, + /// the `Name` property will be an empty string. + /// Opening a window via ctrl+clicking a link would result in the `Name` property + /// being set to an empty string. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Name([out, retval] LPWSTR* value); + + + +} + + + +/// This is a continuation of the `ICoreWebView2NewWindowRequestedEventArgs` interface. +[uuid(842bed3c-6ad6-4dd9-b938-28c96667ad66), object, pointer_default(unique)] +interface ICoreWebView2NewWindowRequestedEventArgs3 : ICoreWebView2NewWindowRequestedEventArgs2 { + /// The frame info of the frame where the new window request originated. The + /// `OriginalSourceFrameInfo` is a snapshot of frame information at the time when the + /// new window was requested. + /// + /// See `ICoreWebView2FrameInfo` for details on frame + /// properties. + [propget] HRESULT OriginalSourceFrameInfo([out, retval] ICoreWebView2FrameInfo** value); + + + +} + + + +/// This is the Interface for non-client region change event args. +[uuid(ab71d500-0820-4a52-809c-48db04ff93bf), object, pointer_default(unique)] +interface ICoreWebView2NonClientRegionChangedEventArgs : IUnknown { + /// This property represents the COREWEBVIEW2_NON_CLIENT_REGION_KIND which the + /// region changed event corresponds to. With this property an app can query + /// for a collection of rects which have that region kind by using + /// QueryNonClientRegion on the composition controller. + [propget] HRESULT RegionKind([out, retval] COREWEBVIEW2_NON_CLIENT_REGION_KIND* value); + + + +} + + + +/// A collection of objects. +[uuid(0f36fd87-4f69-4415-98da-888f89fb9a33), object, pointer_default(unique)] +interface ICoreWebView2ObjectCollectionView : IUnknown { + /// Gets the number of objects contained in the `ContextMenuItemCollection`. + [propget] HRESULT Count([out, retval] UINT32* value); + + + + /// Gets the object at the specified index. + HRESULT GetValueAtIndex( + [in] UINT32 index + , [out, retval] IUnknown** value); + + +} + + + +/// This is a continuation of the `ICoreWebView2PermissionRequestedEventArgs` interface. +[uuid(74d7127f-9de6-4200-8734-42d6fb4ff741), object, pointer_default(unique)] +interface ICoreWebView2PermissionRequestedEventArgs2 : ICoreWebView2PermissionRequestedEventArgs { + /// Gets the `Handled` property. + [propget] HRESULT Handled([out, retval] BOOL* value); + + + /// By default, both the `PermissionRequested` event handlers on the + /// `CoreWebView2Frame` and the `CoreWebView2` will be invoked, with the + /// `CoreWebView2Frame` event handlers invoked first. The host may + /// set this flag to `TRUE` within the `CoreWebView2Frame` event handlers + /// to prevent the remaining `CoreWebView2` event handlers from being invoked. + /// + /// If a deferral is taken on the event args, then you must synchronously + /// set `Handled` to TRUE prior to taking your deferral to prevent the + /// `CoreWebView2`s event handlers from being invoked. + [propput] HRESULT Handled([in] BOOL value); + + + +} + + + +/// This is a continuation of the `ICoreWebView2PermissionRequestedEventArgs2` interface. +[uuid(e61670bc-3dce-4177-86d2-c629ae3cb6ac), object, pointer_default(unique)] +interface ICoreWebView2PermissionRequestedEventArgs3 : ICoreWebView2PermissionRequestedEventArgs2 { + /// Gets the `SavesInProfile` property. + [propget] HRESULT SavesInProfile([out, retval] BOOL* value); + + + /// The permission state set from the `PermissionRequested` event is saved in + /// the profile by default; it persists across sessions and becomes the new + /// default behavior for future `PermissionRequested` events. Browser + /// heuristics can affect whether the event continues to be raised when the + /// state is saved in the profile. Set the `SavesInProfile` property to + /// `FALSE` to not persist the state beyond the current request, and to + /// continue to receive `PermissionRequested` + /// events for this origin and permission kind. + [propput] HRESULT SavesInProfile([in] BOOL value); + + + +} + + + +/// Provides a set of properties for a permission setting. +[uuid(792b6eca-5576-421c-9119-74ebb3a4ffb3), object, pointer_default(unique)] +interface ICoreWebView2PermissionSetting : IUnknown { + /// The kind of the permission setting. See `COREWEBVIEW2_PERMISSION_KIND` for + /// more details. + [propget] HRESULT PermissionKind([out, retval] COREWEBVIEW2_PERMISSION_KIND* value); + + + /// The origin of the permission setting. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT PermissionOrigin([out, retval] LPWSTR* value); + + + /// The state of the permission setting. + [propget] HRESULT PermissionState([out, retval] COREWEBVIEW2_PERMISSION_STATE* value); + + + +} + + + +/// Event args for the `ProcessFailed` event. +[uuid(8155a9a4-1474-4a86-8cae-151b0fa6b8ca), object, pointer_default(unique)] +interface ICoreWebView2ProcessFailedEventArgs : IUnknown { + /// The kind of process failure that has occurred. This is a combination of + /// process kind (for example, browser, renderer, gpu) and failure (exit, + /// unresponsiveness). Renderer processes are further divided in _main frame_ + /// renderer (`RenderProcessExited`, `RenderProcessUnresponsive`) and + /// _subframe_ renderer (`FrameRenderProcessExited`). To learn about the + /// conditions under which each failure kind occurs, see + /// `COREWEBVIEW2_PROCESS_FAILED_KIND`. + [propget] HRESULT ProcessFailedKind([out, retval] COREWEBVIEW2_PROCESS_FAILED_KIND* value); + + + +} + + + +/// A continuation of the ICoreWebView2ProcessFailedEventArgs2 interface +/// fot getting blocked file for code integrity process failures. +[uuid(ab667428-094d-5fd1-b480-8b4c0fdbdf2f), object, pointer_default(unique)] +interface ICoreWebView2ProcessFailedEventArgs3 : ICoreWebView2ProcessFailedEventArgs2 { + /// This property is the full path of the module that caused the + /// crash in cases of Windows Code Integrity failures. + /// [Windows Code Integrity](/mem/intune/user-help/you-need-to-enable-code-integrity) + /// is a feature that verifies the integrity and + /// authenticity of dynamic-link libraries (DLLs) + /// on Windows systems. It ensures that only trusted + /// code can run on the system and prevents unauthorized or + /// malicious modifications. + /// When ProcessFailed occurred due to a failed Code Integrity check, + /// this property returns the full path of the file that was prevented from + /// loading on the system. + /// The webview2 process which tried to load the DLL will fail with + /// exit code STATUS_INVALID_IMAGE_HASH(-1073740760). + /// A file can fail integrity check for various + /// reasons, such as: + /// - It has an invalid or missing signature that does + /// not match the publisher or signer of the file. + /// - It has been tampered with or corrupted by malware or other software. + /// - It has been blocked by an administrator or a security policy. + /// This property always will be the empty string if failure is not caused by + /// STATUS_INVALID_IMAGE_HASH. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FailureSourceModulePath([out, retval] LPWSTR* value); + + + +} + + +/// Receives the result of the `ClearBrowsingData` method. +[uuid(e9710a06-1d1d-49b2-8234-226f35846ae5), object, pointer_default(unique)] +interface ICoreWebView2ClearBrowsingDataCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} +// Skipping ICoreWebView2ClearBrowsingDataCompletedHandler redefinition + +// Skipping ICoreWebView2ClearBrowsingDataCompletedHandler redefinition + + + +/// Profile2 interface. +/// +[uuid(fa740d4b-5eae-4344-a8ad-74be31925397), object, pointer_default(unique)] +interface ICoreWebView2Profile2 : ICoreWebView2Profile { + /// Clear browsing data based on a data type. This method takes two parameters, + /// the first being a mask of one or more `COREWEBVIEW2_BROWSING_DATA_KINDS`. OR + /// operation(s) can be applied to multiple `COREWEBVIEW2_BROWSING_DATA_KINDS` to + /// create a mask representing those data types. The browsing data kinds that are + /// supported are listed below. These data kinds follow a hierarchical structure in + /// which nested bullet points are included in their parent bullet point's data kind. + /// Ex: All DOM storage is encompassed in all site data which is encompassed in + /// all profile data. + /// + /// * All Profile + /// * All Site Data + /// * All DOM Storage: File Systems, Indexed DB, Local Storage, Web SQL, Cache + /// Storage + /// * Cookies + /// * Disk Cache + /// * Download History + /// * General Autofill + /// * Password Autosave + /// * Browsing History + /// * Settings + /// + /// The completed handler will be invoked when the browsing data has been cleared and + /// will indicate if the specified data was properly cleared. In the case in which + /// the operation is interrupted and the corresponding data is not fully cleared + /// the handler will return `E_ABORT` and otherwise will return `S_OK`. + /// Because this is an asynchronous operation, code that is dependent on the cleared + /// data must be placed in the callback of this operation. + /// If the WebView object is closed before the clear browsing data operation + /// has completed, the handler will be released, but not invoked. In this case + /// the clear browsing data operation may or may not be completed. + /// ClearBrowsingData clears the `dataKinds` regardless of timestamp. + HRESULT ClearBrowsingData( + [in] COREWEBVIEW2_BROWSING_DATA_KINDS dataKinds + , [in] ICoreWebView2ClearBrowsingDataCompletedHandler* handler); + /// ClearBrowsingDataInTimeRange behaves like ClearBrowsingData except that it + /// takes in two additional parameters for the start and end time for which it + /// should clear the data between. The `startTime` and `endTime` + /// parameters correspond to the number of seconds since the UNIX epoch. + /// `startTime` is inclusive while `endTime` is exclusive, therefore the data will + /// be cleared between [startTime, endTime). + HRESULT ClearBrowsingDataInTimeRange( + [in] COREWEBVIEW2_BROWSING_DATA_KINDS dataKinds, + [in] double startTime, + [in] double endTime + , [in] ICoreWebView2ClearBrowsingDataCompletedHandler* handler); + /// ClearBrowsingDataAll behaves like ClearBrowsingData except that it + /// clears the entirety of the data associated with the profile it is called on. + /// It clears the data regardless of timestamp. + /// + /// \snippet AppWindow.cpp ClearBrowsingData + HRESULT ClearBrowsingDataAll( + [in] ICoreWebView2ClearBrowsingDataCompletedHandler* handler); + + +} + + + +/// This is an extension of the ICoreWebView2Profile interface to control levels of tracking prevention. +[uuid(b188e659-5685-4e05-bdba-fc640e0f1992), object, pointer_default(unique)] +interface ICoreWebView2Profile3 : ICoreWebView2Profile2 { + /// Gets the `PreferredTrackingPreventionLevel` property. + [propget] HRESULT PreferredTrackingPreventionLevel([out, retval] COREWEBVIEW2_TRACKING_PREVENTION_LEVEL* value); + + + /// The `PreferredTrackingPreventionLevel` property allows you to control levels of tracking prevention for WebView2 + /// which are associated with a profile. This level would apply to the context of the profile. That is, all WebView2s + /// sharing the same profile will be affected and also the value is persisted in the user data folder. + /// + /// See `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL` for descriptions of levels. + /// + /// If tracking prevention feature is enabled when creating the WebView2 environment, you can also disable tracking + /// prevention later using this property and `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_NONE` value but that doesn't + /// improves runtime performance. + /// + /// There is `ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention` property to enable/disable tracking prevention feature + /// for all the WebView2's created in the same environment. If enabled, `PreferredTrackingPreventionLevel` is set to + /// `COREWEBVIEW2_TRACKING_PREVENTION_LEVEL_BALANCED` by default for all the WebView2's and profiles created in the same + /// environment or is set to the level whatever value was last changed/persisted to the profile. If disabled + /// `PreferredTrackingPreventionLevel` is not respected by WebView2. If `PreferredTrackingPreventionLevel` is set when the + /// feature is disabled, the property value get changed and persisted but it will takes effect only if + /// `ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention` is true. + /// + /// See `ICoreWebView2EnvironmentOptions5::EnableTrackingPrevention` for more details. + /// \snippet SettingsComponent.cpp SetTrackingPreventionLevel + [propput] HRESULT PreferredTrackingPreventionLevel([in] COREWEBVIEW2_TRACKING_PREVENTION_LEVEL value); + + + +} + + +/// Receives the result of the `SetPermissionState` method. +[uuid(fc77fb30-9c9e-4076-b8c7-7644a703ca1b), object, pointer_default(unique)] +interface ICoreWebView2SetPermissionStateCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} +/// Receives the result of the `GetNonDefaultPermissionSettings` method. +[uuid(38274481-a15c-4563-94cf-990edc9aeb95), object, pointer_default(unique)] +interface ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2PermissionSettingCollectionView* result); +} + + +/// This is the ICoreWebView2Profile interface for the permission management APIs. +[uuid(8f4ae680-192e-4ec8-833a-21cfadaef628), object, pointer_default(unique)] +interface ICoreWebView2Profile4 : ICoreWebView2Profile3 { + /// Sets permission state for the given permission kind and origin + /// asynchronously. The change persists across sessions until it is changed by + /// another call to `SetPermissionState`, or by setting the `State` property + /// in `PermissionRequestedEventArgs`. Setting the state to + /// `COREWEBVIEW2_PERMISSION_STATE_DEFAULT` will erase any state saved in the + /// profile and restore the default behavior. + /// The origin should have a valid scheme and host (e.g. "https://www.example.com"), + /// otherwise the method fails with `E_INVALIDARG`. Additional URI parts like + /// path and fragment are ignored. For example, "https://wwww.example.com/app1/index.html/" + /// is treated the same as "https://wwww.example.com". See the + /// [MDN origin definition](https://developer.mozilla.org/docs/Glossary/Origin) + /// for more details. + /// + /// \snippet ScenarioPermissionManagement.cpp SetPermissionState + HRESULT SetPermissionState( + [in] COREWEBVIEW2_PERMISSION_KIND PermissionKind, + [in] LPCWSTR origin, + [in] COREWEBVIEW2_PERMISSION_STATE State + , [in] ICoreWebView2SetPermissionStateCompletedHandler* handler); + + /// Invokes the handler with a collection of all nondefault permission settings. + /// Use this method to get the permission state set in the current and previous + /// sessions. + /// + /// \snippet ScenarioPermissionManagement.cpp GetNonDefaultPermissionSettings + HRESULT GetNonDefaultPermissionSettings( + [in] ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler* handler); + + +} + + + +/// This is the ICoreWebView2Profile interface for cookie manager. +[uuid(2ee5b76e-6e80-4df2-bcd3-d4ec3340a01b), object, pointer_default(unique)] +interface ICoreWebView2Profile5 : ICoreWebView2Profile4 { + /// Get the cookie manager for the profile. All CoreWebView2s associated with this + /// profile share the same cookie values. Changes to cookies in this cookie manager apply to all + /// CoreWebView2s associated with this profile. + /// See ICoreWebView2CookieManager. + /// + /// \snippet ScenarioCookieManagement.cpp CookieManagerProfile + [propget] HRESULT CookieManager([out, retval] ICoreWebView2CookieManager** value); + + + +} + + +/// Receives the result of the `AddBrowserExtension` method. +[uuid(df1aab27-82b9-4ab6-aae8-017a49398c14), object, pointer_default(unique)] +interface ICoreWebView2ProfileAddBrowserExtensionCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2BrowserExtension* result); +} +/// Receives the result of the `GetBrowserExtensions` method. +[uuid(fce16a1c-f107-4601-8b75-fc4940ae25d0), object, pointer_default(unique)] +interface ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2BrowserExtensionList* result); +} + +/// A collection of ICoreWebView2BrowserExtension. +[uuid(2ef3d2dc-bd5f-4f4d-90af-fd67798f0c2f), object, pointer_default(unique)] +interface ICoreWebView2BrowserExtensionList : IUnknown { + /// The number of elements contained in the collection. + [propget] HRESULT Count([out, retval] UINT32* value); + + /// Gets the element at the given index. + HRESULT GetValueAtIndex([in] UINT32 index, [out, retval] ICoreWebView2BrowserExtension** value); +} + + +/// Interfaces in profile for managing browser extensions. +[uuid(7b4c7906-a1aa-4cb4-b723-db09f813d541), object, pointer_default(unique)] +interface ICoreWebView2Profile7 : ICoreWebView2Profile6 { + /// Adds the [browser extension](https://developer.mozilla.org/docs/Mozilla/Add-ons/WebExtensions) + /// using the extension path for unpacked extensions from the local device. Extension is + /// running right after installation. + /// The extension folder path is the topmost folder of an unpacked browser extension and + /// contains the browser extension manifest file. + /// If the `extensionFolderPath` is an invalid path or doesn't contain the extension manifest.json + /// file, this function will return `ERROR_FILE_NOT_FOUND` to callers. + /// Installed extension will default `IsEnabled` to true. + /// When `AreBrowserExtensionsEnabled` is `FALSE`, `AddBrowserExtension` will fail and return + /// HRESULT `ERROR_NOT_SUPPORTED`. + /// During installation, the content of the extension is not copied to the user data folder. + /// Once the extension is installed, changing the content of the extension will cause the + /// extension to be removed from the installed profile. + /// When an extension is added the extension is persisted in the corresponding profile. The + /// extension will still be installed the next time you use this profile. + /// When an extension is installed from a folder path, adding the same extension from the same + /// folder path means reinstalling this extension. When two extensions with the same Id are + /// installed, only the later installed extension will be kept. + /// + /// Extensions that are designed to include any UI interactions (e.g. icon, badge, pop up, etc.) + /// can be loaded and used but will have missing UI entry points due to the lack of browser + /// UI elements to host these entry points in WebView2. + /// + /// The following summarizes the possible error values that can be returned from + /// `AddBrowserExtension` and a description of why these errors occur. + /// + /// Error value | Description + /// ----------------------------------------------- | -------------------------- + /// `HRESULT_FROM_WIN32(ERROR_NOT_SUPPORTED)` | Extensions are disabled. + /// `HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND)` | Cannot find `manifest.json` file or it is not a valid extension manifest. + /// `E_ACCESSDENIED` | Cannot load extension with file or directory name starting with \"_\", reserved for use by the system. + /// `E_FAIL` | Extension failed to install with other unknown reasons. + HRESULT AddBrowserExtension( + [in] LPCWSTR extensionFolderPath + , [in] ICoreWebView2ProfileAddBrowserExtensionCompletedHandler* handler); + + /// Gets a snapshot of the set of extensions installed at the time `GetBrowserExtensions` is + /// called. If an extension is installed or uninstalled after `GetBrowserExtensions` completes, + /// the list returned by `GetBrowserExtensions` remains the same. + /// When `AreBrowserExtensionsEnabled` is `FALSE`, `GetBrowserExtensions` won't return any + /// extensions on current user profile. + HRESULT GetBrowserExtensions( + [in] ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler* handler); + + +} + + + +/// The event args for `SaveFileSecurityCheckStarting` event. +[uuid(cf4ff1d1-5a67-5660-8d63-ef699881ea65), object, pointer_default(unique)] +interface ICoreWebView2SaveFileSecurityCheckStartingEventArgs : IUnknown { + /// Gets the `CancelSave` property. + [propget] HRESULT CancelSave([out, retval] BOOL* value); + + + /// Set if cancel the upcoming save/download. `TRUE` means the action + /// will be cancelled before validations in default policy. + /// + /// The default value is `FALSE`. + [propput] HRESULT CancelSave([in] BOOL value); + + + /// Get the document origin URI of this file save operation. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT DocumentOriginUri([out, retval] LPWSTR* value); + + + /// Get the extension of file to be saved. + /// + /// The file extension is the extension portion of the FilePath, + /// preserving original case. + /// + /// Only final extension with period "." will be provided. For example, + /// "*.tar.gz" is a double extension, where the ".gz" will be its + /// final extension. + /// + /// File extension can be empty, if the file name has no extension + /// at all. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FileExtension([out, retval] LPWSTR* value); + + + /// Get the full path of file to be saved. This includes the + /// file name and extension. + /// + /// This method doesn't provide path validation, the returned + /// string may longer than MAX_PATH. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT FilePath([out, retval] LPWSTR* value); + + + /// Gets the `SuppressDefaultPolicy` property. + [propget] HRESULT SuppressDefaultPolicy([out, retval] BOOL* value); + + + /// Set if the default policy checking and security warning will be + /// suppressed. `TRUE` means it will be suppressed. + /// + /// The default value is `FALSE`. + [propput] HRESULT SuppressDefaultPolicy([in] BOOL value); + + + + /// Returns an `ICoreWebView2Deferral` object. Use this operation to complete + /// the SaveFileSecurityCheckStartingEvent. + /// + /// The default policy checking and any default UI will be blocked temporarily, + /// saving file to local won't start, until the deferral is completed. + HRESULT GetDeferral( + [out, retval] ICoreWebView2Deferral** value); + + +} + + + +/// Event args for the `ScreenCaptureStarting` event. +[uuid(892c03fd-aee3-5eba-a1fa-6fd2f6484b2b), object, pointer_default(unique)] +interface ICoreWebView2ScreenCaptureStartingEventArgs : IUnknown { + /// Gets the `Cancel` property. + [propget] HRESULT Cancel([out, retval] BOOL* value); + + + /// The host may set this flag to cancel the screen capture. If canceled, + /// the screen capture UI is not displayed regardless of the + /// `Handled` property. + /// On the script side, it will return with a NotAllowedError as Permission denied. + [propput] HRESULT Cancel([in] BOOL value); + + + /// Gets the `Handled` property. + [propget] HRESULT Handled([out, retval] BOOL* value); + + + /// By default, both the `ScreenCaptureStarting` event handlers on the + /// `CoreWebView2Frame` and the `CoreWebView2` will be invoked, with the + /// `CoreWebView2Frame` event handlers invoked first. The host may + /// set this flag to `TRUE` within the `CoreWebView2Frame` event handlers + /// to prevent the remaining `CoreWebView2` event handlers from being + /// invoked. If the flag is set to `FALSE` within the `CoreWebView2Frame` + /// event handlers, downstream handlers can update the `Cancel` property. + /// + /// If a deferral is taken on the event args, then you must synchronously + /// set `Handled` to TRUE prior to taking your deferral to prevent the + /// `CoreWebView2`s event handlers from being invoked. + [propput] HRESULT Handled([in] BOOL value); + + + /// The associated frame information that requests the screen capture + /// permission. This can be used to get the frame source, name, frameId, + /// and parent frame information. + [propget] HRESULT OriginalSourceFrameInfo([out, retval] ICoreWebView2FrameInfo** value); + + + + /// Returns an `ICoreWebView2Deferral` object. Use this deferral to + /// defer the decision to show the Screen Capture UI. getDisplayMedia() + /// won't call its callbacks until the deferral is completed. + HRESULT GetDeferral( + [out, retval] ICoreWebView2Deferral** value); + + +} + + + +/// A continuation of the ICoreWebView2Settings interface that manages the user agent. +[uuid(ee9a0f68-f46c-4e32-ac23-ef8cac224d2a), object, pointer_default(unique)] +interface ICoreWebView2Settings2 : ICoreWebView2Settings { + /// Gets the `UserAgent` property. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT UserAgent([out, retval] LPWSTR* value); + + + /// This setting determines the UserAgent of WebView. This property may be overridden if + /// the User-Agent header is set in a request. If the parameter is empty + /// the User Agent will not be updated and the current User Agent will remain. + /// Setting this property may clear User Agent Client Hints headers + /// Sec-CH-UA-* and script values from navigator.userAgentData. Current + /// implementation behavior is subject to change. + /// The User Agent set will also be effective on service workers + /// and shared workers associated with the WebView. If there are + /// multiple WebViews associated with the same service worker or + /// shared worker, the last User Agent set will be used. + /// + /// \snippet SettingsComponent.cpp UserAgent + [propput] HRESULT UserAgent([in] LPCWSTR value); + + + +} + + + +/// A continuation of the ICoreWebView2Settings interface that manages whether +/// browser accelerator keys are enabled. +[uuid(fdb5ab74-af33-4854-84f0-0a631deb5eba), object, pointer_default(unique)] +interface ICoreWebView2Settings3 : ICoreWebView2Settings2 { + /// Gets the `AreBrowserAcceleratorKeysEnabled` property. + [propget] HRESULT AreBrowserAcceleratorKeysEnabled([out, retval] BOOL* value); + + + /// When this setting is set to FALSE, it disables all accelerator keys that + /// access features specific to a web browser, including but not limited to: + /// - Ctrl-F and F3 for Find on Page + /// - Ctrl-P for Print + /// - Ctrl-R and F5 for Reload + /// - Ctrl-Plus and Ctrl-Minus for zooming + /// - Ctrl-Shift-C and F12 for DevTools + /// - Special keys for browser functions, such as Back, Forward, and Search + /// + /// It does not disable accelerator keys related to movement and text editing, + /// such as: + /// - Home, End, Page Up, and Page Down + /// - Ctrl-X, Ctrl-C, Ctrl-V + /// - Ctrl-A for Select All + /// - Ctrl-Z for Undo + /// + /// Those accelerator keys will always be enabled unless they are handled in + /// the `AcceleratorKeyPressed` event. + /// + /// This setting has no effect on the `AcceleratorKeyPressed` event. The event + /// will be fired for all accelerator keys, whether they are enabled or not. + /// + /// The default value for `AreBrowserAcceleratorKeysEnabled` is TRUE. + /// + /// \snippet SettingsComponent.cpp AreBrowserAcceleratorKeysEnabled + [propput] HRESULT AreBrowserAcceleratorKeysEnabled([in] BOOL value); + + + +} + + + +/// A continuation of the ICoreWebView2Settings interface to manage pinch zoom. +[uuid(183e7052-1d03-43a0-ab99-98e043b66b39), object, pointer_default(unique)] +interface ICoreWebView2Settings5 : ICoreWebView2Settings4 { + /// Gets the `IsPinchZoomEnabled` property. + [propget] HRESULT IsPinchZoomEnabled([out, retval] BOOL* value); + + + /// Pinch-zoom, referred to as "Page Scale" zoom, is performed as a post-rendering step, + /// it changes the page scale factor property and scales the surface the web page is + /// rendered onto when user performs a pinch zooming action. It does not change the layout + /// but rather changes the viewport and clips the web content, the content outside of the + /// viewport isn't visible onscreen and users can't reach this content using mouse. + /// + /// The `IsPinchZoomEnabled` property enables or disables the ability of + /// the end user to use a pinching motion on touch input enabled devices + /// to scale the web content in the WebView2. It defaults to `TRUE`. + /// When set to `FALSE`, the end user cannot pinch zoom after the next navigation. + /// Disabling/Enabling `IsPinchZoomEnabled` only affects the end user's ability to use + /// pinch motions and does not change the page scale factor. + /// This API only affects the Page Scale zoom and has no effect on the + /// existing browser zoom properties (`IsZoomControlEnabled` and `ZoomFactor`) + /// or other end user mechanisms for zooming. + /// + /// \snippet SettingsComponent.cpp TogglePinchZoomEnabled + [propput] HRESULT IsPinchZoomEnabled([in] BOOL value); + + + +} + + + +/// A continuation of the ICoreWebView2Settings interface to manage swipe navigation. +[uuid(11cb3acd-9bc8-43b8-83bf-f40753714f87), object, pointer_default(unique)] +interface ICoreWebView2Settings6 : ICoreWebView2Settings5 { + /// Gets the `IsSwipeNavigationEnabled` property. + [propget] HRESULT IsSwipeNavigationEnabled([out, retval] BOOL* value); + + + /// The `IsSwipeNavigationEnabled` property enables or disables the ability of the + /// end user to use swiping gesture on touch input enabled devices to + /// navigate in WebView2. It defaults to `TRUE`. + /// + /// When this property is `TRUE`, then all configured navigation gestures are enabled: + /// 1. Swiping left and right to navigate forward and backward is always configured. + /// 2. Swiping down to refresh is off by default and not exposed via our API currently, + /// it requires the "--pull-to-refresh" option to be included in the additional browser + /// arguments to be configured. (See put_AdditionalBrowserArguments.) + /// + /// When set to `FALSE`, the end user cannot swipe to navigate or pull to refresh. + /// This API only affects the overscrolling navigation functionality and has no + /// effect on the scrolling interaction used to explore the web content shown + /// in WebView2. + /// + /// Disabling/Enabling IsSwipeNavigationEnabled takes effect after the + /// next navigation. + /// + /// \snippet SettingsComponent.cpp ToggleSwipeNavigationEnabled + [propput] HRESULT IsSwipeNavigationEnabled([in] BOOL value); + + + +} + + + +/// A continuation of the ICoreWebView2Settings interface to hide Pdf toolbar items. +[uuid(488dc902-35ef-42d2-bc7d-94b65c4bc49c), object, pointer_default(unique)] +interface ICoreWebView2Settings7 : ICoreWebView2Settings6 { + /// Gets the `HiddenPdfToolbarItems` property. + [propget] HRESULT HiddenPdfToolbarItems([out, retval] COREWEBVIEW2_PDF_TOOLBAR_ITEMS* value); + + + /// `HiddenPdfToolbarItems` is used to customize the PDF toolbar items. By default, it is COREWEBVIEW2_PDF_TOOLBAR_ITEMS_NONE and so it displays all of the items. + /// Changes to this property apply to all CoreWebView2s in the same environment and using the same profile. + /// Changes to this setting apply only after the next navigation. + /// \snippet SettingsComponent.cpp ToggleHidePdfToolbarItems + [propput] HRESULT HiddenPdfToolbarItems([in] COREWEBVIEW2_PDF_TOOLBAR_ITEMS value); + + + +} + + + +/// A continuation of the ICoreWebView2Settings interface to manage smartscreen. +[uuid(9e6b0e8f-86ad-4e81-8147-a9b5edb68650), object, pointer_default(unique)] +interface ICoreWebView2Settings8 : ICoreWebView2Settings7 { + /// Gets the `IsReputationCheckingRequired` property. + [propget] HRESULT IsReputationCheckingRequired([out, retval] BOOL* value); + + + /// SmartScreen helps webviews identify reported phishing and malware websites + /// and also helps users make informed decisions about downloads. + /// `IsReputationCheckingRequired` is used to control whether SmartScreen + /// enabled or not. SmartScreen is enabled or disabled for all CoreWebView2s + /// using the same user data folder. If + /// CoreWebView2Setting.IsReputationCheckingRequired is true for any + /// CoreWebView2 using the same user data folder, then SmartScreen is enabled. + /// If CoreWebView2Setting.IsReputationCheckingRequired is false for all + /// CoreWebView2 using the same user data folder, then SmartScreen is + /// disabled. When it is changed, the change will be applied to all WebViews + /// using the same user data folder on the next navigation or download. The + /// default value for `IsReputationCheckingRequired` is true. If the newly + /// created CoreWebview2 does not set SmartScreen to false, when + /// navigating(Such as Navigate(), LoadDataUrl(), ExecuteScript(), etc.), the + /// default value will be applied to all CoreWebview2 using the same user data + /// folder. + /// SmartScreen of WebView2 apps can be controlled by Windows system setting + /// "SmartScreen for Microsoft Edge", specially, for WebView2 in Windows + /// Store apps, SmartScreen is controlled by another Windows system setting + /// "SmartScreen for Microsoft Store apps". When the Windows setting is enabled, the + /// SmartScreen operates under the control of the `IsReputationCheckingRequired`. + /// When the Windows setting is disabled, the SmartScreen will be disabled + /// regardless of the `IsReputationCheckingRequired` value set in WebView2 apps. + /// In other words, under this circumstance the value of + /// `IsReputationCheckingRequired` will be saved but overridden by system setting. + /// Upon re-enabling the Windows setting, the CoreWebview2 will reference the + /// `IsReputationCheckingRequired` to determine the SmartScreen status. + /// \snippet SettingsComponent.cpp ToggleSmartScreen + [propput] HRESULT IsReputationCheckingRequired([in] BOOL value); + + + +} + + + +/// This is the ICoreWebView2Settings Experimental Interface. +[uuid(0528a73b-e92d-49f4-927a-e547dddaa37d), object, pointer_default(unique)] +interface ICoreWebView2Settings9 : ICoreWebView2Settings8 { + /// Gets the `IsNonClientRegionSupportEnabled` property. + [propget] HRESULT IsNonClientRegionSupportEnabled([out, retval] BOOL* value); + + + /// The `IsNonClientRegionSupportEnabled` property enables web pages to use the + /// `app-region` CSS style. Disabling/Enabling the `IsNonClientRegionSupportEnabled` + /// takes effect after the next navigation. Defaults to `FALSE`. + /// + /// When this property is `TRUE`, then all the non-client region features + /// will be enabled: + /// Draggable Regions will be enabled, they are regions on a webpage that + /// are marked with the CSS attribute `app-region: drag/no-drag`. When set to + /// `drag`, these regions will be treated like the window's title bar, supporting + /// dragging of the entire WebView and its host app window; the system menu shows + /// upon right click, and a double click will trigger maximizing/restoration of the + /// window size. + /// + /// When set to `FALSE`, all non-client region support will be disabled. + /// The `app-region` CSS style will be ignored on web pages. + /// \snippet SettingsComponent.cpp ToggleNonClientRegionSupportEnabled + [propput] HRESULT IsNonClientRegionSupportEnabled([in] BOOL value); + + + +} + + + +/// Event args for the `SourceChanged` event. +[uuid(31e0e545-1dba-4266-8914-f63848a1f7d7), object, pointer_default(unique)] +interface ICoreWebView2SourceChangedEventArgs : IUnknown { + /// `TRUE` if the page being navigated to is a new document. + [propget] HRESULT IsNewDocument([out, retval] BOOL* value); + + + +} + + + +/// Event args for the `WebMessageReceived` event. +[uuid(0f99a40c-e962-4207-9e92-e3d542eff849), object, pointer_default(unique)] +interface ICoreWebView2WebMessageReceivedEventArgs : IUnknown { + /// The URI of the document that sent this web message. + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT Source([out, retval] LPWSTR* value); + + + /// The message posted from the WebView content to the host converted to a + /// JSON string. Run this operation to communicate using JavaScript objects. + /// + /// For example, the following `postMessage` runs result in the following + /// `WebMessageAsJson` values. + /// + /// ```json + /// postMessage({'a': 'b'}) L"{\"a\": \"b\"}" + /// postMessage(1.2) L"1.2" + /// postMessage('example') L"\"example\"" + /// ``` + /// + /// The caller must free the returned string with `CoTaskMemFree`. See + /// [API Conventions](/microsoft-edge/webview2/concepts/win32-api-conventions#strings). + [propget] HRESULT WebMessageAsJson([out, retval] LPWSTR* value); + + + + /// If the message posted from the WebView content to the host is a string + /// type, this method returns the value of that string. If the message + /// posted is some other kind of JavaScript type this method fails with the + /// following error. + /// + /// ```text + /// E_INVALIDARG + /// ``` + /// + /// Run this operation to communicate using simple strings. + /// + /// For example, the following `postMessage` runs result in the following + /// `WebMessageAsString` values. + /// + /// ```json + /// postMessage({'a': 'b'}) E_INVALIDARG + /// postMessage(1.2) E_INVALIDARG + /// postMessage('example') L"example" + /// ``` + HRESULT TryGetWebMessageAsString( + [out, retval] LPWSTR* value); + + +} + + + +/// Extension of WebMessageReceivedEventArgs to provide access to additional +/// WebMessage objects. +[uuid(06fc7ab7-c90c-4297-9389-33ca01cf6d5e), object, pointer_default(unique)] +interface ICoreWebView2WebMessageReceivedEventArgs2 : ICoreWebView2WebMessageReceivedEventArgs { + /// Additional received WebMessage objects. To pass `additionalObjects` via + /// WebMessage to the app, use the + /// `chrome.webview.postMessageWithAdditionalObjects` content API. + /// Any DOM object type that can be natively representable that has been + /// passed in to `additionalObjects` parameter will be accessible here. + /// Currently a WebMessage object can be the `ICoreWebView2File` type. + /// Entries in the collection can be `nullptr` if `null` or `undefined` was + /// passed. + [propget] HRESULT AdditionalObjects([out, retval] ICoreWebView2ObjectCollectionView** value); + + + +} + + + +/// Event args for the `WebResourceRequested` event. +[uuid(9c562c24-b219-4d7f-92f6-b187fbbadd56), object, pointer_default(unique)] +interface ICoreWebView2WebResourceRequestedEventArgs2 : ICoreWebView2WebResourceRequestedEventArgs { + /// The web resource requested source. + [propget] HRESULT RequestedSourceKind([out, retval] COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS* value); + + + +} + + + +/// Event args for the WebResourceResponseReceived event. +[uuid(d1db483d-6796-4b8b-80fc-13712bb716f4), object, pointer_default(unique)] +interface ICoreWebView2WebResourceResponseReceivedEventArgs : IUnknown { + /// The request object for the web resource, as committed. This includes + /// headers added by the network stack that were not be included during the + /// associated WebResourceRequested event, such as Authentication headers. + /// Modifications to this object have no effect on how the request is + /// processed as it has already been sent. + [propget] HRESULT Request([out, retval] ICoreWebView2WebResourceRequest** value); + + + /// View of the response object received for the web resource. + [propget] HRESULT Response([out, retval] ICoreWebView2WebResourceResponseView** value); + + + +} + + +/// Receives `BasicAuthenticationRequested` events. +[uuid(58b4d6c2-18d4-497e-b39b-9a96533fa278), object, pointer_default(unique)] +interface ICoreWebView2BasicAuthenticationRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2BasicAuthenticationRequestedEventArgs* args); +} + + +/// This interface is an extension of `ICoreWebView2_9` that supports +/// BasicAuthenticationRequested event. +[uuid(b1690564-6f5a-4983-8e48-31d1143fecdb), object, pointer_default(unique)] +interface ICoreWebView2_10 : ICoreWebView2_9 { + /// Adds an event handler for the `BasicAuthenticationRequested` event. + /// Add an event handler for the BasicAuthenticationRequested event. + /// BasicAuthenticationRequested event is raised when WebView encounters a + /// Basic HTTP Authentication request as described in + /// https://developer.mozilla.org/docs/Web/HTTP/Authentication, a Digest + /// HTTP Authentication request as described in + /// https://developer.mozilla.org/docs/Web/HTTP/Headers/Authorization#digest, + /// an NTLM authentication or a Proxy Authentication request. + /// + /// The host can provide a response with credentials for the authentication or + /// cancel the request. If the host sets the Cancel property to false but does not + /// provide either UserName or Password properties on the Response property, then + /// WebView2 will show the default authentication challenge dialog prompt to + /// the user. + /// + /// \snippet ScenarioAuthentication.cpp BasicAuthenticationRequested + HRESULT add_BasicAuthenticationRequested( + [in] ICoreWebView2BasicAuthenticationRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_BasicAuthenticationRequested`. + HRESULT remove_BasicAuthenticationRequested( + [in] EventRegistrationToken token); + + +} + + + +/// This interface is an extension of `ICoreWebView2_12` that supports Profile +/// API. +[uuid(f75f09a8-667e-4983-88d6-c8773f315e84), object, pointer_default(unique)] +interface ICoreWebView2_13 : ICoreWebView2_12 { + /// The associated `ICoreWebView2Profile` object. If this CoreWebView2 was created with a + /// CoreWebView2ControllerOptions, the CoreWebView2Profile will match those specified options. + /// Otherwise if this CoreWebView2 was created without a CoreWebView2ControllerOptions, then + /// this will be the default CoreWebView2Profile for the corresponding CoreWebView2Environment. + /// + /// \snippet AppWindow.cpp CoreWebView2Profile + [propget] HRESULT Profile([out, retval] ICoreWebView2Profile** value); + + + +} + + +/// Receives the result of the `ClearServerCertificateErrorActions` method. +[uuid(3b40aac6-acfe-4ffd-8211-f607b96e2d5b), object, pointer_default(unique)] +interface ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode); +} + +/// Receives `ServerCertificateErrorDetected` events. +[uuid(969b3a26-d85e-4795-8199-fef57344da22), object, pointer_default(unique)] +interface ICoreWebView2ServerCertificateErrorDetectedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ServerCertificateErrorDetectedEventArgs* args); +} + + +/// This interface is an extension of `ICoreWebView2_13` that adds +/// ServerCertificate support. +[uuid(6daa4f10-4a90-4753-8898-77c5df534165), object, pointer_default(unique)] +interface ICoreWebView2_14 : ICoreWebView2_13 { + /// Adds an event handler for the `ServerCertificateErrorDetected` event. + /// Add an event handler for the ServerCertificateErrorDetected event. + /// The ServerCertificateErrorDetected event is raised when the WebView2 + /// cannot verify server's digital certificate while loading a web page. + /// + /// This event will raise for all web resources and follows the `WebResourceRequested` event. + /// + /// If you don't handle the event, WebView2 will show the default TLS interstitial error page to the user + /// for navigations, and for non-navigations the web request is cancelled. + /// + /// Note that WebView2 before raising `ServerCertificateErrorDetected` raises a `NavigationCompleted` event + /// with `IsSuccess` as FALSE and any of the below WebErrorStatuses that indicate a certificate failure. + /// + /// - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_COMMON_NAME_IS_INCORRECT + /// - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_EXPIRED + /// - COREWEBVIEW2_WEB_ERROR_STATUS_CLIENT_CERTIFICATE_CONTAINS_ERRORS + /// - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_REVOKED + /// - COREWEBVIEW2_WEB_ERROR_STATUS_CERTIFICATE_IS_INVALID + /// + /// For more details see `ICoreWebView2NavigationCompletedEventArgs::get_IsSuccess` and handle + /// ServerCertificateErrorDetected event or show the default TLS interstitial error page to the user + /// according to the app needs. + /// + /// WebView2 caches the response when action is `COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION_ALWAYS_ALLOW` + /// for the RequestUri's host and the server certificate in the session and the `ServerCertificateErrorDetected` + /// event won't be raised again. + /// + /// To raise the event again you must clear the cache using `ClearServerCertificateErrorActions`. + /// + /// \snippet SettingsComponent.cpp ServerCertificateErrorDetected1 + HRESULT add_ServerCertificateErrorDetected( + [in] ICoreWebView2ServerCertificateErrorDetectedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_ServerCertificateErrorDetected`. + HRESULT remove_ServerCertificateErrorDetected( + [in] EventRegistrationToken token); + + + /// Clears all cached decisions to proceed with TLS certificate errors from the + /// ServerCertificateErrorDetected event for all WebView2's sharing the same session. + HRESULT ClearServerCertificateErrorActions( + [in] ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler* handler); + + +} + + + +/// This interface is an extension of `ICoreWebView2_16` that supports shared buffer based on file mapping. +[uuid(702e75d4-fd44-434d-9d70-1a68a6b1192a), object, pointer_default(unique)] +interface ICoreWebView2_17 : ICoreWebView2_16 { + /// Share a shared buffer object with script of the main frame in the WebView. + /// The script will receive a `sharedbufferreceived` event from chrome.webview. + /// The event arg for that event will have the following methods and properties: + /// `getBuffer()`: return an ArrayBuffer object with the backing content from the shared buffer. + /// `additionalData`: an object as the result of parsing `additionalDataAsJson` as JSON string. + /// This property will be `undefined` if `additionalDataAsJson` is nullptr or empty string. + /// `source`: with a value set as `chrome.webview` object. + /// If a string is provided as `additionalDataAsJson` but it is not a valid JSON string, + /// the API will fail with `E_INVALIDARG`. + /// If `access` is COREWEBVIEW2_SHARED_BUFFER_ACCESS_READ_ONLY, the script will only have read access to the buffer. + /// If the script tries to modify the content in a read only buffer, it will cause an access + /// violation in WebView renderer process and crash the renderer process. + /// If the shared buffer is already closed, the API will fail with `RO_E_CLOSED`. + /// + /// The script code should call `chrome.webview.releaseBuffer` with + /// the shared buffer as the parameter to release underlying resources as soon + /// as it does not need access to the shared buffer any more. + /// + /// The application can post the same shared buffer object to multiple web pages or iframes, or + /// post to the same web page or iframe multiple times. Each `PostSharedBufferToScript` will + /// create a separate ArrayBuffer object with its own view of the memory and is separately + /// released. The underlying shared memory will be released when all the views are released. + /// + /// For example, if we want to send data to script for one time read only consumption. + /// + /// \snippet ScenarioSharedBuffer.cpp OneTimeShareBuffer + /// + /// In the HTML document, + /// + /// \snippet assets\ScenarioSharedBuffer.html ShareBufferScriptCode_1 + /// + /// \snippet assets\ScenarioSharedBuffer.html ShareBufferScriptCode_2 + /// + /// Sharing a buffer to script has security risk. You should only share buffer with trusted site. + /// If a buffer is shared to a untrusted site, possible sensitive information could be leaked. + /// If a buffer is shared as modifiable by the script and the script modifies it in an unexpected way, + /// it could result in corrupted data that might even crash the application. + /// + HRESULT PostSharedBufferToScript( + [in] ICoreWebView2SharedBuffer* sharedBuffer, + [in] COREWEBVIEW2_SHARED_BUFFER_ACCESS access, + [in] LPCWSTR additionalDataAsJson + ); + + +} + + +/// Receives `LaunchingExternalUriScheme` events. +[uuid(74f712e0-8165-43a9-a13f-0cce597e75df), object, pointer_default(unique)] +interface ICoreWebView2LaunchingExternalUriSchemeEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2LaunchingExternalUriSchemeEventArgs* args); +} + + +/// This interface is an extension of `ICoreWebView2_17` that manages +/// navigation requests to URI schemes registered with the OS. +[uuid(7a626017-28be-49b2-b865-3ba2b3522d90), object, pointer_default(unique)] +interface ICoreWebView2_18 : ICoreWebView2_17 { + /// Adds an event handler for the `LaunchingExternalUriScheme` event. + /// Add an event handler for the `LaunchingExternalUriScheme` event. + /// The `LaunchingExternalUriScheme` event is raised when a navigation request is made to + /// a URI scheme that is registered with the OS. + /// The `LaunchingExternalUriScheme` event handler may suppress the default dialog + /// or replace the default dialog with a custom dialog. + /// + /// If a deferral is not taken on the event args, the external URI scheme launch is + /// blocked until the event handler returns. If a deferral is taken, the + /// external URI scheme launch is blocked until the deferral is completed. + /// The host also has the option to cancel the URI scheme launch. + /// + /// The `NavigationStarting` and `NavigationCompleted` events will be raised, + /// regardless of whether the `Cancel` property is set to `TRUE` or + /// `FALSE`. The `NavigationCompleted` event will be raised with the `IsSuccess` property + /// set to `FALSE` and the `WebErrorStatus` property set to `ConnectionAborted` regardless of + /// whether the host sets the `Cancel` property on the + /// `ICoreWebView2LaunchingExternalUriSchemeEventArgs`. The `SourceChanged`, `ContentLoading`, + /// and `HistoryChanged` events will not be raised for this navigation to the external URI + /// scheme regardless of the `Cancel` property. + /// The `LaunchingExternalUriScheme` event will be raised after the + /// `NavigationStarting` event and before the `NavigationCompleted` event. + /// The default `CoreWebView2Settings` will also be updated upon navigation to an external + /// URI scheme. If a setting on the `CoreWebView2Settings` interface has been changed, + /// navigating to an external URI scheme will trigger the `CoreWebView2Settings` to update. + /// + /// The WebView2 may not display the default dialog based on user settings, browser settings, + /// and whether the origin is determined as a + /// [trustworthy origin](https://w3c.github.io/webappsec-secure-contexts# + /// potentially-trustworthy-origin); however, the event will still be raised. + /// + /// If the request is initiated by a cross-origin frame without a user gesture, + /// the request will be blocked and the `LaunchingExternalUriScheme` event will not + /// be raised. + /// \snippet SettingsComponent.cpp ToggleLaunchingExternalUriScheme + HRESULT add_LaunchingExternalUriScheme( + [in] ICoreWebView2LaunchingExternalUriSchemeEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_LaunchingExternalUriScheme`. + HRESULT remove_LaunchingExternalUriScheme( + [in] EventRegistrationToken token); + + +} + + + +/// This interface is an extension of `ICoreWebView2_18` that manages memory usage +/// target level. +[uuid(6921f954-79b0-437f-a997-c85811897c68), object, pointer_default(unique)] +interface ICoreWebView2_19 : ICoreWebView2_18 { + /// Gets the `MemoryUsageTargetLevel` property. + [propget] HRESULT MemoryUsageTargetLevel([out, retval] COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL* value); + + + /// An app may set `MemoryUsageTargetLevel` to indicate desired memory + /// consumption level of WebView. Scripts will not be impacted and continue + /// to run. This is useful for inactive apps that still want to run scripts + /// and/or keep network connections alive and therefore could not call + /// `TrySuspend` and `Resume` to reduce memory consumption. These apps can + /// set memory usage target level to `COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_LOW` + /// when the app becomes inactive, and set back to + /// `COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_NORMAL` when the app becomes + /// active. It is not necessary to set CoreWebView2Controller's IsVisible + /// property to false when setting the property. + /// It is a best effort operation to change memory usage level, and the + /// API will return before the operation completes. + /// Setting the level to `COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_LOW` + /// could potentially cause memory for some WebView browser processes to be + /// swapped out to disk in some circumstances. + /// It is a best effort to reduce memory usage as much as possible. If a script + /// runs after its related memory has been swapped out, the memory will be swapped + /// back in to ensure the script can still run, but performance might be impacted. + /// Therefore, the app should set the level back to + /// `COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL_NORMAL` when the app becomes + /// active again. Setting memory usage target level back to normal will not happen + /// automatically. + /// An app should choose to use either the combination of `TrySuspend` and `Resume` + /// or the combination of setting MemoryUsageTargetLevel to low and normal. It is + /// not advisable to mix them. + /// Trying to set `MemoryUsageTargetLevel` while suspended will be ignored. + /// The `TrySuspend` and `Resume` methods will change the `MemoryUsageTargetLevel`. + /// `TrySuspend` will automatically set `MemoryUsageTargetLevel` to low while + /// `Resume` on suspended WebView will automatically set `MemoryUsageTargetLevel` + /// to normal. Calling `Resume` when the WebView is not suspended would not change + /// `MemoryUsageTargetLevel`. + /// + /// \snippet ViewComponent.cpp MemoryUsageTargetLevel + [propput] HRESULT MemoryUsageTargetLevel([in] COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL value); + + + +} + + + +/// This interface is an extension of `ICoreWebView2_19` that provides the `FrameId` property. +[uuid(b4bc1926-7305-11ee-b962-0242ac120002), object, pointer_default(unique)] +interface ICoreWebView2_20 : ICoreWebView2_19 { + /// The unique identifier of the main frame. It's the same kind of ID as + /// with the `FrameId` in `CoreWebView2Frame` and via `CoreWebView2FrameInfo`. + /// Note that `FrameId` may not be valid if `CoreWebView2` has not done + /// any navigation. It's safe to get this value during or after the first + /// `ContentLoading` event. Otherwise, it could return the invalid frame Id 0. + [propget] HRESULT FrameId([out, retval] UINT32* value); + + + +} + + +/// Receives the result of the `ExecuteScriptWithResult` method. +[uuid(1bb5317b-8238-4c67-a7ff-baf6558f289d), object, pointer_default(unique)] +interface ICoreWebView2ExecuteScriptWithResultCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] ICoreWebView2ExecuteScriptResult* result); +} + + +/// This is the interface for getting string and exception with ExecuteScriptWithResult. +[uuid(c4980dea-587b-43b9-8143-3ef3bf552d95), object, pointer_default(unique)] +interface ICoreWebView2_21 : ICoreWebView2_20 { + /// Run JavaScript code from the JavaScript parameter in the current + /// top-level document rendered in the WebView. + /// The result of the execution is returned asynchronously in the CoreWebView2ExecuteScriptResult object + /// which has methods and properties to obtain the successful result of script execution as well as any + /// unhandled JavaScript exceptions. + /// If this method is + /// run after the NavigationStarting event during a navigation, the script + /// runs in the new document when loading it, around the time + /// ContentLoading is run. This operation executes the script even if + /// ICoreWebView2Settings::IsScriptEnabled is set to FALSE. + /// + /// \snippet ScriptComponent.cpp ExecuteScriptWithResult + HRESULT ExecuteScriptWithResult( + [in] LPCWSTR javaScript + , [in] ICoreWebView2ExecuteScriptWithResultCompletedHandler* handler); + + +} + + + +/// This interface is an extension of `ICoreWebView2` that allows to +/// set filters in order to receive WebResourceRequested events for +/// service workers, shared workers and different origin iframes. +[uuid(db75dfc7-a857-4632-a398-6969dde26c0a), object, pointer_default(unique)] +interface ICoreWebView2_22 : ICoreWebView2_21 { + /// A web resource request with a resource context that matches this + /// filter's resource context and a URI that matches this filter's URI + /// wildcard string for corresponding request sources will be raised via + /// the `WebResourceRequested` event. To receive all raised events filters + /// have to be added before main page navigation. + /// + /// The `uri` parameter value is a wildcard string matched against the URI + /// of the web resource request. This is a glob style + /// wildcard string in which a `*` matches zero or more characters and a `?` + /// matches exactly one character. + /// These wildcard characters can be escaped using a backslash just before + /// the wildcard character in order to represent the literal `*` or `?`. + /// + /// The matching occurs over the URI as a whole string and not limiting + /// wildcard matches to particular parts of the URI. + /// The wildcard filter is compared to the URI after the URI has been + /// normalized, any URI fragment has been removed, and non-ASCII hostnames + /// have been converted to punycode. + /// + /// Specifying a `nullptr` for the uri is equivalent to an empty string which + /// matches no URIs. + /// + /// For more information about resource context filters, navigate to + /// [COREWEBVIEW2_WEB_RESOURCE_CONTEXT](/microsoft-edge/webview2/reference/win32/icorewebview2#corewebview2_web_resource_context). + /// + /// The `requestSourceKinds` is a mask of one or more + /// `COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS`. OR operation(s) can be + /// applied to multiple `COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS` to + /// create a mask representing those data types. API returns `E_INVALIDARG` if + /// `requestSourceKinds` equals to zero. For more information about request + /// source kinds, navigate to + /// [COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS](/microsoft-edge/webview2/reference/win32/icorewebview2#corewebview2_web_resource_request_source_kinds). + /// + /// Because service workers and shared workers run separately from any one + /// HTML document their WebResourceRequested will be raised for all + /// CoreWebView2s that have appropriate filters added in the corresponding + /// CoreWebView2Environment. You should only add a WebResourceRequested filter + /// for COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SERVICE_WORKER or + /// COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS_SHARED_WORKER on + /// one CoreWebView2 to avoid handling the same WebResourceRequested + /// event multiple times. + /// + /// | URI Filter String | Request URI | Match | Notes | + /// | ---- | ---- | ---- | ---- | + /// | `*` | `https://contoso.com/a/b/c` | Yes | A single * will match all URIs | + /// | `*://contoso.com/*` | `https://contoso.com/a/b/c` | Yes | Matches everything in contoso.com across all schemes | + /// | `*://contoso.com/*` | `https://example.com/?https://contoso.com/` | Yes | But also matches a URI with just the same text anywhere in the URI | + /// | `example` | `https://contoso.com/example` | No | The filter does not perform partial matches | + /// | `*example` | `https://contoso.com/example` | Yes | The filter matches across URI parts | + /// | `*example` | `https://contoso.com/path/?example` | Yes | The filter matches across URI parts | + /// | `*example` | `https://contoso.com/path/?query#example` | No | The filter is matched against the URI with no fragment | + /// | `*example` | `https://example` | No | The URI is normalized before filter matching so the actual URI used for comparison is `https://example/` | + /// | `*example/` | `https://example` | Yes | Just like above, but this time the filter ends with a / just like the normalized URI | + /// | `https://xn--qei.example/` | `https://❤.example/` | Yes | Non-ASCII hostnames are normalized to punycode before wildcard comparison | + /// | `https://❤.example/` | `https://xn--qei.example/` | No | Non-ASCII hostnames are normalized to punycode before wildcard comparison | + /// + /// \snippet ScenarioSharedWorkerWRR.cpp WebResourceRequested2 + HRESULT AddWebResourceRequestedFilterWithRequestSourceKinds( + [in] LPCWSTR uri, + [in] COREWEBVIEW2_WEB_RESOURCE_CONTEXT ResourceContext, + [in] COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS requestSourceKinds + ); + + /// Removes a matching WebResource filter that was previously added for the + /// `WebResourceRequested` event. If the same filter was added multiple + /// times, then it must be removed as many times as it was added for the + /// removal to be effective. Returns `E_INVALIDARG` for a filter that was + /// not added or is already removed. + /// If the filter was added for multiple requestSourceKinds and removed just for one of them + /// the filter remains for the non-removed requestSourceKinds. + HRESULT RemoveWebResourceRequestedFilterWithRequestSourceKinds( + [in] LPCWSTR uri, + [in] COREWEBVIEW2_WEB_RESOURCE_CONTEXT ResourceContext, + [in] COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS requestSourceKinds + ); + + +} + + +/// Receives the result of the `ShowSaveAsUI` method. +[uuid(e24b07e3-8169-5c34-994a-7f6478946a3c), object, pointer_default(unique)] +interface ICoreWebView2ShowSaveAsUICompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] COREWEBVIEW2_SAVE_AS_UI_RESULT result); +} + +/// Receives `SaveAsUIShowing` events. +[uuid(6baa177e-3a2e-5ccf-9a13-fad676cd0522), object, pointer_default(unique)] +interface ICoreWebView2SaveAsUIShowingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2SaveAsUIShowingEventArgs* args); +} + + +/// This is the ICoreWebView2_25 interface. +[uuid(b5a86092-df50-5b4f-a17b-6c8f8b40b771), object, pointer_default(unique)] +interface ICoreWebView2_25 : ICoreWebView2_24 { + /// Adds an event handler for the `SaveAsUIShowing` event. + /// This event is raised when save as is triggered, programmatically or manually. + /// + /// \snippet ScenarioSaveAs.cpp ToggleSilent + HRESULT add_SaveAsUIShowing( + [in] ICoreWebView2SaveAsUIShowingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_SaveAsUIShowing`. + HRESULT remove_SaveAsUIShowing( + [in] EventRegistrationToken token); + + + /// Programmatically trigger a Save As action for the currently loaded document. + /// The `SaveAsUIShowing` event is raised. + /// + /// Opens a system modal dialog by default. If the `SuppressDefaultDialog` property + /// is `TRUE`, the system dialog is not opened. + /// + /// This method returns `COREWEBVIEW2_SAVE_AS_UI_RESULT`. See + /// `COREWEBVIEW2_SAVE_AS_UI_RESULT` for details. + /// + /// \snippet ScenarioSaveAs.cpp ProgrammaticSaveAs + HRESULT ShowSaveAsUI( + [in] ICoreWebView2ShowSaveAsUICompletedHandler* handler); + + +} + + + +/// This is the ICoreWebView_23 interface for +/// PostWebMessageAsJsonWithAdditionalObjects. +[uuid(508f0db5-90c4-5872-90a7-267a91377502), object, pointer_default(unique)] +interface ICoreWebView2_23 : ICoreWebView2_22 { + /// Same as `PostWebMessageAsJson`, but also has support for posting DOM objects + /// to page content. The `additionalObjects` property in the DOM MessageEvent + /// fired on the page content is an array-like list of DOM objects that can + /// be posted to the web content. Currently these can be the following + /// types of objects: + /// + /// | Win32 | DOM type | + /// |-------------------|-------------| + /// | ICoreWebView2FileSystemHandle | [FileSystemHandle](https://developer.mozilla.org/docs/Web/API/FileSystemHandle) | + /// | nullptr | null | + /// The objects are posted to the web content, following the + /// [structured-clone](https://developer.mozilla.org/docs/Web/API/Web_Workers_API/Structured_clone_algorithm) + /// semantics, meaning only objects that can be cloned can be posted. + /// They will also behave as if they had been created by the web content they are + /// posted to. For example, if a FileSystemFileHandle is posted to a web content + /// it can only be re-transferred via postMessage to other web content + /// [with the same origin](https://fs.spec.whatwg.org/#filesystemhandle). + /// Warning: An app needs to be mindful when using this API to post DOM objects + /// as this API provides the web content with unusual access to sensitive Web + /// Platform features such as filesystem access! Similar to PostWebMessageAsJson + /// the app should check the `Source` property of WebView2 right before posting the message + /// to ensure the message and objects will only be sent to the target web content + /// that it expects to receive the DOM objects. Additionally, the order + /// of messages that are posted between `PostWebMessageAsJson` and `PostWebMessageAsJsonWithAdditionalObjects` + /// may not be preserved. + /// \snippet ScenarioFileSystemHandleShare.cpp PostWebMessageWithAdditionalObjects + HRESULT PostWebMessageAsJsonWithAdditionalObjects( + [in] LPCWSTR webMessageAsJson, + [in] ICoreWebView2ObjectCollectionView* additionalObjects + ); + + +} + + +/// Receives `ScreenCaptureStarting` events. +[uuid(e24ff05a-1db5-59d9-89f3-3c864268db4a), object, pointer_default(unique)] +interface ICoreWebView2ScreenCaptureStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ScreenCaptureStartingEventArgs* args); +} + + +/// This interface is an extension of `ICoreWebView2` that supports the ScreenCaptureStarting event. +[uuid(00fbe33b-8c07-517c-aa23-0ddd4b5f6fa0), object, pointer_default(unique)] +interface ICoreWebView2_27 : ICoreWebView2_26 { + /// Adds an event handler for the `ScreenCaptureStarting` event. + /// Add an event handler for the `ScreenCaptureStarting` event. + /// `ScreenCaptureStarting` event is raised when the [Screen Capture API](https://www.w3.org/TR/screen-capture/) + /// is requested by the user using getDisplayMedia(). + /// \snippet ScenarioScreenCapture.cpp ScreenCaptureStarting0 + HRESULT add_ScreenCaptureStarting( + [in] ICoreWebView2ScreenCaptureStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_ScreenCaptureStarting`. + HRESULT remove_ScreenCaptureStarting( + [in] EventRegistrationToken token); + + +} + + + +/// Interface providing methods to access the find session functionalities in the CoreWebView2. +[uuid(62e50381-5bf5-51a8-aae0-f20a3a9c8a90), object, pointer_default(unique)] +interface ICoreWebView2_28 : ICoreWebView2_27 { + /// Retrieves the find session interface for the current web view. + [propget] HRESULT Find([out, retval] ICoreWebView2Find** value); + + + +} + + +/// Receives `SaveFileSecurityCheckStarting` events. +[uuid(7899576c-19e3-57c8-b7d1-55808292de57), object, pointer_default(unique)] +interface ICoreWebView2SaveFileSecurityCheckStartingEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2SaveFileSecurityCheckStartingEventArgs* args); +} + + +/// This is the ICoreWebView2_26 interface. +[uuid(806268b8-f897-5685-88e5-c45fca0b1a48), object, pointer_default(unique)] +interface ICoreWebView2_26 : ICoreWebView2_25 { + /// Adds an event handler for the `SaveFileSecurityCheckStarting` event. + /// This event will be raised during system FileTypePolicy + /// checking the dangerous file extension list. + /// + /// Developers can specify their own logic for determining whether + /// to allow a particular type of file to be saved from the document origin URI. + /// Developers can also determine the save decision based on other criteria. + /// + /// Here are two properties in `ICoreWebView2SaveFileSecurityCheckStartingEventArgs` + /// to manage the decision: `CancelSave` and `SuppressDefaultPolicy`. + /// Table of Properties' value and result: + /// + /// | CancelSave | SuppressDefaultPolicy | Result + /// | ---------- | ------ | --------------------- + /// | False | False | Perform the default policy check. It may show the + /// | | | security warning UI if the file extension is + /// | | | dangerous. + /// | ---------- | ------ | --------------------- + /// | False | True | Skip the default policy check and the possible + /// | | | security warning. Start saving or downloading. + /// | ---------- | ------ | --------------------- + /// | True | Any | Skip the default policy check and the possible + /// | | | security warning. Abort save or download. + /// + /// \snippet ScenarioFileTypePolicy.cpp SuppressPolicyForExtension + HRESULT add_SaveFileSecurityCheckStarting( + [in] ICoreWebView2SaveFileSecurityCheckStartingEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_SaveFileSecurityCheckStarting`. + HRESULT remove_SaveFileSecurityCheckStarting( + [in] EventRegistrationToken token); + + +} + + +/// Receives `NotificationReceived` events. +[uuid(89c5d598-8788-423b-be97-e6e01c0f9ee3), object, pointer_default(unique)] +interface ICoreWebView2NotificationReceivedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2NotificationReceivedEventArgs* args); +} + + +/// This is the ICoreWebView2_24 interface that manages WebView2 Web +/// Notification functionality. +[uuid(39a7ad55-4287-5cc1-88a1-c6f458593824), object, pointer_default(unique)] +interface ICoreWebView2_24 : ICoreWebView2_23 { + /// Adds an event handler for the `NotificationReceived` event. + /// Add an event handler for the `NotificationReceived` event for + /// non-persistent notifications. + /// + /// If a deferral is not taken on the event args, the subsequent scripts after + /// the DOM notification creation call (i.e. `Notification()`) are blocked + /// until the event handler returns. If a deferral is taken, the scripts are + /// blocked until the deferral is completed. + HRESULT add_NotificationReceived( + [in] ICoreWebView2NotificationReceivedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_NotificationReceived`. + HRESULT remove_NotificationReceived( + [in] EventRegistrationToken token); + + +} + + +/// Receives `ClientCertificateRequested` events. +[uuid(d7175ba2-bcc3-11eb-8529-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2ClientCertificateRequestedEventHandler : IUnknown { + /// Provides the event args for the corresponding event. + HRESULT Invoke( + [in] ICoreWebView2* sender, + [in] ICoreWebView2ClientCertificateRequestedEventArgs* args); +} + + +/// A continuation of the ICoreWebView2_4 interface to support ClientCertificateRequested +/// event. +[uuid(bedb11b8-d63c-11eb-b8bc-0242ac130003), object, pointer_default(unique)] +interface ICoreWebView2_5 : ICoreWebView2_4 { + /// Adds an event handler for the `ClientCertificateRequested` event. + /// Add an event handler for the ClientCertificateRequested event. + /// The ClientCertificateRequested event is raised when the WebView2 + /// is making a request to an HTTP server that needs a client certificate + /// for HTTP authentication. + /// Read more about HTTP client certificates at + /// [RFC 8446 The Transport Layer Security (TLS) Protocol Version 1.3](https://tools.ietf.org/html/rfc8446). + /// + /// With this event you have several options for responding to client certificate requests: + /// + /// Scenario | Handled | Cancel | SelectedCertificate + /// ---------------------------------------------------------- | ------- | ------ | ------------------- + /// Respond to server with a certificate | True | False | MutuallyTrustedCertificate value + /// Respond to server without certificate | True | False | null + /// Display default client certificate selection dialog prompt | False | False | n/a + /// Cancel the request | n/a | True | n/a + /// + /// If you don't handle the event, WebView2 will + /// show the default client certificate selection dialog prompt to user. + /// + /// \snippet SettingsComponent.cpp ClientCertificateRequested1 + /// \snippet ScenarioClientCertificateRequested.cpp ClientCertificateRequested2 + HRESULT add_ClientCertificateRequested( + [in] ICoreWebView2ClientCertificateRequestedEventHandler* eventHandler, + [out] EventRegistrationToken* token); + + /// Removes an event handler previously added with `add_ClientCertificateRequested`. + HRESULT remove_ClientCertificateRequested( + [in] EventRegistrationToken token); + + +} + + + +/// This interface is an extension of `ICoreWebView2_5` that manages opening +/// the browser task manager window. +[uuid(499aadac-d92c-4589-8a75-111bfc167795), object, pointer_default(unique)] +interface ICoreWebView2_6 : ICoreWebView2_5 { + /// Opens the Browser Task Manager view as a new window in the foreground. + /// If the Browser Task Manager is already open, this will bring it into + /// the foreground. WebView2 currently blocks the Shift+Esc shortcut for + /// opening the task manager. An end user can open the browser task manager + /// manually via the `Browser task manager` entry of the DevTools window's + /// title bar's context menu. + HRESULT OpenTaskManagerWindow( + ); + + +} + + +/// Receives the result of the `PrintToPdf` method. +[uuid(ccf1ef04-fd8e-4d5f-b2de-0983e41b8c36), object, pointer_default(unique)] +interface ICoreWebView2PrintToPdfCompletedHandler : IUnknown { + + /// Provides the result of the corresponding asynchronous method. + HRESULT Invoke([in] HRESULT errorCode, [in] BOOL result); +} + + +/// This interface is an extension of `ICoreWebView2_6` that supports printing +/// to PDF. +[uuid(79c24d83-09a3-45ae-9418-487f32a58740), object, pointer_default(unique)] +interface ICoreWebView2_7 : ICoreWebView2_6 { + /// Print the current page to PDF asynchronously with the provided settings. + /// See `ICoreWebView2PrintSettings` for description of settings. Passing + /// nullptr for `printSettings` results in default print settings used. + /// + /// Use `resultFilePath` to specify the path to the PDF file. The host should + /// provide an absolute path, including file name. If the path + /// points to an existing file, the file will be overwritten. If the path is + /// not valid, the method fails with `E_INVALIDARG`. + /// + /// The async `PrintToPdf` operation completes when the data has been written + /// to the PDF file. At this time the + /// `ICoreWebView2PrintToPdfCompletedHandler` is invoked. If the + /// application exits before printing is complete, the file is not saved. + /// Only one `Printing` operation can be in progress at a time. If + /// `PrintToPdf` is called while a `PrintToPdf` or `PrintToPdfStream` or `Print` or + /// `ShowPrintUI` job is in progress, the completed handler is immediately invoked + /// with `isSuccessful` set to FALSE. + /// + /// \snippet FileComponent.cpp PrintToPdf + HRESULT PrintToPdf( + [in] LPCWSTR ResultFilePath, + [in] ICoreWebView2PrintSettings* printSettings + , [in] ICoreWebView2PrintToPdfCompletedHandler* handler); + + +} + + + +} From ab1a694dd8e8cb6f1a03b117733d93be55125984 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Sat, 16 May 2026 13:37:48 +1000 Subject: [PATCH 11/13] fix(webview2/scripts): make generator + tests portable on Windows MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Two Windows-side issues surfaced when the Engineer-Windows agent ran the generator's own test suite inside the golden Hyper-V VM: 1. `webview2gen` tests build the CLI with `go build -o webview2gen` and then `exec.Command(bin, ...)` — on Windows `go build` writes `webview2gen.exe` regardless, so the exec.Command misses the binary by name. Mirror the same `.exe` suffix the toolchain does. 2. text/template preserves whatever line endings the template carries. A Windows checkout with core.autocrlf=true converts every `.tmpl` to CRLF, so the emitted Go files become CRLF and diverge from the LF golden files committed in scripts/generator/testfiles/. Strip CR in the writer (runGenerate) and the verifier (runVerify) so the output is deterministic across platforms. Defense in depth: add webview2/.gitattributes forcing LF on `.tmpl`, `.go`, `.go.txt`, `.idl`. This stops the CRLF from entering the checkout in the first place; the generator-side normalisation handles the case where a checkout already has CRLF. Verified on Mac: - `go test ./...` in scripts/ — all green - `webview2gen verify` — 320 files match the committed tree --- webview2/.gitattributes | 10 ++++++++++ webview2/scripts/cmd/webview2gen/main.go | 13 +++++++++++-- webview2/scripts/cmd/webview2gen/main_test.go | 6 ++++++ 3 files changed, 27 insertions(+), 2 deletions(-) create mode 100644 webview2/.gitattributes diff --git a/webview2/.gitattributes b/webview2/.gitattributes new file mode 100644 index 00000000000..0412dd5b73a --- /dev/null +++ b/webview2/.gitattributes @@ -0,0 +1,10 @@ +# Force LF line endings for all webview2 sources, generated bindings, and +# generator fixtures so Windows checkouts with core.autocrlf=true don't +# silently convert templates to CRLF — which makes text/template emit +# CRLF in the bindings, which then diverges from the LF golden files +# committed in scripts/generator/testfiles/. +* text=auto eol=lf +*.tmpl text eol=lf +*.idl text eol=lf +*.go text eol=lf +*.go.txt text eol=lf diff --git a/webview2/scripts/cmd/webview2gen/main.go b/webview2/scripts/cmd/webview2gen/main.go index db47dc94ffb..c6363d96d68 100644 --- a/webview2/scripts/cmd/webview2gen/main.go +++ b/webview2/scripts/cmd/webview2gen/main.go @@ -177,7 +177,7 @@ func runGenerate(args []string) error { } for _, f := range files { path := filepath.Join(*out, f.FileName) - if err := os.WriteFile(path, f.Content.Bytes(), 0o644); err != nil { + if err := os.WriteFile(path, normalizeNewlines(f.Content.Bytes()), 0o644); err != nil { return fmt.Errorf("write %s: %w", path, err) } } @@ -185,6 +185,15 @@ func runGenerate(args []string) error { return nil } +// normalizeNewlines collapses CRLF to LF. text/template preserves whatever +// line endings the template source carried, so on Windows checkouts with +// core.autocrlf=true the templates become CRLF and the emitted Go files +// diverge from the LF golden files committed to the repo. Stripping CR +// in the generator keeps the output deterministic across platforms. +func normalizeNewlines(b []byte) []byte { + return bytes.ReplaceAll(b, []byte("\r\n"), []byte("\n")) +} + // ----------------------------------------------------------------------- // capabilities // ----------------------------------------------------------------------- @@ -298,7 +307,7 @@ func runVerify(args []string) error { diffs = append(diffs, fmt.Sprintf("missing committed file: %s (%v)", path, err)) continue } - if !bytes.Equal(got, f.Content.Bytes()) { + if !bytes.Equal(normalizeNewlines(got), normalizeNewlines(f.Content.Bytes())) { diffs = append(diffs, fmt.Sprintf("changed file: %s", path)) } } diff --git a/webview2/scripts/cmd/webview2gen/main_test.go b/webview2/scripts/cmd/webview2gen/main_test.go index 1d6fddc5f30..fa8e19ba0b4 100644 --- a/webview2/scripts/cmd/webview2gen/main_test.go +++ b/webview2/scripts/cmd/webview2gen/main_test.go @@ -8,6 +8,7 @@ import ( "os" "os/exec" "path/filepath" + "runtime" "strings" "testing" @@ -19,6 +20,11 @@ import ( func buildBinary(t *testing.T) string { t.Helper() bin := filepath.Join(t.TempDir(), "webview2gen") + // `go build -o ` on Windows writes .exe regardless of the + // requested name. Mirror that so exec.Command finds the right file. + if runtime.GOOS == "windows" { + bin += ".exe" + } cmd := exec.Command("go", "build", "-o", bin, ".") out, err := cmd.CombinedOutput() if err != nil { From a71a16f4d84aab6e1fa8cf2ede659ef24c604766 Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Fri, 29 May 2026 12:41:14 +1000 Subject: [PATCH 12/13] fix(webview2/scripts/generator): three runtime bugs in emitted Go bindings MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Engineer-Windows surfaced three generator bugs while smoke-testing pkg/webview2 on the win-node1 VM. Each one produced code that compiled cleanly under `GOOS=windows go vet` but failed at runtime — `go vet` is a syntax/unused-var check, not a behaviour check. All three were fixed at the generator level per the project guidance; no hand-edits to generated code. 1. HWND/HANDLE/HCURSOR as scalars (param.go) These are uintptr aliases in golang.org/x/sys/windows — they're already handle *values*, not pointers to handles. The default branch in processVtableCallInput emitted `uintptr(unsafe.Pointer(&parentWindow))`, which passes a stack-local pointer instead of the handle value. The receiving COM method dereferences this as garbage. Added these three names to the scalar-pass-by-value branch alongside int/uint/float/bool, matching the existing treatment in defaultErrorValue(). 2. syscall.Call third return as err (interfaceMethod.tmpl + SuccessValues) `windows.syscall.Call` returns (r1, r2, lastErr) — lastErr is GetLastError, not the HRESULT, and is non-nil after every call regardless of success. The template bound the third return to `err` and SuccessValues emitted `return ..., err` for the success path, so methods that succeeded surfaced stale Win32 errors from prior unrelated syscalls. Template now uses `_` for the third return; SuccessValues emits `nil`. 3. windows.NewCallback string params (interfaceInvoke.tmpl + interface.go) `windows.NewCallback` panics at init if any callback parameter is wider than a uintptr. Go `string` is a 2-word fat pointer, so any event handler with a string parameter (e.g. AddScriptToExecuteOnDocumentCreatedCompleted's `result LPCWSTR`) was unsafe to register. The Invoke trampoline now accepts `*uint16` for string params and converts to `string` inline via UTF16PtrToString before the impl call. Added InvokeGoInputs, InvokeConversionCode, InvokeInputParamNames methods on InterfaceMethod to drive the new template form. The Impl interface keeps the Go-native `string` signature so callers are unaffected. Generator testfiles updated to match the new emitter. `webview2gen verify` clean (320 files match), `GOOS=windows go vet ./pkg/webview2/` clean, `go test ./...` in scripts/ green. --- .../generator/testfiles/ICoreWebView2.go.txt | 8 +-- ...View2AcceleratorKeyPressedEventArgs.go.txt | 4 +- ...oreWebView2CustomSchemeRegistration.go.txt | 4 +- .../testfiles/ICoreWebView2FrameInfo.go.txt | 8 +-- ...CoreWebView2ProcessFailedEventArgs2.go.txt | 4 +- .../testfiles/ICoreWebView2_3.go.txt | 4 +- webview2/scripts/generator/types/interface.go | 54 ++++++++++++++++++- webview2/scripts/generator/types/param.go | 9 +++- .../types/templates/interfaceInvoke.tmpl | 4 +- .../types/templates/interfaceMethod.tmpl | 2 +- 10 files changed, 80 insertions(+), 21 deletions(-) diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt index 48cf9e7fc4f..89787a6e6b7 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2.go.txt @@ -32,7 +32,7 @@ func (i *ICoreWebView2) AddNavigationStarting(eventHandler *ICoreWebView2Navigat var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNavigationStarting.Call( + hr, _, _ := i.Vtbl.AddNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -40,19 +40,19 @@ func (i *ICoreWebView2) AddNavigationStarting(eventHandler *ICoreWebView2Navigat if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) GetSettings() (*ICoreWebView2Settings, error) { var settings *ICoreWebView2Settings - hr, _, err := i.Vtbl.GetSettings.Call( + hr, _, _ := i.Vtbl.GetSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&settings)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return settings, err + return settings, nil } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt index 97e25484a2a..b24faedfe6f 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2AcceleratorKeyPressedEventArgs.go.txt @@ -31,12 +31,12 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetKeyEventKind() (COREWEB var keyEventKind COREWEBVIEW2_KEY_EVENT_KIND - hr, _, err := i.Vtbl.GetKeyEventKind.Call( + hr, _, _ := i.Vtbl.GetKeyEventKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&keyEventKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return keyEventKind, err + return keyEventKind, nil } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt index 02636061f19..d6ed9a655d8 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2CustomSchemeRegistration.go.txt @@ -43,7 +43,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOrigins } - hr, _, err := i.Vtbl.SetAllowedOrigins.Call( + hr, _, _ := i.Vtbl.SetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(allowedOriginsCount), uintptr(unsafe.Pointer(_allowedOrigins)), @@ -51,5 +51,5 @@ func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOrigins if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt index da52141aa74..5f6700e6e12 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2FrameInfo.go.txt @@ -33,7 +33,7 @@ func (i *ICoreWebView2FrameInfo) GetName() (string, error) { var _name *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_name)), ) @@ -43,7 +43,7 @@ func (i *ICoreWebView2FrameInfo) GetName() (string, error) { // Get result and cleanup name := UTF16PtrToString(_name) CoTaskMemFree(unsafe.Pointer(_name)) - return name, err + return name, nil } func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { @@ -51,7 +51,7 @@ func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { var _source *uint16 - hr, _, err := i.Vtbl.GetSource.Call( + hr, _, _ := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_source)), ) @@ -61,5 +61,5 @@ func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { // Get result and cleanup source := UTF16PtrToString(_source) CoTaskMemFree(unsafe.Pointer(_source)) - return source, err + return source, nil } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt index 715915d2f1e..8db591029c1 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2ProcessFailedEventArgs2.go.txt @@ -46,12 +46,12 @@ func (i *ICoreWebView2ProcessFailedEventArgs2) GetExitCode() (int, error) { var exitCode int - hr, _, err := i.Vtbl.GetExitCode.Call( + hr, _, _ := i.Vtbl.GetExitCode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&exitCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return exitCode, err + return exitCode, nil } diff --git a/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt b/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt index aea387cf462..6a62fc04b5d 100644 --- a/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt +++ b/webview2/scripts/generator/testfiles/ICoreWebView2_3.go.txt @@ -46,7 +46,7 @@ func (i *ICoreWebView2_3) GetIsSuspended() (bool, error) { // Create int32 to hold bool result var _isSuspended int32 - hr, _, err := i.Vtbl.GetIsSuspended.Call( + hr, _, _ := i.Vtbl.GetIsSuspended.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSuspended)), ) @@ -55,5 +55,5 @@ func (i *ICoreWebView2_3) GetIsSuspended() (bool, error) { } // Get result and cleanup isSuspended := _isSuspended != 0 - return isSuspended, err + return isSuspended, nil } diff --git a/webview2/scripts/generator/types/interface.go b/webview2/scripts/generator/types/interface.go index a0d19c385b9..0425d9d1959 100644 --- a/webview2/scripts/generator/types/interface.go +++ b/webview2/scripts/generator/types/interface.go @@ -292,12 +292,64 @@ func (m *InterfaceMethod) GetHResultVariable() string { return "_" } +// InvokeGoInputs renders the parameter list for the C-side trampoline that +// windows.NewCallback wraps. Strings are passed as *uint16 because +// windows.NewCallback panics at init if any parameter is wider than a uintptr +// (Go strings are 2-word fat pointers and slices are 3-word). +func (m *InterfaceMethod) InvokeGoInputs() string { + var inputs slicer.StringSlicer + for _, p := range m.inputParams { + t := p.AsInputType() + if t == "string" { + t = "*uint16" + } + inputs.Add(p.Name + " " + t) + } + return inputs.Join(", ") +} + +// InvokeConversionCode emits the Go statements that convert *uint16 trampoline +// parameters back into Go strings before the impl call. Empty if the Invoke +// method has no string parameters. +func (m *InterfaceMethod) InvokeConversionCode() string { + var buf bytes.Buffer + for _, p := range m.inputParams { + if p.AsInputType() == "string" { + buf.WriteString("\t_") + buf.WriteString(p.Name) + buf.WriteString(" := UTF16PtrToString(") + buf.WriteString(p.Name) + buf.WriteString(")\n") + } + } + return buf.String() +} + +// InvokeInputParamNames is the InputParamNames variant for the Invoke +// trampoline — string params become `_name` (the converted Go string), +// everything else stays as `name`. +func (m *InterfaceMethod) InvokeInputParamNames() string { + var names slicer.StringSlicer + for _, p := range m.inputParams { + name := p.Name + if p.AsInputType() == "string" { + name = "_" + name + } + names.Add(name) + } + return names.Join(", ") +} + func (m *InterfaceMethod) SuccessValues() string { + // The third return from syscall.Call is GetLastError, which is non-nil after + // every call regardless of HRESULT — using it as the method's err return causes + // successful calls to surface stale Win32 errors from prior unrelated syscalls. + // The template binds the third return to `_`; the success path returns nil. var successValues slicer.StringSlicer for _, outputParam := range m.outputParams { successValues.Add(outputParam.GetReturnVariableName()) } - successValues.Add("err") + successValues.Add("nil") return successValues.Join(", ") } diff --git a/webview2/scripts/generator/types/param.go b/webview2/scripts/generator/types/param.go index ce6e9b50323..dd2af402bcf 100644 --- a/webview2/scripts/generator/types/param.go +++ b/webview2/scripts/generator/types/param.go @@ -154,9 +154,16 @@ func (p *Param) processVtableCallInput() { // Scalar numeric / bool inputs: use GoType (handles uppercase IDL names like UINT32, // INT32, BOOL that map to Go uint32, int32, bool). For bool, setup code converts to // int32 first so the local variable is already an int32 and uintptr() is correct. + // + // HWND, HANDLE, HCURSOR are uintptr aliases in golang.org/x/sys/windows — they're + // already handle *values*, not pointers to handles. Passing their address gives a + // stack-local pointer instead of the handle itself, which the receiving COM method + // dereferences as garbage. Match the existing defaultErrorValue() treatment of + // these as scalars. goType := p.GoType if strings.HasPrefix(goType, "int") || strings.HasPrefix(goType, "uint") || - goType == "float32" || goType == "float64" || goType == "bool" { + goType == "float32" || goType == "float64" || goType == "bool" || + goType == "HWND" || goType == "HANDLE" || goType == "HCURSOR" { p.VtableCallInput = "uintptr(" + variableName + ")" return } diff --git a/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl b/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl index e33b981860c..4a1951e6e8d 100644 --- a/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl +++ b/webview2/scripts/generator/types/templates/interfaceInvoke.tmpl @@ -10,8 +10,8 @@ func {{.Declaration.Name}}IUnknownRelease(this *{{.Declaration.Name}}) uintptr { return uintptr(this.impl.Release()) } -func {{.Declaration.Name}}Invoke(this *{{.Declaration.Name}}, {{.InvokeMethod.GoInputs}}) uintptr { - return this.impl.{{.InvokeMethod.GoMethodName}}({{.InvokeMethod.InputParamNames}}) +func {{.Declaration.Name}}Invoke(this *{{.Declaration.Name}}, {{.InvokeMethod.InvokeGoInputs}}) uintptr { +{{.InvokeMethod.InvokeConversionCode}} return this.impl.{{.InvokeMethod.GoMethodName}}({{.InvokeMethod.InvokeInputParamNames}}) } type {{.Declaration.Name}}Impl interface { diff --git a/webview2/scripts/generator/types/templates/interfaceMethod.tmpl b/webview2/scripts/generator/types/templates/interfaceMethod.tmpl index 23e36d8bbf9..8cfcb84c301 100644 --- a/webview2/scripts/generator/types/templates/interfaceMethod.tmpl +++ b/webview2/scripts/generator/types/templates/interfaceMethod.tmpl @@ -2,7 +2,7 @@ func (i *{{.Name}}) {{.Method.ProcessedName}}({{.Method.GoInputs}}) {{.Method.GoReturnTypes}} { {{ .Method.SetupCode}} - {{ .Method.GetHResultVariable }}, _, err := i.Vtbl.{{.Method.ProcessedName}}.Call( + {{ .Method.GetHResultVariable }}, _, _ := i.Vtbl.{{.Method.ProcessedName}}.Call( uintptr(unsafe.Pointer(i)), {{ .Method.VtableCallInputs}} ) From 69b18a218900b87d2f3ac1d26b065358fded16cf Mon Sep 17 00:00:00 2001 From: Lea Anthony Date: Fri, 29 May 2026 12:41:22 +1000 Subject: [PATCH 13/13] chore(webview2): regenerate pkg/webview2 after generator fixes MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Output of `webview2gen generate -dir . -out ../pkg/webview2` after the three generator fixes in the previous commit: - HWND/HANDLE/HCURSOR params now emit `uintptr(x)` instead of `uintptr(unsafe.Pointer(&x))` — fixes silent garbage-handle bugs in every HWND-taking method (e.g. CreateCoreWebView2Controller's parentWindow). - syscall.Call third return is discarded; success path returns nil instead of stale GetLastError — every method that previously returned `..., err` now returns `..., nil` on success. - Invoke trampolines for handlers with string callback parameters now take `*uint16` and convert inline. 191 files changed; no API changes, no new files (the same SDK 1.0.3967.48 output, just emitted with the bug fixes). `webview2gen verify` clean. --- webview2/pkg/webview2/ICoreWebView2.go | 232 +++++++++--------- ...eWebView2AcceleratorKeyPressedEventArgs.go | 24 +- ...WebView2AcceleratorKeyPressedEventArgs2.go | 8 +- ...xecuteOnDocumentCreatedCompletedHandler.go | 5 +- ...w2BasicAuthenticationRequestedEventArgs.go | 24 +- ...CoreWebView2BasicAuthenticationResponse.go | 16 +- .../webview2/ICoreWebView2BrowserExtension.go | 20 +- .../ICoreWebView2BrowserExtensionList.go | 8 +- ...reWebView2BrowserProcessExitedEventArgs.go | 8 +- ...lDevToolsProtocolMethodCompletedHandler.go | 5 +- .../pkg/webview2/ICoreWebView2Certificate.go | 32 +-- .../ICoreWebView2ClientCertificate.go | 36 +-- ...CoreWebView2ClientCertificateCollection.go | 8 +- ...iew2ClientCertificateRequestedEventArgs.go | 48 ++-- .../ICoreWebView2CompositionController.go | 32 +-- .../ICoreWebView2CompositionController2.go | 4 +- .../ICoreWebView2CompositionController3.go | 16 +- .../ICoreWebView2CompositionController4.go | 16 +- .../ICoreWebView2CompositionController5.go | 8 +- .../ICoreWebView2ContentLoadingEventArgs.go | 8 +- .../webview2/ICoreWebView2ContextMenuItem.go | 52 ++-- .../ICoreWebView2ContextMenuItemCollection.go | 16 +- ...reWebView2ContextMenuRequestedEventArgs.go | 32 +-- .../ICoreWebView2ContextMenuTarget.go | 52 ++-- .../pkg/webview2/ICoreWebView2Controller.go | 94 +++---- .../pkg/webview2/ICoreWebView2Controller2.go | 8 +- .../pkg/webview2/ICoreWebView2Controller3.go | 32 +-- .../pkg/webview2/ICoreWebView2Controller4.go | 8 +- .../ICoreWebView2ControllerOptions.go | 16 +- .../ICoreWebView2ControllerOptions2.go | 8 +- .../ICoreWebView2ControllerOptions3.go | 8 +- .../ICoreWebView2ControllerOptions4.go | 8 +- webview2/pkg/webview2/ICoreWebView2Cookie.go | 56 ++--- .../pkg/webview2/ICoreWebView2CookieList.go | 8 +- .../webview2/ICoreWebView2CookieManager.go | 32 +-- .../ICoreWebView2CustomSchemeRegistration.go | 28 +-- .../ICoreWebView2DOMContentLoadedEventArgs.go | 4 +- .../pkg/webview2/ICoreWebView2Deferral.go | 4 +- ...2DevToolsProtocolEventReceivedEventArgs.go | 4 +- ...DevToolsProtocolEventReceivedEventArgs2.go | 4 +- ...reWebView2DevToolsProtocolEventReceiver.go | 8 +- .../ICoreWebView2DownloadOperation.go | 76 +++--- .../ICoreWebView2DownloadStartingEventArgs.go | 32 +-- .../ICoreWebView2DragStartingEventArgs.go | 24 +- .../pkg/webview2/ICoreWebView2Environment.go | 22 +- .../webview2/ICoreWebView2Environment10.go | 16 +- .../webview2/ICoreWebView2Environment11.go | 4 +- .../webview2/ICoreWebView2Environment12.go | 4 +- .../webview2/ICoreWebView2Environment13.go | 4 +- .../webview2/ICoreWebView2Environment14.go | 12 +- .../webview2/ICoreWebView2Environment15.go | 4 +- .../pkg/webview2/ICoreWebView2Environment2.go | 4 +- .../pkg/webview2/ICoreWebView2Environment3.go | 10 +- .../pkg/webview2/ICoreWebView2Environment4.go | 6 +- .../pkg/webview2/ICoreWebView2Environment5.go | 8 +- .../pkg/webview2/ICoreWebView2Environment6.go | 4 +- .../pkg/webview2/ICoreWebView2Environment7.go | 4 +- .../pkg/webview2/ICoreWebView2Environment8.go | 12 +- .../pkg/webview2/ICoreWebView2Environment9.go | 4 +- .../ICoreWebView2EnvironmentOptions.go | 32 +-- .../ICoreWebView2EnvironmentOptions2.go | 8 +- .../ICoreWebView2EnvironmentOptions3.go | 8 +- .../ICoreWebView2EnvironmentOptions4.go | 8 +- .../ICoreWebView2EnvironmentOptions5.go | 8 +- .../ICoreWebView2EnvironmentOptions6.go | 8 +- .../ICoreWebView2EnvironmentOptions7.go | 16 +- .../ICoreWebView2EnvironmentOptions8.go | 8 +- ...reWebView2ExecuteScriptCompletedHandler.go | 5 +- .../ICoreWebView2ExecuteScriptResult.go | 16 +- webview2/pkg/webview2/ICoreWebView2File.go | 4 +- .../webview2/ICoreWebView2FileSystemHandle.go | 12 +- webview2/pkg/webview2/ICoreWebView2Find.go | 40 +-- .../pkg/webview2/ICoreWebView2FindOptions.go | 40 +-- webview2/pkg/webview2/ICoreWebView2Frame.go | 32 +-- webview2/pkg/webview2/ICoreWebView2Frame2.go | 52 ++-- webview2/pkg/webview2/ICoreWebView2Frame3.go | 8 +- webview2/pkg/webview2/ICoreWebView2Frame4.go | 4 +- webview2/pkg/webview2/ICoreWebView2Frame5.go | 4 +- webview2/pkg/webview2/ICoreWebView2Frame6.go | 8 +- webview2/pkg/webview2/ICoreWebView2Frame7.go | 8 +- .../ICoreWebView2FrameCreatedEventArgs.go | 4 +- .../pkg/webview2/ICoreWebView2FrameInfo.go | 8 +- .../pkg/webview2/ICoreWebView2FrameInfo2.go | 12 +- .../ICoreWebView2FrameInfoCollection.go | 4 +- ...CoreWebView2FrameInfoCollectionIterator.go | 12 +- ...reWebView2HttpHeadersCollectionIterator.go | 12 +- .../ICoreWebView2HttpRequestHeaders.go | 24 +- .../ICoreWebView2HttpResponseHeaders.go | 20 +- ...iew2LaunchingExternalUriSchemeEventArgs.go | 24 +- ...CoreWebView2MoveFocusRequestedEventArgs.go | 12 +- ...oreWebView2NavigationCompletedEventArgs.go | 12 +- ...reWebView2NavigationCompletedEventArgs2.go | 4 +- ...CoreWebView2NavigationStartingEventArgs.go | 28 +-- ...oreWebView2NavigationStartingEventArgs2.go | 8 +- ...oreWebView2NavigationStartingEventArgs3.go | 4 +- ...CoreWebView2NewWindowRequestedEventArgs.go | 32 +-- ...oreWebView2NewWindowRequestedEventArgs2.go | 4 +- ...oreWebView2NewWindowRequestedEventArgs3.go | 4 +- ...WebView2NonClientRegionChangedEventArgs.go | 4 +- .../pkg/webview2/ICoreWebView2Notification.go | 72 +++--- ...reWebView2NotificationReceivedEventArgs.go | 20 +- .../webview2/ICoreWebView2ObjectCollection.go | 8 +- .../ICoreWebView2ObjectCollectionView.go | 8 +- ...oreWebView2PermissionRequestedEventArgs.go | 24 +- ...reWebView2PermissionRequestedEventArgs2.go | 8 +- ...reWebView2PermissionRequestedEventArgs3.go | 8 +- .../ICoreWebView2PermissionSetting.go | 12 +- ...WebView2PermissionSettingCollectionView.go | 8 +- .../pkg/webview2/ICoreWebView2PointerInfo.go | 224 ++++++++--------- .../webview2/ICoreWebView2PrintSettings.go | 104 ++++---- .../webview2/ICoreWebView2PrintSettings2.go | 64 ++--- .../ICoreWebView2ProcessExtendedInfo.go | 8 +- ...reWebView2ProcessExtendedInfoCollection.go | 8 +- .../ICoreWebView2ProcessFailedEventArgs.go | 4 +- .../ICoreWebView2ProcessFailedEventArgs2.go | 16 +- .../ICoreWebView2ProcessFailedEventArgs3.go | 4 +- .../pkg/webview2/ICoreWebView2ProcessInfo.go | 8 +- .../ICoreWebView2ProcessInfoCollection.go | 8 +- webview2/pkg/webview2/ICoreWebView2Profile.go | 28 +-- .../pkg/webview2/ICoreWebView2Profile2.go | 12 +- .../pkg/webview2/ICoreWebView2Profile3.go | 8 +- .../pkg/webview2/ICoreWebView2Profile4.go | 8 +- .../pkg/webview2/ICoreWebView2Profile5.go | 4 +- .../pkg/webview2/ICoreWebView2Profile6.go | 16 +- .../pkg/webview2/ICoreWebView2Profile7.go | 8 +- .../pkg/webview2/ICoreWebView2Profile8.go | 12 +- .../ICoreWebView2RegionRectCollectionView.go | 8 +- .../ICoreWebView2SaveAsUIShowingEventArgs.go | 48 ++-- ...2SaveFileSecurityCheckStartingEventArgs.go | 32 +-- ...eWebView2ScreenCaptureStartingEventArgs.go | 24 +- ...oreWebView2ScriptDialogOpeningEventArgs.go | 32 +-- .../webview2/ICoreWebView2ScriptException.go | 20 +- ...ServerCertificateErrorDetectedEventArgs.go | 24 +- .../pkg/webview2/ICoreWebView2Settings.go | 72 +++--- .../pkg/webview2/ICoreWebView2Settings2.go | 8 +- .../pkg/webview2/ICoreWebView2Settings3.go | 8 +- .../pkg/webview2/ICoreWebView2Settings4.go | 16 +- .../pkg/webview2/ICoreWebView2Settings5.go | 8 +- .../pkg/webview2/ICoreWebView2Settings6.go | 8 +- .../pkg/webview2/ICoreWebView2Settings7.go | 8 +- .../pkg/webview2/ICoreWebView2Settings8.go | 8 +- .../pkg/webview2/ICoreWebView2Settings9.go | 8 +- .../pkg/webview2/ICoreWebView2SharedBuffer.go | 20 +- .../ICoreWebView2SourceChangedEventArgs.go | 4 +- .../webview2/ICoreWebView2StringCollection.go | 8 +- ...CoreWebView2WebMessageReceivedEventArgs.go | 12 +- ...oreWebView2WebMessageReceivedEventArgs2.go | 4 +- .../ICoreWebView2WebResourceRequest.go | 28 +-- ...reWebView2WebResourceRequestedEventArgs.go | 20 +- ...eWebView2WebResourceRequestedEventArgs2.go | 4 +- .../ICoreWebView2WebResourceResponse.go | 28 +-- ...ew2WebResourceResponseReceivedEventArgs.go | 8 +- .../ICoreWebView2WebResourceResponseView.go | 16 +- .../webview2/ICoreWebView2WindowFeatures.go | 40 +-- webview2/pkg/webview2/ICoreWebView2_10.go | 8 +- webview2/pkg/webview2/ICoreWebView2_11.go | 12 +- webview2/pkg/webview2/ICoreWebView2_12.go | 12 +- webview2/pkg/webview2/ICoreWebView2_13.go | 4 +- webview2/pkg/webview2/ICoreWebView2_14.go | 12 +- webview2/pkg/webview2/ICoreWebView2_15.go | 16 +- webview2/pkg/webview2/ICoreWebView2_16.go | 12 +- webview2/pkg/webview2/ICoreWebView2_17.go | 4 +- webview2/pkg/webview2/ICoreWebView2_18.go | 8 +- webview2/pkg/webview2/ICoreWebView2_19.go | 8 +- webview2/pkg/webview2/ICoreWebView2_2.go | 28 +-- webview2/pkg/webview2/ICoreWebView2_20.go | 4 +- webview2/pkg/webview2/ICoreWebView2_21.go | 4 +- webview2/pkg/webview2/ICoreWebView2_22.go | 8 +- webview2/pkg/webview2/ICoreWebView2_23.go | 4 +- webview2/pkg/webview2/ICoreWebView2_24.go | 8 +- webview2/pkg/webview2/ICoreWebView2_25.go | 12 +- webview2/pkg/webview2/ICoreWebView2_26.go | 8 +- webview2/pkg/webview2/ICoreWebView2_27.go | 8 +- webview2/pkg/webview2/ICoreWebView2_28.go | 4 +- webview2/pkg/webview2/ICoreWebView2_3.go | 20 +- webview2/pkg/webview2/ICoreWebView2_4.go | 16 +- webview2/pkg/webview2/ICoreWebView2_5.go | 8 +- webview2/pkg/webview2/ICoreWebView2_6.go | 4 +- webview2/pkg/webview2/ICoreWebView2_7.go | 4 +- webview2/pkg/webview2/ICoreWebView2_8.go | 28 +-- webview2/pkg/webview2/ICoreWebView2_9.go | 36 +-- 181 files changed, 1695 insertions(+), 1692 deletions(-) diff --git a/webview2/pkg/webview2/ICoreWebView2.go b/webview2/pkg/webview2/ICoreWebView2.go index 68bf115cd16..a824c1b3d53 100644 --- a/webview2/pkg/webview2/ICoreWebView2.go +++ b/webview2/pkg/webview2/ICoreWebView2.go @@ -88,14 +88,14 @@ func (i *ICoreWebView2) GetSettings() (*ICoreWebView2Settings, error) { var settings *ICoreWebView2Settings - hr, _, err := i.Vtbl.GetSettings.Call( + hr, _, _ := i.Vtbl.GetSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&settings)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return settings, err + return settings, nil } func (i *ICoreWebView2) GetSource() (string, error) { @@ -103,7 +103,7 @@ func (i *ICoreWebView2) GetSource() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetSource.Call( + hr, _, _ := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -113,7 +113,7 @@ func (i *ICoreWebView2) GetSource() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2) Navigate(uri string) error { @@ -124,14 +124,14 @@ func (i *ICoreWebView2) Navigate(uri string) error { return err } - hr, _, err := i.Vtbl.Navigate.Call( + hr, _, _ := i.Vtbl.Navigate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) NavigateToString(htmlContent string) error { @@ -142,21 +142,21 @@ func (i *ICoreWebView2) NavigateToString(htmlContent string) error { return err } - hr, _, err := i.Vtbl.NavigateToString.Call( + hr, _, _ := i.Vtbl.NavigateToString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_htmlContent)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddNavigationStarting(eventHandler *ICoreWebView2NavigationStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNavigationStarting.Call( + hr, _, _ := i.Vtbl.AddNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -164,27 +164,27 @@ func (i *ICoreWebView2) AddNavigationStarting(eventHandler *ICoreWebView2Navigat if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveNavigationStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNavigationStarting.Call( + hr, _, _ := i.Vtbl.RemoveNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddContentLoading(eventHandler *ICoreWebView2ContentLoadingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddContentLoading.Call( + hr, _, _ := i.Vtbl.AddContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -192,27 +192,27 @@ func (i *ICoreWebView2) AddContentLoading(eventHandler *ICoreWebView2ContentLoad if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveContentLoading(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveContentLoading.Call( + hr, _, _ := i.Vtbl.RemoveContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddSourceChanged(eventHandler *ICoreWebView2SourceChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddSourceChanged.Call( + hr, _, _ := i.Vtbl.AddSourceChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -220,27 +220,27 @@ func (i *ICoreWebView2) AddSourceChanged(eventHandler *ICoreWebView2SourceChange if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveSourceChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveSourceChanged.Call( + hr, _, _ := i.Vtbl.RemoveSourceChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddHistoryChanged(eventHandler *ICoreWebView2HistoryChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddHistoryChanged.Call( + hr, _, _ := i.Vtbl.AddHistoryChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -248,27 +248,27 @@ func (i *ICoreWebView2) AddHistoryChanged(eventHandler *ICoreWebView2HistoryChan if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveHistoryChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveHistoryChanged.Call( + hr, _, _ := i.Vtbl.RemoveHistoryChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddNavigationCompleted(eventHandler *ICoreWebView2NavigationCompletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNavigationCompleted.Call( + hr, _, _ := i.Vtbl.AddNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -276,27 +276,27 @@ func (i *ICoreWebView2) AddNavigationCompleted(eventHandler *ICoreWebView2Naviga if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveNavigationCompleted(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNavigationCompleted.Call( + hr, _, _ := i.Vtbl.RemoveNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddFrameNavigationStarting(eventHandler *ICoreWebView2NavigationStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddFrameNavigationStarting.Call( + hr, _, _ := i.Vtbl.AddFrameNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -304,27 +304,27 @@ func (i *ICoreWebView2) AddFrameNavigationStarting(eventHandler *ICoreWebView2Na if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveFrameNavigationStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveFrameNavigationStarting.Call( + hr, _, _ := i.Vtbl.RemoveFrameNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddFrameNavigationCompleted(eventHandler *ICoreWebView2NavigationCompletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddFrameNavigationCompleted.Call( + hr, _, _ := i.Vtbl.AddFrameNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -332,27 +332,27 @@ func (i *ICoreWebView2) AddFrameNavigationCompleted(eventHandler *ICoreWebView2N if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveFrameNavigationCompleted(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveFrameNavigationCompleted.Call( + hr, _, _ := i.Vtbl.RemoveFrameNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddScriptDialogOpening(eventHandler *ICoreWebView2ScriptDialogOpeningEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddScriptDialogOpening.Call( + hr, _, _ := i.Vtbl.AddScriptDialogOpening.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -360,27 +360,27 @@ func (i *ICoreWebView2) AddScriptDialogOpening(eventHandler *ICoreWebView2Script if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveScriptDialogOpening(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveScriptDialogOpening.Call( + hr, _, _ := i.Vtbl.RemoveScriptDialogOpening.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddPermissionRequested(eventHandler *ICoreWebView2PermissionRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddPermissionRequested.Call( + hr, _, _ := i.Vtbl.AddPermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -388,27 +388,27 @@ func (i *ICoreWebView2) AddPermissionRequested(eventHandler *ICoreWebView2Permis if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemovePermissionRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemovePermissionRequested.Call( + hr, _, _ := i.Vtbl.RemovePermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddProcessFailed(eventHandler *ICoreWebView2ProcessFailedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddProcessFailed.Call( + hr, _, _ := i.Vtbl.AddProcessFailed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -416,20 +416,20 @@ func (i *ICoreWebView2) AddProcessFailed(eventHandler *ICoreWebView2ProcessFaile if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveProcessFailed(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveProcessFailed.Call( + hr, _, _ := i.Vtbl.RemoveProcessFailed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddScriptToExecuteOnDocumentCreated(javaScript string, handler *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler) error { @@ -440,7 +440,7 @@ func (i *ICoreWebView2) AddScriptToExecuteOnDocumentCreated(javaScript string, h return err } - hr, _, err := i.Vtbl.AddScriptToExecuteOnDocumentCreated.Call( + hr, _, _ := i.Vtbl.AddScriptToExecuteOnDocumentCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -448,7 +448,7 @@ func (i *ICoreWebView2) AddScriptToExecuteOnDocumentCreated(javaScript string, h if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) RemoveScriptToExecuteOnDocumentCreated(id string) error { @@ -459,14 +459,14 @@ func (i *ICoreWebView2) RemoveScriptToExecuteOnDocumentCreated(id string) error return err } - hr, _, err := i.Vtbl.RemoveScriptToExecuteOnDocumentCreated.Call( + hr, _, _ := i.Vtbl.RemoveScriptToExecuteOnDocumentCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_id)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) ExecuteScript(javaScript string, handler *ICoreWebView2ExecuteScriptCompletedHandler) error { @@ -477,7 +477,7 @@ func (i *ICoreWebView2) ExecuteScript(javaScript string, handler *ICoreWebView2E return err } - hr, _, err := i.Vtbl.ExecuteScript.Call( + hr, _, _ := i.Vtbl.ExecuteScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -485,13 +485,13 @@ func (i *ICoreWebView2) ExecuteScript(javaScript string, handler *ICoreWebView2E if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) CapturePreview(imageFormat COREWEBVIEW2_CAPTURE_PREVIEW_IMAGE_FORMAT, imageStream *IStream, handler *ICoreWebView2CapturePreviewCompletedHandler) error { - hr, _, err := i.Vtbl.CapturePreview.Call( + hr, _, _ := i.Vtbl.CapturePreview.Call( uintptr(unsafe.Pointer(i)), uintptr(imageFormat), uintptr(unsafe.Pointer(imageStream)), @@ -500,19 +500,19 @@ func (i *ICoreWebView2) CapturePreview(imageFormat COREWEBVIEW2_CAPTURE_PREVIEW_ if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) Reload() error { - hr, _, err := i.Vtbl.Reload.Call( + hr, _, _ := i.Vtbl.Reload.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) PostWebMessageAsJson(webMessageAsJson string) error { @@ -523,14 +523,14 @@ func (i *ICoreWebView2) PostWebMessageAsJson(webMessageAsJson string) error { return err } - hr, _, err := i.Vtbl.PostWebMessageAsJson.Call( + hr, _, _ := i.Vtbl.PostWebMessageAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsJson)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) PostWebMessageAsString(webMessageAsString string) error { @@ -541,21 +541,21 @@ func (i *ICoreWebView2) PostWebMessageAsString(webMessageAsString string) error return err } - hr, _, err := i.Vtbl.PostWebMessageAsString.Call( + hr, _, _ := i.Vtbl.PostWebMessageAsString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsString)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddWebMessageReceived(handler *ICoreWebView2WebMessageReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddWebMessageReceived.Call( + hr, _, _ := i.Vtbl.AddWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), uintptr(unsafe.Pointer(&token)), @@ -563,20 +563,20 @@ func (i *ICoreWebView2) AddWebMessageReceived(handler *ICoreWebView2WebMessageRe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveWebMessageReceived(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveWebMessageReceived.Call( + hr, _, _ := i.Vtbl.RemoveWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) CallDevToolsProtocolMethod(methodName string, parametersAsJson string, handler *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler) error { @@ -592,7 +592,7 @@ func (i *ICoreWebView2) CallDevToolsProtocolMethod(methodName string, parameters return err } - hr, _, err := i.Vtbl.CallDevToolsProtocolMethod.Call( + hr, _, _ := i.Vtbl.CallDevToolsProtocolMethod.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_methodName)), uintptr(unsafe.Pointer(_parametersAsJson)), @@ -601,28 +601,28 @@ func (i *ICoreWebView2) CallDevToolsProtocolMethod(methodName string, parameters if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) GetBrowserProcessId() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetBrowserProcessId.Call( + hr, _, _ := i.Vtbl.GetBrowserProcessId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2) GetCanGoBack() (bool, error) { // Create int32 to hold bool result var _canGoBack int32 - hr, _, err := i.Vtbl.GetCanGoBack.Call( + hr, _, _ := i.Vtbl.GetCanGoBack.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_canGoBack)), ) @@ -631,14 +631,14 @@ func (i *ICoreWebView2) GetCanGoBack() (bool, error) { } // Get result and cleanup canGoBack := _canGoBack != 0 - return canGoBack, err + return canGoBack, nil } func (i *ICoreWebView2) GetCanGoForward() (bool, error) { // Create int32 to hold bool result var _canGoForward int32 - hr, _, err := i.Vtbl.GetCanGoForward.Call( + hr, _, _ := i.Vtbl.GetCanGoForward.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_canGoForward)), ) @@ -647,31 +647,31 @@ func (i *ICoreWebView2) GetCanGoForward() (bool, error) { } // Get result and cleanup canGoForward := _canGoForward != 0 - return canGoForward, err + return canGoForward, nil } func (i *ICoreWebView2) GoBack() error { - hr, _, err := i.Vtbl.GoBack.Call( + hr, _, _ := i.Vtbl.GoBack.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) GoForward() error { - hr, _, err := i.Vtbl.GoForward.Call( + hr, _, _ := i.Vtbl.GoForward.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) GetDevToolsProtocolEventReceiver(eventName string) (*ICoreWebView2DevToolsProtocolEventReceiver, error) { @@ -683,7 +683,7 @@ func (i *ICoreWebView2) GetDevToolsProtocolEventReceiver(eventName string) (*ICo } var receiver *ICoreWebView2DevToolsProtocolEventReceiver - hr, _, err := i.Vtbl.GetDevToolsProtocolEventReceiver.Call( + hr, _, _ := i.Vtbl.GetDevToolsProtocolEventReceiver.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_eventName)), uintptr(unsafe.Pointer(&receiver)), @@ -691,26 +691,26 @@ func (i *ICoreWebView2) GetDevToolsProtocolEventReceiver(eventName string) (*ICo if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return receiver, err + return receiver, nil } func (i *ICoreWebView2) Stop() error { - hr, _, err := i.Vtbl.Stop.Call( + hr, _, _ := i.Vtbl.Stop.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddNewWindowRequested(eventHandler *ICoreWebView2NewWindowRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNewWindowRequested.Call( + hr, _, _ := i.Vtbl.AddNewWindowRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -718,27 +718,27 @@ func (i *ICoreWebView2) AddNewWindowRequested(eventHandler *ICoreWebView2NewWind if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveNewWindowRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNewWindowRequested.Call( + hr, _, _ := i.Vtbl.RemoveNewWindowRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddDocumentTitleChanged(eventHandler *ICoreWebView2DocumentTitleChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDocumentTitleChanged.Call( + hr, _, _ := i.Vtbl.AddDocumentTitleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -746,20 +746,20 @@ func (i *ICoreWebView2) AddDocumentTitleChanged(eventHandler *ICoreWebView2Docum if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveDocumentTitleChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDocumentTitleChanged.Call( + hr, _, _ := i.Vtbl.RemoveDocumentTitleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) GetDocumentTitle() (string, error) { @@ -767,7 +767,7 @@ func (i *ICoreWebView2) GetDocumentTitle() (string, error) { var _title *uint16 - hr, _, err := i.Vtbl.GetDocumentTitle.Call( + hr, _, _ := i.Vtbl.GetDocumentTitle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_title)), ) @@ -777,7 +777,7 @@ func (i *ICoreWebView2) GetDocumentTitle() (string, error) { // Get result and cleanup title := UTF16PtrToString(_title) CoTaskMemFree(unsafe.Pointer(_title)) - return title, err + return title, nil } func (i *ICoreWebView2) AddHostObjectToScript(name string, object *VARIANT) error { @@ -788,7 +788,7 @@ func (i *ICoreWebView2) AddHostObjectToScript(name string, object *VARIANT) erro return err } - hr, _, err := i.Vtbl.AddHostObjectToScript.Call( + hr, _, _ := i.Vtbl.AddHostObjectToScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(object)), @@ -796,7 +796,7 @@ func (i *ICoreWebView2) AddHostObjectToScript(name string, object *VARIANT) erro if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) RemoveHostObjectFromScript(name string) error { @@ -807,33 +807,33 @@ func (i *ICoreWebView2) RemoveHostObjectFromScript(name string) error { return err } - hr, _, err := i.Vtbl.RemoveHostObjectFromScript.Call( + hr, _, _ := i.Vtbl.RemoveHostObjectFromScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) OpenDevToolsWindow() error { - hr, _, err := i.Vtbl.OpenDevToolsWindow.Call( + hr, _, _ := i.Vtbl.OpenDevToolsWindow.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddContainsFullScreenElementChanged(eventHandler *ICoreWebView2ContainsFullScreenElementChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddContainsFullScreenElementChanged.Call( + hr, _, _ := i.Vtbl.AddContainsFullScreenElementChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -841,27 +841,27 @@ func (i *ICoreWebView2) AddContainsFullScreenElementChanged(eventHandler *ICoreW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveContainsFullScreenElementChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveContainsFullScreenElementChanged.Call( + hr, _, _ := i.Vtbl.RemoveContainsFullScreenElementChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) GetContainsFullScreenElement() (bool, error) { // Create int32 to hold bool result var _containsFullScreenElement int32 - hr, _, err := i.Vtbl.GetContainsFullScreenElement.Call( + hr, _, _ := i.Vtbl.GetContainsFullScreenElement.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_containsFullScreenElement)), ) @@ -870,14 +870,14 @@ func (i *ICoreWebView2) GetContainsFullScreenElement() (bool, error) { } // Get result and cleanup containsFullScreenElement := _containsFullScreenElement != 0 - return containsFullScreenElement, err + return containsFullScreenElement, nil } func (i *ICoreWebView2) AddWebResourceRequested(eventHandler *ICoreWebView2WebResourceRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddWebResourceRequested.Call( + hr, _, _ := i.Vtbl.AddWebResourceRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -885,20 +885,20 @@ func (i *ICoreWebView2) AddWebResourceRequested(eventHandler *ICoreWebView2WebRe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveWebResourceRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveWebResourceRequested.Call( + hr, _, _ := i.Vtbl.RemoveWebResourceRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddWebResourceRequestedFilter(uri string, resourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT) error { @@ -909,7 +909,7 @@ func (i *ICoreWebView2) AddWebResourceRequestedFilter(uri string, resourceContex return err } - hr, _, err := i.Vtbl.AddWebResourceRequestedFilter.Call( + hr, _, _ := i.Vtbl.AddWebResourceRequestedFilter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(resourceContext), @@ -917,7 +917,7 @@ func (i *ICoreWebView2) AddWebResourceRequestedFilter(uri string, resourceContex if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) RemoveWebResourceRequestedFilter(uri string, resourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT) error { @@ -928,7 +928,7 @@ func (i *ICoreWebView2) RemoveWebResourceRequestedFilter(uri string, resourceCon return err } - hr, _, err := i.Vtbl.RemoveWebResourceRequestedFilter.Call( + hr, _, _ := i.Vtbl.RemoveWebResourceRequestedFilter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(resourceContext), @@ -936,14 +936,14 @@ func (i *ICoreWebView2) RemoveWebResourceRequestedFilter(uri string, resourceCon if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2) AddWindowCloseRequested(eventHandler *ICoreWebView2WindowCloseRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddWindowCloseRequested.Call( + hr, _, _ := i.Vtbl.AddWindowCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -951,18 +951,18 @@ func (i *ICoreWebView2) AddWindowCloseRequested(eventHandler *ICoreWebView2Windo if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2) RemoveWindowCloseRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveWindowCloseRequested.Call( + hr, _, _ := i.Vtbl.RemoveWindowCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go index ef5bd969aba..f36b5f3b37c 100644 --- a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs.go @@ -36,63 +36,63 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetKeyEventKind() (COREWEB var keyEventKind COREWEBVIEW2_KEY_EVENT_KIND - hr, _, err := i.Vtbl.GetKeyEventKind.Call( + hr, _, _ := i.Vtbl.GetKeyEventKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&keyEventKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return keyEventKind, err + return keyEventKind, nil } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetVirtualKey() (uint, error) { var virtualKey uint - hr, _, err := i.Vtbl.GetVirtualKey.Call( + hr, _, _ := i.Vtbl.GetVirtualKey.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&virtualKey)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return virtualKey, err + return virtualKey, nil } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetKeyEventLParam() (int, error) { var lParam int - hr, _, err := i.Vtbl.GetKeyEventLParam.Call( + hr, _, _ := i.Vtbl.GetKeyEventLParam.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&lParam)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return lParam, err + return lParam, nil } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetPhysicalKeyStatus() (COREWEBVIEW2_PHYSICAL_KEY_STATUS, error) { var physicalKeyStatus COREWEBVIEW2_PHYSICAL_KEY_STATUS - hr, _, err := i.Vtbl.GetPhysicalKeyStatus.Call( + hr, _, _ := i.Vtbl.GetPhysicalKeyStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&physicalKeyStatus)), ) if windows.Handle(hr) != windows.S_OK { return COREWEBVIEW2_PHYSICAL_KEY_STATUS{}, syscall.Errno(hr) } - return physicalKeyStatus, err + return physicalKeyStatus, nil } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _handled int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_handled)), ) @@ -101,7 +101,7 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) GetHandled() (bool, error) } // Get result and cleanup handled := _handled != 0 - return handled, err + return handled, nil } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) PutHandled(handled bool) error { @@ -112,12 +112,12 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs) PutHandled(handled bool) e _handled = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_handled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go index 7cf4306bbcd..1741ecf0d0b 100644 --- a/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2AcceleratorKeyPressedEventArgs2.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) GetIsBrowserAcceleratorKe // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsBrowserAcceleratorKeyEnabled.Call( + hr, _, _ := i.Vtbl.GetIsBrowserAcceleratorKeyEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) GetIsBrowserAcceleratorKe } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) PutIsBrowserAcceleratorKeyEnabled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2AcceleratorKeyPressedEventArgs2) PutIsBrowserAcceleratorKe _value = 1 } - hr, _, err := i.Vtbl.PutIsBrowserAcceleratorKeyEnabled.Call( + hr, _, _ := i.Vtbl.PutIsBrowserAcceleratorKeyEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go index 65117a5d739..1a3338bd501 100644 --- a/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler.go @@ -37,8 +37,9 @@ func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerIUnknownRel return uintptr(this.impl.Release()) } -func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerInvoke(this *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler, errorCode uintptr, result string) uintptr { - return this.impl.AddScriptToExecuteOnDocumentCreatedCompleted(errorCode, result) +func ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerInvoke(this *ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandler, errorCode uintptr, result *uint16) uintptr { + _result := UTF16PtrToString(result) + return this.impl.AddScriptToExecuteOnDocumentCreatedCompleted(errorCode, _result) } type ICoreWebView2AddScriptToExecuteOnDocumentCreatedCompletedHandlerImpl interface { diff --git a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go index 6e77deca2bd..27335e00498 100644 --- a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationRequestedEventArgs.go @@ -37,7 +37,7 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetUri() (string, e var _value *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,7 +47,7 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetUri() (string, e // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetChallenge() (string, error) { @@ -55,7 +55,7 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetChallenge() (str var _challenge *uint16 - hr, _, err := i.Vtbl.GetChallenge.Call( + hr, _, _ := i.Vtbl.GetChallenge.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_challenge)), ) @@ -65,28 +65,28 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetChallenge() (str // Get result and cleanup challenge := UTF16PtrToString(_challenge) CoTaskMemFree(unsafe.Pointer(_challenge)) - return challenge, err + return challenge, nil } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetResponse() (*ICoreWebView2BasicAuthenticationResponse, error) { var response *ICoreWebView2BasicAuthenticationResponse - hr, _, err := i.Vtbl.GetResponse.Call( + hr, _, _ := i.Vtbl.GetResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&response)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return response, err + return response, nil } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _cancel int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_cancel)), ) @@ -95,7 +95,7 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetCancel() (bool, } // Get result and cleanup cancel := _cancel != 0 - return cancel, err + return cancel, nil } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) PutCancel(cancel bool) error { @@ -106,26 +106,26 @@ func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) PutCancel(cancel bo _cancel = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_cancel), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2BasicAuthenticationRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go index d19eaec3091..1f76b71443a 100644 --- a/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go +++ b/webview2/pkg/webview2/ICoreWebView2BasicAuthenticationResponse.go @@ -35,7 +35,7 @@ func (i *ICoreWebView2BasicAuthenticationResponse) GetUserName() (string, error) var _userName *uint16 - hr, _, err := i.Vtbl.GetUserName.Call( + hr, _, _ := i.Vtbl.GetUserName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_userName)), ) @@ -45,7 +45,7 @@ func (i *ICoreWebView2BasicAuthenticationResponse) GetUserName() (string, error) // Get result and cleanup userName := UTF16PtrToString(_userName) CoTaskMemFree(unsafe.Pointer(_userName)) - return userName, err + return userName, nil } func (i *ICoreWebView2BasicAuthenticationResponse) PutUserName(userName string) error { @@ -56,14 +56,14 @@ func (i *ICoreWebView2BasicAuthenticationResponse) PutUserName(userName string) return err } - hr, _, err := i.Vtbl.PutUserName.Call( + hr, _, _ := i.Vtbl.PutUserName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_userName)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2BasicAuthenticationResponse) GetPassword() (string, error) { @@ -71,7 +71,7 @@ func (i *ICoreWebView2BasicAuthenticationResponse) GetPassword() (string, error) var _password *uint16 - hr, _, err := i.Vtbl.GetPassword.Call( + hr, _, _ := i.Vtbl.GetPassword.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_password)), ) @@ -81,7 +81,7 @@ func (i *ICoreWebView2BasicAuthenticationResponse) GetPassword() (string, error) // Get result and cleanup password := UTF16PtrToString(_password) CoTaskMemFree(unsafe.Pointer(_password)) - return password, err + return password, nil } func (i *ICoreWebView2BasicAuthenticationResponse) PutPassword(password string) error { @@ -92,12 +92,12 @@ func (i *ICoreWebView2BasicAuthenticationResponse) PutPassword(password string) return err } - hr, _, err := i.Vtbl.PutPassword.Call( + hr, _, _ := i.Vtbl.PutPassword.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_password)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go b/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go index 0a37fec38a3..3f33f1ab446 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserExtension.go @@ -36,7 +36,7 @@ func (i *ICoreWebView2BrowserExtension) GetId() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetId.Call( + hr, _, _ := i.Vtbl.GetId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -46,7 +46,7 @@ func (i *ICoreWebView2BrowserExtension) GetId() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2BrowserExtension) GetName() (string, error) { @@ -54,7 +54,7 @@ func (i *ICoreWebView2BrowserExtension) GetName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -64,27 +64,27 @@ func (i *ICoreWebView2BrowserExtension) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2BrowserExtension) Remove(handler *ICoreWebView2BrowserExtensionRemoveCompletedHandler) error { - hr, _, err := i.Vtbl.Remove.Call( + hr, _, _ := i.Vtbl.Remove.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2BrowserExtension) GetIsEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsEnabled.Call( + hr, _, _ := i.Vtbl.GetIsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -93,7 +93,7 @@ func (i *ICoreWebView2BrowserExtension) GetIsEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2BrowserExtension) Enable(isEnabled bool, handler *ICoreWebView2BrowserExtensionEnableCompletedHandler) error { @@ -104,7 +104,7 @@ func (i *ICoreWebView2BrowserExtension) Enable(isEnabled bool, handler *ICoreWeb _isEnabled = 1 } - hr, _, err := i.Vtbl.Enable.Call( + hr, _, _ := i.Vtbl.Enable.Call( uintptr(unsafe.Pointer(i)), uintptr(_isEnabled), uintptr(unsafe.Pointer(handler)), @@ -112,5 +112,5 @@ func (i *ICoreWebView2BrowserExtension) Enable(isEnabled bool, handler *ICoreWeb if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go index 1af677cac52..6b8609d2a61 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserExtensionList.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2BrowserExtensionList) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2BrowserExtensionList) GetValueAtIndex(index uint32) (*ICoreWebView2BrowserExtension, error) { var value *ICoreWebView2BrowserExtension - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2BrowserExtensionList) GetValueAtIndex(index uint32) (*ICor if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go index e91b3a0b266..abbbe9a8b71 100644 --- a/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2BrowserProcessExitedEventArgs.go @@ -32,26 +32,26 @@ func (i *ICoreWebView2BrowserProcessExitedEventArgs) GetBrowserProcessExitKind() var value COREWEBVIEW2_BROWSER_PROCESS_EXIT_KIND - hr, _, err := i.Vtbl.GetBrowserProcessExitKind.Call( + hr, _, _ := i.Vtbl.GetBrowserProcessExitKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2BrowserProcessExitedEventArgs) GetBrowserProcessId() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetBrowserProcessId.Call( + hr, _, _ := i.Vtbl.GetBrowserProcessId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go index 74b0efcfdef..1e6d95c4e84 100644 --- a/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2CallDevToolsProtocolMethodCompletedHandler.go @@ -37,8 +37,9 @@ func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerIUnknownRelease(this return uintptr(this.impl.Release()) } -func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerInvoke(this *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler, errorCode uintptr, result string) uintptr { - return this.impl.CallDevToolsProtocolMethodCompleted(errorCode, result) +func ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerInvoke(this *ICoreWebView2CallDevToolsProtocolMethodCompletedHandler, errorCode uintptr, result *uint16) uintptr { + _result := UTF16PtrToString(result) + return this.impl.CallDevToolsProtocolMethodCompleted(errorCode, _result) } type ICoreWebView2CallDevToolsProtocolMethodCompletedHandlerImpl interface { diff --git a/webview2/pkg/webview2/ICoreWebView2Certificate.go b/webview2/pkg/webview2/ICoreWebView2Certificate.go index 8c24efa699d..27baa6b59c4 100644 --- a/webview2/pkg/webview2/ICoreWebView2Certificate.go +++ b/webview2/pkg/webview2/ICoreWebView2Certificate.go @@ -39,7 +39,7 @@ func (i *ICoreWebView2Certificate) GetSubject() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetSubject.Call( + hr, _, _ := i.Vtbl.GetSubject.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -49,7 +49,7 @@ func (i *ICoreWebView2Certificate) GetSubject() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Certificate) GetIssuer() (string, error) { @@ -57,7 +57,7 @@ func (i *ICoreWebView2Certificate) GetIssuer() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetIssuer.Call( + hr, _, _ := i.Vtbl.GetIssuer.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -67,35 +67,35 @@ func (i *ICoreWebView2Certificate) GetIssuer() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Certificate) GetValidFrom() (float64, error) { var value float64 - hr, _, err := i.Vtbl.GetValidFrom.Call( + hr, _, _ := i.Vtbl.GetValidFrom.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Certificate) GetValidTo() (float64, error) { var value float64 - hr, _, err := i.Vtbl.GetValidTo.Call( + hr, _, _ := i.Vtbl.GetValidTo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Certificate) GetDerEncodedSerialNumber() (string, error) { @@ -103,7 +103,7 @@ func (i *ICoreWebView2Certificate) GetDerEncodedSerialNumber() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetDerEncodedSerialNumber.Call( + hr, _, _ := i.Vtbl.GetDerEncodedSerialNumber.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -113,7 +113,7 @@ func (i *ICoreWebView2Certificate) GetDerEncodedSerialNumber() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Certificate) GetDisplayName() (string, error) { @@ -121,7 +121,7 @@ func (i *ICoreWebView2Certificate) GetDisplayName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetDisplayName.Call( + hr, _, _ := i.Vtbl.GetDisplayName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -131,7 +131,7 @@ func (i *ICoreWebView2Certificate) GetDisplayName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Certificate) ToPemEncoding() (string, error) { @@ -139,7 +139,7 @@ func (i *ICoreWebView2Certificate) ToPemEncoding() (string, error) { var _pemEncodedData *uint16 - hr, _, err := i.Vtbl.ToPemEncoding.Call( + hr, _, _ := i.Vtbl.ToPemEncoding.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_pemEncodedData)), ) @@ -149,19 +149,19 @@ func (i *ICoreWebView2Certificate) ToPemEncoding() (string, error) { // Get result and cleanup pemEncodedData := UTF16PtrToString(_pemEncodedData) CoTaskMemFree(unsafe.Pointer(_pemEncodedData)) - return pemEncodedData, err + return pemEncodedData, nil } func (i *ICoreWebView2Certificate) GetPemEncodedIssuerCertificateChain() (*ICoreWebView2StringCollection, error) { var value *ICoreWebView2StringCollection - hr, _, err := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( + hr, _, _ := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go index 7b7dceb2d25..956261d8d91 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificate.go @@ -40,7 +40,7 @@ func (i *ICoreWebView2ClientCertificate) GetSubject() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetSubject.Call( + hr, _, _ := i.Vtbl.GetSubject.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -50,7 +50,7 @@ func (i *ICoreWebView2ClientCertificate) GetSubject() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) GetIssuer() (string, error) { @@ -58,7 +58,7 @@ func (i *ICoreWebView2ClientCertificate) GetIssuer() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetIssuer.Call( + hr, _, _ := i.Vtbl.GetIssuer.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -68,35 +68,35 @@ func (i *ICoreWebView2ClientCertificate) GetIssuer() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) GetValidFrom() (float64, error) { var value float64 - hr, _, err := i.Vtbl.GetValidFrom.Call( + hr, _, _ := i.Vtbl.GetValidFrom.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) GetValidTo() (float64, error) { var value float64 - hr, _, err := i.Vtbl.GetValidTo.Call( + hr, _, _ := i.Vtbl.GetValidTo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) GetDerEncodedSerialNumber() (string, error) { @@ -104,7 +104,7 @@ func (i *ICoreWebView2ClientCertificate) GetDerEncodedSerialNumber() (string, er var _value *uint16 - hr, _, err := i.Vtbl.GetDerEncodedSerialNumber.Call( + hr, _, _ := i.Vtbl.GetDerEncodedSerialNumber.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -114,7 +114,7 @@ func (i *ICoreWebView2ClientCertificate) GetDerEncodedSerialNumber() (string, er // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) GetDisplayName() (string, error) { @@ -122,7 +122,7 @@ func (i *ICoreWebView2ClientCertificate) GetDisplayName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetDisplayName.Call( + hr, _, _ := i.Vtbl.GetDisplayName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -132,7 +132,7 @@ func (i *ICoreWebView2ClientCertificate) GetDisplayName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) ToPemEncoding() (string, error) { @@ -140,7 +140,7 @@ func (i *ICoreWebView2ClientCertificate) ToPemEncoding() (string, error) { var _pemEncodedData *uint16 - hr, _, err := i.Vtbl.ToPemEncoding.Call( + hr, _, _ := i.Vtbl.ToPemEncoding.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_pemEncodedData)), ) @@ -150,33 +150,33 @@ func (i *ICoreWebView2ClientCertificate) ToPemEncoding() (string, error) { // Get result and cleanup pemEncodedData := UTF16PtrToString(_pemEncodedData) CoTaskMemFree(unsafe.Pointer(_pemEncodedData)) - return pemEncodedData, err + return pemEncodedData, nil } func (i *ICoreWebView2ClientCertificate) GetPemEncodedIssuerCertificateChain() (*ICoreWebView2StringCollection, error) { var value *ICoreWebView2StringCollection - hr, _, err := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( + hr, _, _ := i.Vtbl.GetPemEncodedIssuerCertificateChain.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificate) GetKind() (COREWEBVIEW2_CLIENT_CERTIFICATE_KIND, error) { var value COREWEBVIEW2_CLIENT_CERTIFICATE_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go index 1bb71a0d562..e84d6366df5 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificateCollection.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2ClientCertificateCollection) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ClientCertificate, error) { var value *ICoreWebView2ClientCertificate - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2ClientCertificateCollection) GetValueAtIndex(index uint32) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go index 3b714b942ba..78bbf784535 100644 --- a/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ClientCertificateRequestedEventArgs.go @@ -43,7 +43,7 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHost() (string, er var _value *uint16 - hr, _, err := i.Vtbl.GetHost.Call( + hr, _, _ := i.Vtbl.GetHost.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -53,28 +53,28 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHost() (string, er // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetPort() (int, error) { var value int - hr, _, err := i.Vtbl.GetPort.Call( + hr, _, _ := i.Vtbl.GetPort.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetIsProxy() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsProxy.Call( + hr, _, _ := i.Vtbl.GetIsProxy.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -83,69 +83,69 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetIsProxy() (bool, e } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetAllowedCertificateAuthorities() (*ICoreWebView2StringCollection, error) { var value *ICoreWebView2StringCollection - hr, _, err := i.Vtbl.GetAllowedCertificateAuthorities.Call( + hr, _, _ := i.Vtbl.GetAllowedCertificateAuthorities.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetMutuallyTrustedCertificates() (*ICoreWebView2ClientCertificateCollection, error) { var value *ICoreWebView2ClientCertificateCollection - hr, _, err := i.Vtbl.GetMutuallyTrustedCertificates.Call( + hr, _, _ := i.Vtbl.GetMutuallyTrustedCertificates.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetSelectedCertificate() (*ICoreWebView2ClientCertificate, error) { var value *ICoreWebView2ClientCertificate - hr, _, err := i.Vtbl.GetSelectedCertificate.Call( + hr, _, _ := i.Vtbl.GetSelectedCertificate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutSelectedCertificate(value *ICoreWebView2ClientCertificate) error { - hr, _, err := i.Vtbl.PutSelectedCertificate.Call( + hr, _, _ := i.Vtbl.PutSelectedCertificate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -154,7 +154,7 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetCancel() (bool, er } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutCancel(value bool) error { @@ -165,21 +165,21 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutCancel(value bool) _value = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -188,7 +188,7 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetHandled() (bool, e } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutHandled(value bool) error { @@ -199,26 +199,26 @@ func (i *ICoreWebView2ClientCertificateRequestedEventArgs) PutHandled(value bool _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ClientCertificateRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController.go b/webview2/pkg/webview2/ICoreWebView2CompositionController.go index 1b0c724f47b..d771db64660 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController.go @@ -38,33 +38,33 @@ func (i *ICoreWebView2CompositionController) GetRootVisualTarget() (*IUnknown, e var target *IUnknown - hr, _, err := i.Vtbl.GetRootVisualTarget.Call( + hr, _, _ := i.Vtbl.GetRootVisualTarget.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&target)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return target, err + return target, nil } func (i *ICoreWebView2CompositionController) PutRootVisualTarget(target *IUnknown) error { - hr, _, err := i.Vtbl.PutRootVisualTarget.Call( + hr, _, _ := i.Vtbl.PutRootVisualTarget.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(target)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CompositionController) SendMouseInput(eventKind COREWEBVIEW2_MOUSE_EVENT_KIND, virtualKeys COREWEBVIEW2_MOUSE_EVENT_VIRTUAL_KEYS, mouseData uint32, point POINT) error { - hr, _, err := i.Vtbl.SendMouseInput.Call( + hr, _, _ := i.Vtbl.SendMouseInput.Call( uintptr(unsafe.Pointer(i)), uintptr(eventKind), uintptr(virtualKeys), @@ -74,13 +74,13 @@ func (i *ICoreWebView2CompositionController) SendMouseInput(eventKind COREWEBVIE if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CompositionController) SendPointerInput(eventKind COREWEBVIEW2_POINTER_EVENT_KIND, pointerInfo *ICoreWebView2PointerInfo) error { - hr, _, err := i.Vtbl.SendPointerInput.Call( + hr, _, _ := i.Vtbl.SendPointerInput.Call( uintptr(unsafe.Pointer(i)), uintptr(eventKind), uintptr(unsafe.Pointer(pointerInfo)), @@ -88,42 +88,42 @@ func (i *ICoreWebView2CompositionController) SendPointerInput(eventKind COREWEBV if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CompositionController) GetCursor() (HCURSOR, error) { var cursor HCURSOR - hr, _, err := i.Vtbl.GetCursor.Call( + hr, _, _ := i.Vtbl.GetCursor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&cursor)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return cursor, err + return cursor, nil } func (i *ICoreWebView2CompositionController) GetSystemCursorId() (uint32, error) { var systemCursorId uint32 - hr, _, err := i.Vtbl.GetSystemCursorId.Call( + hr, _, _ := i.Vtbl.GetSystemCursorId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&systemCursorId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return systemCursorId, err + return systemCursorId, nil } func (i *ICoreWebView2CompositionController) AddCursorChanged(eventHandler *ICoreWebView2CursorChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddCursorChanged.Call( + hr, _, _ := i.Vtbl.AddCursorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -131,18 +131,18 @@ func (i *ICoreWebView2CompositionController) AddCursorChanged(eventHandler *ICor if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2CompositionController) RemoveCursorChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveCursorChanged.Call( + hr, _, _ := i.Vtbl.RemoveCursorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController2.go b/webview2/pkg/webview2/ICoreWebView2CompositionController2.go index 72d204afa3f..a5203e9a675 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController2.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController2.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2CompositionController2) GetAutomationProvider() (*IUnknown var value *IUnknown - hr, _, err := i.Vtbl.GetAutomationProvider.Call( + hr, _, _ := i.Vtbl.GetAutomationProvider.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController3.go b/webview2/pkg/webview2/ICoreWebView2CompositionController3.go index a7e38f35e9f..9a5343e690b 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController3.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController3.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2CompositionController3) DragEnter(dataObject *IDataObject, var effect uint32 - hr, _, err := i.Vtbl.DragEnter.Call( + hr, _, _ := i.Vtbl.DragEnter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(dataObject)), uintptr(keyState), @@ -59,26 +59,26 @@ func (i *ICoreWebView2CompositionController3) DragEnter(dataObject *IDataObject, if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return effect, err + return effect, nil } func (i *ICoreWebView2CompositionController3) DragLeave() error { - hr, _, err := i.Vtbl.DragLeave.Call( + hr, _, _ := i.Vtbl.DragLeave.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CompositionController3) DragOver(keyState uint32, point POINT) (uint32, error) { var effect uint32 - hr, _, err := i.Vtbl.DragOver.Call( + hr, _, _ := i.Vtbl.DragOver.Call( uintptr(unsafe.Pointer(i)), uintptr(keyState), uintptr(unsafe.Pointer(&point)), @@ -87,14 +87,14 @@ func (i *ICoreWebView2CompositionController3) DragOver(keyState uint32, point PO if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return effect, err + return effect, nil } func (i *ICoreWebView2CompositionController3) Drop(dataObject *IDataObject, keyState uint32, point POINT) (uint32, error) { var effect uint32 - hr, _, err := i.Vtbl.Drop.Call( + hr, _, _ := i.Vtbl.Drop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(dataObject)), uintptr(keyState), @@ -104,5 +104,5 @@ func (i *ICoreWebView2CompositionController3) Drop(dataObject *IDataObject, keyS if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return effect, err + return effect, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController4.go b/webview2/pkg/webview2/ICoreWebView2CompositionController4.go index bbdb1832c14..964db3b1c4c 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController4.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController4.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2CompositionController4) GetNonClientRegionAtPoint(point PO var value COREWEBVIEW2_NON_CLIENT_REGION_KIND - hr, _, err := i.Vtbl.GetNonClientRegionAtPoint.Call( + hr, _, _ := i.Vtbl.GetNonClientRegionAtPoint.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&point)), uintptr(unsafe.Pointer(&value)), @@ -57,14 +57,14 @@ func (i *ICoreWebView2CompositionController4) GetNonClientRegionAtPoint(point PO if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2CompositionController4) QueryNonClientRegion(kind COREWEBVIEW2_NON_CLIENT_REGION_KIND) (*ICoreWebView2RegionRectCollectionView, error) { var rects *ICoreWebView2RegionRectCollectionView - hr, _, err := i.Vtbl.QueryNonClientRegion.Call( + hr, _, _ := i.Vtbl.QueryNonClientRegion.Call( uintptr(unsafe.Pointer(i)), uintptr(kind), uintptr(unsafe.Pointer(&rects)), @@ -72,14 +72,14 @@ func (i *ICoreWebView2CompositionController4) QueryNonClientRegion(kind COREWEBV if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return rects, err + return rects, nil } func (i *ICoreWebView2CompositionController4) AddNonClientRegionChanged(eventHandler *ICoreWebView2NonClientRegionChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNonClientRegionChanged.Call( + hr, _, _ := i.Vtbl.AddNonClientRegionChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -87,18 +87,18 @@ func (i *ICoreWebView2CompositionController4) AddNonClientRegionChanged(eventHan if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2CompositionController4) RemoveNonClientRegionChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNonClientRegionChanged.Call( + hr, _, _ := i.Vtbl.RemoveNonClientRegionChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CompositionController5.go b/webview2/pkg/webview2/ICoreWebView2CompositionController5.go index c70a13e74dc..23b722fa810 100644 --- a/webview2/pkg/webview2/ICoreWebView2CompositionController5.go +++ b/webview2/pkg/webview2/ICoreWebView2CompositionController5.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2CompositionController5) AddDragStarting(eventHandler *ICor var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDragStarting.Call( + hr, _, _ := i.Vtbl.AddDragStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2CompositionController5) AddDragStarting(eventHandler *ICor if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2CompositionController5) RemoveDragStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDragStarting.Call( + hr, _, _ := i.Vtbl.RemoveDragStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go index fb5326ac6d6..477e74f94ae 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ContentLoadingEventArgs.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2ContentLoadingEventArgs) GetIsErrorPage() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsErrorPage.Call( + hr, _, _ := i.Vtbl.GetIsErrorPage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -41,19 +41,19 @@ func (i *ICoreWebView2ContentLoadingEventArgs) GetIsErrorPage() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContentLoadingEventArgs) GetNavigationId() (uint64, error) { var value uint64 - hr, _, err := i.Vtbl.GetNavigationId.Call( + hr, _, _ := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go index cad243e32cc..54a8a9f5047 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuItem.go @@ -44,7 +44,7 @@ func (i *ICoreWebView2ContextMenuItem) GetName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -54,7 +54,7 @@ func (i *ICoreWebView2ContextMenuItem) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) GetLabel() (string, error) { @@ -62,7 +62,7 @@ func (i *ICoreWebView2ContextMenuItem) GetLabel() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetLabel.Call( + hr, _, _ := i.Vtbl.GetLabel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -72,21 +72,21 @@ func (i *ICoreWebView2ContextMenuItem) GetLabel() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) GetCommandId() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetCommandId.Call( + hr, _, _ := i.Vtbl.GetCommandId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) GetShortcutKeyDescription() (string, error) { @@ -94,7 +94,7 @@ func (i *ICoreWebView2ContextMenuItem) GetShortcutKeyDescription() (string, erro var _value *uint16 - hr, _, err := i.Vtbl.GetShortcutKeyDescription.Call( + hr, _, _ := i.Vtbl.GetShortcutKeyDescription.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -104,35 +104,35 @@ func (i *ICoreWebView2ContextMenuItem) GetShortcutKeyDescription() (string, erro // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) GetIcon() (*IStream, error) { var value *IStream - hr, _, err := i.Vtbl.GetIcon.Call( + hr, _, _ := i.Vtbl.GetIcon.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) GetKind() (COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND, error) { var value COREWEBVIEW2_CONTEXT_MENU_ITEM_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) PutIsEnabled(value bool) error { @@ -143,21 +143,21 @@ func (i *ICoreWebView2ContextMenuItem) PutIsEnabled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsEnabled.Call( + hr, _, _ := i.Vtbl.PutIsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ContextMenuItem) GetIsEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsEnabled.Call( + hr, _, _ := i.Vtbl.GetIsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -166,7 +166,7 @@ func (i *ICoreWebView2ContextMenuItem) GetIsEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) PutIsChecked(value bool) error { @@ -177,21 +177,21 @@ func (i *ICoreWebView2ContextMenuItem) PutIsChecked(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsChecked.Call( + hr, _, _ := i.Vtbl.PutIsChecked.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ContextMenuItem) GetIsChecked() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsChecked.Call( + hr, _, _ := i.Vtbl.GetIsChecked.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -200,28 +200,28 @@ func (i *ICoreWebView2ContextMenuItem) GetIsChecked() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) GetChildren() (*ICoreWebView2ContextMenuItemCollection, error) { var value *ICoreWebView2ContextMenuItemCollection - hr, _, err := i.Vtbl.GetChildren.Call( + hr, _, _ := i.Vtbl.GetChildren.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItem) AddCustomItemSelected(eventHandler *ICoreWebView2CustomItemSelectedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddCustomItemSelected.Call( + hr, _, _ := i.Vtbl.AddCustomItemSelected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -229,18 +229,18 @@ func (i *ICoreWebView2ContextMenuItem) AddCustomItemSelected(eventHandler *ICore if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2ContextMenuItem) RemoveCustomItemSelected(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveCustomItemSelected.Call( + hr, _, _ := i.Vtbl.RemoveCustomItemSelected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go index eebd78dac16..edc56c7ef3f 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuItemCollection.go @@ -34,21 +34,21 @@ func (i *ICoreWebView2ContextMenuItemCollection) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItemCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ContextMenuItem, error) { var value *ICoreWebView2ContextMenuItem - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -56,26 +56,26 @@ func (i *ICoreWebView2ContextMenuItemCollection) GetValueAtIndex(index uint32) ( if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuItemCollection) RemoveValueAtIndex(index uint32) error { - hr, _, err := i.Vtbl.RemoveValueAtIndex.Call( + hr, _, _ := i.Vtbl.RemoveValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ContextMenuItemCollection) InsertValueAtIndex(index uint32, value *ICoreWebView2ContextMenuItem) error { - hr, _, err := i.Vtbl.InsertValueAtIndex.Call( + hr, _, _ := i.Vtbl.InsertValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(value)), @@ -83,5 +83,5 @@ func (i *ICoreWebView2ContextMenuItemCollection) InsertValueAtIndex(index uint32 if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go index 47ec58f6696..5e411e9c9b9 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuRequestedEventArgs.go @@ -38,69 +38,69 @@ func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetMenuItems() (*ICoreWebVi var value *ICoreWebView2ContextMenuItemCollection - hr, _, err := i.Vtbl.GetMenuItems.Call( + hr, _, _ := i.Vtbl.GetMenuItems.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetContextMenuTarget() (*ICoreWebView2ContextMenuTarget, error) { var value *ICoreWebView2ContextMenuTarget - hr, _, err := i.Vtbl.GetContextMenuTarget.Call( + hr, _, _ := i.Vtbl.GetContextMenuTarget.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetLocation() (POINT, error) { var value POINT - hr, _, err := i.Vtbl.GetLocation.Call( + hr, _, _ := i.Vtbl.GetLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) PutSelectedCommandId(value int32) error { - hr, _, err := i.Vtbl.PutSelectedCommandId.Call( + hr, _, _ := i.Vtbl.PutSelectedCommandId.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetSelectedCommandId() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetSelectedCommandId.Call( + hr, _, _ := i.Vtbl.GetSelectedCommandId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) PutHandled(value bool) error { @@ -111,21 +111,21 @@ func (i *ICoreWebView2ContextMenuRequestedEventArgs) PutHandled(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -134,19 +134,19 @@ func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetHandled() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go b/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go index 3bc3c793834..9ba486a7bcb 100644 --- a/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go +++ b/webview2/pkg/webview2/ICoreWebView2ContextMenuTarget.go @@ -43,21 +43,21 @@ func (i *ICoreWebView2ContextMenuTarget) GetKind() (COREWEBVIEW2_CONTEXT_MENU_TA var value COREWEBVIEW2_CONTEXT_MENU_TARGET_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetIsEditable() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsEditable.Call( + hr, _, _ := i.Vtbl.GetIsEditable.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -66,14 +66,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetIsEditable() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetIsRequestedForMainFrame() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsRequestedForMainFrame.Call( + hr, _, _ := i.Vtbl.GetIsRequestedForMainFrame.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -82,7 +82,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetIsRequestedForMainFrame() (bool, err } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetPageUri() (string, error) { @@ -90,7 +90,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetPageUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetPageUri.Call( + hr, _, _ := i.Vtbl.GetPageUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -100,7 +100,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetPageUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetFrameUri() (string, error) { @@ -108,7 +108,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetFrameUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetFrameUri.Call( + hr, _, _ := i.Vtbl.GetFrameUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -118,14 +118,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetFrameUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetHasLinkUri() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasLinkUri.Call( + hr, _, _ := i.Vtbl.GetHasLinkUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -134,7 +134,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasLinkUri() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetLinkUri() (string, error) { @@ -142,7 +142,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetLinkUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetLinkUri.Call( + hr, _, _ := i.Vtbl.GetLinkUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -152,14 +152,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetLinkUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetHasLinkText() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasLinkText.Call( + hr, _, _ := i.Vtbl.GetHasLinkText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -168,7 +168,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasLinkText() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetLinkText() (string, error) { @@ -176,7 +176,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetLinkText() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetLinkText.Call( + hr, _, _ := i.Vtbl.GetLinkText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -186,14 +186,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetLinkText() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetHasSourceUri() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasSourceUri.Call( + hr, _, _ := i.Vtbl.GetHasSourceUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -202,7 +202,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasSourceUri() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetSourceUri() (string, error) { @@ -210,7 +210,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetSourceUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetSourceUri.Call( + hr, _, _ := i.Vtbl.GetSourceUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -220,14 +220,14 @@ func (i *ICoreWebView2ContextMenuTarget) GetSourceUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetHasSelection() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasSelection.Call( + hr, _, _ := i.Vtbl.GetHasSelection.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -236,7 +236,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetHasSelection() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ContextMenuTarget) GetSelectionText() (string, error) { @@ -244,7 +244,7 @@ func (i *ICoreWebView2ContextMenuTarget) GetSelectionText() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetSelectionText.Call( + hr, _, _ := i.Vtbl.GetSelectionText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -254,5 +254,5 @@ func (i *ICoreWebView2ContextMenuTarget) GetSelectionText() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller.go b/webview2/pkg/webview2/ICoreWebView2Controller.go index 6e4d63b99e1..4fc5b42bd80 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller.go @@ -53,7 +53,7 @@ func (i *ICoreWebView2Controller) GetIsVisible() (bool, error) { // Create int32 to hold bool result var _isVisible int32 - hr, _, err := i.Vtbl.GetIsVisible.Call( + hr, _, _ := i.Vtbl.GetIsVisible.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isVisible)), ) @@ -62,7 +62,7 @@ func (i *ICoreWebView2Controller) GetIsVisible() (bool, error) { } // Get result and cleanup isVisible := _isVisible != 0 - return isVisible, err + return isVisible, nil } func (i *ICoreWebView2Controller) PutIsVisible(isVisible bool) error { @@ -73,75 +73,75 @@ func (i *ICoreWebView2Controller) PutIsVisible(isVisible bool) error { _isVisible = 1 } - hr, _, err := i.Vtbl.PutIsVisible.Call( + hr, _, _ := i.Vtbl.PutIsVisible.Call( uintptr(unsafe.Pointer(i)), uintptr(_isVisible), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) GetBounds() (RECT, error) { var bounds RECT - hr, _, err := i.Vtbl.GetBounds.Call( + hr, _, _ := i.Vtbl.GetBounds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bounds)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return bounds, err + return bounds, nil } func (i *ICoreWebView2Controller) PutBounds(bounds RECT) error { - hr, _, err := i.Vtbl.PutBounds.Call( + hr, _, _ := i.Vtbl.PutBounds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bounds)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) GetZoomFactor() (float64, error) { var zoomFactor float64 - hr, _, err := i.Vtbl.GetZoomFactor.Call( + hr, _, _ := i.Vtbl.GetZoomFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&zoomFactor)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return zoomFactor, err + return zoomFactor, nil } func (i *ICoreWebView2Controller) PutZoomFactor(zoomFactor float64) error { - hr, _, err := i.Vtbl.PutZoomFactor.Call( + hr, _, _ := i.Vtbl.PutZoomFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(zoomFactor), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) AddZoomFactorChanged(eventHandler *ICoreWebView2ZoomFactorChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddZoomFactorChanged.Call( + hr, _, _ := i.Vtbl.AddZoomFactorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -149,26 +149,26 @@ func (i *ICoreWebView2Controller) AddZoomFactorChanged(eventHandler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Controller) RemoveZoomFactorChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveZoomFactorChanged.Call( + hr, _, _ := i.Vtbl.RemoveZoomFactorChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) SetBoundsAndZoomFactor(bounds RECT, zoomFactor float64) error { - hr, _, err := i.Vtbl.SetBoundsAndZoomFactor.Call( + hr, _, _ := i.Vtbl.SetBoundsAndZoomFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bounds)), uintptr(zoomFactor), @@ -176,27 +176,27 @@ func (i *ICoreWebView2Controller) SetBoundsAndZoomFactor(bounds RECT, zoomFactor if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) MoveFocus(reason COREWEBVIEW2_MOVE_FOCUS_REASON) error { - hr, _, err := i.Vtbl.MoveFocus.Call( + hr, _, _ := i.Vtbl.MoveFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(reason), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) AddMoveFocusRequested(eventHandler *ICoreWebView2MoveFocusRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddMoveFocusRequested.Call( + hr, _, _ := i.Vtbl.AddMoveFocusRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -204,27 +204,27 @@ func (i *ICoreWebView2Controller) AddMoveFocusRequested(eventHandler *ICoreWebVi if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Controller) RemoveMoveFocusRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveMoveFocusRequested.Call( + hr, _, _ := i.Vtbl.RemoveMoveFocusRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) AddGotFocus(eventHandler *ICoreWebView2FocusChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddGotFocus.Call( + hr, _, _ := i.Vtbl.AddGotFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -232,27 +232,27 @@ func (i *ICoreWebView2Controller) AddGotFocus(eventHandler *ICoreWebView2FocusCh if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Controller) RemoveGotFocus(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveGotFocus.Call( + hr, _, _ := i.Vtbl.RemoveGotFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) AddLostFocus(eventHandler *ICoreWebView2FocusChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddLostFocus.Call( + hr, _, _ := i.Vtbl.AddLostFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -260,27 +260,27 @@ func (i *ICoreWebView2Controller) AddLostFocus(eventHandler *ICoreWebView2FocusC if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Controller) RemoveLostFocus(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveLostFocus.Call( + hr, _, _ := i.Vtbl.RemoveLostFocus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) AddAcceleratorKeyPressed(eventHandler *ICoreWebView2AcceleratorKeyPressedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddAcceleratorKeyPressed.Call( + hr, _, _ := i.Vtbl.AddAcceleratorKeyPressed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -288,83 +288,83 @@ func (i *ICoreWebView2Controller) AddAcceleratorKeyPressed(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Controller) RemoveAcceleratorKeyPressed(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveAcceleratorKeyPressed.Call( + hr, _, _ := i.Vtbl.RemoveAcceleratorKeyPressed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) GetParentWindow() (HWND, error) { var parentWindow HWND - hr, _, err := i.Vtbl.GetParentWindow.Call( + hr, _, _ := i.Vtbl.GetParentWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&parentWindow)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return parentWindow, err + return parentWindow, nil } func (i *ICoreWebView2Controller) PutParentWindow(parentWindow HWND) error { - hr, _, err := i.Vtbl.PutParentWindow.Call( + hr, _, _ := i.Vtbl.PutParentWindow.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&parentWindow)), + uintptr(parentWindow), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) NotifyParentWindowPositionChanged() error { - hr, _, err := i.Vtbl.NotifyParentWindowPositionChanged.Call( + hr, _, _ := i.Vtbl.NotifyParentWindowPositionChanged.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) Close() error { - hr, _, err := i.Vtbl.Close.Call( + hr, _, _ := i.Vtbl.Close.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller) GetCoreWebView2() (*ICoreWebView2, error) { var coreWebView2 *ICoreWebView2 - hr, _, err := i.Vtbl.GetCoreWebView2.Call( + hr, _, _ := i.Vtbl.GetCoreWebView2.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&coreWebView2)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return coreWebView2, err + return coreWebView2, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller2.go b/webview2/pkg/webview2/ICoreWebView2Controller2.go index 349813795a0..4966614cc2c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller2.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller2.go @@ -47,25 +47,25 @@ func (i *ICoreWebView2Controller2) GetDefaultBackgroundColor() (COREWEBVIEW2_COL var value COREWEBVIEW2_COLOR - hr, _, err := i.Vtbl.GetDefaultBackgroundColor.Call( + hr, _, _ := i.Vtbl.GetDefaultBackgroundColor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return COREWEBVIEW2_COLOR{}, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Controller2) PutDefaultBackgroundColor(value COREWEBVIEW2_COLOR) error { - hr, _, err := i.Vtbl.PutDefaultBackgroundColor.Call( + hr, _, _ := i.Vtbl.PutDefaultBackgroundColor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller3.go b/webview2/pkg/webview2/ICoreWebView2Controller3.go index 69d0c670d5f..8fabf3b563b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller3.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller3.go @@ -53,34 +53,34 @@ func (i *ICoreWebView2Controller3) GetRasterizationScale() (float64, error) { var scale float64 - hr, _, err := i.Vtbl.GetRasterizationScale.Call( + hr, _, _ := i.Vtbl.GetRasterizationScale.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&scale)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return scale, err + return scale, nil } func (i *ICoreWebView2Controller3) PutRasterizationScale(scale float64) error { - hr, _, err := i.Vtbl.PutRasterizationScale.Call( + hr, _, _ := i.Vtbl.PutRasterizationScale.Call( uintptr(unsafe.Pointer(i)), uintptr(scale), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller3) GetShouldDetectMonitorScaleChanges() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldDetectMonitorScaleChanges.Call( + hr, _, _ := i.Vtbl.GetShouldDetectMonitorScaleChanges.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -89,7 +89,7 @@ func (i *ICoreWebView2Controller3) GetShouldDetectMonitorScaleChanges() (bool, e } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Controller3) PutShouldDetectMonitorScaleChanges(value bool) error { @@ -100,21 +100,21 @@ func (i *ICoreWebView2Controller3) PutShouldDetectMonitorScaleChanges(value bool _value = 1 } - hr, _, err := i.Vtbl.PutShouldDetectMonitorScaleChanges.Call( + hr, _, _ := i.Vtbl.PutShouldDetectMonitorScaleChanges.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller3) AddRasterizationScaleChanged(eventHandler *ICoreWebView2RasterizationScaleChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddRasterizationScaleChanged.Call( + hr, _, _ := i.Vtbl.AddRasterizationScaleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -122,45 +122,45 @@ func (i *ICoreWebView2Controller3) AddRasterizationScaleChanged(eventHandler *IC if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Controller3) RemoveRasterizationScaleChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveRasterizationScaleChanged.Call( + hr, _, _ := i.Vtbl.RemoveRasterizationScaleChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Controller3) GetBoundsMode() (COREWEBVIEW2_BOUNDS_MODE, error) { var boundsMode COREWEBVIEW2_BOUNDS_MODE - hr, _, err := i.Vtbl.GetBoundsMode.Call( + hr, _, _ := i.Vtbl.GetBoundsMode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&boundsMode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return boundsMode, err + return boundsMode, nil } func (i *ICoreWebView2Controller3) PutBoundsMode(boundsMode COREWEBVIEW2_BOUNDS_MODE) error { - hr, _, err := i.Vtbl.PutBoundsMode.Call( + hr, _, _ := i.Vtbl.PutBoundsMode.Call( uintptr(unsafe.Pointer(i)), uintptr(boundsMode), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Controller4.go b/webview2/pkg/webview2/ICoreWebView2Controller4.go index 60da67e87b2..9871c254842 100644 --- a/webview2/pkg/webview2/ICoreWebView2Controller4.go +++ b/webview2/pkg/webview2/ICoreWebView2Controller4.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Controller4) GetAllowExternalDrop() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetAllowExternalDrop.Call( + hr, _, _ := i.Vtbl.GetAllowExternalDrop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2Controller4) GetAllowExternalDrop() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Controller4) PutAllowExternalDrop(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2Controller4) PutAllowExternalDrop(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutAllowExternalDrop.Call( + hr, _, _ := i.Vtbl.PutAllowExternalDrop.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go index 38140ae3cdf..6c6747585e3 100644 --- a/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions.go @@ -35,7 +35,7 @@ func (i *ICoreWebView2ControllerOptions) GetProfileName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetProfileName.Call( + hr, _, _ := i.Vtbl.GetProfileName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -45,7 +45,7 @@ func (i *ICoreWebView2ControllerOptions) GetProfileName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ControllerOptions) PutProfileName(value string) error { @@ -56,21 +56,21 @@ func (i *ICoreWebView2ControllerOptions) PutProfileName(value string) error { return err } - hr, _, err := i.Vtbl.PutProfileName.Call( + hr, _, _ := i.Vtbl.PutProfileName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ControllerOptions) GetIsInPrivateModeEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsInPrivateModeEnabled.Call( + hr, _, _ := i.Vtbl.GetIsInPrivateModeEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -79,7 +79,7 @@ func (i *ICoreWebView2ControllerOptions) GetIsInPrivateModeEnabled() (bool, erro } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ControllerOptions) PutIsInPrivateModeEnabled(value bool) error { @@ -90,12 +90,12 @@ func (i *ICoreWebView2ControllerOptions) PutIsInPrivateModeEnabled(value bool) e _value = 1 } - hr, _, err := i.Vtbl.PutIsInPrivateModeEnabled.Call( + hr, _, _ := i.Vtbl.PutIsInPrivateModeEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go index 5034c9d817e..b214d817825 100644 --- a/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions2.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2ControllerOptions2) GetScriptLocale() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetScriptLocale.Call( + hr, _, _ := i.Vtbl.GetScriptLocale.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,7 +58,7 @@ func (i *ICoreWebView2ControllerOptions2) GetScriptLocale() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ControllerOptions2) PutScriptLocale(value string) error { @@ -69,12 +69,12 @@ func (i *ICoreWebView2ControllerOptions2) PutScriptLocale(value string) error { return err } - hr, _, err := i.Vtbl.PutScriptLocale.Call( + hr, _, _ := i.Vtbl.PutScriptLocale.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go index 0cb8913000d..23bc9d9c890 100644 --- a/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions3.go @@ -47,25 +47,25 @@ func (i *ICoreWebView2ControllerOptions3) GetDefaultBackgroundColor() (COREWEBVI var value COREWEBVIEW2_COLOR - hr, _, err := i.Vtbl.GetDefaultBackgroundColor.Call( + hr, _, _ := i.Vtbl.GetDefaultBackgroundColor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return COREWEBVIEW2_COLOR{}, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ControllerOptions3) PutDefaultBackgroundColor(value COREWEBVIEW2_COLOR) error { - hr, _, err := i.Vtbl.PutDefaultBackgroundColor.Call( + hr, _, _ := i.Vtbl.PutDefaultBackgroundColor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go b/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go index 7dbdea6cd20..9dee0be717b 100644 --- a/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go +++ b/webview2/pkg/webview2/ICoreWebView2ControllerOptions4.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2ControllerOptions4) GetAllowHostInputProcessing() (bool, e // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetAllowHostInputProcessing.Call( + hr, _, _ := i.Vtbl.GetAllowHostInputProcessing.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2ControllerOptions4) GetAllowHostInputProcessing() (bool, e } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ControllerOptions4) PutAllowHostInputProcessing(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2ControllerOptions4) PutAllowHostInputProcessing(value bool _value = 1 } - hr, _, err := i.Vtbl.PutAllowHostInputProcessing.Call( + hr, _, _ := i.Vtbl.PutAllowHostInputProcessing.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Cookie.go b/webview2/pkg/webview2/ICoreWebView2Cookie.go index 204c07ab534..c33eefc8cc1 100644 --- a/webview2/pkg/webview2/ICoreWebView2Cookie.go +++ b/webview2/pkg/webview2/ICoreWebView2Cookie.go @@ -45,7 +45,7 @@ func (i *ICoreWebView2Cookie) GetName() (string, error) { var _name *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_name)), ) @@ -55,7 +55,7 @@ func (i *ICoreWebView2Cookie) GetName() (string, error) { // Get result and cleanup name := UTF16PtrToString(_name) CoTaskMemFree(unsafe.Pointer(_name)) - return name, err + return name, nil } func (i *ICoreWebView2Cookie) GetValue() (string, error) { @@ -63,7 +63,7 @@ func (i *ICoreWebView2Cookie) GetValue() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetValue.Call( + hr, _, _ := i.Vtbl.GetValue.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -73,7 +73,7 @@ func (i *ICoreWebView2Cookie) GetValue() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Cookie) PutValue(value string) error { @@ -84,14 +84,14 @@ func (i *ICoreWebView2Cookie) PutValue(value string) error { return err } - hr, _, err := i.Vtbl.PutValue.Call( + hr, _, _ := i.Vtbl.PutValue.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Cookie) GetDomain() (string, error) { @@ -99,7 +99,7 @@ func (i *ICoreWebView2Cookie) GetDomain() (string, error) { var _domain *uint16 - hr, _, err := i.Vtbl.GetDomain.Call( + hr, _, _ := i.Vtbl.GetDomain.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_domain)), ) @@ -109,7 +109,7 @@ func (i *ICoreWebView2Cookie) GetDomain() (string, error) { // Get result and cleanup domain := UTF16PtrToString(_domain) CoTaskMemFree(unsafe.Pointer(_domain)) - return domain, err + return domain, nil } func (i *ICoreWebView2Cookie) GetPath() (string, error) { @@ -117,7 +117,7 @@ func (i *ICoreWebView2Cookie) GetPath() (string, error) { var _path *uint16 - hr, _, err := i.Vtbl.GetPath.Call( + hr, _, _ := i.Vtbl.GetPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_path)), ) @@ -127,41 +127,41 @@ func (i *ICoreWebView2Cookie) GetPath() (string, error) { // Get result and cleanup path := UTF16PtrToString(_path) CoTaskMemFree(unsafe.Pointer(_path)) - return path, err + return path, nil } func (i *ICoreWebView2Cookie) GetExpires() (float64, error) { var expires float64 - hr, _, err := i.Vtbl.GetExpires.Call( + hr, _, _ := i.Vtbl.GetExpires.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&expires)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return expires, err + return expires, nil } func (i *ICoreWebView2Cookie) PutExpires(expires float64) error { - hr, _, err := i.Vtbl.PutExpires.Call( + hr, _, _ := i.Vtbl.PutExpires.Call( uintptr(unsafe.Pointer(i)), uintptr(expires), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Cookie) GetIsHttpOnly() (bool, error) { // Create int32 to hold bool result var _isHttpOnly int32 - hr, _, err := i.Vtbl.GetIsHttpOnly.Call( + hr, _, _ := i.Vtbl.GetIsHttpOnly.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isHttpOnly)), ) @@ -170,7 +170,7 @@ func (i *ICoreWebView2Cookie) GetIsHttpOnly() (bool, error) { } // Get result and cleanup isHttpOnly := _isHttpOnly != 0 - return isHttpOnly, err + return isHttpOnly, nil } func (i *ICoreWebView2Cookie) PutIsHttpOnly(isHttpOnly bool) error { @@ -181,48 +181,48 @@ func (i *ICoreWebView2Cookie) PutIsHttpOnly(isHttpOnly bool) error { _isHttpOnly = 1 } - hr, _, err := i.Vtbl.PutIsHttpOnly.Call( + hr, _, _ := i.Vtbl.PutIsHttpOnly.Call( uintptr(unsafe.Pointer(i)), uintptr(_isHttpOnly), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Cookie) GetSameSite() (COREWEBVIEW2_COOKIE_SAME_SITE_KIND, error) { var sameSite COREWEBVIEW2_COOKIE_SAME_SITE_KIND - hr, _, err := i.Vtbl.GetSameSite.Call( + hr, _, _ := i.Vtbl.GetSameSite.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&sameSite)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return sameSite, err + return sameSite, nil } func (i *ICoreWebView2Cookie) PutSameSite(sameSite COREWEBVIEW2_COOKIE_SAME_SITE_KIND) error { - hr, _, err := i.Vtbl.PutSameSite.Call( + hr, _, _ := i.Vtbl.PutSameSite.Call( uintptr(unsafe.Pointer(i)), uintptr(sameSite), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Cookie) GetIsSecure() (bool, error) { // Create int32 to hold bool result var _isSecure int32 - hr, _, err := i.Vtbl.GetIsSecure.Call( + hr, _, _ := i.Vtbl.GetIsSecure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSecure)), ) @@ -231,7 +231,7 @@ func (i *ICoreWebView2Cookie) GetIsSecure() (bool, error) { } // Get result and cleanup isSecure := _isSecure != 0 - return isSecure, err + return isSecure, nil } func (i *ICoreWebView2Cookie) PutIsSecure(isSecure bool) error { @@ -242,21 +242,21 @@ func (i *ICoreWebView2Cookie) PutIsSecure(isSecure bool) error { _isSecure = 1 } - hr, _, err := i.Vtbl.PutIsSecure.Call( + hr, _, _ := i.Vtbl.PutIsSecure.Call( uintptr(unsafe.Pointer(i)), uintptr(_isSecure), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Cookie) GetIsSession() (bool, error) { // Create int32 to hold bool result var _isSession int32 - hr, _, err := i.Vtbl.GetIsSession.Call( + hr, _, _ := i.Vtbl.GetIsSession.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSession)), ) @@ -265,5 +265,5 @@ func (i *ICoreWebView2Cookie) GetIsSession() (bool, error) { } // Get result and cleanup isSession := _isSession != 0 - return isSession, err + return isSession, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CookieList.go b/webview2/pkg/webview2/ICoreWebView2CookieList.go index f3dce94630c..7ba508f2f71 100644 --- a/webview2/pkg/webview2/ICoreWebView2CookieList.go +++ b/webview2/pkg/webview2/ICoreWebView2CookieList.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2CookieList) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2CookieList) GetValueAtIndex(index uint32) (*ICoreWebView2Cookie, error) { var value *ICoreWebView2Cookie - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2CookieList) GetValueAtIndex(index uint32) (*ICoreWebView2C if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CookieManager.go b/webview2/pkg/webview2/ICoreWebView2CookieManager.go index 9d528a50f7e..52605628b88 100644 --- a/webview2/pkg/webview2/ICoreWebView2CookieManager.go +++ b/webview2/pkg/webview2/ICoreWebView2CookieManager.go @@ -58,7 +58,7 @@ func (i *ICoreWebView2CookieManager) CreateCookie(name string, value string, dom } var cookie *ICoreWebView2Cookie - hr, _, err := i.Vtbl.CreateCookie.Call( + hr, _, _ := i.Vtbl.CreateCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_value)), @@ -69,14 +69,14 @@ func (i *ICoreWebView2CookieManager) CreateCookie(name string, value string, dom if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return cookie, err + return cookie, nil } func (i *ICoreWebView2CookieManager) CopyCookie(cookieParam *ICoreWebView2Cookie) (*ICoreWebView2Cookie, error) { var cookie *ICoreWebView2Cookie - hr, _, err := i.Vtbl.CopyCookie.Call( + hr, _, _ := i.Vtbl.CopyCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(cookieParam)), uintptr(unsafe.Pointer(&cookie)), @@ -84,7 +84,7 @@ func (i *ICoreWebView2CookieManager) CopyCookie(cookieParam *ICoreWebView2Cookie if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return cookie, err + return cookie, nil } func (i *ICoreWebView2CookieManager) GetCookies(uri string, handler *ICoreWebView2GetCookiesCompletedHandler) error { @@ -95,7 +95,7 @@ func (i *ICoreWebView2CookieManager) GetCookies(uri string, handler *ICoreWebVie return err } - hr, _, err := i.Vtbl.GetCookies.Call( + hr, _, _ := i.Vtbl.GetCookies.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(unsafe.Pointer(handler)), @@ -103,33 +103,33 @@ func (i *ICoreWebView2CookieManager) GetCookies(uri string, handler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CookieManager) AddOrUpdateCookie(cookie *ICoreWebView2Cookie) error { - hr, _, err := i.Vtbl.AddOrUpdateCookie.Call( + hr, _, _ := i.Vtbl.AddOrUpdateCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(cookie)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CookieManager) DeleteCookie(cookie *ICoreWebView2Cookie) error { - hr, _, err := i.Vtbl.DeleteCookie.Call( + hr, _, _ := i.Vtbl.DeleteCookie.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(cookie)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CookieManager) DeleteCookies(name string, uri string) error { @@ -145,7 +145,7 @@ func (i *ICoreWebView2CookieManager) DeleteCookies(name string, uri string) erro return err } - hr, _, err := i.Vtbl.DeleteCookies.Call( + hr, _, _ := i.Vtbl.DeleteCookies.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_uri)), @@ -153,7 +153,7 @@ func (i *ICoreWebView2CookieManager) DeleteCookies(name string, uri string) erro if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CookieManager) DeleteCookiesWithDomainAndPath(name string, domain string, path string) error { @@ -174,7 +174,7 @@ func (i *ICoreWebView2CookieManager) DeleteCookiesWithDomainAndPath(name string, return err } - hr, _, err := i.Vtbl.DeleteCookiesWithDomainAndPath.Call( + hr, _, _ := i.Vtbl.DeleteCookiesWithDomainAndPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_domain)), @@ -183,17 +183,17 @@ func (i *ICoreWebView2CookieManager) DeleteCookiesWithDomainAndPath(name string, if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CookieManager) DeleteAllCookies() error { - hr, _, err := i.Vtbl.DeleteAllCookies.Call( + hr, _, _ := i.Vtbl.DeleteAllCookies.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go b/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go index 05b7ec7bb94..59207f39d59 100644 --- a/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go +++ b/webview2/pkg/webview2/ICoreWebView2CustomSchemeRegistration.go @@ -38,7 +38,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetSchemeName() (string, error) var _schemeName *uint16 - hr, _, err := i.Vtbl.GetSchemeName.Call( + hr, _, _ := i.Vtbl.GetSchemeName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_schemeName)), ) @@ -48,14 +48,14 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetSchemeName() (string, error) // Get result and cleanup schemeName := UTF16PtrToString(_schemeName) CoTaskMemFree(unsafe.Pointer(_schemeName)) - return schemeName, err + return schemeName, nil } func (i *ICoreWebView2CustomSchemeRegistration) GetTreatAsSecure() (bool, error) { // Create int32 to hold bool result var _treatAsSecure int32 - hr, _, err := i.Vtbl.GetTreatAsSecure.Call( + hr, _, _ := i.Vtbl.GetTreatAsSecure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_treatAsSecure)), ) @@ -64,7 +64,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetTreatAsSecure() (bool, error) } // Get result and cleanup treatAsSecure := _treatAsSecure != 0 - return treatAsSecure, err + return treatAsSecure, nil } func (i *ICoreWebView2CustomSchemeRegistration) PutTreatAsSecure(value bool) error { @@ -75,14 +75,14 @@ func (i *ICoreWebView2CustomSchemeRegistration) PutTreatAsSecure(value bool) err _value = 1 } - hr, _, err := i.Vtbl.PutTreatAsSecure.Call( + hr, _, _ := i.Vtbl.PutTreatAsSecure.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CustomSchemeRegistration) GetAllowedOrigins() (uint32, *string, error) { @@ -90,7 +90,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetAllowedOrigins() (uint32, *st var allowedOriginsCount uint32 var allowedOrigins *string - hr, _, err := i.Vtbl.GetAllowedOrigins.Call( + hr, _, _ := i.Vtbl.GetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&allowedOriginsCount)), uintptr(unsafe.Pointer(&allowedOrigins)), @@ -98,7 +98,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetAllowedOrigins() (uint32, *st if windows.Handle(hr) != windows.S_OK { return 0, nil, syscall.Errno(hr) } - return allowedOriginsCount, allowedOrigins, err + return allowedOriginsCount, allowedOrigins, nil } func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOriginsCount uint32, allowedOrigins []string) error { @@ -117,7 +117,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOrigins } - hr, _, err := i.Vtbl.SetAllowedOrigins.Call( + hr, _, _ := i.Vtbl.SetAllowedOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(allowedOriginsCount), uintptr(unsafe.Pointer(_allowedOrigins)), @@ -125,14 +125,14 @@ func (i *ICoreWebView2CustomSchemeRegistration) SetAllowedOrigins(allowedOrigins if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2CustomSchemeRegistration) GetHasAuthorityComponent() (bool, error) { // Create int32 to hold bool result var _hasAuthorityComponent int32 - hr, _, err := i.Vtbl.GetHasAuthorityComponent.Call( + hr, _, _ := i.Vtbl.GetHasAuthorityComponent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_hasAuthorityComponent)), ) @@ -141,7 +141,7 @@ func (i *ICoreWebView2CustomSchemeRegistration) GetHasAuthorityComponent() (bool } // Get result and cleanup hasAuthorityComponent := _hasAuthorityComponent != 0 - return hasAuthorityComponent, err + return hasAuthorityComponent, nil } func (i *ICoreWebView2CustomSchemeRegistration) PutHasAuthorityComponent(hasAuthorityComponent bool) error { @@ -152,12 +152,12 @@ func (i *ICoreWebView2CustomSchemeRegistration) PutHasAuthorityComponent(hasAuth _hasAuthorityComponent = 1 } - hr, _, err := i.Vtbl.PutHasAuthorityComponent.Call( + hr, _, _ := i.Vtbl.PutHasAuthorityComponent.Call( uintptr(unsafe.Pointer(i)), uintptr(_hasAuthorityComponent), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go index b39904b2e48..7ad7ed7e56f 100644 --- a/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DOMContentLoadedEventArgs.go @@ -31,12 +31,12 @@ func (i *ICoreWebView2DOMContentLoadedEventArgs) GetNavigationId() (uint64, erro var value uint64 - hr, _, err := i.Vtbl.GetNavigationId.Call( + hr, _, _ := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Deferral.go b/webview2/pkg/webview2/ICoreWebView2Deferral.go index 7a24b0a736c..079a2b9cb90 100644 --- a/webview2/pkg/webview2/ICoreWebView2Deferral.go +++ b/webview2/pkg/webview2/ICoreWebView2Deferral.go @@ -30,11 +30,11 @@ func (i *ICoreWebView2Deferral) Release() uint32 { func (i *ICoreWebView2Deferral) Complete() error { - hr, _, err := i.Vtbl.Complete.Call( + hr, _, _ := i.Vtbl.Complete.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go index e239937f580..6d98cdace13 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) GetParameterObject var _value *uint16 - hr, _, err := i.Vtbl.GetParameterObjectAsJson.Call( + hr, _, _ := i.Vtbl.GetParameterObjectAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -42,5 +42,5 @@ func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs) GetParameterObject // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go index 3db1fd58159..aa8efc01e26 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceivedEventArgs2.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) GetSessionId() (s var _value *uint16 - hr, _, err := i.Vtbl.GetSessionId.Call( + hr, _, _ := i.Vtbl.GetSessionId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -57,5 +57,5 @@ func (i *ICoreWebView2DevToolsProtocolEventReceivedEventArgs2) GetSessionId() (s // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go index 702d3984c47..b9e812be853 100644 --- a/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go +++ b/webview2/pkg/webview2/ICoreWebView2DevToolsProtocolEventReceiver.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2DevToolsProtocolEventReceiver) AddDevToolsProtocolEventRec var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDevToolsProtocolEventReceived.Call( + hr, _, _ := i.Vtbl.AddDevToolsProtocolEventReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -40,18 +40,18 @@ func (i *ICoreWebView2DevToolsProtocolEventReceiver) AddDevToolsProtocolEventRec if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2DevToolsProtocolEventReceiver) RemoveDevToolsProtocolEventReceived(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDevToolsProtocolEventReceived.Call( + hr, _, _ := i.Vtbl.RemoveDevToolsProtocolEventReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go b/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go index 98358d3a7c2..480e60776ad 100644 --- a/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go +++ b/webview2/pkg/webview2/ICoreWebView2DownloadOperation.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2DownloadOperation) AddBytesReceivedChanged(eventHandler *I var token EventRegistrationToken - hr, _, err := i.Vtbl.AddBytesReceivedChanged.Call( + hr, _, _ := i.Vtbl.AddBytesReceivedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -57,27 +57,27 @@ func (i *ICoreWebView2DownloadOperation) AddBytesReceivedChanged(eventHandler *I if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2DownloadOperation) RemoveBytesReceivedChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveBytesReceivedChanged.Call( + hr, _, _ := i.Vtbl.RemoveBytesReceivedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadOperation) AddEstimatedEndTimeChanged(eventHandler *ICoreWebView2EstimatedEndTimeChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddEstimatedEndTimeChanged.Call( + hr, _, _ := i.Vtbl.AddEstimatedEndTimeChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -85,27 +85,27 @@ func (i *ICoreWebView2DownloadOperation) AddEstimatedEndTimeChanged(eventHandler if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2DownloadOperation) RemoveEstimatedEndTimeChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveEstimatedEndTimeChanged.Call( + hr, _, _ := i.Vtbl.RemoveEstimatedEndTimeChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadOperation) AddStateChanged(eventHandler *ICoreWebView2StateChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddStateChanged.Call( + hr, _, _ := i.Vtbl.AddStateChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -113,20 +113,20 @@ func (i *ICoreWebView2DownloadOperation) AddStateChanged(eventHandler *ICoreWebV if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2DownloadOperation) RemoveStateChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveStateChanged.Call( + hr, _, _ := i.Vtbl.RemoveStateChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadOperation) GetUri() (string, error) { @@ -134,7 +134,7 @@ func (i *ICoreWebView2DownloadOperation) GetUri() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -144,7 +144,7 @@ func (i *ICoreWebView2DownloadOperation) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2DownloadOperation) GetContentDisposition() (string, error) { @@ -152,7 +152,7 @@ func (i *ICoreWebView2DownloadOperation) GetContentDisposition() (string, error) var _contentDisposition *uint16 - hr, _, err := i.Vtbl.GetContentDisposition.Call( + hr, _, _ := i.Vtbl.GetContentDisposition.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_contentDisposition)), ) @@ -162,7 +162,7 @@ func (i *ICoreWebView2DownloadOperation) GetContentDisposition() (string, error) // Get result and cleanup contentDisposition := UTF16PtrToString(_contentDisposition) CoTaskMemFree(unsafe.Pointer(_contentDisposition)) - return contentDisposition, err + return contentDisposition, nil } func (i *ICoreWebView2DownloadOperation) GetMimeType() (string, error) { @@ -170,7 +170,7 @@ func (i *ICoreWebView2DownloadOperation) GetMimeType() (string, error) { var _mimeType *uint16 - hr, _, err := i.Vtbl.GetMimeType.Call( + hr, _, _ := i.Vtbl.GetMimeType.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_mimeType)), ) @@ -180,35 +180,35 @@ func (i *ICoreWebView2DownloadOperation) GetMimeType() (string, error) { // Get result and cleanup mimeType := UTF16PtrToString(_mimeType) CoTaskMemFree(unsafe.Pointer(_mimeType)) - return mimeType, err + return mimeType, nil } func (i *ICoreWebView2DownloadOperation) GetTotalBytesToReceive() (int64, error) { var totalBytesToReceive int64 - hr, _, err := i.Vtbl.GetTotalBytesToReceive.Call( + hr, _, _ := i.Vtbl.GetTotalBytesToReceive.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&totalBytesToReceive)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return totalBytesToReceive, err + return totalBytesToReceive, nil } func (i *ICoreWebView2DownloadOperation) GetBytesReceived() (int64, error) { var bytesReceived int64 - hr, _, err := i.Vtbl.GetBytesReceived.Call( + hr, _, _ := i.Vtbl.GetBytesReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&bytesReceived)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return bytesReceived, err + return bytesReceived, nil } func (i *ICoreWebView2DownloadOperation) GetEstimatedEndTime() (string, error) { @@ -216,7 +216,7 @@ func (i *ICoreWebView2DownloadOperation) GetEstimatedEndTime() (string, error) { var _estimatedEndTime *uint16 - hr, _, err := i.Vtbl.GetEstimatedEndTime.Call( + hr, _, _ := i.Vtbl.GetEstimatedEndTime.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_estimatedEndTime)), ) @@ -226,7 +226,7 @@ func (i *ICoreWebView2DownloadOperation) GetEstimatedEndTime() (string, error) { // Get result and cleanup estimatedEndTime := UTF16PtrToString(_estimatedEndTime) CoTaskMemFree(unsafe.Pointer(_estimatedEndTime)) - return estimatedEndTime, err + return estimatedEndTime, nil } func (i *ICoreWebView2DownloadOperation) GetResultFilePath() (string, error) { @@ -234,7 +234,7 @@ func (i *ICoreWebView2DownloadOperation) GetResultFilePath() (string, error) { var _resultFilePath *uint16 - hr, _, err := i.Vtbl.GetResultFilePath.Call( + hr, _, _ := i.Vtbl.GetResultFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_resultFilePath)), ) @@ -244,78 +244,78 @@ func (i *ICoreWebView2DownloadOperation) GetResultFilePath() (string, error) { // Get result and cleanup resultFilePath := UTF16PtrToString(_resultFilePath) CoTaskMemFree(unsafe.Pointer(_resultFilePath)) - return resultFilePath, err + return resultFilePath, nil } func (i *ICoreWebView2DownloadOperation) GetState() (COREWEBVIEW2_DOWNLOAD_STATE, error) { var downloadState COREWEBVIEW2_DOWNLOAD_STATE - hr, _, err := i.Vtbl.GetState.Call( + hr, _, _ := i.Vtbl.GetState.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&downloadState)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return downloadState, err + return downloadState, nil } func (i *ICoreWebView2DownloadOperation) GetInterruptReason() (COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON, error) { var interruptReason COREWEBVIEW2_DOWNLOAD_INTERRUPT_REASON - hr, _, err := i.Vtbl.GetInterruptReason.Call( + hr, _, _ := i.Vtbl.GetInterruptReason.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&interruptReason)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return interruptReason, err + return interruptReason, nil } func (i *ICoreWebView2DownloadOperation) Cancel() error { - hr, _, err := i.Vtbl.Cancel.Call( + hr, _, _ := i.Vtbl.Cancel.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadOperation) Pause() error { - hr, _, err := i.Vtbl.Pause.Call( + hr, _, _ := i.Vtbl.Pause.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadOperation) Resume() error { - hr, _, err := i.Vtbl.Resume.Call( + hr, _, _ := i.Vtbl.Resume.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadOperation) GetCanResume() (bool, error) { // Create int32 to hold bool result var _canResume int32 - hr, _, err := i.Vtbl.GetCanResume.Call( + hr, _, _ := i.Vtbl.GetCanResume.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_canResume)), ) @@ -324,5 +324,5 @@ func (i *ICoreWebView2DownloadOperation) GetCanResume() (bool, error) { } // Get result and cleanup canResume := _canResume != 0 - return canResume, err + return canResume, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go index 2b8ac81cc8b..e7c9a29411c 100644 --- a/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DownloadStartingEventArgs.go @@ -38,21 +38,21 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetDownloadOperation() (*ICoreW var downloadOperation *ICoreWebView2DownloadOperation - hr, _, err := i.Vtbl.GetDownloadOperation.Call( + hr, _, _ := i.Vtbl.GetDownloadOperation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&downloadOperation)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return downloadOperation, err + return downloadOperation, nil } func (i *ICoreWebView2DownloadStartingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _cancel int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_cancel)), ) @@ -61,7 +61,7 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetCancel() (bool, error) { } // Get result and cleanup cancel := _cancel != 0 - return cancel, err + return cancel, nil } func (i *ICoreWebView2DownloadStartingEventArgs) PutCancel(cancel bool) error { @@ -72,14 +72,14 @@ func (i *ICoreWebView2DownloadStartingEventArgs) PutCancel(cancel bool) error { _cancel = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_cancel), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadStartingEventArgs) GetResultFilePath() (string, error) { @@ -87,7 +87,7 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetResultFilePath() (string, er var _resultFilePath *uint16 - hr, _, err := i.Vtbl.GetResultFilePath.Call( + hr, _, _ := i.Vtbl.GetResultFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_resultFilePath)), ) @@ -97,7 +97,7 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetResultFilePath() (string, er // Get result and cleanup resultFilePath := UTF16PtrToString(_resultFilePath) CoTaskMemFree(unsafe.Pointer(_resultFilePath)) - return resultFilePath, err + return resultFilePath, nil } func (i *ICoreWebView2DownloadStartingEventArgs) PutResultFilePath(resultFilePath string) error { @@ -108,21 +108,21 @@ func (i *ICoreWebView2DownloadStartingEventArgs) PutResultFilePath(resultFilePat return err } - hr, _, err := i.Vtbl.PutResultFilePath.Call( + hr, _, _ := i.Vtbl.PutResultFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_resultFilePath)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadStartingEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _handled int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_handled)), ) @@ -131,7 +131,7 @@ func (i *ICoreWebView2DownloadStartingEventArgs) GetHandled() (bool, error) { } // Get result and cleanup handled := _handled != 0 - return handled, err + return handled, nil } func (i *ICoreWebView2DownloadStartingEventArgs) PutHandled(handled bool) error { @@ -142,26 +142,26 @@ func (i *ICoreWebView2DownloadStartingEventArgs) PutHandled(handled bool) error _handled = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_handled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DownloadStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go index d5dc28a3b9b..2aa1d22786e 100644 --- a/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2DragStartingEventArgs.go @@ -36,35 +36,35 @@ func (i *ICoreWebView2DragStartingEventArgs) GetAllowedDropEffects() (uint32, er var value uint32 - hr, _, err := i.Vtbl.GetAllowedDropEffects.Call( + hr, _, _ := i.Vtbl.GetAllowedDropEffects.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2DragStartingEventArgs) GetData() (*IDataObject, error) { var value *IDataObject - hr, _, err := i.Vtbl.GetData.Call( + hr, _, _ := i.Vtbl.GetData.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2DragStartingEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -73,7 +73,7 @@ func (i *ICoreWebView2DragStartingEventArgs) GetHandled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2DragStartingEventArgs) PutHandled(value bool) error { @@ -84,40 +84,40 @@ func (i *ICoreWebView2DragStartingEventArgs) PutHandled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2DragStartingEventArgs) GetPosition() (POINT, error) { var value POINT - hr, _, err := i.Vtbl.GetPosition.Call( + hr, _, _ := i.Vtbl.GetPosition.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2DragStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment.go b/webview2/pkg/webview2/ICoreWebView2Environment.go index 27e5e30904d..1be80156435 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment.go @@ -34,15 +34,15 @@ func (i *ICoreWebView2Environment) Release() uint32 { func (i *ICoreWebView2Environment) CreateCoreWebView2Controller(parentWindow HWND, handler *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) error { - hr, _, err := i.Vtbl.CreateCoreWebView2Controller.Call( + hr, _, _ := i.Vtbl.CreateCoreWebView2Controller.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&parentWindow)), + uintptr(parentWindow), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Environment) CreateWebResourceResponse(content *IStream, statusCode int, reasonPhrase string, headers string) (*ICoreWebView2WebResourceResponse, error) { @@ -59,7 +59,7 @@ func (i *ICoreWebView2Environment) CreateWebResourceResponse(content *IStream, s } var response *ICoreWebView2WebResourceResponse - hr, _, err := i.Vtbl.CreateWebResourceResponse.Call( + hr, _, _ := i.Vtbl.CreateWebResourceResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(content)), uintptr(statusCode), @@ -70,7 +70,7 @@ func (i *ICoreWebView2Environment) CreateWebResourceResponse(content *IStream, s if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return response, err + return response, nil } func (i *ICoreWebView2Environment) GetBrowserVersionString() (string, error) { @@ -78,7 +78,7 @@ func (i *ICoreWebView2Environment) GetBrowserVersionString() (string, error) { var _versionInfo *uint16 - hr, _, err := i.Vtbl.GetBrowserVersionString.Call( + hr, _, _ := i.Vtbl.GetBrowserVersionString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_versionInfo)), ) @@ -88,14 +88,14 @@ func (i *ICoreWebView2Environment) GetBrowserVersionString() (string, error) { // Get result and cleanup versionInfo := UTF16PtrToString(_versionInfo) CoTaskMemFree(unsafe.Pointer(_versionInfo)) - return versionInfo, err + return versionInfo, nil } func (i *ICoreWebView2Environment) AddNewBrowserVersionAvailable(eventHandler *ICoreWebView2NewBrowserVersionAvailableEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNewBrowserVersionAvailable.Call( + hr, _, _ := i.Vtbl.AddNewBrowserVersionAvailable.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -103,18 +103,18 @@ func (i *ICoreWebView2Environment) AddNewBrowserVersionAvailable(eventHandler *I if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Environment) RemoveNewBrowserVersionAvailable(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNewBrowserVersionAvailable.Call( + hr, _, _ := i.Vtbl.RemoveNewBrowserVersionAvailable.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment10.go b/webview2/pkg/webview2/ICoreWebView2Environment10.go index ac506e9a60a..0ca6641d435 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment10.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment10.go @@ -48,42 +48,42 @@ func (i *ICoreWebView2Environment10) CreateCoreWebView2ControllerOptions() (*ICo var value *ICoreWebView2ControllerOptions - hr, _, err := i.Vtbl.CreateCoreWebView2ControllerOptions.Call( + hr, _, _ := i.Vtbl.CreateCoreWebView2ControllerOptions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Environment10) CreateCoreWebView2ControllerWithOptions(ParentWindow HWND, options *ICoreWebView2ControllerOptions, handler *ICoreWebView2CreateCoreWebView2ControllerCompletedHandler) error { - hr, _, err := i.Vtbl.CreateCoreWebView2ControllerWithOptions.Call( + hr, _, _ := i.Vtbl.CreateCoreWebView2ControllerWithOptions.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&ParentWindow)), + uintptr(ParentWindow), uintptr(unsafe.Pointer(options)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Environment10) CreateCoreWebView2CompositionControllerWithOptions(ParentWindow HWND, options *ICoreWebView2ControllerOptions, handler *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) error { - hr, _, err := i.Vtbl.CreateCoreWebView2CompositionControllerWithOptions.Call( + hr, _, _ := i.Vtbl.CreateCoreWebView2CompositionControllerWithOptions.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&ParentWindow)), + uintptr(ParentWindow), uintptr(unsafe.Pointer(options)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment11.go b/webview2/pkg/webview2/ICoreWebView2Environment11.go index a178efde0a8..a2bde8d3fc3 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment11.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment11.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Environment11) GetFailureReportFolderPath() (string, error var _value *uint16 - hr, _, err := i.Vtbl.GetFailureReportFolderPath.Call( + hr, _, _ := i.Vtbl.GetFailureReportFolderPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -57,5 +57,5 @@ func (i *ICoreWebView2Environment11) GetFailureReportFolderPath() (string, error // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment12.go b/webview2/pkg/webview2/ICoreWebView2Environment12.go index 05612beed60..5906915fa5c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment12.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment12.go @@ -46,7 +46,7 @@ func (i *ICoreWebView2Environment12) CreateSharedBuffer(Size uint64) (*ICoreWebV var value *ICoreWebView2SharedBuffer - hr, _, err := i.Vtbl.CreateSharedBuffer.Call( + hr, _, _ := i.Vtbl.CreateSharedBuffer.Call( uintptr(unsafe.Pointer(i)), uintptr(Size), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2Environment12) CreateSharedBuffer(Size uint64) (*ICoreWebV if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment13.go b/webview2/pkg/webview2/ICoreWebView2Environment13.go index 27efa9e9c02..7ff03cc2da3 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment13.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment13.go @@ -45,12 +45,12 @@ func (i *ICoreWebView2) GetICoreWebView2Environment13() (*ICoreWebView2Environme func (i *ICoreWebView2Environment13) GetProcessExtendedInfos(handler *ICoreWebView2GetProcessExtendedInfosCompletedHandler) error { - hr, _, err := i.Vtbl.GetProcessExtendedInfos.Call( + hr, _, _ := i.Vtbl.GetProcessExtendedInfos.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment14.go b/webview2/pkg/webview2/ICoreWebView2Environment14.go index dd97e432159..9b062b00257 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment14.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment14.go @@ -53,7 +53,7 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemFileHandle(path string, } var value *ICoreWebView2FileSystemHandle - hr, _, err := i.Vtbl.CreateWebFileSystemFileHandle.Call( + hr, _, _ := i.Vtbl.CreateWebFileSystemFileHandle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_path)), uintptr(permission), @@ -62,7 +62,7 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemFileHandle(path string, if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Environment14) CreateWebFileSystemDirectoryHandle(path string, permission COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION) (*ICoreWebView2FileSystemHandle, error) { @@ -74,7 +74,7 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemDirectoryHandle(path str } var value *ICoreWebView2FileSystemHandle - hr, _, err := i.Vtbl.CreateWebFileSystemDirectoryHandle.Call( + hr, _, _ := i.Vtbl.CreateWebFileSystemDirectoryHandle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_path)), uintptr(permission), @@ -83,14 +83,14 @@ func (i *ICoreWebView2Environment14) CreateWebFileSystemDirectoryHandle(path str if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Environment14) CreateObjectCollection(length uint32, items **IUnknown) (*ICoreWebView2ObjectCollection, error) { var objectCollection *ICoreWebView2ObjectCollection - hr, _, err := i.Vtbl.CreateObjectCollection.Call( + hr, _, _ := i.Vtbl.CreateObjectCollection.Call( uintptr(unsafe.Pointer(i)), uintptr(length), uintptr(unsafe.Pointer(&items)), @@ -99,5 +99,5 @@ func (i *ICoreWebView2Environment14) CreateObjectCollection(length uint32, items if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return objectCollection, err + return objectCollection, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment15.go b/webview2/pkg/webview2/ICoreWebView2Environment15.go index 99ac15b5b68..602d9d6efb2 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment15.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment15.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2Environment15) CreateFindOptions() (*ICoreWebView2FindOpti var value *ICoreWebView2FindOptions - hr, _, err := i.Vtbl.CreateFindOptions.Call( + hr, _, _ := i.Vtbl.CreateFindOptions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment2.go b/webview2/pkg/webview2/ICoreWebView2Environment2.go index cf10892ca7b..cfcb1ab1ac0 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment2.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment2.go @@ -61,7 +61,7 @@ func (i *ICoreWebView2Environment2) CreateWebResourceRequest(uri string, Method } var value *ICoreWebView2WebResourceRequest - hr, _, err := i.Vtbl.CreateWebResourceRequest.Call( + hr, _, _ := i.Vtbl.CreateWebResourceRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(unsafe.Pointer(_Method)), @@ -72,5 +72,5 @@ func (i *ICoreWebView2Environment2) CreateWebResourceRequest(uri string, Method if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment3.go b/webview2/pkg/webview2/ICoreWebView2Environment3.go index d0f9cb884c0..77f5bc27d4a 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment3.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment3.go @@ -46,27 +46,27 @@ func (i *ICoreWebView2) GetICoreWebView2Environment3() (*ICoreWebView2Environmen func (i *ICoreWebView2Environment3) CreateCoreWebView2CompositionController(ParentWindow HWND, handler *ICoreWebView2CreateCoreWebView2CompositionControllerCompletedHandler) error { - hr, _, err := i.Vtbl.CreateCoreWebView2CompositionController.Call( + hr, _, _ := i.Vtbl.CreateCoreWebView2CompositionController.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&ParentWindow)), + uintptr(ParentWindow), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Environment3) CreateCoreWebView2PointerInfo() (*ICoreWebView2PointerInfo, error) { var value *ICoreWebView2PointerInfo - hr, _, err := i.Vtbl.CreateCoreWebView2PointerInfo.Call( + hr, _, _ := i.Vtbl.CreateCoreWebView2PointerInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment4.go b/webview2/pkg/webview2/ICoreWebView2Environment4.go index 66a8d1452ee..d5f99124d4f 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment4.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment4.go @@ -46,13 +46,13 @@ func (i *ICoreWebView2Environment4) GetAutomationProviderForWindow(hwnd HWND) (* var value *IUnknown - hr, _, err := i.Vtbl.GetAutomationProviderForWindow.Call( + hr, _, _ := i.Vtbl.GetAutomationProviderForWindow.Call( uintptr(unsafe.Pointer(i)), - uintptr(unsafe.Pointer(&hwnd)), + uintptr(hwnd), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment5.go b/webview2/pkg/webview2/ICoreWebView2Environment5.go index 9c984d7b51b..d46cf16dbe5 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment5.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment5.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Environment5) AddBrowserProcessExited(eventHandler *ICoreW var token EventRegistrationToken - hr, _, err := i.Vtbl.AddBrowserProcessExited.Call( + hr, _, _ := i.Vtbl.AddBrowserProcessExited.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2Environment5) AddBrowserProcessExited(eventHandler *ICoreW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Environment5) RemoveBrowserProcessExited(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveBrowserProcessExited.Call( + hr, _, _ := i.Vtbl.RemoveBrowserProcessExited.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment6.go b/webview2/pkg/webview2/ICoreWebView2Environment6.go index 453a51fd70c..101dfc9605b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment6.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment6.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2Environment6) CreatePrintSettings() (*ICoreWebView2PrintSe var value *ICoreWebView2PrintSettings - hr, _, err := i.Vtbl.CreatePrintSettings.Call( + hr, _, _ := i.Vtbl.CreatePrintSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment7.go b/webview2/pkg/webview2/ICoreWebView2Environment7.go index b475f57289a..955c41bd970 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment7.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment7.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Environment7) GetUserDataFolder() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetUserDataFolder.Call( + hr, _, _ := i.Vtbl.GetUserDataFolder.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -57,5 +57,5 @@ func (i *ICoreWebView2Environment7) GetUserDataFolder() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment8.go b/webview2/pkg/webview2/ICoreWebView2Environment8.go index 1d5d1d726cf..e0aed7be3d3 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment8.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment8.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2Environment8) AddProcessInfosChanged(eventHandler *ICoreWe var token EventRegistrationToken - hr, _, err := i.Vtbl.AddProcessInfosChanged.Call( + hr, _, _ := i.Vtbl.AddProcessInfosChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -56,32 +56,32 @@ func (i *ICoreWebView2Environment8) AddProcessInfosChanged(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Environment8) RemoveProcessInfosChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveProcessInfosChanged.Call( + hr, _, _ := i.Vtbl.RemoveProcessInfosChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Environment8) GetProcessInfos() (*ICoreWebView2ProcessInfoCollection, error) { var value *ICoreWebView2ProcessInfoCollection - hr, _, err := i.Vtbl.GetProcessInfos.Call( + hr, _, _ := i.Vtbl.GetProcessInfos.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Environment9.go b/webview2/pkg/webview2/ICoreWebView2Environment9.go index 25fc49e610e..40ea34ee2c3 100644 --- a/webview2/pkg/webview2/ICoreWebView2Environment9.go +++ b/webview2/pkg/webview2/ICoreWebView2Environment9.go @@ -51,7 +51,7 @@ func (i *ICoreWebView2Environment9) CreateContextMenuItem(Label string, iconStre } var value *ICoreWebView2ContextMenuItem - hr, _, err := i.Vtbl.CreateContextMenuItem.Call( + hr, _, _ := i.Vtbl.CreateContextMenuItem.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_Label)), uintptr(unsafe.Pointer(iconStream)), @@ -61,5 +61,5 @@ func (i *ICoreWebView2Environment9) CreateContextMenuItem(Label string, iconStre if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go index 8133c0b6924..abf44412ee1 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions.go @@ -39,7 +39,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetAdditionalBrowserArguments() (strin var _value *uint16 - hr, _, err := i.Vtbl.GetAdditionalBrowserArguments.Call( + hr, _, _ := i.Vtbl.GetAdditionalBrowserArguments.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -49,7 +49,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetAdditionalBrowserArguments() (strin // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions) PutAdditionalBrowserArguments(value string) error { @@ -60,14 +60,14 @@ func (i *ICoreWebView2EnvironmentOptions) PutAdditionalBrowserArguments(value st return err } - hr, _, err := i.Vtbl.PutAdditionalBrowserArguments.Call( + hr, _, _ := i.Vtbl.PutAdditionalBrowserArguments.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2EnvironmentOptions) GetLanguage() (string, error) { @@ -75,7 +75,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetLanguage() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetLanguage.Call( + hr, _, _ := i.Vtbl.GetLanguage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -85,7 +85,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetLanguage() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions) PutLanguage(value string) error { @@ -96,14 +96,14 @@ func (i *ICoreWebView2EnvironmentOptions) PutLanguage(value string) error { return err } - hr, _, err := i.Vtbl.PutLanguage.Call( + hr, _, _ := i.Vtbl.PutLanguage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2EnvironmentOptions) GetTargetCompatibleBrowserVersion() (string, error) { @@ -111,7 +111,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetTargetCompatibleBrowserVersion() (s var _value *uint16 - hr, _, err := i.Vtbl.GetTargetCompatibleBrowserVersion.Call( + hr, _, _ := i.Vtbl.GetTargetCompatibleBrowserVersion.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -121,7 +121,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetTargetCompatibleBrowserVersion() (s // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions) PutTargetCompatibleBrowserVersion(value string) error { @@ -132,21 +132,21 @@ func (i *ICoreWebView2EnvironmentOptions) PutTargetCompatibleBrowserVersion(valu return err } - hr, _, err := i.Vtbl.PutTargetCompatibleBrowserVersion.Call( + hr, _, _ := i.Vtbl.PutTargetCompatibleBrowserVersion.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2EnvironmentOptions) GetAllowSingleSignOnUsingOSPrimaryAccount() (bool, error) { // Create int32 to hold bool result var _allow int32 - hr, _, err := i.Vtbl.GetAllowSingleSignOnUsingOSPrimaryAccount.Call( + hr, _, _ := i.Vtbl.GetAllowSingleSignOnUsingOSPrimaryAccount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_allow)), ) @@ -155,7 +155,7 @@ func (i *ICoreWebView2EnvironmentOptions) GetAllowSingleSignOnUsingOSPrimaryAcco } // Get result and cleanup allow := _allow != 0 - return allow, err + return allow, nil } func (i *ICoreWebView2EnvironmentOptions) PutAllowSingleSignOnUsingOSPrimaryAccount(allow bool) error { @@ -166,12 +166,12 @@ func (i *ICoreWebView2EnvironmentOptions) PutAllowSingleSignOnUsingOSPrimaryAcco _allow = 1 } - hr, _, err := i.Vtbl.PutAllowSingleSignOnUsingOSPrimaryAccount.Call( + hr, _, _ := i.Vtbl.PutAllowSingleSignOnUsingOSPrimaryAccount.Call( uintptr(unsafe.Pointer(i)), uintptr(_allow), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go index 7f4c263fc6b..8366d7dc713 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions2.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2EnvironmentOptions2) GetExclusiveUserDataFolderAccess() (b // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetExclusiveUserDataFolderAccess.Call( + hr, _, _ := i.Vtbl.GetExclusiveUserDataFolderAccess.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -41,7 +41,7 @@ func (i *ICoreWebView2EnvironmentOptions2) GetExclusiveUserDataFolderAccess() (b } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions2) PutExclusiveUserDataFolderAccess(value bool) error { @@ -52,12 +52,12 @@ func (i *ICoreWebView2EnvironmentOptions2) PutExclusiveUserDataFolderAccess(valu _value = 1 } - hr, _, err := i.Vtbl.PutExclusiveUserDataFolderAccess.Call( + hr, _, _ := i.Vtbl.PutExclusiveUserDataFolderAccess.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go index b19d353261f..24a292885bc 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions3.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2EnvironmentOptions3) GetIsCustomCrashReportingEnabled() (b // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsCustomCrashReportingEnabled.Call( + hr, _, _ := i.Vtbl.GetIsCustomCrashReportingEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -41,7 +41,7 @@ func (i *ICoreWebView2EnvironmentOptions3) GetIsCustomCrashReportingEnabled() (b } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions3) PutIsCustomCrashReportingEnabled(value bool) error { @@ -52,12 +52,12 @@ func (i *ICoreWebView2EnvironmentOptions3) PutIsCustomCrashReportingEnabled(valu _value = 1 } - hr, _, err := i.Vtbl.PutIsCustomCrashReportingEnabled.Call( + hr, _, _ := i.Vtbl.PutIsCustomCrashReportingEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go index 5a71f081c3e..e7b933cdf27 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions4.go @@ -33,7 +33,7 @@ func (i *ICoreWebView2EnvironmentOptions4) GetCustomSchemeRegistrations() (uint3 var count uint32 var schemeRegistrations ICoreWebView2CustomSchemeRegistration - hr, _, err := i.Vtbl.GetCustomSchemeRegistrations.Call( + hr, _, _ := i.Vtbl.GetCustomSchemeRegistrations.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&count)), uintptr(unsafe.Pointer(&schemeRegistrations)), @@ -41,13 +41,13 @@ func (i *ICoreWebView2EnvironmentOptions4) GetCustomSchemeRegistrations() (uint3 if windows.Handle(hr) != windows.S_OK { return 0, ICoreWebView2CustomSchemeRegistration{}, syscall.Errno(hr) } - return count, schemeRegistrations, err + return count, schemeRegistrations, nil } func (i *ICoreWebView2EnvironmentOptions4) SetCustomSchemeRegistrations(count uint32, schemeRegistrations **ICoreWebView2CustomSchemeRegistration) error { - hr, _, err := i.Vtbl.SetCustomSchemeRegistrations.Call( + hr, _, _ := i.Vtbl.SetCustomSchemeRegistrations.Call( uintptr(unsafe.Pointer(i)), uintptr(count), uintptr(unsafe.Pointer(&schemeRegistrations)), @@ -55,5 +55,5 @@ func (i *ICoreWebView2EnvironmentOptions4) SetCustomSchemeRegistrations(count ui if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go index 2efe04641e7..043a73fccb8 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions5.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2EnvironmentOptions5) GetEnableTrackingPrevention() (bool, // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetEnableTrackingPrevention.Call( + hr, _, _ := i.Vtbl.GetEnableTrackingPrevention.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -41,7 +41,7 @@ func (i *ICoreWebView2EnvironmentOptions5) GetEnableTrackingPrevention() (bool, } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions5) PutEnableTrackingPrevention(value bool) error { @@ -52,12 +52,12 @@ func (i *ICoreWebView2EnvironmentOptions5) PutEnableTrackingPrevention(value boo _value = 1 } - hr, _, err := i.Vtbl.PutEnableTrackingPrevention.Call( + hr, _, _ := i.Vtbl.PutEnableTrackingPrevention.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go index dd35988512c..7ced2a56098 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions6.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2EnvironmentOptions6) GetAreBrowserExtensionsEnabled() (boo // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetAreBrowserExtensionsEnabled.Call( + hr, _, _ := i.Vtbl.GetAreBrowserExtensionsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -41,7 +41,7 @@ func (i *ICoreWebView2EnvironmentOptions6) GetAreBrowserExtensionsEnabled() (boo } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions6) PutAreBrowserExtensionsEnabled(value bool) error { @@ -52,12 +52,12 @@ func (i *ICoreWebView2EnvironmentOptions6) PutAreBrowserExtensionsEnabled(value _value = 1 } - hr, _, err := i.Vtbl.PutAreBrowserExtensionsEnabled.Call( + hr, _, _ := i.Vtbl.PutAreBrowserExtensionsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go index 31bdcfc86fc..72d1de34b86 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions7.go @@ -34,52 +34,52 @@ func (i *ICoreWebView2EnvironmentOptions7) GetChannelSearchKind() (COREWEBVIEW2_ var value COREWEBVIEW2_CHANNEL_SEARCH_KIND - hr, _, err := i.Vtbl.GetChannelSearchKind.Call( + hr, _, _ := i.Vtbl.GetChannelSearchKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions7) PutChannelSearchKind(value COREWEBVIEW2_CHANNEL_SEARCH_KIND) error { - hr, _, err := i.Vtbl.PutChannelSearchKind.Call( + hr, _, _ := i.Vtbl.PutChannelSearchKind.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2EnvironmentOptions7) GetReleaseChannels() (COREWEBVIEW2_RELEASE_CHANNELS, error) { var value COREWEBVIEW2_RELEASE_CHANNELS - hr, _, err := i.Vtbl.GetReleaseChannels.Call( + hr, _, _ := i.Vtbl.GetReleaseChannels.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions7) PutReleaseChannels(value COREWEBVIEW2_RELEASE_CHANNELS) error { - hr, _, err := i.Vtbl.PutReleaseChannels.Call( + hr, _, _ := i.Vtbl.PutReleaseChannels.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go index bc943c3719d..5fb779d37e1 100644 --- a/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go +++ b/webview2/pkg/webview2/ICoreWebView2EnvironmentOptions8.go @@ -32,25 +32,25 @@ func (i *ICoreWebView2EnvironmentOptions8) GetScrollBarStyle() (COREWEBVIEW2_SCR var value COREWEBVIEW2_SCROLLBAR_STYLE - hr, _, err := i.Vtbl.GetScrollBarStyle.Call( + hr, _, _ := i.Vtbl.GetScrollBarStyle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2EnvironmentOptions8) PutScrollBarStyle(value COREWEBVIEW2_SCROLLBAR_STYLE) error { - hr, _, err := i.Vtbl.PutScrollBarStyle.Call( + hr, _, _ := i.Vtbl.PutScrollBarStyle.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go index 00ecc34026a..c6ed0c00915 100644 --- a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go +++ b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptCompletedHandler.go @@ -37,8 +37,9 @@ func ICoreWebView2ExecuteScriptCompletedHandlerIUnknownRelease(this *ICoreWebVie return uintptr(this.impl.Release()) } -func ICoreWebView2ExecuteScriptCompletedHandlerInvoke(this *ICoreWebView2ExecuteScriptCompletedHandler, errorCode uintptr, result string) uintptr { - return this.impl.ExecuteScriptCompleted(errorCode, result) +func ICoreWebView2ExecuteScriptCompletedHandlerInvoke(this *ICoreWebView2ExecuteScriptCompletedHandler, errorCode uintptr, result *uint16) uintptr { + _result := UTF16PtrToString(result) + return this.impl.ExecuteScriptCompleted(errorCode, _result) } type ICoreWebView2ExecuteScriptCompletedHandlerImpl interface { diff --git a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go index 1c31e733f0a..1d231b8f1ea 100644 --- a/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go +++ b/webview2/pkg/webview2/ICoreWebView2ExecuteScriptResult.go @@ -34,7 +34,7 @@ func (i *ICoreWebView2ExecuteScriptResult) GetSucceeded() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetSucceeded.Call( + hr, _, _ := i.Vtbl.GetSucceeded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -43,7 +43,7 @@ func (i *ICoreWebView2ExecuteScriptResult) GetSucceeded() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ExecuteScriptResult) GetResultAsJson() (string, error) { @@ -51,7 +51,7 @@ func (i *ICoreWebView2ExecuteScriptResult) GetResultAsJson() (string, error) { var _jsonResult *uint16 - hr, _, err := i.Vtbl.GetResultAsJson.Call( + hr, _, _ := i.Vtbl.GetResultAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_jsonResult)), ) @@ -61,7 +61,7 @@ func (i *ICoreWebView2ExecuteScriptResult) GetResultAsJson() (string, error) { // Get result and cleanup jsonResult := UTF16PtrToString(_jsonResult) CoTaskMemFree(unsafe.Pointer(_jsonResult)) - return jsonResult, err + return jsonResult, nil } func (i *ICoreWebView2ExecuteScriptResult) TryGetResultAsString() (string, bool, error) { @@ -70,7 +70,7 @@ func (i *ICoreWebView2ExecuteScriptResult) TryGetResultAsString() (string, bool, // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.TryGetResultAsString.Call( + hr, _, _ := i.Vtbl.TryGetResultAsString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_stringResult)), uintptr(unsafe.Pointer(&_value)), @@ -83,19 +83,19 @@ func (i *ICoreWebView2ExecuteScriptResult) TryGetResultAsString() (string, bool, CoTaskMemFree(unsafe.Pointer(_stringResult)) // Get result and cleanup value := _value != 0 - return stringResult, value, err + return stringResult, value, nil } func (i *ICoreWebView2ExecuteScriptResult) GetException() (*ICoreWebView2ScriptException, error) { var exception *ICoreWebView2ScriptException - hr, _, err := i.Vtbl.GetException.Call( + hr, _, _ := i.Vtbl.GetException.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&exception)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return exception, err + return exception, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2File.go b/webview2/pkg/webview2/ICoreWebView2File.go index e3e9b0e061d..aa16269c75b 100644 --- a/webview2/pkg/webview2/ICoreWebView2File.go +++ b/webview2/pkg/webview2/ICoreWebView2File.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2File) GetPath() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetPath.Call( + hr, _, _ := i.Vtbl.GetPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -42,5 +42,5 @@ func (i *ICoreWebView2File) GetPath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go b/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go index b4be106bf12..79a1e56074d 100644 --- a/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go +++ b/webview2/pkg/webview2/ICoreWebView2FileSystemHandle.go @@ -33,14 +33,14 @@ func (i *ICoreWebView2FileSystemHandle) GetKind() (COREWEBVIEW2_FILE_SYSTEM_HAND var value COREWEBVIEW2_FILE_SYSTEM_HANDLE_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2FileSystemHandle) GetPath() (string, error) { @@ -48,7 +48,7 @@ func (i *ICoreWebView2FileSystemHandle) GetPath() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetPath.Call( + hr, _, _ := i.Vtbl.GetPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,19 +58,19 @@ func (i *ICoreWebView2FileSystemHandle) GetPath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2FileSystemHandle) GetPermission() (COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION, error) { var value COREWEBVIEW2_FILE_SYSTEM_HANDLE_PERMISSION - hr, _, err := i.Vtbl.GetPermission.Call( + hr, _, _ := i.Vtbl.GetPermission.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Find.go b/webview2/pkg/webview2/ICoreWebView2Find.go index 4f901067101..57fb36039e7 100644 --- a/webview2/pkg/webview2/ICoreWebView2Find.go +++ b/webview2/pkg/webview2/ICoreWebView2Find.go @@ -40,35 +40,35 @@ func (i *ICoreWebView2Find) GetActiveMatchIndex() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetActiveMatchIndex.Call( + hr, _, _ := i.Vtbl.GetActiveMatchIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Find) GetMatchCount() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetMatchCount.Call( + hr, _, _ := i.Vtbl.GetMatchCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Find) AddActiveMatchIndexChanged(eventHandler *ICoreWebView2FindActiveMatchIndexChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddActiveMatchIndexChanged.Call( + hr, _, _ := i.Vtbl.AddActiveMatchIndexChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -76,27 +76,27 @@ func (i *ICoreWebView2Find) AddActiveMatchIndexChanged(eventHandler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Find) RemoveActiveMatchIndexChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveActiveMatchIndexChanged.Call( + hr, _, _ := i.Vtbl.RemoveActiveMatchIndexChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Find) AddMatchCountChanged(eventHandler *ICoreWebView2FindMatchCountChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddMatchCountChanged.Call( + hr, _, _ := i.Vtbl.AddMatchCountChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -104,26 +104,26 @@ func (i *ICoreWebView2Find) AddMatchCountChanged(eventHandler *ICoreWebView2Find if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Find) RemoveMatchCountChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveMatchCountChanged.Call( + hr, _, _ := i.Vtbl.RemoveMatchCountChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Find) Start(options *ICoreWebView2FindOptions, handler *ICoreWebView2FindStartCompletedHandler) error { - hr, _, err := i.Vtbl.Start.Call( + hr, _, _ := i.Vtbl.Start.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(options)), uintptr(unsafe.Pointer(handler)), @@ -131,41 +131,41 @@ func (i *ICoreWebView2Find) Start(options *ICoreWebView2FindOptions, handler *IC if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Find) FindNext() error { - hr, _, err := i.Vtbl.FindNext.Call( + hr, _, _ := i.Vtbl.FindNext.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Find) FindPrevious() error { - hr, _, err := i.Vtbl.FindPrevious.Call( + hr, _, _ := i.Vtbl.FindPrevious.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Find) Stop() error { - hr, _, err := i.Vtbl.Stop.Call( + hr, _, _ := i.Vtbl.Stop.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FindOptions.go b/webview2/pkg/webview2/ICoreWebView2FindOptions.go index c2fcb4bbf5f..a4bb8497512 100644 --- a/webview2/pkg/webview2/ICoreWebView2FindOptions.go +++ b/webview2/pkg/webview2/ICoreWebView2FindOptions.go @@ -41,7 +41,7 @@ func (i *ICoreWebView2FindOptions) GetFindTerm() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetFindTerm.Call( + hr, _, _ := i.Vtbl.GetFindTerm.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -51,7 +51,7 @@ func (i *ICoreWebView2FindOptions) GetFindTerm() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2FindOptions) PutFindTerm(value string) error { @@ -62,21 +62,21 @@ func (i *ICoreWebView2FindOptions) PutFindTerm(value string) error { return err } - hr, _, err := i.Vtbl.PutFindTerm.Call( + hr, _, _ := i.Vtbl.PutFindTerm.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2FindOptions) GetIsCaseSensitive() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsCaseSensitive.Call( + hr, _, _ := i.Vtbl.GetIsCaseSensitive.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -85,7 +85,7 @@ func (i *ICoreWebView2FindOptions) GetIsCaseSensitive() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2FindOptions) PutIsCaseSensitive(value bool) error { @@ -96,21 +96,21 @@ func (i *ICoreWebView2FindOptions) PutIsCaseSensitive(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsCaseSensitive.Call( + hr, _, _ := i.Vtbl.PutIsCaseSensitive.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2FindOptions) GetShouldHighlightAllMatches() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldHighlightAllMatches.Call( + hr, _, _ := i.Vtbl.GetShouldHighlightAllMatches.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -119,7 +119,7 @@ func (i *ICoreWebView2FindOptions) GetShouldHighlightAllMatches() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2FindOptions) PutShouldHighlightAllMatches(value bool) error { @@ -130,21 +130,21 @@ func (i *ICoreWebView2FindOptions) PutShouldHighlightAllMatches(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutShouldHighlightAllMatches.Call( + hr, _, _ := i.Vtbl.PutShouldHighlightAllMatches.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2FindOptions) GetShouldMatchWord() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldMatchWord.Call( + hr, _, _ := i.Vtbl.GetShouldMatchWord.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -153,7 +153,7 @@ func (i *ICoreWebView2FindOptions) GetShouldMatchWord() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2FindOptions) PutShouldMatchWord(value bool) error { @@ -164,21 +164,21 @@ func (i *ICoreWebView2FindOptions) PutShouldMatchWord(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutShouldMatchWord.Call( + hr, _, _ := i.Vtbl.PutShouldMatchWord.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2FindOptions) GetSuppressDefaultFindDialog() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetSuppressDefaultFindDialog.Call( + hr, _, _ := i.Vtbl.GetSuppressDefaultFindDialog.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -187,7 +187,7 @@ func (i *ICoreWebView2FindOptions) GetSuppressDefaultFindDialog() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2FindOptions) PutSuppressDefaultFindDialog(value bool) error { @@ -198,12 +198,12 @@ func (i *ICoreWebView2FindOptions) PutSuppressDefaultFindDialog(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutSuppressDefaultFindDialog.Call( + hr, _, _ := i.Vtbl.PutSuppressDefaultFindDialog.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame.go b/webview2/pkg/webview2/ICoreWebView2Frame.go index 0e71106fbd0..50f7d6a254a 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame.go @@ -39,7 +39,7 @@ func (i *ICoreWebView2Frame) GetName() (string, error) { var _name *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_name)), ) @@ -49,14 +49,14 @@ func (i *ICoreWebView2Frame) GetName() (string, error) { // Get result and cleanup name := UTF16PtrToString(_name) CoTaskMemFree(unsafe.Pointer(_name)) - return name, err + return name, nil } func (i *ICoreWebView2Frame) AddNameChanged(eventHandler *ICoreWebView2FrameNameChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNameChanged.Call( + hr, _, _ := i.Vtbl.AddNameChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -64,20 +64,20 @@ func (i *ICoreWebView2Frame) AddNameChanged(eventHandler *ICoreWebView2FrameName if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame) RemoveNameChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNameChanged.Call( + hr, _, _ := i.Vtbl.RemoveNameChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame) AddHostObjectToScriptWithOrigins(name string, object *VARIANT, originsCount uint32, origins []string) error { @@ -101,7 +101,7 @@ func (i *ICoreWebView2Frame) AddHostObjectToScriptWithOrigins(name string, objec } - hr, _, err := i.Vtbl.AddHostObjectToScriptWithOrigins.Call( + hr, _, _ := i.Vtbl.AddHostObjectToScriptWithOrigins.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(object)), @@ -111,7 +111,7 @@ func (i *ICoreWebView2Frame) AddHostObjectToScriptWithOrigins(name string, objec if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame) RemoveHostObjectFromScript(name string) error { @@ -122,21 +122,21 @@ func (i *ICoreWebView2Frame) RemoveHostObjectFromScript(name string) error { return err } - hr, _, err := i.Vtbl.RemoveHostObjectFromScript.Call( + hr, _, _ := i.Vtbl.RemoveHostObjectFromScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame) AddDestroyed(eventHandler *ICoreWebView2FrameDestroyedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDestroyed.Call( + hr, _, _ := i.Vtbl.AddDestroyed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -144,27 +144,27 @@ func (i *ICoreWebView2Frame) AddDestroyed(eventHandler *ICoreWebView2FrameDestro if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame) RemoveDestroyed(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDestroyed.Call( + hr, _, _ := i.Vtbl.RemoveDestroyed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame) IsDestroyed() (bool, error) { // Create int32 to hold bool result var _destroyed int32 - hr, _, err := i.Vtbl.IsDestroyed.Call( + hr, _, _ := i.Vtbl.IsDestroyed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_destroyed)), ) @@ -173,5 +173,5 @@ func (i *ICoreWebView2Frame) IsDestroyed() (bool, error) { } // Get result and cleanup destroyed := _destroyed != 0 - return destroyed, err + return destroyed, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame2.go b/webview2/pkg/webview2/ICoreWebView2Frame2.go index 735122b486c..af0377ce405 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame2.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame2.go @@ -58,7 +58,7 @@ func (i *ICoreWebView2Frame2) AddNavigationStarting(eventHandler *ICoreWebView2F var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNavigationStarting.Call( + hr, _, _ := i.Vtbl.AddNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -66,27 +66,27 @@ func (i *ICoreWebView2Frame2) AddNavigationStarting(eventHandler *ICoreWebView2F if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame2) RemoveNavigationStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNavigationStarting.Call( + hr, _, _ := i.Vtbl.RemoveNavigationStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) AddContentLoading(eventHandler *ICoreWebView2FrameContentLoadingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddContentLoading.Call( + hr, _, _ := i.Vtbl.AddContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -94,27 +94,27 @@ func (i *ICoreWebView2Frame2) AddContentLoading(eventHandler *ICoreWebView2Frame if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame2) RemoveContentLoading(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveContentLoading.Call( + hr, _, _ := i.Vtbl.RemoveContentLoading.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) AddNavigationCompleted(eventHandler *ICoreWebView2FrameNavigationCompletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNavigationCompleted.Call( + hr, _, _ := i.Vtbl.AddNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -122,27 +122,27 @@ func (i *ICoreWebView2Frame2) AddNavigationCompleted(eventHandler *ICoreWebView2 if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame2) RemoveNavigationCompleted(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNavigationCompleted.Call( + hr, _, _ := i.Vtbl.RemoveNavigationCompleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) AddDOMContentLoaded(eventHandler *ICoreWebView2FrameDOMContentLoadedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDOMContentLoaded.Call( + hr, _, _ := i.Vtbl.AddDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -150,20 +150,20 @@ func (i *ICoreWebView2Frame2) AddDOMContentLoaded(eventHandler *ICoreWebView2Fra if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame2) RemoveDOMContentLoaded(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDOMContentLoaded.Call( + hr, _, _ := i.Vtbl.RemoveDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) ExecuteScript(javaScript string, handler *ICoreWebView2ExecuteScriptCompletedHandler) error { @@ -174,7 +174,7 @@ func (i *ICoreWebView2Frame2) ExecuteScript(javaScript string, handler *ICoreWeb return err } - hr, _, err := i.Vtbl.ExecuteScript.Call( + hr, _, _ := i.Vtbl.ExecuteScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -182,7 +182,7 @@ func (i *ICoreWebView2Frame2) ExecuteScript(javaScript string, handler *ICoreWeb if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) PostWebMessageAsJson(webMessageAsJson string) error { @@ -193,14 +193,14 @@ func (i *ICoreWebView2Frame2) PostWebMessageAsJson(webMessageAsJson string) erro return err } - hr, _, err := i.Vtbl.PostWebMessageAsJson.Call( + hr, _, _ := i.Vtbl.PostWebMessageAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsJson)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) PostWebMessageAsString(webMessageAsString string) error { @@ -211,21 +211,21 @@ func (i *ICoreWebView2Frame2) PostWebMessageAsString(webMessageAsString string) return err } - hr, _, err := i.Vtbl.PostWebMessageAsString.Call( + hr, _, _ := i.Vtbl.PostWebMessageAsString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsString)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Frame2) AddWebMessageReceived(handler *ICoreWebView2FrameWebMessageReceivedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddWebMessageReceived.Call( + hr, _, _ := i.Vtbl.AddWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), uintptr(unsafe.Pointer(&token)), @@ -233,18 +233,18 @@ func (i *ICoreWebView2Frame2) AddWebMessageReceived(handler *ICoreWebView2FrameW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame2) RemoveWebMessageReceived(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveWebMessageReceived.Call( + hr, _, _ := i.Vtbl.RemoveWebMessageReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame3.go b/webview2/pkg/webview2/ICoreWebView2Frame3.go index 960f6d296ac..26f90c7216c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame3.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame3.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Frame3) AddPermissionRequested(eventHandler *ICoreWebView2 var token EventRegistrationToken - hr, _, err := i.Vtbl.AddPermissionRequested.Call( + hr, _, _ := i.Vtbl.AddPermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2Frame3) AddPermissionRequested(eventHandler *ICoreWebView2 if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame3) RemovePermissionRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemovePermissionRequested.Call( + hr, _, _ := i.Vtbl.RemovePermissionRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame4.go b/webview2/pkg/webview2/ICoreWebView2Frame4.go index 9cdc9823fa6..00ae8102cc7 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame4.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame4.go @@ -50,7 +50,7 @@ func (i *ICoreWebView2Frame4) PostSharedBufferToScript(sharedBuffer *ICoreWebVie return err } - hr, _, err := i.Vtbl.PostSharedBufferToScript.Call( + hr, _, _ := i.Vtbl.PostSharedBufferToScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(sharedBuffer)), uintptr(access), @@ -59,5 +59,5 @@ func (i *ICoreWebView2Frame4) PostSharedBufferToScript(sharedBuffer *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame5.go b/webview2/pkg/webview2/ICoreWebView2Frame5.go index a34882e0244..3709bf2f0a7 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame5.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame5.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2Frame5) GetFrameId() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetFrameId.Call( + hr, _, _ := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame6.go b/webview2/pkg/webview2/ICoreWebView2Frame6.go index 5d74b3891f7..e68bd24d03d 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame6.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame6.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Frame6) AddScreenCaptureStarting(eventHandler *ICoreWebVie var token EventRegistrationToken - hr, _, err := i.Vtbl.AddScreenCaptureStarting.Call( + hr, _, _ := i.Vtbl.AddScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2Frame6) AddScreenCaptureStarting(eventHandler *ICoreWebVie if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame6) RemoveScreenCaptureStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveScreenCaptureStarting.Call( + hr, _, _ := i.Vtbl.RemoveScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Frame7.go b/webview2/pkg/webview2/ICoreWebView2Frame7.go index c332deb51c3..fcf5441bc66 100644 --- a/webview2/pkg/webview2/ICoreWebView2Frame7.go +++ b/webview2/pkg/webview2/ICoreWebView2Frame7.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Frame7) AddFrameCreated(eventHandler *ICoreWebView2FrameCh var token EventRegistrationToken - hr, _, err := i.Vtbl.AddFrameCreated.Call( + hr, _, _ := i.Vtbl.AddFrameCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2Frame7) AddFrameCreated(eventHandler *ICoreWebView2FrameCh if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Frame7) RemoveFrameCreated(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveFrameCreated.Call( + hr, _, _ := i.Vtbl.RemoveFrameCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go index b626d4b56fb..6ed0ac10920 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameCreatedEventArgs.go @@ -31,12 +31,12 @@ func (i *ICoreWebView2FrameCreatedEventArgs) GetFrame() (*ICoreWebView2Frame, er var value *ICoreWebView2Frame - hr, _, err := i.Vtbl.GetFrame.Call( + hr, _, _ := i.Vtbl.GetFrame.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfo.go b/webview2/pkg/webview2/ICoreWebView2FrameInfo.go index 7a3e6d0902d..c59ac743f5b 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfo.go @@ -33,7 +33,7 @@ func (i *ICoreWebView2FrameInfo) GetName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -43,7 +43,7 @@ func (i *ICoreWebView2FrameInfo) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { @@ -51,7 +51,7 @@ func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetSource.Call( + hr, _, _ := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -61,5 +61,5 @@ func (i *ICoreWebView2FrameInfo) GetSource() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go b/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go index a5834228649..6fa72335ec1 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfo2.go @@ -48,40 +48,40 @@ func (i *ICoreWebView2FrameInfo2) GetParentFrameInfo() (*ICoreWebView2FrameInfo, var frameInfo *ICoreWebView2FrameInfo - hr, _, err := i.Vtbl.GetParentFrameInfo.Call( + hr, _, _ := i.Vtbl.GetParentFrameInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frameInfo)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return frameInfo, err + return frameInfo, nil } func (i *ICoreWebView2FrameInfo2) GetFrameId() (uint32, error) { var id uint32 - hr, _, err := i.Vtbl.GetFrameId.Call( + hr, _, _ := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&id)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return id, err + return id, nil } func (i *ICoreWebView2FrameInfo2) GetFrameKind() (COREWEBVIEW2_FRAME_KIND, error) { var kind COREWEBVIEW2_FRAME_KIND - hr, _, err := i.Vtbl.GetFrameKind.Call( + hr, _, _ := i.Vtbl.GetFrameKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&kind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return kind, err + return kind, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go index de51e1b3a2f..e464e361451 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollection.go @@ -31,12 +31,12 @@ func (i *ICoreWebView2FrameInfoCollection) GetIterator() (*ICoreWebView2FrameInf var value *ICoreWebView2FrameInfoCollectionIterator - hr, _, err := i.Vtbl.GetIterator.Call( + hr, _, _ := i.Vtbl.GetIterator.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go index e329c00c275..b8b64b3191e 100644 --- a/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go +++ b/webview2/pkg/webview2/ICoreWebView2FrameInfoCollectionIterator.go @@ -33,7 +33,7 @@ func (i *ICoreWebView2FrameInfoCollectionIterator) GetHasCurrent() (bool, error) // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasCurrent.Call( + hr, _, _ := i.Vtbl.GetHasCurrent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -42,28 +42,28 @@ func (i *ICoreWebView2FrameInfoCollectionIterator) GetHasCurrent() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2FrameInfoCollectionIterator) GetCurrent() (*ICoreWebView2FrameInfo, error) { var value *ICoreWebView2FrameInfo - hr, _, err := i.Vtbl.GetCurrent.Call( + hr, _, _ := i.Vtbl.GetCurrent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2FrameInfoCollectionIterator) MoveNext() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.MoveNext.Call( + hr, _, _ := i.Vtbl.MoveNext.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -72,5 +72,5 @@ func (i *ICoreWebView2FrameInfoCollectionIterator) MoveNext() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go b/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go index e33874b7344..3f22c6211ec 100644 --- a/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go +++ b/webview2/pkg/webview2/ICoreWebView2HttpHeadersCollectionIterator.go @@ -36,7 +36,7 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) GetCurrentHeader() (string, var _value *uint16 - hr, _, err := i.Vtbl.GetCurrentHeader.Call( + hr, _, _ := i.Vtbl.GetCurrentHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_name)), uintptr(unsafe.Pointer(&_value)), @@ -50,14 +50,14 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) GetCurrentHeader() (string, // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return name, value, err + return name, value, nil } func (i *ICoreWebView2HttpHeadersCollectionIterator) GetHasCurrentHeader() (bool, error) { // Create int32 to hold bool result var _hasCurrent int32 - hr, _, err := i.Vtbl.GetHasCurrentHeader.Call( + hr, _, _ := i.Vtbl.GetHasCurrentHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_hasCurrent)), ) @@ -66,14 +66,14 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) GetHasCurrentHeader() (bool } // Get result and cleanup hasCurrent := _hasCurrent != 0 - return hasCurrent, err + return hasCurrent, nil } func (i *ICoreWebView2HttpHeadersCollectionIterator) MoveNext() (bool, error) { // Create int32 to hold bool result var _hasNext int32 - hr, _, err := i.Vtbl.MoveNext.Call( + hr, _, _ := i.Vtbl.MoveNext.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_hasNext)), ) @@ -82,5 +82,5 @@ func (i *ICoreWebView2HttpHeadersCollectionIterator) MoveNext() (bool, error) { } // Get result and cleanup hasNext := _hasNext != 0 - return hasNext, err + return hasNext, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go b/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go index d52e438e24d..6ceddb29b26 100644 --- a/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go +++ b/webview2/pkg/webview2/ICoreWebView2HttpRequestHeaders.go @@ -42,7 +42,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeader(name string) (string, error) var _value *uint16 - hr, _, err := i.Vtbl.GetHeader.Call( + hr, _, _ := i.Vtbl.GetHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&_value)), @@ -53,7 +53,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeader(name string) (string, error) // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2HttpRequestHeaders) GetHeaders(name string) (*ICoreWebView2HttpHeadersCollectionIterator, error) { @@ -65,7 +65,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeaders(name string) (*ICoreWebView } var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, err := i.Vtbl.GetHeaders.Call( + hr, _, _ := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&value)), @@ -73,7 +73,7 @@ func (i *ICoreWebView2HttpRequestHeaders) GetHeaders(name string) (*ICoreWebView if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2HttpRequestHeaders) Contains(name string) (bool, error) { @@ -85,7 +85,7 @@ func (i *ICoreWebView2HttpRequestHeaders) Contains(name string) (bool, error) { } // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.Contains.Call( + hr, _, _ := i.Vtbl.Contains.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&_value)), @@ -95,7 +95,7 @@ func (i *ICoreWebView2HttpRequestHeaders) Contains(name string) (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2HttpRequestHeaders) SetHeader(name string, value string) error { @@ -111,7 +111,7 @@ func (i *ICoreWebView2HttpRequestHeaders) SetHeader(name string, value string) e return err } - hr, _, err := i.Vtbl.SetHeader.Call( + hr, _, _ := i.Vtbl.SetHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_value)), @@ -119,7 +119,7 @@ func (i *ICoreWebView2HttpRequestHeaders) SetHeader(name string, value string) e if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2HttpRequestHeaders) RemoveHeader(name string) error { @@ -130,26 +130,26 @@ func (i *ICoreWebView2HttpRequestHeaders) RemoveHeader(name string) error { return err } - hr, _, err := i.Vtbl.RemoveHeader.Call( + hr, _, _ := i.Vtbl.RemoveHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2HttpRequestHeaders) GetIterator() (*ICoreWebView2HttpHeadersCollectionIterator, error) { var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, err := i.Vtbl.GetIterator.Call( + hr, _, _ := i.Vtbl.GetIterator.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go b/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go index 20492e27821..fc658e87229 100644 --- a/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go +++ b/webview2/pkg/webview2/ICoreWebView2HttpResponseHeaders.go @@ -44,7 +44,7 @@ func (i *ICoreWebView2HttpResponseHeaders) AppendHeader(name string, value strin return err } - hr, _, err := i.Vtbl.AppendHeader.Call( + hr, _, _ := i.Vtbl.AppendHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(_value)), @@ -52,7 +52,7 @@ func (i *ICoreWebView2HttpResponseHeaders) AppendHeader(name string, value strin if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2HttpResponseHeaders) Contains(name string) (bool, error) { @@ -64,7 +64,7 @@ func (i *ICoreWebView2HttpResponseHeaders) Contains(name string) (bool, error) { } // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.Contains.Call( + hr, _, _ := i.Vtbl.Contains.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&_value)), @@ -74,7 +74,7 @@ func (i *ICoreWebView2HttpResponseHeaders) Contains(name string) (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2HttpResponseHeaders) GetHeader(name string) (string, error) { @@ -87,7 +87,7 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeader(name string) (string, error var _value *uint16 - hr, _, err := i.Vtbl.GetHeader.Call( + hr, _, _ := i.Vtbl.GetHeader.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&_value)), @@ -98,7 +98,7 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeader(name string) (string, error // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2HttpResponseHeaders) GetHeaders(name string) (*ICoreWebView2HttpHeadersCollectionIterator, error) { @@ -110,7 +110,7 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeaders(name string) (*ICoreWebVie } var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, err := i.Vtbl.GetHeaders.Call( + hr, _, _ := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_name)), uintptr(unsafe.Pointer(&value)), @@ -118,19 +118,19 @@ func (i *ICoreWebView2HttpResponseHeaders) GetHeaders(name string) (*ICoreWebVie if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2HttpResponseHeaders) GetIterator() (*ICoreWebView2HttpHeadersCollectionIterator, error) { var value *ICoreWebView2HttpHeadersCollectionIterator - hr, _, err := i.Vtbl.GetIterator.Call( + hr, _, _ := i.Vtbl.GetIterator.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go b/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go index d6b54d389a0..6a51dd340e6 100644 --- a/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2LaunchingExternalUriSchemeEventArgs.go @@ -37,7 +37,7 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetUri() (string, err var _value *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,7 +47,7 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetUri() (string, err // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetInitiatingOrigin() (string, error) { @@ -55,7 +55,7 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetInitiatingOrigin() var _value *uint16 - hr, _, err := i.Vtbl.GetInitiatingOrigin.Call( + hr, _, _ := i.Vtbl.GetInitiatingOrigin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -65,14 +65,14 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetInitiatingOrigin() // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsUserInitiated.Call( + hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -81,14 +81,14 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetIsUserInitiated() } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -97,7 +97,7 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetCancel() (bool, er } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) PutCancel(value bool) error { @@ -108,26 +108,26 @@ func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) PutCancel(value bool) _value = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2LaunchingExternalUriSchemeEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go index 520d0d13c37..638c123e9b8 100644 --- a/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2MoveFocusRequestedEventArgs.go @@ -33,21 +33,21 @@ func (i *ICoreWebView2MoveFocusRequestedEventArgs) GetReason() (COREWEBVIEW2_MOV var reason COREWEBVIEW2_MOVE_FOCUS_REASON - hr, _, err := i.Vtbl.GetReason.Call( + hr, _, _ := i.Vtbl.GetReason.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&reason)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return reason, err + return reason, nil } func (i *ICoreWebView2MoveFocusRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2MoveFocusRequestedEventArgs) GetHandled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2MoveFocusRequestedEventArgs) PutHandled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2MoveFocusRequestedEventArgs) PutHandled(value bool) error _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go index c878b76e56d..8820ae6b735 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs.go @@ -33,7 +33,7 @@ func (i *ICoreWebView2NavigationCompletedEventArgs) GetIsSuccess() (bool, error) // Create int32 to hold bool result var _isSuccess int32 - hr, _, err := i.Vtbl.GetIsSuccess.Call( + hr, _, _ := i.Vtbl.GetIsSuccess.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSuccess)), ) @@ -42,33 +42,33 @@ func (i *ICoreWebView2NavigationCompletedEventArgs) GetIsSuccess() (bool, error) } // Get result and cleanup isSuccess := _isSuccess != 0 - return isSuccess, err + return isSuccess, nil } func (i *ICoreWebView2NavigationCompletedEventArgs) GetWebErrorStatus() (COREWEBVIEW2_WEB_ERROR_STATUS, error) { var webErrorStatus COREWEBVIEW2_WEB_ERROR_STATUS - hr, _, err := i.Vtbl.GetWebErrorStatus.Call( + hr, _, _ := i.Vtbl.GetWebErrorStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&webErrorStatus)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return webErrorStatus, err + return webErrorStatus, nil } func (i *ICoreWebView2NavigationCompletedEventArgs) GetNavigationId() (uint64, error) { var navigationId uint64 - hr, _, err := i.Vtbl.GetNavigationId.Call( + hr, _, _ := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&navigationId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return navigationId, err + return navigationId, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go index fb74dfb13f4..b24c950063e 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationCompletedEventArgs2.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2NavigationCompletedEventArgs2) GetHttpStatusCode() (int, e var value int - hr, _, err := i.Vtbl.GetHttpStatusCode.Call( + hr, _, _ := i.Vtbl.GetHttpStatusCode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go index 5649d9df8a6..9512d9219f8 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs.go @@ -38,7 +38,7 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetUri() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -48,14 +48,14 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2NavigationStartingEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _isUserInitiated int32 - hr, _, err := i.Vtbl.GetIsUserInitiated.Call( + hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isUserInitiated)), ) @@ -64,14 +64,14 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetIsUserInitiated() (bool, e } // Get result and cleanup isUserInitiated := _isUserInitiated != 0 - return isUserInitiated, err + return isUserInitiated, nil } func (i *ICoreWebView2NavigationStartingEventArgs) GetIsRedirected() (bool, error) { // Create int32 to hold bool result var _isRedirected int32 - hr, _, err := i.Vtbl.GetIsRedirected.Call( + hr, _, _ := i.Vtbl.GetIsRedirected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isRedirected)), ) @@ -80,28 +80,28 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetIsRedirected() (bool, erro } // Get result and cleanup isRedirected := _isRedirected != 0 - return isRedirected, err + return isRedirected, nil } func (i *ICoreWebView2NavigationStartingEventArgs) GetRequestHeaders() (*ICoreWebView2HttpRequestHeaders, error) { var requestHeaders *ICoreWebView2HttpRequestHeaders - hr, _, err := i.Vtbl.GetRequestHeaders.Call( + hr, _, _ := i.Vtbl.GetRequestHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&requestHeaders)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return requestHeaders, err + return requestHeaders, nil } func (i *ICoreWebView2NavigationStartingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _cancel int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_cancel)), ) @@ -110,7 +110,7 @@ func (i *ICoreWebView2NavigationStartingEventArgs) GetCancel() (bool, error) { } // Get result and cleanup cancel := _cancel != 0 - return cancel, err + return cancel, nil } func (i *ICoreWebView2NavigationStartingEventArgs) PutCancel(cancel bool) error { @@ -121,26 +121,26 @@ func (i *ICoreWebView2NavigationStartingEventArgs) PutCancel(cancel bool) error _cancel = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_cancel), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2NavigationStartingEventArgs) GetNavigationId() (uint64, error) { var navigationId uint64 - hr, _, err := i.Vtbl.GetNavigationId.Call( + hr, _, _ := i.Vtbl.GetNavigationId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&navigationId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return navigationId, err + return navigationId, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go index d066fcd48e5..6dfe4ba9ce5 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs2.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2NavigationStartingEventArgs2) GetAdditionalAllowedFrameAnc var _value *uint16 - hr, _, err := i.Vtbl.GetAdditionalAllowedFrameAncestors.Call( + hr, _, _ := i.Vtbl.GetAdditionalAllowedFrameAncestors.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,7 +58,7 @@ func (i *ICoreWebView2NavigationStartingEventArgs2) GetAdditionalAllowedFrameAnc // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2NavigationStartingEventArgs2) PutAdditionalAllowedFrameAncestors(value string) error { @@ -69,12 +69,12 @@ func (i *ICoreWebView2NavigationStartingEventArgs2) PutAdditionalAllowedFrameAnc return err } - hr, _, err := i.Vtbl.PutAdditionalAllowedFrameAncestors.Call( + hr, _, _ := i.Vtbl.PutAdditionalAllowedFrameAncestors.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go index f60705a3af4..eced67d0630 100644 --- a/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2NavigationStartingEventArgs3.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2NavigationStartingEventArgs3) GetNavigationKind() (COREWEB var value COREWEBVIEW2_NAVIGATION_KIND - hr, _, err := i.Vtbl.GetNavigationKind.Call( + hr, _, _ := i.Vtbl.GetNavigationKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go index 4f644915076..fb7d8bac8ef 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs.go @@ -39,7 +39,7 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetUri() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -49,34 +49,34 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) PutNewWindow(newWindow *ICoreWebView2) error { - hr, _, err := i.Vtbl.PutNewWindow.Call( + hr, _, _ := i.Vtbl.PutNewWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(newWindow)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetNewWindow() (*ICoreWebView2, error) { var newWindow *ICoreWebView2 - hr, _, err := i.Vtbl.GetNewWindow.Call( + hr, _, _ := i.Vtbl.GetNewWindow.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&newWindow)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return newWindow, err + return newWindow, nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) PutHandled(handled bool) error { @@ -87,21 +87,21 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) PutHandled(handled bool) erro _handled = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_handled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _handled int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_handled)), ) @@ -110,14 +110,14 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetHandled() (bool, error) { } // Get result and cleanup handled := _handled != 0 - return handled, err + return handled, nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _isUserInitiated int32 - hr, _, err := i.Vtbl.GetIsUserInitiated.Call( + hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isUserInitiated)), ) @@ -126,33 +126,33 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs) GetIsUserInitiated() (bool, e } // Get result and cleanup isUserInitiated := _isUserInitiated != 0 - return isUserInitiated, err + return isUserInitiated, nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } func (i *ICoreWebView2NewWindowRequestedEventArgs) GetWindowFeatures() (*ICoreWebView2WindowFeatures, error) { var value *ICoreWebView2WindowFeatures - hr, _, err := i.Vtbl.GetWindowFeatures.Call( + hr, _, _ := i.Vtbl.GetWindowFeatures.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go index c8c30947d06..a9f06ef8ed7 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs2.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs2) GetName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -57,5 +57,5 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs2) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go index edb17fe9cde..0b433abfa14 100644 --- a/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2NewWindowRequestedEventArgs3.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2NewWindowRequestedEventArgs3) GetOriginalSourceFrameInfo() var value *ICoreWebView2FrameInfo - hr, _, err := i.Vtbl.GetOriginalSourceFrameInfo.Call( + hr, _, _ := i.Vtbl.GetOriginalSourceFrameInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go index 41d1bcdd0e3..9796eb16283 100644 --- a/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NonClientRegionChangedEventArgs.go @@ -31,12 +31,12 @@ func (i *ICoreWebView2NonClientRegionChangedEventArgs) GetRegionKind() (COREWEBV var value COREWEBVIEW2_NON_CLIENT_REGION_KIND - hr, _, err := i.Vtbl.GetRegionKind.Call( + hr, _, _ := i.Vtbl.GetRegionKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Notification.go b/webview2/pkg/webview2/ICoreWebView2Notification.go index ff97119246b..e4df31653ce 100644 --- a/webview2/pkg/webview2/ICoreWebView2Notification.go +++ b/webview2/pkg/webview2/ICoreWebView2Notification.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2Notification) AddCloseRequested(eventHandler *ICoreWebView var token EventRegistrationToken - hr, _, err := i.Vtbl.AddCloseRequested.Call( + hr, _, _ := i.Vtbl.AddCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -56,56 +56,56 @@ func (i *ICoreWebView2Notification) AddCloseRequested(eventHandler *ICoreWebView if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Notification) RemoveCloseRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveCloseRequested.Call( + hr, _, _ := i.Vtbl.RemoveCloseRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Notification) ReportShown() error { - hr, _, err := i.Vtbl.ReportShown.Call( + hr, _, _ := i.Vtbl.ReportShown.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Notification) ReportClicked() error { - hr, _, err := i.Vtbl.ReportClicked.Call( + hr, _, _ := i.Vtbl.ReportClicked.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Notification) ReportClosed() error { - hr, _, err := i.Vtbl.ReportClosed.Call( + hr, _, _ := i.Vtbl.ReportClosed.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Notification) GetBody() (string, error) { @@ -113,7 +113,7 @@ func (i *ICoreWebView2Notification) GetBody() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetBody.Call( + hr, _, _ := i.Vtbl.GetBody.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -123,21 +123,21 @@ func (i *ICoreWebView2Notification) GetBody() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetDirection() (COREWEBVIEW2_TEXT_DIRECTION_KIND, error) { var value COREWEBVIEW2_TEXT_DIRECTION_KIND - hr, _, err := i.Vtbl.GetDirection.Call( + hr, _, _ := i.Vtbl.GetDirection.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetLanguage() (string, error) { @@ -145,7 +145,7 @@ func (i *ICoreWebView2Notification) GetLanguage() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetLanguage.Call( + hr, _, _ := i.Vtbl.GetLanguage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -155,7 +155,7 @@ func (i *ICoreWebView2Notification) GetLanguage() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetTag() (string, error) { @@ -163,7 +163,7 @@ func (i *ICoreWebView2Notification) GetTag() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetTag.Call( + hr, _, _ := i.Vtbl.GetTag.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -173,7 +173,7 @@ func (i *ICoreWebView2Notification) GetTag() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetIconUri() (string, error) { @@ -181,7 +181,7 @@ func (i *ICoreWebView2Notification) GetIconUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetIconUri.Call( + hr, _, _ := i.Vtbl.GetIconUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -191,7 +191,7 @@ func (i *ICoreWebView2Notification) GetIconUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetTitle() (string, error) { @@ -199,7 +199,7 @@ func (i *ICoreWebView2Notification) GetTitle() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetTitle.Call( + hr, _, _ := i.Vtbl.GetTitle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -209,7 +209,7 @@ func (i *ICoreWebView2Notification) GetTitle() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetBadgeUri() (string, error) { @@ -217,7 +217,7 @@ func (i *ICoreWebView2Notification) GetBadgeUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetBadgeUri.Call( + hr, _, _ := i.Vtbl.GetBadgeUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -227,7 +227,7 @@ func (i *ICoreWebView2Notification) GetBadgeUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetBodyImageUri() (string, error) { @@ -235,7 +235,7 @@ func (i *ICoreWebView2Notification) GetBodyImageUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetBodyImageUri.Call( + hr, _, _ := i.Vtbl.GetBodyImageUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -245,14 +245,14 @@ func (i *ICoreWebView2Notification) GetBodyImageUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetShouldRenotify() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldRenotify.Call( + hr, _, _ := i.Vtbl.GetShouldRenotify.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -261,14 +261,14 @@ func (i *ICoreWebView2Notification) GetShouldRenotify() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetRequiresInteraction() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetRequiresInteraction.Call( + hr, _, _ := i.Vtbl.GetRequiresInteraction.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -277,14 +277,14 @@ func (i *ICoreWebView2Notification) GetRequiresInteraction() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetIsSilent() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsSilent.Call( + hr, _, _ := i.Vtbl.GetIsSilent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -293,21 +293,21 @@ func (i *ICoreWebView2Notification) GetIsSilent() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetTimestamp() (float64, error) { var value float64 - hr, _, err := i.Vtbl.GetTimestamp.Call( + hr, _, _ := i.Vtbl.GetTimestamp.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Notification) GetVibrationPattern() (uint32, *uint64, error) { @@ -315,7 +315,7 @@ func (i *ICoreWebView2Notification) GetVibrationPattern() (uint32, *uint64, erro var count uint32 var vibrationPattern *uint64 - hr, _, err := i.Vtbl.GetVibrationPattern.Call( + hr, _, _ := i.Vtbl.GetVibrationPattern.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&count)), uintptr(unsafe.Pointer(&vibrationPattern)), @@ -323,5 +323,5 @@ func (i *ICoreWebView2Notification) GetVibrationPattern() (uint32, *uint64, erro if windows.Handle(hr) != windows.S_OK { return 0, nil, syscall.Errno(hr) } - return count, vibrationPattern, err + return count, vibrationPattern, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go index 32f5e310ffb..f89ca347673 100644 --- a/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2NotificationReceivedEventArgs.go @@ -36,7 +36,7 @@ func (i *ICoreWebView2NotificationReceivedEventArgs) GetSenderOrigin() (string, var _value *uint16 - hr, _, err := i.Vtbl.GetSenderOrigin.Call( + hr, _, _ := i.Vtbl.GetSenderOrigin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -46,21 +46,21 @@ func (i *ICoreWebView2NotificationReceivedEventArgs) GetSenderOrigin() (string, // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2NotificationReceivedEventArgs) GetNotification() (*ICoreWebView2Notification, error) { var value *ICoreWebView2Notification - hr, _, err := i.Vtbl.GetNotification.Call( + hr, _, _ := i.Vtbl.GetNotification.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2NotificationReceivedEventArgs) PutHandled(value bool) error { @@ -71,21 +71,21 @@ func (i *ICoreWebView2NotificationReceivedEventArgs) PutHandled(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2NotificationReceivedEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -94,19 +94,19 @@ func (i *ICoreWebView2NotificationReceivedEventArgs) GetHandled() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2NotificationReceivedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go b/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go index d1b49ad87e7..622da3a0706 100644 --- a/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ObjectCollection.go @@ -46,20 +46,20 @@ func (i *ICoreWebView2) GetICoreWebView2ObjectCollection() (*ICoreWebView2Object func (i *ICoreWebView2ObjectCollection) RemoveValueAtIndex(index uint32) error { - hr, _, err := i.Vtbl.RemoveValueAtIndex.Call( + hr, _, _ := i.Vtbl.RemoveValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ObjectCollection) InsertValueAtIndex(index uint32, value *IUnknown) error { - hr, _, err := i.Vtbl.InsertValueAtIndex.Call( + hr, _, _ := i.Vtbl.InsertValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(value)), @@ -67,5 +67,5 @@ func (i *ICoreWebView2ObjectCollection) InsertValueAtIndex(index uint32, value * if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go b/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go index 7eecb57ed80..7b9f25d9755 100644 --- a/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go +++ b/webview2/pkg/webview2/ICoreWebView2ObjectCollectionView.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2ObjectCollectionView) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ObjectCollectionView) GetValueAtIndex(index uint32) (*IUnknown, error) { var value *IUnknown - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2ObjectCollectionView) GetValueAtIndex(index uint32) (*IUnk if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go index e2ad0e9ef34..ac087b6ff84 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs.go @@ -37,7 +37,7 @@ func (i *ICoreWebView2PermissionRequestedEventArgs) GetUri() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -47,28 +47,28 @@ func (i *ICoreWebView2PermissionRequestedEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2PermissionRequestedEventArgs) GetPermissionKind() (COREWEBVIEW2_PERMISSION_KIND, error) { var permissionKind COREWEBVIEW2_PERMISSION_KIND - hr, _, err := i.Vtbl.GetPermissionKind.Call( + hr, _, _ := i.Vtbl.GetPermissionKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&permissionKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return permissionKind, err + return permissionKind, nil } func (i *ICoreWebView2PermissionRequestedEventArgs) GetIsUserInitiated() (bool, error) { // Create int32 to hold bool result var _isUserInitiated int32 - hr, _, err := i.Vtbl.GetIsUserInitiated.Call( + hr, _, _ := i.Vtbl.GetIsUserInitiated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isUserInitiated)), ) @@ -77,46 +77,46 @@ func (i *ICoreWebView2PermissionRequestedEventArgs) GetIsUserInitiated() (bool, } // Get result and cleanup isUserInitiated := _isUserInitiated != 0 - return isUserInitiated, err + return isUserInitiated, nil } func (i *ICoreWebView2PermissionRequestedEventArgs) GetState() (COREWEBVIEW2_PERMISSION_STATE, error) { var state COREWEBVIEW2_PERMISSION_STATE - hr, _, err := i.Vtbl.GetState.Call( + hr, _, _ := i.Vtbl.GetState.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&state)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return state, err + return state, nil } func (i *ICoreWebView2PermissionRequestedEventArgs) PutState(state COREWEBVIEW2_PERMISSION_STATE) error { - hr, _, err := i.Vtbl.PutState.Call( + hr, _, _ := i.Vtbl.PutState.Call( uintptr(unsafe.Pointer(i)), uintptr(state), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PermissionRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go index 36c0f684270..a0188efa5b8 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs2.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2PermissionRequestedEventArgs2) GetHandled() (bool, error) // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2PermissionRequestedEventArgs2) GetHandled() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2PermissionRequestedEventArgs2) PutHandled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2PermissionRequestedEventArgs2) PutHandled(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go index a0c23b79432..06136188899 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionRequestedEventArgs3.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2PermissionRequestedEventArgs3) GetSavesInProfile() (bool, // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetSavesInProfile.Call( + hr, _, _ := i.Vtbl.GetSavesInProfile.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2PermissionRequestedEventArgs3) GetSavesInProfile() (bool, } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2PermissionRequestedEventArgs3) PutSavesInProfile(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2PermissionRequestedEventArgs3) PutSavesInProfile(value boo _value = 1 } - hr, _, err := i.Vtbl.PutSavesInProfile.Call( + hr, _, _ := i.Vtbl.PutSavesInProfile.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go b/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go index 2cd8253f944..ab8079b9615 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionSetting.go @@ -33,14 +33,14 @@ func (i *ICoreWebView2PermissionSetting) GetPermissionKind() (COREWEBVIEW2_PERMI var value COREWEBVIEW2_PERMISSION_KIND - hr, _, err := i.Vtbl.GetPermissionKind.Call( + hr, _, _ := i.Vtbl.GetPermissionKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PermissionSetting) GetPermissionOrigin() (string, error) { @@ -48,7 +48,7 @@ func (i *ICoreWebView2PermissionSetting) GetPermissionOrigin() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetPermissionOrigin.Call( + hr, _, _ := i.Vtbl.GetPermissionOrigin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,19 +58,19 @@ func (i *ICoreWebView2PermissionSetting) GetPermissionOrigin() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2PermissionSetting) GetPermissionState() (COREWEBVIEW2_PERMISSION_STATE, error) { var value COREWEBVIEW2_PERMISSION_STATE - hr, _, err := i.Vtbl.GetPermissionState.Call( + hr, _, _ := i.Vtbl.GetPermissionState.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go b/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go index e599b574254..1573d45708a 100644 --- a/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go +++ b/webview2/pkg/webview2/ICoreWebView2PermissionSettingCollectionView.go @@ -32,7 +32,7 @@ func (i *ICoreWebView2PermissionSettingCollectionView) GetValueAtIndex(index uin var permissionSetting *ICoreWebView2PermissionSetting - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&permissionSetting)), @@ -40,19 +40,19 @@ func (i *ICoreWebView2PermissionSettingCollectionView) GetValueAtIndex(index uin if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return permissionSetting, err + return permissionSetting, nil } func (i *ICoreWebView2PermissionSettingCollectionView) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PointerInfo.go b/webview2/pkg/webview2/ICoreWebView2PointerInfo.go index 5aef4b2a58c..2a66472d055 100644 --- a/webview2/pkg/webview2/ICoreWebView2PointerInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2PointerInfo.go @@ -86,754 +86,754 @@ func (i *ICoreWebView2PointerInfo) GetPointerKind() (uint32, error) { var pointerKind uint32 - hr, _, err := i.Vtbl.GetPointerKind.Call( + hr, _, _ := i.Vtbl.GetPointerKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return pointerKind, err + return pointerKind, nil } func (i *ICoreWebView2PointerInfo) PutPointerKind(pointerKind uint32) error { - hr, _, err := i.Vtbl.PutPointerKind.Call( + hr, _, _ := i.Vtbl.PutPointerKind.Call( uintptr(unsafe.Pointer(i)), uintptr(pointerKind), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPointerId() (uint32, error) { var pointerId uint32 - hr, _, err := i.Vtbl.GetPointerId.Call( + hr, _, _ := i.Vtbl.GetPointerId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return pointerId, err + return pointerId, nil } func (i *ICoreWebView2PointerInfo) PutPointerId(pointerId uint32) error { - hr, _, err := i.Vtbl.PutPointerId.Call( + hr, _, _ := i.Vtbl.PutPointerId.Call( uintptr(unsafe.Pointer(i)), uintptr(pointerId), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetFrameId() (uint32, error) { var frameId uint32 - hr, _, err := i.Vtbl.GetFrameId.Call( + hr, _, _ := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frameId)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return frameId, err + return frameId, nil } func (i *ICoreWebView2PointerInfo) PutFrameId(frameId uint32) error { - hr, _, err := i.Vtbl.PutFrameId.Call( + hr, _, _ := i.Vtbl.PutFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(frameId), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPointerFlags() (uint32, error) { var pointerFlags uint32 - hr, _, err := i.Vtbl.GetPointerFlags.Call( + hr, _, _ := i.Vtbl.GetPointerFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerFlags)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return pointerFlags, err + return pointerFlags, nil } func (i *ICoreWebView2PointerInfo) PutPointerFlags(pointerFlags uint32) error { - hr, _, err := i.Vtbl.PutPointerFlags.Call( + hr, _, _ := i.Vtbl.PutPointerFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(pointerFlags), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPointerDeviceRect() (RECT, error) { var pointerDeviceRect RECT - hr, _, err := i.Vtbl.GetPointerDeviceRect.Call( + hr, _, _ := i.Vtbl.GetPointerDeviceRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerDeviceRect)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return pointerDeviceRect, err + return pointerDeviceRect, nil } func (i *ICoreWebView2PointerInfo) PutPointerDeviceRect(pointerDeviceRect RECT) error { - hr, _, err := i.Vtbl.PutPointerDeviceRect.Call( + hr, _, _ := i.Vtbl.PutPointerDeviceRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pointerDeviceRect)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetDisplayRect() (RECT, error) { var displayRect RECT - hr, _, err := i.Vtbl.GetDisplayRect.Call( + hr, _, _ := i.Vtbl.GetDisplayRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&displayRect)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return displayRect, err + return displayRect, nil } func (i *ICoreWebView2PointerInfo) PutDisplayRect(displayRect RECT) error { - hr, _, err := i.Vtbl.PutDisplayRect.Call( + hr, _, _ := i.Vtbl.PutDisplayRect.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&displayRect)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPixelLocation() (POINT, error) { var pixelLocation POINT - hr, _, err := i.Vtbl.GetPixelLocation.Call( + hr, _, _ := i.Vtbl.GetPixelLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocation)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return pixelLocation, err + return pixelLocation, nil } func (i *ICoreWebView2PointerInfo) PutPixelLocation(pixelLocation POINT) error { - hr, _, err := i.Vtbl.PutPixelLocation.Call( + hr, _, _ := i.Vtbl.PutPixelLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocation)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetHimetricLocation() (POINT, error) { var himetricLocation POINT - hr, _, err := i.Vtbl.GetHimetricLocation.Call( + hr, _, _ := i.Vtbl.GetHimetricLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocation)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return himetricLocation, err + return himetricLocation, nil } func (i *ICoreWebView2PointerInfo) PutHimetricLocation(himetricLocation POINT) error { - hr, _, err := i.Vtbl.PutHimetricLocation.Call( + hr, _, _ := i.Vtbl.PutHimetricLocation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocation)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPixelLocationRaw() (POINT, error) { var pixelLocationRaw POINT - hr, _, err := i.Vtbl.GetPixelLocationRaw.Call( + hr, _, _ := i.Vtbl.GetPixelLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return pixelLocationRaw, err + return pixelLocationRaw, nil } func (i *ICoreWebView2PointerInfo) PutPixelLocationRaw(pixelLocationRaw POINT) error { - hr, _, err := i.Vtbl.PutPixelLocationRaw.Call( + hr, _, _ := i.Vtbl.PutPixelLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pixelLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetHimetricLocationRaw() (POINT, error) { var himetricLocationRaw POINT - hr, _, err := i.Vtbl.GetHimetricLocationRaw.Call( + hr, _, _ := i.Vtbl.GetHimetricLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return himetricLocationRaw, err + return himetricLocationRaw, nil } func (i *ICoreWebView2PointerInfo) PutHimetricLocationRaw(himetricLocationRaw POINT) error { - hr, _, err := i.Vtbl.PutHimetricLocationRaw.Call( + hr, _, _ := i.Vtbl.PutHimetricLocationRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&himetricLocationRaw)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTime() (uint32, error) { var time uint32 - hr, _, err := i.Vtbl.GetTime.Call( + hr, _, _ := i.Vtbl.GetTime.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&time)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return time, err + return time, nil } func (i *ICoreWebView2PointerInfo) PutTime(time uint32) error { - hr, _, err := i.Vtbl.PutTime.Call( + hr, _, _ := i.Vtbl.PutTime.Call( uintptr(unsafe.Pointer(i)), uintptr(time), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetHistoryCount() (uint32, error) { var historyCount uint32 - hr, _, err := i.Vtbl.GetHistoryCount.Call( + hr, _, _ := i.Vtbl.GetHistoryCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&historyCount)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return historyCount, err + return historyCount, nil } func (i *ICoreWebView2PointerInfo) PutHistoryCount(historyCount uint32) error { - hr, _, err := i.Vtbl.PutHistoryCount.Call( + hr, _, _ := i.Vtbl.PutHistoryCount.Call( uintptr(unsafe.Pointer(i)), uintptr(historyCount), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetInputData() (int32, error) { var inputData int32 - hr, _, err := i.Vtbl.GetInputData.Call( + hr, _, _ := i.Vtbl.GetInputData.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&inputData)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return inputData, err + return inputData, nil } func (i *ICoreWebView2PointerInfo) PutInputData(inputData int32) error { - hr, _, err := i.Vtbl.PutInputData.Call( + hr, _, _ := i.Vtbl.PutInputData.Call( uintptr(unsafe.Pointer(i)), uintptr(inputData), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetKeyStates() (uint32, error) { var keyStates uint32 - hr, _, err := i.Vtbl.GetKeyStates.Call( + hr, _, _ := i.Vtbl.GetKeyStates.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&keyStates)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return keyStates, err + return keyStates, nil } func (i *ICoreWebView2PointerInfo) PutKeyStates(keyStates uint32) error { - hr, _, err := i.Vtbl.PutKeyStates.Call( + hr, _, _ := i.Vtbl.PutKeyStates.Call( uintptr(unsafe.Pointer(i)), uintptr(keyStates), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPerformanceCount() (uint64, error) { var performanceCount uint64 - hr, _, err := i.Vtbl.GetPerformanceCount.Call( + hr, _, _ := i.Vtbl.GetPerformanceCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&performanceCount)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return performanceCount, err + return performanceCount, nil } func (i *ICoreWebView2PointerInfo) PutPerformanceCount(performanceCount uint64) error { - hr, _, err := i.Vtbl.PutPerformanceCount.Call( + hr, _, _ := i.Vtbl.PutPerformanceCount.Call( uintptr(unsafe.Pointer(i)), uintptr(performanceCount), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetButtonChangeKind() (int32, error) { var buttonChangeKind int32 - hr, _, err := i.Vtbl.GetButtonChangeKind.Call( + hr, _, _ := i.Vtbl.GetButtonChangeKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&buttonChangeKind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return buttonChangeKind, err + return buttonChangeKind, nil } func (i *ICoreWebView2PointerInfo) PutButtonChangeKind(buttonChangeKind int32) error { - hr, _, err := i.Vtbl.PutButtonChangeKind.Call( + hr, _, _ := i.Vtbl.PutButtonChangeKind.Call( uintptr(unsafe.Pointer(i)), uintptr(buttonChangeKind), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPenFlags() (uint32, error) { var penFLags uint32 - hr, _, err := i.Vtbl.GetPenFlags.Call( + hr, _, _ := i.Vtbl.GetPenFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penFLags)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penFLags, err + return penFLags, nil } func (i *ICoreWebView2PointerInfo) PutPenFlags(penFLags uint32) error { - hr, _, err := i.Vtbl.PutPenFlags.Call( + hr, _, _ := i.Vtbl.PutPenFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(penFLags), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPenMask() (uint32, error) { var penMask uint32 - hr, _, err := i.Vtbl.GetPenMask.Call( + hr, _, _ := i.Vtbl.GetPenMask.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penMask)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penMask, err + return penMask, nil } func (i *ICoreWebView2PointerInfo) PutPenMask(penMask uint32) error { - hr, _, err := i.Vtbl.PutPenMask.Call( + hr, _, _ := i.Vtbl.PutPenMask.Call( uintptr(unsafe.Pointer(i)), uintptr(penMask), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPenPressure() (uint32, error) { var penPressure uint32 - hr, _, err := i.Vtbl.GetPenPressure.Call( + hr, _, _ := i.Vtbl.GetPenPressure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penPressure)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penPressure, err + return penPressure, nil } func (i *ICoreWebView2PointerInfo) PutPenPressure(penPressure uint32) error { - hr, _, err := i.Vtbl.PutPenPressure.Call( + hr, _, _ := i.Vtbl.PutPenPressure.Call( uintptr(unsafe.Pointer(i)), uintptr(penPressure), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPenRotation() (uint32, error) { var penRotation uint32 - hr, _, err := i.Vtbl.GetPenRotation.Call( + hr, _, _ := i.Vtbl.GetPenRotation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penRotation)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penRotation, err + return penRotation, nil } func (i *ICoreWebView2PointerInfo) PutPenRotation(penRotation uint32) error { - hr, _, err := i.Vtbl.PutPenRotation.Call( + hr, _, _ := i.Vtbl.PutPenRotation.Call( uintptr(unsafe.Pointer(i)), uintptr(penRotation), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPenTiltX() (int32, error) { var penTiltX int32 - hr, _, err := i.Vtbl.GetPenTiltX.Call( + hr, _, _ := i.Vtbl.GetPenTiltX.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penTiltX)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penTiltX, err + return penTiltX, nil } func (i *ICoreWebView2PointerInfo) PutPenTiltX(penTiltX int32) error { - hr, _, err := i.Vtbl.PutPenTiltX.Call( + hr, _, _ := i.Vtbl.PutPenTiltX.Call( uintptr(unsafe.Pointer(i)), uintptr(penTiltX), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetPenTiltY() (int32, error) { var penTiltY int32 - hr, _, err := i.Vtbl.GetPenTiltY.Call( + hr, _, _ := i.Vtbl.GetPenTiltY.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&penTiltY)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return penTiltY, err + return penTiltY, nil } func (i *ICoreWebView2PointerInfo) PutPenTiltY(penTiltY int32) error { - hr, _, err := i.Vtbl.PutPenTiltY.Call( + hr, _, _ := i.Vtbl.PutPenTiltY.Call( uintptr(unsafe.Pointer(i)), uintptr(penTiltY), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTouchFlags() (uint32, error) { var touchFlags uint32 - hr, _, err := i.Vtbl.GetTouchFlags.Call( + hr, _, _ := i.Vtbl.GetTouchFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchFlags)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchFlags, err + return touchFlags, nil } func (i *ICoreWebView2PointerInfo) PutTouchFlags(touchFlags uint32) error { - hr, _, err := i.Vtbl.PutTouchFlags.Call( + hr, _, _ := i.Vtbl.PutTouchFlags.Call( uintptr(unsafe.Pointer(i)), uintptr(touchFlags), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTouchMask() (uint32, error) { var touchMask uint32 - hr, _, err := i.Vtbl.GetTouchMask.Call( + hr, _, _ := i.Vtbl.GetTouchMask.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchMask)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchMask, err + return touchMask, nil } func (i *ICoreWebView2PointerInfo) PutTouchMask(touchMask uint32) error { - hr, _, err := i.Vtbl.PutTouchMask.Call( + hr, _, _ := i.Vtbl.PutTouchMask.Call( uintptr(unsafe.Pointer(i)), uintptr(touchMask), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTouchContact() (RECT, error) { var touchContact RECT - hr, _, err := i.Vtbl.GetTouchContact.Call( + hr, _, _ := i.Vtbl.GetTouchContact.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContact)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return touchContact, err + return touchContact, nil } func (i *ICoreWebView2PointerInfo) PutTouchContact(touchContact RECT) error { - hr, _, err := i.Vtbl.PutTouchContact.Call( + hr, _, _ := i.Vtbl.PutTouchContact.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContact)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTouchContactRaw() (RECT, error) { var touchContactRaw RECT - hr, _, err := i.Vtbl.GetTouchContactRaw.Call( + hr, _, _ := i.Vtbl.GetTouchContactRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContactRaw)), ) if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return touchContactRaw, err + return touchContactRaw, nil } func (i *ICoreWebView2PointerInfo) PutTouchContactRaw(touchContactRaw RECT) error { - hr, _, err := i.Vtbl.PutTouchContactRaw.Call( + hr, _, _ := i.Vtbl.PutTouchContactRaw.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchContactRaw)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTouchOrientation() (uint32, error) { var touchOrientation uint32 - hr, _, err := i.Vtbl.GetTouchOrientation.Call( + hr, _, _ := i.Vtbl.GetTouchOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchOrientation)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchOrientation, err + return touchOrientation, nil } func (i *ICoreWebView2PointerInfo) PutTouchOrientation(touchOrientation uint32) error { - hr, _, err := i.Vtbl.PutTouchOrientation.Call( + hr, _, _ := i.Vtbl.PutTouchOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(touchOrientation), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PointerInfo) GetTouchPressure() (uint32, error) { var touchPressure uint32 - hr, _, err := i.Vtbl.GetTouchPressure.Call( + hr, _, _ := i.Vtbl.GetTouchPressure.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&touchPressure)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return touchPressure, err + return touchPressure, nil } func (i *ICoreWebView2PointerInfo) PutTouchPressure(touchPressure uint32) error { - hr, _, err := i.Vtbl.PutTouchPressure.Call( + hr, _, _ := i.Vtbl.PutTouchPressure.Call( uintptr(unsafe.Pointer(i)), uintptr(touchPressure), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PrintSettings.go b/webview2/pkg/webview2/ICoreWebView2PrintSettings.go index 1ba4bbd15d2..7eb8d91bf32 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintSettings.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintSettings.go @@ -56,223 +56,223 @@ func (i *ICoreWebView2PrintSettings) GetOrientation() (COREWEBVIEW2_PRINT_ORIENT var orientation COREWEBVIEW2_PRINT_ORIENTATION - hr, _, err := i.Vtbl.GetOrientation.Call( + hr, _, _ := i.Vtbl.GetOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&orientation)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return orientation, err + return orientation, nil } func (i *ICoreWebView2PrintSettings) PutOrientation(orientation COREWEBVIEW2_PRINT_ORIENTATION) error { - hr, _, err := i.Vtbl.PutOrientation.Call( + hr, _, _ := i.Vtbl.PutOrientation.Call( uintptr(unsafe.Pointer(i)), uintptr(orientation), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetScaleFactor() (float64, error) { var scaleFactor float64 - hr, _, err := i.Vtbl.GetScaleFactor.Call( + hr, _, _ := i.Vtbl.GetScaleFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&scaleFactor)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return scaleFactor, err + return scaleFactor, nil } func (i *ICoreWebView2PrintSettings) PutScaleFactor(scaleFactor float64) error { - hr, _, err := i.Vtbl.PutScaleFactor.Call( + hr, _, _ := i.Vtbl.PutScaleFactor.Call( uintptr(unsafe.Pointer(i)), uintptr(scaleFactor), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetPageWidth() (float64, error) { var pageWidth float64 - hr, _, err := i.Vtbl.GetPageWidth.Call( + hr, _, _ := i.Vtbl.GetPageWidth.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pageWidth)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return pageWidth, err + return pageWidth, nil } func (i *ICoreWebView2PrintSettings) PutPageWidth(pageWidth float64) error { - hr, _, err := i.Vtbl.PutPageWidth.Call( + hr, _, _ := i.Vtbl.PutPageWidth.Call( uintptr(unsafe.Pointer(i)), uintptr(pageWidth), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetPageHeight() (float64, error) { var pageHeight float64 - hr, _, err := i.Vtbl.GetPageHeight.Call( + hr, _, _ := i.Vtbl.GetPageHeight.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&pageHeight)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return pageHeight, err + return pageHeight, nil } func (i *ICoreWebView2PrintSettings) PutPageHeight(pageHeight float64) error { - hr, _, err := i.Vtbl.PutPageHeight.Call( + hr, _, _ := i.Vtbl.PutPageHeight.Call( uintptr(unsafe.Pointer(i)), uintptr(pageHeight), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetMarginTop() (float64, error) { var marginTop float64 - hr, _, err := i.Vtbl.GetMarginTop.Call( + hr, _, _ := i.Vtbl.GetMarginTop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginTop)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginTop, err + return marginTop, nil } func (i *ICoreWebView2PrintSettings) PutMarginTop(marginTop float64) error { - hr, _, err := i.Vtbl.PutMarginTop.Call( + hr, _, _ := i.Vtbl.PutMarginTop.Call( uintptr(unsafe.Pointer(i)), uintptr(marginTop), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetMarginBottom() (float64, error) { var marginBottom float64 - hr, _, err := i.Vtbl.GetMarginBottom.Call( + hr, _, _ := i.Vtbl.GetMarginBottom.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginBottom)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginBottom, err + return marginBottom, nil } func (i *ICoreWebView2PrintSettings) PutMarginBottom(marginBottom float64) error { - hr, _, err := i.Vtbl.PutMarginBottom.Call( + hr, _, _ := i.Vtbl.PutMarginBottom.Call( uintptr(unsafe.Pointer(i)), uintptr(marginBottom), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetMarginLeft() (float64, error) { var marginLeft float64 - hr, _, err := i.Vtbl.GetMarginLeft.Call( + hr, _, _ := i.Vtbl.GetMarginLeft.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginLeft)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginLeft, err + return marginLeft, nil } func (i *ICoreWebView2PrintSettings) PutMarginLeft(marginLeft float64) error { - hr, _, err := i.Vtbl.PutMarginLeft.Call( + hr, _, _ := i.Vtbl.PutMarginLeft.Call( uintptr(unsafe.Pointer(i)), uintptr(marginLeft), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetMarginRight() (float64, error) { var marginRight float64 - hr, _, err := i.Vtbl.GetMarginRight.Call( + hr, _, _ := i.Vtbl.GetMarginRight.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&marginRight)), ) if windows.Handle(hr) != windows.S_OK { return 0.0, syscall.Errno(hr) } - return marginRight, err + return marginRight, nil } func (i *ICoreWebView2PrintSettings) PutMarginRight(marginRight float64) error { - hr, _, err := i.Vtbl.PutMarginRight.Call( + hr, _, _ := i.Vtbl.PutMarginRight.Call( uintptr(unsafe.Pointer(i)), uintptr(marginRight), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetShouldPrintBackgrounds() (bool, error) { // Create int32 to hold bool result var _shouldPrintBackgrounds int32 - hr, _, err := i.Vtbl.GetShouldPrintBackgrounds.Call( + hr, _, _ := i.Vtbl.GetShouldPrintBackgrounds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_shouldPrintBackgrounds)), ) @@ -281,7 +281,7 @@ func (i *ICoreWebView2PrintSettings) GetShouldPrintBackgrounds() (bool, error) { } // Get result and cleanup shouldPrintBackgrounds := _shouldPrintBackgrounds != 0 - return shouldPrintBackgrounds, err + return shouldPrintBackgrounds, nil } func (i *ICoreWebView2PrintSettings) PutShouldPrintBackgrounds(shouldPrintBackgrounds bool) error { @@ -292,21 +292,21 @@ func (i *ICoreWebView2PrintSettings) PutShouldPrintBackgrounds(shouldPrintBackgr _shouldPrintBackgrounds = 1 } - hr, _, err := i.Vtbl.PutShouldPrintBackgrounds.Call( + hr, _, _ := i.Vtbl.PutShouldPrintBackgrounds.Call( uintptr(unsafe.Pointer(i)), uintptr(_shouldPrintBackgrounds), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetShouldPrintSelectionOnly() (bool, error) { // Create int32 to hold bool result var _shouldPrintSelectionOnly int32 - hr, _, err := i.Vtbl.GetShouldPrintSelectionOnly.Call( + hr, _, _ := i.Vtbl.GetShouldPrintSelectionOnly.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_shouldPrintSelectionOnly)), ) @@ -315,7 +315,7 @@ func (i *ICoreWebView2PrintSettings) GetShouldPrintSelectionOnly() (bool, error) } // Get result and cleanup shouldPrintSelectionOnly := _shouldPrintSelectionOnly != 0 - return shouldPrintSelectionOnly, err + return shouldPrintSelectionOnly, nil } func (i *ICoreWebView2PrintSettings) PutShouldPrintSelectionOnly(shouldPrintSelectionOnly bool) error { @@ -326,21 +326,21 @@ func (i *ICoreWebView2PrintSettings) PutShouldPrintSelectionOnly(shouldPrintSele _shouldPrintSelectionOnly = 1 } - hr, _, err := i.Vtbl.PutShouldPrintSelectionOnly.Call( + hr, _, _ := i.Vtbl.PutShouldPrintSelectionOnly.Call( uintptr(unsafe.Pointer(i)), uintptr(_shouldPrintSelectionOnly), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetShouldPrintHeaderAndFooter() (bool, error) { // Create int32 to hold bool result var _shouldPrintHeaderAndFooter int32 - hr, _, err := i.Vtbl.GetShouldPrintHeaderAndFooter.Call( + hr, _, _ := i.Vtbl.GetShouldPrintHeaderAndFooter.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_shouldPrintHeaderAndFooter)), ) @@ -349,7 +349,7 @@ func (i *ICoreWebView2PrintSettings) GetShouldPrintHeaderAndFooter() (bool, erro } // Get result and cleanup shouldPrintHeaderAndFooter := _shouldPrintHeaderAndFooter != 0 - return shouldPrintHeaderAndFooter, err + return shouldPrintHeaderAndFooter, nil } func (i *ICoreWebView2PrintSettings) PutShouldPrintHeaderAndFooter(shouldPrintHeaderAndFooter bool) error { @@ -360,14 +360,14 @@ func (i *ICoreWebView2PrintSettings) PutShouldPrintHeaderAndFooter(shouldPrintHe _shouldPrintHeaderAndFooter = 1 } - hr, _, err := i.Vtbl.PutShouldPrintHeaderAndFooter.Call( + hr, _, _ := i.Vtbl.PutShouldPrintHeaderAndFooter.Call( uintptr(unsafe.Pointer(i)), uintptr(_shouldPrintHeaderAndFooter), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetHeaderTitle() (string, error) { @@ -375,7 +375,7 @@ func (i *ICoreWebView2PrintSettings) GetHeaderTitle() (string, error) { var _headerTitle *uint16 - hr, _, err := i.Vtbl.GetHeaderTitle.Call( + hr, _, _ := i.Vtbl.GetHeaderTitle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_headerTitle)), ) @@ -385,7 +385,7 @@ func (i *ICoreWebView2PrintSettings) GetHeaderTitle() (string, error) { // Get result and cleanup headerTitle := UTF16PtrToString(_headerTitle) CoTaskMemFree(unsafe.Pointer(_headerTitle)) - return headerTitle, err + return headerTitle, nil } func (i *ICoreWebView2PrintSettings) PutHeaderTitle(headerTitle string) error { @@ -396,14 +396,14 @@ func (i *ICoreWebView2PrintSettings) PutHeaderTitle(headerTitle string) error { return err } - hr, _, err := i.Vtbl.PutHeaderTitle.Call( + hr, _, _ := i.Vtbl.PutHeaderTitle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_headerTitle)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings) GetFooterUri() (string, error) { @@ -411,7 +411,7 @@ func (i *ICoreWebView2PrintSettings) GetFooterUri() (string, error) { var _footerUri *uint16 - hr, _, err := i.Vtbl.GetFooterUri.Call( + hr, _, _ := i.Vtbl.GetFooterUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_footerUri)), ) @@ -421,7 +421,7 @@ func (i *ICoreWebView2PrintSettings) GetFooterUri() (string, error) { // Get result and cleanup footerUri := UTF16PtrToString(_footerUri) CoTaskMemFree(unsafe.Pointer(_footerUri)) - return footerUri, err + return footerUri, nil } func (i *ICoreWebView2PrintSettings) PutFooterUri(footerUri string) error { @@ -432,12 +432,12 @@ func (i *ICoreWebView2PrintSettings) PutFooterUri(footerUri string) error { return err } - hr, _, err := i.Vtbl.PutFooterUri.Call( + hr, _, _ := i.Vtbl.PutFooterUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_footerUri)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go b/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go index 3aa6eb3c15a..93cba61edc0 100644 --- a/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go +++ b/webview2/pkg/webview2/ICoreWebView2PrintSettings2.go @@ -62,7 +62,7 @@ func (i *ICoreWebView2PrintSettings2) GetPageRanges() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetPageRanges.Call( + hr, _, _ := i.Vtbl.GetPageRanges.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -72,7 +72,7 @@ func (i *ICoreWebView2PrintSettings2) GetPageRanges() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutPageRanges(value string) error { @@ -83,176 +83,176 @@ func (i *ICoreWebView2PrintSettings2) PutPageRanges(value string) error { return err } - hr, _, err := i.Vtbl.PutPageRanges.Call( + hr, _, _ := i.Vtbl.PutPageRanges.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetPagesPerSide() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetPagesPerSide.Call( + hr, _, _ := i.Vtbl.GetPagesPerSide.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutPagesPerSide(value int32) error { - hr, _, err := i.Vtbl.PutPagesPerSide.Call( + hr, _, _ := i.Vtbl.PutPagesPerSide.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetCopies() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetCopies.Call( + hr, _, _ := i.Vtbl.GetCopies.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutCopies(value int32) error { - hr, _, err := i.Vtbl.PutCopies.Call( + hr, _, _ := i.Vtbl.PutCopies.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetCollation() (COREWEBVIEW2_PRINT_COLLATION, error) { var value COREWEBVIEW2_PRINT_COLLATION - hr, _, err := i.Vtbl.GetCollation.Call( + hr, _, _ := i.Vtbl.GetCollation.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutCollation(value COREWEBVIEW2_PRINT_COLLATION) error { - hr, _, err := i.Vtbl.PutCollation.Call( + hr, _, _ := i.Vtbl.PutCollation.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetColorMode() (COREWEBVIEW2_PRINT_COLOR_MODE, error) { var value COREWEBVIEW2_PRINT_COLOR_MODE - hr, _, err := i.Vtbl.GetColorMode.Call( + hr, _, _ := i.Vtbl.GetColorMode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutColorMode(value COREWEBVIEW2_PRINT_COLOR_MODE) error { - hr, _, err := i.Vtbl.PutColorMode.Call( + hr, _, _ := i.Vtbl.PutColorMode.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetDuplex() (COREWEBVIEW2_PRINT_DUPLEX, error) { var value COREWEBVIEW2_PRINT_DUPLEX - hr, _, err := i.Vtbl.GetDuplex.Call( + hr, _, _ := i.Vtbl.GetDuplex.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutDuplex(value COREWEBVIEW2_PRINT_DUPLEX) error { - hr, _, err := i.Vtbl.PutDuplex.Call( + hr, _, _ := i.Vtbl.PutDuplex.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetMediaSize() (COREWEBVIEW2_PRINT_MEDIA_SIZE, error) { var value COREWEBVIEW2_PRINT_MEDIA_SIZE - hr, _, err := i.Vtbl.GetMediaSize.Call( + hr, _, _ := i.Vtbl.GetMediaSize.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutMediaSize(value COREWEBVIEW2_PRINT_MEDIA_SIZE) error { - hr, _, err := i.Vtbl.PutMediaSize.Call( + hr, _, _ := i.Vtbl.PutMediaSize.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2PrintSettings2) GetPrinterName() (string, error) { @@ -260,7 +260,7 @@ func (i *ICoreWebView2PrintSettings2) GetPrinterName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetPrinterName.Call( + hr, _, _ := i.Vtbl.GetPrinterName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -270,7 +270,7 @@ func (i *ICoreWebView2PrintSettings2) GetPrinterName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2PrintSettings2) PutPrinterName(value string) error { @@ -281,12 +281,12 @@ func (i *ICoreWebView2PrintSettings2) PutPrinterName(value string) error { return err } - hr, _, err := i.Vtbl.PutPrinterName.Call( + hr, _, _ := i.Vtbl.PutPrinterName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go index f79c5c1f2bb..bcea5a2c9ff 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfo.go @@ -32,26 +32,26 @@ func (i *ICoreWebView2ProcessExtendedInfo) GetProcessInfo() (*ICoreWebView2Proce var processInfo *ICoreWebView2ProcessInfo - hr, _, err := i.Vtbl.GetProcessInfo.Call( + hr, _, _ := i.Vtbl.GetProcessInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&processInfo)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return processInfo, err + return processInfo, nil } func (i *ICoreWebView2ProcessExtendedInfo) GetAssociatedFrameInfos() (*ICoreWebView2FrameInfoCollection, error) { var frames *ICoreWebView2FrameInfoCollection - hr, _, err := i.Vtbl.GetAssociatedFrameInfos.Call( + hr, _, _ := i.Vtbl.GetAssociatedFrameInfos.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frames)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return frames, err + return frames, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go index ec568252b3a..741c45f56b4 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessExtendedInfoCollection.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2ProcessExtendedInfoCollection) GetCount() (uint32, error) var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ProcessExtendedInfoCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ProcessExtendedInfo, error) { var value *ICoreWebView2ProcessExtendedInfo - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2ProcessExtendedInfoCollection) GetValueAtIndex(index uint3 if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go index fe391d37891..a5c7aabc775 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs.go @@ -31,12 +31,12 @@ func (i *ICoreWebView2ProcessFailedEventArgs) GetProcessFailedKind() (COREWEBVIE var value COREWEBVIEW2_PROCESS_FAILED_KIND - hr, _, err := i.Vtbl.GetProcessFailedKind.Call( + hr, _, _ := i.Vtbl.GetProcessFailedKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go index e0ce47cc5a3..a9deb9d3a81 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs2.go @@ -49,28 +49,28 @@ func (i *ICoreWebView2ProcessFailedEventArgs2) GetReason() (COREWEBVIEW2_PROCESS var reason COREWEBVIEW2_PROCESS_FAILED_REASON - hr, _, err := i.Vtbl.GetReason.Call( + hr, _, _ := i.Vtbl.GetReason.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&reason)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return reason, err + return reason, nil } func (i *ICoreWebView2ProcessFailedEventArgs2) GetExitCode() (int, error) { var exitCode int - hr, _, err := i.Vtbl.GetExitCode.Call( + hr, _, _ := i.Vtbl.GetExitCode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&exitCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return exitCode, err + return exitCode, nil } func (i *ICoreWebView2ProcessFailedEventArgs2) GetProcessDescription() (string, error) { @@ -78,7 +78,7 @@ func (i *ICoreWebView2ProcessFailedEventArgs2) GetProcessDescription() (string, var _processDescription *uint16 - hr, _, err := i.Vtbl.GetProcessDescription.Call( + hr, _, _ := i.Vtbl.GetProcessDescription.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_processDescription)), ) @@ -88,19 +88,19 @@ func (i *ICoreWebView2ProcessFailedEventArgs2) GetProcessDescription() (string, // Get result and cleanup processDescription := UTF16PtrToString(_processDescription) CoTaskMemFree(unsafe.Pointer(_processDescription)) - return processDescription, err + return processDescription, nil } func (i *ICoreWebView2ProcessFailedEventArgs2) GetFrameInfosForFailedProcess() (*ICoreWebView2FrameInfoCollection, error) { var frames *ICoreWebView2FrameInfoCollection - hr, _, err := i.Vtbl.GetFrameInfosForFailedProcess.Call( + hr, _, _ := i.Vtbl.GetFrameInfosForFailedProcess.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&frames)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return frames, err + return frames, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go index a57795ad9df..1e0d74af496 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessFailedEventArgs3.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2ProcessFailedEventArgs3) GetFailureSourceModulePath() (str var _value *uint16 - hr, _, err := i.Vtbl.GetFailureSourceModulePath.Call( + hr, _, _ := i.Vtbl.GetFailureSourceModulePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -57,5 +57,5 @@ func (i *ICoreWebView2ProcessFailedEventArgs3) GetFailureSourceModulePath() (str // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go b/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go index 8c8e3aa4b85..370a5a009a1 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessInfo.go @@ -32,26 +32,26 @@ func (i *ICoreWebView2ProcessInfo) GetProcessId() (int32, error) { var value int32 - hr, _, err := i.Vtbl.GetProcessId.Call( + hr, _, _ := i.Vtbl.GetProcessId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ProcessInfo) GetKind() (COREWEBVIEW2_PROCESS_KIND, error) { var kind COREWEBVIEW2_PROCESS_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&kind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return kind, err + return kind, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go b/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go index f98f151f997..97f47fbef71 100644 --- a/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2ProcessInfoCollection.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2ProcessInfoCollection) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ProcessInfoCollection) GetValueAtIndex(index uint32) (*ICoreWebView2ProcessInfo, error) { var value *ICoreWebView2ProcessInfo - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2ProcessInfoCollection) GetValueAtIndex(index uint32) (*ICo if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile.go b/webview2/pkg/webview2/ICoreWebView2Profile.go index 8db1cf4acef..621673e78f8 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile.go @@ -38,7 +38,7 @@ func (i *ICoreWebView2Profile) GetProfileName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetProfileName.Call( + hr, _, _ := i.Vtbl.GetProfileName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -48,14 +48,14 @@ func (i *ICoreWebView2Profile) GetProfileName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Profile) GetIsInPrivateModeEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsInPrivateModeEnabled.Call( + hr, _, _ := i.Vtbl.GetIsInPrivateModeEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -64,7 +64,7 @@ func (i *ICoreWebView2Profile) GetIsInPrivateModeEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Profile) GetProfilePath() (string, error) { @@ -72,7 +72,7 @@ func (i *ICoreWebView2Profile) GetProfilePath() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetProfilePath.Call( + hr, _, _ := i.Vtbl.GetProfilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -82,7 +82,7 @@ func (i *ICoreWebView2Profile) GetProfilePath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Profile) GetDefaultDownloadFolderPath() (string, error) { @@ -90,7 +90,7 @@ func (i *ICoreWebView2Profile) GetDefaultDownloadFolderPath() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetDefaultDownloadFolderPath.Call( + hr, _, _ := i.Vtbl.GetDefaultDownloadFolderPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -100,7 +100,7 @@ func (i *ICoreWebView2Profile) GetDefaultDownloadFolderPath() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Profile) PutDefaultDownloadFolderPath(value string) error { @@ -111,39 +111,39 @@ func (i *ICoreWebView2Profile) PutDefaultDownloadFolderPath(value string) error return err } - hr, _, err := i.Vtbl.PutDefaultDownloadFolderPath.Call( + hr, _, _ := i.Vtbl.PutDefaultDownloadFolderPath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile) GetPreferredColorScheme() (COREWEBVIEW2_PREFERRED_COLOR_SCHEME, error) { var value COREWEBVIEW2_PREFERRED_COLOR_SCHEME - hr, _, err := i.Vtbl.GetPreferredColorScheme.Call( + hr, _, _ := i.Vtbl.GetPreferredColorScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Profile) PutPreferredColorScheme(value COREWEBVIEW2_PREFERRED_COLOR_SCHEME) error { - hr, _, err := i.Vtbl.PutPreferredColorScheme.Call( + hr, _, _ := i.Vtbl.PutPreferredColorScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile2.go b/webview2/pkg/webview2/ICoreWebView2Profile2.go index a0127a3e741..091ac5739da 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile2.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile2.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2) GetICoreWebView2Profile2() (*ICoreWebView2Profile2, erro func (i *ICoreWebView2Profile2) ClearBrowsingData(dataKinds COREWEBVIEW2_BROWSING_DATA_KINDS, handler *ICoreWebView2ClearBrowsingDataCompletedHandler) error { - hr, _, err := i.Vtbl.ClearBrowsingData.Call( + hr, _, _ := i.Vtbl.ClearBrowsingData.Call( uintptr(unsafe.Pointer(i)), uintptr(dataKinds), uintptr(unsafe.Pointer(handler)), @@ -55,13 +55,13 @@ func (i *ICoreWebView2Profile2) ClearBrowsingData(dataKinds COREWEBVIEW2_BROWSIN if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile2) ClearBrowsingDataInTimeRange(dataKinds COREWEBVIEW2_BROWSING_DATA_KINDS, startTime float64, endTime float64, handler *ICoreWebView2ClearBrowsingDataCompletedHandler) error { - hr, _, err := i.Vtbl.ClearBrowsingDataInTimeRange.Call( + hr, _, _ := i.Vtbl.ClearBrowsingDataInTimeRange.Call( uintptr(unsafe.Pointer(i)), uintptr(dataKinds), uintptr(startTime), @@ -71,18 +71,18 @@ func (i *ICoreWebView2Profile2) ClearBrowsingDataInTimeRange(dataKinds COREWEBVI if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile2) ClearBrowsingDataAll(handler *ICoreWebView2ClearBrowsingDataCompletedHandler) error { - hr, _, err := i.Vtbl.ClearBrowsingDataAll.Call( + hr, _, _ := i.Vtbl.ClearBrowsingDataAll.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile3.go b/webview2/pkg/webview2/ICoreWebView2Profile3.go index 650c433d4ae..13a5929b0d8 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile3.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile3.go @@ -47,25 +47,25 @@ func (i *ICoreWebView2Profile3) GetPreferredTrackingPreventionLevel() (COREWEBVI var value COREWEBVIEW2_TRACKING_PREVENTION_LEVEL - hr, _, err := i.Vtbl.GetPreferredTrackingPreventionLevel.Call( + hr, _, _ := i.Vtbl.GetPreferredTrackingPreventionLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Profile3) PutPreferredTrackingPreventionLevel(value COREWEBVIEW2_TRACKING_PREVENTION_LEVEL) error { - hr, _, err := i.Vtbl.PutPreferredTrackingPreventionLevel.Call( + hr, _, _ := i.Vtbl.PutPreferredTrackingPreventionLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile4.go b/webview2/pkg/webview2/ICoreWebView2Profile4.go index 5a3ca6fd7f2..bde7f119dc2 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile4.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile4.go @@ -51,7 +51,7 @@ func (i *ICoreWebView2Profile4) SetPermissionState(PermissionKind COREWEBVIEW2_P return err } - hr, _, err := i.Vtbl.SetPermissionState.Call( + hr, _, _ := i.Vtbl.SetPermissionState.Call( uintptr(unsafe.Pointer(i)), uintptr(PermissionKind), uintptr(unsafe.Pointer(_origin)), @@ -61,18 +61,18 @@ func (i *ICoreWebView2Profile4) SetPermissionState(PermissionKind COREWEBVIEW2_P if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile4) GetNonDefaultPermissionSettings(handler *ICoreWebView2GetNonDefaultPermissionSettingsCompletedHandler) error { - hr, _, err := i.Vtbl.GetNonDefaultPermissionSettings.Call( + hr, _, _ := i.Vtbl.GetNonDefaultPermissionSettings.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile5.go b/webview2/pkg/webview2/ICoreWebView2Profile5.go index 4b89a83e21b..f51a9a28d1c 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile5.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile5.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2Profile5) GetCookieManager() (*ICoreWebView2CookieManager, var value *ICoreWebView2CookieManager - hr, _, err := i.Vtbl.GetCookieManager.Call( + hr, _, _ := i.Vtbl.GetCookieManager.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile6.go b/webview2/pkg/webview2/ICoreWebView2Profile6.go index 2798553aacb..f13ba723add 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile6.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile6.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2Profile6) GetIsPasswordAutosaveEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( + hr, _, _ := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,7 +58,7 @@ func (i *ICoreWebView2Profile6) GetIsPasswordAutosaveEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Profile6) PutIsPasswordAutosaveEnabled(value bool) error { @@ -69,21 +69,21 @@ func (i *ICoreWebView2Profile6) PutIsPasswordAutosaveEnabled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( + hr, _, _ := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile6) GetIsGeneralAutofillEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsGeneralAutofillEnabled.Call( + hr, _, _ := i.Vtbl.GetIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -92,7 +92,7 @@ func (i *ICoreWebView2Profile6) GetIsGeneralAutofillEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Profile6) PutIsGeneralAutofillEnabled(value bool) error { @@ -103,12 +103,12 @@ func (i *ICoreWebView2Profile6) PutIsGeneralAutofillEnabled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsGeneralAutofillEnabled.Call( + hr, _, _ := i.Vtbl.PutIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile7.go b/webview2/pkg/webview2/ICoreWebView2Profile7.go index f439615395b..9051a084291 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile7.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile7.go @@ -51,7 +51,7 @@ func (i *ICoreWebView2Profile7) AddBrowserExtension(extensionFolderPath string, return err } - hr, _, err := i.Vtbl.AddBrowserExtension.Call( + hr, _, _ := i.Vtbl.AddBrowserExtension.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_extensionFolderPath)), uintptr(unsafe.Pointer(handler)), @@ -59,18 +59,18 @@ func (i *ICoreWebView2Profile7) AddBrowserExtension(extensionFolderPath string, if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile7) GetBrowserExtensions(handler *ICoreWebView2ProfileGetBrowserExtensionsCompletedHandler) error { - hr, _, err := i.Vtbl.GetBrowserExtensions.Call( + hr, _, _ := i.Vtbl.GetBrowserExtensions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Profile8.go b/webview2/pkg/webview2/ICoreWebView2Profile8.go index 5a78eb2b48c..7016ebeb704 100644 --- a/webview2/pkg/webview2/ICoreWebView2Profile8.go +++ b/webview2/pkg/webview2/ICoreWebView2Profile8.go @@ -47,20 +47,20 @@ func (i *ICoreWebView2) GetICoreWebView2Profile8() (*ICoreWebView2Profile8, erro func (i *ICoreWebView2Profile8) Delete() error { - hr, _, err := i.Vtbl.Delete.Call( + hr, _, _ := i.Vtbl.Delete.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Profile8) AddDeleted(eventHandler *ICoreWebView2ProfileDeletedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDeleted.Call( + hr, _, _ := i.Vtbl.AddDeleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -68,18 +68,18 @@ func (i *ICoreWebView2Profile8) AddDeleted(eventHandler *ICoreWebView2ProfileDel if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2Profile8) RemoveDeleted(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDeleted.Call( + hr, _, _ := i.Vtbl.RemoveDeleted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go b/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go index 6fe30bcf126..e3855215681 100644 --- a/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go +++ b/webview2/pkg/webview2/ICoreWebView2RegionRectCollectionView.go @@ -32,21 +32,21 @@ func (i *ICoreWebView2RegionRectCollectionView) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2RegionRectCollectionView) GetValueAtIndex(index uint32) (RECT, error) { var value RECT - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&value)), @@ -54,5 +54,5 @@ func (i *ICoreWebView2RegionRectCollectionView) GetValueAtIndex(index uint32) (R if windows.Handle(hr) != windows.S_OK { return RECT{}, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go index ea0cdaff0bd..0a2eca85585 100644 --- a/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2SaveAsUIShowingEventArgs.go @@ -43,7 +43,7 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetContentMimeType() (string, er var _value *uint16 - hr, _, err := i.Vtbl.GetContentMimeType.Call( + hr, _, _ := i.Vtbl.GetContentMimeType.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -53,7 +53,7 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetContentMimeType() (string, er // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutCancel(value bool) error { @@ -64,21 +64,21 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutCancel(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetCancel() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -87,7 +87,7 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetCancel() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSuppressDefaultDialog(value bool) error { @@ -98,21 +98,21 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSuppressDefaultDialog(value b _value = 1 } - hr, _, err := i.Vtbl.PutSuppressDefaultDialog.Call( + hr, _, _ := i.Vtbl.PutSuppressDefaultDialog.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSuppressDefaultDialog() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetSuppressDefaultDialog.Call( + hr, _, _ := i.Vtbl.GetSuppressDefaultDialog.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -121,21 +121,21 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSuppressDefaultDialog() (bool } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSaveAsFilePath(value string) error { @@ -146,14 +146,14 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutSaveAsFilePath(value string) return err } - hr, _, err := i.Vtbl.PutSaveAsFilePath.Call( + hr, _, _ := i.Vtbl.PutSaveAsFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSaveAsFilePath() (string, error) { @@ -161,7 +161,7 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSaveAsFilePath() (string, err var _value *uint16 - hr, _, err := i.Vtbl.GetSaveAsFilePath.Call( + hr, _, _ := i.Vtbl.GetSaveAsFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -171,7 +171,7 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetSaveAsFilePath() (string, err // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutAllowReplace(value bool) error { @@ -182,21 +182,21 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutAllowReplace(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutAllowReplace.Call( + hr, _, _ := i.Vtbl.PutAllowReplace.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetAllowReplace() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetAllowReplace.Call( + hr, _, _ := i.Vtbl.GetAllowReplace.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -205,32 +205,32 @@ func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetAllowReplace() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) PutKind(value COREWEBVIEW2_SAVE_AS_KIND) error { - hr, _, err := i.Vtbl.PutKind.Call( + hr, _, _ := i.Vtbl.PutKind.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveAsUIShowingEventArgs) GetKind() (COREWEBVIEW2_SAVE_AS_KIND, error) { var value COREWEBVIEW2_SAVE_AS_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go index fdf413c0533..416f727e9bd 100644 --- a/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2SaveFileSecurityCheckStartingEventArgs.go @@ -38,7 +38,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetCancelSave() (b // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetCancelSave.Call( + hr, _, _ := i.Vtbl.GetCancelSave.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -47,7 +47,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetCancelSave() (b } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) PutCancelSave(value bool) error { @@ -58,14 +58,14 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) PutCancelSave(valu _value = 1 } - hr, _, err := i.Vtbl.PutCancelSave.Call( + hr, _, _ := i.Vtbl.PutCancelSave.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDocumentOriginUri() (string, error) { @@ -73,7 +73,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDocumentOriginU var _value *uint16 - hr, _, err := i.Vtbl.GetDocumentOriginUri.Call( + hr, _, _ := i.Vtbl.GetDocumentOriginUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -83,7 +83,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDocumentOriginU // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFileExtension() (string, error) { @@ -91,7 +91,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFileExtension() var _value *uint16 - hr, _, err := i.Vtbl.GetFileExtension.Call( + hr, _, _ := i.Vtbl.GetFileExtension.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -101,7 +101,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFileExtension() // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFilePath() (string, error) { @@ -109,7 +109,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFilePath() (str var _value *uint16 - hr, _, err := i.Vtbl.GetFilePath.Call( + hr, _, _ := i.Vtbl.GetFilePath.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -119,14 +119,14 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetFilePath() (str // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetSuppressDefaultPolicy() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetSuppressDefaultPolicy.Call( + hr, _, _ := i.Vtbl.GetSuppressDefaultPolicy.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -135,7 +135,7 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetSuppressDefault } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) PutSuppressDefaultPolicy(value bool) error { @@ -146,26 +146,26 @@ func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) PutSuppressDefault _value = 1 } - hr, _, err := i.Vtbl.PutSuppressDefaultPolicy.Call( + hr, _, _ := i.Vtbl.PutSuppressDefaultPolicy.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2SaveFileSecurityCheckStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go index 15890e2797e..91f3ad1fb38 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ScreenCaptureStartingEventArgs.go @@ -36,7 +36,7 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetCancel() (bool, error) // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetCancel.Call( + hr, _, _ := i.Vtbl.GetCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -45,7 +45,7 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetCancel() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) PutCancel(value bool) error { @@ -56,21 +56,21 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) PutCancel(value bool) erro _value = 1 } - hr, _, err := i.Vtbl.PutCancel.Call( + hr, _, _ := i.Vtbl.PutCancel.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetHandled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHandled.Call( + hr, _, _ := i.Vtbl.GetHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -79,7 +79,7 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetHandled() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) PutHandled(value bool) error { @@ -90,40 +90,40 @@ func (i *ICoreWebView2ScreenCaptureStartingEventArgs) PutHandled(value bool) err _value = 1 } - hr, _, err := i.Vtbl.PutHandled.Call( + hr, _, _ := i.Vtbl.PutHandled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetOriginalSourceFrameInfo() (*ICoreWebView2FrameInfo, error) { var value *ICoreWebView2FrameInfo - hr, _, err := i.Vtbl.GetOriginalSourceFrameInfo.Call( + hr, _, _ := i.Vtbl.GetOriginalSourceFrameInfo.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ScreenCaptureStartingEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var value *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go index 540d363ddc6..475b155351f 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ScriptDialogOpeningEventArgs.go @@ -39,7 +39,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetUri() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -49,21 +49,21 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetKind() (COREWEBVIEW2_SCRIPT_DIALOG_KIND, error) { var kind COREWEBVIEW2_SCRIPT_DIALOG_KIND - hr, _, err := i.Vtbl.GetKind.Call( + hr, _, _ := i.Vtbl.GetKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&kind)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return kind, err + return kind, nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetMessage() (string, error) { @@ -71,7 +71,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetMessage() (string, error) var _message *uint16 - hr, _, err := i.Vtbl.GetMessage.Call( + hr, _, _ := i.Vtbl.GetMessage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_message)), ) @@ -81,19 +81,19 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetMessage() (string, error) // Get result and cleanup message := UTF16PtrToString(_message) CoTaskMemFree(unsafe.Pointer(_message)) - return message, err + return message, nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) Accept() error { - hr, _, err := i.Vtbl.Accept.Call( + hr, _, _ := i.Vtbl.Accept.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDefaultText() (string, error) { @@ -101,7 +101,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDefaultText() (string, er var _defaultText *uint16 - hr, _, err := i.Vtbl.GetDefaultText.Call( + hr, _, _ := i.Vtbl.GetDefaultText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_defaultText)), ) @@ -111,7 +111,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDefaultText() (string, er // Get result and cleanup defaultText := UTF16PtrToString(_defaultText) CoTaskMemFree(unsafe.Pointer(_defaultText)) - return defaultText, err + return defaultText, nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetResultText() (string, error) { @@ -119,7 +119,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetResultText() (string, err var _resultText *uint16 - hr, _, err := i.Vtbl.GetResultText.Call( + hr, _, _ := i.Vtbl.GetResultText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_resultText)), ) @@ -129,7 +129,7 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetResultText() (string, err // Get result and cleanup resultText := UTF16PtrToString(_resultText) CoTaskMemFree(unsafe.Pointer(_resultText)) - return resultText, err + return resultText, nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) PutResultText(resultText string) error { @@ -140,26 +140,26 @@ func (i *ICoreWebView2ScriptDialogOpeningEventArgs) PutResultText(resultText str return err } - hr, _, err := i.Vtbl.PutResultText.Call( + hr, _, _ := i.Vtbl.PutResultText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_resultText)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ScriptDialogOpeningEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ScriptException.go b/webview2/pkg/webview2/ICoreWebView2ScriptException.go index 1c12c9bacc1..c67e066e2e5 100644 --- a/webview2/pkg/webview2/ICoreWebView2ScriptException.go +++ b/webview2/pkg/webview2/ICoreWebView2ScriptException.go @@ -35,28 +35,28 @@ func (i *ICoreWebView2ScriptException) GetLineNumber() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetLineNumber.Call( + hr, _, _ := i.Vtbl.GetLineNumber.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ScriptException) GetColumnNumber() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetColumnNumber.Call( + hr, _, _ := i.Vtbl.GetColumnNumber.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ScriptException) GetName() (string, error) { @@ -64,7 +64,7 @@ func (i *ICoreWebView2ScriptException) GetName() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetName.Call( + hr, _, _ := i.Vtbl.GetName.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -74,7 +74,7 @@ func (i *ICoreWebView2ScriptException) GetName() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ScriptException) GetMessage() (string, error) { @@ -82,7 +82,7 @@ func (i *ICoreWebView2ScriptException) GetMessage() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetMessage.Call( + hr, _, _ := i.Vtbl.GetMessage.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -92,7 +92,7 @@ func (i *ICoreWebView2ScriptException) GetMessage() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ScriptException) GetToJson() (string, error) { @@ -100,7 +100,7 @@ func (i *ICoreWebView2ScriptException) GetToJson() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetToJson.Call( + hr, _, _ := i.Vtbl.GetToJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -110,5 +110,5 @@ func (i *ICoreWebView2ScriptException) GetToJson() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go index 2f62ed2c183..76b5a0fae7d 100644 --- a/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2ServerCertificateErrorDetectedEventArgs.go @@ -36,14 +36,14 @@ func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetErrorStatus() var value COREWEBVIEW2_WEB_ERROR_STATUS - hr, _, err := i.Vtbl.GetErrorStatus.Call( + hr, _, _ := i.Vtbl.GetErrorStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetRequestUri() (string, error) { @@ -51,7 +51,7 @@ func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetRequestUri() ( var _value *uint16 - hr, _, err := i.Vtbl.GetRequestUri.Call( + hr, _, _ := i.Vtbl.GetRequestUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -61,60 +61,60 @@ func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetRequestUri() ( // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetServerCertificate() (*ICoreWebView2Certificate, error) { var value *ICoreWebView2Certificate - hr, _, err := i.Vtbl.GetServerCertificate.Call( + hr, _, _ := i.Vtbl.GetServerCertificate.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetAction() (COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION, error) { var value COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION - hr, _, err := i.Vtbl.GetAction.Call( + hr, _, _ := i.Vtbl.GetAction.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) PutAction(value COREWEBVIEW2_SERVER_CERTIFICATE_ERROR_ACTION) error { - hr, _, err := i.Vtbl.PutAction.Call( + hr, _, _ := i.Vtbl.PutAction.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2ServerCertificateErrorDetectedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings.go b/webview2/pkg/webview2/ICoreWebView2Settings.go index fd15d30132f..550b4105110 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2Settings) GetIsScriptEnabled() (bool, error) { // Create int32 to hold bool result var _isScriptEnabled int32 - hr, _, err := i.Vtbl.GetIsScriptEnabled.Call( + hr, _, _ := i.Vtbl.GetIsScriptEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isScriptEnabled)), ) @@ -57,7 +57,7 @@ func (i *ICoreWebView2Settings) GetIsScriptEnabled() (bool, error) { } // Get result and cleanup isScriptEnabled := _isScriptEnabled != 0 - return isScriptEnabled, err + return isScriptEnabled, nil } func (i *ICoreWebView2Settings) PutIsScriptEnabled(isScriptEnabled bool) error { @@ -68,21 +68,21 @@ func (i *ICoreWebView2Settings) PutIsScriptEnabled(isScriptEnabled bool) error { _isScriptEnabled = 1 } - hr, _, err := i.Vtbl.PutIsScriptEnabled.Call( + hr, _, _ := i.Vtbl.PutIsScriptEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_isScriptEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetIsWebMessageEnabled() (bool, error) { // Create int32 to hold bool result var _isWebMessageEnabled int32 - hr, _, err := i.Vtbl.GetIsWebMessageEnabled.Call( + hr, _, _ := i.Vtbl.GetIsWebMessageEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isWebMessageEnabled)), ) @@ -91,7 +91,7 @@ func (i *ICoreWebView2Settings) GetIsWebMessageEnabled() (bool, error) { } // Get result and cleanup isWebMessageEnabled := _isWebMessageEnabled != 0 - return isWebMessageEnabled, err + return isWebMessageEnabled, nil } func (i *ICoreWebView2Settings) PutIsWebMessageEnabled(isWebMessageEnabled bool) error { @@ -102,21 +102,21 @@ func (i *ICoreWebView2Settings) PutIsWebMessageEnabled(isWebMessageEnabled bool) _isWebMessageEnabled = 1 } - hr, _, err := i.Vtbl.PutIsWebMessageEnabled.Call( + hr, _, _ := i.Vtbl.PutIsWebMessageEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_isWebMessageEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetAreDefaultScriptDialogsEnabled() (bool, error) { // Create int32 to hold bool result var _areDefaultScriptDialogsEnabled int32 - hr, _, err := i.Vtbl.GetAreDefaultScriptDialogsEnabled.Call( + hr, _, _ := i.Vtbl.GetAreDefaultScriptDialogsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_areDefaultScriptDialogsEnabled)), ) @@ -125,7 +125,7 @@ func (i *ICoreWebView2Settings) GetAreDefaultScriptDialogsEnabled() (bool, error } // Get result and cleanup areDefaultScriptDialogsEnabled := _areDefaultScriptDialogsEnabled != 0 - return areDefaultScriptDialogsEnabled, err + return areDefaultScriptDialogsEnabled, nil } func (i *ICoreWebView2Settings) PutAreDefaultScriptDialogsEnabled(areDefaultScriptDialogsEnabled bool) error { @@ -136,21 +136,21 @@ func (i *ICoreWebView2Settings) PutAreDefaultScriptDialogsEnabled(areDefaultScri _areDefaultScriptDialogsEnabled = 1 } - hr, _, err := i.Vtbl.PutAreDefaultScriptDialogsEnabled.Call( + hr, _, _ := i.Vtbl.PutAreDefaultScriptDialogsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_areDefaultScriptDialogsEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetIsStatusBarEnabled() (bool, error) { // Create int32 to hold bool result var _isStatusBarEnabled int32 - hr, _, err := i.Vtbl.GetIsStatusBarEnabled.Call( + hr, _, _ := i.Vtbl.GetIsStatusBarEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isStatusBarEnabled)), ) @@ -159,7 +159,7 @@ func (i *ICoreWebView2Settings) GetIsStatusBarEnabled() (bool, error) { } // Get result and cleanup isStatusBarEnabled := _isStatusBarEnabled != 0 - return isStatusBarEnabled, err + return isStatusBarEnabled, nil } func (i *ICoreWebView2Settings) PutIsStatusBarEnabled(isStatusBarEnabled bool) error { @@ -170,21 +170,21 @@ func (i *ICoreWebView2Settings) PutIsStatusBarEnabled(isStatusBarEnabled bool) e _isStatusBarEnabled = 1 } - hr, _, err := i.Vtbl.PutIsStatusBarEnabled.Call( + hr, _, _ := i.Vtbl.PutIsStatusBarEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_isStatusBarEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetAreDevToolsEnabled() (bool, error) { // Create int32 to hold bool result var _areDevToolsEnabled int32 - hr, _, err := i.Vtbl.GetAreDevToolsEnabled.Call( + hr, _, _ := i.Vtbl.GetAreDevToolsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_areDevToolsEnabled)), ) @@ -193,7 +193,7 @@ func (i *ICoreWebView2Settings) GetAreDevToolsEnabled() (bool, error) { } // Get result and cleanup areDevToolsEnabled := _areDevToolsEnabled != 0 - return areDevToolsEnabled, err + return areDevToolsEnabled, nil } func (i *ICoreWebView2Settings) PutAreDevToolsEnabled(areDevToolsEnabled bool) error { @@ -204,21 +204,21 @@ func (i *ICoreWebView2Settings) PutAreDevToolsEnabled(areDevToolsEnabled bool) e _areDevToolsEnabled = 1 } - hr, _, err := i.Vtbl.PutAreDevToolsEnabled.Call( + hr, _, _ := i.Vtbl.PutAreDevToolsEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_areDevToolsEnabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetAreDefaultContextMenusEnabled() (bool, error) { // Create int32 to hold bool result var _enabled int32 - hr, _, err := i.Vtbl.GetAreDefaultContextMenusEnabled.Call( + hr, _, _ := i.Vtbl.GetAreDefaultContextMenusEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_enabled)), ) @@ -227,7 +227,7 @@ func (i *ICoreWebView2Settings) GetAreDefaultContextMenusEnabled() (bool, error) } // Get result and cleanup enabled := _enabled != 0 - return enabled, err + return enabled, nil } func (i *ICoreWebView2Settings) PutAreDefaultContextMenusEnabled(enabled bool) error { @@ -238,21 +238,21 @@ func (i *ICoreWebView2Settings) PutAreDefaultContextMenusEnabled(enabled bool) e _enabled = 1 } - hr, _, err := i.Vtbl.PutAreDefaultContextMenusEnabled.Call( + hr, _, _ := i.Vtbl.PutAreDefaultContextMenusEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_enabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetAreHostObjectsAllowed() (bool, error) { // Create int32 to hold bool result var _allowed int32 - hr, _, err := i.Vtbl.GetAreHostObjectsAllowed.Call( + hr, _, _ := i.Vtbl.GetAreHostObjectsAllowed.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_allowed)), ) @@ -261,7 +261,7 @@ func (i *ICoreWebView2Settings) GetAreHostObjectsAllowed() (bool, error) { } // Get result and cleanup allowed := _allowed != 0 - return allowed, err + return allowed, nil } func (i *ICoreWebView2Settings) PutAreHostObjectsAllowed(allowed bool) error { @@ -272,21 +272,21 @@ func (i *ICoreWebView2Settings) PutAreHostObjectsAllowed(allowed bool) error { _allowed = 1 } - hr, _, err := i.Vtbl.PutAreHostObjectsAllowed.Call( + hr, _, _ := i.Vtbl.PutAreHostObjectsAllowed.Call( uintptr(unsafe.Pointer(i)), uintptr(_allowed), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetIsZoomControlEnabled() (bool, error) { // Create int32 to hold bool result var _enabled int32 - hr, _, err := i.Vtbl.GetIsZoomControlEnabled.Call( + hr, _, _ := i.Vtbl.GetIsZoomControlEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_enabled)), ) @@ -295,7 +295,7 @@ func (i *ICoreWebView2Settings) GetIsZoomControlEnabled() (bool, error) { } // Get result and cleanup enabled := _enabled != 0 - return enabled, err + return enabled, nil } func (i *ICoreWebView2Settings) PutIsZoomControlEnabled(enabled bool) error { @@ -306,21 +306,21 @@ func (i *ICoreWebView2Settings) PutIsZoomControlEnabled(enabled bool) error { _enabled = 1 } - hr, _, err := i.Vtbl.PutIsZoomControlEnabled.Call( + hr, _, _ := i.Vtbl.PutIsZoomControlEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_enabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings) GetIsBuiltInErrorPageEnabled() (bool, error) { // Create int32 to hold bool result var _enabled int32 - hr, _, err := i.Vtbl.GetIsBuiltInErrorPageEnabled.Call( + hr, _, _ := i.Vtbl.GetIsBuiltInErrorPageEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_enabled)), ) @@ -329,7 +329,7 @@ func (i *ICoreWebView2Settings) GetIsBuiltInErrorPageEnabled() (bool, error) { } // Get result and cleanup enabled := _enabled != 0 - return enabled, err + return enabled, nil } func (i *ICoreWebView2Settings) PutIsBuiltInErrorPageEnabled(enabled bool) error { @@ -340,12 +340,12 @@ func (i *ICoreWebView2Settings) PutIsBuiltInErrorPageEnabled(enabled bool) error _enabled = 1 } - hr, _, err := i.Vtbl.PutIsBuiltInErrorPageEnabled.Call( + hr, _, _ := i.Vtbl.PutIsBuiltInErrorPageEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_enabled), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings2.go b/webview2/pkg/webview2/ICoreWebView2Settings2.go index 4e053de02ce..d8293fc2cb2 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings2.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings2.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2Settings2) GetUserAgent() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetUserAgent.Call( + hr, _, _ := i.Vtbl.GetUserAgent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,7 +58,7 @@ func (i *ICoreWebView2Settings2) GetUserAgent() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2Settings2) PutUserAgent(value string) error { @@ -69,12 +69,12 @@ func (i *ICoreWebView2Settings2) PutUserAgent(value string) error { return err } - hr, _, err := i.Vtbl.PutUserAgent.Call( + hr, _, _ := i.Vtbl.PutUserAgent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings3.go b/webview2/pkg/webview2/ICoreWebView2Settings3.go index 91625fbfdcc..794f783129b 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings3.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings3.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Settings3) GetAreBrowserAcceleratorKeysEnabled() (bool, er // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetAreBrowserAcceleratorKeysEnabled.Call( + hr, _, _ := i.Vtbl.GetAreBrowserAcceleratorKeysEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2Settings3) GetAreBrowserAcceleratorKeysEnabled() (bool, er } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings3) PutAreBrowserAcceleratorKeysEnabled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2Settings3) PutAreBrowserAcceleratorKeysEnabled(value bool) _value = 1 } - hr, _, err := i.Vtbl.PutAreBrowserAcceleratorKeysEnabled.Call( + hr, _, _ := i.Vtbl.PutAreBrowserAcceleratorKeysEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings4.go b/webview2/pkg/webview2/ICoreWebView2Settings4.go index dda35213822..9a2a06b01d0 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings4.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings4.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2Settings4) GetIsPasswordAutosaveEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( + hr, _, _ := i.Vtbl.GetIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -58,7 +58,7 @@ func (i *ICoreWebView2Settings4) GetIsPasswordAutosaveEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings4) PutIsPasswordAutosaveEnabled(value bool) error { @@ -69,21 +69,21 @@ func (i *ICoreWebView2Settings4) PutIsPasswordAutosaveEnabled(value bool) error _value = 1 } - hr, _, err := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( + hr, _, _ := i.Vtbl.PutIsPasswordAutosaveEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2Settings4) GetIsGeneralAutofillEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsGeneralAutofillEnabled.Call( + hr, _, _ := i.Vtbl.GetIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -92,7 +92,7 @@ func (i *ICoreWebView2Settings4) GetIsGeneralAutofillEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings4) PutIsGeneralAutofillEnabled(value bool) error { @@ -103,12 +103,12 @@ func (i *ICoreWebView2Settings4) PutIsGeneralAutofillEnabled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsGeneralAutofillEnabled.Call( + hr, _, _ := i.Vtbl.PutIsGeneralAutofillEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings5.go b/webview2/pkg/webview2/ICoreWebView2Settings5.go index e3d92609a61..287c8a6cd15 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings5.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings5.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Settings5) GetIsPinchZoomEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsPinchZoomEnabled.Call( + hr, _, _ := i.Vtbl.GetIsPinchZoomEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2Settings5) GetIsPinchZoomEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings5) PutIsPinchZoomEnabled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2Settings5) PutIsPinchZoomEnabled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsPinchZoomEnabled.Call( + hr, _, _ := i.Vtbl.PutIsPinchZoomEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings6.go b/webview2/pkg/webview2/ICoreWebView2Settings6.go index 51eb42a2bce..e8f95b2bb7a 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings6.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings6.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Settings6) GetIsSwipeNavigationEnabled() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsSwipeNavigationEnabled.Call( + hr, _, _ := i.Vtbl.GetIsSwipeNavigationEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2Settings6) GetIsSwipeNavigationEnabled() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings6) PutIsSwipeNavigationEnabled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2Settings6) PutIsSwipeNavigationEnabled(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsSwipeNavigationEnabled.Call( + hr, _, _ := i.Vtbl.PutIsSwipeNavigationEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings7.go b/webview2/pkg/webview2/ICoreWebView2Settings7.go index 7e07fdae4f7..9059b583ae0 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings7.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings7.go @@ -47,25 +47,25 @@ func (i *ICoreWebView2Settings7) GetHiddenPdfToolbarItems() (COREWEBVIEW2_PDF_TO var value COREWEBVIEW2_PDF_TOOLBAR_ITEMS - hr, _, err := i.Vtbl.GetHiddenPdfToolbarItems.Call( + hr, _, _ := i.Vtbl.GetHiddenPdfToolbarItems.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2Settings7) PutHiddenPdfToolbarItems(value COREWEBVIEW2_PDF_TOOLBAR_ITEMS) error { - hr, _, err := i.Vtbl.PutHiddenPdfToolbarItems.Call( + hr, _, _ := i.Vtbl.PutHiddenPdfToolbarItems.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings8.go b/webview2/pkg/webview2/ICoreWebView2Settings8.go index 9e06f311873..d81a18e2a0d 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings8.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings8.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Settings8) GetIsReputationCheckingRequired() (bool, error) // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsReputationCheckingRequired.Call( + hr, _, _ := i.Vtbl.GetIsReputationCheckingRequired.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2Settings8) GetIsReputationCheckingRequired() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings8) PutIsReputationCheckingRequired(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2Settings8) PutIsReputationCheckingRequired(value bool) err _value = 1 } - hr, _, err := i.Vtbl.PutIsReputationCheckingRequired.Call( + hr, _, _ := i.Vtbl.PutIsReputationCheckingRequired.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2Settings9.go b/webview2/pkg/webview2/ICoreWebView2Settings9.go index 30b56e0e5be..ac9b1d4ea1f 100644 --- a/webview2/pkg/webview2/ICoreWebView2Settings9.go +++ b/webview2/pkg/webview2/ICoreWebView2Settings9.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2Settings9) GetIsNonClientRegionSupportEnabled() (bool, err // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsNonClientRegionSupportEnabled.Call( + hr, _, _ := i.Vtbl.GetIsNonClientRegionSupportEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -56,7 +56,7 @@ func (i *ICoreWebView2Settings9) GetIsNonClientRegionSupportEnabled() (bool, err } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2Settings9) PutIsNonClientRegionSupportEnabled(value bool) error { @@ -67,12 +67,12 @@ func (i *ICoreWebView2Settings9) PutIsNonClientRegionSupportEnabled(value bool) _value = 1 } - hr, _, err := i.Vtbl.PutIsNonClientRegionSupportEnabled.Call( + hr, _, _ := i.Vtbl.PutIsNonClientRegionSupportEnabled.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go b/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go index 5f69a589de6..1163a24e6b6 100644 --- a/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go +++ b/webview2/pkg/webview2/ICoreWebView2SharedBuffer.go @@ -35,66 +35,66 @@ func (i *ICoreWebView2SharedBuffer) GetSize() (uint64, error) { var value uint64 - hr, _, err := i.Vtbl.GetSize.Call( + hr, _, _ := i.Vtbl.GetSize.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2SharedBuffer) GetBuffer() (*uint8, error) { var value *uint8 - hr, _, err := i.Vtbl.GetBuffer.Call( + hr, _, _ := i.Vtbl.GetBuffer.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2SharedBuffer) OpenStream() (*IStream, error) { var value *IStream - hr, _, err := i.Vtbl.OpenStream.Call( + hr, _, _ := i.Vtbl.OpenStream.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2SharedBuffer) GetFileMappingHandle() (HANDLE, error) { var value HANDLE - hr, _, err := i.Vtbl.GetFileMappingHandle.Call( + hr, _, _ := i.Vtbl.GetFileMappingHandle.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2SharedBuffer) Close() error { - hr, _, err := i.Vtbl.Close.Call( + hr, _, _ := i.Vtbl.Close.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go index eb5dafdf9e3..686d0ec7967 100644 --- a/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2SourceChangedEventArgs.go @@ -31,7 +31,7 @@ func (i *ICoreWebView2SourceChangedEventArgs) GetIsNewDocument() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsNewDocument.Call( + hr, _, _ := i.Vtbl.GetIsNewDocument.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -40,5 +40,5 @@ func (i *ICoreWebView2SourceChangedEventArgs) GetIsNewDocument() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2StringCollection.go b/webview2/pkg/webview2/ICoreWebView2StringCollection.go index 1b8d8c4d8d3..65305893feb 100644 --- a/webview2/pkg/webview2/ICoreWebView2StringCollection.go +++ b/webview2/pkg/webview2/ICoreWebView2StringCollection.go @@ -32,14 +32,14 @@ func (i *ICoreWebView2StringCollection) GetCount() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetCount.Call( + hr, _, _ := i.Vtbl.GetCount.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2StringCollection) GetValueAtIndex(index uint32) (string, error) { @@ -47,7 +47,7 @@ func (i *ICoreWebView2StringCollection) GetValueAtIndex(index uint32) (string, e var _value *uint16 - hr, _, err := i.Vtbl.GetValueAtIndex.Call( + hr, _, _ := i.Vtbl.GetValueAtIndex.Call( uintptr(unsafe.Pointer(i)), uintptr(index), uintptr(unsafe.Pointer(&_value)), @@ -58,5 +58,5 @@ func (i *ICoreWebView2StringCollection) GetValueAtIndex(index uint32) (string, e // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go index 5a00690bb01..d4f44f4de3a 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs.go @@ -34,7 +34,7 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) GetSource() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetSource.Call( + hr, _, _ := i.Vtbl.GetSource.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -44,7 +44,7 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) GetSource() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2WebMessageReceivedEventArgs) GetWebMessageAsJson() (string, error) { @@ -52,7 +52,7 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) GetWebMessageAsJson() (string var _value *uint16 - hr, _, err := i.Vtbl.GetWebMessageAsJson.Call( + hr, _, _ := i.Vtbl.GetWebMessageAsJson.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -62,7 +62,7 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) GetWebMessageAsJson() (string // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2WebMessageReceivedEventArgs) TryGetWebMessageAsString() (string, error) { @@ -70,7 +70,7 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) TryGetWebMessageAsString() (s var _value *uint16 - hr, _, err := i.Vtbl.TryGetWebMessageAsString.Call( + hr, _, _ := i.Vtbl.TryGetWebMessageAsString.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -80,5 +80,5 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs) TryGetWebMessageAsString() (s // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go index 781f62263df..2675ee02e9e 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2WebMessageReceivedEventArgs2.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2WebMessageReceivedEventArgs2) GetAdditionalObjects() (*ICo var value *ICoreWebView2ObjectCollectionView - hr, _, err := i.Vtbl.GetAdditionalObjects.Call( + hr, _, _ := i.Vtbl.GetAdditionalObjects.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go index 9b0086fadba..90001ccc831 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequest.go @@ -38,7 +38,7 @@ func (i *ICoreWebView2WebResourceRequest) GetUri() (string, error) { var _uri *uint16 - hr, _, err := i.Vtbl.GetUri.Call( + hr, _, _ := i.Vtbl.GetUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_uri)), ) @@ -48,7 +48,7 @@ func (i *ICoreWebView2WebResourceRequest) GetUri() (string, error) { // Get result and cleanup uri := UTF16PtrToString(_uri) CoTaskMemFree(unsafe.Pointer(_uri)) - return uri, err + return uri, nil } func (i *ICoreWebView2WebResourceRequest) PutUri(uri string) error { @@ -59,14 +59,14 @@ func (i *ICoreWebView2WebResourceRequest) PutUri(uri string) error { return err } - hr, _, err := i.Vtbl.PutUri.Call( + hr, _, _ := i.Vtbl.PutUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2WebResourceRequest) GetMethod() (string, error) { @@ -74,7 +74,7 @@ func (i *ICoreWebView2WebResourceRequest) GetMethod() (string, error) { var _method *uint16 - hr, _, err := i.Vtbl.GetMethod.Call( + hr, _, _ := i.Vtbl.GetMethod.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_method)), ) @@ -84,7 +84,7 @@ func (i *ICoreWebView2WebResourceRequest) GetMethod() (string, error) { // Get result and cleanup method := UTF16PtrToString(_method) CoTaskMemFree(unsafe.Pointer(_method)) - return method, err + return method, nil } func (i *ICoreWebView2WebResourceRequest) PutMethod(method string) error { @@ -95,53 +95,53 @@ func (i *ICoreWebView2WebResourceRequest) PutMethod(method string) error { return err } - hr, _, err := i.Vtbl.PutMethod.Call( + hr, _, _ := i.Vtbl.PutMethod.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_method)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2WebResourceRequest) GetContent() (*IStream, error) { var content *IStream - hr, _, err := i.Vtbl.GetContent.Call( + hr, _, _ := i.Vtbl.GetContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&content)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return content, err + return content, nil } func (i *ICoreWebView2WebResourceRequest) PutContent(content *IStream) error { - hr, _, err := i.Vtbl.PutContent.Call( + hr, _, _ := i.Vtbl.PutContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(content)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2WebResourceRequest) GetHeaders() (*ICoreWebView2HttpRequestHeaders, error) { var headers *ICoreWebView2HttpRequestHeaders - hr, _, err := i.Vtbl.GetHeaders.Call( + hr, _, _ := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&headers)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return headers, err + return headers, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go index c54270b232c..ff42ad1db77 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs.go @@ -35,67 +35,67 @@ func (i *ICoreWebView2WebResourceRequestedEventArgs) GetRequest() (*ICoreWebView var request *ICoreWebView2WebResourceRequest - hr, _, err := i.Vtbl.GetRequest.Call( + hr, _, _ := i.Vtbl.GetRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&request)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return request, err + return request, nil } func (i *ICoreWebView2WebResourceRequestedEventArgs) GetResponse() (*ICoreWebView2WebResourceResponse, error) { var response *ICoreWebView2WebResourceResponse - hr, _, err := i.Vtbl.GetResponse.Call( + hr, _, _ := i.Vtbl.GetResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&response)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return response, err + return response, nil } func (i *ICoreWebView2WebResourceRequestedEventArgs) PutResponse(response *ICoreWebView2WebResourceResponse) error { - hr, _, err := i.Vtbl.PutResponse.Call( + hr, _, _ := i.Vtbl.PutResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(response)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2WebResourceRequestedEventArgs) GetDeferral() (*ICoreWebView2Deferral, error) { var deferral *ICoreWebView2Deferral - hr, _, err := i.Vtbl.GetDeferral.Call( + hr, _, _ := i.Vtbl.GetDeferral.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&deferral)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return deferral, err + return deferral, nil } func (i *ICoreWebView2WebResourceRequestedEventArgs) GetResourceContext() (COREWEBVIEW2_WEB_RESOURCE_CONTEXT, error) { var context COREWEBVIEW2_WEB_RESOURCE_CONTEXT - hr, _, err := i.Vtbl.GetResourceContext.Call( + hr, _, _ := i.Vtbl.GetResourceContext.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&context)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return context, err + return context, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go index 3e37a096ee2..c58bd65583a 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceRequestedEventArgs2.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2WebResourceRequestedEventArgs2) GetRequestedSourceKind() ( var value COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS - hr, _, err := i.Vtbl.GetRequestedSourceKind.Call( + hr, _, _ := i.Vtbl.GetRequestedSourceKind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go index 83b6ba170c0..2848af6b744 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponse.go @@ -37,68 +37,68 @@ func (i *ICoreWebView2WebResourceResponse) GetContent() (*IStream, error) { var content *IStream - hr, _, err := i.Vtbl.GetContent.Call( + hr, _, _ := i.Vtbl.GetContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&content)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return content, err + return content, nil } func (i *ICoreWebView2WebResourceResponse) PutContent(content *IStream) error { - hr, _, err := i.Vtbl.PutContent.Call( + hr, _, _ := i.Vtbl.PutContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(content)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2WebResourceResponse) GetHeaders() (*ICoreWebView2HttpResponseHeaders, error) { var headers *ICoreWebView2HttpResponseHeaders - hr, _, err := i.Vtbl.GetHeaders.Call( + hr, _, _ := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&headers)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return headers, err + return headers, nil } func (i *ICoreWebView2WebResourceResponse) GetStatusCode() (int, error) { var statusCode int - hr, _, err := i.Vtbl.GetStatusCode.Call( + hr, _, _ := i.Vtbl.GetStatusCode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&statusCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return statusCode, err + return statusCode, nil } func (i *ICoreWebView2WebResourceResponse) PutStatusCode(statusCode int) error { - hr, _, err := i.Vtbl.PutStatusCode.Call( + hr, _, _ := i.Vtbl.PutStatusCode.Call( uintptr(unsafe.Pointer(i)), uintptr(statusCode), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2WebResourceResponse) GetReasonPhrase() (string, error) { @@ -106,7 +106,7 @@ func (i *ICoreWebView2WebResourceResponse) GetReasonPhrase() (string, error) { var _reasonPhrase *uint16 - hr, _, err := i.Vtbl.GetReasonPhrase.Call( + hr, _, _ := i.Vtbl.GetReasonPhrase.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_reasonPhrase)), ) @@ -116,7 +116,7 @@ func (i *ICoreWebView2WebResourceResponse) GetReasonPhrase() (string, error) { // Get result and cleanup reasonPhrase := UTF16PtrToString(_reasonPhrase) CoTaskMemFree(unsafe.Pointer(_reasonPhrase)) - return reasonPhrase, err + return reasonPhrase, nil } func (i *ICoreWebView2WebResourceResponse) PutReasonPhrase(reasonPhrase string) error { @@ -127,12 +127,12 @@ func (i *ICoreWebView2WebResourceResponse) PutReasonPhrase(reasonPhrase string) return err } - hr, _, err := i.Vtbl.PutReasonPhrase.Call( + hr, _, _ := i.Vtbl.PutReasonPhrase.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_reasonPhrase)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go index fece79a81f2..2d5f298530e 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseReceivedEventArgs.go @@ -32,26 +32,26 @@ func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) GetRequest() (*ICore var value *ICoreWebView2WebResourceRequest - hr, _, err := i.Vtbl.GetRequest.Call( + hr, _, _ := i.Vtbl.GetRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2WebResourceResponseReceivedEventArgs) GetResponse() (*ICoreWebView2WebResourceResponseView, error) { var value *ICoreWebView2WebResourceResponseView - hr, _, err := i.Vtbl.GetResponse.Call( + hr, _, _ := i.Vtbl.GetResponse.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go index e35854ac25d..21ef5c43a39 100644 --- a/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go +++ b/webview2/pkg/webview2/ICoreWebView2WebResourceResponseView.go @@ -34,28 +34,28 @@ func (i *ICoreWebView2WebResourceResponseView) GetHeaders() (*ICoreWebView2HttpR var headers *ICoreWebView2HttpResponseHeaders - hr, _, err := i.Vtbl.GetHeaders.Call( + hr, _, _ := i.Vtbl.GetHeaders.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&headers)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return headers, err + return headers, nil } func (i *ICoreWebView2WebResourceResponseView) GetStatusCode() (int, error) { var statusCode int - hr, _, err := i.Vtbl.GetStatusCode.Call( + hr, _, _ := i.Vtbl.GetStatusCode.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&statusCode)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return statusCode, err + return statusCode, nil } func (i *ICoreWebView2WebResourceResponseView) GetReasonPhrase() (string, error) { @@ -63,7 +63,7 @@ func (i *ICoreWebView2WebResourceResponseView) GetReasonPhrase() (string, error) var _reasonPhrase *uint16 - hr, _, err := i.Vtbl.GetReasonPhrase.Call( + hr, _, _ := i.Vtbl.GetReasonPhrase.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_reasonPhrase)), ) @@ -73,18 +73,18 @@ func (i *ICoreWebView2WebResourceResponseView) GetReasonPhrase() (string, error) // Get result and cleanup reasonPhrase := UTF16PtrToString(_reasonPhrase) CoTaskMemFree(unsafe.Pointer(_reasonPhrase)) - return reasonPhrase, err + return reasonPhrase, nil } func (i *ICoreWebView2WebResourceResponseView) GetContent(handler *ICoreWebView2WebResourceResponseViewGetContentCompletedHandler) error { - hr, _, err := i.Vtbl.GetContent.Call( + hr, _, _ := i.Vtbl.GetContent.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go b/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go index 6ed417d0e1d..55917ce3fd8 100644 --- a/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go +++ b/webview2/pkg/webview2/ICoreWebView2WindowFeatures.go @@ -40,7 +40,7 @@ func (i *ICoreWebView2WindowFeatures) GetHasPosition() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasPosition.Call( + hr, _, _ := i.Vtbl.GetHasPosition.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -49,14 +49,14 @@ func (i *ICoreWebView2WindowFeatures) GetHasPosition() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetHasSize() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetHasSize.Call( + hr, _, _ := i.Vtbl.GetHasSize.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -65,70 +65,70 @@ func (i *ICoreWebView2WindowFeatures) GetHasSize() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetLeft() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetLeft.Call( + hr, _, _ := i.Vtbl.GetLeft.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetTop() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetTop.Call( + hr, _, _ := i.Vtbl.GetTop.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetHeight() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetHeight.Call( + hr, _, _ := i.Vtbl.GetHeight.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetWidth() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetWidth.Call( + hr, _, _ := i.Vtbl.GetWidth.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayMenuBar() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldDisplayMenuBar.Call( + hr, _, _ := i.Vtbl.GetShouldDisplayMenuBar.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -137,14 +137,14 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayMenuBar() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayStatus() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldDisplayStatus.Call( + hr, _, _ := i.Vtbl.GetShouldDisplayStatus.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -153,14 +153,14 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayStatus() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayToolbar() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldDisplayToolbar.Call( + hr, _, _ := i.Vtbl.GetShouldDisplayToolbar.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -169,14 +169,14 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayToolbar() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2WindowFeatures) GetShouldDisplayScrollBars() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetShouldDisplayScrollBars.Call( + hr, _, _ := i.Vtbl.GetShouldDisplayScrollBars.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -185,5 +185,5 @@ func (i *ICoreWebView2WindowFeatures) GetShouldDisplayScrollBars() (bool, error) } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_10.go b/webview2/pkg/webview2/ICoreWebView2_10.go index ccccf18c5eb..ad4d8eb1ab7 100644 --- a/webview2/pkg/webview2/ICoreWebView2_10.go +++ b/webview2/pkg/webview2/ICoreWebView2_10.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2_10) AddBasicAuthenticationRequested(eventHandler *ICoreWe var token EventRegistrationToken - hr, _, err := i.Vtbl.AddBasicAuthenticationRequested.Call( + hr, _, _ := i.Vtbl.AddBasicAuthenticationRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2_10) AddBasicAuthenticationRequested(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_10) RemoveBasicAuthenticationRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveBasicAuthenticationRequested.Call( + hr, _, _ := i.Vtbl.RemoveBasicAuthenticationRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_11.go b/webview2/pkg/webview2/ICoreWebView2_11.go index 9962ca696ea..d97ab095b46 100644 --- a/webview2/pkg/webview2/ICoreWebView2_11.go +++ b/webview2/pkg/webview2/ICoreWebView2_11.go @@ -62,7 +62,7 @@ func (i *ICoreWebView2_11) CallDevToolsProtocolMethodForSession(sessionId string return err } - hr, _, err := i.Vtbl.CallDevToolsProtocolMethodForSession.Call( + hr, _, _ := i.Vtbl.CallDevToolsProtocolMethodForSession.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_sessionId)), uintptr(unsafe.Pointer(_methodName)), @@ -72,14 +72,14 @@ func (i *ICoreWebView2_11) CallDevToolsProtocolMethodForSession(sessionId string if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_11) AddContextMenuRequested(eventHandler *ICoreWebView2ContextMenuRequestedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddContextMenuRequested.Call( + hr, _, _ := i.Vtbl.AddContextMenuRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -87,18 +87,18 @@ func (i *ICoreWebView2_11) AddContextMenuRequested(eventHandler *ICoreWebView2Co if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_11) RemoveContextMenuRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveContextMenuRequested.Call( + hr, _, _ := i.Vtbl.RemoveContextMenuRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_12.go b/webview2/pkg/webview2/ICoreWebView2_12.go index e0482283343..1566e258a98 100644 --- a/webview2/pkg/webview2/ICoreWebView2_12.go +++ b/webview2/pkg/webview2/ICoreWebView2_12.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2_12) AddStatusBarTextChanged(eventHandler *ICoreWebView2St var token EventRegistrationToken - hr, _, err := i.Vtbl.AddStatusBarTextChanged.Call( + hr, _, _ := i.Vtbl.AddStatusBarTextChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -56,20 +56,20 @@ func (i *ICoreWebView2_12) AddStatusBarTextChanged(eventHandler *ICoreWebView2St if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_12) RemoveStatusBarTextChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveStatusBarTextChanged.Call( + hr, _, _ := i.Vtbl.RemoveStatusBarTextChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_12) GetStatusBarText() (string, error) { @@ -77,7 +77,7 @@ func (i *ICoreWebView2_12) GetStatusBarText() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetStatusBarText.Call( + hr, _, _ := i.Vtbl.GetStatusBarText.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -87,5 +87,5 @@ func (i *ICoreWebView2_12) GetStatusBarText() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_13.go b/webview2/pkg/webview2/ICoreWebView2_13.go index ccf2fcdd033..88d5083c463 100644 --- a/webview2/pkg/webview2/ICoreWebView2_13.go +++ b/webview2/pkg/webview2/ICoreWebView2_13.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2_13) GetProfile() (*ICoreWebView2Profile, error) { var value *ICoreWebView2Profile - hr, _, err := i.Vtbl.GetProfile.Call( + hr, _, _ := i.Vtbl.GetProfile.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_14.go b/webview2/pkg/webview2/ICoreWebView2_14.go index 6954552b19f..9f5441c51e9 100644 --- a/webview2/pkg/webview2/ICoreWebView2_14.go +++ b/webview2/pkg/webview2/ICoreWebView2_14.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2_14) AddServerCertificateErrorDetected(eventHandler *ICore var token EventRegistrationToken - hr, _, err := i.Vtbl.AddServerCertificateErrorDetected.Call( + hr, _, _ := i.Vtbl.AddServerCertificateErrorDetected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -56,31 +56,31 @@ func (i *ICoreWebView2_14) AddServerCertificateErrorDetected(eventHandler *ICore if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_14) RemoveServerCertificateErrorDetected(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveServerCertificateErrorDetected.Call( + hr, _, _ := i.Vtbl.RemoveServerCertificateErrorDetected.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_14) ClearServerCertificateErrorActions(handler *ICoreWebView2ClearServerCertificateErrorActionsCompletedHandler) error { - hr, _, err := i.Vtbl.ClearServerCertificateErrorActions.Call( + hr, _, _ := i.Vtbl.ClearServerCertificateErrorActions.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_15.go b/webview2/pkg/webview2/ICoreWebView2_15.go index 302de4c6e76..b1411b152aa 100644 --- a/webview2/pkg/webview2/ICoreWebView2_15.go +++ b/webview2/pkg/webview2/ICoreWebView2_15.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2_15) AddFaviconChanged(eventHandler *ICoreWebView2FaviconC var token EventRegistrationToken - hr, _, err := i.Vtbl.AddFaviconChanged.Call( + hr, _, _ := i.Vtbl.AddFaviconChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -57,20 +57,20 @@ func (i *ICoreWebView2_15) AddFaviconChanged(eventHandler *ICoreWebView2FaviconC if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_15) RemoveFaviconChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveFaviconChanged.Call( + hr, _, _ := i.Vtbl.RemoveFaviconChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_15) GetFaviconUri() (string, error) { @@ -78,7 +78,7 @@ func (i *ICoreWebView2_15) GetFaviconUri() (string, error) { var _value *uint16 - hr, _, err := i.Vtbl.GetFaviconUri.Call( + hr, _, _ := i.Vtbl.GetFaviconUri.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -88,13 +88,13 @@ func (i *ICoreWebView2_15) GetFaviconUri() (string, error) { // Get result and cleanup value := UTF16PtrToString(_value) CoTaskMemFree(unsafe.Pointer(_value)) - return value, err + return value, nil } func (i *ICoreWebView2_15) GetFavicon(format COREWEBVIEW2_FAVICON_IMAGE_FORMAT, completedHandler *ICoreWebView2GetFaviconCompletedHandler) error { - hr, _, err := i.Vtbl.GetFavicon.Call( + hr, _, _ := i.Vtbl.GetFavicon.Call( uintptr(unsafe.Pointer(i)), uintptr(format), uintptr(unsafe.Pointer(completedHandler)), @@ -102,5 +102,5 @@ func (i *ICoreWebView2_15) GetFavicon(format COREWEBVIEW2_FAVICON_IMAGE_FORMAT, if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_16.go b/webview2/pkg/webview2/ICoreWebView2_16.go index 81db6722083..f84e3fb495c 100644 --- a/webview2/pkg/webview2/ICoreWebView2_16.go +++ b/webview2/pkg/webview2/ICoreWebView2_16.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2) GetICoreWebView2_16() (*ICoreWebView2_16, error) { func (i *ICoreWebView2_16) Print(printSettings *ICoreWebView2PrintSettings, handler *ICoreWebView2PrintCompletedHandler) error { - hr, _, err := i.Vtbl.Print.Call( + hr, _, _ := i.Vtbl.Print.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(printSettings)), uintptr(unsafe.Pointer(handler)), @@ -55,26 +55,26 @@ func (i *ICoreWebView2_16) Print(printSettings *ICoreWebView2PrintSettings, hand if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_16) ShowPrintUI(printDialogKind COREWEBVIEW2_PRINT_DIALOG_KIND) error { - hr, _, err := i.Vtbl.ShowPrintUI.Call( + hr, _, _ := i.Vtbl.ShowPrintUI.Call( uintptr(unsafe.Pointer(i)), uintptr(printDialogKind), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_16) PrintToPdfStream(printSettings *ICoreWebView2PrintSettings, handler *ICoreWebView2PrintToPdfStreamCompletedHandler) error { - hr, _, err := i.Vtbl.PrintToPdfStream.Call( + hr, _, _ := i.Vtbl.PrintToPdfStream.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(printSettings)), uintptr(unsafe.Pointer(handler)), @@ -82,5 +82,5 @@ func (i *ICoreWebView2_16) PrintToPdfStream(printSettings *ICoreWebView2PrintSet if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_17.go b/webview2/pkg/webview2/ICoreWebView2_17.go index 04a04d159e2..07b909389b9 100644 --- a/webview2/pkg/webview2/ICoreWebView2_17.go +++ b/webview2/pkg/webview2/ICoreWebView2_17.go @@ -50,7 +50,7 @@ func (i *ICoreWebView2_17) PostSharedBufferToScript(sharedBuffer *ICoreWebView2S return err } - hr, _, err := i.Vtbl.PostSharedBufferToScript.Call( + hr, _, _ := i.Vtbl.PostSharedBufferToScript.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(sharedBuffer)), uintptr(access), @@ -59,5 +59,5 @@ func (i *ICoreWebView2_17) PostSharedBufferToScript(sharedBuffer *ICoreWebView2S if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_18.go b/webview2/pkg/webview2/ICoreWebView2_18.go index b9821f7f59a..f26ce96cbd8 100644 --- a/webview2/pkg/webview2/ICoreWebView2_18.go +++ b/webview2/pkg/webview2/ICoreWebView2_18.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2_18) AddLaunchingExternalUriScheme(eventHandler *ICoreWebV var token EventRegistrationToken - hr, _, err := i.Vtbl.AddLaunchingExternalUriScheme.Call( + hr, _, _ := i.Vtbl.AddLaunchingExternalUriScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2_18) AddLaunchingExternalUriScheme(eventHandler *ICoreWebV if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_18) RemoveLaunchingExternalUriScheme(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveLaunchingExternalUriScheme.Call( + hr, _, _ := i.Vtbl.RemoveLaunchingExternalUriScheme.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_19.go b/webview2/pkg/webview2/ICoreWebView2_19.go index d7b441b88d2..bda09c2b02d 100644 --- a/webview2/pkg/webview2/ICoreWebView2_19.go +++ b/webview2/pkg/webview2/ICoreWebView2_19.go @@ -47,25 +47,25 @@ func (i *ICoreWebView2_19) GetMemoryUsageTargetLevel() (COREWEBVIEW2_MEMORY_USAG var value COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL - hr, _, err := i.Vtbl.GetMemoryUsageTargetLevel.Call( + hr, _, _ := i.Vtbl.GetMemoryUsageTargetLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2_19) PutMemoryUsageTargetLevel(value COREWEBVIEW2_MEMORY_USAGE_TARGET_LEVEL) error { - hr, _, err := i.Vtbl.PutMemoryUsageTargetLevel.Call( + hr, _, _ := i.Vtbl.PutMemoryUsageTargetLevel.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_2.go b/webview2/pkg/webview2/ICoreWebView2_2.go index 65a2d3adf8b..0f9a7fc1fc7 100644 --- a/webview2/pkg/webview2/ICoreWebView2_2.go +++ b/webview2/pkg/webview2/ICoreWebView2_2.go @@ -52,7 +52,7 @@ func (i *ICoreWebView2_2) AddWebResourceResponseReceived(eventHandler *ICoreWebV var token EventRegistrationToken - hr, _, err := i.Vtbl.AddWebResourceResponseReceived.Call( + hr, _, _ := i.Vtbl.AddWebResourceResponseReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -60,40 +60,40 @@ func (i *ICoreWebView2_2) AddWebResourceResponseReceived(eventHandler *ICoreWebV if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_2) RemoveWebResourceResponseReceived(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveWebResourceResponseReceived.Call( + hr, _, _ := i.Vtbl.RemoveWebResourceResponseReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_2) NavigateWithWebResourceRequest(request *ICoreWebView2WebResourceRequest) error { - hr, _, err := i.Vtbl.NavigateWithWebResourceRequest.Call( + hr, _, _ := i.Vtbl.NavigateWithWebResourceRequest.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(request)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_2) AddDOMContentLoaded(eventHandler *ICoreWebView2DOMContentLoadedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDOMContentLoaded.Call( + hr, _, _ := i.Vtbl.AddDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -101,46 +101,46 @@ func (i *ICoreWebView2_2) AddDOMContentLoaded(eventHandler *ICoreWebView2DOMCont if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_2) RemoveDOMContentLoaded(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDOMContentLoaded.Call( + hr, _, _ := i.Vtbl.RemoveDOMContentLoaded.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_2) GetCookieManager() (*ICoreWebView2CookieManager, error) { var cookieManager *ICoreWebView2CookieManager - hr, _, err := i.Vtbl.GetCookieManager.Call( + hr, _, _ := i.Vtbl.GetCookieManager.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&cookieManager)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return cookieManager, err + return cookieManager, nil } func (i *ICoreWebView2_2) GetEnvironment() (*ICoreWebView2Environment, error) { var environment *ICoreWebView2Environment - hr, _, err := i.Vtbl.GetEnvironment.Call( + hr, _, _ := i.Vtbl.GetEnvironment.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&environment)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return environment, err + return environment, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_20.go b/webview2/pkg/webview2/ICoreWebView2_20.go index 1e4681bf6a6..3d00213cc07 100644 --- a/webview2/pkg/webview2/ICoreWebView2_20.go +++ b/webview2/pkg/webview2/ICoreWebView2_20.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2_20) GetFrameId() (uint32, error) { var value uint32 - hr, _, err := i.Vtbl.GetFrameId.Call( + hr, _, _ := i.Vtbl.GetFrameId.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_21.go b/webview2/pkg/webview2/ICoreWebView2_21.go index 2e0de2ac793..13d93ab6c00 100644 --- a/webview2/pkg/webview2/ICoreWebView2_21.go +++ b/webview2/pkg/webview2/ICoreWebView2_21.go @@ -50,7 +50,7 @@ func (i *ICoreWebView2_21) ExecuteScriptWithResult(javaScript string, handler *I return err } - hr, _, err := i.Vtbl.ExecuteScriptWithResult.Call( + hr, _, _ := i.Vtbl.ExecuteScriptWithResult.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_javaScript)), uintptr(unsafe.Pointer(handler)), @@ -58,5 +58,5 @@ func (i *ICoreWebView2_21) ExecuteScriptWithResult(javaScript string, handler *I if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_22.go b/webview2/pkg/webview2/ICoreWebView2_22.go index 4248b1224cf..902e474812f 100644 --- a/webview2/pkg/webview2/ICoreWebView2_22.go +++ b/webview2/pkg/webview2/ICoreWebView2_22.go @@ -51,7 +51,7 @@ func (i *ICoreWebView2_22) AddWebResourceRequestedFilterWithRequestSourceKinds(u return err } - hr, _, err := i.Vtbl.AddWebResourceRequestedFilterWithRequestSourceKinds.Call( + hr, _, _ := i.Vtbl.AddWebResourceRequestedFilterWithRequestSourceKinds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(ResourceContext), @@ -60,7 +60,7 @@ func (i *ICoreWebView2_22) AddWebResourceRequestedFilterWithRequestSourceKinds(u if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_22) RemoveWebResourceRequestedFilterWithRequestSourceKinds(uri string, ResourceContext COREWEBVIEW2_WEB_RESOURCE_CONTEXT, requestSourceKinds COREWEBVIEW2_WEB_RESOURCE_REQUEST_SOURCE_KINDS) error { @@ -71,7 +71,7 @@ func (i *ICoreWebView2_22) RemoveWebResourceRequestedFilterWithRequestSourceKind return err } - hr, _, err := i.Vtbl.RemoveWebResourceRequestedFilterWithRequestSourceKinds.Call( + hr, _, _ := i.Vtbl.RemoveWebResourceRequestedFilterWithRequestSourceKinds.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_uri)), uintptr(ResourceContext), @@ -80,5 +80,5 @@ func (i *ICoreWebView2_22) RemoveWebResourceRequestedFilterWithRequestSourceKind if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_23.go b/webview2/pkg/webview2/ICoreWebView2_23.go index 6ac775b6445..a9b1e5f9002 100644 --- a/webview2/pkg/webview2/ICoreWebView2_23.go +++ b/webview2/pkg/webview2/ICoreWebView2_23.go @@ -50,7 +50,7 @@ func (i *ICoreWebView2_23) PostWebMessageAsJsonWithAdditionalObjects(webMessageA return err } - hr, _, err := i.Vtbl.PostWebMessageAsJsonWithAdditionalObjects.Call( + hr, _, _ := i.Vtbl.PostWebMessageAsJsonWithAdditionalObjects.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_webMessageAsJson)), uintptr(unsafe.Pointer(additionalObjects)), @@ -58,5 +58,5 @@ func (i *ICoreWebView2_23) PostWebMessageAsJsonWithAdditionalObjects(webMessageA if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_24.go b/webview2/pkg/webview2/ICoreWebView2_24.go index 085479e34cc..23770e1e7d7 100644 --- a/webview2/pkg/webview2/ICoreWebView2_24.go +++ b/webview2/pkg/webview2/ICoreWebView2_24.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2_24) AddNotificationReceived(eventHandler *ICoreWebView2No var token EventRegistrationToken - hr, _, err := i.Vtbl.AddNotificationReceived.Call( + hr, _, _ := i.Vtbl.AddNotificationReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2_24) AddNotificationReceived(eventHandler *ICoreWebView2No if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_24) RemoveNotificationReceived(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveNotificationReceived.Call( + hr, _, _ := i.Vtbl.RemoveNotificationReceived.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_25.go b/webview2/pkg/webview2/ICoreWebView2_25.go index 7583ca4540d..e9a7a671fa2 100644 --- a/webview2/pkg/webview2/ICoreWebView2_25.go +++ b/webview2/pkg/webview2/ICoreWebView2_25.go @@ -48,7 +48,7 @@ func (i *ICoreWebView2_25) AddSaveAsUIShowing(eventHandler *ICoreWebView2SaveAsU var token EventRegistrationToken - hr, _, err := i.Vtbl.AddSaveAsUIShowing.Call( + hr, _, _ := i.Vtbl.AddSaveAsUIShowing.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -56,31 +56,31 @@ func (i *ICoreWebView2_25) AddSaveAsUIShowing(eventHandler *ICoreWebView2SaveAsU if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_25) RemoveSaveAsUIShowing(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveSaveAsUIShowing.Call( + hr, _, _ := i.Vtbl.RemoveSaveAsUIShowing.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_25) ShowSaveAsUI(handler *ICoreWebView2ShowSaveAsUICompletedHandler) error { - hr, _, err := i.Vtbl.ShowSaveAsUI.Call( + hr, _, _ := i.Vtbl.ShowSaveAsUI.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_26.go b/webview2/pkg/webview2/ICoreWebView2_26.go index 1cdb24d7185..7761794efe1 100644 --- a/webview2/pkg/webview2/ICoreWebView2_26.go +++ b/webview2/pkg/webview2/ICoreWebView2_26.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2_26) AddSaveFileSecurityCheckStarting(eventHandler *ICoreW var token EventRegistrationToken - hr, _, err := i.Vtbl.AddSaveFileSecurityCheckStarting.Call( + hr, _, _ := i.Vtbl.AddSaveFileSecurityCheckStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2_26) AddSaveFileSecurityCheckStarting(eventHandler *ICoreW if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_26) RemoveSaveFileSecurityCheckStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveSaveFileSecurityCheckStarting.Call( + hr, _, _ := i.Vtbl.RemoveSaveFileSecurityCheckStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_27.go b/webview2/pkg/webview2/ICoreWebView2_27.go index 4ffd82f614a..06129e3b068 100644 --- a/webview2/pkg/webview2/ICoreWebView2_27.go +++ b/webview2/pkg/webview2/ICoreWebView2_27.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2_27) AddScreenCaptureStarting(eventHandler *ICoreWebView2S var token EventRegistrationToken - hr, _, err := i.Vtbl.AddScreenCaptureStarting.Call( + hr, _, _ := i.Vtbl.AddScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2_27) AddScreenCaptureStarting(eventHandler *ICoreWebView2S if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_27) RemoveScreenCaptureStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveScreenCaptureStarting.Call( + hr, _, _ := i.Vtbl.RemoveScreenCaptureStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_28.go b/webview2/pkg/webview2/ICoreWebView2_28.go index f90e3848065..6664344f23e 100644 --- a/webview2/pkg/webview2/ICoreWebView2_28.go +++ b/webview2/pkg/webview2/ICoreWebView2_28.go @@ -46,12 +46,12 @@ func (i *ICoreWebView2_28) GetFind() (*ICoreWebView2Find, error) { var value *ICoreWebView2Find - hr, _, err := i.Vtbl.GetFind.Call( + hr, _, _ := i.Vtbl.GetFind.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return nil, syscall.Errno(hr) } - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_3.go b/webview2/pkg/webview2/ICoreWebView2_3.go index f1fde7367cd..d0dd0040701 100644 --- a/webview2/pkg/webview2/ICoreWebView2_3.go +++ b/webview2/pkg/webview2/ICoreWebView2_3.go @@ -49,33 +49,33 @@ func (i *ICoreWebView2) GetICoreWebView2_3() (*ICoreWebView2_3, error) { func (i *ICoreWebView2_3) TrySuspend(handler *ICoreWebView2TrySuspendCompletedHandler) error { - hr, _, err := i.Vtbl.TrySuspend.Call( + hr, _, _ := i.Vtbl.TrySuspend.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_3) Resume() error { - hr, _, err := i.Vtbl.Resume.Call( + hr, _, _ := i.Vtbl.Resume.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_3) GetIsSuspended() (bool, error) { // Create int32 to hold bool result var _isSuspended int32 - hr, _, err := i.Vtbl.GetIsSuspended.Call( + hr, _, _ := i.Vtbl.GetIsSuspended.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_isSuspended)), ) @@ -84,7 +84,7 @@ func (i *ICoreWebView2_3) GetIsSuspended() (bool, error) { } // Get result and cleanup isSuspended := _isSuspended != 0 - return isSuspended, err + return isSuspended, nil } func (i *ICoreWebView2_3) SetVirtualHostNameToFolderMapping(hostName string, folderPath string, accessKind COREWEBVIEW2_HOST_RESOURCE_ACCESS_KIND) error { @@ -100,7 +100,7 @@ func (i *ICoreWebView2_3) SetVirtualHostNameToFolderMapping(hostName string, fol return err } - hr, _, err := i.Vtbl.SetVirtualHostNameToFolderMapping.Call( + hr, _, _ := i.Vtbl.SetVirtualHostNameToFolderMapping.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_hostName)), uintptr(unsafe.Pointer(_folderPath)), @@ -109,7 +109,7 @@ func (i *ICoreWebView2_3) SetVirtualHostNameToFolderMapping(hostName string, fol if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_3) ClearVirtualHostNameToFolderMapping(hostName string) error { @@ -120,12 +120,12 @@ func (i *ICoreWebView2_3) ClearVirtualHostNameToFolderMapping(hostName string) e return err } - hr, _, err := i.Vtbl.ClearVirtualHostNameToFolderMapping.Call( + hr, _, _ := i.Vtbl.ClearVirtualHostNameToFolderMapping.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_hostName)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_4.go b/webview2/pkg/webview2/ICoreWebView2_4.go index 7723b96f922..f67b5952ab9 100644 --- a/webview2/pkg/webview2/ICoreWebView2_4.go +++ b/webview2/pkg/webview2/ICoreWebView2_4.go @@ -49,7 +49,7 @@ func (i *ICoreWebView2_4) AddFrameCreated(eventHandler *ICoreWebView2FrameCreate var token EventRegistrationToken - hr, _, err := i.Vtbl.AddFrameCreated.Call( + hr, _, _ := i.Vtbl.AddFrameCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -57,27 +57,27 @@ func (i *ICoreWebView2_4) AddFrameCreated(eventHandler *ICoreWebView2FrameCreate if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_4) RemoveFrameCreated(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveFrameCreated.Call( + hr, _, _ := i.Vtbl.RemoveFrameCreated.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_4) AddDownloadStarting(eventHandler *ICoreWebView2DownloadStartingEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddDownloadStarting.Call( + hr, _, _ := i.Vtbl.AddDownloadStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -85,18 +85,18 @@ func (i *ICoreWebView2_4) AddDownloadStarting(eventHandler *ICoreWebView2Downloa if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_4) RemoveDownloadStarting(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveDownloadStarting.Call( + hr, _, _ := i.Vtbl.RemoveDownloadStarting.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_5.go b/webview2/pkg/webview2/ICoreWebView2_5.go index 429d67cde4c..8383a3a4263 100644 --- a/webview2/pkg/webview2/ICoreWebView2_5.go +++ b/webview2/pkg/webview2/ICoreWebView2_5.go @@ -47,7 +47,7 @@ func (i *ICoreWebView2_5) AddClientCertificateRequested(eventHandler *ICoreWebVi var token EventRegistrationToken - hr, _, err := i.Vtbl.AddClientCertificateRequested.Call( + hr, _, _ := i.Vtbl.AddClientCertificateRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -55,18 +55,18 @@ func (i *ICoreWebView2_5) AddClientCertificateRequested(eventHandler *ICoreWebVi if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_5) RemoveClientCertificateRequested(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveClientCertificateRequested.Call( + hr, _, _ := i.Vtbl.RemoveClientCertificateRequested.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_6.go b/webview2/pkg/webview2/ICoreWebView2_6.go index 02cb30aee9a..089c19d9e55 100644 --- a/webview2/pkg/webview2/ICoreWebView2_6.go +++ b/webview2/pkg/webview2/ICoreWebView2_6.go @@ -45,11 +45,11 @@ func (i *ICoreWebView2) GetICoreWebView2_6() (*ICoreWebView2_6, error) { func (i *ICoreWebView2_6) OpenTaskManagerWindow() error { - hr, _, err := i.Vtbl.OpenTaskManagerWindow.Call( + hr, _, _ := i.Vtbl.OpenTaskManagerWindow.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_7.go b/webview2/pkg/webview2/ICoreWebView2_7.go index 066c881b705..1baf296d64a 100644 --- a/webview2/pkg/webview2/ICoreWebView2_7.go +++ b/webview2/pkg/webview2/ICoreWebView2_7.go @@ -50,7 +50,7 @@ func (i *ICoreWebView2_7) PrintToPdf(ResultFilePath string, printSettings *ICore return err } - hr, _, err := i.Vtbl.PrintToPdf.Call( + hr, _, _ := i.Vtbl.PrintToPdf.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(_ResultFilePath)), uintptr(unsafe.Pointer(printSettings)), @@ -59,5 +59,5 @@ func (i *ICoreWebView2_7) PrintToPdf(ResultFilePath string, printSettings *ICore if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_8.go b/webview2/pkg/webview2/ICoreWebView2_8.go index dfc7411b96d..0c0fcaf78ef 100644 --- a/webview2/pkg/webview2/ICoreWebView2_8.go +++ b/webview2/pkg/webview2/ICoreWebView2_8.go @@ -52,7 +52,7 @@ func (i *ICoreWebView2_8) AddIsMutedChanged(eventHandler *ICoreWebView2IsMutedCh var token EventRegistrationToken - hr, _, err := i.Vtbl.AddIsMutedChanged.Call( + hr, _, _ := i.Vtbl.AddIsMutedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -60,27 +60,27 @@ func (i *ICoreWebView2_8) AddIsMutedChanged(eventHandler *ICoreWebView2IsMutedCh if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_8) RemoveIsMutedChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveIsMutedChanged.Call( + hr, _, _ := i.Vtbl.RemoveIsMutedChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_8) GetIsMuted() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsMuted.Call( + hr, _, _ := i.Vtbl.GetIsMuted.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -89,7 +89,7 @@ func (i *ICoreWebView2_8) GetIsMuted() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2_8) PutIsMuted(value bool) error { @@ -100,21 +100,21 @@ func (i *ICoreWebView2_8) PutIsMuted(value bool) error { _value = 1 } - hr, _, err := i.Vtbl.PutIsMuted.Call( + hr, _, _ := i.Vtbl.PutIsMuted.Call( uintptr(unsafe.Pointer(i)), uintptr(_value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_8) AddIsDocumentPlayingAudioChanged(eventHandler *ICoreWebView2IsDocumentPlayingAudioChangedEventHandler) (EventRegistrationToken, error) { var token EventRegistrationToken - hr, _, err := i.Vtbl.AddIsDocumentPlayingAudioChanged.Call( + hr, _, _ := i.Vtbl.AddIsDocumentPlayingAudioChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(eventHandler)), uintptr(unsafe.Pointer(&token)), @@ -122,27 +122,27 @@ func (i *ICoreWebView2_8) AddIsDocumentPlayingAudioChanged(eventHandler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_8) RemoveIsDocumentPlayingAudioChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveIsDocumentPlayingAudioChanged.Call( + hr, _, _ := i.Vtbl.RemoveIsDocumentPlayingAudioChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_8) GetIsDocumentPlayingAudio() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsDocumentPlayingAudio.Call( + hr, _, _ := i.Vtbl.GetIsDocumentPlayingAudio.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -151,5 +151,5 @@ func (i *ICoreWebView2_8) GetIsDocumentPlayingAudio() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } diff --git a/webview2/pkg/webview2/ICoreWebView2_9.go b/webview2/pkg/webview2/ICoreWebView2_9.go index ece83df7c9c..6c1f392905a 100644 --- a/webview2/pkg/webview2/ICoreWebView2_9.go +++ b/webview2/pkg/webview2/ICoreWebView2_9.go @@ -54,7 +54,7 @@ func (i *ICoreWebView2_9) AddIsDefaultDownloadDialogOpenChanged(handler *ICoreWe var token EventRegistrationToken - hr, _, err := i.Vtbl.AddIsDefaultDownloadDialogOpenChanged.Call( + hr, _, _ := i.Vtbl.AddIsDefaultDownloadDialogOpenChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(handler)), uintptr(unsafe.Pointer(&token)), @@ -62,27 +62,27 @@ func (i *ICoreWebView2_9) AddIsDefaultDownloadDialogOpenChanged(handler *ICoreWe if windows.Handle(hr) != windows.S_OK { return EventRegistrationToken{}, syscall.Errno(hr) } - return token, err + return token, nil } func (i *ICoreWebView2_9) RemoveIsDefaultDownloadDialogOpenChanged(token EventRegistrationToken) error { - hr, _, err := i.Vtbl.RemoveIsDefaultDownloadDialogOpenChanged.Call( + hr, _, _ := i.Vtbl.RemoveIsDefaultDownloadDialogOpenChanged.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&token)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_9) GetIsDefaultDownloadDialogOpen() (bool, error) { // Create int32 to hold bool result var _value int32 - hr, _, err := i.Vtbl.GetIsDefaultDownloadDialogOpen.Call( + hr, _, _ := i.Vtbl.GetIsDefaultDownloadDialogOpen.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&_value)), ) @@ -91,83 +91,83 @@ func (i *ICoreWebView2_9) GetIsDefaultDownloadDialogOpen() (bool, error) { } // Get result and cleanup value := _value != 0 - return value, err + return value, nil } func (i *ICoreWebView2_9) OpenDefaultDownloadDialog() error { - hr, _, err := i.Vtbl.OpenDefaultDownloadDialog.Call( + hr, _, _ := i.Vtbl.OpenDefaultDownloadDialog.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_9) CloseDefaultDownloadDialog() error { - hr, _, err := i.Vtbl.CloseDefaultDownloadDialog.Call( + hr, _, _ := i.Vtbl.CloseDefaultDownloadDialog.Call( uintptr(unsafe.Pointer(i)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_9) GetDefaultDownloadDialogCornerAlignment() (COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT, error) { var value COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT - hr, _, err := i.Vtbl.GetDefaultDownloadDialogCornerAlignment.Call( + hr, _, _ := i.Vtbl.GetDefaultDownloadDialogCornerAlignment.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return 0, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2_9) PutDefaultDownloadDialogCornerAlignment(value COREWEBVIEW2_DEFAULT_DOWNLOAD_DIALOG_CORNER_ALIGNMENT) error { - hr, _, err := i.Vtbl.PutDefaultDownloadDialogCornerAlignment.Call( + hr, _, _ := i.Vtbl.PutDefaultDownloadDialogCornerAlignment.Call( uintptr(unsafe.Pointer(i)), uintptr(value), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil } func (i *ICoreWebView2_9) GetDefaultDownloadDialogMargin() (POINT, error) { var value POINT - hr, _, err := i.Vtbl.GetDefaultDownloadDialogMargin.Call( + hr, _, _ := i.Vtbl.GetDefaultDownloadDialogMargin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return POINT{}, syscall.Errno(hr) } - return value, err + return value, nil } func (i *ICoreWebView2_9) PutDefaultDownloadDialogMargin(value POINT) error { - hr, _, err := i.Vtbl.PutDefaultDownloadDialogMargin.Call( + hr, _, _ := i.Vtbl.PutDefaultDownloadDialogMargin.Call( uintptr(unsafe.Pointer(i)), uintptr(unsafe.Pointer(&value)), ) if windows.Handle(hr) != windows.S_OK { return syscall.Errno(hr) } - return err + return nil }