diff options
author | Jay Freeman (saurik) <saurik@saurik.com> | 2011-02-28 21:08:18 -0800 |
---|---|---|
committer | Jay Freeman (saurik) <saurik@saurik.com> | 2011-03-07 02:41:31 -0800 |
commit | aa35fd7b4dd1970d469f6ca6a9907f4618856a2f (patch) | |
tree | abe26c206991d32bfe113e9a4a656ec13282b693 /CyteKit/CyteWebViewController.mm | |
parent | f8d15be29e828985c2e114d5ed15ad1b83453af0 (diff) |
Separate out CyteKit/CyteWebView.*.
Diffstat (limited to 'CyteKit/CyteWebViewController.mm')
-rw-r--r-- | CyteKit/CyteWebViewController.mm | 300 |
1 files changed, 0 insertions, 300 deletions
diff --git a/CyteKit/CyteWebViewController.mm b/CyteKit/CyteWebViewController.mm index 4cbdfd2..78c94a7 100644 --- a/CyteKit/CyteWebViewController.mm +++ b/CyteKit/CyteWebViewController.mm @@ -13,7 +13,6 @@ extern NSString * const kCAFilterNearest; #include <WebCore/WebCoreThread.h> -#include <WebKit/WebPolicyDelegate.h> #include <WebKit/WebPreferences.h> #include <WebKit/DOMCSSPrimitiveValue.h> @@ -22,9 +21,6 @@ extern NSString * const kCAFilterNearest; #include <WebKit/DOMHTMLBodyElement.h> #include <WebKit/DOMRGBColor.h> -//#include <WebCore/Page.h> -//#include <WebCore/Settings.h> - #include "substrate.h" #define ForSaurik 0 @@ -150,302 +146,6 @@ float CYScrollViewDecelerationRateNormal; @end -// CYWebPolicyDecision* {{{ -enum CYWebPolicyDecision { - CYWebPolicyDecisionUnknown, - CYWebPolicyDecisionDownload, - CYWebPolicyDecisionIgnore, - CYWebPolicyDecisionUse, -}; - -@interface CYWebPolicyDecisionMediator : NSObject < - WebPolicyDecisionListener -> { - id<WebPolicyDecisionListener> listener_; - CYWebPolicyDecision decision_; -} - -- (id) initWithListener:(id<WebPolicyDecisionListener>)listener; - -- (CYWebPolicyDecision) decision; -- (bool) decided; -- (bool) decide; - -@end - -@implementation CYWebPolicyDecisionMediator - -- (id) initWithListener:(id<WebPolicyDecisionListener>)listener { - if ((self = [super init]) != nil) { - listener_ = listener; - } return self; -} - -- (CYWebPolicyDecision) decision { - return decision_; -} - -- (bool) decided { - return decision_ != CYWebPolicyDecisionUnknown; -} - -- (bool) decide { - switch (decision_) { - case CYWebPolicyDecisionUnknown: - default: - NSLog(@"CYWebPolicyDecisionUnknown"); - return false; - - case CYWebPolicyDecisionDownload: [listener_ download]; break; - case CYWebPolicyDecisionIgnore: [listener_ ignore]; break; - case CYWebPolicyDecisionUse: [listener_ use]; break; - } - - return true; -} - -- (void) download { - decision_ = CYWebPolicyDecisionDownload; -} - -- (void) ignore { - decision_ = CYWebPolicyDecisionIgnore; -} - -- (void) use { - decision_ = CYWebPolicyDecisionUse; -} - -@end -// }}} - -@implementation CYWebView : UIWebView - -#if ShowInternals -#include "CyteKit/UCInternal.h" -#endif - -- (id) initWithFrame:(CGRect)frame { - if ((self = [super initWithFrame:frame]) != nil) { - } return self; -} - -- (void) dealloc { - [super dealloc]; -} - -- (id<CYWebViewDelegate>) delegate { - return (id<CYWebViewDelegate>) [super delegate]; -} - -/*- (WebView *) webView:(WebView *)view createWebViewWithRequest:(NSURLRequest *)request { - id<CYWebViewDelegate> delegate([self delegate]); - WebView *created(nil); - if (created == nil && [delegate respondsToSelector:@selector(webView:createWebViewWithRequest:)]) - created = [delegate webView:view createWebViewWithRequest:request]; - if (created == nil && [UIWebView instancesRespondToSelector:@selector(webView:createWebViewWithRequest:)]) - created = [super webView:view createWebViewWithRequest:request]; - return created; -}*/ - -// webView:addMessageToConsole: (X.Xx) {{{ -static void $UIWebViewWebViewDelegate$webView$addMessageToConsole$(UIWebViewWebViewDelegate *self, SEL sel, WebView *view, NSDictionary *message) { - UIWebView *uiWebView(MSHookIvar<UIWebView *>(self, "uiWebView")); - if ([uiWebView respondsToSelector:@selector(webView:addMessageToConsole:)]) - [uiWebView webView:view addMessageToConsole:message]; -} - -- (void) webView:(WebView *)view addMessageToConsole:(NSDictionary *)message { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:addMessageToConsole:)]) - [delegate webView:view addMessageToConsole:message]; - if ([UIWebView instancesRespondToSelector:@selector(webView:addMessageToConsole:)]) - [super webView:view addMessageToConsole:message]; -} -// }}} -// webView:decidePolicyForNavigationAction:request:frame:decisionListener: (2.0+) {{{ -- (void) webView:(WebView *)view decidePolicyForNavigationAction:(NSDictionary *)action request:(NSURLRequest *)request frame:(WebFrame *)frame decisionListener:(id<WebPolicyDecisionListener>)listener { - id<CYWebViewDelegate> delegate([self delegate]); - CYWebPolicyDecisionMediator *mediator([[[CYWebPolicyDecisionMediator alloc] initWithListener:listener] autorelease]); - if (![mediator decided] && [delegate respondsToSelector:@selector(webView:decidePolicyForNavigationAction:request:frame:decisionListener:)]) - [delegate webView:view decidePolicyForNavigationAction:action request:request frame:frame decisionListener:mediator]; - if (![mediator decided] && [UIWebView instancesRespondToSelector:@selector(webView:decidePolicyForNavigationAction:request:frame:decisionListener:)]) - [super webView:view decidePolicyForNavigationAction:action request:request frame:frame decisionListener:mediator]; - [mediator decide]; -} -// }}} -// webView:decidePolicyForNewWindowAction:request:newFrameName:decisionListener: (3.0+) {{{ -static void $UIWebViewWebViewDelegate$webView$decidePolicyForNewWindowAction$request$newFrameName$decisionListener$(UIWebViewWebViewDelegate *self, SEL sel, WebView *view, NSDictionary *action, NSURLRequest *request, NSString *frame, id<WebPolicyDecisionListener> listener) { - UIWebView *uiWebView(MSHookIvar<UIWebView *>(self, "uiWebView")); - if ([uiWebView respondsToSelector:@selector(webView:decidePolicyForNewWindowAction:request:newFrameName:decisionListener:)]) - [uiWebView webView:view decidePolicyForNewWindowAction:action request:request newFrameName:frame decisionListener:listener]; -} - -- (void) webView:(WebView *)view decidePolicyForNewWindowAction:(NSDictionary *)action request:(NSURLRequest *)request newFrameName:(NSString *)frame decisionListener:(id<WebPolicyDecisionListener>)listener { - id<CYWebViewDelegate> delegate([self delegate]); - CYWebPolicyDecisionMediator *mediator([[[CYWebPolicyDecisionMediator alloc] initWithListener:listener] autorelease]); - if (![mediator decided] && [delegate respondsToSelector:@selector(webView:decidePolicyForNewWindowAction:request:newFrameName:decisionListener:)]) - [delegate webView:view decidePolicyForNewWindowAction:action request:request newFrameName:frame decisionListener:mediator]; - if (![mediator decided] && [UIWebView instancesRespondToSelector:@selector(webView:decidePolicyForNewWindowAction:request:newFrameName:decisionListener:)]) - [super webView:view decidePolicyForNewWindowAction:action request:request newFrameName:frame decisionListener:mediator]; - [mediator decide]; -} -// }}} -// webView:didClearWindowObject:forFrame: (3.2+) {{{ -static void $UIWebViewWebViewDelegate$webView$didClearWindowObject$forFrame$(UIWebViewWebViewDelegate *self, SEL sel, WebView *view, WebScriptObject *window, WebFrame *frame) { - UIWebView *uiWebView(MSHookIvar<UIWebView *>(self, "uiWebView")); - if ([uiWebView respondsToSelector:@selector(webView:didClearWindowObject:forFrame:)]) - [uiWebView webView:view didClearWindowObject:window forFrame:frame]; -} - -- (void) webView:(WebView *)view didClearWindowObject:(WebScriptObject *)window forFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:didClearWindowObject:forFrame:)]) - [delegate webView:view didClearWindowObject:window forFrame:frame]; - if ([UIWebView instancesRespondToSelector:@selector(webView:didClearWindowObject:forFrame:)]) - [super webView:view didClearWindowObject:window forFrame:frame]; -} -// }}} -// webView:didFailLoadWithError:forFrame: (2.0+) {{{ -- (void) webView:(WebView *)view didFailLoadWithError:(NSError *)error forFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:didFailLoadWithError:forFrame:)]) - [delegate webView:view didFailLoadWithError:error forFrame:frame]; - if ([UIWebView instancesRespondToSelector:@selector(webView:didFailLoadWithError:forFrame:)]) - [super webView:view didFailLoadWithError:error forFrame:frame]; -} -// }}} -// webView:didFailProvisionalLoadWithError:forFrame: (2.0+) {{{ -- (void) webView:(WebView *)view didFailProvisionalLoadWithError:(NSError *)error forFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:didFailProvisionalLoadWithError:forFrame:)]) - [delegate webView:view didFailProvisionalLoadWithError:error forFrame:frame]; - if ([UIWebView instancesRespondToSelector:@selector(webView:didFailProvisionalLoadWithError:forFrame:)]) - [super webView:view didFailProvisionalLoadWithError:error forFrame:frame]; -} -// }}} -// webView:didFinishLoadForFrame: (2.0+) {{{ -- (void) webView:(WebView *)view didFinishLoadForFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:didFinishLoadForFrame:)]) - [delegate webView:view didFinishLoadForFrame:frame]; - if ([UIWebView instancesRespondToSelector:@selector(webView:didFinishLoadForFrame:)]) - [super webView:view didFinishLoadForFrame:frame]; -} -// }}} -// webView:didReceiveTitle:forFrame: (3.2+) {{{ -static void $UIWebViewWebViewDelegate$webView$didReceiveTitle$forFrame$(UIWebViewWebViewDelegate *self, SEL sel, WebView *view, NSString *title, WebFrame *frame) { - UIWebView *uiWebView(MSHookIvar<UIWebView *>(self, "uiWebView")); - if ([uiWebView respondsToSelector:@selector(webView:didReceiveTitle:forFrame:)]) - [uiWebView webView:view didReceiveTitle:title forFrame:frame]; -} - -- (void) webView:(WebView *)view didReceiveTitle:(NSString *)title forFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:didReceiveTitle:forFrame:)]) - [delegate webView:view didReceiveTitle:title forFrame:frame]; - if ([UIWebView instancesRespondToSelector:@selector(webView:didReceiveTitle:forFrame:)]) - [super webView:view didReceiveTitle:title forFrame:frame]; -} -// }}} -// webView:didStartProvisionalLoadForFrame: (2.0+) {{{ -- (void) webView:(WebView *)view didStartProvisionalLoadForFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webView:didStartProvisionalLoadForFrame:)]) - [delegate webView:view didStartProvisionalLoadForFrame:frame]; - if ([UIWebView instancesRespondToSelector:@selector(webView:didStartProvisionalLoadForFrame:)]) - [super webView:view didStartProvisionalLoadForFrame:frame]; -} -// }}} -// webView:resource:willSendRequest:redirectResponse:fromDataSource: (3.2+) {{{ -static NSURLRequest *$UIWebViewWebViewDelegate$webView$resource$willSendRequest$redirectResponse$fromDataSource$(UIWebViewWebViewDelegate *self, SEL sel, WebView *view, id identifier, NSURLRequest *request, NSURLResponse *response, WebDataSource *source) { - UIWebView *uiWebView(MSHookIvar<UIWebView *>(self, "uiWebView")); - if ([uiWebView respondsToSelector:@selector(webView:resource:willSendRequest:redirectResponse:fromDataSource:)]) - request = [uiWebView webView:view resource:identifier willSendRequest:request redirectResponse:response fromDataSource:source]; - return request; -} - -- (NSURLRequest *) webView:(WebView *)view resource:(id)identifier willSendRequest:(NSURLRequest *)request redirectResponse:(NSURLResponse *)response fromDataSource:(WebDataSource *)source { - id<CYWebViewDelegate> delegate([self delegate]); - if ([UIWebView instancesRespondToSelector:@selector(webView:resource:willSendRequest:redirectResponse:fromDataSource:)]) - request = [super webView:view resource:identifier willSendRequest:request redirectResponse:response fromDataSource:source]; - if ([delegate respondsToSelector:@selector(webView:resource:willSendRequest:redirectResponse:fromDataSource:)]) - request = [delegate webView:view resource:identifier willSendRequest:request redirectResponse:response fromDataSource:source]; - return request; -} -// }}} -// webView:runJavaScriptAlertPanelWithMessage:initiatedByFrame: (2.1+) {{{ -- (void) webView:(WebView *)view runJavaScriptAlertPanelWithMessage:(NSString *)message initiatedByFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([UIWebView instancesRespondToSelector:@selector(webView:runJavaScriptAlertPanelWithMessage:initiatedByFrame:)]) - if ( - ![delegate respondsToSelector:@selector(webView:shouldRunJavaScriptAlertPanelWithMessage:initiatedByFrame:)] || - [delegate webView:view shouldRunJavaScriptAlertPanelWithMessage:message initiatedByFrame:frame] - ) - [super webView:view runJavaScriptAlertPanelWithMessage:message initiatedByFrame:frame]; -} -// }}} -// webView:runJavaScriptConfirmPanelWithMessage:initiatedByFrame: (2.1+) {{{ -- (BOOL) webView:(WebView *)view runJavaScriptConfirmPanelWithMessage:(NSString *)message initiatedByFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([UIWebView instancesRespondToSelector:@selector(webView:runJavaScriptConfirmPanelWithMessage:initiatedByFrame:)]) - if ( - ![delegate respondsToSelector:@selector(webView:shouldRunJavaScriptConfirmPanelWithMessage:initiatedByFrame:)] || - [delegate webView:view shouldRunJavaScriptConfirmPanelWithMessage:message initiatedByFrame:frame] - ) - return [super webView:view runJavaScriptConfirmPanelWithMessage:message initiatedByFrame:frame]; - return NO; -} -// }}} -// webView:runJavaScriptTextInputPanelWithPrompt:defaultText:initiatedByFrame: (2.1+) {{{ -- (NSString *) webView:(WebView *)view runJavaScriptTextInputPanelWithPrompt:(NSString *)prompt defaultText:(NSString *)text initiatedByFrame:(WebFrame *)frame { - id<CYWebViewDelegate> delegate([self delegate]); - if ([UIWebView instancesRespondToSelector:@selector(webView:runJavaScriptTextInputPanelWithPrompt:defaultText:initiatedByFrame:)]) - if ( - ![delegate respondsToSelector:@selector(webView:shouldRunJavaScriptTextInputPanelWithPrompt:defaultText:initiatedByFrame:)] || - [delegate webView:view shouldRunJavaScriptTextInputPanelWithPrompt:prompt defaultText:text initiatedByFrame:frame] - ) - return [super webView:view runJavaScriptTextInputPanelWithPrompt:prompt defaultText:text initiatedByFrame:frame]; - return nil; -} -// }}} -// webViewClose: (3.2+) {{{ -static void $UIWebViewWebViewDelegate$webViewClose$(UIWebViewWebViewDelegate *self, SEL sel, WebView *view) { - UIWebView *uiWebView(MSHookIvar<UIWebView *>(self, "uiWebView")); - if ([uiWebView respondsToSelector:@selector(webViewClose:)]) - [uiWebView webViewClose:view]; -} - -- (void) webViewClose:(WebView *)view { - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webViewClose:)]) - [delegate webViewClose:view]; - if ([UIWebView instancesRespondToSelector:@selector(webViewClose:)]) - [super webViewClose:view]; -} -// }}} - -- (void) _updateViewSettings { - [super _updateViewSettings]; - - id<CYWebViewDelegate> delegate([self delegate]); - if ([delegate respondsToSelector:@selector(webViewUpdateViewSettings:)]) - [delegate webViewUpdateViewSettings:self]; -} - -+ (void) initialize { - if (Class $UIWebViewWebViewDelegate = objc_getClass("UIWebViewWebViewDelegate")) { - class_addMethod($UIWebViewWebViewDelegate, @selector(webView:addMessageToConsole:), (IMP) &$UIWebViewWebViewDelegate$webView$addMessageToConsole$, "v16@0:4@8@12"); - class_addMethod($UIWebViewWebViewDelegate, @selector(webView:decidePolicyForNewWindowAction:request:newFrameName:decisionListener:), (IMP) &$UIWebViewWebViewDelegate$webView$decidePolicyForNewWindowAction$request$newFrameName$decisionListener$, "v28@0:4@8@12@16@20@24"); - class_addMethod($UIWebViewWebViewDelegate, @selector(webView:didClearWindowObject:forFrame:), (IMP) &$UIWebViewWebViewDelegate$webView$didClearWindowObject$forFrame$, "v20@0:4@8@12@16"); - class_addMethod($UIWebViewWebViewDelegate, @selector(webView:didReceiveTitle:forFrame:), (IMP) &$UIWebViewWebViewDelegate$webView$didReceiveTitle$forFrame$, "v20@0:4@8@12@16"); - class_addMethod($UIWebViewWebViewDelegate, @selector(webView:resource:willSendRequest:redirectResponse:fromDataSource:), (IMP) &$UIWebViewWebViewDelegate$webView$resource$willSendRequest$redirectResponse$fromDataSource$, "@28@0:4@8@12@16@20@24"); - class_addMethod($UIWebViewWebViewDelegate, @selector(webViewClose:), (IMP) &$UIWebViewWebViewDelegate$webViewClose$, "v12@0:4@8"); - } -} - -@end - @implementation BrowserController #if ShowInternals |