Use HandleWindowEvent() from C callbacks

Avoids issues with exceptions. Also remove worthless null pointer checks, the
pointer has already been dereferenced, and GetEventHandler() never returns NULL
This commit is contained in:
Paul Cornett 2017-06-15 09:22:37 -07:00
parent 188b249467
commit b4a6f39ab2
2 changed files with 16 additions and 35 deletions

View File

@ -63,8 +63,7 @@ wxgtk_webview_webkit_load_status(GtkWidget* widget,
webKitCtrl->GetId(), webKitCtrl->GetId(),
url, target); url, target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
} }
else if (status == WEBKIT_LOAD_COMMITTED) else if (status == WEBKIT_LOAD_COMMITTED)
{ {
@ -73,8 +72,7 @@ wxgtk_webview_webkit_load_status(GtkWidget* widget,
webKitCtrl->GetId(), webKitCtrl->GetId(),
url, target); url, target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
} }
} }
@ -99,8 +97,7 @@ wxgtk_webview_webkit_navigation(WebKitWebView *,
wxString(uri, wxConvUTF8), wxString(uri, wxConvUTF8),
target); target);
if(webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
webkit_web_policy_decision_ignore(policy_decision); webkit_web_policy_decision_ignore(policy_decision);
return TRUE; return TRUE;
@ -123,8 +120,7 @@ wxgtk_webview_webkit_navigation(WebKitWebView *,
wxString( uri, wxConvUTF8 ), wxString( uri, wxConvUTF8 ),
target); target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
if (!event.IsAllowed()) if (!event.IsAllowed())
{ {
@ -297,10 +293,7 @@ wxgtk_webview_webkit_error(WebKitWebView*,
event.SetString(description); event.SetString(description);
event.SetInt(type); event.SetInt(type);
if (webKitWindow && webKitWindow->GetEventHandler()) webKitWindow->HandleWindowEvent(event);
{
webKitWindow->GetEventHandler()->ProcessEvent(event);
}
return FALSE; return FALSE;
} }
@ -321,8 +314,7 @@ wxgtk_webview_webkit_new_window(WebKitWebView*,
wxString( uri, wxConvUTF8 ), wxString( uri, wxConvUTF8 ),
target); target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
//We always want the user to handle this themselves //We always want the user to handle this themselves
webkit_web_policy_decision_ignore(policy_decision); webkit_web_policy_decision_ignore(policy_decision);
@ -341,9 +333,7 @@ wxgtk_webview_webkit_title_changed(WebKitWebView*,
""); "");
event.SetString(wxString(title, wxConvUTF8)); event.SetString(wxString(title, wxConvUTF8));
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
} }
static void static void

View File

@ -44,8 +44,7 @@ wxgtk_webview_webkit_load_changed(GtkWidget *,
webKitCtrl->GetId(), webKitCtrl->GetId(),
url, target); url, target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
} }
else if (load_event == WEBKIT_LOAD_COMMITTED) else if (load_event == WEBKIT_LOAD_COMMITTED)
{ {
@ -54,8 +53,7 @@ wxgtk_webview_webkit_load_changed(GtkWidget *,
webKitCtrl->GetId(), webKitCtrl->GetId(),
url, target); url, target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
} }
} }
@ -80,8 +78,7 @@ wxgtk_webview_webkit_navigation(WebKitWebView *web_view,
wxString(uri, wxConvUTF8), wxString(uri, wxConvUTF8),
target); target);
if(webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
webkit_policy_decision_ignore(decision); webkit_policy_decision_ignore(decision);
return TRUE; return TRUE;
@ -104,8 +101,7 @@ wxgtk_webview_webkit_navigation(WebKitWebView *web_view,
wxString( uri, wxConvUTF8 ), wxString( uri, wxConvUTF8 ),
target); target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
if (!event.IsAllowed()) if (!event.IsAllowed())
{ {
@ -256,10 +252,7 @@ wxgtk_webview_webkit_load_failed(WebKitWebView *,
event.SetString(description); event.SetString(description);
event.SetInt(type); event.SetInt(type);
if (webKitWindow && webKitWindow->GetEventHandler()) webKitWindow->HandleWindowEvent(event);
{
webKitWindow->GetEventHandler()->ProcessEvent(event);
}
return FALSE; return FALSE;
} }
@ -279,8 +272,7 @@ wxgtk_webview_webkit_new_window(WebKitPolicyDecision *decision,
wxString( uri, wxConvUTF8 ), wxString( uri, wxConvUTF8 ),
target); target);
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
//We always want the user to handle this themselves //We always want the user to handle this themselves
webkit_policy_decision_ignore(decision); webkit_policy_decision_ignore(decision);
@ -318,8 +310,7 @@ wxgtk_webview_webkit_title_changed(GtkWidget* widget,
""); "");
event.SetString(wxString(title, wxConvUTF8)); event.SetString(wxString(title, wxConvUTF8));
if (webKitCtrl && webKitCtrl->GetEventHandler()) webKitCtrl->HandleWindowEvent(event);
webKitCtrl->GetEventHandler()->ProcessEvent(event);
g_free(title); g_free(title);
} }