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:
parent
188b249467
commit
b4a6f39ab2
@ -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
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user