Fix: Chromium & DialogHandler onFileDialog callback args:acceptFiltersList

This commit is contained in:
杨红岩 2023-07-14 09:28:58 +08:00
parent 981751a3b0
commit b89c3bd57c
5 changed files with 20 additions and 30 deletions

View File

@ -61,7 +61,7 @@ type chromiumEventOnExtensionLoaded func(sender lcl.IObject, extension *ICefExte
type chromiumEventOnExtensionLoadFailed func(sender lcl.IObject, result consts.TCefErrorCode) type chromiumEventOnExtensionLoadFailed func(sender lcl.IObject, result consts.TCefErrorCode)
type chromiumEventOnExtensionUnloaded func(sender lcl.IObject, extension *ICefExtension) type chromiumEventOnExtensionUnloaded func(sender lcl.IObject, extension *ICefExtension)
type chromiumEventOnFavIconUrlChange func(sender lcl.IObject, browser *ICefBrowser, iconUrls []string) // TStrings => []string type chromiumEventOnFavIconUrlChange func(sender lcl.IObject, browser *ICefBrowser, iconUrls []string) // TStrings => []string
type chromiumEventOnFileDialog func(sender lcl.IObject, browser *ICefBrowser, mode consts.TCefFileDialogMode, title, defaultFilePath string, acceptFilters []string, callback *ICefFileDialogCallback) bool type chromiumEventOnFileDialog func(sender lcl.IObject, browser *ICefBrowser, mode consts.FileDialogMode, title, defaultFilePath string, acceptFilters *lcl.TStrings, callback *ICefFileDialogCallback) bool
type chromiumEventOnGetAccessibilityHandler func(sender lcl.IObject, accessibilityHandler *ICefAccessibilityHandler) type chromiumEventOnGetAccessibilityHandler func(sender lcl.IObject, accessibilityHandler *ICefAccessibilityHandler)
type chromiumEventOnGetAudioParameters func(sender lcl.IObject, browser *ICefBrowser, params *TCefAudioParameters) bool type chromiumEventOnGetAudioParameters func(sender lcl.IObject, browser *ICefBrowser, params *TCefAudioParameters) bool
type chromiumEventOnGetResourceHandler func(sender lcl.IObject, browser *ICefBrowser, frame *ICefFrame, request *ICefRequest) (resourceHandler *ICefResourceHandler) type chromiumEventOnGetResourceHandler func(sender lcl.IObject, browser *ICefBrowser, frame *ICefFrame, request *ICefRequest) (resourceHandler *ICefResourceHandler)

View File

@ -310,22 +310,22 @@ func init() {
fn.(chromiumEventOnFavIconUrlChange)(lcl.AsObject(getPtr(0)), browse, iconUrls) fn.(chromiumEventOnFavIconUrlChange)(lcl.AsObject(getPtr(0)), browse, iconUrls)
case chromiumEventOnFileDialog: case chromiumEventOnFileDialog:
browse := &ICefBrowser{instance: getPtr(1)} browse := &ICefBrowser{instance: getPtr(1)}
mode := consts.TCefFileDialogMode(getVal(2)) mode := consts.FileDialogMode(getVal(2))
title := api.GoStr(getVal(3)) title := api.GoStr(getVal(3))
defaultFilePath := api.GoStr(getVal(4)) defaultFilePath := api.GoStr(getVal(4))
acceptFiltersList := lcl.AsStrings(getVal(5)) acceptFiltersList := lcl.AsStrings(getVal(5))
callback := &ICefFileDialogCallback{instance: getPtr(6)} callback := &ICefFileDialogCallback{instance: getPtr(6)}
result := (*bool)(getPtr(7)) result := (*bool)(getPtr(7))
var acceptFilters []string //var acceptFilters []string
if acceptFiltersList.IsValid() { //if acceptFiltersList.IsValid() {
count := int(acceptFiltersList.Count()) // count := int(acceptFiltersList.Count())
acceptFilters = make([]string, count, count) // acceptFilters = make([]string, count, count)
for i := 0; i < count; i++ { // for i := 0; i < count; i++ {
acceptFilters[i] = acceptFiltersList.Strings(int32(i)) // acceptFilters[i] = acceptFiltersList.Strings(int32(i))
} // }
acceptFiltersList.Free() // //acceptFiltersList.Free()
} //}
*result = fn.(chromiumEventOnFileDialog)(lcl.AsObject(getPtr(0)), browse, mode, title, defaultFilePath, acceptFilters, callback) *result = fn.(chromiumEventOnFileDialog)(lcl.AsObject(getPtr(0)), browse, mode, title, defaultFilePath, acceptFiltersList, callback)
case chromiumEventOnGetAccessibilityHandler: case chromiumEventOnGetAccessibilityHandler:
accessibilityHandler := &ICefAccessibilityHandler{instance: getPtr(1)} accessibilityHandler := &ICefAccessibilityHandler{instance: getPtr(1)}
fn.(chromiumEventOnGetAccessibilityHandler)(lcl.AsObject(getPtr(0)), accessibilityHandler) fn.(chromiumEventOnGetAccessibilityHandler)(lcl.AsObject(getPtr(0)), accessibilityHandler)

View File

@ -68,7 +68,7 @@ func (m *ICefDialogHandler) SetOnFileDialog(fn onFileDialog) {
// ************************** events ************************** // // ************************** events ************************** //
type onFileDialog func(browser *ICefBrowser, mode consts.TCefFileDialogMode, title, defaultFilePath string, acceptFilters []string, callback *ICefFileDialogCallback) bool type onFileDialog func(browser *ICefBrowser, mode consts.FileDialogMode, title, defaultFilePath string, acceptFilters *lcl.TStrings, callback *ICefFileDialogCallback) bool
func init() { func init() {
lcl.RegisterExtEventCallback(func(fn interface{}, getVal func(idx int) uintptr) bool { lcl.RegisterExtEventCallback(func(fn interface{}, getVal func(idx int) uintptr) bool {
@ -78,22 +78,13 @@ func init() {
switch fn.(type) { switch fn.(type) {
case onFileDialog: case onFileDialog:
browse := &ICefBrowser{instance: getPtr(0)} browse := &ICefBrowser{instance: getPtr(0)}
mode := consts.TCefFileDialogMode(getVal(1)) mode := consts.FileDialogMode(getVal(1))
title := api.GoStr(getVal(2)) title := api.GoStr(getVal(2))
defaultFilePath := api.GoStr(getVal(3)) defaultFilePath := api.GoStr(getVal(3))
acceptFiltersList := lcl.AsStrings(getVal(4)) acceptFiltersList := lcl.AsStrings(getVal(4))
callback := &ICefFileDialogCallback{instance: getPtr(5)} callback := &ICefFileDialogCallback{instance: getPtr(5)}
result := (*bool)(getPtr(6)) result := (*bool)(getPtr(6))
var acceptFilters []string *result = fn.(onFileDialog)(browse, mode, title, defaultFilePath, acceptFiltersList, callback)
if acceptFiltersList.IsValid() {
count := int(acceptFiltersList.Count())
acceptFilters = make([]string, count, count)
for i := 0; i < count; i++ {
acceptFilters[i] = acceptFiltersList.Strings(int32(i))
}
acceptFiltersList.Free()
}
*result = fn.(onFileDialog)(browse, mode, title, defaultFilePath, acceptFilters, callback)
default: default:
return false return false
} }

View File

@ -42,9 +42,11 @@ func (m *ICefFileDialogCallback) Cont(filePaths []string) {
if !m.IsValid() { if !m.IsValid() {
return return
} }
fps := lcl.NewStrings() fps := lcl.NewStringList()
for _, fp := range filePaths { if filePaths != nil {
fps.Add(fp) for _, fp := range filePaths {
fps.Add(fp)
}
} }
imports.Proc(def.FileDialogCallback_Cont).Call(m.Instance(), fps.Instance()) imports.Proc(def.FileDialogCallback_Cont).Call(m.Instance(), fps.Instance())
fps.Free() fps.Free()

View File

@ -1201,9 +1201,6 @@ const (
// /include/internal/cef_types.h (cef_quick_menu_edit_state_flags_t) // /include/internal/cef_types.h (cef_quick_menu_edit_state_flags_t)
type TCefQuickMenuEditStateFlags = types.Int32 type TCefQuickMenuEditStateFlags = types.Int32
// /include/internal/cef_types.h (cef_file_dialog_mode_t)
type TCefFileDialogMode = types.Cardinal
// /include/internal/cef_types.h (cef_log_severity_t) // /include/internal/cef_types.h (cef_log_severity_t)
type TCefLogSeverity = types.Cardinal type TCefLogSeverity = types.Cardinal