summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJay Freeman (saurik) <saurik@saurik.com>2009-01-23 11:39:31 +0000
committerJay Freeman (saurik) <saurik@saurik.com>2010-09-30 07:09:39 +0000
commit1b1b3f4af0bd30c5c6c7378187766155b1963b9d (patch)
tree72529f5246256a930f4676b34e46a207202c190f
parent2fc76a2d05d0bdb0916e907a501e0777caeeab20 (diff)
Fixed some bugs in new window opening.
-rw-r--r--UICaboodle/BrowserView.h1
-rw-r--r--UICaboodle/BrowserView.m42
2 files changed, 25 insertions, 18 deletions
diff --git a/UICaboodle/BrowserView.h b/UICaboodle/BrowserView.h
index 632528d..09680e3 100644
--- a/UICaboodle/BrowserView.h
+++ b/UICaboodle/BrowserView.h
@@ -68,6 +68,7 @@
- (void) reloadURL;
- (WebView *) webView;
+- (UIWebDocumentView *) documentView;
- (id) initWithBook:(RVBook *)book;
diff --git a/UICaboodle/BrowserView.m b/UICaboodle/BrowserView.m
index 1fd1422..0816523 100644
--- a/UICaboodle/BrowserView.m
+++ b/UICaboodle/BrowserView.m
@@ -168,11 +168,13 @@
@implementation BrowserView
-#if ForSaurik
+#if ShowInternals
#include "Internals.h"
#endif
- (void) dealloc {
+ NSLog(@"deallocating WebView");
+
if (challenge_ != nil)
[challenge_ release];
@@ -260,7 +262,6 @@
}
- (void) reloadURL {
- NSLog(@"rlu:%@", request_);
if (request_ == nil)
return;
@@ -284,6 +285,10 @@
return [webview_ webView];
}
+- (UIWebDocumentView *) documentView {
+ return webview_;
+}
+
- (void) view:(UIView *)sender didSetFrame:(CGRect)frame {
[scroller_ setContentSize:frame.size];
}
@@ -294,8 +299,8 @@
- (void) pushPage:(RVPage *)page {
[page setDelegate:delegate_];
- [book_ pushPage:page];
[self setBackButtonTitle:title_];
+ [book_ pushPage:page];
}
- (BOOL) getSpecial:(NSURL *)url {
@@ -318,6 +323,9 @@
return true;
}
+- (void) webViewShow:(WebView *)sender {
+}
+
- (void) webView:(WebView *)sender runJavaScriptAlertPanelWithMessage:(NSString *)message initiatedByFrame:(WebFrame *)frame {
UIActionSheet *sheet = [[[UIActionSheet alloc]
initWithTitle:nil
@@ -395,9 +403,10 @@
}
- (void) webView:(WebView *)sender decidePolicyForNewWindowAction:(NSDictionary *)action request:(NSURLRequest *)request newFrameName:(NSString *)name decisionListener:(id<WebPolicyDecisionListener>)listener {
+ NSLog(@"nwa:%@", name);
+
if (NSURL *url = [request URL]) {
if (name == nil) unknown: {
- NSLog(@"win:%@:%@", url, [action description]);
if (![self getSpecial:url]) {
NSString *scheme([[url scheme] lowercaseString]);
if ([scheme isEqualToString:@"mailto"])
@@ -411,6 +420,10 @@
RVPage *page([delegate_ pageForURL:url hasTag:NULL]);
if (page == nil) {
+ /* XXX: call createWebViewWithRequest instead */
+
+ [self setBackButtonTitle:title_];
+
BrowserView *browser([[[BrowserView alloc] initWithBook:book] autorelease]);
[browser loadURL:url];
page = browser;
@@ -630,26 +643,19 @@
return [self _addHeadersToRequest:request];
}
-- (WebView *) _createWebViewWithRequest:(NSURLRequest *)request pushed:(BOOL)pushed {
- [self setBackButtonTitle:title_];
+- (WebView *) webView:(WebView *)sender createWebViewWithRequest:(NSURLRequest *)request windowFeatures:(NSDictionary *)features {
+#if ForSaurik
+ NSLog(@"cwv:%@ (%@)", request, title_);
+#endif
BrowserView *browser = [[[BrowserView alloc] initWithBook:book_] autorelease];
- [browser setDelegate:delegate_];
-
- if (pushed) {
- [browser loadRequest:request];
- [book_ pushPage:browser];
- }
-
+ [self pushPage:browser];
+ [browser loadRequest:request];
return [browser webView];
}
- (WebView *) webView:(WebView *)sender createWebViewWithRequest:(NSURLRequest *)request {
- return [self _createWebViewWithRequest:request pushed:(request != nil)];
-}
-
-- (WebView *) webView:(WebView *)sender createWebViewWithRequest:(NSURLRequest *)request windowFeatures:(NSDictionary *)features {
- return [self _createWebViewWithRequest:request pushed:YES];
+ return [self webView:sender createWebViewWithRequest:request windowFeatures:nil];
}
- (void) webView:(WebView *)sender didReceiveTitle:(NSString *)title forFrame:(WebFrame *)frame {