summaryrefslogtreecommitdiffstats
path: root/WebKit/mac/ChangeLog-2007-10-14
diff options
context:
space:
mode:
Diffstat (limited to 'WebKit/mac/ChangeLog-2007-10-14')
-rw-r--r--WebKit/mac/ChangeLog-2007-10-1424506
1 files changed, 24506 insertions, 0 deletions
diff --git a/WebKit/mac/ChangeLog-2007-10-14 b/WebKit/mac/ChangeLog-2007-10-14
new file mode 100644
index 0000000..ccf939d
--- /dev/null
+++ b/WebKit/mac/ChangeLog-2007-10-14
@@ -0,0 +1,24506 @@
+=== Start merge of feature-branch 2007-10-12 ===
+
+2007-10-03 Andrew Wellington <proton@wiretapped.net>
+
+ Reviewed by Mark Rowe.
+
+ Mac build fix for issue introduced in r26027
+
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+
+2007-10-01 Eric Seidel <eric@webkit.org>
+
+ Reviewed by Oliver Hunt.
+
+ SVG Subresources will not be saved when creating WebArchives
+ http://bugs.webkit.org/show_bug.cgi?id=15280
+
+ Implement _subresourceURLs methods for more SVGElement types
+ more such methods will be needed as we add support for other
+ external references (such as use, mpath, tref, etc.)
+
+ * DOM/WebDOMOperations.mm:
+ (-[DOMSVGScriptElement _subresourceURLs]): added.
+ (-[DOMSVGCursorElement _subresourceURLs]): added.
+ (-[DOMSVGFEImageElement _subresourceURLs]): added.
+
+2007-10-01 Eric Seidel <eric@webkit.org>
+
+ Reviewed by Oliver Hunt.
+
+ WebArchives do not embed stylesheets referenced by xml-stylesheeet
+ http://bugs.webkit.org/show_bug.cgi?id=15320
+
+ * DOM/WebDOMOperations.mm:
+ (-[DOMProcessingInstruction _stylesheetURL]): needed to access [[self sheet] href]
+ (-[DOMProcessingInstruction _subresourceURLs]): call and return _stylesheetURL
+
+2007-10-01 Eric Seidel <eric@webkit.org>
+
+ Reviewed by Oliver Hunt.
+
+ * DOM/WebDOMOperations.mm: added DOMSVGElementImage _subresources implementation
+ (-[DOMNode _URLsFromSelectors:]): now handles DOMSVGAnimatedString return values
+ (-[DOMSVGImageElement _subresourceURLs]): added.
+ * MigrateHeaders.make: copies DOMSVG* headers into WebKit/PrivateHeaders
+
+2007-10-01 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Mark.
+
+ Enable Experimental SVG features by default when building from Xcode
+
+ * Configurations/WebKit.xcconfig:
+
+=== End merge of feature-branch 2007-10-12 ===
+
+2007-10-11 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Fix for <rdar://problem/5488678>. Disable debugging symbols in production builds for 10.4
+ PowerPC to prevent a huge STABS section from being generated.
+
+ * Configurations/Base.xcconfig:
+
+2007-10-10 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Geoff Garen.
+
+ Fixed <rdar://5464402> Crash when running fast/frames/onload-remove-iframe-crash.html in DRT
+ createFrame() now returns a RefPtr instead of a raw Frame pointer.
+ Making this change improves the way we handle frames on Windows WebKit.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::createFrame):
+
+2007-10-04 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Fix for <rdar://problem/5441823> REGRESSION (r25142, Tiger only):
+ Vertical scroll bar not redrawn properly when going back in history
+ (15033)
+
+ This fix if-defs r25142 to be Leopard-only since it causes
+ correctness issues on Tiger and does not seem to have any
+ performance impact on Tiger either.
+
+ * WebView/WebDynamicScrollBarsView.m:
+ (-[WebDynamicScrollBarsView setScrollBarsSuppressed:repaintOnUnsuppress:]):
+ (-[WebDynamicScrollBarsView reflectScrolledClipView:]):
+
+2007-10-04 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Oliver.
+
+ Switch to default level of debugging symbols to resolve <rdar://problem/5488678>.
+ The "full" level appears to offer no observable benefits even though the documentation
+ suggests it be used for dead code stripping. This should also decrease link times.
+
+ * Configurations/Base.xcconfig:
+
+2007-10-04 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ WebKit part of fix for <rdar://problem/5369017> REGRESSION: Can't tab to webview that doesn't have editable content
+
+ * WebView/WebHTMLView.mm: (-[WebHTMLView becomeFirstResponder]): Pass in the FocusDirection.
+
+2007-10-04 Darin Adler <darin@apple.com>
+
+ * WebView/WebHTMLView.mm: (-[WebHTMLView _updateActiveState]):
+ Removed a bogus comment.
+
+2007-10-02 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ Re-added _minimumRequiredSafariBuildNumber. It turns out older version of Safari still rely
+ on this method, so we need to keep it around at least until the next major Safari release.
+
+ * StringsNotToBeLocalized.txt:
+ * WebView/WebView.mm:
+ (+[WebView _minimumRequiredSafariBuildNumber]):
+ * WebView/WebViewPrivate.h:
+
+2007-10-02 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/5517710>
+
+ * WebView/WebView.mm: Removed -[WebView _minimumRequiredSafariBuildNumber] because newer
+ versions of Safari no longer use this method. This won't break existing Safaris because
+ they always use a respondsToSelector check before calling this.
+
+ * WebView/WebViewPrivate.h: Ditto.
+
+2007-09-27 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Ollie
+
+ - fixed <rdar://problem/5408186> REGRESSION (5522-5523.9): Safari leaks every browser window
+
+ The leak started occurring when we removed the code to clear the delegates and the host window
+ from Safari as part of the fix for 5479443. But it turns out that Safari code was masking a
+ bug here in WebView: setHostWindow:nil needs to be called before setting _private->closed to
+ YES, or it will do nothing at all, causing a world leak due to a circular reference between
+ the window and the WebView.
+
+ I toyed with a more complex fix, but this is the simplest one that retains the fix for 5479443
+ while otherwise restoring the code order to be as close as possible to what it was before
+ 5479443 was fixed.
+
+ * WebView/WebView.mm:
+ (-[WebView _close]):
+ Moved the call that sets _private->closed to YES to be after the code that clears the delegates
+ and the host window. Added a comment about this order.
+
+2007-09-27 Kevin Decker <kdecker@apple.com>
+
+ Rubber stamped by Darin.
+
+ <rdar://problem/5493093>
+
+ * WebKit.order: Added.
+ * WebKit.xcodeproj/project.pbxproj: We're changing from using an order file built by
+ another team to using one we actually check into our project repository. Linker settings for
+ Symbol Ordering Flags have been updated accordingly.
+
+2007-09-26 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Adele Peterson.
+
+ Fixed <rdar://problem/5507476> Promote cache model SPI to API
+
+ Promoted cache model SPI to API. This was just a move, with some small
+ edits to the documentation (changing 'application' to 'WebView' in
+ some cases, since the interface is now per-WebView).
+
+ * WebView/WebPreferences.h:
+ * WebView/WebPreferences.m:
+ (-[WebPreferences setCacheModel:]):
+ (-[WebPreferences cacheModel]):
+ * WebView/WebPreferencesPrivate.h:
+
+2007-09-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5498016> Photoshop CS3: Adobe Help Viewer 1.1 crashes in 9A553
+
+ WebKit started calling the mouseDidMoveOverElement delegate method with a nil dictionary in r14982.
+ We originally intended to call this delegate method sometimes with a nil dictionary, but due to
+ a bug dating back to WebKit 1.0 this delegate was never called with nil! Unfortunately we can't
+ start calling this with nil since it will break Adobe Help Viewer, and possibly other clients.
+
+ * WebView/WebView.mm:
+ (-[WebView _mouseDidMoveOverElement:modifierFlags:]):
+
+2007-09-21 Kevin Decker <kdecker@apple.com>
+
+ * Plugins/WebBaseNetscapePluginView.mm: Build fix.
+ The first argument of aglChoosePixelFormat() has changed from const AGLDevice *gdevs on Tiger to
+ const void *gdevs on Leopard.
+
+2007-09-20 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Darin Adler.
+
+ <rdar://problem/5493093>
+
+ Reduced launch time by lazily linking both the AGL and OpenGL frameworks until they are really needed.
+
+ * Plugins/WebBaseNetscapePluginView.mm: Soft link all AGL and OpenGL functions used by
+ WebBaseNetscapePluginView.
+
+ * WebKit.xcodeproj/project.pbxproj: Removed AGL and OpenGL from the project.
+
+2007-09-20 John Sullivan <sullivan@apple.com>
+
+ Build fix for stoooopid old PPC gcc compiler
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::checkSpellingOfString):
+ replace perfectly valid ?: syntax with if/else
+
+2007-09-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin Adler.
+
+ - WebKit part of speculative fix for <rdar://problem/5490627>, about crashes constructing a
+ String using the values filled in by checkSpellingOfString()
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::checkSpellingOfString):
+ convert NSNotFound to -1, since WebCore code expects -1 for this purpose. We already do this
+ in checkGrammarOfString.
+
+2007-09-19 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Darin Adler.
+
+ <rdar://problem/5491066> soft link Accelerate.framework
+
+ * Misc/WebGraphicsExtras.c:
+ (WebConvertBGRAToARGB): Improve launch time performance and reduce vsize
+ footprint by soft linking the Accelerate.framework.
+ * WebKit.xcodeproj/project.pbxproj: Remove no longer needed frameworks.
+
+2007-09-18 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Fixed <rdar://problem/5490204> In some cases, WebKit can make the
+ Foundation disk cache way too big or way too small
+
+ Use the actual location of the foundation disk cache, rather than
+ the user's home directory, when determining how big to make it.
+
+ * WebView/WebView.mm:
+ (+[WebView _setCacheModel:]):
+
+2007-09-17 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Fixed a hang due to an infinite script running in the window's unload
+ event handler, which may be the cause of <rdar://problem/5479443>
+ REGRESSION: Hang due to infinite JS recursion on close @ engadget.com
+ (onunload-based ad)
+
+ * WebView/WebUIDelegatePrivate.h: Added FIXME.
+
+ * WebView/WebView.h: Clarified headerdoc ambiguity about when delegate
+ methods stop firing.
+
+ * WebView/WebView.mm:
+ (-[WebView _close]): The fix: don't nil out our delegates until after
+ detaching the FrameLoader, because the act of detaching the FrameLoader
+ might fire important delegate methods, like webViewShouldInterruptJavaScript:.
+ Don't do other tear-down either, because the unload event handler needs
+ to run in a fully constructed page.
+
+ This change is fairly low risk because niling out our delegates is a
+ very recent, never-shipped feature in WebKit, so it's unlikely that any
+ apps rely on it in a crazy way.
+
+2007-09-15 Darin Adler <darin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ - fix <rdar://problem/5391540> REGRESSION: Can't drag images from Safari to applications
+ in the dock (Tiger Preview, others in Leopard)
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_declareAndWriteDragImageForElement:URL:title:archive:source:]):
+ Re-implement code here that has been missing for the last couple of years since we
+ did some image refactoring. Was pretty easy now that we can freely call C++ code
+ in WebKit.
+
+2007-09-14 Mark Rowe <mrowe@apple.com>
+
+ Build fix for Tiger.
+
+ * WebView/WebArchive.m:
+ (-[WebArchive initWithCoder:]): Use @catch(id) rather than @catch(...).
+ * WebView/WebPreferences.m:
+ (-[WebPreferences initWithCoder:]): Ditto.
+ * WebView/WebResource.mm:
+ (-[WebResource initWithCoder:]): Ditto.
+ (-[WebResource _initWithPropertyList:]): Ditto.
+
+2007-09-14 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff Garen and Tim Hatcher.
+
+ - fixed <rdar://problem/5482745> initFromCoder: and initWithPropertyList: functions
+ should guard against incorrect types
+
+ * WebView/WebArchive.m:
+ (isArrayOfClass): Added helper function.
+ (-[WebArchive _initWithPropertyList:]): Tweaked function to remove the need for a
+ type cast.
+ (-[WebArchive initWithCoder:]): Added type checking for the main resource,
+ subresources array, and subframe archives array. Also replaced NS_DURING with @try.
+ * WebView/WebPreferences.m: (-[WebPreferences initWithCoder:]): Added type checking
+ for the identifier and the values dictionary, including ensuring that it's a mutable
+ dictionary.
+ * WebView/WebResource.mm:
+ (-[WebResource initWithCoder:]): Added type checking for all the fields.
+ (-[WebResource _initWithPropertyList:]): Added type checking for the NSURLResponse.
+
+ * WebKit.exp: Removed accidentally exported internal symbol; I checked and it's not
+ used anywhere.
+
+2007-09-13 Darin Adler <darin@apple.com>
+
+ Reviewed by Oliver.
+
+ - fix <rdar://problem/5470457> REGRESSION: Input method inline hole is mishandled in text
+ <input> elements with maxlength limit
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _selectionChanged]): Tweaked code a bit.
+ (-[WebHTMLView markedRange]): Simplified logic, since markedTextNSRange works when there's
+ no composition range.
+ (-[WebHTMLView hasMarkedText]): Call directly to Editor instead of bridge.
+ (-[WebHTMLView unmarkText]): Call new confirmComposition to make it clear that this is
+ confirming text, not just unmarking it to discard it.
+ (extractUnderlines): Added. Converts directly from an NSAttributedString to the
+ CompositionUnderline vector that's used by WebCore.
+ (-[WebHTMLView setMarkedText:selectedRange:]): Changed to use the new setComposition.
+ (-[WebHTMLView insertText:]): Changed to use confirmComposition when appropriate, instead
+ of relying on special behavior of Editor::insertText.
+ (-[WebHTMLView _updateSelectionForInputManager]): Rewrote to use getCompositionSelection
+ and confirmCompositionWithoutDisturbingSelection.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ Removed obsolete markedTextAbandoned function.
+
+2007-09-12 David Kilzer <ddkilzer@apple.com>
+
+ Rubber-stamped by Darin and reviewed by Adam.
+
+ Removed import of unused icon database headers.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2007-09-11 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Remove the unused class_getMethodImplementation function.
+
+ * Misc/WebNSObjectExtras.h:
+
+2007-09-11 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ Fixed CFNetwork version check so it actually works.
+
+ * Misc/WebKitVersionChecks.h:
+ * WebView/WebView.mm:
+ (+[WebView _setCacheModel:]): Don't use NSVersionOfLinkTimeLibrary because
+ we don't link against CFNetwork directly, so it returns -1. Also, use
+ the proper hex encoding instead of decimal numbers.
+
+2007-09-11 Darin Adler <darin@apple.com>
+
+ - redo fix for <rdar://problem/5472899> REGRESSION (TOT): Crash in FrameLoadDelegate loading stationery
+
+ * WebView/WebView.mm:
+ (getMethod): Added.
+ (-[WebView _cacheResourceLoadDelegateImplementations]): Use getMethod.
+ (-[WebView _cacheFrameLoadDelegateImplementations]): Ditto.
+
+2007-09-11 Darin Adler <darin@apple.com>
+
+ Rubber-stamped by Dave Harrison.
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface):
+ Removed wkCreateURLPasteboardFlavorTypeName and wkCreateURLNPasteboardFlavorTypeName.
+
+2007-09-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ - fix <rdar://problem/5472899> REGRESSION (TOT): Crash in FrameLoadDelegate loading stationery
+
+ * Misc/WebNSObjectExtras.h:
+ (class_getMethodImplementation): Added.
+ (method_setImplementation): Added.
+
+ * WebView/WebHTMLView.mm: (+[WebHTMLViewPrivate initialize]):
+ * Carbon/HIViewAdapter.m: (+[HIViewAdapter bindHIViewToNSView:nsView:]):
+ Remove old-ObjC code path, since WebNSObjectExtras.h now implements everything we need.
+
+ * WebView/WebView.mm:
+ (-[WebView _cacheResourceLoadDelegateImplementations]): Don't bother doing a separate
+ respondsToSelector call, since class_getMethodImplementation will return 0 for selectors
+ that we don't respond to. The bug fix is to actually set the cached pointer to 0.
+ Also get rid of the unnecessary use of a macro; instead use the functions from
+ WebNSObjectExtras.h on Tiger and the appropriate function directly on Leopard.
+ (-[WebView _cacheFrameLoadDelegateImplementations]): Ditto.
+
+2007-09-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Sam, Ollie.
+
+ * WebView/WebView.mm: (+[WebView _setCacheModel:]): A slightly cleaner 64-bit
+ fix for the NSURLCache capacity code in this file.
+
+2007-09-11 Darin Adler <darin@apple.com>
+
+ Rubber-stamped by Mark Rowe.
+
+ * Misc/WebNSPasteboardExtras.mm: Fix incorrect strings in my last check-in.
+ The strings I checked in were wrong and were breaking layout tests too.
+ These new ones match what WebKitSystemInterface was returning.
+
+2007-09-10 Geoffrey Garen <ggaren@apple.com>
+
+ Fixed 64-bit build (I think).
+
+ * WebView/WebView.mm:
+ (max): Added. In 64-bit land, -diskCapacity magically starts returning
+ unsigned long instead of unsigned, so we define a custom max() that's
+ willing to compare unsigned to unsigned long.
+
+2007-09-10 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - <rdar://problem/5471082> Removing WebURLPboardType from headers broke SPI-using applications
+
+ Rolled out my fix for bug 4582212 and fixed it in a much simpler way.
+
+ * Misc/WebNSPasteboardExtras.h:
+ * Misc/WebNSPasteboardExtras.mm:
+ * WebCoreSupport/WebPasteboardHelper.mm:
+ * WebKit.exp:
+ * WebView/WebHTMLView.mm:
+ * WebView/WebView.mm:
+ Rolled out the new PasteboardType functions and changed the PboardType globals to be initialized
+ with constant values.
+
+2007-09-10 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Always animate when calling _scrollTo.
+
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _scrollVerticallyBy:]):
+ (-[WebFrameView _scrollHorizontallyBy:]):
+
+2007-09-08 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ <rdar://problem/5434431> - Asynchronous Icon Database
+
+ WebKit side of things
+ Mainly, there are Notifications WebKit has to listen for now that tell it when to either call back into WebCore
+ for some purpose or to send the webView:didReceiveIcon: delegate call
+
+ Many smaller tweaks as well.
+
+ * Misc/WebIconDatabase.h:
+ * Misc/WebIconDatabase.mm:
+ (defaultClient):
+ (-[WebIconDatabase init]):
+ (+[WebIconDatabase delayDatabaseCleanup]): Accessor so clients can prevent the thread from cleaning up the database
+ before they've done all their necessary retaining of icons.
+ (+[WebIconDatabase allowDatabaseCleanup]):
+ (-[WebIconDatabase removeAllIcons]):
+ (-[WebIconDatabase _isEnabled]):
+ (-[WebIconDatabase _sendNotificationForURL:]):
+ (-[WebIconDatabase _sendDidRemoveAllIconsNotification]):
+ (-[WebIconDatabase _databaseDirectory]):
+
+ (-[ThreadEnabler threadEnablingSelector:]): Quick and dirty class to enabled Cocoa multithreading
+ (+[ThreadEnabler enableThreading]):
+ (importToWebCoreFormat):
+ * Misc/WebIconDatabaseInternal.h: Expose the internal methods of WebIconDatabase that are required by WebIconDatabaseClient
+
+ * Misc/WebNSNotificationCenterExtras.h: Added. - Great utility class whose design was borrowed from Colloquy
+ that allows the posting of a Cocoa notification on the main thread from *any* thread
+ * Misc/WebNSNotificationCenterExtras.m: Added.
+ (-[NSNotificationCenter postNotificationOnMainThreadWithName:object:]):
+ (-[NSNotificationCenter postNotificationOnMainThreadWithName:object:userInfo:]):
+ (-[NSNotificationCenter postNotificationOnMainThreadWithName:object:userInfo:waitUntilDone:]):
+ (+[NSNotificationCenter _postNotificationName:]):
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidReceiveIcon): Send the webView:didReceiveIcon: delegate call
+ (WebFrameLoaderClient::registerForIconNotification):
+
+ * WebCoreSupport/WebIconDatabaseClient.h: Added.
+ * WebCoreSupport/WebIconDatabaseClient.mm: Added.
+ (WebIconDatabaseClient::performImport): Perform the Safari 2 icon import
+ (WebIconDatabaseClient::dispatchDidRemoveAllIcons): Send the NSNotification
+ (WebIconDatabaseClient::dispatchDidAddIconForPageURL): Ditto
+
+ * WebView/WebView.mm:
+ (-[WebView _receivedIconChangedNotification:]): Check and see if this notification is for this WebView's current URL by
+ calling back into the IconDatabase
+ (-[WebView _registerForIconNotification:]): Support for WebIconDatabaseClient
+ (-[WebView _dispatchDidReceiveIconFromWebFrame:]): Dispatch this delegate call as well as unregister for the notification
+ * WebView/WebViewInternal.h:
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-09-07 Geoffrey Garen <ggaren@apple.com>
+
+ Suggested by Maciej Stachowiak.
+
+ Added wKiosk Browser to the browser list. Pretty sweet app.
+
+ * WebView/WebPreferences.m:
+ (cacheModelForMainBundle):
+
+2007-09-07 Geoffrey Garen <ggaren@apple.com>
+
+ Build fix.
+
+ * WebView/WebView.mm:
+ (+[WebView _setCacheModel:]):
+
+2007-09-05 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler, Maciej Stachowiak, Mark Rowe, Tim Hatcher.
+
+ Fixed <rdar://problem/5326009> Make non-browser WebKit clients have no
+ memory cache, or a very tiny one
+
+ High level explanation:
+ - Added SPI for specifying a cache model on a per-WebView basis.
+ (Hopefully, this will become API soon.) We balance competing
+ cache models simply by using the largest one that pertains at a
+ given time.
+
+ - Added heuristic for guessing a default cache model in WebViews
+ that don't specify one:
+ 1) Default to DocumentViewer for apps linked on or after this
+ WebKit. Default to DocumentBrowser otherwise.
+
+ 2) Assign specific defaults to well-known clients based on
+ bundle ID.
+
+ 3) Grow the default to DocumentBrowser if a navigation takes
+ place.
+
+ - As a part of the DocumentBrowser & PrimaryWebBrowser settings:
+ 1) Make the Foundation disk cache much much bigger than the
+ default 20MB, if space allows. (This is a hedge against a small
+ WebCore cache in DocumentBrowser mode, but also an all-around
+ win for page load speed.)
+
+ 2) Scaled the Foundation memory cache's capacity with physical
+ RAM, just like we do with other caches. This is a small win on
+ low memory systems.
+
+ * Misc/WebKitSystemBits.h:
+ * Misc/WebKitSystemBits.m:
+ (WebMemorySize): Renamed from "WebSystemMainMemory."
+ (WebHomeDirectoryFreeSize): Added function to measure the free space
+ on the user's home directory. We use this as a factor in determining
+ the disk cache's cacpacity.
+
+ * Misc/WebKitVersionChecks.h: Support for linked on or after check.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::didPerformFirstNavigation): Implementation of
+ heuristic rule #3.
+
+ * WebView/WebPreferenceKeysPrivate.h:
+ * WebView/WebPreferences.m:
+ (cacheModelForMainBundle): Implementation of heuristic rule #2.
+ (-[NSMutableDictionary _web_checkLastReferenceForIdentifier:]): Added
+ notification for when a WebPreferences instance becomes inert. We use
+ this to shrink the cache model back down if possible. Moved this code
+ into a WebPreferences method, since it's not really a feature of
+ NSDictionary.
+
+ * WebView/WebPreferencesPrivate.h: SPI declarations.
+
+ * WebView/WebView.mm: Replaced manual notification posts with calls to
+ the _postPreferencesChangesNotification convenience method.
+
+ (-[WebView _preferencesChangedNotification:]): Merged dispersed code
+ for updating preferences-related settings into this one function. This
+ was needed for an earlier version of the patch, even though the
+ current version could probably do without it.
+
+ (+[WebView _preferencesChangedNotification:]): Added a class-level
+ listener for WebPreferences changes. This listener takes care of
+ modifying the class-level global cache model setting if necessary.
+
+ (+[WebPreferences standardPreferences]): Removed call to
+ _postPreferencesChangesNotification because the notification already
+ posts when you create the WebPreferences object. (I noticed this
+ inefficiency because my new _preferencesChangedNotification: method was
+ called excessively at startup.)
+
+ Also Added explicit tracking of WebPreferences clients, so we know when
+ a WebPreferences instance becomes inert:
+
+ (-[WebPreferences didRemoveFromWebView]):
+ (-[WebPreferences willAddToWebView]):
+
+ (+[WebView _setCacheModel:]): Translates a cache model into actual
+ settings in various APIs. Caches that have unbounded value grow
+ linearly relative to available space. Caches that have bounded value
+ grow inverse-squaredly relative to available space.
+
+2007-09-05 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5443883> Uncaught Objective-C exceptions in WebKit clients lead to hard-to-diagnose crashes
+
+ Changed all the direct delegate calls to use helper functions that have direct access to
+ WebView's delegate objects. These helper methods will catch any ObjC exceptions and call
+ ReportDiscardedDelegateException to log the discarded exception. WebView's that have
+ catchesDelegateExceptions set to NO will not pay the cost of a @try/@catch. The delegate
+ forwarders also have the same behavior.
+
+ * Misc/WebKitLogging.h:
+ * Misc/WebKitLogging.m:
+ (ReportDiscardedDelegateException):
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView loadPluginRequest:]):
+ * Plugins/WebNullPluginView.mm:
+ (-[WebNullPluginView viewDidMoveToWindow]):
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::createWindow):
+ (WebChromeClient::createModalDialog):
+ (WebChromeClient::runModal):
+ (WebChromeClient::toolbarsVisible):
+ (WebChromeClient::statusbarVisible):
+ (WebChromeClient::addMessageToConsole):
+ (WebChromeClient::canRunBeforeUnloadConfirmPanel):
+ (WebChromeClient::runBeforeUnloadConfirmPanel):
+ (WebChromeClient::runJavaScriptAlert):
+ (WebChromeClient::runJavaScriptConfirm):
+ (WebChromeClient::runJavaScriptPrompt):
+ (WebChromeClient::shouldInterruptJavaScript):
+ (WebChromeClient::setStatusbarText):
+ (WebChromeClient::print):
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::getCustomMenuFromDefaultItems):
+ (WebContextMenuClient::contextMenuItemSelected):
+ * WebCoreSupport/WebDragClient.mm:
+ (WebDragClient::startDrag):
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::textFieldDidBeginEditing):
+ (WebEditorClient::textFieldDidEndEditing):
+ (WebEditorClient::textDidChangeInTextField):
+ (WebEditorClient::doTextFieldCommandFromEvent):
+ (WebEditorClient::textWillBeDeletedInTextField):
+ (WebEditorClient::textDidChangeInTextArea):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge viewForPluginWithFrame:URL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::assignIdentifierToInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::willCacheResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::dispatchDidHandleOnloadEvents):
+ (WebFrameLoaderClient::dispatchDidReceiveServerRedirectForProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidCancelClientRedirect):
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect):
+ (WebFrameLoaderClient::dispatchDidChangeLocationWithinPage):
+ (WebFrameLoaderClient::dispatchWillClose):
+ (WebFrameLoaderClient::dispatchDidReceiveIcon):
+ (WebFrameLoaderClient::dispatchDidStartProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidReceiveTitle):
+ (WebFrameLoaderClient::dispatchDidCommitLoad):
+ (WebFrameLoaderClient::dispatchDidFailProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidFailLoad):
+ (WebFrameLoaderClient::dispatchDidFinishDocumentLoad):
+ (WebFrameLoaderClient::dispatchDidFinishLoad):
+ (WebFrameLoaderClient::dispatchDidFirstLayout):
+ (WebFrameLoaderClient::dispatchCreatePage):
+ (WebFrameLoaderClient::dispatchUnableToImplementPolicy):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ (WebFrameLoaderClient::dispatchDidLoadMainResource):
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView callDelegateDoCommandBySelectorIfNeeded:]):
+ (-[WebHTMLView validateUserInterfaceItem:]):
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView validateUserInterfaceItem:]):
+ (-[WebPDFView PDFViewSavePDFToDownloadFolder:]):
+ * WebView/WebView.mm:
+ (-[WebView _openNewWindowWithRequest:]):
+ (-[WebView _menuForElement:defaultItems:]):
+ (-[WebView _mouseDidMoveOverElement:modifierFlags:]):
+ (-[WebView _cacheResourceLoadDelegateImplementations]):
+ (-[WebView _cacheFrameLoadDelegateImplementations]):
+ (-[WebView _policyDelegateForwarder]):
+ (-[WebView _UIDelegateForwarder]):
+ (-[WebView _editingDelegateForwarder]):
+ (-[WebView _scriptDebugDelegateForwarder]):
+ (-[WebView _setCatchesDelegateExceptions:]):
+ (-[WebView _catchesDelegateExceptions]):
+ (-[_WebSafeForwarder initWithTarget:defaultTarget:]):
+ (-[_WebSafeForwarder forwardInvocation:]):
+ (-[_WebSafeForwarder methodSignatureForSelector:]):
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ (-[WebView validateUserInterfaceItem:]):
+ (-[WebView _headerHeight]):
+ (-[WebView _footerHeight]):
+ (-[WebView _drawHeaderInRect:]):
+ (-[WebView _drawFooterInRect:]):
+ (-[WebView _shouldChangeSelectedDOMRange:toDOMRange:affinity:stillSelecting:]):
+ (CallDelegate):
+ (CallDelegateReturningFloat):
+ (CallDelegateReturningBoolean):
+ (CallUIDelegate):
+ (CallUIDelegateReturningFloat):
+ (CallUIDelegateReturningBoolean):
+ (CallFrameLoadDelegate):
+ (CallResourceLoadDelegate):
+ (CallFormDelegate):
+ (CallFormDelegateReturningBoolean):
+ * WebView/WebViewInternal.h:
+ * WebView/WebViewPrivate.h:
+
+2007-09-04 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5452908> NIBs saved in the Pre-10.2 format while Safari 3 installed do not work without Safari 3
+
+ This happened because we encoded a new field that the old WebKit does not know how to read.
+ And NSCoder throws an exception if initWithCoder finishes while there is still unread data in the archive.
+
+ The WebViewVersion is now 4 to distinguish that we do not encode/decode allowsUndo.
+
+ * WebView/WebView.mm:
+ (-[WebView initWithCoder:]): Only try to read allowsUndo if the version is 3.
+ (-[WebView encodeWithCoder:]): No longer encode allowsUndo.
+
+2007-09-04 David Hyatt <hyatt@apple.com>
+
+ Fix for <rdar://problem/5271213>, resizing iChat window is slower than in
+ Tiger. This patch implements a fast scaling mode that can be used by
+ WebViews, e.g., during window resizing.
+
+ Reviewed by John Sullivan
+
+ * WebView/WebView.mm:
+ (-[WebView _setUseFastImageScalingMode:]):
+ (-[WebView _inFastImageScalingMode]):
+ * WebView/WebViewPrivate.h:
+
+2007-09-04 Darin Adler <darin@apple.com>
+
+ Reviewed by Hyatt.
+
+ * WebView/WebView.mm:
+ (-[WebView _loadBackForwardListFromOtherView:]): Added missing null check.
+ (-[WebView _setInitiatedDrag:]): Ditto.
+ (-[WebView _clearUndoRedoOperations]): Ditto.
+ (-[WebView encodeWithCoder:]): Ditto.
+ (-[WebView backForwardList]): Ditto.
+ (-[WebView setMaintainsBackForwardList:]): Ditto.
+
+2007-09-04 Tristan O'Tierney <tristan@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/5454935> Can't reply to this message in Mail -- -[DOMRange webArchive] is throwing an exception
+
+ * WebView/WebArchiver.mm:
+ (+[WebArchiver _archiveWithMarkupString:fromFrame:nodes:]):
+ Guard the creation of WebResource by ensuring that the passed in
+ responseURL is never nil.
+
+2007-09-03 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/5452164> Production build with in symbols directory has no debug info
+
+ Enable debug symbol generation on all build configurations. Production builds are stripped
+ of symbols by Xcode during deployment post-processing.
+
+ * Configurations/Base.xcconfig:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-09-02 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John Sullivan and Mark Rowe
+
+ Groundwork for support for monitoring IconDatabase in-memory statistics
+
+ * Misc/WebCoreStatistics.h:
+ * Misc/WebCoreStatistics.mm:
+ (+[WebCoreStatistics iconPageURLMappingCount]):
+ (+[WebCoreStatistics iconRetainedPageURLCount]):
+ (+[WebCoreStatistics iconRecordCount]):
+ (+[WebCoreStatistics iconsWithDataCount]):
+
+2007-09-01 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Sam.
+
+ <rdar://problem/5344848> IME is incorrectly used for key events when on non-editable regions
+
+ EditorClient::setInputMethodState stub
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::setInputMethodState):
+
+2007-08-30 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Tim.
+
+ <rdar://problem/5439953> REGRESSION: Cannot load feeds in widgets in Dashcode due to change in WebKit delegate methods
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _attachScriptDebugger]): Don't create the debugger object if the frame has not yet
+ created its script interpreter, to avoid premature dispatch of windowScriptObjectAvailable/Cleared
+ delegate methods. The script debugger will be created in any case when the window object does appear.
+
+2007-08-29 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - fix <rdar://problem/4582212> WebKit inappropriately adds +initialize to
+ NSPasteboard via a category, prevents AppKit initialize
+ http://bugs.webkit.org/show_bug.cgi?id=9417
+
+ * Misc/WebNSPasteboardExtras.h: Got rid of the global data objects and replaced
+ them with global functions.
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (initializePasteboardTypes): Changed the initialize method to be this function.
+ (WebURLPasteboardType): Added, calls the initialize function and then returns
+ the value of the global.
+ (WebURLNamePasteboardType): Ditto.
+ (+[NSPasteboard _web_writableTypesForURL]): Changed to call the new function instead
+ of getting at the global directly.
+ (+[NSPasteboard _web_dragTypesForURL]): Ditto.
+ (-[NSPasteboard _web_writeURL:andTitle:types:]): Ditto.
+ * WebCoreSupport/WebPasteboardHelper.mm:
+ (WebPasteboardHelper::urlFromPasteboard): Ditto.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _documentFragmentFromPasteboard:forType:inContext:subresources:]): Ditto.
+
+ * WebView/WebView.mm:
+ (+[WebView initialize]): Added a call to one of the functions to take advantage
+ of the side effect that initializes the globals; this is to help out old versions
+ of Safari.
+ (+[WebView URLTitleFromPasteboard:]): Changed to call the new function instead
+ of getting at the global directly.
+
+ * WebKit.exp: Add exports of the new functions.
+
+2007-08-29 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=15098
+ <rdar://problem/5440319> REGRESSION (9A530-9A534): Double scroll bar on pdfs
+
+ * WebCoreSupport/WebFrameLoaderClient.mm: (WebFrameLoaderClient::makeDocumentView):
+ Don't suppress scrollbars before the view creation if we're making the view for a non-html view
+
+ * WebView/WebFrameViewInternal.h: Make _scrollView return a WebDynamicScrollBarsView since so many clients were relying on it being that type anyway.
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _setDocumentView:]):
+ (-[WebFrameView _scrollView]):
+ (-[WebFrameView setAllowsScrolling:]):
+ (-[WebFrameView allowsScrolling]):
+ * WebView/WebView.mm:
+ (-[WebView setAlwaysShowVerticalScroller:]):
+ (-[WebView alwaysShowVerticalScroller]):
+ (-[WebView setAlwaysShowHorizontalScroller:]):
+ (-[WebView alwaysShowHorizontalScroller]):
+
+2007-08-29 David Hyatt <hyatt@apple.com>
+
+ The method that was swizzled to fix 5441281 does not exist on Tiger.
+ Tiger has to do a double swizzle instead (of resetCursorRects and NSCursor's
+ set method) in order to roughly achieve the same effect.
+
+ Reviewed by darin
+
+ * WebView/WebHTMLView.mm:
+ (resetCursorRects):
+ (setCursor):
+ (+[WebHTMLViewPrivate initialize]):
+
+2007-08-29 Anders Carlsson <andersca@apple.com>
+
+ Fix 64-bit build.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2007-08-29 David Hyatt <hyatt@apple.com>
+
+ Fix for 5441281, remove our dependency on cursor rects and drag margins
+ in AppKit for a large performance boost on the PLT and iBench.
+
+ Reviewed by darin
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView sendNullEvent]):
+ (-[WebBaseNetscapePluginView mouseEntered:]):
+ (-[WebBaseNetscapePluginView mouseExited:]):
+ (-[WebBaseNetscapePluginView stop]):
+ Clean up cursor setting from Netscape plugins. Don't unconditionally mutate
+ the cursor when a plugin stops.
+
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _setDocumentView:]):
+ Suppress the resetting of drag margins while the new document view is being
+ added to the view hierarchy.
+
+ * WebView/WebHTMLView.mm:
+ (-[NSWindow _web_borderView]):
+ Expose the border view of the NSWindow so that it can be hit tested.
+
+ (setCursorForMouseLocation):
+ Apply a method swizzle to override the private AppKit method, _setCursorForMouseLocation.
+ We have to do this to suppress the cursor rect invalidation handling from resetting
+ the cursor for no reason.
+
+ The swizzle will do a hit test and allow the cursor set to occur if the mouse ends up
+ being over a plugin or over a view other than a WebHTMLView.
+
+ (+[WebHTMLViewPrivate initialize]):
+ The swizzle for setCursorForMouseLocation is set up here.
+
+ (-[WebHTMLView _frameOrBoundsChanged]):
+ Add a 100ms delay to the fake mouse moved event that fires when the view moves
+ under the mouse (without the mouse moving). This happens on iBench when the
+ pages get scrolled. By adding a delay we ensure that even with the mouse inside
+ the window, we don't experience cursor thrashing when pages are updating and
+ scrolling rapidly.
+
+2007-08-28 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5424866> Bottom portion of any Web Clip widget appears transparent
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ Use the enum from FrameLoaderTypes.h.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::objectContentType):
+ Return ObjectContentNetscapePlugin and ObjectContentOtherPlugin depending on the plug-in type.
+
+2007-08-28 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ Fix fallout from the fix for <rdar://problem/5437983> (Loading history containing 100,000 entries adds 20s to Safari's startup)
+ in r25275. The array of entries for each day was being maintained in the reverse of the order that was expected.
+
+ * History/WebHistory.mm:
+ (-[WebHistoryPrivate insertItem:forDateKey:]): Maintain the array of entries in descending order.
+
+2007-08-28 Mark Rowe <mrowe@apple.com>
+
+ Fix the buildbot build.
+
+ * History/WebHistory.mm:
+ (timeIntervalForBeginningOfDay): Explicitly cast to silence compiler warning.
+
+2007-08-28 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Darin Adler.
+
+ <rdar://problem/5437983> Loading history containing 100,000 entries adds 20s to Safari's startup
+
+ Move WebHistoryItemPrivate from using a sorted array of NSCalendarDate's that map to a sorted array of arrays
+ of WebHistoryItem's over to using a HashMap of NSTimeIntervals and arrays of WebHistoryItems. NSTimeInterval
+ uses less memory and is substantially cheaper during comparisons than NSCalendarDate. The use of the HashMap
+ avoids the needs to repeatedly search within an array to locate the array that corresponds to the given days
+ history items.
+
+ The result of these changes is that loading 100,000 history items drops from around 25s to 1.6s. Loading
+ 100 items drops from 0.003s to 0.002s.
+
+ * History/WebHistory.mm:
+ (-[WebHistoryPrivate init]):
+ (-[WebHistoryPrivate dealloc]):
+ (timeIntervalForBeginningOfDay): Return the NSTimeInterval representing the beginning of the specified day.
+ (-[WebHistoryPrivate findKey:forDay:]):
+ (-[WebHistoryPrivate insertItem:forDateKey:]): Perform a binary search within the day's history items rather than a linear search.
+ (-[WebHistoryPrivate _removeItemFromDateCaches:]):
+ (-[WebHistoryPrivate _addItemToDateCaches:]):
+ (-[WebHistoryPrivate removeAllItems]):
+ (-[WebHistoryPrivate orderedLastVisitedDays]): Generate and cache the sorted NSArray of NSCalendarDate's exposed in the API.
+ This cache is invalidated by _removeItemFromDateCaches: and _addItemToDateCaches: when needed.
+ (-[WebHistoryPrivate orderedItemsLastVisitedOnDay:]):
+ (-[WebHistoryPrivate arrayRepresentation]):
+ (-[WebHistoryPrivate _loadHistoryGutsFromURL:savedItemsCount:collectDiscardedItemsInto:error:]): Use an autorelease pool to keep the
+ number of live autoreleased objects generated to a reasonable level.
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem initWithURLString:title:displayTitle:lastVisitedTimeInterval:]):
+ (-[WebHistoryItem initFromDictionaryRepresentation:]): Use the new HistoryItem constructor that accepts the alternate title
+ rather than setting it after construction. This prevents a modification notification from being sent for each WebHistoryItem that is loaded.
+ * History/WebHistoryItemInternal.h:
+ * History/WebHistoryPrivate.h:
+ * Misc/WebNSCalendarDateExtras.h: Removed as _webkit_compareDay: is no longer used.
+ * Misc/WebNSCalendarDateExtras.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-08-28 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5298296> XMLHttpRequest readyState 3 & responseText buffer issues
+
+ Expose WKSetNSURLRequestShouldContentSniff to WebCore.
+
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+
+2007-08-24 Kevin McCullough <kmccullough@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5437038> 1 credential object leaked for each call to credentialWithUser:password:persistence
+ - Use initWithUser instead of credentialWithUser because credentialWithUser leaks.
+
+ * Panels/WebAuthenticationPanel.m:
+ (-[WebAuthenticationPanel runAsModalDialogWithChallenge:]):
+ (-[WebAuthenticationPanel sheetDidEnd:returnCode:contextInfo:]):
+
+2007-08-24 Adele Peterson <adele@apple.com>
+
+ Fix by Darin, reviewed by Adele.
+
+ Fix for <rdar://problem/5433422> Upon quitting, WebKit loads the WebPlugin shared database and immediately closes it
+
+ * Plugins/WebPluginDatabase.h: Added closeSharedDatabase, which won't create a new database if we're just trying to close it.
+ * Plugins/WebPluginDatabase.m: (+[WebPluginDatabase closeSharedDatabase]): Added.
+ * WebView/WebView.mm:
+ (-[WebView _close]): Call closeSharedDatabase.
+ (+[WebView _applicationWillTerminate]): Call closeSharedDatabase.
+
+2007-08-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/5410937> HIWebView in SimpleCarbonWeb doesn't seem to be getting adequate invalidation when window is resized
+
+ This is a more localized fix for yesterday's change. Now explicitly call _web_layoutIfNeededRecursive inside the
+ HIWebView Draw() function. Adds a FIXME to explain that we need to do layout before Carbon has decided what regions to draw.
+ Doing layout in Draw() will potentially cause drawing to happen in two passes, but this has always been a problem in Carbon.
+
+ * Carbon/HIWebView.m:
+ (Draw): Call _web_layoutIfNeededRecursive on the main WebHTMLView.
+ (SetFocusPart): Fix to work in ObjC++ (now that HIWebView.m is treated as a ObjC++ file.)
+ * WebView/WebView.mm: Removes the 4 displayIfNeeded methods from yesterday's change.
+ * WebKit.xcodeproj/project.pbxproj: Force the file type of HIWebView.m to ObjC++ so WebHTMLViewInternal.h can be included.
+
+2007-08-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Dave Hyatt.
+
+ <rdar://problem/5410937> HIWebView in SimpleCarbonWeb doesn't seem to be getting adequate invalidation when window is resized
+
+ The Carbon HIWebView was relying on layout happening when displayIfNeededInRect: was called on the WebView.
+ This would happen on Tiger because _recursiveDisplayRectIfNeededIgnoringOpacity: would always do a layout if needed.
+ Doing a layout in _recursiveDisplayRectIfNeededIgnoringOpacity was removed in Leopard in favor of viewWillDraw, and
+ the fact that adding new dirty rects inside _recursiveDisplayRectIfNeededIgnoringOpacity on Leopard will not
+ cause a drawRect in the same display loop.
+
+ So any client on Leopard calling displayIfNeeded* on the WebView would get a layout and any new dirty rects. So
+ _web_layoutIfNeededRecursive needs to be called on the main frame's WebHTMLView to make sure we layout and
+ display anything that is really needed.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _layoutIfNeeded]):
+ (-[WebHTMLView _web_layoutIfNeededRecursive]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebView.mm:
+ (-[WebView displayIfNeeded]): Call _web_layoutIfNeededRecursive on the main WebHTMLView.
+ (-[WebView displayIfNeededIgnoringOpacity]): Ditto.
+ (-[WebView displayIfNeededInRect:]): Ditto.
+ (-[WebView displayIfNeededInRectIgnoringOpacity:]): Ditto.
+
+2007-08-22 Timothy Hatcher <timothy@apple.com>
+
+ Rolling out r25102 for <rdar://problem/5410937> until
+ <rdar://problem/5429920> is resolved.
+
+ * Carbon/CarbonUtils.m:
+ (WebInitForCarbon):
+ (PoolCleaner):
+ * Carbon/CarbonWindowAdapter.h:
+ * Carbon/CarbonWindowAdapter.m:
+ * Carbon/CarbonWindowContentView.h:
+ * Carbon/CarbonWindowContentView.m:
+ * Carbon/CarbonWindowFrame.h:
+ * Carbon/CarbonWindowFrame.m:
+ * Carbon/HIViewAdapter.h:
+ * Carbon/HIViewAdapter.m:
+ * Carbon/HIWebView.h:
+ * Carbon/HIWebView.m:
+
+2007-08-20 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adam Roben
+
+ WebKit part of fix for:
+ <rdar://problem/5417777> WebKit focus ring color no longer matches system focus rings
+
+ * Misc/WebNSAttributedStringExtras.mm:
+ now includes <WebCore/ColorMac.h> to account for moved declaration
+ * WebView/WebFrame.mm:
+ ditto
+
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.mm:
+ (+[WebView _setUsesTestModeFocusRingColor:]):
+ new SPI, calls through to new WebCore function. This is used by DumpRenderTree to make sure the
+ focus ring color is always the same when performing layout tests, regardless of OS X version.
+ (+[WebView _usesTestModeFocusRingColor]):
+ new SPI, calls through to new WebCore function
+
+2007-08-20 Antti Koivisto <antti@apple.com>
+
+ Reviewed by John.
+
+ Fix <rdar://problem/5378390>
+ Crash at Range::startContainer() when creating multiple ToDos on the same line
+
+ Null check range.
+
+ No layout test, this only happens with ObjC API.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _expandSelectionToGranularity:]):
+
+2007-08-20 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed, fix for crash on launch bug in last patch.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView setDataSource:]): Remove an assertion, fix code to work right in the
+ face of that condition.
+
+2007-08-18 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - fixed <rdar://problem/5198272> REGRESSION: PLT 1.5% slower due to r21367 (change to start frames with empty documents)
+
+ There were three main cuases of extra time due to creating the initial empty document:
+
+ 1) Creating an extra WebHTMLView and swapping it for a new one for each frame created.
+ 2) Parsing the minimal markup for the initial document's contents.
+ 3) Clearing the Window object an extra time and dispatching the corresponding delegate method.
+
+ The WebKit part of the fixes addresses 1.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::makeDocumentView): When switching from the initial
+ empty document to the first real document, reuse the WebHTMLView.
+
+ It might actually be a significant performance improvement to always
+ reuse the WebHTMLView, but that is a much riskier change and not
+ needed to fix the regression right now.
+
+2007-08-17 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - WebKit part of fix to scrollbar suppression hack for Leopard
+
+ * WebView/WebDynamicScrollBarsView.m:
+ (-[WebDynamicScrollBarsView reflectScrolledClipView:]): Don't call the superclass method
+ when scrollbars are suppressed.
+ (-[WebDynamicScrollBarsView setScrollBarsSuppressed:repaintOnUnsuppress:]): Instead call it
+ here, when unsuppressing.
+
+2007-08-17 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - fix <rdar://problem/5414518> Use root URL as origin URL when quarantining downloads
+
+ * WebCoreSupport/WebFrameLoaderClient.mm: (WebFrameLoaderClient::setOriginalURLForDownload):
+ Extract only the scheme and host name and make the originating URL from that.
+
+ * WebKit/StringsNotToBeLocalized.txt: Updated for recent changes.
+
+2007-08-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5398301> Xcode threw mutation exception while enumerating subviews (GC only)
+
+ I was never able to reproduce this exception. But there can be cases where layout will
+ trigger JavaScript or plugin code that can modify the WebView view hierarchy during a
+ recursive enumeration of all the subviews.
+
+ This patch does two things:
+ 1) Adds a check in debug builds that will LOG when any view is added or removed during layout.
+ Noting that added views will not recieve layout this round and might paint without first recieving layout.
+
+ 2) Recursivly builds up an array of descendant WebHTMLViews before calling layout on them.
+ This matches the behavior of makeObjectsPerformSelector: in the non-GC case (making a copy
+ before enumerating.)
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _web_setPrintingModeRecursive]): Use _web_addDescendantWebHTMLViewsToArray to build up an array
+ of WebHTMLViews to enumerate.
+ (-[WebHTMLView _web_clearPrintingModeRecursive]): Ditto.
+ (-[WebHTMLView _web_setPrintingModeRecursiveAndAdjustViewSize]): Ditto.
+ (-[WebHTMLView _web_layoutIfNeededRecursive]): Ditto.
+ (-[WebHTMLView _layoutIfNeeded]): Moved to WebHTMLViewFileInternal category.
+ (-[WebHTMLView didAddSubview:]): LOG in debug builds.
+ (-[WebHTMLView willRemoveSubview:]): Ditto.
+ (-[NSView _web_addDescendantWebHTMLViewsToArray:]): Recursivly build an array of descendant WebHTMLViews.
+ * WebView/WebHTMLViewInternal.h: Added a BOOL in WebHTMLViewPrivate to track subview changes (debug only.)
+
+2007-08-17 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Dave Hyatt.
+
+ <rdar://problem/5379040>
+ REGRESSION (Tiger-Leopard): ADOBE: Safari calls NPP_SetWindow with bad values sometimes
+
+ Pass the right size when creating the views.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge viewForPluginWithFrame:URL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::createPlugin):
+
+2007-08-13 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Dave Hyatt.
+
+ WebKit changes to support new cache eviction model in WebCore.
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]): Modified to reflect new API in WebCore.
+ * WebView/WebView.mm:
+ (+[WebView _initializeCacheSizesIfNecessary]): Slightly increased cache
+ size on low memory systems to avoid affecting the PLT for now.
+
+2007-08-15 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5410937> HIWebView in SimpleCarbonWeb doesn't seem to be getting adequate invalidation when window is resized
+
+ HIWebViewCreate now just returns a HIViewRef created with HICocoaViewCreate. This eliminates lots of old code and
+ makes HIWebView a better citizen starting with Leopard. The old code paths are still needed for Tiger, so now
+ most of the files in the WebKit/Carbon directory are #ifdef BUILDING_ON_TIGER.
+
+ The Tiger code is unchanged and dosen't exhibit the invalidation problem when the window resizes.
+
+ * Carbon/CarbonUtils.m:
+ (WebInitForCarbon): #ifdef BUILDING_ON_TIGER portions of this code that is not needed on Leopard.
+ * Carbon/CarbonWindowAdapter.h: #ifdef BUILDING_ON_TIGER
+ * Carbon/CarbonWindowAdapter.m: Ditto.
+ * Carbon/CarbonWindowContentView.h: Ditto.
+ * Carbon/CarbonWindowContentView.m: Ditto.
+ * Carbon/CarbonWindowFrame.h: Ditto.
+ * Carbon/CarbonWindowFrame.m: Ditto.
+ * Carbon/HIViewAdapter.h: Ditto.
+ * Carbon/HIViewAdapter.m: Ditto.
+ * Carbon/HIWebView.h: Consolidate two #ifdef __OBJC__ blocks into one.
+ * Carbon/HIWebView.m: Implement Leopard specific HIWebViewCreate, HIWebViewCreateWithClass and HIWebViewGetWebView.
+ (HIWebViewCreate): Call HIWebViewCreateWithClass passing [WebView class].
+ (HIWebViewCreateWithClass): Call HICocoaViewCreate with an instance of the class passed in.
+ (HIWebViewGetWebView): Call HICocoaViewGetView.
+
+2007-08-14 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin, John, Maciej, Oliver, and Tim
+
+ <rdar://problem/5394708> - Crash on launch with corrupt icon database
+
+ Expose some new SPI to help recover from this case should it happen again
+
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase init]): Use the new _databaseDirectory to determine where to open the database on disk
+ (+[WebIconDatabase _checkIntegrityBeforeOpening]): Tell the icon database to check integrity when it opens
+ (-[WebIconDatabase _databaseDirectory]): Moved the database-directory-determining logic here as it's now used in two places
+ * Misc/WebIconDatabasePrivate.h: Added _checkIntegrityBeforeOpening SPI for clients to give hints about when the
+ integrity check should run
+
+2007-08-12 Alexey Proskuryakov <ap@webkit.org>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=4648
+ Shockwave unable to load GZip'd text resources when server sends Content-Length header
+
+ * Plugins/WebBaseNetscapePluginStream.mm:
+ (-[WebBaseNetscapePluginStream startStreamWithResponse:]): Don't trust
+ -[NSURLResponse expectedContentLength] if Content-Encoding is not identity.
+
+2007-08-10 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ <rdar://problem/5403302> HIWebView.h should be #ifdefed out for 64-bit
+
+ * Carbon/HIWebView.h: #ifdef out the header in 64-bit. Adds a comment about 32-bit only.
+ * Carbon/CarbonUtils.h: Ditto.
+
+2007-08-10 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/5394449> Stop using some Carbon UI APIs for 64 bit
+
+ Disable NPObject use in 64-bit on Mac OS X. Also generate the 64-bit export file.
+
+ * Configurations/WebKit.xcconfig: Point to the generated 64-bit export file.
+ * Plugins/WebBasePluginPackage.h:
+ * Plugins/npfunctions.h: #ifdef out this header in 64-bit on Mac OS X.
+ * WebKit.LP64.exp: Removed.
+ * WebKit.xcodeproj/project.pbxproj: Generate the the 64-bit export file.
+ * WebKitPrefix.h: Define WTF_USE_NPOBJECT.
+
+2007-08-10 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/5390568>
+ REGRESSION: -[WebFrame loadHTMLString:baseURL:] leaks the data source
+
+ If the identifier is not in the map, just bail out instead of asserting. This is a better fix for
+ <rdar://problem/5133420> because WebCore shouldn't have to worry about the lifetime of WebKit objects.
+
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::decreaseLoadCount):
+
+2007-08-10 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Darin.
+
+ Fixed <rdar://problem/5000470> REGRESSION: ATOK IM: reconvert returns incorrect symbol due to inconsistent range domains in TSM by working around <rdar://problem/5400551> [NSAttributedString(WebKitExtras) _web_attributedStringFromRange:] adds whitespace to the requested range
+
+ We truncate the returned string to the expected length.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView attributedSubstringFromRange:]):
+
+2007-08-09 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Antti.
+
+ <rdar://problem/5400709> Versioning in debug and release builds should include minor and tiny version before +
+
+ * Configurations/Version.xcconfig:
+ * WebKit.xcodeproj/project.pbxproj: Add a shell script phase to make to dependency between
+ Version.xcconfig and Info.plist explicit to Xcode.
+
+2007-08-08 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Anders Carlsson.
+
+ Fixed: <rdar://problem/5394449> Stop using some Carbon UI APIs for 64 bit
+
+ #ifdef'd out Netscape style plug-ins on 64-bit because Mac OS X doesn't support 64-bit Carbon UI.
+
+ * Plugins/WebBaseNetscapePluginStream.h:
+ * Plugins/WebBaseNetscapePluginStream.mm:
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (+[WebBaseNetscapePluginView getCarbonEvent:]):
+ (TSMEventHandler):
+ * Plugins/WebBaseNetscapePluginViewInternal.h:
+ * Plugins/WebBaseNetscapePluginViewPrivate.h:
+ * Plugins/WebBasePluginPackage.m:
+ (+[WebBasePluginPackage pluginWithPath:]):
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.mm:
+ * Plugins/WebNetscapePluginPackage.h:
+ * Plugins/WebNetscapePluginPackage.m:
+ * Plugins/WebNetscapePluginStream.h:
+ * Plugins/WebNetscapePluginStream.mm:
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase pluginForKey:withEnumeratorSelector:]):
+ * Plugins/npapi.m:
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ * WebView/WebFrame.mm:
+ * WebView/WebFramePrivate.h:
+ * WebView/WebHTMLView.mm:
+ (-[NSArray _web_makePluginViewsPerformSelector:withObject:]):
+ * WebView/WebHTMLViewInternal.h:
+
+2007-08-07 David Hyatt <hyatt@apple.com>
+
+ Fix a botched backout of the Quicktime plugin clipping fix that broke Java. The plugin view should not
+ be set to autosize with the parent view. Also, cleanup of script objects was removed accidentally as
+ well.
+
+ Reviewed by olliej
+
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController destroyPlugin:]):
+ (-[WebPluginController destroyAllPlugins]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge pluginViewWithPackage:attributeNames:attributeValues:baseURL:DOMElement:loadManually:]):
+
+2007-08-03 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Oliver
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=14824 and <rdar://problem/5372989>
+
+ When unregistering a MIMEType, remove it from the WebCore registry unconditionally
+ When registrying a MIMEType whose view class is WebHTMLView, add it to the WebCore registry
+
+ * WebView/WebView.mm:
+ (+[WebView _unregisterViewClassAndRepresentationClassForMIMEType:]):
+ (+[WebView _registerViewClass:representationClass:forURLScheme:]):
+ (+[WebView registerViewClass:representationClass:forMIMEType:]):
+
+2007-08-03 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ Correct the bundle version check to work in Debug and Release builds too.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-08-02 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim
+
+ <rdar://problem/5381463> - setMIMETypesShownAsHTML mutates while enumerating
+
+ * WebView/WebView.mm:
+ (+[WebView setMIMETypesShownAsHTML:]): Copy the dictionary before we work with it.
+
+2007-08-02 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Kevin McCullough.
+
+ fixed <rdar://problem/5310312> REGRESSION: javascript is mis-escaped at http://labs.zarate.org/passwd causing bookmarklet to break
+
+ * Misc/WebNSURLExtras.mm:
+ (+[NSURL _web_URLWithUserTypedString:relativeToURL:]):
+ (-[NSURL _web_userVisibleString]):
+ (-[NSURL _web_URLWithLowercasedScheme]):
+ (-[NSURL _web_dataForURLComponentType:]):
+ These 4 changes are just casting changes.
+
+ (-[NSString _webkit_stringByReplacingValidPercentEscapes]):
+ This change replaces the call to an NSURL method with a webcore one that doesn't abort the escaping effort once an illegal character is encountered.
+
+2007-08-01 Anders Carlsson <andersca@apple.com>
+
+ Fix build.
+
+ * Misc/WebNSURLExtras.mm:
+ (+[NSURL _web_URLWithUserTypedString:relativeToURL:]):
+ (-[NSURL _web_userVisibleString]):
+ (-[NSURL _web_URLWithLowercasedScheme]):
+ (-[NSURL _web_dataForURLComponentType:]):
+
+2007-08-01 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by .
+
+ Making WebNSURLExtras objc++
+
+ * Misc/WebNSURLExtras.m: Removed.
+ * Misc/WebNSURLExtras.mm: Copied from WebKit/Misc/WebNSURLExtras.m.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-08-01 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders Carlsson and Kevin Decker.
+
+ - fix <rdar://problem/5377432> Removal of MakeDataExecutable from 64-bit breaks WebKit build
+
+ The trick was to ifdef out more of the code that's only needed to support CFM, which exists
+ only for 32-bit PowerPC.
+
+ * Plugins/WebNetscapePluginPackage.h: Define a SUPPORT_CFM symbol in this internal header when
+ we support CFM. We support it only on 32-bit PowerPC. Only define the isBundle, isCFM, and
+ connID fields when SUPPORT_CFM is on. Also use ResFileRefNum instead of SInt16.
+ * Plugins/WebNetscapePluginPackage.m: Only compile the function pointer and transition vector
+ functions when SUPPORT_CFM is on.
+ (-[WebNetscapePluginPackage openResourceFile]): Put the non-bundle case inside a SUPPORT_CFM
+ ifdef, since all non-CFM plug-ins are bundles.
+ (-[WebNetscapePluginPackage closeResourceFile:]): Ditto.
+ (-[WebNetscapePluginPackage _initWithPath:]): Use SUPPORT_CFM to compile out the code for
+ non-bundle and bundle-based CFM plug-ins, and code that sets isBundle and isCFM.
+ (-[WebNetscapePluginPackage executableType]): Put the CFM case inside SUPPORT_CFM.
+ (-[WebNetscapePluginPackage load]): Put the non-bundle and CFM cases inside SUPPORT_CFM.
+ There was a bit of dead code here.
+ (-[WebNetscapePluginPackage _unloadWithShutdown:]): Put the non-bundle case inside
+ SUPPORT_CFM.
+
+2007-07-31 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Oliver and Beth.
+
+ <rdar://problem/5211271> ADOBE Leopard 9A410: At the first Launching InDesign after deactivate, EULA page gets blanked.
+
+ Check for more Adobe applications that need the frame reload quirk. Also cache the answer
+ so the version check dosen't happen more than once.
+
+ * WebView/WebView.mm:
+ (-[WebView _needsAdobeFrameReloadingQuirk]):
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-07-30 Adele Peterson <adele@apple.com>
+
+ Reviewed by Oliver.
+
+ Fix for <rdar://problem/5308020> REGRESSION: Command-N with Dvorak-Qwerty keyboard layout stopped working inside web page text fields
+
+ * WebView/WebHTMLView.mm: (-[WebHTMLView _handleStyleKeyEquivalent:]):
+ The input method may have modified the character we get, so don't use charactersIgnoringModifiers to interpret the character we get.
+
+2007-07-30 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - fixed <rdar://problem/5216176> Need WebKit SPI to allow clients using embedded WebViews to avoid
+ clipping ends of some printed pages
+
+ This provides Mail, and other clients that print views that embed WebViews, a way to ensure that
+ the HTML is laid out for printing before pagination occurs.
+
+ * WebView/WebHTMLViewPrivate.h:
+ new SPI method -_layoutForPrinting
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _web_setPrintingModeRecursiveAndAdjustViewSize]):
+ new method, just like existing _web_setPrintingModeRecursive except passes YES for adjustViewSize
+ (-[WebHTMLView _layoutForPrinting]):
+ new SPI method, sets printing mode temporarily to adjust the view size for printing
+ (-[NSView _web_setPrintingModeRecursiveAndAdjustViewSize]):
+ new helper method to do the recursion
+
+2007-07-30 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for <rdar://problem/5367919> A crash occurs at WebCore::Frame::isFrameSet() when attempting to print a iframe before it loads at http://www.monster.com/
+
+ * WebView/WebHTMLView.mm: (-[WebHTMLView knowsPageRange:]): Nil check for frame.
+
+2007-07-30 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5370710>
+ REGRESSION: After switching from Bookmark view, the Find Banner won't appear while displaying a PDF file
+
+ Implement hasHTMLView.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::hasHTMLView):
+
+2007-07-30 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by Tristan.
+
+ <rdar://problem/5098931> Attachments are lost when they are moved into a ToDo after a delete
+
+ Mail needs to be asked if it is OK to do the content movement that happens
+ after a deleting in a situation like this one:
+ <div contenteditable="plaintext-only">foo</div><div>^bar</div>
+ so that they can prevent the move or so that they can save content that
+ will be stripped by the move. This could have been done with shouldInsertNode
+ and a new WebViewInsertAction for "moves", but WebKit clients like Mail and
+ DashCode think that a shouldInsert* means that the user pasted something and
+ perform actions only appropriate for pastes. This change is less risky because
+ it won't require those clients to change their code.
+
+ * DefaultDelegates/WebDefaultEditingDelegate.m:
+ (-[WebDefaultEditingDelegate webView:shouldMoveRangeAfterDelete:replacingRange:]):
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::shouldMoveRangeAfterDelete):
+ * WebView/WebEditingDelegatePrivate.h:
+
+2007-07-29 Adele Peterson <adele@apple.com>
+
+ Reviewed by John.
+
+ WebKit part of fix for <rdar://problem/5102522> REGRESSION: Can't tab to webview that doesn't have editable content
+
+ * WebView/WebHTMLView.mm: (-[WebHTMLView becomeFirstResponder]): Call new setInitialFocus method instead of advanceFocus.
+
+2007-07-27 Darin Adler <darin@apple.com>
+
+ - fix build
+
+ * WebKitPrefix.h: Removed the USING_WEBCORE_XXX definitions.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView delete:]): Fixed this to use WebCore again; I accidentally revived a dead
+ code path that didn't work in the last patch!
+ (-[WebHTMLView deleteToMark:]): Ditto.
+ (-[WebHTMLView copy:]): Removed the unused side of the ifdef.
+ (-[WebHTMLView cut:]): Ditto.
+ (-[WebHTMLView paste:]): Ditto.
+
+2007-07-27 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher and Oliver Hunt.
+
+ - fix <rdar://problem/5355815> webView:doCommandBySelector: isn't getting called for copy:
+
+ Added code so that webView:doCommandBySelector: is called for every command.
+
+ * WebView/WebHTMLView.mm: Made 44 of the commands use the WEBCORE_COMMAND macro instead
+ of being handwritten. For all the others, added invocation of COMMAND_PROLOGUE macro at
+ the start of the command.
+ (-[WebHTMLView callDelegateDoCommandBySelectorIfNeeded:]): Added.
+ (-[WebHTMLView callWebCoreCommand:]): Added.
+ (-[WebHTMLView delete:]): Removed unused code path -- easy to bring back some day, but
+ we don't need it compiled in.
+ (-[WebHTMLView deleteBackwardByDecomposingPreviousCharacter:]): Changed so this doesn't
+ call deleteBackward: any more so we don't call the delegate two times.
+ (-[WebHTMLView deleteToMark:]): Changed so this doesn't call delete: any more so we don't
+ call the delegate two times.
+ (-[WebHTMLView selectToMark:]): Changed so this doesn't call setMark: any more so we don't
+ call the delegate two times.
+ (-[WebHTMLView doCommandBySelector:]): Added code to set the private variable
+ selectorForDoCommandBySelector. This allows callDelegateDoCommandBySelectorIfNeeded to
+ detect that we've already called the delegate and avoids calling it twice.
+
+ * WebView/WebHTMLViewInternal.h: Added the selectorForDoCommandBySelector field.
+
+2007-07-26 Alexey Proskuryakov <ap@webkit.org>
+
+ Reviewed by Oliver.
+
+ http://bugs.webkit.org/show_bug.cgi?id=14733
+ Add a logging channel for text input
+ <rdar://problem/5364667>
+
+ * Misc/WebKitLogging.h:
+ * Misc/WebKitLogging.m:
+ (WebKitInitializeLoggingChannelsIfNecessary):
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView validAttributesForMarkedText]):
+ (-[WebHTMLView textStorage]):
+ (-[WebHTMLView characterIndexForPoint:]):
+ (-[WebHTMLView firstRectForCharacterRange:]):
+ (-[WebHTMLView selectedRange]):
+ (-[WebHTMLView markedRange]):
+ (-[WebHTMLView attributedSubstringFromRange:]):
+ (-[WebHTMLView hasMarkedText]):
+ (-[WebHTMLView unmarkText]):
+ (-[WebHTMLView setMarkedText:selectedRange:]):
+ (-[WebHTMLView doCommandBySelector:]):
+ (-[WebHTMLView insertText:]):
+
+2007-07-26 Darin Adler <darin@apple.com>
+
+ - fix Tiger build
+
+ * Misc/WebTypesInternal.h: For use inside the library, use NSInteger and
+ NSUInteger, just like on Leopard. WebNSInteger and WebNSUInteger are still
+ present, but they are used in public and private headers only.
+
+ * Carbon/CarbonWindowAdapter.m:
+ * Carbon/CarbonWindowFrame.m:
+ * DefaultDelegates/WebScriptDebugServer.m:
+ * History/WebBackForwardList.mm:
+ * Misc/WebDownload.m:
+ * Misc/WebSearchableTextView.m:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ * WebView/WebHTMLView.mm:
+ * WebView/WebPDFView.mm:
+ * WebView/WebView.mm:
+ * WebView/WebViewInternal.h:
+ Update all implementation files and internal headers to use NSInteger and
+ NSUInteger rather than WebNSInteger and WebNSUInteger.
+
+2007-07-26 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/5362989> Searching a pdf in some modes shows hilights for all instances
+ of the word, even those not on the current page
+
+ It turns out that there were three different issues here, all contributing to incorrect display
+ of multiple matches for PDF pages in certain display modes. (1) in non-continuous display modes,
+ we weren't updating the match rects when the displayed page is changed with page up/down (e.g.);
+ (2) the mechanism to update the match rects on scrolling was busted except for the first scroll
+ away from 0,0; (3) the PDFKit API returns selection bounds for non-displayed pages in non-continuous
+ modes just as if they were the displayed pages. This patch fixes all three issues.
+
+ * WebView/WebPDFView.h:
+ made ivar name even longer
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView setPDFDocument:]):
+ updated for ivar name change
+ (-[WebPDFView viewDidMoveToWindow]):
+ observe page-change notifications as well as the others; this is necessary because in the
+ non-continuous modes the view can be completely updated without any scrolling involved (problem 1)
+ (-[WebPDFView viewWillMoveToWindow:]):
+ stop observing page-change notifications
+ (-[WebPDFView rectsForTextMatches]):
+ skip any pages that aren't visible; this avoids treating matches on non-displayed non-continous
+ modes as if they were on the displayed page (problem 3)
+ (-[WebPDFView _PDFDocumentViewMightHaveScrolled:]):
+ after checking whether scroll position has changed since we last checked it, remember the new
+ one (d'oh!) (problem 2)
+
+ (-[WebPDFView _scaleOrDisplayModeOrPageChanged:]):
+ renamed to include page changes
+
+ (-[WebPDFView _visiblePDFPages]):
+ new method, returns the set of pages that are at least partly visible
+
+2007-07-24 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam and Justin.
+
+ <rdar://problem/5141779> WebView editableDOMRangeForPoint: & moveDragCaretToPoint: returns last position in DOMText range
+
+ editableDOMRangeForPoint:, moveDragCaretToPoint:, and removeDragCaret now call directly into
+ WebCore without relying on bridge look up through the now removed _bridgeAtPoint:.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebView.mm:
+ (-[WebView moveDragCaretToPoint:]):
+ (-[WebView removeDragCaret]):
+ (-[WebView editableDOMRangeForPoint:]):
+
+2007-07-24 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Anders.
+
+ <rdar://problem/4699455> REGRESSION (Safari 2->Safari 3): Adobe Reader 7.0.8 plug-in doesn't work
+
+ * Plugins/WebNetscapePluginEmbeddedView.h: Added a #define that renames this class to "WebNetscapePluginDocumentView"
+ This is necessary because the Adobe 7.x Acrobat plug-in has a hard coded check for a view named "WebNetscapePluginDocumentView"
+ and will not function correctly if it doesn't find a view in the hierarchy without the old class name.
+
+2007-07-24 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Antti.
+
+ <rdar://problem/5356666> NSMenuItem's seen leaking on buildbot
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::contextMenuItemSelected): Release platformItem as we were transferred its ownership by releasePlatformDescription.
+
+2007-07-23 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Darin.
+
+ We have to be able to support insertText: followed by doCommandBySelector: in
+ order to support the 2- and 3-Set Korean and RuSwitcher IMs at least.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView insertText:]):
+
+2007-07-23 Alice Liu <alice.liu@apple.com>
+
+ Reverting change 24535 now that a solution has been found that doesn't
+ involve exposing an interface unnecessarily.
+
+ * WebView/WebHTMLView.mm:
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-07-23 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ Expose [WebHTMLView hasMarkedText] to
+ fix <rdar://problem/4830074> autocomplete breaks Japanese typing
+
+ * WebView/WebHTMLView.mm:
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-07-22 Darin Adler <darin@apple.com>
+
+ * StringsNotToBeLocalized.txt: Updated for recent changes.
+
+2007-07-21 Adam Roben <aroben@apple.com>
+
+ Fix REGRESSION: Right-click/control-click broken
+
+ http://bugs.webkit.org/show_bug.cgi?id=14658
+ <rdar://problem/5346830>
+
+ Reviewed by Mitz.
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusToSendToOldClients): Update defaultItemsCount after removing
+ items from the defaultItems array.
+
+2007-07-20 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adele.
+
+ <rdar://problem/5319438> REGRESSION: Cannot paste into an active inline input area (14522)
+ http://bugs.webkit.org/show_bug.cgi?id=14522
+
+ AppKit sends noop: to -[WebHTMLView doCommandBySelector:] when an IM does not handle event,
+ we now check this as it is necessary to work around some IMs that do send messages
+ (such as insertText: rather than unmarkText: to confirm a composition)
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]):
+ (-[WebHTMLView doCommandBySelector:]):
+ * WebView/WebHTMLViewInternal.h:
+
+2007-07-20 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adele and Andersca
+
+ <rdar://problem/5336105> - WebBackForwardList created from scratch is unusable (always leads to crash)
+
+ * History/WebBackForwardList.mm:
+ (-[WebBackForwardList init]): Have a default initializer that uses an empty BackFowardList not associated with a page.
+
+ * WebView/WebFrame.mm:
+ (kit): For clarity's sake, this should return nil, not 0
+
+2007-07-20 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5109817> Ctrl-click on word in non-editable text doesn't select it
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm: Removed the method
+ for enabling/disabling word selection on right click.
+ * WebView/WebView.mm: Ditto.
+ * WebView/WebViewPrivate.h: Removed the getter/setter entirely,
+ it was in a private Category for Mail, but wasn't used by Mail
+ on Tiger or Leopard, they apparently implement word selection on
+ their own.
+
+2007-07-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5199812> WebView needs to adopt viewWillDraw (moving off of _propagateDirtyRectsToOpaqueAncestors)
+ <rdar://problem/5017301> REGRESSION: Scroller in Widget Manager splits down the middle while scrolling
+
+ On Leopard _propagateDirtyRectsToOpaqueAncestors is no longer called by AppKit. Also marking new dirty rects
+ underneath _recursiveDisplayRectIfNeededIgnoringOpacity will wait until the next runloop to draw them,
+ causing rendering to happen in two steps instead of one as WebCore expected.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _topHTMLView]): Move to the file internal category so we can use it in viewWillDraw.
+ (-[WebHTMLView _isTopHTMLView]): Ditto.
+ (-[WebHTMLView _propagateDirtyRectsToOpaqueAncestors]): #ifdef for Tiger only.
+ (-[WebHTMLView viewWillDraw]): Do a recursive layout if this is the top WebHTMLView.
+ (-[WebHTMLView _recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]):
+ Don't do layout here on Leopard since viewWillDraw handled it.
+ (-[WebHTMLView _recursiveDisplayAllDirtyWithLockFocus:visRect:]): Ditto.
+
+2007-07-20 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Tim and Geoff.
+
+ Fix for <rdar://problem/5346855> Mail crashes at
+ WebCore::RenderTableSection:paint + 846 when attempting to display
+ a HTML based message
+
+ After reapplying styles, the RenderView needs layout. However,
+ layoutToMinimumPageWidth:maximumPageWidth:adjustingViewSize used to
+ return early if the WebHTMLView itself does not need layout.
+ Because the WebHTMLView is not necessarily in synch with the
+ RenderTree, returning early here can get us into a bad situation
+ where we paint before laying out the Render Tree. This patch checks
+ both the WebHTMLView and the bridge (which checks the RenderView,
+ etc), so that we do not return early without laying out the Render
+ Tree.
+
+ Some day, we should phase out WebHTMLView keeping track of
+ needsLayout at all. But that is a bit beyond the scope of this fix.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView layoutToMinimumPageWidth:maximumPageWidth:adjustingViewSize:]):
+
+2007-07-20 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin Adler and David Harrison
+
+ - fixed <rdar://problem/5307075> REGRESSION: Bottom of some printed pages are truncated
+
+ The "avoid orphan" code I added a year ago was causing the page to be imaged to a larger
+ height (good), but not shrinking everything to compensate (bad). Bad one-year-ago me!
+
+ * WebView/WebHTMLViewInternal.h:
+ added avoidingPrintOrphan boolean
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _setPrinting:minimumPageWidth:maximumPageWidth:adjustViewSize:]):
+ clear _private->avoidingPrintOrphan when clearing _private->printing
+ (-[WebHTMLView _scaleFactorForPrintOperation:]):
+ take _private->avoidingPrintOrphan into account when computing the scale factor
+ (-[WebHTMLView knowsPageRange:]):
+ set _private->avoidingPrintOrphan when we're shrinking to avoid an orphan
+
+2007-07-19 Adam Roben <aroben@apple.com>
+
+ Fix <rdar://problem/5344972> REGRESSION: A error dialog occurs when
+ attempting to ctrl-click in a iChat message window (webview)
+
+ Reviewed by Oliver.
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusToSendToOldClients): Don't check for the Inspect Element item
+ if we have fewer than 2 items.
+
+2007-07-18 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Dave Hyatt.
+
+ <rdar://problem/5345099>
+
+ Reduced default WebCore cache size from 32 MB to 23 MB on systems below
+ 512 MB RAM. This improves RPRVT usage in the Safari pageout test by
+ ~10% on a system with 384 MB RAM.
+
+ At 23 MB, no extra resources are evicted from the cache during a PLT
+ run, so this is a safe change PLT-wise. 23 MB is also seems to be a
+ generous number in real world usage.
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+
+2007-07-18 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/5341133> REGRESSION (Safari 2->Safari 3): DjVu plug-in doesn't load in Safari 3
+
+ The DjVu plug-in uses the size of the passed in NPNetscapeFuncs struct to copy it over to a NPNetscapeFuncs struct
+ whose size was determined when DjVu was compiled. This means that when we add extra functions to the vtable,
+ DjVu will segfault copying it into the (too small) destination struct.
+
+ Fix this by special-casing the DjVu plug-in and setting the NPNetscapeFuncs size to be the same size as what DjVu expects.
+
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage _applyDjVuWorkaround]):
+ (-[WebNetscapePluginPackage load]):
+
+2007-07-18 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/5343767> Should have a way to disable the Web Inspector
+
+ Adds a new DisableWebKitDeveloperExtras default that will force the Web Inspector to be disabled.
+ This overrides the WebKitDeveloperExtras and IncludeDebugMenu default. It also disables
+ the Web Inspector in Debug builds.
+
+ * WebView/WebView.mm:
+ (+[WebView _developerExtrasEnabled]): Check for the DisableWebKitDeveloperExtras default.
+ (-[WebView _commonInitializationWithFrameName:groupName:]): Make a new WebInspectorClient when making the Page.
+
+2007-07-18 Anders Carlsson <andersca@apple.com>
+
+ Build fix.
+
+ * Misc/WebNSAttributedStringExtras.mm:
+
+2007-07-18 Sam Weinig <sam@webkit.org>
+
+ Rubber-stamped by Adam Roben.
+
+ Update after renaming MimeTypeRegistry to MIMETypeRegistry.
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_writePromisedRTFDFromArchive:containsImage:]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _documentFragmentWithArchive:]):
+ * WebView/WebHTMLRepresentation.mm:
+ (+[WebHTMLRepresentation supportedNonImageMIMETypes]):
+ (+[WebHTMLRepresentation supportedImageMIMETypes]):
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _imageExistsAtPaths:]):
+
+2007-07-18 Tristan O'Tierney <tristan@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ <rdar://problem/5341334> Alt-clicking a link in Safari does not register original URL info with gatekeeper
+ <rdar://problem/5342570> REGRESSION: A hang occurs when attempting to open a attached file from a .Mac web mail message
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ Added a new method, setOriginalURLForDownload, for both download()
+ and startDownload() to share.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::download):
+ Moved all the gatekeeper code into setOriginalURLForDownload.
+
+ (WebFrameLoaderClient::setOriginalURLForDownload):
+ Same code that was in download() but moved into a single place for both
+ startDownload and download to use. Also returned the boolean logic
+ for detecting _wasUserGesture back to it's previous state, since my prior change
+ was incorrect. Additionally I found a loop index bug with backListCount and fixed it.
+
+ (WebFrameLoaderClient::startDownload):
+ Calls out to setOriginalURLForDownload after a download is created.
+
+ * WebView/WebView.mm:
+ (-[WebView _downloadURL:]):
+ Changed to return the WebDownload object created inside _downloadURL
+
+ * WebView/WebViewInternal.h:
+ Changed _downloadURL to return the WebDownload it creates.
+
+2007-07-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/5336267> loadData:MIMEType:textEncodingName:baseURL: doesn't like relative URLs
+
+ Get the absoluteURL from any user supplied NSURL before we pass it down to WebCore.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _loadData:MIMEType:textEncodingName:baseURL:unreachableURL:]):
+ * WebView/WebView.mm:
+ (-[WebView userAgentForURL:]):
+
+2007-07-17 Adam Roben <aroben@apple.com>
+
+ Fix Bug 14324: Cannot remove/customize the "Inspect Element" contextual menu item
+ http://bugs.webkit.org/show_bug.cgi?id=14324
+
+ Only clients linking against new versions of WebKit will see the item.
+ I've maintained our behavior for old clients of not including the
+ Inspect Element item in the menu items passed to the UI delegate.
+
+ Reviewed by Tim.
+
+ * Misc/WebKitVersionChecks.h: Added a new constant.
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (isPreInspectElementTagClient): Added.
+ (fixMenusToSendToOldClients): Return an array of items that should be
+ appended to the menu received from the delegate.
+ (fixMenusReceivedFromOldClients): Append the saved items to the array.
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): Retain/release
+ the saved items.
+
+2007-07-17 Adam Roben <aroben@apple.com>
+
+ Remove WebContextMenuClient::shouldIncludeInspectElementItem
+
+ Reviewed by Tim.
+
+ * WebCoreSupport/WebContextMenuClient.h:
+ * WebCoreSupport/WebContextMenuClient.mm:
+
+2007-07-17 Adam Roben <aroben@apple.com>
+
+ Initialize Settings::developerExtrasEnabled
+
+ Reviewed by Tim.
+
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-07-17 Geoffrey Garen <ggaren@apple.com>
+
+ Build fix.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ * WebView/WebFramePrivate.h:
+
+2007-07-17 Tristan O'Tierney <tristan@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ <rdar://problem/5294691> Source of file is misrepresented if downloaded by typing in URL in Safari address bar
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::download):
+ Revised code to check the initial request's referrer before assuming it has a history to check.
+
+2007-07-16 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adam
+
+ Begin the arduous task of localizing FTP directory listings while removing a global initializer!
+
+ * English.lproj/Localizable.strings:
+ * WebCoreSupport/WebViewFactory.mm:
+ (-[WebViewFactory unknownFileSizeText]):
+
+2007-07-16 Adam Roben <aroben@apple.com>
+
+ Move printing from WebFrameBridge to WebChromeClient
+
+ Reviewed by Darin.
+
+ * WebCoreSupport/WebChromeClient.h: Updated for ChromeClient changes.
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::print): Moved code from WebFrameBridge.
+ * WebCoreSupport/WebFrameBridge.mm: Removed -print.
+
+2007-07-16 Darin Adler <darin@apple.com>
+
+ * StringsNotToBeLocalized.txt: Update for recent changes.
+
+2007-07-16 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker and Darin Adler
+
+ - fixed <rdar://problem/5337529> Holes in Find banner overlay on PDF pages are left in wrong place after changing scale
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _scaleOrDisplayModeChanged:]):
+ tell UI delegate that the entire PDF view has been redrawn
+
+2007-07-14 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Sam Weinig
+
+ Initial check-in for <rdar://problem/3154486> - Supporting FTP directory listings in the browser
+
+ * WebView/WebPreferenceKeysPrivate.h: Added preference keys for the FTP template location, as well as to force
+ FTP directory listings, bypassing the policy delegate. This is necessary to test the new feature until browser
+ policy delegate support is added.
+
+ * WebView/WebPreferences.m:
+ (-[WebPreferences _setFTPDirectoryTemplatePath:]):
+ (-[WebPreferences _ftpDirectoryTemplatePath]):
+ (-[WebPreferences _setForceFTPDirectoryListings:]):
+ (-[WebPreferences _forceFTPDirectoryListings]):
+ * WebView/WebPreferencesPrivate.h:
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-07-13 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5290103> Assert failure when loading page with multipart resource
+
+ Don't try to call the delegate method if the resource object doesn't exist in the
+ identifier map. When a multipart resource has finished loading one part, it is removed from the
+ web view identifier map.
+
+ This is not an ideal fix, a better fix would be to special-case multipart resources and not remove
+ them when the first part has finished loading. I've filed <rdar://problem/5335034> to track doing that.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::willCacheResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+
+2007-07-13 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ <rdar://problem/5333766> Can't include WebEditingDelegatePrivate.h
+
+ * WebView/WebEditingDelegatePrivate.h: Changed the include to be a framework include,
+ so other projects can use this header.
+
+2007-07-12 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin and Maciej.
+
+ <rdar://problem/5271096> panic after Safari stress test, caused by port leak
+
+ Replace uses of -[NSObject performSelector:withObject:afterDelay:] with CFRunLoopTimer. performSelector
+ causes the target (the WebHTMLView in this case) to be retained until the timer fires. Furthermore, when
+ running the PLT or iBench, the timers will not fire until the main loop is entered (usually after running all tests).
+
+ This means that the timers and ports will not be released until after the test has finished running.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLViewPrivate dealloc]):
+ (-[WebHTMLView _cancelUpdateMouseoverTimer]):
+ (-[WebHTMLView _updateMouseoverWithFakeEvent]):
+ (-[WebHTMLView _updateMouseoverTimerCallback:]):
+ (-[WebHTMLView _frameOrBoundsChanged]):
+ (-[WebHTMLView _updateActiveState]):
+ (-[WebHTMLView _updateActiveStateTimerCallback:]):
+ (-[WebHTMLView viewWillMoveToWindow:]):
+ (-[WebHTMLView viewDidMoveToWindow]):
+ (-[WebHTMLView mouseDown:]):
+ (-[WebTextCompleteController dealloc]):
+ * WebView/WebHTMLViewInternal.h:
+
+2007-07-13 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Mitz.
+
+ Build fix. Stub out WebChromeClient::print.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::print):
+
+2007-07-11 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Oliver.
+
+ <rdar://problem/5108789> WEBVIEW: Drawing artifacts when dragging in IB
+
+ Interface Builder 3 is relying on KVO notifications for frameOrigin and frameSize,
+ among other standard NSView keys. Change automaticallyNotifiesObserversForKey to
+ return NO only for keys WebView manually fires notifications for.
+
+ * WebView/WebView.mm:
+ (+[WebView automaticallyNotifiesObserversForKey:]): Selectivly return NO for keys we manually fire.
+ (-[WebView _declaredKeys]): Code clean up.
+
+2007-07-10 Antti Koivisto <antti@apple.com>
+
+ Reviewed by John.
+
+ Fix <rdar://problem/4570550>
+ Hang in layout/layoutBlock/layoutBlockChildren preparing to print certain Mail messages
+
+ When printing from Mail, WebHTMLView is a subview of the view that is actually printed and does not
+ receive calls that would set it to printing mode. Method adjustPageHeightNew is called repeatedly (for each page) during
+ printing and it enables printing mode temporarily for each call. This triggers two full style recalcs and layouts
+ each time making printing at least O(n^2).
+
+ Instead of enabling printing mode and resetting it back immediatly do the resetting asynchronously, after
+ all adjustPageHeightNew calls are done. Normal Safari printing is not affected as adjustPageHeightNew is only
+ called in case WebHTMLView is embedded in the view that is being printed.
+
+ No automatic test possible, requires printing and non-Safari client.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView adjustPageHeightNew:top:bottom:limit:]):
+
+2007-07-10 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ - Fixed <rdar://problem/5049509> REGRESSION(10.4.9-9A377a): REAP Suite
+ installer shows empty modal alert window (hangs) if user cancels during
+ "installing shared components" phase
+
+ Added Adobe installers to the family of apps that need a data load
+ loading quirk.
+
+ Added a linked-on-or-after check because this code is no longer
+ Tiger-only.
+
+ I tested this code on Tiger and Leopard.
+
+ * Misc/WebKitVersionChecks.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDocumentLoaderMac.mm:
+ (needsDataLoadWorkaround):
+ (WebDocumentLoaderMac::setDataSource):
+
+2007-07-10 Darin Adler <darin@apple.com>
+
+ - fix build
+
+ * WebView/WebHTMLView.mm: Add include of ContextMenu.h.
+
+2007-07-10 Darin Adler <darin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ - <rdar://problem/5321953> remove workaround for fixed AppKit mouse moved bug
+
+ * WebView/WebHTMLView.mm: Put the workaround for bug 3429631 inside an
+ ifdef BUILDING_ON_TIGER.
+
+2007-07-09 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Oliver.
+
+ <rdar://problem/4954319>
+ Acrobat 7 / Safari crash: CrashTracer: 99 crashes in Safari at
+ com.apple.WebCore: WebCore::NetscapePlugInStreamLoader::isDone const + 0
+
+ Add a new initWithFrameLoader: method to WebNetscapePluginStream which is to be used when
+ the stream is a "fake" stream for full frame plug-ins.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView pluginView:receivedResponse:]):
+ * Plugins/WebNetscapePluginStream.h:
+ * Plugins/WebNetscapePluginStream.mm:
+ (-[WebNetscapePluginStream initWithFrameLoader:]):
+ (-[WebNetscapePluginStream initWithRequest:plugin:notifyData:sendNotification:]):
+ (-[WebNetscapePluginStream start]):
+ (-[WebNetscapePluginStream cancelLoadWithError:]):
+ (-[WebNetscapePluginStream stop]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::createFrame):
+
+2007-07-09 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - fixed <rdar://problem/5320208> WebKit should prevent Time Machine from backing up WebKit clients' icon databases
+
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase init]):
+ Re-added the code to exclude the icon database from backups. We now do this at the same time we (try to) import
+ the old icon database format, which happens only once per icon database's lifetime.
+ (-[WebIconDatabase _importToWebCoreFormat]):
+ Assert that we haven't imported yet rather than bailing out. It's now the caller's responsibility to check
+ whether we've imported yet.
+
+2007-07-08 John Sullivan <sullivan@apple.com>
+
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase init]):
+ Removed the code to exclude the icon database from backups. We still want to do this, but in a way
+ that only runs once ever, instead of once per launch, due to performance concerns.
+
+2007-07-07 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - fix <rdar://problem/5124665> WebCore secondary-thread assertion should use linked-on-or-after check instead of building on Tiger check
+
+ * Misc/WebKitVersionChecks.h: Added WEBKIT_FIRST_VERSION_WITH_MAIN_THREAD_EXCEPTIONS.
+
+ * WebView/WebFrameView.mm: (-[WebFrameView initWithFrame:]): In first-time initialization block,
+ check for binaries linked against older versions of WebKit, and set the default thread violation
+ behavior to LogOnFirstThreadViolation.
+
+ * WebView/WebView.mm: (+[WebView initialize]): Improved comments.
+
+2007-07-06 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5318756> Need to refactor IM/Marked text code to share logic with windows.
+
+ Moved a number of methods from WebHTMLView into WebCore.
+ Replaced bridge methods with calls directly into WebCore objects.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView setMarkedText:selectedRange:]):
+ Now calls WebCore object methods directly, rather than calling
+ via the bridge.
+
+2007-07-06 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Brady
+
+ - WebKit part of fix for:
+ <rdar://problem/5310739> Time Machine shouldn't back up WebKit's icon database files
+
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase init]):
+ Use CSBackupSetItemExcluded to tell Time Machine not to back up the icon database file
+
+2007-07-07 Mark Rowe <mrowe@apple.com>
+
+ Build fix. Update WebDynamicScrollBarsView.h to include methods added and used in r24060.
+
+ * WebView/WebDynamicScrollBarsView.h:
+
+2007-07-05 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5236277> REGRESSION-9A458: SPI for setting scroll bar behavior doesn't work
+
+ Calling setHorizontalScrollingMode: calls updateScrollers before returning, this will cause
+ WebCore to reset the scrolling mode based on the CSS overflow rules. So the setAlwaysShowHorizontalScroller:
+ and setAlwaysShowVerticalScroller: methods needed a way to lock the scrolling mode before
+ calling updateScrollers.
+
+ * WebView/WebDynamicScrollBarsView.m:
+ (-[WebDynamicScrollBarsView updateScrollers]):
+ (-[WebDynamicScrollBarsView setHorizontalScrollingMode:]):
+ (-[WebDynamicScrollBarsView setHorizontalScrollingMode:andLock:]):
+ (-[WebDynamicScrollBarsView setVerticalScrollingMode:]):
+ (-[WebDynamicScrollBarsView setVerticalScrollingMode:andLock:]):
+ (-[WebDynamicScrollBarsView setScrollingMode:]):
+ (-[WebDynamicScrollBarsView setScrollingMode:andLock:]):
+ * WebView/WebView.mm:
+ (-[WebView setAlwaysShowVerticalScroller:]):
+ (-[WebView setAlwaysShowHorizontalScroller:]):
+
+2007-07-06 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=10267
+ Can't scroll page downwards with scroll wheel, when pointer is on top of non-scrolling iframe
+
+ * WebView/WebDynamicScrollBarsView.m:
+ (-[WebDynamicScrollBarsView scrollWheel:]): Override the superclass
+ implementation to forward the wheel event to the next responder if this view
+ does not allow scrolling in the event's direction.
+
+2007-07-05 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adam
+
+ - WebKit part of fix for <rdar://problem/5315033>
+
+ * WebView/WebDocumentPrivate.h:
+ new selectionImageForcingBlackText: method. selectionImageForcingWhiteText: is no longer used and was never
+ in an official release of WebKit, so it could be removed, except that doing so would cause trouble for people
+ using nightly WebKit with Safari 3.0 beta. So I left it in, but made it just force black text instead of
+ white text, which will look different for those nightly WebKit/Safari 3.0 beta people but not break anything.
+
+ * Misc/WebSearchableTextView.m:
+ (-[WebSearchableTextView selectionImageForcingBlackText:]):
+ new unimplemented protocol method for this obsolete class
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView selectionImageForcingBlackText:]):
+ calls through to WebCore the way selectionImageForcingWhiteText: used to
+ (-[WebHTMLView selectionImageForcingWhiteText:]):
+ now just calls selectionImageForcingBlackText:, thus not working as you would expect from the name
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView selectionImageForcingBlackText:]):
+ guts of old selectionImageForcingWhiteText:, but with black substituted for white
+ (-[WebPDFView selectionImageForcingWhiteText:]):
+ now just calls selectionImageForcingBlackText:, thus not working as you would expect from the name
+
+2007-07-05 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5314993> Shiira 2.1 throws an exception open a new window: -[WebInspector window]: unrecognized selector
+
+ Add an empty implementation of this method to prevent Shiira from throwing an exception.
+ Also log that this method is obsolete and the class will be removed.
+
+ * WebInspector/WebInspector.mm:
+ (-[WebInspector window]):
+
+2007-07-04 Adam Roben <aroben@apple.com>
+
+ Move tooltip logic down into WebCore so that it can be shared cross-platform
+
+ Reviewed by Sam.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::setToolTip): Added.
+ * WebView/WebHTMLView.mm: Removed _resetCachedWebPreferences.
+ (-[WebHTMLView _updateMouseoverWithEvent:]): Removed tooltip code.
+ (-[WebHTMLView initWithFrame:]): Removed call to
+ _resetCachedWebPreferences.
+ (-[WebHTMLView setDataSource:]): Ditto.
+ * WebView/WebHTMLViewInternal.h: Removed showsURLsInToolTips ivar.
+ * WebView/WebHTMLViewPrivate.h: Added declaration for _setTooltip so
+ that WebChromeClient can call it.
+
+2007-07-04 Adam Roben <aroben@apple.com>
+
+ Initialize Settings::showsURLsInToolTips
+
+ Reviewed by Sam.
+
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-07-04 Adam Roben <aroben@apple.com>
+
+ Removed call to mouseDidMoveOverElement now that WebCore handles it
+
+ Reviewed by Sam.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+
+2007-07-04 Adam Roben <aroben@apple.com>
+
+ Add WebChromeClient::mouseDidMoveOverElement
+
+ This is not called yet.
+
+ Reviewed by Sam.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+
+2007-07-03 Darin Adler <darin@apple.com>
+
+ * StringsNotToBeLocalized.txt: Updated for recent changes.
+
+2007-07-03 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Remove HIWebView in 64-bit.
+
+ Also disable a few calls that are now gone in 64-bit and filed these bugs:
+
+ <rdar://problem/5311653> WebKit needs to adopt HIGetMousePosition where we used GetGlobalMouse before
+ <rdar://problem/5311648> WebKit needs to move off of CopyEvent in WebBaseNetscapePluginView
+ <rdar://problem/5311640> WebKit needs a new solution for HISearchWindowShow on 64-bit
+
+ * Carbon/CarbonUtils.m:
+ * Carbon/CarbonWindowAdapter.m:
+ * Carbon/CarbonWindowContentView.m:
+ * Carbon/CarbonWindowFrame.m:
+ * Carbon/HIViewAdapter.m:
+ (SetViewNeedsDisplay):
+ * Carbon/HIWebView.m:
+ (Draw):
+ (SyncFrame):
+ * Configurations/WebKit.xcconfig:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (+[WebBaseNetscapePluginView getCarbonEvent:]):
+ (TSMEventHandler):
+ * WebKit.LP64.exp: Added.
+ * WebView/WebView.mm:
+ (-[WebView _searchWithSpotlightFromMenu:]):
+
+2007-07-03 Adam Roben <aroben@apple.com>
+
+ Merge the Windows and Mac localized strings and exceptions files
+
+ Reviewed by Darin and Anders.
+
+ * English.lproj/Localizable.strings: Added Windows strings.
+ * StringsNotToBeLocalized.txt: Renamed from WebKit/English.lproj/StringsNotToBeLocalized.txt.
+
+2007-07-03 Adele Peterson <adele@apple.com>
+
+ Removed printf I accidently left in.
+
+ * Misc/WebNSURLExtras.m: (mapHostNames):
+
+2007-07-03 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for: <rdar://problem/5292988> domain names shouldn't contain ignorable characters
+
+ * Misc/WebNSURLExtras.m:
+ (isLookalikeCharacter): Renamed. Also excludes any non-printable character,
+ any character considered as whitespace that isn't already converted to a space by ICU, any ignorable character,
+ and any character excluded in Mozilla's blacklist: http://kb.mozillazine.org/Network.IDN.blacklist_chars
+ (allCharactersInIDNScriptWhiteList):
+
+2007-07-03 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - fix <rdar://problem/5310848> WebDataSource lifetime problem -- may be cause of the leaks seen on the buildbot
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSourcePrivate dealloc]): Added a call to the new detachDataSource function.
+ (-[WebDataSourcePrivate finalize]): Ditto.
+
+ * WebView/WebDocumentLoaderMac.h: Added detachDataSource function to be used when the
+ WebDataSource is deallocated. Added retain/releaseDataSource helper functions to be
+ used to retain and release the data source object. Replaced the m_hasEverBeenDetached
+ boolean with a more primitive and hence easier to understand m_isDataSourceRetained boolean.
+
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::WebDocumentLoaderMac): Initialize m_isDataSourceRetained to false.
+ (WebDocumentLoaderMac::setDataSource): Call retainDataSource instead of calling HardRetain
+ on the dataSource parameter. Also updated a comment.
+ (WebDocumentLoaderMac::attachToFrame): Call retainDataSource unconditionally rather than
+ trying to use m_hasEverBeenDetached to decide if a retain is needed. Also got rid of an
+ assertion that m_loadingResources is empty -- not important any more.
+ (WebDocumentLoaderMac::detachFromFrame): Call releaseDataSource instead of using
+ HardRelease, but only if m_loadingResources is empty. If it's non-empty, then we'll
+ do the releaseDataSource later in decreaseLoadCount.
+ (WebDocumentLoaderMac::increaseLoadCount): Call retainDataSource unconditionally
+ rather than calling HardRetain only if the old set of resources was empty.
+ (WebDocumentLoaderMac::decreaseLoadCount): Call releaseDataSource if m_loadingResources
+ is empty and we're not attached to a frame. If we are attached to a frame, then
+ we'll do the releaseDataSource later in detachFromFrame.
+ (WebDocumentLoaderMac::retainDataSource): Added. Calls CFRetain, but only if the data
+ source is not already retained (according to the boolean).
+ (WebDocumentLoaderMac::releaseDataSource): Added. Calls CFRelease, but only if the data
+ source is currently retained (according to the boolean).
+ (WebDocumentLoaderMac::detachDataSource): Added. Sets m_dataSource to nil. Since this
+ is only called from WebDataSource's dealloc and finalize methods, it won't ever be called
+ when the m_isDataSourceRetained boolean is true.
+
+2007-07-03 Darin Adler <darin@apple.com>
+
+ - forgot to check in one file in the fix for <rdar://problem/5307880>
+ some classes need finalize methods because of non-trivial work done in dealloc methods
+
+ * WebView/WebView.mm: (-[WebViewPrivate finalize]): Delete identifierMap so it doesn't leak.
+
+2007-07-03 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ * WebView/WebView.mm:
+ (-[WebView stringByEvaluatingJavaScriptFromString:]):
+ ASSERT that the value returned isn't nil. It can't be nil when invoked on the main frame.
+
+2007-07-04 Mark Rowe <mrowe@apple.com>
+
+ Unreviewed 64-bit build fixes.
+
+ * WebCoreSupport/WebInspectorClient.mm: Let the compiler know that WebFrameView is a subclass of NSView.
+ * WebView/WebDocumentInternal.h: Remove our preprocessor macro once we're done with it.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView markAllMatchesForText:caseSensitive:limit:]): Fix argument types.
+
+2007-07-02 Darin Adler <darin@apple.com>
+
+ Reviewed by Kevin Decker and Tim Hatcher.
+
+ - fix <rdar://problem/5307880> some classes need finalize methods
+ because of non-trivial work done in dealloc methods
+
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer dealloc]): Added a comment about how this probably won't
+ work under GC.
+ * WebInspector/WebNodeHighlight.m:
+ (-[WebNodeHighlight dealloc]): Ditto.
+
+ * WebView/WebDataSource.mm:
+ (+[WebDataSourcePrivate initialize]): Added. Makes finalize run on main thread.
+ (-[WebDataSourcePrivate finalize]): Added. Calls deref on the document loader.
+ * WebView/WebHTMLView.mm:
+ (+[WebHTMLViewPrivate initialize]): Added. Makes finalize run on main thread.
+ (-[WebHTMLViewPrivate finalize]): Added. Calls deref on promisedDragTIFFDataSource.
+
+ * WebKit.xcodeproj/project.pbxproj: Let Xcode be Xcode.
+
+2007-07-02 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Justin.
+
+ Fix for
+ <rdar://problem/5290113> WebKit does not correctly handle replacement ranges from the IM in -[WebHTMLView insertText:]
+ http://bugs.webkit.org/show_bug.cgi?id=13664
+
+ We replicate the logic of -[WebHTMLView setMarkedText:selectedRange:] to handle the Input Method
+ feeding us a replacement string through insertText: so we can handle IMs that use insertText to
+ replace text.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView insertText:]):
+
+2007-07-01 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Alexey.
+
+ Fix for <rdar://problem/5306210> Some events are still passed to WebCore despite being handled by the IM
+ http://bugs.webkit.org/show_bug.cgi?id=14457
+
+ We have to assume that the IM will consume all events, so we remove the dependency
+ on -[WebHTMLView hasMarkedText].
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]):
+
+2007-06-29 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ - WebKit support for accessing the set of rectangles that encompass the selected text
+
+ * WebView/WebDocumentPrivate.h:
+ added -selectionTextRects to WebDocumentSelection protocol; tweaked comments
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _selectionDraggingRect]):
+ use selectionRect instead of selectionImageRect since they're the same and maybe we can get
+ rid of selectionImageRect someday
+ (-[WebHTMLView selectionTextRects]):
+ added implementation of new protocol method, which calls through to WebCore
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView selectionTextRects]):
+ added simple implementation of new protocol method, which just returns the single selection rect.
+ PDFKit doesn't support obtaining multiple rects to describe a multi-line selection.
+ (-[WebPDFView selectionImageForcingWhiteText:]):
+ use selectionRect instead of selectionImageRect since they're the same and maybe we can get
+ rid of selectionImageRect someday
+
+ * Misc/WebSearchableTextView.m:
+ (-[WebSearchableTextView selectionTextRects]):
+ added no-op implementation of new protocol method to this obsolete class
+
+2007-06-28 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5287569> WEBVIEW: Creating a webview in IB 3.0 (v2.0) NIB later crashes Interface Builder 2.5.4 on Tiger
+
+ Prevent encoding any of the WebView subviews. The subviews are ignored by -[WebView initWithCoder:] and will be recreated.
+ The Tiger 2.0 code crashed when the WebView released the subviews in initWithCoder:, so now there are no subviews to release.
+ This never happened before because the Tiger 2.0 code and IB wouldn't encode a WebView that has a WebHTMLView.
+
+ * WebView/WebView.mm:
+ (-[WebView encodeWithCoder:]):
+
+2007-06-26 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - WebKit support for displaying multiple text matches in PDF views (<rdar://problem/4601967>)
+
+ * WebView/WebPDFView.h:
+ new ivars textMatches and lastScrollPosition; now conforms to WebMultipleTextMatches protocol
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView dealloc]):
+ release textMatches
+ (-[WebPDFView viewDidMoveToWindow]):
+ start observing bounds changes in the PDF document's enclosing clip view, so we can notice when
+ scrolling takes place
+ (-[WebPDFView viewWillMoveToWindow:]):
+ stop observing bounds changes in the PDF document's enclosing clip view
+ (-[WebPDFView searchFor:direction:caseSensitive:wrap:startInSelection:]):
+ most of the code here has been moved into the new method _nextMatchFor::::, which this now calls
+ (-[WebPDFView setMarkedTextMatchesAreHighlighted:]):
+ implementation of WebMultipleTextMatches protocol method, does nothing useful here because we don't
+ support inline highlighting of matches in PDF documents
+ (-[WebPDFView markedTextMatchesAreHighlighted]):
+ implementation of WebMultipleTextMatches protocol method
+ (-[WebPDFView markAllMatchesForText:caseSensitive:limit:]):
+ implementation of WebMultipleTextMatches protocol method; calls _nextMatchFor:::: in a loop until
+ entire document is searched or limit is hit; records results by saving PDFSelections in textMatches ivar
+ (-[WebPDFView unmarkAllTextMatches]):
+ implementation of WebMultipleTextMatches protocol method; clears saved textMatches
+ (-[WebPDFView rectsForTextMatches]):
+ implementation of WebMultipleTextMatches protocol method; converts saved PDFSelections into NSValue
+ objects that represent NSRects
+ (-[WebPDFView _clipViewForPDFDocumentView]):
+ new helper method to find the clip view whose bounds determine the current scroll position
+ (-[WebPDFView _nextMatchFor:direction:caseSensitive:wrap:fromSelection:startInSelection:]):
+ new helper method, extracted from searchFor:::::
+ (-[WebPDFView _PDFDocumentViewMightHaveScrolled:]):
+ new notification callback; tells webView's delegate when document has scrolled
+ (-[WebPDFView _setTextMatches:]):
+ new helper method, stores value in ivar
+
+2007-06-26 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Maciej.
+
+ Hopefully fix remainder of the IME issues on Mac.
+ We now assume that the IME silently consumes any event given
+ to it during text composition, and only override this assumption
+ if the NSTextInput or NSResponder callbacks are made.
+
+ This prevents us from treating those events that the IME has
+ consumed internally (eg. candidate window navigation) as unhandled
+ events that should be bubbled.
+
+ This fixes:
+ <rdar://problem/5107538> Major problems handling key press event with non-english Input Methods
+ <rdar://problem/4196249> REGRESSION: Mail: Inputting space (U+0020) with IM deletes subsequent line breaks on Mail.app
+ <rdar://problem/5015544> REGRESSION: Reverse conversion keyboard command does not work in Safari.
+ <rdar://problem/5045121> REGRESSION: Inline is confirmed after press left/right arrow keys, happens in Mail but not in TextEdit.
+ <rdar://problem/5076807> REGRESSION: Can't undo conversion of inline text (by hitting ESC)
+ <rdar://problem/5085781> REGRESSION: Active input area lost "selected" highlight
+ <rdar://problem/5094200> space key pressed to close the associated words candidate window gets inserted as text
+ <rdar://problem/5228294> Candidate item for character matrix is sometimes skipped
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView launchKeyEvent:]):
+ (-[WebHTMLView keyDown:]):
+ (-[WebHTMLView keyUp:]):
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]):
+ (-[WebHTMLView unmarkText]):
+ (-[WebHTMLView setMarkedText:selectedRange:]):
+ (-[WebHTMLView doCommandBySelector:]):
+ (-[WebHTMLView insertText:]):
+
+2007-06-26 Jim Correia <jim.correia@pobox.com>
+
+ Reviewed by Darin.
+
+ Fix http://bugs.webkit.org/show_bug.cgi?id=14411
+ Bug 14411: WebNetscapePluginPackage overagressively sets CurApRefNum, which affects shipping versions of BBEdit.
+ <rdar://problem/5297268>
+
+ * Plugins/WebNetscapePluginPackage.m:
+ (+[WebNetscapePluginPackage initialize]): Force the Resource Manager to
+ lazy initialize, and only set CurApRefNum to the system file if
+ CurApRefNum is still -1 after that forced lazy initialization.
+
+2007-06-25 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5294036> -[WebView customTextEncodingName] API may return empty string instead of nil
+
+ * WebView/WebView.mm:
+ (-[WebView _mainFrameOverrideEncoding]): Addded the nsStringNilIfEmpty() inline to the data being returned because
+ our API says "The custom text encoding name or nil if no custom text encoding name has been set." I also verified
+ the standing Tiger WebKit behavior for this method and it does indeed return nil if a custom encoding wasn't set.
+
+2007-06-25 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - WebKit part of <rdar://problem/5293820>, needed to support multiple matches in PDFs
+
+ * WebView/WebDocumentInternal.h:
+ Added WebMultipleTextMatches protocol, containing five methods that were formerly implemented in WebHTMLView
+ * WebView/WebHTMLViewPrivate.h:
+ Removed declarations for the methods that are now in WebMultipleTextMatches protocol
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView markAllMatchesForText:caseSensitive:limit:]):
+ moved this method into the WebDocumentInternalProtocols portion of the file
+ (-[WebHTMLView setMarkedTextMatchesAreHighlighted:]):
+ ditto
+ (-[WebHTMLView markedTextMatchesAreHighlighted]):
+ ditto
+ (-[WebHTMLView unmarkAllTextMatches]):
+ ditto
+ (-[WebHTMLView rectsForTextMatches]):
+ ditto
+
+ * WebView/WebView.mm:
+ (-[WebView canMarkAllTextMatches]):
+ new method, returns YES only if the documentView of every frame implements WebMultipleTextMatches
+ (-[WebView markAllMatchesForText:caseSensitive:highlight:limit:]):
+ check for WebMultipleTextMatches protocol instead of checking for WebHTMLView class
+ (-[WebView unmarkAllTextMatches]):
+ ditto
+ (-[WebView rectsForTextMatches]):
+ ditto
+
+ * WebView/WebViewPrivate.h:
+ declared new method canMarkAllTextMatches
+
+2007-06-25 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ Fixed <rdar://problem/5292259> Find on Page doesn't work (throws exception) on page that includes PDF in a subframe
+
+ * WebView/WebView.mm:
+ (-[WebView markAllMatchesForText:caseSensitive:highlight:limit:]):
+ We were testing whether the view was an HTMLView, but then running code that assumed it was an HTMLView outside of
+ that test. That's a bad idea.
+
+2007-06-22 Adele Peterson <adele@apple.com>
+
+ Reviewed by Geoff and Darin.
+
+ Fix for: <rdar://problem/5239236> Other slash characters should not be permitted as part of a domain name
+
+ * Misc/WebNSURLExtras.m:
+ (isSlashOrPeriodLookalike):
+ (allCharactersInIDNScriptWhiteList):
+
+2007-06-21 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Antti.
+
+ Remove empty directories
+
+ * WebInspector/webInspector: directory removed.
+ * WebInspector/webInspector/Images: directory removed
+
+2007-06-21 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by Tim.
+
+ <rdar://problem/5237524>
+ REGRESSION: Keyboard commands don't work in a message window until you click inside the message
+
+ When you open a message in its own window, Mail creates an empty
+ WebView, makes that WebView firstResponder and then sets off a
+ load inside that WebView.
+
+ When we're asked to create the empty WebView, we put an empty
+ WebHTMLView inside it (in r21367 we began creating a document
+ for empty frames). When Mail makes the WebView first responder
+ we make that empty WebHTMLView firstResponder. Then when the
+ load finishes we create a new WebHTMLView and set it as the
+ document view.
+
+ Inside _setDocumentView, if the old document view or one of its
+ descendants was the first responder, we'd makeFirstResponder:nil
+ so that the window wouldn't be left with a firstResponder that
+ was no longer inside of it. This change fixes the bug by instead
+ transferring firstResponder status to the new document view.
+
+ We could also fix this by not allowing the WebHTMLView to become
+ firstResponder when it's in the provisional state mentioned above.
+
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _setDocumentView:]):
+
+2007-06-21 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adele
+
+ - fixed <rdar://problem/5268673> REGRESSION: Context menu missing for PDF in frame when there's no selection
+
+ This was surprisingly interesting. It turns out that at least for Safari, the method [WebDefaultUIDelegate
+ webView:contextMenuItemsForElement:defaultMenuItems:] is only exercised from WebPDFView these days. It mimics
+ some of the code that was moved to WebCore as part of the Great Context Menu Refactoring of 2006, but is
+ independent of that code. And it was partly broken/incomplete, probably as a result of said refactoring.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.mm:
+ (localizedMenuTitleFromAppKit()):
+ deleted this function since I removed all callers
+ (-[WebDefaultUIDelegate menuItemWithTag:target:representedObject:]):
+ Handle WebMenuItemTagOpenFrameInNewWindow tag, since code later in this file was relying on it. Added
+ ASSERT_NOT_REACHED to the default case, since returning nil from this method is bad.
+ Also, use WebKit versions of menu title strings rather than AppKit versions. We added these strings to WebKit
+ a while back so we don't need to sneakily find them in AppKit anymore.
+ (-[WebDefaultUIDelegate webView:contextMenuItemsForElement:defaultMenuItems:]):
+ make the WebView be the target of the Open Frame in New Window item; previously it was self, but that was
+ just silly (probably a leftover from some code shuffling when context menus were reimplemented)
+
+ * WebView/WebView.mm:
+ (-[WebView _openFrameInNewWindowFromMenu:]):
+ new method, used by Open Frame in New Window menu item.
+
+ * WebView/WebViewInternal.h:
+ Declare new method used by menu item. This isn't necessary for compilation, but could prevent the accidental
+ deletion of the method implementation.
+
+2007-06-20 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Adam.
+
+ Fix http://bugs.webkit.org/show_bug.cgi?id=14255.
+ Bug 14255: Reproducible crash opening web inspector from debug menu
+
+ Reinstate the WebInspector class so WebKit clients that currently depend on it
+ will build and run correctly.
+
+ * WebInspector/WebInspector.h: Added.
+ * WebInspector/WebInspector.mm: Added.
+ (+[WebInspector webInspector]):
+ (-[WebInspector dealloc]):
+ (-[WebInspector setWebFrame:]):
+ (-[WebInspector showWindow:]):
+ * WebKit.exp:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-06-20 Adam Roben <aroben@apple.com>
+
+ Land the new Inspector.
+
+ Co-written with Tim Hatcher.
+
+ Reviewed by Anders, Adele, Hyatt, and Sam.
+
+ Implement the InspectorClient interface.
+
+ * WebCoreSupport/WebInspectorClient.h: Added.
+ * WebCoreSupport/WebInspectorClient.mm: Added.
+ (WebInspectorClient::WebInspectorClient):
+ (WebInspectorClient::inspectorDestroyed):
+ (WebInspectorClient::createPage):
+ (WebInspectorClient::showWindow):
+ (WebInspectorClient::closeWindow):
+ (WebInspectorClient::attachWindow):
+ (WebInspectorClient::detachWindow):
+ (WebInspectorClient::highlight):
+ (WebInspectorClient::hideHighlight):
+ (WebInspectorClient::inspectedURLChanged):
+ (WebInspectorClient::updateWindowTitle):
+ (-[WebInspectorWindowController init]):
+ (-[WebInspectorWindowController initWithInspectedWebView:]):
+ (-[WebInspectorWindowController dealloc]):
+ (-[WebInspectorWindowController inspectorVisible]):
+ (-[WebInspectorWindowController webView]):
+ (-[WebInspectorWindowController window]):
+ (-[WebInspectorWindowController windowShouldClose:]):
+ (-[WebInspectorWindowController close]):
+ (-[WebInspectorWindowController showWindow:]):
+ (-[WebInspectorWindowController attach]):
+ (-[WebInspectorWindowController detach]):
+ (-[WebInspectorWindowController highlightAndScrollToNode:]):
+ (-[WebInspectorWindowController highlightNode:]):
+ (-[WebInspectorWindowController hideHighlight]):
+ (-[WebInspectorWindowController animationDidEnd:]):
+
+ Add an easier-to-see highlight.
+
+ * Misc/WebNSViewExtras.h:
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_convertRect:toView:]):
+ * WebInspector/WebNodeHighlight.h:
+ * WebInspector/WebNodeHighlight.m:
+ (-[WebNodeHighlightFadeInAnimation setCurrentProgress:]):
+ (-[WebNodeHighlight initWithTargetView:]):
+ (-[WebNodeHighlight setHighlightedNode:]):
+ (-[WebNodeHighlight highlightedNode]):
+ (-[WebNodeHighlight dealloc]):
+ (-[WebNodeHighlight attachHighlight]):
+ (-[WebNodeHighlight delegate]):
+ (-[WebNodeHighlight detachHighlight]):
+ (-[WebNodeHighlight show]):
+ (-[WebNodeHighlight hide]):
+ (-[WebNodeHighlight animationDidEnd:]):
+ (-[WebNodeHighlight ignoresMouseEvents]):
+ (-[WebNodeHighlight highlightView]):
+ (-[WebNodeHighlight setDelegate:]):
+ (-[WebNodeHighlight setHolesNeedUpdateInTargetViewRect:]):
+ (-[WebNodeHighlight setIgnoresMouseEvents:]):
+ (-[WebNodeHighlight targetView]):
+ (-[WebNodeHighlight _computeHighlightWindowFrame]):
+ (-[WebNodeHighlight _repositionHighlightWindow]):
+ * WebInspector/WebNodeHighlightView.h:
+ * WebInspector/WebNodeHighlightView.m:
+ (-[WebNodeHighlightView initWithWebNodeHighlight:]):
+ (-[WebNodeHighlightView dealloc]):
+ (-[WebNodeHighlightView detachFromWebNodeHighlight]):
+ (-[WebNodeHighlightView drawRect:]):
+ (-[WebNodeHighlightView webNodeHighlight]):
+ (-[WebNodeHighlightView fractionFadedIn]):
+ (-[WebNodeHighlightView setFractionFadedIn:]):
+ (-[WebNodeHighlightView setHolesNeedUpdateInRect:]):
+ (-[WebNodeHighlightView _holes]):
+
+ WebView changes needed for the new Inspector.
+
+ * WebView/WebView.mm: Remove the old _inspectElement method now that
+ this is handled by WebCore.
+ (-[WebView _isClosed]): Added.
+ (-[WebView initWithFrame]): Give each Page an InspectorClient to
+ enable the Inspector.
+ * WebView/WebViewPrivate.h:
+
+ Updates needed for WebCore changes.
+
+ * WebCoreSupport/WebContextMenuClient.h:
+ * WebCoreSupport/WebContextMenuClient.mm:
+ * WebCoreSupport/WebViewFactory.mm:
+ (-[WebViewFactory contextMenuItemTagInspectElement]):
+ * WebView/WebUIDelegatePrivate.h:
+
+ Remove old Inspector code.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::assignIdentifierToInitialRequest):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ * WebInspector/WebInspector.m: Removed.
+ * WebInspector/WebInspectorPanel.h: Removed.
+ * WebInspector/WebInspectorPanel.m: Removed.
+ * WebInspector/webInspector/Images/button.png: Removed.
+ * WebInspector/webInspector/Images/buttonDivider.png: Removed.
+ * WebInspector/webInspector/Images/buttonPressed.png: Removed.
+ * WebInspector/webInspector/Images/close.png: Removed.
+ * WebInspector/webInspector/Images/closePressed.png: Removed.
+ * WebInspector/webInspector/Images/downTriangle.png: Removed.
+ * WebInspector/webInspector/Images/menu.png: Removed.
+ * WebInspector/webInspector/Images/menuPressed.png: Removed.
+ * WebInspector/webInspector/Images/popup.png: Removed.
+ * WebInspector/webInspector/Images/popupPressed.png: Removed.
+ * WebInspector/webInspector/Images/resize.png: Removed.
+ * WebInspector/webInspector/Images/rightTriangle.png: Removed.
+ * WebInspector/webInspector/Images/scrollThumbBottom.png: Removed.
+ * WebInspector/webInspector/Images/scrollThumbMiddle.png: Removed.
+ * WebInspector/webInspector/Images/scrollTrackBottom.png: Removed.
+ * WebInspector/webInspector/Images/upTriangle.png: Removed.
+ * WebInspector/webInspector/inspector.css: Removed.
+ * WebInspector/webInspector/inspector.html: Removed.
+ * WebInspector/webInspector/inspector.js: Removed.
+ * WebInspector/webInspector/scrollarea.js: Removed.
+ * WebInspector/webInspector/scrollbar.js: Removed.
+ * WebInspector/webInspector/utilities.js: Removed.
+ * WebView/WebFrame.mm:
+ (-[WebFramePrivate dealloc]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView menuForEvent:]):
+
+ Build-fu:
+
+ * WebKit.exp:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-06-20 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5263541> REGRESSION (Safari 3 Beta 1): Pressing Delete doesn't delete an HTML message in Mail
+
+ Mail wasn't receiving the keyDown event because WebFrameView was blocking it.
+ It blocks the event and moves back/forward on Delete/Shift+Delete if the
+ back/forward list is enabled.
+
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView keyDown:]): Check to see if the BackForwardList is
+ enabled. It always exists.
+
+2007-06-19 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/5266289> REGRESSION (Safari 3 Beta 1): Incoming iChat messages are delayed
+
+ * WebView/WebDocumentLoaderMac.mm:
+ (needsAppKitWorkaround):
+ New function which checks if the frame load delegate belongs to AppKit.
+
+ (WebDocumentLoaderMac::setDataSource):
+ If the frame load delegate belongs to AppKit, set m_deferMainResourceDataLoad to false.
+
+2007-06-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ - fixed <rdar://problem/5272011> Hole for find-on-page match in subframe isn't clipped by frame bounds
+
+ * WebView/WebView.mm:
+ (-[WebView rectsForTextMatches]):
+ intersect the HTMLView's computed rect with the visible rect for that view
+
+2007-06-19 Jim Correia <jim.correia@pobox.com>
+
+ Reviewed by Kevin Decker
+
+ * Carbon/HIWebView.m:
+ (WindowHandler): HIObjectIsOfClass requires non-NULL input on Tiger. Reworked Kevin Decker's patch to remove the conditional compilation for Tiger, yet still avoid crashing BBEdit.
+
+2007-06-18 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Beth.
+
+ Build fix.
+
+ * WebCoreSupport/WebChromeClient.mm:
+
+2007-06-18 Kevin Decker <kdecker@apple.com>
+
+ * Carbon/HIWebView.m:
+ (WindowHandler): Fixed the Tiger build; ControlKind wasn't defined.
+
+2007-06-18 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Fixed: <rdar://problem/5276135> With Safari 3 Tiger Beta installed, a crash occurs in BBEdit while mousing down and dragging outside of HTML preview window
+
+ * Carbon/HIWebView.m:
+ (WindowHandler): Because the fix for 5051616 causes Tiger to crash in HIToolbox (but not on Leopard), I reverted back to using GetControlKind
+ on Tiger only, instead of HIObjectIsOfClass.
+
+2007-06-16 David Hyatt <hyatt@apple.com>
+
+ Back out fix for 13972. Quicktime will no longer clip correctly. :(
+ Too many regressions in Mail caused by inserting an extra view into the
+ hierarchy. Can revisit later.
+
+ Reviewed by olliej
+
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController destroyPlugin:]):
+ (-[WebPluginController destroyAllPlugins]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge pluginViewWithPackage:attributeNames:attributeValues:baseURL:DOMElement:loadManually:]):
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView addSubview:]):
+ (-[WebHTMLView willRemoveSubview:]):
+
+2007-06-15 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Darin.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=14053
+ Autogenerate JS binding for Rect
+
+ - Fix conflicts by using ::Rect instead of Rect.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ (-[WebBaseNetscapePluginView tellQuickTimeToChill]):
+ (-[WebBaseNetscapePluginView invalidateRegion:]):
+ (-[WebBaseNetscapePluginView _printedPluginBitmap]):
+
+2007-06-15 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Kevin.
+
+ A better fix for <rdar://problem/5271774>. Only try to access the element if the
+ view has an associated window. This also works with GC. (Fix suggested by Kevin.)
+
+ * Plugins/WebKitPluginContainerView.mm:
+ (-[WebKitPluginContainerView dealloc]):
+ (-[WebKitPluginContainerView visibleRect]):
+
+2007-06-15 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Kevin.
+
+ <rdar://problem/5271774> REGRESSION: A crash occurs when closing a window that contains a QT movie
+
+ In some cases, calling [super dealloc] might end up calling visibleRect, so make sure to
+ set _element to 0 so we won't send a message to a freed object and crash.
+
+ * Plugins/WebKitPluginContainerView.mm:
+ (-[WebKitPluginContainerView dealloc]):
+ (-[WebKitPluginContainerView visibleRect]):
+
+2007-06-14 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff.
+
+ Call cleanupScriptObjectsForPlugin on the frame after destroying the plug-in.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView _destroyPlugin]):
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController destroyPlugin:]):
+ (-[WebPluginController destroyAllPlugins]):
+
+2007-06-13 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adele Peterson
+
+ - fixed <rdar://problem/5267607> Clicking the "Save to Downloads" button in
+ PDF overlay too soon results in corrupt file
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView PDFViewSavePDFToDownloadFolder:]):
+ Just beep if the document isn't available yet, since trying to save it as a file
+ really isn't a good idea.
+
+2007-06-12 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Darin.
+
+ Use correct size for BITMAPINFOHEADER -- whoops.
+
+ * win/WebIconDatabase.cpp:
+ (createDIB):
+ (WebIconDatabase::getOrCreateDefaultIconBitmap):
+
+2007-06-10 David Hyatt <hyatt@apple.com>
+
+ Fix for bug 14037, make sure respondsToSelector does the write thing
+ when invoked on a WebKit plugin's container view.
+
+ Reviewed by Mark Rowe
+
+ * Plugins/WebKitPluginContainerView.mm:
+ (-[WebKitPluginContainerView respondsToSelector:]):
+
+2007-06-08 John Sullivan <sullivan@apple.com>
+
+ * WebView/WebViewPrivate.h:
+ Added a FIXME
+
+2007-06-07 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by Tristan.
+
+ <rdar://problem/5250997> A crash occurs when selecting Undo Typing for a page that has been closed in tab
+
+ * WebView/WebView.mm:
+ (-[WebView _clearUndoRedoOperations]): Added.
+ * WebView/WebViewPrivate.h:
+
+2007-06-07 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Sam "The Intern" Weinig.
+
+ Don't be overzealous with the input checks, firstRectForCharacterRange
+ can be determined even when there is not an active editable region.
+
+ This unbreaks editing/input/range-for-empty-document which was broken
+ by aforementioned overzealousness.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView firstRectForCharacterRange:]):
+
+2007-06-07 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Justin.
+
+ Add checks to make sure we don't try to create, use
+ or return invalid ranges to TSM when it calls us despite
+ not currently being in an editable region.
+
+ * WebView/WebHTMLView.mm:
+ (isTextInput):
+ (-[WebHTMLView textStorage]):
+ (-[WebHTMLView firstRectForCharacterRange:]):
+ (-[WebHTMLView selectedRange]):
+ (-[WebHTMLView attributedSubstringFromRange:]):
+
+2007-06-06 David Hyatt <hyatt@apple.com>
+
+ Make sure to hand back a script object for webkit plugins (the container
+ view forwards to its plugin child).
+
+ Reviewed by sullivan
+
+ * Plugins/WebKitPluginContainerView.h:
+ * Plugins/WebKitPluginContainerView.mm:
+ (-[WebKitPluginContainerView objectForWebScript]):
+
+2007-06-06 David Hyatt <hyatt@apple.com>
+
+ Fix for bug 13972, quicktime doesn't respect CSS clip and overflow properties.
+ Make sure that calls to [NSView visibleRect] will do the right thing for both
+ Netscape plugins and WebKit plugins.
+
+ Reviewed by olliej
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView visibleRect]):
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ (-[WebBaseNetscapePluginView isOpaque]):
+ * Plugins/WebKitPluginContainerView.h: Added.
+ * Plugins/WebKitPluginContainerView.mm: Added.
+ (-[WebKitPluginContainerView initWithFrame:DOMElement:]):
+ (-[WebKitPluginContainerView dealloc]):
+ (-[WebKitPluginContainerView visibleRect]):
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController destroyAllPlugins]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge pluginViewWithPackage:attributeNames:attributeValues:baseURL:DOMElement:loadManually:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView addSubview:]):
+ (-[WebHTMLView willRemoveSubview:]):
+
+2007-06-04 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Geoff and Justin.
+
+ Fix for <rdar://problem/5246941> Clicking URL field on
+ Safari causes halt for a minute when using input methods.
+ and <rdar://problem/5245964> Safari hangs for several
+ seconds when trying to select text using mouse
+
+ This is a by product of the textStorage hack used to fix
+ rdar://problem/5000470 -- TSM calls textStorage repeatedly
+ when changing focus, on certain mouse events, etc. If there
+ is no selection/editable region we repeatedly create an
+ NSAttributedString from the full document. If the document is
+ sufficiently long this starts consuming an inordinate amount of
+ time.
+
+ This check should really have been present in the original
+ patch.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView textStorage]):
+
+2007-05-31 David Hyatt <hyatt@apple.com>
+
+ Fix for 11768, Flash plugin does not respect clips set by CSS.
+
+ Reviewed by olliej
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+
+2007-05-30 Mark Rowe <mrowe@apple.com>
+
+ Build fixes after r21889.
+
+ * ForwardingHeaders/kjs/function.h: Added.
+
+2007-05-29 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Geoff.
+
+ 64-bit build fix. Ensure that use of WebNSUInteger in headers is matched by WebNSUInteger in implementations.
+
+ * DefaultDelegates/WebScriptDebugServer.h:
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer webView:didParseSource:baseLineNumber:fromURL:sourceId:forWebFrame:]):
+ (-[WebScriptDebugServer webView:failedToParseSource:baseLineNumber:fromURL:withError:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServerPrivate.h:
+ * History/WebBackForwardList.mm:
+ (-[WebBackForwardList setPageCacheSize:]):
+ (-[WebBackForwardList pageCacheSize]):
+ * WebView/WebView.mm:
+ (-[WebView markAllMatchesForText:caseSensitive:highlight:limit:]):
+
+2007-05-26 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ * MigrateHeaders.make: Added dependency on this makefile itself, which is
+ useful when you change the sed command or other aspect of this file. My build
+ failed until I made this fix.
+
+2007-05-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Fixed <rdar://problem/5055182> The page cache has no global cap.
+
+ The main WebKit changes are:
+ 1. Changed -[WebBackForwardList setPageCacheSize] and -[WebBackForwardList
+ pageCacheSize] to accomodate the new global page cache model, updating
+ their documentation.
+
+ 2. Added -[WebPreferences setShouldUsePageCache] and -[WebPreferences
+ shouldUsePageCache] as pending public API.
+
+ 3. Centralized calculation of object cache and page cache sizes inside
+ WebPreferences.
+
+ Cchanged our old behavior of reading a preference and applying a fudge
+ factor with a new behavior of just using the preference directly. The
+ old behavior was confusing and often inappropriate. (For example, if
+ you set a page cache size of 100, a 256MB machine would somewhat
+ arbitrarily reduce that number to 98. ???)
+
+ * WebView/WebView.mm: Added support for two flags to determine whether
+ to use the page cache. If either -[WebBackForwardList setPageCacheSize:0]
+ or -[WebPreferences setShouldUsePageCache:NO] is called, we don't use
+ the page cache.
+
+2007-05-25 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/5219089> Changes for migration of DictionaryServices
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]): look for the HIDictionaryWindowShow symbol in HIToolbox
+
+2007-05-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ Fixed global initializer (like you fix a dog).
+
+ I'm not sure how our script missed this. I tested, and it generally doesn't
+ seem to work very well.
+
+ * WebView/WebHTMLView.mm: Allocate lazily to avoid the performance hit of
+ a global initializer.
+ (promisedDataClient):
+ (-[WebHTMLViewPrivate dealloc]):
+ (-[WebHTMLViewPrivate clear]):
+ (-[WebHTMLView setPromisedDragTIFFDataSource:WebCore::]):
+
+2007-05-25 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ <rdar://problem/5228371> - REGRESSION - Certain mail message bodies display as empty
+
+ This is due to http://trac.webkit.org/projects/webkit/changeset/21480 which unintentionally
+ made applewebdata urls result in check.call(false) instead of check.call(true)
+
+ Best place for a fix is to have the FrameLoaderClient::canHandleRequest() call return true, which
+ really is rooted in WebView
+
+ <rdar://problem/5229587> tracks adding a layout test
+
+ * WebView/WebView.mm:
+ (+[WebView _canHandleRequest:]): Return true for applewebdata URLs
+
+2007-05-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler, Tim Hatcher.
+
+ "unsigned" => "WebNSUInteger" in public API.
+
+ * History/WebBackForwardList.h:
+ * WebView/WebScriptDebugDelegate.h:
+ * WebView/WebUIDelegate.h:
+ * WebView/WebViewPrivate.h:
+
+2007-05-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Moved JavaScriptCore-related pending public API to public API.
+
+ * MigrateHeaders.make: Hack to prevent <JavaScriptCore/JSBase.h> from
+ automatically converting to <WebKit/JSBase.h>
+
+ Moved -windowObject and -globalContext
+
+ * WebView/WebFramePrivate.h: from here
+ * WebView/WebFrame.h: to here
+ * WebView/WebFrame.mm: and out of its temporary category
+
+ Moved -didClearWindowObject:forFrame:
+
+ * WebView/WebViewPrivate.h: from here
+ * WebView/WebFrameLoadDelegate.h: to here
+
+2007-05-25 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders and Tim
+
+ - fixed <rdar://problem/5226000> REGRESSION: In Gmail and Mail, a hang occurs when attempting
+ to grammar/spellcheck a word in a reply
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::checkGrammarOfString):
+ Fixed recently-introduced false assumption that NSNotFound == -1
+
+2007-05-24 dethbakin <bdakin@apple.com>
+
+ Reviewed by Geoff.
+
+ Fix for <rdar://problem/5023545> QuickBooks Pro 2007:hang/crash
+ after closing QuickBooks Tutorial Center with Leopard9A377
+
+ We can hit a race condition where drawRect will be called after the
+ WebView has closed. Quickbooks does not properly close the WebView
+ and set the UIDelegate to nil, so the UIDelegate is stale and we
+ crash. This is a regression because the code that uses the
+ UIDelegate in the drawRect code path was only added recently. The
+ method that the UIDelegate calls into is new -- it does not exist
+ on Tiger -- so there is no harm in not running this code for
+ applications linked against older WebKits. Other applications may
+ run into this same bug so I am not doing a bundle
+ check...particularly because, as I mentioned, the new UIDelegate
+ call would not be implemented by older clients anyway.
+
+ * Misc/WebKitVersionChecks.h:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView drawSingleRect:]):
+
+2007-05-24 Darin Adler <darin@apple.com>
+
+ * English.lproj/StringsNotToBeLocalized.txt: Update for recent changes.
+
+2007-05-24 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam, Darin, and Geoff.
+
+ Fix for <rdar://problem/5000470> REGRESSION: The IM reconvert
+ function returns incorrect symbol due to inconsistent range
+ domains in TSM
+
+ Text Services Management uses ranges provided by the
+ NSTextInput API to index into the string return by
+ -[WebHTMLView string]. As a result some input methods
+ incorrectly get their candidate text from the beginning
+ of the document instead of from the input element.
+
+ TSM prefers to query -textStorage over -string so as a
+ workaround we provide an implementation of -textStorage that
+ returns the content of the current text input. TSM only ever
+ queries the result of textStorage as an NSAttributedString so
+ we do not need to implement a fake NSTextStorage class
+
+ This should not cause harm to anything else as textStorage is
+ actually a method on NSTextView, which we clearly are not. TSM
+ only queries the method because it uses respondsToSelector to
+ control behaviour.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView textStorage]):
+
+
+2007-05-24 David Harrison <harrison@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/5225343> REGRESSION: With View Source window opened, navigating to a different URL in the browser window results in a crash at WebCore::FrameLoader::frameHasLoaded()
+
+ _private->loader->frameLoader() was not being nil checked.
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource request]):
+ Add nil check for _private->loader->frameLoader()
+
+2007-05-23 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/3663808> Resize large images to fit in the browser window
+
+ Add new WebPreferences SPI.
+
+ * WebView/WebPreferenceKeysPrivate.h:
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+ (-[WebPreferences enableAutomaticImageResizing]):
+ (-[WebPreferences setEnableAutomaticImageResizing:]):
+ * WebView/WebPreferencesPrivate.h:
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-05-23 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Darin.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=13830
+ Auto-generate JS DOM bindings for HTMLDocument and most of the rest
+ of HTMLElement
+
+ * MigrateHeaders.make: add DOMHTMLDocumentPrivate.h
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-05-23 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Geoff.
+
+ Fix for <rdar://problem/5223782> REGRESSION: Can't drag and drop a standalone image
+
+ The main resource for a standalone image webarchive has the same mimetype as the
+ underlying image.
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_writePromisedRTFDFromArchive:containsImage:]):
+
+2007-05-22 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Adam.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=13833
+ Add ObjC DOM binding for HTMLMarqeeElement
+
+ - Also adds missing DOMHTMLFramePrivate.
+
+ * MigrateHeaders.make:
+
+2007-05-22 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ * WebInspector/webInspector/treeoutline.js: Use ownerDocument instead of non-standard
+ document property.
+
+2007-05-22 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Adding some asserts to help detect other cases of <rdar://problem/5171145>
+
+ * WebCoreSupport/WebFrameBridge.mm: (-[WebFrameBridge makeFirstResponder:]):
+
+2007-05-22 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Kevin (Sarge)
+
+ <rdar://problem/5219885> - Crash after closing a inline popup ad at http://news.yahoo.com/
+
+ This regressed in http://trac.webkit.org/projects/webkit/changeset/21618
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame dataSource]): Null check the frameloader
+
+2007-05-21 Adele Peterson <adele@apple.com>
+
+ Fix by Darin, reviewed by me.
+
+ Fix for <rdar://problem/5171145> Safari crashed closing tab in NSInputContext updateInputContexts
+
+ * WebView/WebFrameView.mm: (-[WebFrameView _setDocumentView:]): If the old view is the first responder,
+ then set the window's first responder to nil so we don't leave the window pointing to a view that's no longer in it.
+
+2007-05-21 Brady Eidson <beidson@apple.com>
+
+ Making the importance of my last change more clear
+
+ * WebView/WebViewPrivate.h: "Leave for Dashboard, people!"
+
+2007-05-21 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Kevin (Sarge)
+
+ <rdar://problem/5217124> - Re-add mistakenly removed SPI
+
+ * WebView/WebView.mm:
+ (-[WebView handleAuthenticationForResource:challenge:fromDataSource:]):
+ * WebView/WebViewPrivate.h:
+
+2007-05-21 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Ada.
+
+ <rdar://problem/5200816> REGRESSION: With Shiira 1.2.2 , I can't open embedded link in flash object by clicking (http:/www.adobe.com )
+
+ Null check the request.
+
+ * WebView/WebView.mm:
+ (+[WebView _canHandleRequest:]):
+
+2007-05-19 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/5205358> REGRESSION (r21367): All messages appear entirely blank when running Mail off of tip of tree WebKit
+
+ The fix is to return nil from [WebFrame dataSource] when it has not loaded anything but the fake
+ empty initial document. However, WebKit still needs the real data source internally, so I also
+ added a [WebFrame _dataSource] method that skips this check, and made WebKit use it throughout.
+
+ * Misc/WebNSAttributedStringExtras.mm:
+ (fileWrapperForElement):
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView dataSource]):
+ * Plugins/WebNullPluginView.mm:
+ (-[WebNullPluginView viewDidMoveToWindow]):
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController URLPolicyCheckReferrer]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge dataSource]):
+ (-[WebFrameBridge redirectDataToPlugin:]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::makeDocumentView):
+ (WebFrameLoaderClient::forceLayoutForNonHTML):
+ (WebFrameLoaderClient::prepareForDataSourceReplacement):
+ (WebFrameLoaderClient::canCachePage):
+ * WebCoreSupport/WebViewFactory.mm:
+ (-[WebViewFactory bridgeForView:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebArchiver.mm:
+ (+[WebArchiver archiveFrame:]):
+ (+[WebArchiver archiveMainResourceForFrame:]):
+ (+[WebArchiver _archiveWithMarkupString:fromFrame:nodes:]):
+ (+[WebArchiver archiveSelectionInFrame:]):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _addChild:]):
+ (-[WebFrame _dataSource]):
+ (-[WebFrame DOMDocument]):
+ (-[WebFrame dataSource]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _setPrinting:minimumPageWidth:maximumPageWidth:adjustViewSize:]):
+ * WebView/WebRenderNode.mm:
+ (-[WebRenderNode initWithWebFrameView:]):
+ * WebView/WebView.mm:
+ (-[WebView _mainFrameOverrideEncoding]):
+ (-[WebView mainFrameURL]):
+ (-[WebView mainFrameTitle]):
+ (-[WebView mainFrameIcon]):
+ (-[WebView validateUserInterfaceItemWithoutDelegate:]):
+ (-[WebView replaceSelectionWithArchive:]):
+ (-[WebView _isLoading]):
+ (-[WebView _performTextSizingSelector:withObject:onTrackingDocs:selForNonTrackingDocs:newScaleFactor:]):
+ (-[WebView _notifyTextSizeMultiplierChanged]):
+
+2007-05-18 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Sam.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=13782
+ REGRESSION (r21528-r21533): Failing editing/selection/drag-in-iframe in pixel mode
+
+ r21533 made used a DOMElement as the source for promise data, this meant it had to
+ clear the dragging pasteboard following the drag. In DRT a drag is non-blocking
+ so this resulted in us prematurely clearing the pasteboard.
+
+ This patch avoids this problem by referencing the source CachedImage rather than the
+ DOMElement, so we don't need to worry about retaining an entire document forever, so
+ we don't need to clear the dragging pasteboard following the drag.
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (imageFromElement):
+ Extract the underlying CachedImage from a DOMElement
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:source:]):
+ Use a CachedImage instead of a DOMElement
+
+ * WebCoreSupport/WebDragClient.mm:
+ (WebDragClient::startDrag):
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLViewPrivate dealloc]):
+ (-[WebHTMLViewPrivate clear]):
+ (-[WebHTMLView pasteboardChangedOwner:]):
+ (-[WebHTMLView pasteboard:provideDataForType:]):
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]):
+ (-[WebHTMLView WebCore::]):
+ (-[WebHTMLView setPromisedDragTIFFDataSource:WebCore::]):
+ Use CachedImage rather than DOMElement as promised data source
+
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-05-18 Tristan O'Tierney <tristan@apple.com>
+
+ Reviewed by Brady E.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::download):
+ asked the webframeloaderclient for its webview's history and
+ injected the originated url into the created WebDownload
+
+2007-05-18 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ Improvement to WebKit part of fix for 5201499 based on more modern understanding. (That is,
+ a couple of hours more modern.)
+
+ * WebView/WebUIDelegatePrivate.h:
+ add showPanel: parameter to just-introduced delegate method webView:saveFrameView:
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView PDFViewSavePDFToDownloadFolder:]):
+ pass NO for new showPanel: parameter, and update comment
+
+2007-05-18 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5204792> REGRESSION (r21367): System widgets are drawn with vertical/horizontal scroll bars
+
+ No test because the bug requires calling setAllowsScrolling: to reproduce.
+
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView setAllowsScrolling:]): Update the FrameView's scroll state as well as the one
+ on WebDynamicScrollBarsView, otherwise this setting won't stick if the frame has already loaded
+ a document.
+
+2007-05-18 Geoffrey Garen <ggaren@apple.com>
+
+ Fixed spelling error.
+
+ * WebView/WebViewPrivate.h:
+
+2007-05-18 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ WebKit part of fix for 5201499 (support for PDFKit UI for saving PDFs to disk)
+
+ Also, the PDFKit mechanism for notifying clients about "Open File Externally" was
+ changed from a notification to a delegate method. The notification was new to
+ Leopard, so removing it doesn't affect clients in the field.
+
+ * WebView/WebUIDelegatePrivate.h:
+ Declared new UI delegate method webView:saveFrameView:, analogous to the existing
+ webView:printFrameView:
+
+ * WebView/WebPDFView.mm:
+ removed declaration of _webkit_PDFKitLaunchNotification
+ (-[WebPDFView viewDidMoveToWindow]):
+ don't observe _webkit_PDFKitLaunchNotification
+ (-[WebPDFView viewWillMoveToWindow:]):
+ ditto
+ (-[WebPDFView PDFViewOpenPDFInNativeApplication:]):
+ new PDFKit delegate method, replaces our use of _webkit_PDFKitLaunchNotification
+ (-[WebPDFView PDFViewSavePDFToDownloadFolder:]):
+ new PDFKit delegate method, calls through to new WebKit UI delegate method
+
+2007-05-17 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Justin.
+
+ Fix for <rdar://problem/4244861> Safari fails to create image file
+ after releasing dragged image that has changed on source page
+
+ This patch fixes this bug by manually creating an NSFileWrapper from
+ the TIFF promise data for a drag if it is available. This bypasses
+ the problem of the required resource no longer being held due to page
+ loads or other constraints.
+
+ We need to leave the old path in place to allow for the case where
+ the promised data is not available.
+
+ * WebCoreSupport/WebDragClient.mm:
+ (WebDragClient::declareAndWriteDragImage):
+ Always use the top WebHTMLView as the pasteboard owner, this is
+ safe as we only use the owner for resolving promised types.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _writeSelectionToPasteboard:]):
+ (-[WebHTMLView writeSelectionToPasteboard:types:]):
+ Always use the top WebHTMLView as the pasteboard owner.
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]):
+ Add path to create NSFileWrapper from promise data.
+
+2007-05-17 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Fix for <rdar://problem/4343832> Trying to drag a large 6.2MB jpeg image
+ out of Safari is unexpectedly slow (4 copies of image plus RTF document on pasteboard)
+
+ This patch causes the construction of the RTF and TIFF data to be delayed until requested.
+
+ We delay TIFF construction from a DOMElement as this may require generating TIFF data
+ from the CachedImage, which is slow. To allow the TIFF data to be created later the
+ it's necessary to add a reference to the source DOMElement to the view.
+
+ * Misc/WebNSPasteboardExtras.h:
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_writePromisedRTFDFromArchive:containsImage:]):
+ Implements the delayed write of RTF data
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:source:]):
+ Set up the pasteboard to allow the data writing to be delayed
+ (-[NSPasteboard _web_declareAndWriteDragImageForElement:URL:title:archive:source:]):
+ Now we need to pass the WebHTMLView on to _web_writeImage:element:URL:title:archive:types:source:
+ * WebCoreSupport/WebDragClient.mm:
+ (WebDragClient::startDrag):
+ Clear the dragging pasteboard once the drag has ended to ensure we don't hold references
+ to anything longer than we need to.
+ (WebDragClient::declareAndWriteDragImage):
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLViewPrivate dealloc]):
+ (-[WebHTMLViewPrivate clear]):
+ (-[WebHTMLView pasteboardChangedOwner:]):
+ Make sure we clear out the DOMElement reference once it is no longer needed
+ (-[WebHTMLView pasteboard:provideDataForType:]):
+ Provide delayed data
+ (-[WebHTMLView _writeSelectionToPasteboard:]):
+ Make sure we set pasteboard ownership correctly
+ (-[WebHTMLView promisedDragTIFFDataSource]):
+ (-[WebHTMLView setPromisedDragTIFFDataSource:]):
+ (-[WebHTMLView writeSelectionToPasteboard:types:]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLViewPrivate.h:
+
+ * WebView/WebView.mm:
+ (-[WebView _writeImageForElement:withPasteboardTypes:toPasteboard:]):
+
+2007-05-16 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5207156> Hamachi test tool causes assertion in FormCompletionController in Safari
+
+ Update for WebCore changes.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+
+2007-05-15 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Sam and Geoff.
+
+ Removing dead code left behind from drag and drop refactoring.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebView/WebHTMLView.mm:
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-05-15 Bruce Q Hammond <bruceq@apple.com>
+
+ Reviewed by Darin.
+
+ Correction of previous patch for http://bugs.webkit.org/show_bug.cgi?id=13578
+ This corrects the sign of the Y-Axis origin adjustment.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+
+2007-05-15 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ Patch: fixed <rdar://problem/5198890> .5% performance regression caused
+ by r21307
+
+ The only code r21307 added that runs during the PLT is a frame load delegate
+ -respondsToSelector: call inside windowObjectCleared(), so it seems like
+ our message dispatch overhead for the frame load delegate is significant.
+
+ This patch is a straight port of Maciej's fix for the same problem in the
+ resource load delegate. The solution is simple enough: don't use Objective-C.
+ Instead, use a special structure that caches which methods the delegate
+ implements, along with pointers to those methods.
+
+ I verified each frame load delegate callback in the debugger, except for
+ -webView:didFailLoadWithError:forFrame:, which is not implemented by Safari
+ or DumpRenderTree.
+
+ * WebKit/DefaultDelegates/WebDefaultFrameLoadDelegate.h: Removed.
+ * WebKit/DefaultDelegates/WebDefaultFrameLoadDelegate.m: Removed.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge windowObjectCleared]): I also removed a misleading
+ comment here. The JS debugger caches the windowScriptObject, so you do
+ need to re-create the debugger every time you invalidate the old
+ WebScriptObject wrapper for the window object and create a new one, or
+ the debugger will stop working. We could fix this in a number of ways,
+ but <rdar://problem/4608404> is not the key issue.
+
+2007-05-15 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Hyatt and Lars.
+
+ - fixed <rdar://problem/5201758> REGRESSION: Stop button enabled and other problems caused by [WebView currentURL] returning non-nil for empty window
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource request]): Return nil when we are still showing the initial empty doc
+
+2007-05-14 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Updated for WebCore move to PageCache singleton. Also removed some WebCore::
+ prefixes and replaced them with 'using namespace WebCore'.
+
+ * History/WebHistoryItem.mm:
+ (+[WebHistoryItem _releaseAllPendingPageCaches]):
+ (-[WebWindowWatcher windowWillClose:]):
+
+2007-05-13 Darin Adler <darin@apple.com>
+
+ - one more retain/release for a tiny bit more robustness
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _updatePreferences:]): [prefs release]
+ (-[WebPDFView _updatePreferencesSoon]): [prefs retain]
+
+2007-05-13 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ - fix <rdar://problem/5188400> Webkit crashes going back from PDF at perl.org site
+
+ * WebView/WebPDFView.h: Replace _updatePreferencesTimer with _willUpdatePreferencesSoon BOOL.
+ Also remove unneeded @public that gives other classes access to our dataSource member.
+
+ * WebView/WebPDFView.mm: Rearrange top of file a bit, remove forward declaration of the
+ _cancelUpdatePreferencesTimer method.
+ (-[WebPDFView dealloc]): Removed call to _cancelUpdatePreferencesTimer.
+ (-[WebPDFView _updatePreferencesNow:]): Added WebPreferences parameter. This sidesteps problems
+ where the dataSource is no longer present by not looking at the dataSource field at all.
+ Also removed the call to _cancelUpdatePreferencesTimer, added code to set _willUpdatePreferencesSoon
+ to NO and added a release to balance a retain I did in _updatePreferencesSoon.
+ (-[WebPDFView _updatePreferencesSoon]): Changed to use performSelectorAfterDelay instead of
+ an NSTimer. Pass in the preferences object as a parameter, since we might not be able to get to
+ the dataSource when the timer fires.
+
+2007-05-10 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ "IconDatabase::sharedIconDatabase()" => "iconDatabase()" for terseness.
+
+2007-05-10 Adele Peterson <adele@apple.com>
+
+ Reviewed by Hyatt.
+
+ WebKit part of fix for <rdar://problem/4100616> Doing a "find" in RSS doesn't scroll to result
+
+ Updated to use selectionRect instead of visibleSelectionRect. selectionRect() now returns the visible rect by default.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ (-[WebHTMLView selectionImageRect]):
+
+2007-05-10 dethbakin <bdakin@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for <rdar://problem/5191941> Leopard: Adobe Acrobat 8:
+ Distiller 8 needs same check fix as 4992521
+
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]): Adobe
+ Distiller needs the same quirk.
+
+2007-05-10 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - WebKit part of fix for:
+ <rdar://problem/5063277> blank screen after login to Citibank Online (accessing document before frame starts loading cancels load)
+ <rdar://problem/5159541> REGRESSION (r20972): Wall Street Journal pages replaced by advertisements (13465)
+
+ The basic approach is to have Frames start out containing an empty document instead of absolutely nothing,
+ so there is no need to initialize them on demand. Various side effects of that cause both of these bugs.
+
+ However, this caused many regressions so I had to fix the fallout.
+
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::takeFocus): Avoid focus cycle problems (can happen in DumpRenderTree
+ with initial empty document now).
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge finishInitializingWithPage:frameName:frameView:ownerElement:]): init the frame.
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]): return image type when appropriate
+ * WebView/WebFrame.mm:
+ (-[WebFrame stopLoading]): use stopForUserCancel().
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _makeDocumentViewForDataSource:]): assume html when no mime type available.
+ * WebView/WebView.mm:
+ (-[WebView becomeFirstResponder]): Track whether we are becoming first responder from
+ outside the view.
+ (-[WebView _becomingFirstResponderFromOutside]): Return this value.
+ * WebView/WebViewInternal.h:
+
+2007-05-09 Oliver Hunt <oliver@apple.com>
+
+ rs=Adele.
+
+ The previous patch (r21346) broke editing, rolling out
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]):
+ (-[WebHTMLView doCommandBySelector:]):
+
+2007-05-09 Adele Peterson <adele@apple.com>
+
+ Reviewed by Oliver.
+
+ Re-applying fix for <rdar://problem/5107538> REGRESSION: Page scroll when selecting characters from inline input candidate window by arrow buttons
+ http://bugs.webkit.org/show_bug.cgi?id=13263
+
+ We don't need to call interpretKeyEvents for cmd-key events as
+ they events will be interpreted by performKeyEquivalent.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]):
+ (-[WebHTMLView doCommandBySelector:]):
+
+2007-05-09 Mark Rowe <mrowe@apple.com>
+
+ Build fix to keep the buildbot happy.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+
+2007-05-08 Bruce Q Hammond <bruceq@apple.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=13578
+ Bug 13578: When QD plugins draw to an offscreen bitmap the origin is not correct
+
+ Now we have correct handling of the origin when QD plugins draw to
+ offscreen bitmaps.
+ Also the clipping code for this path was doing unnecessary work which
+ caused incorrect results; it has been removed.
+
+ This change should not affect Safari and in general will only affect
+ plugins (e.g. Flash) drawing to a CGBitmapContext.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+
+2007-05-08 Steve Falkenburg <sfalken@apple.com>
+
+ Reviewed by Darin.
+
+ Implemented spelling/grammar related WebEditorClient methods.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::ignoreWordInSpellDocument): Added. Call through to NSSpellChecker.
+ (WebEditorClient::learnWord): Added. Call through to NSSpellChecker.
+ (WebEditorClient::checkSpellingOfString): Added. Call through to NSSpellChecker.
+ (WebEditorClient::checkGrammarOfString): Added. Call through to NSSpellChecker.
+ (WebEditorClient::updateSpellingUIWithGrammarString): Added. Call through to NSSpellChecker.
+ (WebEditorClient::updateSpellingUIWithMisspelledWord): Added. Call through to NSSpellChecker.
+ (WebEditorClient::showSpellingUI): Added. Call through to NSSpellChecker.
+ (WebEditorClient::spellingUIIsShowing): Added. Call through to NSSpellChecker.
+ (WebEditorClient::getGuessesForWord): Added. Call through to NSSpellChecker.
+
+2007-05-08 Steve Falkenburg <sfalken@apple.com>
+
+ Reviewed by Ada.
+
+ Slight modification to last editor method fix.
+
+ * WebCoreSupport/WebEditorClient.h:
+ (WebEditorClient::updateSpellingUIWithGrammarString):
+
+2007-05-07 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ Fixed <rdar://problem/5140447> API for fetching JSGlobalContextRef from
+ WebView or WebFrame
+
+ Added -[WebFrame windowObject] and -[WebFrame globalContext], along with
+ a new frame load delegate method, - (void)webView:(WebView *)webView
+ didClearWindowObject:(WebScriptObject *)windowObject forFrame:(WebFrame *)frame.
+ This is all to support briding between the WebScriptObject and JavaScriptCore
+ APIs.
+
+ Also fixed more of <rdar://problem/4395622> API: WebScriptObject.h incorrectly
+ reports that -isSelectorExcludedFromWebScript returns NO by default, and
+ generally cleaned up the WebScriptObject headerdoc.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge windowObjectCleared]):
+ * WebView/WebFrame.mm:
+ (-[WebFrame windowObject]):
+ (-[WebFrame globalContext]):
+ * WebView/WebFramePrivate.h:
+ * WebView/WebViewPrivate.h:
+
+2007-05-07 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5180384> webView:validateUserInterfaceItem:defaultValidation: does not get called on WebUIDelegates
+
+ Call the delegate when the one of our views gets a validateUserInterfaceItem: call.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView validateUserInterfaceItemWithoutDelegate:]): Validate without the delegate.
+ (-[WebHTMLView validateUserInterfaceItem:]): Call the delegate with the result of validateUserInterfaceItemWithoutDelegate:.
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView validateUserInterfaceItemWithoutDelegate:]): Validate without the delegate.
+ (-[WebPDFView validateUserInterfaceItem:]): Call the delegate with the result of validateUserInterfaceItemWithoutDelegate:.
+ * WebView/WebView.mm:
+ (-[WebView _responderValidateUserInterfaceItem:]): Call validateUserInterfaceItemWithoutDelegate: to prevent asking the delegate twice.
+ (-[WebView validateUserInterfaceItemWithoutDelegate:]): Validate without the delegate.
+ (-[WebView validateUserInterfaceItem:]): Call the delegate with the result of validateUserInterfaceItemWithoutDelegate:.
+
+2007-05-07 Brady Eidson <beidson@apple.com>
+
+ Actually finish the code move from my last checkin
+
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem _transientPropertyForKey:]):
+ (-[WebHistoryItem _setTransientProperty:forKey:]):
+
+2007-05-07 Brady Eidson <beidson@apple.com>
+
+ Rubberstamped by Kevin (Sarge)
+
+ Make _transientPropertyForKey: and _setTransientProperty:forKey: SPI
+
+ * History/WebHistoryItemInternal.h:
+ * History/WebHistoryItemPrivate.h:
+
+2007-05-04 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ First step in fixing <rdar://problem/5055182> The back cache has no global cap
+
+ Stop giving SnapBack infinite cache-ability. Instead, make SnapBack rely
+ on the underlying back cache.
+
+ I left -setAlwaysAttemptToUsePageCache: as an empty stub because we don't
+ want to break Safari 2.0, but I removed its header declaration so nobody
+ else starts using it.
+
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem setAlwaysAttemptToUsePageCache:]):
+ * History/WebHistoryItemPrivate.h:
+
+2007-05-04 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Brady Eidson.
+
+ Some cleanup in preparation for fixing <rdar://problem/5055182> The
+ back/forward cache has no global cap
+
+ Unified naming of WebKit/WebCore b/f lists -- instead of the potpourri
+ of webBackForwardList, backForwardList, list, kitList, coreList, listWrapper,
+ and webCoreBackForwardList, we use webBackForwardList for WebKit and
+ backForwardList for WebCore, matching their respective class names.
+
+ Removed "private" versions of kit() and core() -- kit() and core() are
+ canonically used for converting between WebKit API objects and WebCore
+ API objects. I think it's clearer to have only one way to do this.
+
+ Removed COMPUTE_DEFAULT_PAGE_CACHE_SIZE, since it was unused.
+
+ Removed _clearPageCache, since it was unused and it duplicated -setPageCacheSize:0.
+
+ Removed _usesPageCache, since it was unused and it duplicated -pageCacheSize.
+
+2007-05-04 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Mark Rowe
+
+ Added main thread assertion to WebHTMLView to help make sure 3rd party clients aren't trying
+ to draw on secondary threads
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView drawRect:]): Added ASSERT_MAIN_THREAD()
+
+2007-05-04 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Antti.
+
+ <rdar://problem/5179977> Use the correct URLs when dispatching delegate methods for data loads.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadData:MIMEType:textEncodingName:baseURL:unreachableURL:]):
+ If the base URL is nil, set it to "about:blank", and set the response URL to a generated applewebdata URL.
+
+ * WebView/WebView.mm:
+ (+[WebView _canHandleRequest:]):
+ No need to special-case applewebdata URLs here anymore, they're only used in responses.
+
+2007-05-03 Steve Falkenburg <sfalken@apple.com>
+
+ Reviewed by Oliver.
+
+ Add missing user description parameter to spelling-related editor client method.
+
+ * WebCoreSupport/WebEditorClient.h:
+ (WebEditorClient::updateSpellingUIWithGrammarString):
+
+2007-05-03 TImothy Hatcher <timothy@apple.com>
+
+ Reviewed by Kevin.
+
+ <rdar://problem/4975212> REGRESSION: With NetNewsWire 2.1.1, the contextual menu shows extra menu items when focus
+ is placed in input or textarea field
+
+ The NetNewsWire UI delegate isn't expecting calls for form controls, so we need to do a linked-on-or-after check.
+ If the application was linked against Tiger or earlier and the element is a text form control, just return the
+ default menu items and bypass the delegate call completely.
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (isPreVersion3Client): Cache the result of the WebKitLinkedOnOrAfter call
+ (fixMenusToSendToOldClients): Call the new isPreVersion3Client()
+ (fixMenusReceivedFromOldClients): Ditto.
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): Return the default menu items if the element is a text form control.
+
+2007-05-03 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Geoff and Kevin.
+
+ <rdar://problem/5141290> WebAssertions.h is still needed by some internal clients
+
+ Second shot at fixing this error. Stub out the macros rather than forwarding to JavaScriptCore, which would
+ leave clients using this header trying to resolve JavaScriptCore symbols against WebKit when linking. This
+ should only happen in production builds when assertions should be disabled anyway as anyone building a
+ development configuration should be in a position to move away from using this header.
+
+ * Misc/WebAssertions.h:
+
+2007-05-03 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Kevin.
+
+ <rdar://problem/5067707> REGRESSION: "Open Link" contextual menu item appears twice in Mail
+
+ Remove the check for Mail in fixMenusToSendToOldClients and fixMenusReceivedFromOldClients
+ when linked on or after Leopard. The isAppleMail() function is still used for Tiger Mail fixups.
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusToSendToOldClients):
+ (fixMenusReceivedFromOldClients):
+
+2007-05-02 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Brady.
+
+ <rdar://problem/5151113> Assertion firing in [FrameProgressEntry addChild:forDataSource:] when navigating cnn.com
+
+ The assertion fired because a plug-in was trying to load a subresource when a new load had started but not yet
+ committed. The check that would have prevented this was removed in order to fix <rdar://problem/5085897>.
+
+ This puts back the check but changes it to allow loads where the target is the same frame as the plugin's parent frame.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView loadRequest:inTarget:withNotifyData:sendNotification:]):
+
+2007-04-27 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ There were only a couple calls to ResourceLoadDelegate forwarder left,
+ this removes the calls and adds a new cached method for didFailLoad.
+
+ * WebKit/DefaultDelegates/WebDefaultResourceLoadDelegate.h: Removed.
+ * WebKit/DefaultDelegates/WebDefaultResourceLoadDelegate.m: Removed.
+ * WebKit/Plugins/WebNullPluginView.mm: Call the resource load delegate directly.
+ * WebKit/WebCoreSupport/WebFrameLoaderClient.mm: Call the cached didFailLoad delegate function.
+ * WebKit/WebKit.xcodeproj/project.pbxproj: Remove WebDefaultResourceLoadDelegate.
+ * WebKit/WebView/WebDataSource.mm: Remove the #import for WebDefaultResourceLoadDelegate.h
+ * WebKit/WebView/WebView.mm: Remove the ResourceLoadDelegate forwarder, and remove a method that isn't used.
+ * WebKit/WebView/WebViewInternal.h: Ditto.
+ * WebKit/WebView/WebViewPrivate.h: Remove a method that is no longer used.
+
+2007-04-27 David Harrison <harrison@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5160627> Export JS list creation support as ObjC SPI for Mail
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _selectedRange]):
+ (-[WebHTMLView _shouldDeleteRange:]):
+ (-[WebHTMLView _canEdit]):
+ (-[WebHTMLView _canEditRichly]):
+ (-[WebHTMLView _hasSelection]):
+ (-[WebHTMLView _hasSelectionOrInsertionPoint]):
+ (-[WebHTMLView _hasInsertionPoint]):
+ (-[WebHTMLView _isEditable]):
+ Condense the check for nil [self frame].
+ Remove canEditRichly checks and rely on the editor to do the check instead.
+
+ (-[WebHTMLView _insertOrderedList]):
+ (-[WebHTMLView _insertUnorderedList]):
+ New.
+
+ (-[WebHTMLView _canIncreaseSelectionListLevel]):
+ (-[WebHTMLView _canDecreaseSelectionListLevel]):
+ (-[WebHTMLView _increaseSelectionListLevel]):
+ (-[WebHTMLView _increaseSelectionListLevelOrdered]):
+ (-[WebHTMLView _increaseSelectionListLevelUnordered]):
+ (-[WebHTMLView _decreaseSelectionListLevel]):
+ Moved from bridge to frame editor.
+
+ * WebView/WebHTMLViewPrivate.h:
+ Add _insertOrderedList and _insertUnorderedList to WebHTMLView(WebPrivate)
+
+2007-04-27 Brady Eidson <beidson@apple.com>
+
+ Rubberstamped by Mark
+
+ Remove default implementation of UIDelegate method that was removed
+
+ I have also been instructed to give Tim a hard time about this one - apparently
+ it was his job to clean it out and he failed... failed miserably.
+
+ :)
+
+ * DefaultDelegates/WebDefaultUIDelegate.m: Removed webViewPrint:
+
+2007-04-27 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Mark.
+
+ <rdar://problem/5154113> Repro ASSERT (would be crash) in KJS::GCLock::GCLock (13462)
+ http://bugs.webkit.org/show_bug.cgi?id=13462
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspectorPrivate dealloc]): Delay release of WebView to avoid GC re-entrancy.
+
+2007-04-27 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Mitz.
+
+ <rdar://problem/5165755>
+ View Source is broken; empty window is shown
+
+ Return YES for applewebdata URLs.
+
+ * WebView/WebView.mm:
+ (+[WebView _canHandleRequest:]):
+
+2007-04-26 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Fix <rdar://problem/5061252> REGRESSION: In Gmail, image fails
+ to be inserted into message field after dragging
+
+ Don't try to create <img> tags for local image files as it results
+ in the potential to submit forms that look like they have an image,
+ when in reality they don't.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _documentFragmentWithPaths:]):
+
+2007-04-26 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5049099> documents no longer have a default base URL
+
+ If the base URL is nil, then create a unique applewebdata URL to match what Tiger WebKit does.
+
+ * WebView/WebFrame.mm:
+ (createUniqueWebDataURL):
+ (-[WebFrame _loadData:MIMEType:textEncodingName:baseURL:unreachableURL:]):
+
+2007-04-25 Oliver Hunt <oliver@apple.com>
+
+ Rubber stamped by Adele.
+
+ Roll out WebKit changes from from r21052 to fix regression noted in
+ <rdar://problem/5159556> REGRESSION: In Mail, pressing option-command- ' doesn't decrease block quote in selection
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]):
+ (-[WebHTMLView doCommandBySelector:]):
+
+2007-04-25 Steve Falkenburg <sfalken@apple.com>
+
+ Reviewed by Adam.
+
+ Mac callbacks for new spelling methods in WebEditorClient.
+ Not used yet.
+
+ * WebCoreSupport/WebEditorClient.h:
+ (WebEditorClient::ignoreWordInSpellDocument):
+ (WebEditorClient::learnWord):
+ (WebEditorClient::checkSpellingOfString):
+ (WebEditorClient::checkGrammarOfString):
+ (WebEditorClient::updateSpellingUIWithGrammarString):
+ (WebEditorClient::updateSpellingUIWithMisspelledWord):
+ (WebEditorClient::showSpellingUI):
+ (WebEditorClient::spellingUIIsShowing):
+ (WebEditorClient::getGuessesForWord):
+
+2007-04-24 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler, Tim Hatcher.
+
+ Fixed a few NSAutoreleasePool issues I noticed while reviewing Brady's patch.
+
+ * Carbon/CarbonUtils.m:
+ (PoolCleaner): Call -drain instead of -release, since -release is a
+ no-op in a GC world.
+
+ * Misc/WebKitErrors.m:
+ (registerErrors): Condensed onto one line.
+
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase refresh]): Call -drain instead of -release, since
+ -release is a no-op in a GC world.
+
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::setStatusbarText):
+
+ * WebInspector/WebNodeHighlightView.m:
+ (-[WebNodeHighlightView initWithHighlight:andRects:forView:]): Don't drain
+ and then release because drain deallocates the receiver, so the release
+ is an over-release.
+
+ * WebView/WebView.mm:
+ (-[WebView rectsForTextMatches]): Re-allocate the pool after draining it,
+ because drain deallocates the receiver, so the drain would leave you without
+ any autorelease pool, causing a leak and then an over-release at the bottom
+ of the loop.
+
+2007-04-24 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Beth, Hyatt, Ada, and Darin
+
+ <rdar://problem/5011477> and <rdar://problem/5011514>
+ Provide support for the icon.db to be moved to a different directory from the old WebKit-style
+ icons, and remove the old directory if that is the case
+
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase _importToWebCoreFormat]): Check "imported()" to determine if a conversion is needed
+ - Look for WebIconDatabaseImportDirectoryDefaultsKey for the source location for the conversion
+ - Set "imported" to true in the Icons.db
+ - If the new Icons.db isn't in the same patch as the old icons, delete the entire directory when finished
+ - Move old icon.db to Icons.db to reflect rename
+ * Misc/WebIconDatabasePrivate.h: Add WebIconDatabaseImportDirectoryDefaultsKey so a WebKit client can tell WebKit
+ where to look for the old icons if their location is different from the icon.db
+ * WebKit.exp:
+
+2007-04-24 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Oliver Hunt.
+
+ Changed an apostrophe (') into a right single quotation mark (U+2019).
+
+ * WebInspector/webInspector/inspector.js:
+
+2007-04-24 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Timothy Hatcher.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=13459
+ The "mapped style" link next to an attribute doesn't work
+
+ * WebInspector/webInspector/inspector.js: Added a check that the rule is
+ mapped from an attribute.
+
+2007-04-23 Adele Peterson <adele@apple.com>
+
+ Fixed and reviewed by Darin, Adele, and Oliver.
+
+ WebKit part of fix for <rdar://problem/5107538> REGRESSION: Page scroll when selecting characters from inline input candidate window by arrow buttons
+ http://bugs.webkit.org/show_bug.cgi?id=13263
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]): If we have no command after calling interpretKeyEvents, we assume the input method handled the key.
+ (-[WebHTMLView doCommandBySelector:]): Add noop: to the command vector, but then when actually performing actions, ignore it.
+
+2007-04-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5124364> IB3 crashes when loading a nib containing a WebView that has a WebHTMLView encoded inside
+
+ Since WebView's initWithCoder throws away all the decoded subviews, the WebHTMLView gets dealoced while it has a nil _private pointer.
+ Checking for a nil _private in WehHTMLView's close fixes this crash. No need to implement a full initWithCoder for WebHTMLView since
+ it will be thrown away by the WebView anyway.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView close]): Return earily if _priviate is nil.
+ (-[WebHTMLView initWithFrame:]): Unrelated change that removes an AppKit version check that predates Tiger.
+
+2007-04-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ Remove the "No Selection" message after leaving search mode.
+ This was a regression caused by the inspector refresh.
+
+ * WebInspector/webInspector/inspector.js:
+
+2007-04-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 6658: World leak when closing inspected window
+ http://bugs.webkit.org/show_bug.cgi?id=6658 and <rdar://problem/4411863>
+
+ Removes over-retains of the inspector WebView, WebInspector and WebInspectorPanel.
+
+ * WebInspector/WebInspector.m:
+ (+[WebInspector sharedWebInspector]): Return the global sharedWebInspector variable.
+ (-[WebInspector window]): Release the window after calling setWindow:.
+ (-[WebInspector windowWillClose:]): Set the JavaScript Inspector variable to null and expire the current highlight.
+ Also clear the global sharedWebInspector variable and release it if self equals sharedWebInspector.
+ (-[WebInspector showWindow:]): Set the JavaScript Inspector variable back to self.
+ * WebInspector/WebInspectorInternal.h: Remove the isSharedInspector member variable.
+ * WebView/WebView.mm:
+ (-[WebView windowScriptObject]): Return nil if core([self mainFrame]) is NULL.
+
+2007-04-23 Darin Adler <darin@apple.com>
+
+ Reviewed by Hyatt.
+
+ - rename box-sizing to -webkit-box-sizing
+
+ * WebInspector/webInspector/inspector.css: Here.
+ * WebInspector/webInspector/inspector.js: And here, in the expected default CSS values list.
+
+2007-04-22 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ The fix for <rdar://problem/4976681> ASSERTION failure on quit @ talkcrunch.com in _NPN_ReleaseObject
+ was #ifdefed out in Production builds.
+
+ * WebView/WebView.mm:
+ (+[WebView initialize]): Move the #ifdef REMOVE_SAFARI_DOM_TREE_DEBUG_ITEM inside initialize around the specific code
+ (+[WebView _applicationWillTerminate]): Moved outside the #ifdef REMOVE_SAFARI_DOM_TREE_DEBUG_ITEM block
+
+2007-04-22 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mitz.
+
+ Bug 13436: Make Option-clicking a disclosure triangle expand the entire subtree
+ http://bugs.webkit.org/show_bug.cgi?id=13436
+
+ Makes option-click recursively expand and collapse the sub-tree. Pressing option-left
+ and -right also recursively expands and collapses the sub-tree.
+
+ * WebInspector/webInspector/treeoutline.js:
+
+2007-04-22 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mitz.
+
+ Bug 13437: Inspector does not update when navigating to a different page
+ http://bugs.webkit.org/show_bug.cgi?id=13437
+
+ * WebInspector/webInspector/inspector.js: Correctly update to a new root node
+ if the new focus node and the old focus node don't have a common ancestor.
+
+2007-04-22 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - fix for <rdar://problem/5100240> REGRESSION: Control-O broken
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:shouldSaveCommand:]): Update to handle a vector of
+ command names instead of a single command.
+ (-[WebHTMLView doCommandBySelector:]): Change logic so that we add the command to a vector
+ and also so that the interpretKeyEvents parameters are still intact for a second call to
+ doCommandBySelector:, since the key bindings mechanism can do more than one.
+ (-[WebHTMLView insertText:]): Added comment.
+
+2007-04-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Oliver.
+
+ - fix some problems I ran into using the inspector
+
+ * WebInspector/webInspector/inspector.js: Add some null checks.
+
+2007-04-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Merge over the WebInspectorRefresh branch. This change removes the NSOutlineView and
+ is replaced with a HTML/JavaScript tree. Most of the inspector logic is now in the JavaScript.
+
+ A few bugs are fixed by these changes:
+
+ Bug 6615: Parent node drop-down list is upside-down
+ http://bugs.webkit.org/show_bug.cgi?id=6615
+
+ Bug 6643: REGRESSION: Tree view repaints lines without erasing them first
+ http://bugs.webkit.org/show_bug.cgi?id=6643
+
+ Bug 6650: Web Inspector HTML Hierarchy can't be scrolled with scrollwheel
+ http://bugs.webkit.org/show_bug.cgi?id=6650
+
+ Bug 6677: Can't drag inspector when tree view has focus
+ http://bugs.webkit.org/show_bug.cgi?id=6677
+
+ Bug 7326: Web Inspector tree scrollbar always shows up when resizing the top pane down
+ http://bugs.webkit.org/show_bug.cgi?id=7326
+
+ * WebInspector/WebInspector.h: Removed the searchQuery methods.
+ * WebInspector/WebInspector.m: Removed the DOMNode category and code for the old outline view.
+ * WebInspector/WebInspectorOutlineView.h: Removed.
+ * WebInspector/WebInspectorOutlineView.m: Removed.
+ * WebInspector/WebInspectorInternal.h: Remove some methods and instance variables.
+ * WebInspector/webInspector/Images/resize.png: Added.
+ * WebInspector/webInspector/inspector.css:
+ * WebInspector/webInspector/inspector.html: Include the new classes and remove the plugin.
+ * WebInspector/webInspector/inspector.js: Changes to use the new tree outline and other fixes.
+ * WebInspector/webInspector/scrollarea.js: Copied from the Dashboard widget resources.
+ * WebInspector/webInspector/scrollbar.js: Ditto.
+ * WebInspector/webInspector/treeoutline.js: New tree outline class.
+ * WebInspector/webInspector/utilities.js: DOM and String prototype additions.
+ * WebKit.xcodeproj/project.pbxproj: Remove WebInspectorOutlineView.
+
+2007-04-20 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Oliver (Black Sheep)
+
+ <rdar://problem/3559794>
+ [WebView setMaintainsBackForwardList:] doesn't actually flush out the current page caches
+
+ * WebView/WebView.mm: Remove _private->useBackForwardList
+ (-[WebView _setInitiatedDrag:]): Use _private->page instead of [self page]
+ (-[WebView initWithCoder:]): Manipulate the flag that is now in WebCore::BackForwardList
+ (-[WebView encodeWithCoder:]): Ditto
+ (-[WebView backForwardList]): Use _private->page instead of [self page]
+ (-[WebView setMaintainsBackForwardList:]): Manipulate the flag that is now in WebCore::BackForwardList
+
+2007-04-20 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5085897> REGRESSION: Some Flash links at www.jumpskyhigh.com just reload the page
+
+ Get rid of the check that would prevent plugin requests from being loaded if a new page load was underway.
+ www.jumpskyhigh.com had a flash movie that was embedded inside an <a> tag and clicking on the plug-in would cause the
+ URL pointed to by the <a> tag to start loading and thus preventing the plug-in from loading the real URL.
+
+ This check was added by Maciej and we should be able to remove it with the loader changes that have happened now,
+ (mainly the fact that resource loaders are handled by the document loader instead of the frame loader).
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView loadRequest:inTarget:withNotifyData:sendNotification:]):
+
+2007-04-19 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Fix for <rdar://problem/4960912> -- REGRESSION: Content-Disposition:
+ filename is ignored for drag-and-drop.
+
+ * WebView/WebResource.mm:
+ (-[WebResource _fileWrapperRepresentation]):
+ When creating the NSFileWrapper check the response for a preferred
+ filename, rather than just blindly hoping for the best.
+
+2007-04-19 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5137002>
+ REGRESSION (r20812): [WebFrame DOMDocument] is returning non-nil value in bookmarks view, causing trouble in Safari
+
+ Put back the MIME type check as a workaround.
+ * WebView/WebFrame.mm:
+ (-[WebFrame DOMDocument]):
+
+2007-04-19 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Oliver and Adam.
+
+ <rdar://problem/5141290> WebAssertions.h is still needed by some internal clients.
+
+ * Misc/WebAssertions.h: Added.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-04-17 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim
+
+ <rdar://problem/5008925>
+ Expose the NSURLConnection delegate willCacheResponse API to WebResourceLoadDelegate
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::willCacheResponse): Call
+ [WebResourceLoadDelegate webView:resource:willCacheResponse:fromDataSource:];
+
+ * WebView/WebView.mm:
+ (-[WebView _cacheResourceLoadDelegateImplementations]): Pull out the willCacheResponse impl
+
+ * WebView/WebViewPrivate.h: Add WebResourceLoadDelegatePrivate category for this new SPI
+
+2007-04-18 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adam
+
+ - fixed <rdar://problem/5103009> REGRESSION: Activity window shows blank name for untitled pages
+
+ * WebView/WebHTMLRepresentation.mm:
+ (-[WebHTMLRepresentation title]):
+ return nil for empty string, to match old behavior
+
+2007-04-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ - fixed <rdar://problem/5138492> Safari doesn't remember some changes to the PDF scale and display mode
+
+ Some of the user interactions that could change the PDF scale and display mode were not going through
+ the proxy mechanism in WebPDFView that updates preferences. Now we also listen to PDFKit notifications
+ in order to catch the other cases.
+
+ * WebView/WebPDFView.h:
+ new _ignoreScaleAndDisplayModeNotifications and _updatePreferencesTimer ivars
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView setPDFDocument:]):
+ ignore scale and display mode notifications while we're setting up a fresh document
+ (-[WebPDFView dealloc]):
+ cancel the new timer (which releases it)
+ (-[WebPDFView viewDidMoveToWindow]):
+ listen for two PDFKit notifications
+ (-[WebPDFView viewWillMoveToWindow:]):
+ stop listening to the two PDFKit notifications
+ (-[WebPDFView _applyPDFDefaults]):
+ white space change
+ (-[WebPDFView _cancelUpdatePreferencesTimer]):
+ invalidate, release, and nil out the timer
+ (-[WebPDFView _scaleOrDisplayModeChanged:]):
+ update preferences soon, unless deliberately ignoring these notifications
+ (-[WebPDFView _updatePreferencesNow]):
+ cancel timer, then save data to preferences (code for saving the data was extracted from
+ -[PDFPrefUpdatingProxy forwardInvocation:])
+ (-[WebPDFView _updatePreferencesSoon]):
+ use timer to consolidate multiple calls into one action; formerly we were setting preferences
+ multiple times for some atomic user actions
+ (-[PDFPrefUpdatingProxy forwardInvocation:]):
+ call _updatePreferencesSoon where we used to immediately set preferences
+
+2007-04-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/4184640> "Look Up in Dictionary" item is always disabled for PDF pages
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView validateUserInterfaceItem:]):
+ enable "Look Up in Dictionary" only if we're using a version of PDFKit that knows how to do so
+ (-[WebPDFView _canLookUpInDictionary]):
+ use respondsToSelector to test whether the current version of PDFKit supports this non-API feature
+ (-[WebPDFView _lookUpInDictionaryFromMenu:]):
+ implement this method, which WebKit includes in the context menu when there's selected text
+ (-[WebPDFView _menuItemsFromPDFKitForEvent:]):
+ updated comment for this change
+
+2007-04-16 Darin Adler <darin@apple.com>
+
+ Rubber stamped by Tim Hatcher.
+
+ * WebKit.xcodeproj/project.pbxproj: Added Radar bug number to the error message
+ for the "version number ending in 4" check so folks from Apple can find the
+ original bug that motivated for this. To summarize what's in that bug, it says that
+ <http://my.fedex.com> was failing, that it was because of the OpenCube DHTML Menu,
+ and that some other affected sites were not using OpenCube (so the error is presumably
+ more widespread).
+
+2007-04-16 Darin Adler <darin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=13303
+ <rdar://problem/5126341> REGRESSION: controls in a background Safari window
+ maintain active appearance if the address bar has focus (13303)
+
+ * WebView/WebHTMLView.mm: (-[WebHTMLView _windowChangedKeyState]):
+ Added. Calls FrameView::updateControlTints.
+
+2007-04-13 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Due to rdar://problem/5133910 -- WebArchives should not be constructed
+ using resource from the cache -- We may try to create a potentially
+ incorrect WebArchive when dragging an image multiple times.
+
+ This patch retains the assertion for invalid behaviour, but adds a
+ branch to make sure we don't try to do anything with the WebArchive
+ in release builds.
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:]):
+
+2007-04-13 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Dave Harrison.
+
+ <rdar://problem/5132727> Soho Mail build fails because of renamed SPI
+
+ * WebView/WebUIDelegatePrivate.h: define WebMenuItemTagSearchInGoogle as OldWebMenuItemTagSearchWeb
+
+2007-04-13 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Oliver.
+
+ <rdar://problem/5130686> Using WebPreferencesPrivate.h requires modifying framework search path
+
+ * WebView/WebPreferencesPrivate.h: Remove unneeded #ifdef.
+
+2007-04-12 Deneb Meketa <dmeketa@adobe.com>
+
+ Reviewed by Darin Adler.
+
+ http://bugs.webkit.org/show_bug.cgi?id=13029
+ rdar://problem/4994849
+ Bug 13029: Permit NPAPI plug-ins to see HTTP response headers.
+
+ * Plugins/WebBaseNetscapePluginStream.h: declarations.
+ * Plugins/WebBaseNetscapePluginStream.mm: main implementation.
+ (-[WebBaseNetscapePluginStream dealloc]): cleanup.
+ (-[WebBaseNetscapePluginStream finalize]): cleanup.
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:headers:]):
+ Pass headers along.
+ (-[WebBaseNetscapePluginStream startStreamWithResponse:]):
+ Main work is here. Extract headers from NSHTTPURLResponse object into a byte sequence.
+ See comments here about how it would be nice to have low-level access to the HTTP response.
+ (-[WebBaseNetscapePluginStream _destroyStream]): cleanup.
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView evaluateJavaScriptPluginRequest:]):
+ Conform to new startStream params. Not applicable here, pass nil.
+
+2007-04-12 Brady Eidson <beidson@apple.com>
+
+ Build fix for case sensitive file systems
+
+ * Misc/WebNSPasteboardExtras.mm:
+ * WebCoreSupport/WebPasteboardHelper.mm:
+
+2007-04-11 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders
+
+ - WebKit part of fix for:
+ <rdar://problem/5128697> REGRESSION: At least one PDF context menu item isn't appearing on Leopard
+
+ * Misc/WebNSArrayExtras.h: Added.
+ * Misc/WebNSArrayExtras.m: Added.
+ (-[NSMutableArray _webkit_removeUselessMenuItemSeparators]):
+ New file, includes this method to strip leading, trailing, and duplicate separators from arrays
+ of NSMenuItems (copied from Safari)
+
+ * WebView/WebUIDelegatePrivate.h:
+ new MenuItemTag enum values for new PDFKit context menu items
+
+ * WebKit.xcodeproj/project.pbxproj:
+ updated for new files
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _anyPDFTagsFoundInMenu:]):
+ check for new PDFKit context menu items
+ (-[WebPDFView _menuItemsFromPDFKitForEvent:]):
+ associate new PDFKit context menu item selectors with the new tags; skip certain selectors that
+ correspond to menu items that WebKit already includes; remove useless menu item separators when
+ we're done, since we might have removed arbitrarily-placed menu items
+
+2007-04-11 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Maciej.
+
+ Adding RetainPtr to the many global obj-c pointers we use in
+ C/C++ methods. This is necessary to prevent GC from collecting
+ globals we want to keep around.
+
+ We use RetainPtr in obj-c++ and c++ files, and CFRetain/Release in pure
+ obj-c.
+
+ This fixes <rdar://problem/5058731> -- Crash in
+ WebCore::DragData::containsCompatibleContent due to early release
+ of types array
+
+ * Misc/WebLocalizableStrings.m:
+ (WebLocalizedString):
+ * Misc/WebNSPasteboardExtras.mm:
+ (+[NSPasteboard _web_writableTypesForURL]):
+ (_writableTypesForImageWithoutArchive):
+ (_writableTypesForImageWithArchive):
+ * Misc/WebNSURLExtras.m:
+ (applyHostNameFunctionToMailToURLString):
+ (applyHostNameFunctionToURLString):
+ * Misc/WebStringTruncator.m:
+ (defaultMenuFont):
+ (fontFromNSFont):
+ * WebCoreSupport/WebPasteboardHelper.mm:
+ (WebPasteboardHelper::insertablePasteboardTypes):
+
+2007-04-11 MorganL <morganl.webkit@yahoo.com>
+
+ Reviewed by Maciej.
+
+ Add a Frame pointer to ChromeClient methods:
+ http://bugs.webkit.org/show_bug.cgi?id=13127
+
+ * COM/ChromeClientWin.cpp:
+ (ChromeClientWin::createWindow):
+ (ChromeClientWin::createModalDialog):
+ * COM/ChromeClientWin.h:
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::createWindow):
+ (WebChromeClient::createModalDialog):
+
+2007-04-10 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ <rdar://problem/4887095> - PageCache and PageState should be combined
+
+ WebKit side of the change to reflect the new object name of CachedPage and new Client method names
+
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem setAlwaysAttemptToUsePageCache:]):
+ (+[WebHistoryItem _releaseAllPendingPageCaches]):
+ (-[WebWindowWatcher windowWillClose:]):
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::setDocumentViewFromCachedPage):
+ (WebFrameLoaderClient::loadedFromCachedPage):
+ (WebFrameLoaderClient::saveDocumentViewToCachedPage):
+
+2007-04-09 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ Support for fixing fast/forms/textarea-paste-newline.html.
+
+ Added SPI for specifying whether a WebView should allow pasting through the
+ DOM API.
+
+ * ChangeLog:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebPreferenceKeysPrivate.h:
+ * WebView/WebPreferences.m:
+ (+[WebPreferences standardPreferences]):
+ (-[WebPreferences isDOMPasteAllowed]):
+ (-[WebPreferences setDOMPasteAllowed:]):
+ * WebView/WebPreferencesPrivate.h:
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-04-09 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5081860>
+ REGRESSION: Select All for standalone image has no visible effect but does change state
+
+ <rdar://problem/5081840>
+ REGRESSION: context menu in white space beyond standalone image is different after Select All
+
+ Have validateUserInterface emulate the old behavior for full-frame images and plugins, which is:
+
+ - For full-frame plugins, always return false.
+ - For images, only return true if the selector is copy: and the image has finished loading.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView validateUserInterfaceItem:]):
+
+2007-04-09 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5026893>
+ REGRESSION: "Mail Contents of this Page" for standalone image in Safari results in a broken image in Mail
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame DOMDocument]):
+ We can't check for _isHTMLDocument here since image and plugin documents inherit from HTMLDocument. Instead,
+ check for those two document types explicitly.
+
+2007-04-09 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff, Ada and John.
+
+ <rdar://problem/4600978> Would like a way to test whether a WebView is displaying a standalone image
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _isDisplayingStandaloneImage]):
+ * WebView/WebFramePrivate.h:
+ Add _isDisplayingStandaloneImage SPI.
+
+2007-04-06 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ Adds a build phase script that ensures WebKit's version dosen't end in a 4.
+ If our version ends in 4, some sites might think we are Netscape 4 in their
+ user agent checks.
+
+ * Configurations/Version.xcconfig:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-04-05 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/5083023>
+ REGRESSION: In Real Player (10.1.0), video continues to play after closing window
+
+ This broke in revision 18422 because now the plugin isn't stopped when the window is closed. Since the window is retained
+ by the plugin view for as long as it is running (so that removeTrackingRect works even though the window has been closed),
+ we would end up with a reference cycle (NSWindow -> WebView -> PluginView -> NSWindow) and stopping the plug-in when the window
+ was closed would break that cycle.
+
+ Applications that call -[WebView close] when closing aren't affected, but RealPlayer doesn't do this.
+
+ The bug that 18422 was supposed to fix was fixed by 19275, which is why it's safe to add back the check.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView addWindowObservers]):
+ (-[WebBaseNetscapePluginView removeWindowObservers]):
+ (-[WebBaseNetscapePluginView windowWillClose:]):
+
+2007-04-05 Kevin McCullough <kmccullough@apple.com>
+
+ Reviewed by Darin.
+
+ - Moved registerURLSchemeAsLocal to the public API.
+
+ * WebView/WebView.h:
+ * WebView/WebView.mm:
+ (+[WebView registerURLSchemeAsLocal:]):
+ * WebView/WebViewPrivate.h:
+
+=== Safari-5522.6 ===
+
+2007-04-04 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5107536>
+ http://bugs.webkit.org/show_bug.cgi?id=13264
+ REGRESSION: Crash when canceling about:blank in Activity viewer
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame stopLoading]):
+ Add a null check for the frame loader - it can be null when the frame has been disconnected
+ from the web page.
+
+2007-04-03 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/5028178>
+ Crash occurs at WebCore::FrameLoader::activeDocumentLoader() after loading Froggster widget
+
+ * Plugins/WebNetscapePluginStream.mm:
+ (-[WebNetscapePluginStream start]):
+ If load returns no the plugin loader has already been removed by the didFail callback.
+
+2007-04-02 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff.
+
+ Fix crash when running plugins/destroy-stream-twice.html under GuardMalloc
+
+ * Plugins/WebBaseNetscapePluginStream.h:
+ * Plugins/WebBaseNetscapePluginStream.mm:
+ (+[WebBaseNetscapePluginStream ownerForStream:]):
+ (-[WebBaseNetscapePluginStream initWithRequestURL:plugin:notifyData:sendNotification:]):
+ (-[WebBaseNetscapePluginStream dealloc]):
+ (-[WebBaseNetscapePluginStream finalize]):
+ Change the streams hash map to contain an NPStream*, and change ownerForStream to take an NPStream*.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView destroyStream:reason:]):
+ Check that the NPStream pointer is valid before accessing stream->ndata.
+
+2007-04-02 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=13026
+ <rdar://problem/5061026> incomplete render of menu
+ (assertion failing in -[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:])
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=13120
+ <rdar://problem/5080339> Plug-ins that draw through the QuickDraw interface may crash
+ by hanging onto old GWorlds.
+
+ - set clip path for CoreGraphics plug-ins in the same way we do for QuickDraw plug-ins
+ this is a better fix for <rdar://problem/4939511> WebKit should set the the CG clip
+ path for plug-ins that draw using Core Graphics
+
+ Incorporates changes from a patch by Mark Ambachtsheer.
+
+ Here are the changes:
+
+ 1) Don't try to use the offscreen code path if GGBitmapContextGetData returns 0.
+ 2) Handle kCGBitmapByteOrderDefault when computing the QD pixel format, even though
+ we don't have any evidence that this happens in practice.
+ 3) Keep the GWorld around until we create a new one or the plug-in is destroyed.
+ 4) Use the GWorld pointer itself as a flag to indicate whether we are using an
+ offscreen GWorld.
+ 5) Set up clipping for CoreGraphics in the same way we do for QuickDraw; remove an
+ earlier attempt that handled CoreGraphics differently.
+
+ * Plugins/WebBaseNetscapePluginView.h: Added a field named offscreenGWorld to hold
+ the GWorld until it's needed.
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (getQDPixelFormatForBitmapContext): Replaced QDPixelFormatFromCGBitmapInfo. Used the
+ "get" prefix so we don't intrude on the QD namespace. Added code to handle the
+ kCGBitmapByteOrderDefault case, although I'm not sure it will really come up in
+ practice -- it wasn't really coming up in the buggy case.
+ (getNPRect): Added helper functions. Used to make the code below clearer.
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]): Use getNPRect to
+ streamline code. Use GetGWorld to save the port since we use SetGWorld to restore
+ it later. Store the GWorld we create in the offscreenGWorld field and dispose the
+ existing one. Don't treat the CGBitmapContext as an offscreen bitmap if it
+ has a data pointer of 0. Set up the clip based on the result of
+ -[NSView getRectsBeingDrawn:count] when setting up the port for CoreGraphics
+ (after saving the port state).
+ (-[WebBaseNetscapePluginView restorePortState:]): Remove now-unneeded code to
+ destroy the offscreen GWorld, and simplified the code that restores the port so we
+ don't need a separate case for offscreen.
+ (-[WebBaseNetscapePluginView fini]): Renamed from freeAttributeKeysAndValues, since
+ this method now does more than just the attributes. This is the shared method that
+ does things needed in both dealloc and finalize. Added a call to DisposeGWorld here.
+ (-[WebBaseNetscapePluginView dealloc]): Updated for name change.
+ (-[WebBaseNetscapePluginView finalize]): Ditto.
+ (-[WebBaseNetscapePluginView drawRect:]): Removed code to set clip. This is done in
+ the saveAndSetNewPortStateForUpdate: method instead.
+
+2007-03-30 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Call execCommand for deleteWordForward and deleteWordBackward instead of calling
+ deleteWithDirection directly.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView deleteWordForward:]):
+ (-[WebHTMLView deleteWordBackward:]):
+
+2007-03-30 Anders Carlsson <andersca@apple.com>
+
+ Reviewed by Geoff.
+
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage load]):
+ Initialize pushpopupsenabledstate, poppopupsenabledstate and enumerate.
+
+ * Plugins/npapi.m:
+ (NPN_PushPopupsEnabledState):
+ (NPN_PopPopupsEnabledState):
+ Add stubs for these functions.
+
+ * Plugins/npfunctions.h:
+ Add new methods to NPNetscapeFuncs.
+
+2007-03-29 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Beth Dakin, reviewed by Maciej Stachowiak.
+
+ Layout test for <rdar://problem/5091330> REGRESSION: Repro crash in
+ -[WebBaseNetscapePluginView(WebNPPCallbacks) destroyStream:reason:]
+ navigating away from page with DivX movie plug-in (13203)
+
+ Changed LOG_ERROR to LOG so the layout test doesn't produce console spew
+ every time you run it.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView destroyStream:reason:]):
+
+2007-03-29 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Brady.
+
+ Fix for <rdar://problem/4674537> REGRESSION: Adobe Acrobat 8 - Text
+ blinks when mouse is moved, and is invisible otherwise
+
+ -and-
+
+ <rdar://problem/4992521> Please adjust WebKit's Acrobat-workaround
+ methodology
+
+ The fix for the first bug is to compare against the bundle
+ identifiers for Adobe Reader and the non-Pro Adobe Acrobat in
+ addition to Adobe Acrobat Pro. The fix for the second bug is to
+ check the version number of Acrobat/Reader through
+ WebKitSystemInterface instead of checking which version of WebKit
+ it has been linked against.
+
+ * English.lproj/StringsNotToBeLocalized.txt: Two new bundle
+ identifiers.
+ * Misc/WebKitVersionChecks.h: Remove Acrobat quirk constant.
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-03-29 Geoffrey Garen <ggaren@apple.com>
+
+ Rubber stamped by Beth Dakin.
+
+ WebBaseNetscapePluginStream.m => WebBaseNetscapePluginStream.mm, since
+ it's ObjC++ now.
+
+ * Plugins/WebBaseNetscapePluginStream.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-03-27 Geoffrey Garen <ggaren@apple.com>
+
+ Reluctantly tolerated by Darin Adler.
+
+ Fixed <rdar://problem/5091330> REGRESSION: Repro crash in
+ -[WebBaseNetscapePluginView(WebNPPCallbacks) destroyStream:reason:]
+ navigating away from page with DivX movie plug-in (13203)
+
+ The problem was that the DivX plug-in would ask us to destroy an NPStream
+ that had already been destroyed, causing us to wander off into freed
+ memory. (I believe the reason this was a regression was that we never used
+ to destroy plug-in streams, period.)
+
+ The solution here is to track the NPStreams belonging to a plug-in, and
+ guard against plug-ins making calls with NPStreams that don't belong to
+ them. (It turns out that NPN_DestroyStream is the only stream-based
+ plug-in call we support.)
+
+ (CarbonPathFromPOSIXPath): Fixed up a cast to be C++ compatible.
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView destroyStream:reason:]): The actual fix.
+ Use helper method to guard against a plug-in using an NPStream that doesn't
+ belong to it.
+ * WebKit.xcodeproj/project.pbxproj: Made WebBaseNetscapePluginView ObjC++
+ so I could use HashMap.
+
+2007-03-28 Adele Peterson <adele@apple.com>
+
+ Reviewed by Brady.
+
+ Update to last fix.
+
+ * Misc/WebKitVersionChecks.h: Added WEBKIT_FIRST_VERSION_WITHOUT_VITALSOURCE_QUIRK.
+ * WebView/WebView.mm: (-[WebView stringByEvaluatingJavaScriptFromString:]):
+ Added check to only use the VitalSource workaround if the app is not linked on or after
+ the defined WEBKIT_FIRST_VERSION_WITHOUT_VITALSOURCE_QUIRK version number.
+
+2007-03-28 Adele Peterson <adele@apple.com>
+
+ Reviewed by Kevin M.
+
+ WebKit part of fix for <rdar://problem/5095515> VitalSource Bookshelf should not pass return statements into stringByEvaluatingJavaScriptFromString
+
+ Added an app specific workaround for VitalSource Bookshelf that strips "return" from the beginning of their script strings. We used to allow this
+ but now we throw a JavaScript exception for return statements that aren't in functions.
+
+ Filed this evangelism bug so we can notify VitalSource of the problem:
+ <rdar://problem/5095515> VitalSource Bookshelf should not pass return statements into stringByEvaluatingJavaScriptFromString
+
+ * WebView/WebView.mm: (-[WebView stringByEvaluatingJavaScriptFromString:]):
+
+2007-03-27 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim
+
+ - fixed <rdar://problem/5092556> Default UA spoofing is always off until explicitly toggled
+
+ * WebView/WebView.mm:
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ initialize the cached value of _private->useSiteSpecificSpoofing here; formerly it would not
+ be initialized correctly in the common case of WebViews that use [WebPreferences standardPreferences]
+
+2007-03-27 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Dave Harrison.
+
+ * Configurations/WebKit.xcconfig: Include UMBRELLA_FRAMEWORKS_DIR in framework search path.
+
+2007-03-26 Antti Koivisto <antti@apple.com>
+
+ Reviewed by Darin.
+
+ On Mac, support fine grained wheel events generated by trackpad and Mighty Mouse.
+ http://bugs.webkit.org/show_bug.cgi?id=13134
+ <rdar://problem/5076249>
+
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface): Expose GetWheelEventDeltas()
+
+2007-03-26 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Dave Harrison
+
+ - fixed <rdar://problem/4769772> Problem with Find on certain PDF page
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _scaledAttributedString:]):
+ We were hitting an exception trying to set the font attribute to nil, which was happening because
+ the result of -[PDFSelection attributedString] had no attributes. That PDFSelection bug is now
+ filed separately, but this works around the exception.
+
+2007-03-24 David Hyatt <hyatt@apple.com>
+
+ Amend the statistics reporting for the WebCore cache to include XSL and to report live/decoded sizes.
+
+ * Misc/WebCache.mm:
+ (+[WebCache statistics]):
+
+2007-03-24 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adam
+
+ RetainPtr is no longer in the WebCore namespace
+
+ * History/WebBackForwardList.mm:
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebView/WebDocumentLoaderMac.h:
+
+2007-03-24 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adam
+
+ <rdar://problem/5086210> - Move RetainPtr to WTF
+
+ * ForwardingHeaders/wtf/RetainPtr.h: Added.
+ * History/WebBackForwardList.mm: Changed #import to <wtf/RetainPtr.h>
+ * WebCoreSupport/WebEditorClient.h: Ditto
+ * WebCoreSupport/WebFrameLoaderClient.h: Ditto
+ * WebView/WebDocumentLoaderMac.h: Ditto
+
+2007-03-24 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adele
+
+ - fixed <rdar://problem/5084872> Need to add flickr to spoof list in WebKit
+ - only do site-specific spoofing if a preference is set
+
+ * WebView/WebPreferenceKeysPrivate.h:
+ added WebKitUseSiteSpecificSpoofingPreferenceKey
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+ initialize WebKitUseSiteSpecificSpoofingPreferenceKey to false
+ (-[WebPreferences _useSiteSpecificSpoofing]):
+ get value of WebKitUseSiteSpecificSpoofingPreferenceKey
+ (-[WebPreferences _setUseSiteSpecificSpoofing:]):
+ set value of WebKitUseSiteSpecificSpoofingPreferenceKey
+
+ * WebView/WebPreferencesPrivate.h:
+ declare _useSiteSpecificSpoofing and _setUseSiteSpecificSpoofing
+
+ * WebView/WebView.mm:
+ cache the value of WebKitUseSiteSpecificSpoofingPreferenceKey in a bool in _private
+ (-[WebView _preferencesChangedNotification:]):
+ update the cached value
+ (-[WebView setPreferences:]):
+ ditto
+ (-[WebView WebCore::_userAgentForURL:WebCore::]):
+ Only spoof here if the new site-specific spoofing preference is enabled. If it is, pass
+ Safari 2.0.4's user agent string for flickr.com. We can remove this case when 5081617 is addressed.
+
+2007-03-24 Mark Rowe <mrowe@apple.com>
+
+ Rubber-stamped by Darin.
+
+ * Configurations/WebKit.xcconfig: Remove unnecessary INFOPLIST_PREPROCESS.
+
+2007-03-23 Mark Rowe <mrowe@apple.com>
+
+ Build fix for when BUILDING_ON_TIGER is not defined.
+
+ * Misc/WebTypesInternal.h:
+ * WebView/WebHTMLView.mm:
+
+2007-03-22 David Kilzer <ddkilzer@apple.com>
+
+ Reviewed by Darin.
+
+ Use BUILDING_ON_TIGER from WebKitPrefix.h instead of local
+ MAC_OS_X_VERSION_MAX_ALLOWED <= MAC_OS_X_VERSION_10_4 tests.
+
+ * Misc/WebTypesInternal.h:
+ * WebView/WebHTMLView.mm:
+
+2007-03-22 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - fix <rdar://problem/5074630> detachChildren call should move from WebKit to WebCore
+
+ * WebCoreSupport/WebFrameLoaderClient.mm: (WebFrameLoaderClient::prepareForDataSourceReplacement):
+ Remove call to detachChildren. This should be a WebCore responsibility.
+
+2007-03-19 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Dave Hyatt.
+
+ <rdar://problem/5067983>
+ iSale: Crash occurs at WebFrameLoaderClient::dispatchDecidePolicyForMIMEType() when attempting to load a HTML template
+
+ Restore old behavior (broke in r14533) where the resource load and download delegates are retained for as long as the
+ data source is loading.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::createDocumentLoader):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::setDataSource):
+ (WebDocumentLoaderMac::decreaseLoadCount):
+
+2007-03-19 Geoffrey Garen <ggaren@apple.com>
+
+ Speculative fix for why ASSERT_MAIN_THREAD didn't work for me. (The
+ documentation says "non-zero," not "1."
+
+ * Misc/WebKitLogging.m:
+ (WebKitRunningOnMainThread):
+
+2007-03-19 Andrew Wellington <proton@wiretapped.net>
+
+ Reviewed by Maciej.
+
+ Really set Xcode editor to use 4 space indentation (http://webkit.org/coding/coding-style.html)
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-03-19 Darin Adler <darin@apple.com>
+
+ * English.lproj/StringsNotToBeLocalized.txt: Update for recent changes.
+
+2007-03-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Justin
+
+ - fixed <rdar://problem/5071238> REGRESSION: opt-cmd-B to show Bookmarks view does
+ nothing when form field has focus
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _handleStyleKeyEquivalent:]):
+ we were counting any set of modifiers plus 'b' as the standard key equivalent for
+ toggling Bold; now we only accept command+'b'
+
+2007-03-19 Adam Roben <aroben@apple.com>
+
+ Reviewed by Hyatt and Maciej.
+
+ Updated WebCoreStatistics for the conversion of WebCoreJavaScript to
+ C++.
+
+ * Misc/WebCoreStatistics.mm:
+ (+[WebCoreStatistics javaScriptObjectsCount]):
+ (+[WebCoreStatistics javaScriptInterpretersCount]):
+ (+[WebCoreStatistics javaScriptProtectedObjectsCount]):
+ (+[WebCoreStatistics javaScriptRootObjectTypeCounts]): Moved
+ conversion to NSCountedSet here from WebCore.
+ (+[WebCoreStatistics garbageCollectJavaScriptObjects]):
+ (+[WebCoreStatistics garbageCollectJavaScriptObjectsOnAlternateThread:]):
+ (+[WebCoreStatistics shouldPrintExceptions]):
+ (+[WebCoreStatistics setShouldPrintExceptions:]):
+ (+[WebCoreStatistics javaScriptReferencedObjectsCount]):
+ (+[WebCoreStatistics javaScriptRootObjectClasses]):
+
+2007-03-18 Andrew Wellington <proton@wiretapped.net>
+
+ Reviewed by Mark Rowe
+
+ Set Xcode editor to use 4 space indentation (http://webkit.org/coding/coding-style.html)
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-03-19 Mark Rowe <mrowe@apple.com>
+
+ Rubber-stamped by Brady.
+
+ Update references to bugzilla.opendarwin.org with bugs.webkit.org.
+
+ * WebInspector/webInspector/inspector.css:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView firstRectForCharacterRange:]):
+ * WebView/WebView.mm:
+ (-[WebView initWithFrame:frameName:groupName:]):
+
+2007-03-18 David Hyatt <hyatt@apple.com>
+
+ Move frame borders out of WebKit and into WebCore.
+
+ Reviewed by aroben, olliej
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView drawRect:]):
+ (-[WebFrameView setFrameSize:]):
+ * WebView/WebFrameViewInternal.h:
+
+2007-03-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ Discovered while working on <rdar://problem/5070334> that many WebView calls will crash if called
+ after -[WebView close] has executed because _private->page is deferenced after it's been set to 0.
+ It might be silly/wrong to call these methods after -close, but obviously it shouldn't crash. Made
+ each use of _private->page robust against nil-dereferencing.
+
+ * WebView/WebView.mm:
+ (-[WebView _loadBackForwardListFromOtherView:]):
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+ (-[WebView _setDashboardBehavior:to:]):
+ (-[WebView _dashboardBehavior:]):
+ (-[WebView goBack]):
+ (-[WebView goForward]):
+ (-[WebView goToBackForwardItem:]):
+ (-[WebView canGoBack]):
+ (-[WebView canGoForward]):
+ (-[WebView setTabKeyCyclesThroughElements:]):
+ (-[WebView tabKeyCyclesThroughElements]):
+ (-[WebView setEditable:]):
+
+2007-03-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ Made Version.xcconfig smarter when building for different configurations.
+ Now uses the 522+ OpenSource version for Debug and Release, while using the
+ full 522.4 version for Production builds. The system prefix is also computed
+ based on the current system, so 4522.4 on Tiger and 5522.4 on Leopard.
+
+ * Configurations/Version.xcconfig:
+ * Configurations/WebKit.xcconfig:
+
+2007-03-16 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Hyatt.
+
+ The old canSaveAsWebArchive call was necessary as stand alone
+ images used to be rendered by ImageDocument.
+
+ Fixes rdar://problem/5061252
+
+ * WebCoreSupport/WebDragClient.h:
+ * WebCoreSupport/WebDragClient.mm:
+ (WebDragClient::declareAndWriteDragImage):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-03-15 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ <rdar://problem/4429701>
+ Implements a port blocking black list that matches Firefox's
+
+ * English.lproj/Localizable.strings: Added localizable string for port blocked error code
+
+ * Misc/WebKitErrors.h:
+ * Misc/WebKitErrors.m:
+ (registerErrors): Add new port blocked error code to WebKitErrorDomain
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::cancelledError): Fixed coding style
+ (WebFrameLoaderClient::blockedError): Return a ResourceError with the new custom error code
+
+2007-03-15 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ * Fixes: <rdar://problem/4927747> WebKit's Current Library Version number should match the Info.plist Version
+ * Factored out most of our common build settings into .xcconfig files. Anything that was common in
+ each build configuration was factored out into the shared .xcconfig file.
+ * Adds a Version.xcconfig file to define the current framework version, to be used in other places.
+ * Use the new $(BUNDLE_VERSION) (defined in Version.xcconfig) in the preprocessed Info.plist.
+ * Use the versions defined in Version.xcconfig to set $(DYLIB_CURRENT_VERSION).
+ * Make WebKit use the same warning flags as the other projects. This required two casts to be added to fix new warnings.
+
+ * Configurations/Base.xcconfig: Added.
+ * Configurations/DebugRelease.xcconfig: Added.
+ * Configurations/Version.xcconfig: Added.
+ * Configurations/WebKit.xcconfig: Added.
+ * Info.plist:
+ * Misc/WebKitVersionChecks.h:
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-03-15 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Anders.
+
+ Fixed: <rdar://problem/5001428> stationery background images do not display
+
+ Change 19244 fixed the method -[WebResource _shouldIgnoreWhenUnarchiving], but also broke Mail stationery.
+
+ The problem was that with archivedResourceForURL now fixed, the engine will try to decode the images. These images wouldn't decode because
+ Mail re-encodes and directly manipulates the image data in such a way that prevented WebKit from decoding the image. Because Mail was giving
+ us bad data, the images wouldn't render. This was never an issue before because archivedResourceForURL (broken) always returned nil, thus the
+ engine would never attempt to decode the resource, therefore the responsibility was delegated to Mail's protocol handler, which would do the
+ right thing and load the image.
+
+ Since Mail is relying on the fact it can store arbitrary data in WebArchives, I've introduced SPI that acts as a hint for us to ignore certain
+ subresources while unarchiving. This SPI is -[WebResource _shouldIgnoreWhenUnarchiving].
+
+ * WebView/WebResource.mm: Addd private ivar shouldIgnoreWhenUnarchiving.
+ (-[WebResource _ignoreWhenUnarchiving]): Added.
+ (-[WebResource _shouldIgnoreWhenUnarchiving]): Added.
+ * WebView/WebResourcePrivate.h: Added two methods to private header.
+ * WebView/WebUnarchivingState.m:
+ (-[WebUnarchivingState archivedResourceForURL:]): Check if we should ignore the resource.
+
+2007-03-15 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Antti.
+
+ Fix for <rdar://problem/5065060> ASSERTION FAILURE: newUsername && newPassword
+ when submitting an authentication form without password.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchWillSubmitForm): Don't omit form fields with empty values from the dictionary
+ passed to the delegate.
+
+2007-03-14 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Dave Hyatt.
+
+ Don't add the data twice, it's also done by didReceiveData.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::deliverArchivedResources):
+
+2007-03-14 Anders Carlsson <acarlsson@apple.com>
+
+ Fix segmentation fault when running layout tests.
+
+ Remove bogus check that that I added on purpose to see how good Geoff is at spotting mistakes when reviewing code.
+ (Turns out he's not that good!)
+
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::increaseLoadCount):
+
+2007-03-14 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ http://bugs.webkit.org/show_bug.cgi?id=13076
+ REGRESSION: Multiple loading tabs cause assertion in WebDocumentLoaderMac::decreaseLoadCount(unsigned long)
+
+ Store the identifier set in the document loader since identifiers are per-webview and not global.
+
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::WebDocumentLoaderMac):
+ (WebDocumentLoaderMac::attachToFrame):
+ (WebDocumentLoaderMac::increaseLoadCount):
+ (WebDocumentLoaderMac::decreaseLoadCount):
+
+2007-03-14 David Harrison <harrison@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5009625> REGRESSION: Aperture 1.5: Can't select entire line of text after correcting a misspelled word
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::respondToChangedSelection):
+ * WebCoreSupport/WebFrameBridge.mm:
+ Provide compatibility by not sending WebViewDidChangeSelectionNotification if
+ the app is Aperture and is linked against WebKit 2.0.
+
+=== Safari-5522.4 ===
+
+2007-03-14 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/5058714>
+ http://bugs.webkit.org/show_bug.cgi?id=13050
+
+ World leaks seen on Leopard after opening then closing tab (13050)
+
+ Add a hash set to prevent the load count to be increased twice for the same resource.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (loadingResources):
+ (WebDocumentLoaderMac::increaseLoadCount):
+ (WebDocumentLoaderMac::decreaseLoadCount):
+
+2007-03-14 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Removed _insertTextWithEvent, _insertNewlineWithEvent, and _insertTextWithEvent.
+ Instead, use execCommand and insertText methods on the Editor.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView insertTab:]):
+ (-[WebHTMLView insertBacktab:]):
+ (-[WebHTMLView insertNewline:]):
+ (-[WebHTMLView insertLineBreak:]):
+ (-[WebHTMLView insertParagraphSeparator:]):
+ (-[WebHTMLView insertNewlineIgnoringFieldEditor:]):
+ (-[WebHTMLView insertTabIgnoringFieldEditor:]):
+ (-[WebHTMLView yank:]):
+ (-[WebHTMLView yankAndSelect:]):
+ (-[WebHTMLView doCommandBySelector:]):
+ (-[WebHTMLView insertText:]):
+
+2007-03-14 David Hyatt <hyatt@apple.com>
+
+ Fixes to ensure that the resource loader's shared buffer can always be used.
+
+ Reviewed by olliej, mjs
+
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase _convertToWebCoreFormat]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::deliverArchivedResources):
+
+2007-03-13 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Brady.
+
+ Modify subresourceForURL to take NSString argument
+ so we can avoid [NSURL absoluteString]
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource subresourceForURL:]):
+
+2007-03-13 Brady Eidson <beidson@apple.com>
+
+ Rubberstamped by Alice
+
+ Meant to be part of my previous checkin... pruning unused code from WebKit
+
+ * WebView/WebFrame.mm: Removed _canCachePage
+ * WebView/WebFrameInternal.h: Ditto
+
+2007-03-13 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Maciej.
+
+ Fix for <rdar://problem/4277074> 8F32: Help Viewer crashed on
+ clicking link - KHTMLView::viewportMouseReleaseEvent (12647)
+
+ Re-set the DocumentLoader's frame when loading it from the page
+ cache before setting the document view.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::setDocumentViewFromPageCache):
+
+2007-03-13 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/5057117> Spoof user agent on Yahoo.com with Safari and WebKit as version 4xx
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView userAgent]): Stop using the deprecated lossyCString method.
+ * WebCoreSupport/WebFrameBridge.mm: Removed dead code, userAgentForURL: wasn't used.
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::userAgent): Call WebView's _userAgentForURL:.
+ * WebView/WebView.mm:
+ (-[WebView _cachedResponseForURL:]): Call userAgentForURL: instead of _userAgent.
+ (-[WebView userAgentForURL:]): Call _userAgentForURL:.
+ (-[WebView _userAgentWithApplicationName:andWebKitVersion:]): New method to construct a UA.
+ (-[WebView _computeUserAgent]): Ractored out into _userAgentWithApplicationName:andWebKitVersion:
+ (-[WebView _userAgentForURL:]): Tail compare for Yahoo.com, and return a UA with an older WebKit version.
+ * WebView/WebViewInternal.h: Declare _userAgentForURL:.
+
+2007-03-12 David Harrison <harrison@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4743256> ctrl-y key binding (yank) should do nothing when kill ring is empty
+
+ Test updated:
+ * editing/pasteboard/emacs-cntl-y-001.html:
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView yank:]):
+ (-[WebHTMLView yankAndSelect:]):
+ Do nothing if the killring is empty.
+
+2007-03-12 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - update for the new naming scheme for the Objective-C wrapper-creation
+ functions: _wrapElement: instead of _elementWith:, etc.
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::textFieldDidBeginEditing):
+ (WebEditorClient::textFieldDidEndEditing):
+ (WebEditorClient::textDidChangeInTextField):
+ (WebEditorClient::doTextFieldCommandFromEvent):
+ (WebEditorClient::textWillBeDeletedInTextField):
+ (WebEditorClient::textDidChangeInTextArea):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::createPlugin):
+ (WebFrameLoaderClient::createJavaAppletWidget):
+ * WebView/WebFrame.mm: (kit):
+ Use the _wrapElement-style functions.
+
+2007-03-12 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5057575>
+ REGRESSION: Repro Crash in FrameLoader::frame loading about:blank in PLT
+
+ Always get the web view from the current web frame, since the document loader's frame can have been zeroed out
+ (for example when detaching the document loader).
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::assignIdentifierToInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+
+2007-03-11 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adele.
+
+ Moved respondToChangedSelection from FrameBridge to EditorClient
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::respondToChangedSelection):
+ * WebCoreSupport/WebFrameBridge.mm:
+ Removed respondToChangedSelection from bridge
+
+2007-03-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12964
+ <rdar://problem/5045717> REGRESSION: crash in -[WebBaseNetscapePluginStream _deliverData]
+ at simpsonsmovie.com (12964)
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:]):
+ At every place we call the plug-in, since it could destroy the stream, get pluginView into a local
+ variable; it will be set to nil if the stream is destroyed.
+ (-[WebBaseNetscapePluginStream _destroyStream]): Added calls to retain/release to handle the case where
+ one of the calls to the plug-in destroys the stream. Added a call to cancelPreviousPerformRequestsWithTarget
+ in case _deliverData has been scheduled but not yet delivered. Also get pluginView into a local variable
+ as mentioned above, and check at strategic points and exit if the stream was already destroyed to avoid
+ multiple calls to NPP_DestroyStream or NPP_URLNotify.
+ (-[WebBaseNetscapePluginStream _deliverData]): Ditto.
+
+2007-03-10 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Fixed <rdar://problem/4587763> PAC file: lock inversion between QT and
+ JSCore causes a hang @ www.panoramas.dk
+
+ See JavaScriptCore ChangeLog for details.
+
+ Drop the JSLock before making calls through the plug-in API from functions
+ that may have been called by JavaScript.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ (-[WebBaseNetscapePluginView setWindowIfNecessary]):
+ (-[WebBaseNetscapePluginView initWithFrame:pluginPackage:URL:baseURL:MIMEType:attributeKeys:attributeValues:loadManually:DOMElement:]):
+ (-[WebBaseNetscapePluginView createPluginScriptableObject]):
+ (-[WebBaseNetscapePluginView evaluateJavaScriptPluginRequest:]):
+ (-[WebBaseNetscapePluginView webFrame:didFinishLoadWithReason:]):
+ (-[WebBaseNetscapePluginView loadPluginRequest:]):
+ (-[WebBaseNetscapePluginView _printedPluginBitmap]):
+ * Plugins/WebPluginController.mm:
+ (+[WebPluginController plugInViewWithArguments:fromPluginPackage:]):
+ (-[WebPluginController startAllPlugins]):
+ (-[WebPluginController stopAllPlugins]):
+ (-[WebPluginController addPlugin:]):
+ (-[WebPluginController destroyPlugin:]):
+ (-[WebPluginController destroyAllPlugins]):
+
+2007-03-10 David Kilzer <ddkilzer@webkit.org>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9609
+ REGRESSION: Missing image icon needs to be moved back to WebKit
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ Use WebCore::Image::loadPlatformResource(const char*) to load the missingImage image.
+
+2007-03-10 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/5051827> HIWebView handling of kEventControlGetData is broken in 64-bit
+
+ On Leopard the kEventParamControlDataBufferSize event parameter is of type typeByteCount.
+ The 32-bit implementation of GetEventParameter will coerce between integer types and
+ typeByteCount while the 64-bit version will return a failure. As typeByteCount is new
+ in Leopard we must continue using typeSInt32 when building for Tiger.
+
+ * Carbon/HIWebView.m:
+ (HIWebViewEventHandler):
+
+2007-03-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4976254> Please get off _NSSoftLinkingGetFrameworkFuncPtr
+
+ Use dlopen and dlsym to access the DCSShowDictionaryServiceWindow function.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+
+2007-03-09 Darin Adler <darin@apple.com>
+
+ Reviewed by Justin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8928
+ <rdar://problem/5045708> REPRODUCIBLE ASSERT: Cannot paste HTML into a
+ contenteditable region in an XHTML document (8928)
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _hasHTMLDocument]): Added.
+ (-[WebHTMLView _documentFragmentFromPasteboard:forType:inContext:subresources:]):
+ Don't call AppKit's conversion from the DOM to an attributed string if the document
+ is not an HTML document, to work around an AppKit limitation (Radar 5052390).
+
+2007-03-09 Darin Adler <darin@apple.com>
+
+ * English.lproj/StringsNotToBeLocalized.txt: Updated for recent changes.
+
+2007-03-08 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/5051616> Mouse clicks and movement are ignored in HIWebView on 64-bit
+
+ Mouse events are not being handled correctly as GetControlKind is returning an error
+ on 64-bit. The more modern HIObjectIsOfClass behaves correctly for this use.
+
+ * Carbon/HIWebView.m:
+ (HIWebViewDestructor):
+ (WindowHandler): Use HIObjectIsOfClass in place of GetControlKind.
+ (HIWebViewEventHandler): Don't leak the NSEvent.
+
+2007-03-08 Bruce Q Hammond <bruceq@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=13009
+ Console spews "CGContextGetType: invalid context" non-stop on web site
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ (-[WebBaseNetscapePluginView restorePortState:]):
+
+2007-03-08 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/4561772> HIWebView does not exist for 64-bit
+
+ Update HIWebView and friends to work without QuickDraw.
+
+ Changes are gleaned from the 64-bit support inside HICocoaView. The main
+ fact of interest are that all Carbon windows must have compositing enabled
+ so the code paths that aren't accessible are #ifdef'd out. Conveniently
+ these are the exact code paths that make use of QuickDraw.
+
+ There are currently minor event-handling and invalidation issues running as
+ 64-bit that are not present in 32-bit.
+
+ * Carbon/CarbonUtils.m:
+ * Carbon/CarbonWindowAdapter.m:
+ * Carbon/CarbonWindowFrame.m:
+ * Carbon/HIViewAdapter.m:
+ (SetViewNeedsDisplay):
+ * Carbon/HIWebView.m:
+ (Draw):
+ (Click):
+ (SyncFrame):
+ (StartUpdateObserver):
+ (StopUpdateObserver):
+ (UpdateObserver):
+ * WebKit.LP64.exp: Removed.
+ * WebKit.xcodeproj/project.pbxproj: Always use WebKit.exp.
+
+2007-03-08 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/4664697> highlighter SPI needs a node parameter to give more context
+
+ Added new methods to the WebHTMLHighlighter protocol that include the DOMNode being painted.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge customHighlightRect:forLine:representedNode:WebCore::]):
+ (-[WebFrameBridge paintCustomHighlight:forBox:onLine:behindText:entireLine:representedNode:WebCore::]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-03-08 Anders Carlsson <acarlsson@apple.com>
+
+ Try fixing the buildbot build.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+
+2007-03-07 Anders Carlsson <acarlsson@apple.com>
+
+ Leopard build fix.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+
+2007-03-07 Bruce Q Hammond <bruceq@apple.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12515
+ Plug-ins that draw through the Quickdraw interface fail in a CGBitmapContex.
+ <rdar://problem/4975122>
+
+ This fixes a problem with Netscape-style Plug-ins which draw through the Quickdraw APIs
+ being unable to render into offscreen bitmap contexts.
+
+ This patches both saveAndSetNewPortStateForUpdate: and restorePortState:
+ These methods now check the current context and see if appropriate setup/cleanup needs to be done
+ for offscreen rendering.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (QDPixelFormatFromCGBitmapInfo):
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ (-[WebBaseNetscapePluginView restorePortState:]):
+
+2007-03-07 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Use HardRetain/HardRelease.
+
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::setDataSource):
+ (WebDocumentLoaderMac::attachToFrame):
+ (WebDocumentLoaderMac::detachFromFrame):
+ (WebDocumentLoaderMac::increaseLoadCount):
+ (WebDocumentLoaderMac::decreaseLoadCount):
+
+2007-03-07 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4961259>
+ REGRESSION: Bumper Car 2.1.1 - Crash at WebCore::FrameLoader::receivedMainResourceError when encountering a invalid URL address
+
+ (The crash was already fixed, this actually makes Bumper Car load the error page correctly.)
+
+ This adds a "load counter" to the document loader and keeps the data source retained for as long as something is loading.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ Increase the load counter.
+
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ Decrease the load counter,
+
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::WebDocumentLoaderMac):
+
+ (WebDocumentLoaderMac::attachToFrame):
+ If the document loader has been detached, make sure to retain its data source here.
+
+ (WebDocumentLoaderMac::detachFromFrame):
+ Release the data source.
+
+ (WebDocumentLoaderMac::increaseLoadCount):
+ Retain the data source if load count was 0.
+
+ (WebDocumentLoaderMac::decreaseLoadCount):
+ Release the data source if load count becomes 0
+
+2007-03-07 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ WebKit part of fix for:
+ http://bugs.webkit.org/show_bug.cgi?id=10871
+ http://bugs.webkit.org/show_bug.cgi?id=12677
+ <rdar://problem/4823129> REGRESSION: IME key events different in nightly
+ <rdar://problem/4759563> REGRESSION: Return key is always sent when you confirm a clause in kotoeri
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent: shouldSaveCommand:]): Added shouldSaveCommand field to WebHTMLViewInterpretKeyEventsParameters.
+ When shouldSaveCommand is true, we call interpretKeyEvents and in doCommandBySelector and insertText, we just save the information without performing any action.
+ When shouldSaveCommand is false, we used the saved information and call doCommandBySelector and insertText directly.
+ If there's no saved command data in the KeyboardEvent, call interpretKeyEvents, and honor the shouldSaveCommand argument. This allows repeating keypress events
+ to function normally.
+ (-[WebHTMLView doCommandBySelector:]): If the WebHTMLViewInterpretKeyEventsParameters shouldSaveCommand field is set, then
+ just save the selector information in the KeyboardEvent, and don't perform the action.
+ (-[WebHTMLView insertText:]): ditto.
+ insertText can be called from an input method or from normal key event processing
+ If its from an input method, then we should go ahead and insert the text now.
+ The only way we know if its from an input method is to check hasMarkedText. There might be a better way to do this.
+
+ * WebView/WebHTMLViewInternal.h: Added shouldSaveCommand argument.
+ * WebView/WebViewInternal.h: ditto.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::handleKeypress): Changed handleKeyPress to handleKeypress. Call _interceptEditingKeyEvent with shouldSaveCommand:NO.
+ (WebEditorClient::handleInputMethodKeypress): Call _interceptEditingKeyEvent with shouldSaveCommand:YES.
+
+2007-03-07 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Brady.
+
+ Update to match WebCore.
+
+ * Plugins/WebNetscapePluginStream.mm:
+ (-[WebNetscapePluginStream start]):
+
+2007-03-07 Jim Correia <jim.correia@pobox.com>
+
+ Reviewed by Darin.
+
+ - WebCore part of fix for http://bugs.webkit.org/show_bug.cgi?id=12463
+ WebArchiver - attempt to insert nil exception when archive empty iframe
+
+ When dealing with an iframe element with no src attribute, the element contains
+ a src attribute in the DOM with a URL of "about:blank" and some HTML to implement
+ the blank page. In the original page source, however, the iframe element does
+ not include a src attribute, which caused a nil archive to be returned for the
+ childFrameArchive and thus caused the bug. The fix is a simple nil check.
+
+ Test: webarchive/archive-empty-frame-source.html
+
+ * WebView/WebArchiver.mm:
+ (+ (NSArray *)_subframeArchivesForFrame:(WebFrame *)frame): Don't add childFrameArchive
+ to the subframeArchives array if it is nil.
+
+2007-03-06 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ Made WebAuthenticationHandler.h SPI so Safari can call it directly.
+
+ * WebKit.exp:
+ added .objc_class_name_WebPanelAuthenticationHandler
+ * WebKit.xcodeproj/project.pbxproj:
+ changed status of WebAuthenticationHandler.h from "project" to "private"
+
+2007-03-06 Kevin McCullough <kmccullough@apple.com>
+
+ Reviewed by Darin.
+
+ - Rename a function to clarify its purpose.
+
+ * WebView/WebView.mm:
+ (+[WebView registerURLSchemeAsLocal:]):
+ * WebView/WebViewPrivate.h:
+
+2007-03-06 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ Update for WebCore changes.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::userAgent):
+
+2007-03-05 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam, Darin.
+
+ <rdar://problem/5025212>
+ In Mail, a crash occurs at WebCore::Frame::tree() when clicking on embedded flash object
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView loadPluginRequest:]):
+ Handle the case where the web view returned from the delegate method is null. Also, send out an error notification
+ in that case so we can catch it.
+
+2007-03-05 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin and Kevin D
+
+ - fixed <rdar://problem/5038087> Header and footer on printed page are too large after certain steps
+
+ * WebView/WebView.mm:
+ (-[WebView _adjustPrintingMarginsForHeaderAndFooter]):
+ This method was modifying the margins in the NSPrintInfo object without any sort of check whether
+ this had already been done. In some cases this can be called multiple times with the same
+ NSPrintInfo, so now we stash information in the NSPrintInfo's dictionary such that we always
+ start with a fresh copy of the original margins.
+
+2007-03-02 Kevin McCullough <kmccullough@apple.com>
+
+ Reviewed by Geoff.
+
+ - rdar://problem/4922454
+ - This fixes a security issue by making remote referrers not able to access local
+ resources, unless they register their schemes to be treated as local. The result is
+ that those schemes can access local resources and cannot be accessed by remote
+ referrers.
+ Because this behavior is new a link-on-or-after check is made to determine if the
+ app should use the older, less safe, behavior.
+
+ * Misc/WebKitVersionChecks.h: added linked-on-or-after check
+ * Misc/WebNSAttributedStringExtras.mm: Moved functionalit into the base class.
+ (fileWrapperForElement):
+ * Plugins/WebNetscapePluginStream.mm: uses new canLoad functions
+ * Plugins/WebPluginContainerCheck.mm: uses new canLoad functions
+ (-[WebPluginContainerCheck _isForbiddenFileLoad]):
+ * WebView/WebView.mm: make linked-on-or-after check and cache value, exposes SPI
+ for registering a scheme as local.
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ (+[WebView registerSchemeAsLocal:]):
+ * WebView/WebViewPrivate.h: exposes SPI for registering a scheme as local.
+
+2007-03-01 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by harrison
+
+ <rdar://problem/4838199>
+ Integrate Mail and WebKit paste operations
+
+ Provide subresources used to create the fragment as a
+ convenience.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+ Update the calls to the changed method.
+ (-[WebHTMLView _documentFragmentFromPasteboard:forType:inContext:subresources:]):
+ Give the caller the subresources in the WebArchive and RTF cases.
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-02-28 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Maciej.
+
+ Fixes <rdar://problem/5012009>
+
+ When looking for a requested resource we should also check
+ the set of manually added subresources if WebCore can't find it.
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource subresourceForURL:]):
+
+2007-02-28 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Beth
+
+ Start using the Thread Safety Check implemented in WebCore for the DOM bindings in the rest of
+ the WebKit API instead of the ASSERT_MAIN_THREAD() hack
+
+ * History/WebBackForwardList.mm:
+ (-[WebBackForwardList initWithWebCoreBackForwardList:]):
+ (-[WebBackForwardList init]):
+ (-[WebBackForwardList dealloc]):
+ (-[WebBackForwardList finalize]):
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem initWithURLString:title:lastVisitedTimeInterval:]):
+ (-[WebHistoryItem dealloc]):
+ (-[WebHistoryItem finalize]):
+ (-[WebHistoryItem copyWithZone:]):
+ (-[WebHistoryItem initWithWebCoreHistoryItem:]):
+ * Misc/WebIconDatabase.mm:
+ (-[WebIconDatabase init]):
+
+2007-02-28 Adele Peterson <adele@apple.com>
+
+ Reviewed by Beth.
+
+ Fix for <rdar://problem/4887423> REGRESSION: search results popup menu strings are not localized
+ and <rdar://problem/3517227> accessibility-related strings in WebCore are not localized
+
+ * WebCoreSupport/WebViewFactory.mm:
+ (-[WebViewFactory searchMenuNoRecentSearchesText]):
+ (-[WebViewFactory searchMenuRecentSearchesText]):
+ (-[WebViewFactory searchMenuClearRecentSearchesText]):
+ (-[WebViewFactory AXWebAreaText]):
+ (-[WebViewFactory AXLinkText]):
+ (-[WebViewFactory AXListMarkerText]):
+ (-[WebViewFactory AXImageMapText]):
+ (-[WebViewFactory AXHeadingText]):
+
+2007-02-28 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/5028473> WebKit allocates a huge number of NSCalendarDates while loading history file
+
+ * History/WebHistory.mm:
+ (-[WebHistoryPrivate insertItem:atDateIndex:]): Use lastVisitedTimeInterval rather than _lastVisitedDate to avoid allocating NSCalendarDates.
+
+2007-02-28 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/4985524> Problem with Blot and ToT WebKit (decoding WebCoreScrollView)
+
+ References to WebCoreScrollView as a subview of a WebHTMLView may be present in some NIB
+ files, so NSUnarchiver must be still able to look up the WebCoreScrollView class.
+
+ * WebKit.exp: Export WebCoreScrollView symbol.
+ * WebView/WebHTMLView.mm: Add empty WebCoreScrollView class.
+
+2007-02-27 Adam Roben <aroben@apple.com>
+
+ Reviewed by Beth.
+
+ Fix <rdar://problem/5011905> REGRESSION: "Open Link" contextual menu
+ item appears twice
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusToSendToOldClients): Remove the "Open Link" item from the
+ default menu items array before sending it off to Tiger Mail.
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): Set the
+ representedObject on every NSMenuItem to match our old (correct) API
+ behavior.
+
+2007-02-27 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=12906
+ REGRESSION: Canvas is pixelated when the page is opened in a background tab
+
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::scaleFactor): If the view is not in a window, use the main
+ screen's scale factor as a best guess.
+
+2007-02-26 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin and Geoff
+
+ * WebView/WebHTMLView.mm:
+ (coreGraphicsScreenPointForAppKitScreenPoint):
+ This method was copied from WebBrowser, and it was wrong. Fixed it. This only
+ affects the Dictionary pop-up panel.
+
+2007-02-26 David Hyatt <hyatt@apple.com>
+
+ Update web inspector to account for border-fit.
+
+ Reviewed by darin
+
+ * WebInspector/webInspector/inspector.js:
+
+2007-02-26 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Re-arranged things to put deprecated methods at the bottom.
+
+ * Misc/WebCoreStatistics.h:
+ * Misc/WebCoreStatistics.mm:
+ (+[WebCoreStatistics javaScriptNoGCAllowedObjectsCount]):
+ (+[WebCoreStatistics javaScriptReferencedObjectsCount]):
+ (+[WebCoreStatistics javaScriptRootObjectClasses]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-02-26 Maciej Stachowiak <mjs@apple.com>
+
+ Rubber stamped by Mitz.
+
+ - fix layout tests by fixing discrepancy in feature macros.
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector _highlightNode:]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-02-23 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=11573
+ REGRESSION: pressing option-left arrow while in suggestion popup moves the insertion point to the left
+
+ * WebView/WebHTMLView.mm:
+ (-[WebTextCompleteController endRevertingChange:moveLeft:]):
+
+2007-02-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Brady.
+
+ <rdar://problem/5016395> _recursive_pauseNullEventsForAllNetscapePlugins still gone
+
+ * WebView/WebFrameInternal.h: Remove _recursive_pauseNullEventsForAllNetscapePlugins
+ * WebView/WebFramePrivate.h: Add _recursive_pauseNullEventsForAllNetscapePlugins
+ * WebView/WebFrame.mm: More _recursive_pauseNullEventsForAllNetscapePlugins
+
+2007-02-22 Adele Peterson <adele@apple.com>
+
+ Reviewed by John.
+
+ Updating this image to match the one in WebCore.
+
+ * WebKit.vcproj/textAreaResizeCorner.png:
+
+2007-02-22 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=12399 REGRESSION:
+ Unable to prevent default context menu from appearing. <rdar://
+ problem/5017416>
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView menuForEvent:]): Clear the controller's context menu
+ before propagating a new context menu event through the DOM.
+
+2007-02-22 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ Removed some unused keyView-related code that I happened to run across.
+ Replacement code is now in WebChromeClient.
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.mm:
+ removed unused stuff
+
+2007-02-22 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12804
+ REGRESSION (r19043-r19063): suggestion popup doesn't work after pressing Option+Esc
+
+ This patch also fixes a bug where using the arrow keys while
+ the suggestion popup is open moves the caret instead of changing the
+ selection in the popup (for up/down) or accepting the selection and
+ closing the popup (for left/right).
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView keyDown:]): Changed to close the popup only if it was open
+ before the current event, so that the Option-Esc that opens the popup will
+ not close it immediately.
+ (-[WebHTMLView _interceptEditingKeyEvent:]): Give the completion popup a
+ chance to intercept keydown events.
+ (-[WebTextCompleteController popupWindowIsOpen]): Added. Returns whether the
+ suggestion popup is open.
+
+2007-02-22 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Mark (age 21).
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12805
+ REGRESSION: suggestion popup has a disabled scroll bar
+
+ * WebView/WebHTMLView.mm:
+ (-[WebTextCompleteController _buildUI]): Uncommented the call to the NSWindow
+ SPI that forces the scroll bar to look active. Also replaced a call to
+ the deprecated NSTableView method setAutoresizesAllColumnsToFit: with
+ the new method setColumnAutoresizingStyle: to eliminate console spew.
+
+2007-02-20 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Maciej.
+
+ WebKit changes needed to implement writeImage() in WebCore's
+ Pasteboard class.
+
+ * Misc/WebKitNSStringExtras.m: Call into WebCore for these
+ implementations.
+ (-[NSString _webkit_hasCaseInsensitiveSuffix:]):
+ (-[NSString _webkit_hasCaseInsensitiveSubstring:]):
+ (-[NSString _webkit_filenameByFixingIllegalCharacters]):
+ * Misc/WebNSURLExtras.m: Same.
+ (-[NSURL _webkit_suggestedFilenameWithMIMEType:]):
+ * WebCoreSupport/WebContextMenuClient.h: Remove
+ copyImageToClipboard()
+ * WebCoreSupport/WebContextMenuClient.mm:
+ * WebCoreSupport/WebSystemInterface.m: Expose
+ GetExtensionsForMIMEType and GetPreferredExtensionForMIMEType to
+ WebCore.
+ (InitWebCoreSystemInterface):
+ * WebCoreSupport/WebViewFactory.mm: New localized string for
+ WebCore.
+ (-[WebViewFactory copyImageUnknownFileLabel]):
+
+2007-02-20 Adam Roben <aroben@apple.com>
+
+ Reviewed by Darin and Anders.
+
+ Update WebKit for WebCore fix for <rdar://problem/4736215> Make
+ WebCoreStringTruncator use WebCore types.
+
+ * Misc/WebStringTruncator.m:
+ (defaultMenuFont): Moved from WebCoreStringTruncator.mm.
+ (core): Added.
+ (+[WebStringTruncator centerTruncateString:toWidth:]):
+ (+[WebStringTruncator centerTruncateString:toWidth:withFont:]):
+ (+[WebStringTruncator rightTruncateString:toWidth:withFont:]):
+ (+[WebStringTruncator widthOfString:font:]):
+ * WebKit.xcodeproj/project.pbxproj: Changed WebStringTruncator to ObjC++.
+
+2007-02-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ Fixes the version number returned when using a CFBundleVersion of "420+".
+
+ * WebView/WebView.mm:
+ (-[WebView _userVisibleBundleVersionFromFullVersion:]): Check the length up to the first
+ non-decimal digit, so this works with versions that have "." and "+".
+
+2007-02-20 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/4989344> REGRESSION: After clicking on page, Find
+ won't find anything if all hits are before the clicked point
+
+ This was caused by a mismatch between WebCore's search code's notion of "selection" and
+ WebView's search code's notion of "selection". WebCore's search code was starting
+ just before or just after the "selection", which included collapsed, zero-length
+ selections. WebKit's search code was only considering non-zero-length selections,
+ and would not search all of the content when there was a zero-length selection.
+ The fix was to make WebKit ignore the selection. This has a side effect of increasing
+ the amount of redundantly-searched content in the case where no matches are found. To
+ compensate for that, I special-cased the most common case of WebViews with a single frame,
+ to avoid ever searching redundantly in those.
+
+ * WebView/WebView.mm:
+ (-[WebView searchFor:direction:caseSensitive:wrap:startInSelection:]):
+ remove startHasSelection ivar; special-case WebViews with only one frame; clarify the
+ code that leads to redundant searching with comments.
+
+2007-02-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4900579> WebKit -finalize methods are not thread-safe; design change needed
+
+ Call WebCoreObjCFinalizeOnMainThread from the initialize method of all the classes
+ that have a finalizer that needs called on the main thread. Assert in finalize that we
+ are on the main thread.
+
+ * Carbon/CarbonWindowAdapter.m:
+ (+[CarbonWindowAdapter initialize]):
+ (-[CarbonWindowAdapter finalize]):
+ * History/WebBackForwardList.mm:
+ (+[WebBackForwardList initialize]):
+ (-[WebBackForwardList finalize]):
+ * History/WebHistoryItem.mm:
+ (+[WebHistoryItem initialize]):
+ * Misc/WebElementDictionary.mm:
+ (+[WebElementDictionary initialize]):
+ (-[WebElementDictionary finalize]):
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (+[WebBaseNetscapePluginStream initialize]):
+ (-[WebBaseNetscapePluginStream finalize]):
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (+[WebBaseNetscapePluginView initialize]):
+ (-[WebBaseNetscapePluginView finalize]):
+ * Plugins/WebBasePluginPackage.m:
+ (+[WebBasePluginPackage initialize]):
+ (-[WebBasePluginPackage finalize]):
+ * Plugins/WebNetscapePluginStream.mm:
+ (-[WebNetscapePluginStream finalize]):
+ * WebCoreSupport/WebEditorClient.mm:
+ (+[WebEditCommand initialize]):
+ (-[WebEditCommand finalize]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (+[WebFrameBridge initialize]):
+ (-[WebFrameBridge finalize]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (+[WebFramePolicyListener initialize]):
+ (-[WebFramePolicyListener finalize]):
+ * WebView/WebHTMLView.mm:
+ (+[WebHTMLView initialize]):
+ (-[WebHTMLView finalize]):
+ * WebView/WebView.mm:
+ (+[WebViewPrivate initialize]):
+ (-[WebViewPrivate finalize]):
+
+2007-02-20 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by darin
+
+ <rdar://problem/4838199>
+ Integrate Mail and WebKit paste operations
+
+ Mail overrides paste: because it has different
+ preferred pasteboard types, but it should use our
+ fragment creation code.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+ Moved fragment creation code into a new method.
+ (-[WebHTMLView _documentFragmentFromPasteboard:forType:inContext:]):
+ Moved fragment creation code here.
+ * WebView/WebHTMLViewPrivate.h: Exposed
+ _documentFragmentFromPasteboard:forType:inContext: as SPI.
+
+2007-02-20 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ * Misc/WebKitNSStringExtras.h:
+ * Misc/WebKitNSStringExtras.m:
+ removed _webkit_userVisibleBundleVersionFromFullVersion; we decided to do this without
+ adding SPI for it.
+
+ * WebView/WebView.mm:
+ (-[WebView _userVisibleBundleVersionFromFullVersion:]):
+ new method, moved here from WebKitNSStringExtras, and is now a WebView method rather than
+ an NSString method
+ (-[WebView _computeUserAgent]):
+ updated for method signature change
+
+2007-02-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ * Misc/WebKitNSStringExtras.h: Added _webkit_userVisibleBundleVersionFromFullVersion.
+ * Misc/WebKitNSStringExtras.m:
+ (-[NSString _webkit_userVisibleBundleVersionFromFullVersion]): If the version is 4 digits long or longer,
+ then the first digit represents the version of the OS. Our user agent string should not
+ include this first digit, so strip it off and report the rest as the version.
+ * WebView/WebView.mm:
+ (-[WebView _computeUserAgent]): Call _webkit_userVisibleBundleVersionFromFullVersion on the CFBundleVersion.
+
+2007-02-20 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ * Plugins/WebPluginController.mm: (-[WebPluginController pluginView:receivedResponse:]):
+ Call cancelMainResourceLoad on the document loader instead of the frame loader.
+
+2007-02-20 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Mitz.
+
+ <rdar://problem/5009627> REGRESSION: Repro overrelease of WebView in failed load, seen in DumpRenderTree
+
+ * WebView/WebView.mm:
+ (-[WebView _removeObjectForIdentifier:]):
+ Return early if the identifier can't be found in the map.
+
+2007-02-19 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin Adler.
+
+ <rdar://problem/4841078> Remove the Mail.app editable link clicking behavior workaround when it is no longer needed
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebView.mm:
+ (-[WebView setPreferences:]):
+
+2007-02-19 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/4868242>
+ http://bugs.webkit.org/show_bug.cgi?id=12670
+ REGRESSION: Many 3rd Party Apps crash in WebCore::DocumentLoader::frameLoader() (12670)
+
+ Bring back the semantic we had that a web view should be retained for as long as something is loading. Use the identifier
+ to object hash map for this.
+
+ * WebView/WebView.mm:
+ (-[WebView _addObject:forIdentifier:]):
+ (-[WebView _removeObjectForIdentifier:]):
+
+2007-02-18 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Oliver
+
+ <rdar://problem/4985321> - Can't edit templates for Web Gallery/Web Page Export in Aperture
+
+ * Misc/WebKitVersionChecks.h: Add a #define for this APERTURE quirk
+ * WebView/WebView.mm:
+ (-[WebView _shouldChangeSelectedDOMRange:toDOMRange:affinity:stillSelecting:]):
+ If the current app is Aperture and it was linked against Tiger WebKit, always allow selection change
+
+2007-02-17 Lars Knoll <lars@trolltech.com>
+
+ Reviewed by Maciej.
+
+ Additional coding by Maciej, additional review by Oliver.
+
+ Added implementations for the new callbacks in EditorClient
+ and ChromeClient (basically moved from WebFrameBridge).
+ Cleaned up some code paths that are not called anymore
+ and done fully inside WebCore now.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.mm:
+ * Misc/WebElementDictionary.mm:
+ * Misc/WebNSAttributedStringExtras.mm:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView getVariable:value:]):
+ * Plugins/WebNetscapePluginEmbeddedView.mm:
+ * Plugins/WebNetscapePluginStream.mm:
+ * Plugins/WebPluginContainerCheck.mm:
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::shouldInterruptJavaScript):
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::shouldChangeSelectedRange):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge finishInitializingWithPage:frameName:frameView:ownerElement:]):
+ (-[WebFrameBridge fini]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ * WebView/WebArchiver.mm:
+ * WebView/WebFrame.mm:
+ (core):
+ (kit):
+ (-[WebFrame _updateBackground]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFrameView.mm:
+ * WebView/WebHTMLRepresentation.mm:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ (-[WebHTMLView _isEditable]):
+ (-[WebHTMLView validateUserInterfaceItem:]):
+ (-[WebHTMLView maintainsInactiveSelection]):
+ (-[WebHTMLView scrollWheel:]):
+ (-[WebHTMLView acceptsFirstMouse:]):
+ (-[WebHTMLView shouldDelayWindowOrderingForEvent:]):
+ (-[WebHTMLView cut:]):
+ (-[WebHTMLView paste:]):
+ (-[WebHTMLView selectedAttributedString]):
+ * WebView/WebScriptDebugDelegate.mm:
+ * WebView/WebView.mm:
+ (-[WebView _dashboardRegions]):
+ (-[WebView setProhibitsMainFrameScrolling:]):
+ (-[WebView _setInViewSourceMode:]):
+ (-[WebView _inViewSourceMode]):
+ (-[WebView shouldClose]):
+ (-[WebView setEditable:]):
+
+2007-02-18 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Moving the drag initiation logic to WebCore.
+ The redundant code in webkit will be moved out in a later patch.
+
+ * WebCoreSupport/WebDragClient.h:
+ * WebCoreSupport/WebDragClient.mm:
+ (getTopHTMLView):
+ Helper function
+ (WebDragClient::willPerformDragSourceAction):
+ (WebDragClient::startDrag):
+ (WebDragClient::createDragImageForLink):
+ Implemented new DragClient methods
+ (WebDragClient::declareAndWriteDragImage):
+ Helper function for the Mac to allow new drag and drop
+ code to match behaviour
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _dragImageForURL:withLabel:]):
+ (-[WebHTMLView _dragImageForLinkElement:]):
+ Refactoring old _dragImageForLinkElement function so that
+ the link drag image can be created with just a URL and label,
+ rather than requiring the original element
+ (-[WebHTMLView dragImage:at:offset:event:pasteboard:source:slideBack:]):
+ Removed logic that is no longer necessary
+ (-[WebHTMLView _mouseDownEvent]):
+ The WebDragClient may need the original mouseDownEvent of a drag when initiating
+ a drag
+ * WebView/WebHTMLViewInternal.h:
+ Declaring _mouseDownEvent
+
+ * WebView/WebHTMLViewPrivate.h:
+ Declaring _dragImageForURL
+
+2007-02-16 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ - fixed <rdar://problem/4811446> "Check Grammar" checkbox in Spelling+Grammar window doesn't
+ live update with menu change in WebKit
+
+ * WebView/WebView.mm:
+ (-[WebView setGrammarCheckingEnabled:]):
+ Use sekrit AppKit knowledge to tell NSSpellChecker about the change, since there's no API
+ for this yet. Also restructured a little to avoid extra work when the value hasn't changed.
+
+2007-02-15 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adam
+
+ Save scroll state for back/forward navigation in FrameLoader, not the client
+
+ * WebCoreSupport/WebFrameLoaderClient.h: Renamed the save/restore methods
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::saveViewStateToItem): Save viewstate only
+ (WebFrameLoaderClient::restoreViewState): Restore viewstate only
+
+2007-02-14 Alexey Proskuryakov <ap@webkit.org>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=12643
+ NPN_Status is using latin-1 encoding for the message instead of UTF-8
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView status:]): Check for possible conversion failure.
+
+2007-02-13 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by John.
+
+ Modify entry point ASSERTs for dragging functions to allow for the case
+ where a load has occurred mid-drag. The load may detach the HTMLView
+ from the WebView so it is no longer possible to check _isTopHTMLView.
+
+ The assertion changes match that of revision 14897 which fixed the
+ more common case ([WebHTMLView draggedImage:endedAt:operation:])
+
+ It's also necessary to check for a null Page now prior to accessing
+ the DragController, which is necessary in all of these methods.
+
+ See rdar://problem/4994870
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView draggingSourceOperationMaskForLocal:]):
+ (-[WebHTMLView draggedImage:movedTo:]):
+ (-[WebHTMLView draggedImage:endedAt:operation:]):
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]):
+
+2007-02-13 Alexey Proskuryakov <ap@webkit.org>
+
+ Reviewed by Maciej.
+
+ http://bugs.webkit.org/show_bug.cgi?id=12643
+ NPN_Status is using latin-1 encoding for the message instead of UTF-8
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView status:]): Use kCFStringEncodingUTF8.
+
+2007-02-13 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Timothy Hatcher.
+
+ Fix http://bugs.webkit.org/show_bug.cgi?id=12745
+ Bug 12745: REGRESSION: Webkit will not load a plugin that Safari can load (symbol missing _objc_msgSend_fpret)
+
+ Treat libobjc as a sub-library of WebKit in Debug/Release so that plugins and applications linked against an
+ umbrella framework version of WebKit that expect to find libobjc symbols in WebKit can do so.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-02-12 Kevin McCullough <kmccullough@apple.com>
+
+ Reviewed by .
+
+ - reverting change to not cause regressions and performance problems.
+
+ * Misc/WebNSAttributedStringExtras.mm:
+ (fileWrapperForElement):
+
+2007-02-12 Darin Adler <darin@apple.com>
+
+ Reviewed by Oliver.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12677
+ <rdar://problem/4759563> REGRESSION: Return key is always sent when you confirm
+ a clause in kotoeri (12677)
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12596
+ <rdar://problem/4794346> REGRESSION: Tab key shifts form field focus instead of
+ navigating prediction window (12596)
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=10010
+ <rdar://problem/4822935> REGRESSION: Pressing Return with unconfirmed text in
+ Hangul inserts carriage return (10010)
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12531
+ <rdar://problem/4975126> REGRESSION: Inline text input types repeated keys in
+ latest nightly (r19336) (12531)
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12539
+ <rdar://problem/4975130> REGRESSION: Pressing Backspace while in inline input
+ area moves to the previous page in history (12539)
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm: (WebEditorClient::markedTextAbandoned):
+ Added.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView menuForEvent:]): Added explicit constructor needed now that the
+ function takes a const&.
+ (-[WebHTMLView becomeFirstResponder]): Removed fake event code, no longer needed
+ since advanceFocus now works fine with 0 for a DOM event.
+ (-[WebHTMLView _expandSelectionToGranularity:]): Changed to use the normal
+ selection controller function instead of selectRange.
+ (-[WebHTMLView insertTab:]): Changed to call bottleneck that receives the DOM
+ event.
+ (-[WebHTMLView insertBacktab:]): Ditto.
+ (-[WebHTMLView insertNewline:]): Ditto.
+ (-[WebHTMLView insertLineBreak:]): Ditto.
+ (-[WebHTMLView insertParagraphSeparator:]): Ditto.
+ (-[WebHTMLView insertNewlineIgnoringFieldEditor:]): Ditto.
+ (-[WebHTMLView insertTabIgnoringFieldEditor:]): Ditto.
+ (-[WebHTMLView yank:]): Updated to call Editor directly since the insertText
+ code now works via a text input event which is not what we want for paste-like
+ things such as yank.
+ (-[WebHTMLView yankAndSelect:]): Ditto.
+ (-[WebHTMLView selectToMark:]): Changed to use the normal selection controller
+ function instead of selectRange, which also allows us to remove the ObjC exception
+ handling code.
+ (-[WebHTMLView swapWithMark:]): Ditto.
+ (-[WebHTMLView transpose:]): Ditto.
+ (-[WebHTMLView unmarkText]): Since this is one of the calls back from the input
+ manager, added code to set the "event was handled" flag. Moved the actual work
+ into the Editor class in WebCore and just call that from here.
+ (-[WebHTMLView _selectRangeInMarkedText:]): Changed to use the normal selection
+ controller function instead of selectRange.
+ (-[WebHTMLView setMarkedText:selectedRange:]): Since this is one of the calls
+ back from the input manager, added code to set the "event was handled" flag.
+ Also changed the ignoreMarkedTextSelectionChange to use the flag over on the
+ WebCore side, since we moved it there and to call selectMarkedText over on
+ the WebCore side too.
+ (-[WebHTMLView doCommandBySelector:]): Added special cases for newline and tab
+ selectors so that the event is passed along. These selectors are special because
+ they are ones that turn into text input events.
+ (-[WebHTMLView _discardMarkedText]): Moved the body of this function into the
+ Editor class in WebCore and just call that from here.
+ (-[WebHTMLView insertText:]): Added code to send a text input event instead of
+ calling the editor to do text insertion. The insertion is then done in the
+ default handler for the text input event.
+ (-[WebHTMLView _insertNewlineWithEvent:isLineBreak:]): Added. Sends a text
+ input event.
+ (-[WebHTMLView _insertTabWithEvent:isBackTab:]): Ditto.
+ (-[WebHTMLView _updateSelectionForInputManager]): Changed to use the
+ ignoreMarkedTextSelectionChange flag in Editor now that the one here is gone.
+
+ * WebView/WebHTMLViewInternal.h: Remove ignoreMarkedTextSelectionChange field.
+
+ * WebView/WebView.mm: (-[WebView setSelectedDOMRange:affinity:]): Changed to
+ use the normal selection controller function instead of selectRange.
+
+2007-02-11 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Mark.
+
+ Switch the initial value of box-sizing property from "border-box" to "content-box".
+
+ * WebInspector/webInspector/inspector.js:
+
+2007-02-10 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=11847
+ REGRESSION (SearchField): Dragging to select in the Web Inspector's search fields drags the inspector window
+
+ * WebInspector/webInspector/inspector.css: Added the search field to the
+ undraggable dashboard-region.
+
+2007-02-09 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Darin & Maciej.
+
+ Fixed: <rdar://problem/4930688> REGRESSION: missing images when reloading webarchives (11962)
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::canUseArchivedResource): The bug here is that because a reload sets a cache
+ policy of NSURLRequestReloadIgnoringCacheData (rightfully so), this method was refusing to load
+ subresources in WebArchives. It's OK to use archive subresources for the NSURLRequestReloadIgnoringCacheData
+ cache policy because we're not worried about the actual contents of a WebArchive changing on disk.
+
+2007-02-09 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by darin
+
+ <rdar://problem/4975120>
+ REGRESSION: double-cursor after switching window away/back (11770)
+ <http://bugs.webkit.org/show_bug.cgi?id=11328>
+ Gmail Editor: Caret can simultaneously appear in both the TO: and message body fields
+
+ * WebCoreSupport/WebFrameBridge.mm: Removed unused methods.
+ * WebView/WebHTMLView.mm: Ditto.
+ (-[WebHTMLView _web_firstResponderCausesFocusDisplay]): Don't
+ appear focused if a descendant view is firstResponder.
+ (-[WebHTMLView _updateActiveState]): Removed the check for a BOOL
+ that was always false.
+ * WebView/WebHTMLViewInternal.h: Removed a BOOL that's always false.
+
+2007-02-09 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for <rdar://problem/4674537> REGRESSION: Adobe Acrobat 8 - Text
+ blinks when mouse is moved, and is invisible otherwise
+
+ Allow quirk if the Application was linked before 3.0 and if the
+ application is Adobe Acrobat.
+
+ * Misc/WebKitVersionChecks.h:
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2007-02-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Brady.
+
+ * WebKit.exp: Add WebBaseNetscapePluginView to the export list.
+
+2007-02-09 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Beth
+
+ - WebKit part of fix for radar 4939636, problems with context menu items and binaries linked
+ against WebKit 2.0.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Changed DYLIB_CURRENT_VERSION to 2 (was 1)
+
+ * Misc/WebKitVersionChecks.h:
+ Added constant WEBKIT_FIRST_VERSION_WITH_3_0_CONTEXT_MENU_TAGS, which is 2 but in the weird
+ format that these version checks use.
+
+ * WebView/WebUIDelegatePrivate.h:
+ Tweaked comments; included the old values for three tags for context menu items that changed
+ from SPI to API in 3.0; renamed WEBMENUITEMTAG_SPI_START to WEBMENUITEMTAG_WEBKIT_3_0_SPI_START
+ for clarity, and bumped its value to avoid conflict with the three old values
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (isAppleMail):
+ new helper function that checks the bundle identifier
+ (fixMenusToSendToOldClients):
+ Removed return value for clarity; now checks linked-on version and also makes special case
+ for Mail; now replaces three API tags with their old SPI values for clients that linked
+ against old WebKit version, in addition to replacing new API with WebMenuItemTagOther for
+ items that had no specific tag before.
+ (fixMenusReceivedFromOldClients):
+ Removed return value for clarity; removed defaultMenuItems parameter because it's no longer
+ necessary; removed code that tried to recognize menus that got confused by the SPI -> API
+ change (we now pass the old SPI values to these clients to avoid confusing them); now
+ restores the tags for the items whose tags were replaced in fixMenusToSendToOldClients
+ (this used to restore the tags of the default items rather than the new items, which was
+ incorrect but happened to work since the clients we tested were using the objects from the
+ default items array in their new items array)
+ (WebContextMenuClient::getCustomMenuFromDefaultItems):
+ Updated to account for the removed return values for the two fix-up methods; moved the
+ autorelease of newItems here, which is clearer and was the source of a leak before.
+
+2007-02-08 Kevin McCullough <KMcCullough@apple.com>
+
+ Reviewed by
+
+ - fixing a build breakage.
+
+ * Misc/WebNSAttributedStringExtras.mm:
+ (fileWrapperForElement):
+
+2007-02-07 Charles Ying <charles_ying@yahoo.com>
+
+ Reviewed by Adam.
+
+ Code suggestion by aroben
+
+ Fix http://bugs.webkit.org/show_bug.cgi?id=12688
+
+ REGRESSION (r19469): ASSERT when right clicking on hyperlinks! in TOT webkit
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusReceivedFromOldClients):
+
+ - fixMenusReceivedFromOldClients was hitting an ASSERT incorrectly
+ because it could not match [item title] to any of the contentMenuItemTags
+ using pointer comparison ==. Instead, it needs to do a string comparison
+ between [item title] and the various contentMenuItemTags using
+ isEqualToString instead of ==. You would encounter this whenever the
+ context menu was activated, e.g., from a hyperlink right click (or
+ control click).
+
+
+2007-02-07 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ Move shouldInterruptJavaScript to the Chrome.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::shouldInterruptJavaScript):
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2007-02-07 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed all places in WebKit where _web_userVisibleString was used where
+ _web_originalDataAsString should have been used instead.
+
+ * History/WebURLsWithTitles.m:
+ (+[WebURLsWithTitles writeURLs:andTitles:toPasteboard:]):
+ use _web_originalDataAsString when writing since these aren't displayed to the user
+ (+[WebURLsWithTitles URLsFromPasteboard:]):
+ use _web_URLWithDataAsString when reading, to match what we used when writing
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_writeURL:andTitle:types:]):
+ use _web_originalDataAsString when writing the NSURL type; continue using
+ _web_userVisibleString when writing the plain text type
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _documentFragmentWithPaths:]):
+ added comment about why _web_userVisibleString is appropriate here
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+ use _web_originalDataAsString when setting the href attribute of an anchor tag
+
+2007-02-07 David Harrison <harrison@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/4943650> REGRESSION: insertion point blink redraws entire web page, making everything slow
+
+ Problem is that AppKit recently changed NSControl to trigger a full redraw if the control has a focus ring.
+ WebHTMLView is a subclass of NSControl, but the focus ring type was the default value, though we actually
+ draw no focus ring. Fix is to formally set our focus ring type.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView initWithFrame:]):
+ Send [self setFocusRingType:NSFocusRingTypeNone].
+
+2007-02-07 John Sullivan <sullivan@apple.com>
+
+ Undid changes that I hadn't intended to check in
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _documentFragmentWithPaths:]):
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+
+2007-02-07 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Ollie and Geoff
+
+ - fixed <rdar://problem/4982345> KURL::createCFURL leak inside -[WebFrameBridge startDraggingImage...]
+ reported by buildbot
+
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ don't retain the imageURL we pass to the drag controller -- it's just automagically
+ converted to a KURL anyway
+
+2007-02-07 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - fixed <rdar://problem/4974420> REGRESSION: Dragging a saved image into the browser window
+ displays a error (No File exists at the address "null") (12662)
+
+ * WebCoreSupport/WebPasteboardHelper.mm:
+ (WebPasteboardHelper::urlFromPasteboard):
+ use _web_originalDataAsString instead of _web_userVisibleString, since _web_userVisibleString
+ can return a string with non-ASCII characters -- suitable for display but not for code
+
+2007-02-07 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - added some clarity to some menu-handling shenanigans
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusToSendToOldClients):
+ renamed from fixMenusForOldClients; added comments, FIXME, and assertion
+ (fixMenusReceivedFromOldClients):
+ renamed from fixMenusFromOldClients; added comments, FIXME, and assertion
+ (WebContextMenuClient::getCustomMenuFromDefaultItems):
+ updated for name changes
+
+2007-02-06 Kevin Decker <kdecker@apple.com>
+
+ Fixed: <rdar://problem/4976681> ASSERTION failure on quit @ talkcrunch.com in _NPN_ReleaseObject
+
+ Reviewed by Anders.
+
+ * Plugins/WebPluginDatabase.m:
+ (+[WebPluginDatabase sharedDatabase]): Removed NSApplicationWillTerminateNotification observer and thus
+ also removed code that would unload the entire plug-in database when receiving that notification.
+
+ The bug here was that this notification callback would happen first before anything else thus unloading
+ plug-ins and releasing plug-in memory. That was crash prone because the JavaScriptCore collector would at
+ a later time attempt to release its CInstance references (references that point to plug-in memory)
+ without knowing WebKit already unloaded the plug-in out from underneath it. The WebPluginDatabase simply
+ does not have enough context to make this decision.
+
+ * WebView/WebView.mm: Added two statics: applicationIsTerminating, pluginDatabaseClientCount.
+ (+[WebView initialize]): Added NSApplicationWillTerminateNotification observer.
+ (+[WebView _applicationWillTerminate]): Added.
+ (-[WebView _close]): WebKit has both a global plug-in database and a separate, per WebView plug-in database.
+ We need to release both sets of plug-ins because Netscape plug-ins have "destructor functions" that should be
+ called when the browser unloads the plug-in. These functions can do important things, such as closing/deleting
+ files so it is important to ensure that they are properly called when the application terminates.
+
+ The new change is that on app shutdown, we unload WebKit's global plug-in database if and only if the last WebView
+ was closed. To do so otherwise would unload plug-ins out from underneath other WebViews.
+
+2007-02-06 Darin Adler <darin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=11080
+ <rdar://problem/4826648> REGRESSION: Incorrect vertical positioning of Safari
+ status bar text containing @ character (11080)
+
+ * Misc/WebKitNSStringExtras.m:
+ (canUseFastRenderer): Fix code that mistakenly used the slow renderer for strings
+ that have a direction of "other neutral", which includes the "@" character.
+ (-[NSString _web_drawAtPoint:font:textColor:]): Add code to make the baseline of
+ the text in the status bar right. AppKit's rule for rounding is complicated enough
+ that this is obviously not perfectly correct, but it does make both code paths
+ use the same baseline in all the places this is currently used in AppKit.
+
+2007-02-06 Darin Adler <darin@apple.com>
+
+ Spotted by Steve F.
+
+ * Misc/WebNSURLExtras.m:
+ (-[NSString _web_mapHostNameWithRange:encode:makeString:]):
+ Fix obvious logic mistake I introduced back in revision 8255.
+ I can't see how to exercise this code path, but I also can't
+ bear to leave this obviously-broken code as-is.
+
+2007-02-05 David Kilzer <ddkilzer@webkit.org>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=7266
+ Webarchive format saves duplicate WebSubresources to .webarchive file
+
+ Tests: webarchive/test-duplicate-resources.html
+ webarchive/test-frameset.html
+
+ * WebView/WebArchiver.mm:
+ (+[WebArchiver _archiveWithMarkupString:fromFrame:nodes:]): Use an NSMutableSet to prevent
+ duplicate subresources from being added to the webarchive.
+
+2007-02-06 Mark Rowe <mrowe@apple.com>
+
+ Roll out incomplete support for font-stretch (r19350) at Dave Hyatt's request.
+ See http://bugs.webkit.org/show_bug.cgi?id=12530#c9 for more info.
+
+ * WebInspector/webInspector/inspector.js:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _addToStyle:fontA:fontB:]):
+
+2007-02-05 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ Fix for <rdar://problem/4975161> REGRESSION: With BumperCar 2.1.1,
+ the contextual menu fails to appear when I ctrl-click on page
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): If the
+ delegate does not respond to contextMenuItemsForElement, return the
+ default menu instead of nil.
+
+2007-02-01 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ Added support for selectively ignoring WebCore::Node leaks during layout
+ tests, so that we can ignore known leaks in other components.
+
+ * Misc/WebCoreStatistics.h:
+ * Misc/WebCoreStatistics.mm:
+ (+[WebCoreStatistics startIgnoringWebCoreNodeLeaks]):
+ (+[WebCoreStatistics stopIgnoringWebCoreNodeLeaks]):
+
+2007-02-01 Nicholas Shanks <webkit@nickshanks.com>
+
+ Reviewed by Mark.
+
+ Add support for CSS2 font-stretch property.
+
+ * WebInspector/webInspector/inspector.js:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _addToStyle:fontA:fontB:]):
+
+2007-02-01 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/4730469> REGRESSION: Assertion failure in -[WebDataSource(WebInternal) _bridge] when forwarding message
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource subresources]): Check for being uncommitted and return emtpy result.
+ (-[WebDataSource subresourceForURL:]): ditto
+
+2007-01-31 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Migrating methods to WebCore
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebView/WebHTMLView.mm:
+ * WebView/WebHTMLViewPrivate.h:
+
+2007-01-31 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4886776>
+ REGRESSION: After opening a web archive, location shows the actual URL, not the webarchive file
+
+ "Revert" the change done in 13734.
+
+ * WebView/WebHTMLRepresentation.mm:
+ (-[WebHTMLRepresentation loadArchive]):
+ Don't do a new load here, as this would cancel the current load and call the resource load
+ delegate's didFailLoadingWithError: method. Instead, call continueLoadWithData.
+
+2007-02-01 Nikolas Zimmermann <zimmermann@kde.org>
+
+ Reviewed by Maciej.
+
+ Fix run-pageloadtest to actually work again.
+
+ * Misc/WebNSWindowExtras.m:
+ (+[NSWindow _webkit_displayThrottledWindows]):
+
+2007-01-31 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ WebKit part of fix for <rdar://problem/4521461> REGRESSION: when keyPress event changes form focus, inserted key goes to wrong control
+
+ * WebCoreSupport/WebEditorClient.mm: (WebEditorClient::handleKeyPress): Instead of using the selected frame, use the
+ frame for the target of the keyboard event. Also, don't do the canEdit check here, since the target's frame might not
+ have a selection at this point. Do the canEdit check within Editor::insertText, where we determine which selection to use
+ for inserting text.
+ * WebView/WebEditingDelegatePrivate.h: Added forward declaration of DOMHTMLElement. This is needed after reordering includes in WebEditorClient.mm.
+
+2007-01-31 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Turning an accidental API change to an SPI change
+
+ * WebView/WebEditingDelegate.h:
+ * WebView/WebEditingDelegatePrivate.h:
+ move some declarations into private header.
+
+2007-01-31 Darin Adler <darin@apple.com>
+
+ - fix build
+
+ * ForwardingHeaders/wtf/ListHashSet.h: Added.
+
+2007-01-31 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - related fix for <rdar://problem/4964407> REGRESSION: Mail hangs when replying, forwarding , or creating a new message
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame loadArchive:]): This method also needs to add the lame WebDataRequest property or other things, like
+ Mail Contents of Page, break.
+
+2007-01-31 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - add back no-op version of silly method so that shipping Safari can still run the PLT
+
+ * Misc/WebNSWindowExtras.m:
+ (-[NSWindow _webkit_displayThrottledWindows]):
+
+2007-01-31 Mark Rowe <mrowe@apple.com>
+
+ More build fixing.
+
+ * Misc/WebKitLogging.h: Use !defined() rather than !.
+ * Plugins/WebNetscapePluginStream.h: Remove #if __cplusplus as this file is only included from Obj-C++ files.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]): Use #ifdef rather than #if.
+ * WebView/WebView.mm:
+ (-[WebView isGrammarCheckingEnabled]): Ditto.
+
+2007-01-31 Mark Rowe <mrowe@apple.com>
+
+ Build fix.
+
+ * WebView/WebView.mm:
+ (-[WebView initWithFrame:frameName:groupName:]):
+
+2007-01-31 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Oliver.
+
+ Enable -Wundef in WebKit, and change misuses of #if to #ifdef or #ifndef as appropriate.
+
+ * Misc/WebKitLogging.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.mm:
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView validateUserInterfaceItem:]):
+ (-[WebHTMLView delete:]):
+ (-[WebHTMLView showGuessPanel:]):
+ (-[WebHTMLView copy:]):
+ (-[WebHTMLView cut:]):
+ (-[WebHTMLView paste:]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebView.mm:
+ (-[WebViewPrivate init]):
+ (-[WebView validateUserInterfaceItem:]):
+ * WebView/WebViewPrivate.h:
+
+2007-01-30 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Oliver
+
+ This is a corollary to <rdar://problem/4944887> where certain things happened on an alternate thread.
+ To help catch such behavior in the future, add ASSERT_MAIN_THREAD() to key WebKit API points
+
+ * History/WebHistoryItem.mm: Added ASSERT_MAIN_THREAD() to suspected API entry points
+ (-[WebHistoryItem dealloc]):
+ (-[WebHistoryItem finalize]):
+ (-[WebHistoryItem copyWithZone:]):
+ (-[WebHistoryItem URLString]):
+ (-[WebHistoryItem originalURLString]):
+ (-[WebHistoryItem title]):
+ (-[WebHistoryItem lastVisitedTimeInterval]):
+ (-[WebHistoryItem isEqual:]):
+ (-[WebHistoryItem description]):
+ (-[WebHistoryItem initWithWebCoreHistoryItem:]):
+ (-[WebHistoryItem initFromDictionaryRepresentation:]):
+ (-[WebHistoryItem scrollPoint]):
+ (-[WebHistoryItem dictionaryRepresentation]):
+ (-[WebHistoryItem target]):
+ (-[WebHistoryItem visitCount]):
+ (-[WebHistoryItem children]):
+ (-[WebHistoryItem URL]):
+ (-[WebHistoryItem _lastVisitedDate]):
+ (-[WebHistoryItem targetItem]):
+
+ * Misc/WebIconDatabase.mm: Added ASSERT_MAIN_THREAD() to suspected API entry points
+ (-[WebIconDatabase iconForURL:withSize:cache:]):
+ (-[WebIconDatabase iconURLForURL:]):
+ (-[WebIconDatabase defaultIconWithSize:]):
+ (-[WebIconDatabase retainIconForURL:]):
+ (-[WebIconDatabase releaseIconForURL:]):
+ (-[WebIconDatabase removeAllIcons]):
+ (-[WebIconDatabase _iconForFileURL:withSize:]):
+ (webGetNSImage):
+
+ * Misc/WebKitLogging.h: Added ASSERT_MAIN_THREAD()
+ * Misc/WebKitLogging.m:
+ (WebKitRunningOnMainThread): Added
+
+ * WebKit.xcodeproj/project.pbxproj: Define DISABLE_THREAD_CHECK until it is
+ safe to run with ASSERT_MAIN_THREAD() active
+
+2007-01-30 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4961953> Stop using NSString deprecated methods like initWithCString:
+
+ * Misc/WebNSImageExtras.m:
+ (-[NSImage _web_saveAndOpen]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-01-30 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Geoff.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12050
+ REGRESSION: Assertion failure in -[WebBaseNetscapePluginView willCallPlugInFunction] (plugin)
+
+ Test: plugins/createScriptableObject-before-start.html
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView createPluginScriptableObject]): Return NULL if
+ the plugin is not started.
+
+2007-01-30 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ <rdar://problem/4964407> REGRESSION: Mail hangs when replying, forwarding , or creating a new message
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadData:MIMEType:textEncodingName:baseURL:unreachableURL:]): Set WebDataRequest property on data
+ load requests since Mail specifically checks for this.
+
+2007-01-30 Graham Dennis <graham.dennis@gmail.com>
+
+ Reviewed by Maciej.
+
+ Part of fix for http://bugs.webkit.org/show_bug.cgi?id=10725
+ Image data in from RTFD clipboard data thrown away
+
+ The URLs for images in RTFD data must not be loaded until the resources
+ have been added to the WebUnarchivingState. This can't happen until
+ after the RTFD data has been parsed, so we must delay loading while this
+ RTFD data is being parsed to a document fragment.
+
+ * WebView/WebHTMLView.mm:
+ (uniqueURLWithRelativePart):
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]): defer loading the resources while RTFD data is being parsed.
+ (+[NSURL _web_uniqueWebDataURL]): Added this back because AppKit uses it.
+ * WebView/WebUnarchivingState.m:
+ (-[WebUnarchivingState archivedResourceForURL:]): orkaround for workaround for rdar://problem/4699166 so that other people can use archivedResourceForURL: too.
+
+2007-01-29 Jim Correia <jim.correia@pobox.com>
+
+ Reviewed by Mark.
+
+ Added support for -allowsUndo/-setAllowsUndo: to allow editable WebView
+ clients to completely disable undo registration. This is functionally
+ equivalent to the methods with the same names on NSTextView.
+
+ * WebView/WebView.mm:
+ (-[WebViewPrivate init]):
+ (-[WebView initWithCoder:]):
+ (-[WebView encodeWithCoder:]):
+ (-[WebView allowsUndo]):
+ (-[WebView setAllowsUndo:]):
+ (-[WebView undoManager]):
+ * WebView/WebViewPrivate.h:
+
+2007-01-29 Ada Chan <adachan@apple.com>
+
+ Reviewed by Brady.
+
+ Moved the update of the title of the current entry in the backforward list to WebCore.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::setTitle):
+
+2007-01-29 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ More preparation for event handling fixes.
+
+ * WebCoreSupport/WebEditorClient.h: Removed EventTargetNode parameter, since you can
+ just get this from the KeyboardEvent.
+ * WebCoreSupport/WebEditorClient.mm: (WebEditorClient::handleKeyPress): ditto.
+
+ * WebView/WebHTMLViewInternal.h: Added interpretKeyEventsParameters struct.
+ * WebView/WebViewInternal.h: Changed parameter from NSEvent to WebCoreKeyboardEvent in _interceptEditingKeyEvent.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView yankAndSelect:]): Updated for new triggeringEvent parameter.
+ (-[WebHTMLView _interceptEditingKeyEvent:]): Set the WebHTMLViewInterpretKeyEventsParameters.
+ (-[WebHTMLView doCommandBySelector:]): Access WebHTMLViewInterpretKeyEventsParameters.
+ (-[WebHTMLView insertText:]): ditto.
+ (-[WebHTMLView _insertText:selectInsertedText:triggeringEvent:]): Added parameter for triggeringEvent.
+
+2007-01-29 Oliver Hunt <oliver@apple.com>
+
+ build fix
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+
+2007-01-25 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Migrated drag state and logic to WebCore, removed superfluous methods
+
+ * ChangeLog:
+ * WebCoreSupport/WebDragClient.h:
+ * WebCoreSupport/WebDragClient.mm:
+ (WebDragClient::dragSourceActionMaskForPoint):
+ * WebCoreSupport/WebFrameBridge.mm:
+ allowDHTMLDrag move to WebCore::EventHandler
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ (-[WebHTMLView draggedImage:movedTo:]):
+ (-[WebHTMLView draggedImage:endedAt:operation:]):
+ dragOffset and dragSourecAction is now stored in WebCore::DragController
+ migrated _delegateDragSourceActionMask to WebCore::DragController
+ * WebView/WebHTMLViewInternal.h:
+ Removed dragOffset declaration, migrated to WebCore::DragController
+ * WebView/WebView.mm:
+ removed unnecessary method, _loadingDragOperationForDraggingInfo
+
+2007-01-29 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Mark.
+
+ - updated for cross-platform data loading support
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::createDocumentLoader):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource initWithRequest:]):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::WebDocumentLoaderMac):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadData:MIMEType:textEncodingName:baseURL:unreachableURL:]):
+ (-[WebFrame loadData:MIMEType:textEncodingName:baseURL:]):
+ (-[WebFrame _loadHTMLString:baseURL:unreachableURL:]):
+ (-[WebFrame loadArchive:]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.mm:
+ (uniqueURLWithRelativePart):
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+
+2007-01-27 David Kilzer <ddkilzer@webkit.org>
+
+ Reviewed by Adam.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12260
+ Windows platform build is not maintained
+
+ * COM/ChromeClientWin.cpp:
+ (ChromeClientWin::canTakeFocus):
+ (ChromeClientWin::takeFocus):
+ * COM/ChromeClientWin.h:
+ * COM/ContextMenuClientWin.cpp:
+ (ContextMenuClientWin::getCustomMenuFromDefaultItems):
+ (ContextMenuClientWin::searchWithGoogle):
+ * COM/ContextMenuClientWin.h:
+ * COM/WebFrameLoaderClient.cpp:
+ (WebFrameLoaderClient::assignIdentifierToInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::dispatchDidFailProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidFailLoad):
+ (WebFrameLoaderClient::dispatchCreatePage):
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction):
+ (WebFrameLoaderClient::dispatchUnableToImplementPolicy):
+ (WebFrameLoaderClient::setMainDocumentError):
+ (WebFrameLoaderClient::incrementProgress):
+ (WebFrameLoaderClient::completeProgress):
+ (WebFrameLoaderClient::startDownload):
+ (WebFrameLoaderClient::committedLoad):
+ (WebFrameLoaderClient::cancelledError):
+ (WebFrameLoaderClient::cannotShowURLError):
+ (WebFrameLoaderClient::interruptForPolicyChangeError):
+ (WebFrameLoaderClient::cannotShowMIMETypeError):
+ (WebFrameLoaderClient::fileDoesNotExistError):
+ (WebFrameLoaderClient::shouldFallBack):
+ (WebFrameLoaderClient::willUseArchive):
+ (WebFrameLoaderClient::createDocumentLoader):
+ (WebFrameLoaderClient::download):
+ * COM/WebFrameLoaderClient.h:
+
+2007-01-27 David Harrison <harrison@apple.com>
+
+ Reviewed by Kevin.
+
+ <rdar://problem/4958902> REGRESSION: Dashboard widgets fail to load
+
+ This was caused by the WebView preferences rework in r18417. Specifically, in
+ _updateWebCoreSettingsFromPreferences when calling setUserStyleSheetLocation,
+ [NSURL URLWithString:] is now messaged directly with the result of
+ [[preferences userStyleSheetLocation] _web_originalDataAsString]], which will
+ be nil if the userStyleSheetLocation has not been set yet. [NSURL URLWithString:]
+ throws an exception when the string is nil. DashboardClient.app calls
+ setUserStyleSheetEnabled *before* calling setUserStyleSheetLocation.
+
+ * WebView/WebView.mm:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+ Pass empty string instead of nil string to [NSURL URLWithString:].
+
+2007-01-26 Darin Adler <darin@apple.com>
+
+ Reviewed by Timothy.
+
+ Fixes crash drawing avatar on mail.yahoo.com.
+
+ * Plugins/WebBaseNetscapePluginStream.m: Retain the object since destroyStreamWithError: might
+ release the last reference to it.
+
+2007-01-26 Darin Adler <darin@apple.com>
+
+ Reviewed by Beth.
+
+ * WebInspector/webInspector/inspector.js: Updated for new computed style properties.
+
+2007-01-26 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by andersca.
+
+ Fixed: <rdar://problem/4946922> WebBaseNetscapePluginView leaks memory
+ http://bugs.webkit.org/show_bug.cgi?id=11523
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream setPlugin:]): Calls -[WebBaseNetscapePluginView disconnectStream:]
+ * Plugins/WebBaseNetscapePluginView.h: Added disconnectStream: to header.
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView stop]): Make a copy of the streams collection prior to calling stop all streams.
+ This is necessary because calling stop has the side effect of removing the stream from this same collection.
+ (-[WebBaseNetscapePluginView disconnectStream:]): Added. Removes the stream from the streams collection.
+
+2007-01-25 Kevin Decker <kdecker@apple.com>
+
+ Backed out my last patch because it crashes espn.com. Stay tuned for a newer version..
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream setPlugin:]): Removed call to streamIsDead.
+ * Plugins/WebBaseNetscapePluginView.h: Removed streamIsDead.
+ * Plugins/WebBaseNetscapePluginView.mm: Ditto.
+
+2007-01-25 Darin Adler <darin@apple.com>
+
+ Reviewed by Beth.
+
+ - fix <rdar://problem/4952766> Safari has a top secret color picker that can be used to... uhh... I don't know
+
+ * Panels/English.lproj/WebAuthenticationPanel.nib/info.nib: Let Interface Builder have its way.
+ * Panels/English.lproj/WebAuthenticationPanel.nib/objects.nib: Remove the NSColorWell that was
+ in here (for no good reason).
+
+2007-01-25 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by andersca.
+
+ A few tweaks with of a fix done by Steve Gehrman.
+
+ Fixed: <rdar://problem/4946922> WebBaseNetscapePluginView leaks memory
+ http://bugs.webkit.org/show_bug.cgi?id=11523
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream setPlugin:]): Calls -[WebBaseNetscapePluginView streamIsDead:]
+ * Plugins/WebBaseNetscapePluginView.h: Added streamIsDead to header.
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView streamIsDead:]): Added. Removes the stream from the streams collection.
+
+2007-01-25 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin, Geoff, Brady, and Darin
+
+ - fixed <rdar://problem/4918446> Safari's temp files (PDF's) should be in a sub-folder when calling Preview
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _path]):
+ use _temporaryPDFDirectoryPath method instead of #defines for hardwiring strings; stop bad practice
+ of modifying the const char* returned by fileSystemRepresentation
+ (-[WebPDFView _temporaryPDFDirectoryPath]):
+ new method, lazily creates and returns a secure temporary directory created with NSTemporaryDirectory()
+ and mkdtemp
+
+ * English.lproj/StringsNotToBeLocalized.txt:
+ Updated for these and other recent changes
+
+2007-01-24 Oliver Hunt <oliver@apple.com>
+
+ Build fix
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]):
+
+2007-01-24 Oliver Hunt <ioliver@apple.com>
+
+ Reviewed by Maciej.
+
+ Migrating more drag state information to WebCore
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLViewPrivate dealloc]):
+ (-[WebHTMLViewPrivate clear]):
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ (-[WebHTMLView _mayStartDragAtEventLocation:]):
+ (-[WebHTMLView close]):
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]):
+ (-[WebHTMLView _delegateDragSourceActionMask]):
+ * WebView/WebHTMLViewInternal.h:
+
+2007-01-24 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ Small improvement to my last checkin to prevent the keyEventWasInterpreted bool from
+ being overwritten by reentrancy.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _interceptEditingKeyEvent:]): Point keyEventWasInterpreted pointer to local variable.
+ (-[WebHTMLView doCommandBySelector:]):
+ (-[WebHTMLView insertText:]):
+ * WebView/WebHTMLViewInternal.h: Added BOOL pointer that will point to the local variable on the stack in _interceptEditingKeyEvent
+
+2007-01-24 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ - Fix for <rdar://problem/4950527> REGRESSION: Can't use arrow keys (left/right) to navigate caret in input (type=text) or textarea fields
+
+ Keep track of whether interpretKeyEvents handles the key event based on whether or not we get
+ called in insertText or doCommandBySelector.
+
+ Test: fast/events/arrow-navigation.html
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView performKeyEquivalent:]):
+ (-[WebHTMLView _interceptEditingKeyEvent:]):
+ (-[WebHTMLView doCommandBySelector:]):
+ (-[WebHTMLView insertText:]):
+ * WebView/WebHTMLViewInternal.h:
+
+2007-01-25 Mark Rowe <mrowe@apple.com>
+
+ Reviewed by Maciej.
+
+ * Info.plist: Update copyright string.
+
+2007-01-24 Darin Adler <darin@apple.com>
+
+ Reviewed by Mark Rowe.
+
+ * WebKit.xcodeproj/project.pbxproj: Changed to /usr/sbin/sysctl
+ so we don't rely on people's paths.
+
+2007-01-24 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - fix small regression and GC problems noticed by code inspection
+
+ * WebView/WebHTMLView.mm: Move global declarations to the start of the file.
+ (+[WebHTMLView _excludedElementsForAttributedStringConversion]):
+ Add a CFRetain here for GC compatibility.
+ (+[WebHTMLView _insertablePasteboardTypes]): Ditto.
+ (-[WebHTMLView performKeyEquivalent:]): Fix small logic mistake that prevents
+ super from being called if EventHandler::keyEvent returns false. Reformatted
+ the code a bit and added a local variable for the frame.
+ (-[WebHTMLView _interceptEditingKeyEvent:]): Added some comments.
+ (-[WebHTMLView validAttributesForMarkedText]): Add a CFRetain here for
+ GC compatibility.
+
+2007-01-23 Adele Peterson <adele@apple.com>
+
+ Reviewed by Adam.
+
+ Fixed 2 layout tests that I broke with my last checkin.
+
+ * WebCoreSupport/WebEditorClient.mm: (WebEditorClient::handleKeyPress): Use the selected frame to get the WebHTMLView.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView performKeyEquivalent:]): Added global to keep track of NSEvent used here.
+ (-[WebHTMLView _interceptEditingKeyEvent:]): Check NSEvent against the event used in performKeyEquivalent.
+ We don't want to intercept these events.
+
+2007-01-23 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ WebKit part of fix for <rdar://problem/4946753>REGRESSION: Inserting tabs is broken in Mail
+
+ In addition to this fix, I also reorganized some event handling code for keyPress events to
+ prepare for another fix.
+
+ * WebCoreSupport/WebEditorClient.h: Added handleKeyPress method.
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::handleKeyPress): Added. Code moved from WebHTMLView keyDown method.
+ This is called from the defaultEventHandler so that in the future, we can make the right
+ decision about which selection the keyPress should apply to.
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView keyDown:]): Moved _interceptEditingKeyEvent call to handleKeyPress.
+ (-[WebHTMLView _interceptEditingKeyEvent:]): Prevents intercepting keys for cmd-modified events. Removed tabCycling checks
+ since this is now handled in WebCore.
+ * WebView/WebHTMLViewInternal.h: Made _interceptEditingKeyEvent SPI.
+ * WebView/WebView.mm: Use new tabKeyCyclesThroughElements methods on the page.
+ (-[WebViewPrivate init]): ditto.
+ (-[WebView setTabKeyCyclesThroughElements:]): ditto.
+ (-[WebView tabKeyCyclesThroughElements]): ditto.
+ (-[WebView setEditable:]): ditto
+
+2007-01-23 Lars Knoll <lars@trolltech.com>
+
+ Reviewed by Maciej
+
+ Make the last remaining pieces of the FrameLoader platform
+ independent. Move most of the code over to WebFrameLoaderClient.
+ Some smaller cleanups in the WebFrameBridge, and moved some
+ platform independent functionality over to the shared code
+ in WebCore.
+
+ * Webcoresupport/WebFrameBridge.mm:
+ (-[WebFrameBridge finishInitializingWithPage:frameName:frameView:ownerElement:]):
+ (-[WebFrameBridge createChildFrameNamed:withURL:referrer:ownerElement:allowsScrolling:marginWidth:marginHeight:]):
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::setTitle):
+ (WebFrameLoaderClient::createFrame):
+ (WebFrameLoaderClient::objectContentType):
+ (nsArray):
+ (WebFrameLoaderClient::createPlugin):
+ (WebFrameLoaderClient::redirectDataToPlugin):
+ (nsMutableArray):
+ (WebFrameLoaderClient::createJavaAppletWidget):
+ (WebFrameLoaderClient::overrideMediaType):
+ (WebFrameLoaderClient::windowObjectCleared):
+
+2007-01-23 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Adam.
+
+ Drop logic bindings for WebKit
+
+ * WebCoreSupport/WebDragClient.h: Added.
+ * WebCoreSupport/WebDragClient.mm: Added.
+ (WebDragClient::WebDragClient):
+ (WebDragClient::actionMaskForDrag):
+ (WebDragClient::willPerformDragDestinationAction):
+ Standard client impl
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ Updated to use DragController to track drag state
+
+ * WebCoreSupport/WebPasteboardHelper.h: Added.
+ (WebPasteboardHelper::WebPasteboardHelper):
+ A *temporary* Helper class to access NSPasteboard access and
+ manipulation functions present in WebKit
+ * WebCoreSupport/WebPasteboardHelper.mm: Added.
+ (WebPasteboardHelper::urlFromPasteboard):
+ (WebPasteboardHelper::plainTextFromPasteboard):
+ (WebPasteboardHelper::fragmentFromPasteboard):
+ (WebPasteboardHelper::insertablePasteboardTypes):
+ See header comment
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDocumentInternal.h:
+ Remove unnecessary protocol
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _setDocumentView:]):
+ Updating to use DragController to track drag state
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ ditto
+ (-[WebHTMLView dragImage:at:offset:event:pasteboard:source:slideBack:]):
+ ditto
+ (-[WebHTMLView draggingSourceOperationMaskForLocal:]):
+ ditto
+ (-[WebHTMLView draggedImage:endedAt:operation:]):
+ ditto
+ (-[WebHTMLView _documentFragmentForPasteboard:]):
+ Helper method to generate DocumentFragment from NSPasteboard without regressing
+ (-[WebHTMLView _canProcessDragWithDraggingInfo:]):
+ Updating to use DragController to track drag state
+ (-[WebHTMLView _isMoveDrag:]):
+ (-[WebHTMLView _isNSColorDrag:]):
+ * WebView/WebHTMLViewInternal.h:
+ Removing unnecessary fields and methods
+ * WebView/WebView.mm:
+ (-[WebViewPrivate dealloc]):
+ Remove obsolete ASSERT
+ (-[WebView _setInitiatedDrag:]):
+ Now passes directly through to DragController
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ (-[WebView _loadingDragOperationForDraggingInfo:]):
+ Removed
+ (-[WebView draggingEntered:]):
+ Updated to use DragController
+ (-[WebView draggingUpdated:]):
+ ditto
+ (-[WebView draggingExited:]):
+ ditto
+ (-[WebView performDragOperation:]):
+ ditto
+ (-[WebView _hitTest:dragTypes:]):
+ * WebView/WebViewInternal.h:
+ remove unnecessary method def
+
+2007-01-22 John Sullivan <sullivan@apple.com>
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ Tiger build fix: remove unused variable for return value of dictionaryServiceWindowShow
+
+2007-01-22 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adam and Darin
+
+ - fixed <rdar://problem/4794320> "Look Up in Dictionary" does nothing in WebKit
+ (need to adopt new API)
+
+ * Misc/WebNSURLExtras.m:
+ (-[NSString _web_isUserVisibleURL]):
+ random typo correction in comment
+
+ * English.lproj/StringsNotToBeLocalized.txt:
+ updated for these changes
+
+ * WebView/WebHTMLView.mm:
+ (coreGraphicsScreenPointForAppKitScreenPoint):
+ new function to convert an AppKit screen point to a CG screen point
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ on Leopard now uses new API. There's something of an impedance mismatch between
+ this API and WebKit, but that was true for the SPI we were using in Tiger also.
+ Bug 4945808 covers the ways in which this is not perfect.
+
+2007-01-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim H.
+
+ * WebInspector/webInspector/inspector.css: Use row-resize for the splitter cursor
+ instead of move. It's a horizontal splitter resizer.
+
+2007-01-19 Adam Roben <aroben@apple.com>
+
+ Reviewed by Beth.
+
+ Fix <rdar://problem/4942294> REGRESSION: "Spelling and Grammar",
+ "Font", "Speech", and "Writing Direction" are missing from contextual
+ menu
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusForOldClients): Change our new SPI tags to
+ WebMenuItemTagOther because old clients aren't expecting the new tags.
+ (fixMenusFromOldClients): Use each menu item's title to figure out its
+ correct tag again.
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): Call
+ fixMenusForOldClients before calling up to the delegate.
+ * WebView/WebUIDelegatePrivate.h: Define WEBMENUITEMTAG_SPI_START so
+ that we can use it in WebContextMenuClient.
+
+2007-01-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - WebKit part of fix for: <rdar://problem/4451715> REGRESSION: On some sites, have to
+ type a character before username/password autofill kicks in
+
+ Added new webView:didFinishDocumentLoadForFrame: SPI and wired it up
+
+ * WebView/WebViewPrivate.h:
+ declare new delegate method
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ declare dispatchDidFinishDocumentLoad()
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidFinishDocumentLoad):
+ new method, calls new delegate method
+
+ * DefaultDelegates/WebDefaultFrameLoadDelegate.m:
+ (-[WebDefaultFrameLoadDelegate webView:didFinishDocumentLoadForFrame:]):
+ empty default implementation of new delegate method
+
+2007-01-19 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by John Sullivan.
+
+ http://bugs.webkit.org/show_bug.cgi?id=12308
+ REGRESSION(r18910): Crash in WebBaseNetscapePluginStream cancelLoadAndDestroyStreamWithError
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView initWithFrame:pluginPackage:URL:baseURL:MIMEType:attributeKeys:attributeValues:loadManually:DOMElement:]):
+ Move code from initWithFrame in here.
+
+2007-01-19 Anders Carlsson <acarlsson@apple.com>
+
+ Yet another build fix.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::setStatusbarText):
+
+2007-01-18 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ Move functions from the bridge to the chrome client.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::runJavaScriptAlert):
+ (WebChromeClient::runJavaScriptConfirm):
+ (WebChromeClient::runJavaScriptPrompt):
+ (WebChromeClient::setStatusBarText):
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2007-01-18 Adam Roben <aroben@apple.com>
+
+ Reviewed by Beth.
+
+ Fix <rdar://problem/4939672> REGRESSION: With text selected that is
+ not a link, the "Remove Link" contextual menu item remains active
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView menuForEvent:]): Leave autoenabling of menu items on so
+ that clients can implement validateMenuItem:.
+
+2007-01-18 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adele
+
+ <rdar://problem/4917290> -
+ Null deref in WebFrameLoaderClient::restoreScrollPositionAndViewState()
+ after regaining network connection
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::restoreScrollPositionAndViewState): Bail early with a null currentItem, preventing
+ a crash in release builds. Leave the ASSERT to help find other cases where this might happen in debug builds.
+
+2007-01-18 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/4939511> WebKit should set the CG clip path for plug-ins that draw using CoreGraphics
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView drawRect:]): Set the CG clip path to the plug-in dirty rect. This allows plug-ins to obtain their
+ dirty rect using functions like CGContextGetClipBoundingBox().
+
+2007-01-17 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Harrison.
+
+ Fix for <rdar://problem/4894155> REGRESSION: Extra line break is pasted with content into message body after choosing File - Paste
+
+ Migration of some editing code from WebHTMView to WebCore::Editor
+ resulted in not calling pasteboardTypesForSelection, which Mail was
+ overriding for the special purpose of adding a type to the
+ pasteboard after WebKit did. This patch adds 2 separate code paths
+ for Tiger and Leopard. On Tiger we give in and call the WebView's
+ pasteboardTypesForSelection. On Leopard we call a delegate after
+ the pasteboard types are set.
+
+ * DefaultDelegates/WebDefaultEditingDelegate.m:
+ (-[WebDefaultEditingDelegate webView:didSetSelectionTypesForPasteboard:]):
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::didSetSelectionTypesForPasteboard):
+ (WebEditorClient::pasteboardTypesForSelection):
+ * WebView/WebEditingDelegate.h:
+
+2007-01-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - WebKit part of fix for <rdar://problem/4462420> REGRESSION: Mail hangs during
+ Replace All if the replacement string contains the search string
+
+ * Misc/WebKitVersionChecks.h:
+ Added extern "C" so this can be used from .mm files. I don't need this change anymore for
+ this fix, but it's still worth fixing now so it doesn't bite anyone later.
+
+ * WebView/WebDocumentPrivate.h:
+ Invented new private protocol WebDocumentIncrementalSearching, that has one method. The one
+ method is just like the one WebDocumentSearching method, but with an additional parameter.
+ We hope to eliminate this dependence on protocols someday, but adding another one as SPI
+ seems like it won't make anything worse.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView searchFor:direction:caseSensitive:wrap:]):
+ now calls through to new method that has one additional parameter, passing NO to match old behavior
+ (-[WebHTMLView searchFor:direction:caseSensitive:wrap:startInSelection:]):
+ pass new parameter to bridge
+
+ * WebView/WebPDFView.h:
+ Declare conformance to WebDocumentIncrementalSearching protocol
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView searchFor:direction:caseSensitive:wrap:]):
+ now calls through to new method that has one additional parameter, passing NO to match old behavior
+ (-[WebPDFView searchFor:direction:caseSensitive:wrap:startInSelection:]):
+ new method, former guts of searchFor:direction:caseSensitive:wrap: but now handles startInSelection
+ parameter
+
+ * WebView/WebViewPrivate.h:
+ Declare new searchFor:direction:caseSensitive:wrap:startInSelection: method, just like existing
+ method but with one additional parameter
+
+ * WebView/WebView.mm:
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ now calls through to new method that has one additional parameter, passing NO to match old behavior
+ (-[WebView searchFor:direction:caseSensitive:wrap:startInSelection:]):
+ new method, former guts of searchFor:direction:caseSensitive:wrap: but now handles startInSelection
+ parameter
+
+2007-01-17 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Deth Bakin and Brian Dash
+
+ Drop Panther Support (?!?) and change the comment explaining some SPI forward decls
+
+ * Misc/WebDownload.m:
+
+2007-01-17 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12278
+ <rdar://problem/4928705> REGRESSION(r13070): Dragged image size includes padding (12278)
+
+ * Misc/WebElementDictionary.mm: (-[WebElementDictionary _imageRect]):
+ Call HitTestResult::imageRect, not HitTestResult::boundingBox.
+
+2007-01-17 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Move all code in WebNetscapePluginEmbeddedView down to WebBaseNetscapePluginView.
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView initWithFrame:pluginPackage:URL:baseURL:MIMEType:attributeKeys:attributeValues:loadManually:DOMElement:]):
+ (-[WebBaseNetscapePluginView didStart]):
+ (-[WebBaseNetscapePluginView dataSource]):
+ (-[WebBaseNetscapePluginView dealloc]):
+ (-[WebBaseNetscapePluginView pluginView:receivedResponse:]):
+ (-[WebBaseNetscapePluginView pluginView:receivedData:]):
+ (-[WebBaseNetscapePluginView pluginView:receivedError:]):
+ (-[WebBaseNetscapePluginView pluginViewFinishedLoading:]):
+ (-[WebBaseNetscapePluginView _redeliverStream]):
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.mm:
+
+2007-01-17 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/4887781> Seed: Repro Safari crash in -[WebHTMLRepresentation receivedData:withDataSource:] (music.aol.com)
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _receivedData:]): Protect self against destruction partway through this method.
+
+2007-01-16 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by harrison.
+
+ Fixed <rdar://problem/4921134> WebKit needs extensible cut/copy to allow additional types to be written to pasteboard
+
+ * DefaultDelegates/WebDefaultEditingDelegate.m:
+ (-[WebDefaultEditingDelegate webView:didWriteSelectionToPasteboard:]):
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::didWriteSelectionToPasteboard):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebEditingDelegate.h:
+
+2007-01-15 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by mjs
+
+ <rdar://problem/4810960>
+ Gmail Editor: window.focus() called on keyDown (9640)
+
+ The window's keydown event handler was being called
+ instead of the editable subframe's if there was a key binding
+ for the key event.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView performKeyEquivalent:]): Don't send the event
+ to WebCore unless this WebHTMLView is the firstResponder.
+
+2007-01-15 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Update to match WebCore.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::willChangeEstimatedProgress):
+ (WebFrameLoaderClient::didChangeEstimatedProgress):
+ (WebFrameLoaderClient::postProgressStartedNotification):
+ (WebFrameLoaderClient::postProgressEstimateChangedNotification):
+ (WebFrameLoaderClient::postProgressFinishedNotification):
+ Post the correct notifications.
+
+ * WebView/WebView.mm:
+ (-[WebViewPrivate init]):
+ (-[WebViewPrivate dealloc]):
+ Get rid of all progress tracking code.
+
+ (-[WebView estimatedProgress]):
+ Call ProgressTracker::estimatedProgress()
+
+2007-01-15 Adam Roben <aroben@apple.com>
+
+ Reviewed by Darin.
+
+ Fix: http://bugs.webkit.org/show_bug.cgi?id=12134
+ REGRESSION: Assertion failure and crash when right clicking selection
+ in forms
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (fixMenusFromOldApps): Static helper to fix up menus from applications
+ compiled against Tiger WebKit.
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): Call helper to
+ fix menus.
+ * WebView/WebUIDelegatePrivate.h: Fixed typo.
+
+2007-01-14 David Kilzer <ddkilzer@kilzer.net>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12251
+ REGRESSION (r18822-r18823): Assertion failure opening document with non-existent resources
+ (dom/xhtml/level2/html/HTMLIFrameElement11.xhtml)
+
+ * WebView/WebView.mm:
+ (-[WebView _objectForIdentifier:]): Removed assertion.
+ (-[WebView _removeObjectForIdentifier:]): Removed assertion.
+
+2007-01-12 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Add a HashMap between unsigned longs and Objective-C objects and use it for
+ the resource load delegate.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::assignIdentifierToInitialRequest):
+ (WebFrameLoaderClient::dispatchIdentifierForInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::incrementProgress):
+ (WebFrameLoaderClient::completeProgress):
+ * WebView/WebView.mm:
+ (-[WebViewPrivate init]):
+ (-[WebViewPrivate dealloc]):
+ (-[WebView _addObject:forIdentifier:]):
+ (-[WebView _objectForIdentifier:]):
+ (-[WebView _removeObjectForIdentifier:]):
+ * WebView/WebViewInternal.h:
+
+2007-01-11 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Anders
+
+ Rewrites HTTP Authentication setting up a more platform-independent structure
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2007-01-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Mitz.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12180
+ REGRESSION: Double-clicking on JS exception in JS log crashes in -[SharedBufferData initWithSharedBuffer:]
+
+ * WebView/WebDataSource.mm: (-[WebDataSource data]): Added null check.
+
+2007-01-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Hyatt.
+
+ - moved code from a couple WebCore bridging classes here instead
+
+ * Misc/WebNSPasteboardExtras.mm:
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:]):
+ Use MimeTypeRegistry instead of WebMimeTypeRegistryBridge.
+
+ * WebView/WebHTMLRepresentation.mm:
+ (stringArray): Added. Helper to convert a HashSet to an NSArray.
+ (concatenateArrays): Added. Helper to concatenate two NSArray objects.
+ (+[WebHTMLRepresentation supportedMIMETypes]): Use MimeTypeRegistry instead of
+ WebMimeTypeRegistryBridge. Also fix a potential GC problem by using a RetainPtr
+ instead of a [retain] on a global variable.
+ (+[WebHTMLRepresentation supportedNonImageMIMETypes]): Ditto.
+ (+[WebHTMLRepresentation supportedImageMIMETypes]): Ditto.
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _imageExistsAtPaths:]): Use MimeTypeRegistry instead of
+ WebMimeTypeRegistryBridge.
+ (-[WebHTMLView _documentFragmentWithPaths:]): Ditto.
+
+ * WebView/WebView.mm: (+[WebView _decodeData:]): Moved code here from
+ the old WebCoreEncodings class.
+
+ * WebKit.xcodeproj/project.pbxproj: Let Xcode have its way with this file.
+ Moved WebRenderNode into the appropriate group.
+
+2007-01-10 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=11775
+ 'Show URLs in Tool Tips' preference is ignored
+
+ * WebView/WebHTMLView.mm:
+ (-[WebHTMLView _resetCachedWebPreferences:]):
+ (-[WebHTMLView setDataSource:]): Added a call to _resetCachedWebPreferences:.
+ Added an assertion that the view is not closed, instead of reopening it.
+ Reopening should not occur, now that <http://bugs.webkit.org/show_bug.cgi?id=12087>
+ is fixed.
+
+2007-01-10 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by John.
+
+ Fix for <rdar://problem/4914258> REGRESSION: Search in Google now
+ operates on the current WebView instead of invoking Safari's
+ service
+
+ * WebCoreSupport/WebContextMenuClient.h:
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::searchWithGoogle): Call into WebView to
+ search in Google.
+ * WebView/WebViewInternal.h: Make _searchWithGoogleFromMenu
+ available.
+
+2007-01-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Rename the now ObjC++ files to be .mm and remove the explicit file types.
+
+ * DOM/WebDOMOperations.m: Removed.
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m: Removed.
+ * English.lproj/StringsNotToBeLocalized.txt:
+ * Misc/WebCoreStatistics.m: Removed.
+ * Misc/WebElementDictionary.m: Removed.
+ * Misc/WebIconDatabase.m: Removed.
+ * Misc/WebNSAttributedStringExtras.m: Removed.
+ * Misc/WebNSPasteboardExtras.m: Removed.
+ * Plugins/WebNetscapePluginEmbeddedView.m: Removed.
+ * Plugins/WebNullPluginView.m: Removed.
+ * Plugins/WebPluginContainerCheck.m: Removed.
+ * WebCoreSupport/WebViewFactory.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebArchiver.m: Removed.
+ * WebView/WebHTMLRepresentation.m: Removed.
+ * WebView/WebHTMLView.m: Removed.
+ * WebView/WebRenderNode.m: Removed.
+ * WebView/WebResource.m: Removed.
+ * WebView/WebScriptDebugDelegate.m: Removed.
+
+2007-01-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - remove window display throttling code; no longer used
+
+ * Misc/WebNSWindowExtras.h:
+ * Misc/WebNSWindowExtras.m:
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView initWithFrame:]):
+ * WebView/WebPreferenceKeysPrivate.h:
+
+2007-01-08 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Brady.
+
+ Remove bridge functions that are implemented directly in FrameLoader now.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2007-01-08 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Mark.
+
+ Adds default value for outline-color and fixes default
+ values of the recently fixed *-color properties.
+
+ * WebInspector/webInspector/inspector.js:
+
+2007-01-08 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=12161 REGRESSION:
+ Crash when control-clicking on an image for contextual menu
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView menuForEvent:]): We need to nil-check coreMenu since
+ it will be nil if the DOM popped up a menu instead. I cleaned up
+ the function to make all the nil checks early returns instead of
+ nesting all of the content. Also moved the autorelease to be with
+ the creation of the menu instead of at the return.
+
+2007-01-08 Sam Weinig <sam@webkit.org>
+
+ Reviewed by Tim H.
+
+ Adds default value for -webkit-box-shadow and fixes default
+ value of -webkit-column-count to be "auto". Also sorts the
+ list of defaults.
+
+ * WebInspector/webInspector/inspector.js:
+
+2007-01-08 Andrew Wellington <proton@wiretapped.net>
+
+ Reviewed by Mark.
+
+ * WebInspector/webInspector/inspector.js: Hide default values of
+ -webkit-column styles in WebInspector.
+
+2007-01-05 Darin Adler <darin@apple.com>
+
+ Reviewed by Hyatt.
+
+ * Misc/WebNSAttributedStringExtras.m:
+ (+[NSAttributedString _web_attributedStringFromRange:]):
+ Updated to use new list marker text API that is String rather than
+ DeprecatedString. Also removed code to do text form of non-text list
+ markers since the list marker class now deals with that.
+
+2007-01-05 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Fix build.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchCreatePage):
+
+2007-01-05 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ The data returned is now a SharedBuffer so wrap it in an NSData object.
+
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource data]):
+
+2007-01-04 Adam Roben <aroben@apple.com>
+
+ Reviewed by Geoff, cheered by others.
+
+ Dead code elimination.
+
+ * WebView/WebHTMLView.m:
+
+2007-01-04 Adam Roben <aroben@apple.com>
+
+ Boo on me for undoing Beth's hard work.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView menuForEvent:]): Undo a mistaken roll out of r18597.
+
+2007-01-04 David Kilzer <ddkilzer@webkit.org>
+
+ Reviewed by Brady.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=12111
+ Uninitialized variable in -[WebDefaultPolicyDelegate webView:decidePolicyForMIMEType:request:frame:decisionListener:]
+
+ * DefaultDelegates/WebDefaultPolicyDelegate.m: Initialize isDirectory.
+
+2007-01-04 Adam Roben <aroben@apple.com>
+
+ Reviewed by Geoff.
+
+ Remove WebKit/AppKit from handling tabbing between subframes.
+
+ * WebCoreSupport/WebChromeClient.h: Added new ChromeClient methods for
+ moving focus out of the WebView.
+ * WebCoreSupport/WebChromeClient.mm: Ditto.
+ (WebChromeClient::canTakeFocus):
+ (WebChromeClient::takeFocus):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge webView]): Added null-check of m_frame.
+ * WebView/WebHTMLView.m: Removed -[WebHTMLView nextValidKeyView].
+ (-[WebHTMLView _updateActiveState]): Changed to focus the frame if
+ WebCore believes it to be the focused frame.
+ (-[WebHTMLView becomeFirstResponder]): Rewrote to call into
+ FocusController to place focus correctly within the WebView.
+
+2007-01-04 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Brady.
+
+ FrameLoaderClient changed yet again.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+
+2007-01-04 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ FrameLoaderClient changed again.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::download):
+ (WebFrameLoaderClient::willUseArchive):
+
+2007-01-04 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ No need to hit test twice.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView menuForEvent:]):
+
+2007-01-04 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ Turn on WebCore context menus. Delete a bunch of WebKit context
+ menu code that is no longer needed.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m: Removed a lot
+ of code from this class. This class only still needs to exist for
+ PDF context menus, so we only need to deal with the menu items that
+ might possibly be added to a PDF context menu.
+ (-[WebDefaultUIDelegate
+ menuItemWithTag:target:representedObject:]): Same.
+ (-[WebDefaultUIDelegate
+ webView:contextMenuItemsForElement:defaultMenuItems:]): Same.
+ * WebCoreSupport/WebContextMenuClient.h: Name change and have the
+ former getCustomMenuFromDefaultItems function return the
+ PlatformMenuDescription since it feels funny to have the client set
+ the new platform description.
+ * WebCoreSupport/WebContextMenuClient.mm: Same.
+ (WebContextMenuClient::getCustomMenuFromDefaultItems): Same. Also
+ move in some code that used to be in _menuForElement.
+ * WebView/WebHTMLView.m: Deleted a bunch of un-used functions
+ (-[WebHTMLView menuForEvent:]): Turn on menus, and append the
+ Inspect Element item.
+ * WebView/WebHTMLViewPrivate.h: Deleted a bunch of un-used
+ functions.
+ * WebView/WebView.mm:
+ (-[WebView _menuForElement:defaultItems:]): Removed a lot of code
+ from _menuForElement that now makes more sense elsewhere. Only PDF
+ context menus use this function now. Hopefully we can just get rid
+ of it soon, too.
+
+2007-01-04 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Brady.
+
+ Update for WebCore changes.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::download):
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::incrementProgress):
+
+2007-01-04 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed by Alexey.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11900:
+ Windows build bustage
+
+ * COM/ChromeClientWin.cpp:
+ (ChromeClientWin::addMessageToConsole):
+ (ChromeClientWin::runBeforeUnloadConfirmPanel):
+ * COM/ChromeClientWin.h:
+ * COM/ContextMenuClientWin.cpp:
+ (ContextMenuClientWin::contextMenuItemSelected):
+ * COM/ContextMenuClientWin.h:
+ * COM/WebFrameLoaderClient.cpp:
+ (WebFrameLoaderClient::setDocumentViewFromPageCache):
+ (WebFrameLoaderClient::forceLayout):
+ (WebFrameLoaderClient::forceLayoutForNonHTML):
+ (WebFrameLoaderClient::updateGlobalHistoryForStandardLoad):
+ (WebFrameLoaderClient::updateGlobalHistoryForReload):
+ (WebFrameLoaderClient::shouldGoToHistoryItem):
+ (WebFrameLoaderClient::saveScrollPositionAndViewStateToItem):
+ (WebFrameLoaderClient::restoreScrollPositionAndViewState):
+ (WebFrameLoaderClient::provisionalLoadStarted):
+ (WebFrameLoaderClient::saveDocumentViewToPageCache):
+ (WebFrameLoaderClient::canCachePage):
+ * COM/WebFrameLoaderClient.h:
+ * WebKit.vcproj/WebKit.vcproj:
+
+2007-01-03 John Sullivan <sullivan@apple.com>
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _openWithFinder:]):
+ Tiger build fix: use [NSNumber initWithInt:] rather than the new [NSNumber initWithInteger:]
+
+2007-01-03 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/4145714> WebKit's PDFView's "Open in Preview" puts the
+ PDF in /tmp, both group and world-readable
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView _openWithFinder:]):
+ Make the file only readable by the current user
+
+2007-01-03 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by John.
+
+ Make localized strings for all of the context menu item titles that
+ are accessible to WebCore.
+
+ * English.lproj/Localizable.strings:
+ * WebCoreSupport/WebViewFactory.m:
+ (-[WebViewFactory contextMenuItemTagOpenLinkInNewWindow]):
+ (-[WebViewFactory contextMenuItemTagDownloadLinkToDisk]):
+ (-[WebViewFactory contextMenuItemTagCopyLinkToClipboard]):
+ (-[WebViewFactory contextMenuItemTagOpenImageInNewWindow]):
+ (-[WebViewFactory contextMenuItemTagDownloadImageToDisk]):
+ (-[WebViewFactory contextMenuItemTagCopyImageToClipboard]):
+ (-[WebViewFactory contextMenuItemTagOpenFrameInNewWindow]):
+ (-[WebViewFactory contextMenuItemTagCopy]):
+ (-[WebViewFactory contextMenuItemTagGoBack]):
+ (-[WebViewFactory contextMenuItemTagGoForward]):
+ (-[WebViewFactory contextMenuItemTagStop]):
+ (-[WebViewFactory contextMenuItemTagReload]):
+ (-[WebViewFactory contextMenuItemTagCut]):
+ (-[WebViewFactory contextMenuItemTagPaste]):
+ (-[WebViewFactory contextMenuItemTagNoGuessesFound]):
+ (-[WebViewFactory contextMenuItemTagIgnoreSpelling]):
+ (-[WebViewFactory contextMenuItemTagLearnSpelling]):
+ (-[WebViewFactory contextMenuItemTagSearchInSpotlight]):
+ (-[WebViewFactory contextMenuItemTagSearchWeb]):
+ (-[WebViewFactory contextMenuItemTagLookUpInDictionary]):
+ (-[WebViewFactory contextMenuItemTagOpenLink]):
+ (-[WebViewFactory contextMenuItemTagIgnoreGrammar]):
+ (-[WebViewFactory contextMenuItemTagSpellingMenu]):
+ (-[WebViewFactory contextMenuItemTagShowSpellingPanel:]):
+ (-[WebViewFactory contextMenuItemTagCheckSpelling]):
+ (-[WebViewFactory contextMenuItemTagCheckSpellingWhileTyping]):
+ (-[WebViewFactory contextMenuItemTagCheckGrammarWithSpelling]):
+ (-[WebViewFactory contextMenuItemTagFontMenu]):
+ (-[WebViewFactory contextMenuItemTagShowFonts]):
+ (-[WebViewFactory contextMenuItemTagBold]):
+ (-[WebViewFactory contextMenuItemTagItalic]):
+ (-[WebViewFactory contextMenuItemTagUnderline]):
+ (-[WebViewFactory contextMenuItemTagOutline]):
+ (-[WebViewFactory contextMenuItemTagStyles]):
+ (-[WebViewFactory contextMenuItemTagShowColors]):
+ (-[WebViewFactory contextMenuItemTagSpeechMenu]):
+ (-[WebViewFactory contextMenuItemTagStartSpeaking]):
+ (-[WebViewFactory contextMenuItemTagStopSpeaking]):
+ (-[WebViewFactory contextMenuItemTagWritingDirectionMenu]):
+ (-[WebViewFactory contextMenuItemTagDefaultDirection]):
+ (-[WebViewFactory contextMenuItemTagLeftToRight]):
+ (-[WebViewFactory contextMenuItemTagRightToLeft]):
+
+2007-01-03 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John Sullivan
+
+ In the Bookmarks View/History View, favicon may be the incorrect size
+
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem icon]): Call to the WebIconDatabase until a WebCore issue is resolved
+
+2007-01-03 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ - Fix for <rdar://problem/4455147> Safari allows division slash character in URLs, which looks like slash character (not fixed by IDNScriptWhiteList.txt)
+
+ * Misc/WebNSURLExtras.m: (allCharactersInIDNScriptWhiteList): Always disallow the division slash character.
+
+2007-01-02 Brady Eidson <beidson@apple.com>
+
+ Controversially reviewed by Tim H. and Maciej
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=12086, http://bugs.webkit.org/show_bug.cgi?id=12088,
+ possibly http://bugs.webkit.org/show_bug.cgi?id=12087, and probably a slew of others
+
+ WebHistoryItems returned from the WebBackForwardList accessors were being release/retained out-of-order
+ by the Safari app. This bug never surfaced before because the WebBackForwardList had a retain on the
+ item, preventing deallocation. Since the items are now just temporary wrappers, the list
+ is no longer actually retaining them.
+
+ This solution is to simulate the ownership with a [[id retain] autorelease] - gross, but maybe the
+ only solution for now... =/
+
+ We can possibly consider reverting this fix at a later date - that task is marked by
+ <rdar://problem/4905705>
+
+ * History/WebBackForwardList.mm:
+ (-[WebBackForwardList backItem]):
+ (-[WebBackForwardList currentItem]):
+ (-[WebBackForwardList forwardItem]):
+ (-[WebBackForwardList itemAtIndex:]):
+
+2007-01-02 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Geoff.
+
+ Remove un-used function.
+
+ * WebCoreSupport/WebContextMenuClient.h:
+ * WebCoreSupport/WebContextMenuClient.mm:
+
+2007-01-02 Brady Eidson <beidson@apple.com>
+
+ Reviewed extensively and repeatedly by Darin
+
+ <rdar://problem/4887137> - WebCore Back/Forward Cache
+ Most things not specifically commented on in the ChangeLog can be summed up as
+ "Do things exactly the same way as we used to, but just stick in WebCore-land as much as possible"
+
+ * History/WebBackForwardList.mm:
+ (kitPrivate): Convenience functions to help with subbing "WebBackForwardListPrivate" for WebCore::BackForwardList
+ (core):
+ (backForwardListWrappers): A HashMap pattern used to map WebCore objects to their WebKit counterpart
+ (kit):
+ (+[WebBackForwardList setDefaultPageCacheSizeIfNecessary]):
+ (-[WebBackForwardList initWithWebCoreBackForwardList:]):
+ (-[WebBackForwardList init]):
+ (-[WebBackForwardList dealloc]):
+ (-[WebBackForwardList finalize]):
+ (-[WebBackForwardList _close]):
+ (-[WebBackForwardList addItem:]):
+ (-[WebBackForwardList removeItem:]):
+ (-[WebBackForwardList containsItem:]):
+ (-[WebBackForwardList goBack]):
+ (-[WebBackForwardList goForward]):
+ (-[WebBackForwardList goToItem:]):
+ (-[WebBackForwardList backItem]):
+ (-[WebBackForwardList currentItem]):
+ (-[WebBackForwardList forwardItem]):
+ (vectorToNSArray):
+ (-[WebBackForwardList backListWithLimit:]):
+ (-[WebBackForwardList forwardListWithLimit:]):
+ (-[WebBackForwardList capacity]):
+ (-[WebBackForwardList setCapacity:]):
+ (-[WebBackForwardList description]):
+ (-[WebBackForwardList _clearPageCache]):
+ (-[WebBackForwardList setPageCacheSize:]):
+ (-[WebBackForwardList pageCacheSize]):
+ (-[WebBackForwardList _usesPageCache]):
+ (-[WebBackForwardList backListCount]):
+ (-[WebBackForwardList forwardListCount]):
+ (-[WebBackForwardList itemAtIndex:]):
+ * History/WebBackForwardListInternal.h: Added.
+
+ * History/WebHistory.m: Removed.
+ * History/WebHistory.mm: Added - Needed to be .mm to accept C++ header style
+ (-[_WebCoreHistoryProvider containsItemForURLLatin1:length:]):
+ (-[_WebCoreHistoryProvider containsItemForURLUnicode:length:]):
+
+ * History/WebHistoryItem.mm:
+ (kitPrivate): Same pattern as WebBackForwardList
+ (core):
+ (historyItemWrappers):
+ (WKNotifyHistoryItemChanged):
+ (-[WebHistoryItem init]):
+ (-[WebHistoryItem initWithURLString:title:lastVisitedTimeInterval:]):
+ (-[WebHistoryItem dealloc]):
+ (-[WebHistoryItem finalize]):
+ (-[WebHistoryItem copyWithZone:]):
+ (-[WebHistoryItem URLString]):
+ (-[WebHistoryItem originalURLString]):
+ (-[WebHistoryItem title]):
+ (-[WebHistoryItem setAlternateTitle:]):
+ (-[WebHistoryItem alternateTitle]):
+ (-[WebHistoryItem icon]):
+ (-[WebHistoryItem lastVisitedTimeInterval]):
+ (-[WebHistoryItem hash]):
+ (-[WebHistoryItem isEqual:]):
+ (-[WebHistoryItem description]):
+ (kit):
+ (+[WebHistoryItem entryWithURL:]):
+ (+[WebHistoryItem initWindowWatcherIfNecessary]):
+ (-[WebHistoryItem initWithURL:target:parent:title:]):
+ (-[WebHistoryItem initWithWebCoreHistoryItem:]):
+ (-[WebHistoryItem setTitle:]):
+ (-[WebHistoryItem setVisitCount:]):
+ (-[WebHistoryItem setViewState:]):
+ (-[WebHistoryItem _mergeAutoCompleteHints:]):
+ (-[WebHistoryItem initFromDictionaryRepresentation:]):
+ (-[WebHistoryItem scrollPoint]):
+ (-[WebHistoryItem _transientPropertyForKey:]):
+ (-[WebHistoryItem _setTransientProperty:forKey:]):
+ (-[WebHistoryItem dictionaryRepresentation]):
+ (-[WebHistoryItem target]):
+ (-[WebHistoryItem isTargetItem]):
+ (-[WebHistoryItem visitCount]):
+ (-[WebHistoryItem RSSFeedReferrer]):
+ (-[WebHistoryItem setRSSFeedReferrer:]):
+ (-[WebHistoryItem children]):
+ (-[WebHistoryItem setAlwaysAttemptToUsePageCache:]):
+ (-[WebHistoryItem URL]):
+ (-[WebHistoryItem _setLastVisitedTimeInterval:]):
+ (-[WebHistoryItem _lastVisitedDate]):
+ (-[WebHistoryItem targetItem]):
+ (+[WebHistoryItem _releaseAllPendingPageCaches]):
+ (-[WebWindowWatcher windowWillClose:]):
+ * History/WebHistoryItemInternal.h:
+ * History/WebHistoryItemPrivate.h:
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::setDocumentViewFromPageCache):
+ (WebFrameLoaderClient::detachedFromParent1):
+ (WebFrameLoaderClient::loadedFromPageCache):
+ (WebFrameLoaderClient::updateGlobalHistoryForStandardLoad):
+ (WebFrameLoaderClient::updateGlobalHistoryForReload):
+ (WebFrameLoaderClient::shouldGoToHistoryItem):
+ (WebFrameLoaderClient::frameLoadCompleted):
+ (WebFrameLoaderClient::saveScrollPositionAndViewStateToItem):
+ (WebFrameLoaderClient::restoreScrollPositionAndViewState):
+ (WebFrameLoaderClient::provisionalLoadStarted):
+ (WebFrameLoaderClient::setTitle):
+ (WebFrameLoaderClient::saveDocumentViewToPageCache):
+ (WebFrameLoaderClient::canCachePage):
+
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+ * WebView/WebDataSource.mm:
+ * WebView/WebDataSourceInternal.h:
+
+ * WebView/WebFrame.mm:
+ (-[WebFramePrivate dealloc]):
+ (-[WebFrame _canCachePage]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ * WebView/WebFrameInternal.h:
+
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView initWithFrame:]):
+ (-[WebFrameView keyDown:]):
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView closeIfNotCurrentView]): Added for a dirty hack in WebCore that is marked with a FIXME Radar
+ * WebView/WebHTMLViewInternal.h:
+
+ * WebView/WebView.mm:
+ (-[WebViewPrivate init]):
+ (-[WebViewPrivate dealloc]):
+ (-[WebView _close]):
+ (-[WebView _loadBackForwardListFromOtherView:]):
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ (-[WebView initWithCoder:]):
+ (-[WebView backForwardList]):
+ (-[WebView goBack]):
+ (-[WebView goForward]):
+ (-[WebView goToBackForwardItem:]):
+ (-[WebView canGoBack]):
+ (-[WebView canGoForward]):
+
+2007-01-02 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/4892525> Cannot open PDF in Preview if you attempted to
+ open it in Preview while PDF was loading
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView menuForEvent:]):
+ added comment
+ (-[WebPDFView validateUserInterfaceItem:]):
+ disable this menu item when there's no document yet
+ (-[WebPDFView _openWithFinder:]):
+ If this is invoked when there is no document yet (e.g. via the PDFKit delegate method),
+ just beep and return. I should make a nice error message here, but I'll do that separately.
+
+2007-01-03 Nikolas Zimmermann <zimmermann@kde.org>
+
+ Reviewed by Timothy.
+
+ Fix inspection of RenderSVGInlineText objects (#text nodes in SVG documents).
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector _highlightNode:]):
+
+2007-01-02 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Darin.
+
+ Fix bug with WebCore context menu item "Copy Image."
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::copyImageToClipboard): We must call
+ declareTypes on the pasteboard.
+
+2006-12-27 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed by Geoff.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9403
+ Red outline from Web Inspector appears above all other OS X windows
+
+ Made the window containing the highlight a child window of the window
+ containing the view.
+
+ * WebInspector/WebNodeHighlight.m:
+ (-[WebNodeHighlight initWithBounds:andRects:forView:]):
+ (-[WebNodeHighlight dealloc]):
+ (-[WebNodeHighlight expire]):
+
+2006-12-27 Matt Lilek <pewtermoose@gmail.com>
+
+ Reviewed by Tim H.
+
+ Bug 11993: REGRESSION(r18320): Web Inspector scroll bars not drawn
+ http://bugs.webkit.org/show_bug.cgi?id=11993
+
+ AppleVerticalScrollbar tries to set a NaN value as the scroll height which
+ causes DOM Exceptions after r18320. This overrides the _setObjectLength
+ method and checks for NaN until a system update can fix this. See rdar://4901491
+
+ * WebInspector/webInspector/inspector.html:
+ * WebInspector/webInspector/inspector.js:
+
+2006-12-27 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ Fixed <rdar://problem/4901629> Crash occurs at WebCore::Frame::page()
+ after closing window containing flash content
+
+ No testcase because we can't open and close windows in DRT.
+
+ I can't reproduce this crash, but from the backtrace it's clear that it
+ occured because of a NULL frame object. Since it's valid for a frame to
+ be NULL, I've added NULL checks.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ (-[WebBaseNetscapePluginView requestWithURLCString:]):
+ (-[WebBaseNetscapePluginView getVariable:value:]):
+
+2006-12-27 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Updated <rdar://problem/4871518> fix based on Darin's comments.
+
+ Instead of searching the frame tree to retrieve the new frame, put it in
+ a RefPtr, and then explicitly check for its removal. This option is slightly
+ more efficient, and it avoids problems that can occur due to frame name collision.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge createChildFrameNamed:withURL:referrer:ownerElement:allowsScrolling:marginWidth:marginHeight:]):
+
+2006-12-26 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Eric Seidel.
+
+ Fixed <rdar://problem/4740328> Safari crash on quit in _NPN_ReleaseObject
+ from KJS::Bindings::CInstance::~CInstance
+
+ The essence of this change is that WebKit shouldn't meddle in plug-in
+ lifetime, since WebCore already manages it. The rest is details.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView removeTrackingRect]): Autorelease our window
+ instead of releasing it, since we might hold the last reference to our window,
+ and releasing it immediately would crash AppKit.
+ (-[WebBaseNetscapePluginView resetTrackingRect]):
+
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView dataSource]): Use our DOMElement to access
+ our WebFrame, since we don't keep around a direct pointer to our WebFrame
+ anymore.
+
+ * Plugins/WebNullPluginView.h:
+ * Plugins/WebNullPluginView.m:
+ (-[WebNullPluginView initWithFrame:error:DOMElement:]):
+ (-[WebNullPluginView dealloc]):
+ (-[WebNullPluginView viewDidMoveToWindow]): Use our DOMElement to access
+ our WebFrame, as above.
+
+ * WebCoreSupport/WebFrameBridge.mm: Don't call _addPlugInView because it
+ doesn't exist anymore. Do pass a DOMElement to WebNullPluginView's initializer,
+ so it can access its frame like WebNetscapePluginEmbeddedView does.
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ (-[WebFrameBridge viewForJavaAppletWithFrame:attributeNames:attributeValues:baseURL:DOMElement:]):
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm: Removed didCloseDocument. It had
+ two purposes -- one unnecessary, one harmful:
+ (1) NULL out plug-ins' weak references to their frames. Unnecessary. Having
+ plug-ins access their frames through their DOM elements solves this problem.
+ (2) Unload plug-ins. Harmful. If a plug-in unloads before WebCore is done
+ with it, WebCore will access unmapped memory. Also unnecessary. WebCore
+ Widgets take care of calling -removeFromSuperview on their NSViews, which
+ is sufficient for stopping plug-ins.
+
+ * WebKit.xcodeproj/project.pbxproj: Made WebNullPluginView.m ObjC++.
+
+ * WebView/WebFrame.mm: Removed _addPlugInView, since it was only used to
+ call -setWebFrame, which is gone.
+ (-[WebFramePrivate dealloc]):
+ * WebView/WebFrameInternal.h: Removed plugInViews, since it was only used
+ by _addPlugInView, which is gone.
+
+2006-12-26 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Eric Seidel.
+
+ Some cleanup in preparation for fixing <rdar://problem/4740328> Safari
+ crash on quit in _NPN_ReleaseObject from KJS::Bindings::CInstance::~CInstance
+
+ Renamed "installedPlugins" to "sharedDatabase." This better follows
+ the Cocoa naming scheme, and calls out the key attribute that produced this
+ crash -- namely, that the database is shared throughout the process.
+
+ -installedPlugins is actually a part of SPI, but a global search showed
+ that it had no users.
+
+ * Plugins/WebPluginDatabase.h:
+ * Plugins/WebPluginDatabase.m:
+ (+[WebPluginDatabase sharedDatabase]):
+ (-[WebPluginDatabase refresh]):
+ (-[WebPluginDatabase _plugInPaths]):
+ (-[WebPluginDatabase _removePlugin:]):
+ * WebCoreSupport/WebViewFactory.m:
+ (-[WebViewFactory pluginsInfo]):
+ (-[WebViewFactory refreshPlugins:]):
+ (-[WebViewFactory pluginSupportsMIMEType:]):
+ * WebView/WebView.mm:
+ (+[WebView _supportedMIMETypes]):
+ (+[WebView _viewClass:andRepresentationClass:forMIMEType:]):
+ (-[WebView _close]):
+ (-[WebView _pluginForMIMEType:]):
+ (-[WebView _pluginForExtension:]):
+ (-[WebView _isMIMETypeRegisteredAsPlugin:]):
+
+2006-12-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Adam Roben.
+
+ Fixed <rdar://problem/4778898> REGRESSION: crash in getInstanceForView()
+ when quitting from kcbs.com
+
+ No testcase because we can't open and close windows in DRT.
+
+ The crash was caused by deallocating plug-ins that were later referenced
+ in the unload event handler.
+
+ * Plugins/WebBaseNetscapePluginView.mm: Don't call stop on ourselves because
+ we may destroy our plugin before the unload handler fires. Also, we don't
+ need to, since didCloseDocument will do it for us.
+
+ (-[WebBaseNetscapePluginView addWindowObservers]): We don't need to listen
+ for windowWillClose anymore, since we don't want to call -stop on ourselves.
+ (-[WebBaseNetscapePluginView removeWindowObservers]): ditto.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::didCloseDocument): Renamed from "willCloseDocument."
+
+2006-12-25 Geoffrey Garen <ggaren@apple.com>
+
+ More "plugin" => "pluginPackage" renaming that I forgot to check in.
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView setPluginPackage:]):
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView initWithFrame:pluginPackage:URL:baseURL:MIMEType:attributeKeys:attributeValues:loadManually:DOMElement:]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ (-[WebFrameBridge viewForJavaAppletWithFrame:attributeNames:attributeValues:baseURL:DOMElement:]):
+
+2006-12-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Eric Seidel.
+
+ Fixed crash when opening view source window.
+
+ * WebView/WebView.mm:
+ (-[WebView initWithCoder:]): Don't use the WebView until calling
+ _commonInitialization...
+
+2006-12-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ Removed WebCoreSettings, cleaned up WebCore::Settings.
+
+ * WebView/WebFrame.mm: Added helper functions for converting between
+ WebKitEditableLinkBehavior and WebCore::EditableLinkBehavior. I'm not sure
+ that this is the best place for these functions, but it's where all the
+ other functions like them reside.
+ (core):
+ (kit):
+ * WebView/WebFrameInternal.h:
+
+ * WebView/WebView.mm: Removed uses of WebCoreSettings. Replaced with direct
+ use of underlying page's settings.
+
+2006-12-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Oliver Hunt.
+
+ Some refactoring in preparation for fixing <rdar://problem/4778898>
+ REGRESSION: crash in getInstanceForView() when quitting from kcbs.com
+
+ Two renames:
+ - "plugin" => "pluginPackage" (since the type is WebNetscapePluginPackage *)
+ - "instance" and/or "pluginPointer" => plugin (since NPP is an opaque handle to a plug-in)
+
+ Removed braces around single-line 'if' statements.
+
+ Made plugin a pointer instead of an inline ivar. This allows us to NULL
+ it out once we call NPP_Destroy on it.
+
+ Added helper functions for creating and destroying plugin. The destroy function
+ NULLs out plugin, which helps with debugging.
+
+ (-[WebBaseNetscapePluginView willCallPlugInFunction]): Added an ASSERT
+ to catch attempts to call functions on destroyed plug-ins.
+
+ (-[WebBaseNetscapePluginView _createPlugin]): New helper function.
+ (-[WebBaseNetscapePluginView _destroyPlugin]): New helper function.
+
+2006-12-24 David Kilzer <ddkilzer@webkit.org>
+
+ Removed empty directory.
+
+ * WebKit/Loader: Removed.
+
+2006-12-22 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Brady Eidson.
+
+ Fixed <rdar://problem/4871518> Leopard9A321: Crash visiting www.audible.com
+ (WebCore::FrameLoader::loadSubframe)
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge createChildFrameNamed:withURL:referrer:ownerElement:allowsScrolling:marginWidth:marginHeight:]):
+ - The fix:
+ Changed to re-fetch the child frame we're trying to load before returning it,
+ since its onload handler may have removed it from the document. This
+ allows us to treat a removed frame like a frame that never loaded.
+
+ - Plus some cleanup:
+ - Changed to return a WebCore::Frame* instead of a WebFrameBridge *,
+ to simplify some code.
+ - Grouped ObjC objects by usage, and moved calls to -release so that they
+ immediately follow the calls that retain.
+
+2006-12-21 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Geoff Garen
+
+ - improved concept and implementation of my previous checkin after discussing with Darin
+
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.mm:
+ (-[WebView setHoverFeedbackSuspended:]):
+ renamed from setIgnoresMouseMovedEvents, and now tells the main WebHTMLView (if any) that this state has
+ changed. Telling just the main WebHTMLView is a bit of an implementation hack. Hopefully someday we can
+ rework the document architecture and make this kind of thing less hacky (but this is following existing
+ customs, so I don't feel too bad)
+ (-[WebView isHoverFeedbackSuspended]):
+ renamed from ignoresMouseMovedEvents
+
+ * WebView/WebHTMLViewInternal.h:
+ declare _hoverFeedbackSuspendedChanged
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ test the webView's state of the hit-tested WebHTMLView rather than self
+ (-[WebHTMLView _hoverFeedbackSuspendedChanged]):
+ generate a fake mouse-moved event, which simulates the mouse moving away from
+ the current element or back over it
+
+2006-12-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Oliver.
+
+ * WebInspector/webInspector/inspector.js: Added default values for the new CSS
+ properties so they don't appear in the inspector when their values are
+ uninteresting.
+
+2006-12-21 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Geoff Garen
+
+ - added WebKit support for making a web page temporarily ignore mouse movements
+
+ * WebView/WebViewPrivate.h:
+ declare ignoresMouseMovedEvents and setIgnoresMouseMovedEvents:
+
+ * WebView/WebView.mm:
+ added ignoresMouseMovedEvents boolean field to _private data structure
+ (-[WebView setIgnoresMouseMovedEvents:]):
+ set new boolean field
+ (-[WebView ignoresMouseMovedEvents]):
+ return new boolean field
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ bail out right away if [[self _webView] ignoresMouseMovedEvents]
+
+2006-12-21 Mark Rowe <bdash@webkit.org>
+
+ Reviewed by Geoff.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11888
+ Bug 11888: REGRESSION (r18320): Web Inspector panes broken
+
+ * WebInspector/webInspector/inspector.js: Use removeProperty to reset a style property to its
+ initial value. Bail out early from updateNodePane if Inspector has not yet been set.
+
+2006-12-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - fix for unrepro infinite recursion bug:
+ <rdar://problem/4448181> CrashTracer: 154 crashes in Safari at com.apple.AppKit:
+ -[NSView isDescendantOf:] + 24; infinite recursion in makeFirstResponder logic
+
+ * WebView/WebView.mm:
+ added becomingFirstResponder BOOL to private struct
+ (-[WebView becomeFirstResponder]):
+ use _private->becomingFirstResponder to guard against infinite recursion; complain on
+ debug builds if we run into this problem
+
+2006-12-19 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4891774> Local WebCore/WebBrowser builds fail in 9A328 due to warning about ObjC-2.0 language features
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-12-18 Ada Chan <adachan@apple.com>
+
+ Reviewed by Adam.
+
+ Moved canRunBeforeUnloadConfirmPanel, runBeforeUnloadConfirmPanel, and closeWindowSoon
+ from WebCoreFrameBridge to Chrome.
+
+ * COM/ChromeClientWin.cpp:
+ (ChromeClientWin::canRunBeforeUnloadConfirmPanel):
+ (ChromeClientWin::runBeforeUnloadConfirmPanel):
+ (ChromeClientWin::closeWindowSoon):
+ * COM/ChromeClientWin.h:
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::canRunBeforeUnloadConfirmPanel):
+ (WebChromeClient::runBeforeUnloadConfirmPanel):
+ (WebChromeClient::closeWindowSoon):
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2006-12-18 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Adam.
+
+ Have the Editor handle deletion instead of WebHTMLView
+
+ * WebKitPrefix.h:
+ Turned on WebCore deletion
+
+ * WebView/WebHTMLViewInternal.h:
+ Moved ownership of startNewKillRingSequence to the WebCore::Editor
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray becomeFirstResponder]):
+ Use the Editor's startNewKillRingSequence flag
+
+ (-[NSArray deleteForward:]):
+ (-[NSArray deleteBackward:]):
+ (-[NSArray deleteWordForward:]):
+ (-[NSArray deleteWordBackward:]):
+ (-[NSArray deleteToBeginningOfLine:]):
+ (-[NSArray deleteToEndOfLine:]):
+ (-[NSArray deleteToBeginningOfParagraph:]):
+ (-[NSArray deleteToEndOfParagraph:]):
+ (-[NSArray deleteToMark:]):
+ use Editor::deleteWithDirection instead of WebHTMLView's
+
+2006-12-16 Adele Peterson <adele@apple.com>
+
+ Reviewed by Adam.
+
+ WebKit part of fix for:
+ <rdar://problem/4463829> Switch to use new search field implementation for <input type="search">
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface): Initialize WKDrawTextFieldCellFocusRing.
+ * WebInspector/webInspector/inspector.css: Set -webkit-user-select:text and text-shadow:none on the search field.
+ These are both properties that we didn't honor in the old control, and the inherited values didn't work or look right.
+
+2006-12-16 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ WebKit side of making WebCore context menus support state and
+ enabled/disabled.
+
+ * WebCoreSupport/WebContextMenuClient.h: contextMenuItemSelected
+ takes a pointer to the parentMenu now since menu items no longer
+ hold onto it.
+ * WebCoreSupport/WebContextMenuClient.mm: Same.
+ (WebContextMenuClient::contextMenuItemSelected): Same.
+ * WebView/WebHTMLView.m: Must call setAutoenablesItems:NO on our
+ menu.
+ (-[NSArray menuForEvent:]):
+ * WebView/WebUIDelegatePrivate.h: No need for if-def.
+
+2006-12-15 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ Update for WebCore changes.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchIdentifierForInitialRequest):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource response]):
+
+2006-12-15 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Update for WebCore changes.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::willUseArchive):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _URLForHistory]):
+
+2006-12-15 Marvin Decker <marv.decker@gmail.com>
+
+ Reviewed by Darin and Alexey.
+
+ Fix the Windows build, move various Client implementations out of
+ WebCore and into WebKit.
+
+ * COM/ChromeClientWin.cpp: Added.
+ (ChromeClientWin::~ChromeClientWin):
+ (ChromeClientWin::chromeDestroyed):
+ (ChromeClientWin::setWindowRect):
+ (ChromeClientWin::windowRect):
+ (ChromeClientWin::pageRect):
+ (ChromeClientWin::scaleFactor):
+ (ChromeClientWin::focus):
+ (ChromeClientWin::unfocus):
+ (ChromeClientWin::createWindow):
+ (ChromeClientWin::createModalDialog):
+ (ChromeClientWin::show):
+ (ChromeClientWin::canRunModal):
+ (ChromeClientWin::runModal):
+ (ChromeClientWin::setToolbarsVisible):
+ (ChromeClientWin::toolbarsVisible):
+ (ChromeClientWin::setStatusbarVisible):
+ (ChromeClientWin::statusbarVisible):
+ (ChromeClientWin::setScrollbarsVisible):
+ (ChromeClientWin::scrollbarsVisible):
+ (ChromeClientWin::setMenubarVisible):
+ (ChromeClientWin::menubarVisible):
+ (ChromeClientWin::setResizable):
+ (ChromeClientWin::addMessageToConsole):
+ * COM/ChromeClientWin.h: Added.
+ * COM/ContextMenuClientWin.cpp: Added.
+ (ContextMenuClientWin::~ContextMenuClientWin):
+ (ContextMenuClientWin::contextMenuDestroyed):
+ (ContextMenuClientWin::addCustomContextMenuItems):
+ (ContextMenuClientWin::contextMenuItemSelected):
+ (ContextMenuClientWin::copyLinkToClipboard):
+ (ContextMenuClientWin::downloadURL):
+ (ContextMenuClientWin::copyImageToClipboard):
+ (ContextMenuClientWin::lookUpInDictionary):
+ (ContextMenuClientWin::speak):
+ (ContextMenuClientWin::stopSpeaking):
+ * COM/ContextMenuClientWin.h: Added.
+ * COM/EditorClientWin.cpp: Added.
+ (EditorClientWin::~EditorClientWin):
+ (EditorClientWin::pageDestroyed):
+ (EditorClientWin::shouldDeleteRange):
+ (EditorClientWin::shouldShowDeleteInterface):
+ (EditorClientWin::smartInsertDeleteEnabled):
+ (EditorClientWin::isContinuousSpellCheckingEnabled):
+ (EditorClientWin::toggleContinuousSpellChecking):
+ (EditorClientWin::isGrammarCheckingEnabled):
+ (EditorClientWin::toggleGrammarChecking):
+ (EditorClientWin::spellCheckerDocumentTag):
+ (EditorClientWin::selectWordBeforeMenuEvent):
+ (EditorClientWin::isEditable):
+ (EditorClientWin::shouldBeginEditing):
+ (EditorClientWin::shouldEndEditing):
+ (EditorClientWin::shouldInsertNode):
+ (EditorClientWin::shouldInsertText):
+ (EditorClientWin::shouldApplyStyle):
+ (EditorClientWin::didBeginEditing):
+ (EditorClientWin::respondToChangedContents):
+ (EditorClientWin::didEndEditing):
+ (EditorClientWin::registerCommandForUndo):
+ (EditorClientWin::registerCommandForRedo):
+ (EditorClientWin::clearUndoRedoOperations):
+ (EditorClientWin::canUndo):
+ (EditorClientWin::canRedo):
+ (EditorClientWin::undo):
+ (EditorClientWin::redo):
+ * COM/EditorClientWin.h: Added.
+ * COM/WebFrame.cpp:
+ (WebFrame::WebFrame):
+ (WebFrame::initWithName):
+ * COM/WebFrame.h:
+ * COM/WebFrameLoaderClient.cpp: Added.
+ (WebFrameLoaderClient::WebFrameLoaderClient):
+ (WebFrameLoaderClient::~WebFrameLoaderClient):
+ (WebFrameLoaderClient::frameLoaderDestroyed):
+ (WebFrameLoaderClient::hasWebView):
+ (WebFrameLoaderClient::hasFrameView):
+ (WebFrameLoaderClient::hasBackForwardList):
+ (WebFrameLoaderClient::resetBackForwardList):
+ (WebFrameLoaderClient::provisionalItemIsTarget):
+ (WebFrameLoaderClient::loadProvisionalItemFromPageCache):
+ (WebFrameLoaderClient::invalidateCurrentItemPageCache):
+ (WebFrameLoaderClient::privateBrowsingEnabled):
+ (WebFrameLoaderClient::makeDocumentView):
+ (WebFrameLoaderClient::makeRepresentation):
+ (WebFrameLoaderClient::forceLayout):
+ (WebFrameLoaderClient::forceLayoutForNonHTML):
+ (WebFrameLoaderClient::updateHistoryForCommit):
+ (WebFrameLoaderClient::updateHistoryForBackForwardNavigation):
+ (WebFrameLoaderClient::updateHistoryForReload):
+ (WebFrameLoaderClient::updateHistoryForStandardLoad):
+ (WebFrameLoaderClient::updateHistoryForInternalLoad):
+ (WebFrameLoaderClient::updateHistoryAfterClientRedirect):
+ (WebFrameLoaderClient::setCopiesOnScroll):
+ (WebFrameLoaderClient::tokenForLoadErrorReset):
+ (WebFrameLoaderClient::resetAfterLoadError):
+ (WebFrameLoaderClient::doNotResetAfterLoadError):
+ (WebFrameLoaderClient::willCloseDocument):
+ (WebFrameLoaderClient::detachedFromParent1):
+ (WebFrameLoaderClient::detachedFromParent2):
+ (WebFrameLoaderClient::detachedFromParent3):
+ (WebFrameLoaderClient::detachedFromParent4):
+ (WebFrameLoaderClient::loadedFromPageCache):
+ (WebFrameLoaderClient::dispatchDidHandleOnloadEvents):
+ (WebFrameLoaderClient::dispatchDidReceiveServerRedirectForProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidCancelClientRedirect):
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect):
+ (WebFrameLoaderClient::dispatchDidChangeLocationWithinPage):
+ (WebFrameLoaderClient::dispatchWillClose):
+ (WebFrameLoaderClient::dispatchDidReceiveIcon):
+ (WebFrameLoaderClient::dispatchDidStartProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidReceiveTitle):
+ (WebFrameLoaderClient::dispatchDidCommitLoad):
+ (WebFrameLoaderClient::dispatchDidFinishLoad):
+ (WebFrameLoaderClient::dispatchDidFirstLayout):
+ (WebFrameLoaderClient::dispatchShow):
+ (WebFrameLoaderClient::cancelPolicyCheck):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ (WebFrameLoaderClient::dispatchDidLoadMainResource):
+ (WebFrameLoaderClient::clearLoadingFromPageCache):
+ (WebFrameLoaderClient::isLoadingFromPageCache):
+ (WebFrameLoaderClient::revertToProvisionalState):
+ (WebFrameLoaderClient::clearUnarchivingState):
+ (WebFrameLoaderClient::progressStarted):
+ (WebFrameLoaderClient::progressCompleted):
+ (WebFrameLoaderClient::setMainFrameDocumentReady):
+ (WebFrameLoaderClient::willChangeTitle):
+ (WebFrameLoaderClient::didChangeTitle):
+ (WebFrameLoaderClient::finishedLoading):
+ (WebFrameLoaderClient::finalSetupForReplace):
+ (WebFrameLoaderClient::setDefersLoading):
+ (WebFrameLoaderClient::isArchiveLoadPending):
+ (WebFrameLoaderClient::cancelPendingArchiveLoad):
+ (WebFrameLoaderClient::clearArchivedResources):
+ (WebFrameLoaderClient::canHandleRequest):
+ (WebFrameLoaderClient::canShowMIMEType):
+ (WebFrameLoaderClient::representationExistsForURLScheme):
+ (WebFrameLoaderClient::generatedMIMETypeForURLScheme):
+ (WebFrameLoaderClient::frameLoadCompleted):
+ (WebFrameLoaderClient::restoreScrollPositionAndViewState):
+ (WebFrameLoaderClient::provisionalLoadStarted):
+ (WebFrameLoaderClient::shouldTreatURLAsSameAsCurrent):
+ (WebFrameLoaderClient::addHistoryItemForFragmentScroll):
+ (WebFrameLoaderClient::didFinishLoad):
+ (WebFrameLoaderClient::prepareForDataSourceReplacement):
+ (WebFrameLoaderClient::setTitle):
+ (WebFrameLoaderClient::userAgent):
+ * COM/WebFrameLoaderClient.h: Added.
+ * COM/WebKitDLL.h:
+ * WebKit.vcproj/WebKit.vcproj:
+
+2006-12-15 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Include ResourceError.h.
+
+ * Plugins/WebNetscapePluginStream.mm:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-12-14 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ Update for WebCore changes.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::incrementProgress):
+ (WebFrameLoaderClient::committedLoad):
+ (WebFrameLoaderClient::deliverArchivedResources):
+ * WebView/WebView.mm:
+ (-[WebView _incrementProgressForIdentifier:length:]):
+ * WebView/WebViewInternal.h:
+
+2006-12-14 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4827549> need NSRange-based selection support exposed.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _selectedNSRange]):
+ (-[WebFrame _selectNSRange:]):
+ * WebView/WebFramePrivate.h:
+
+2006-12-14 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by John.
+
+ Update for WebCore changes.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::dispatchDidFailProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidFailLoad):
+ (WebFrameLoaderClient::dispatchUnableToImplementPolicy):
+ (WebFrameLoaderClient::setMainDocumentError):
+ (WebFrameLoaderClient::cancelledError):
+ (WebFrameLoaderClient::cannotShowURLError):
+ (WebFrameLoaderClient::interruptForPolicyChangeError):
+ (WebFrameLoaderClient::cannotShowMIMETypeError):
+ (WebFrameLoaderClient::fileDoesNotExistError):
+ (WebFrameLoaderClient::shouldFallBack):
+
+2006-12-13 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - adjusted for changes from NSURLRequest to ResourceRequest
+
+ * Plugins/WebPluginController.mm:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::updateHistoryForReload):
+ (WebFrameLoaderClient::dispatchIdentifierForInitialRequest):
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction):
+ (WebFrameLoaderClient::startDownload):
+ (WebFrameLoaderClient::cannotShowURLError):
+ (WebFrameLoaderClient::createDocumentLoader):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _initWithDocumentLoader:]):
+ (-[WebDataSource initialRequest]):
+ (-[WebDataSource request]):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::WebDocumentLoaderMac):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _createItem:]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame loadArchive:]):
+
+2006-12-12 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::download):
+ Get the handle and proxy from the ResourceHandle now that they aren't passed to us.
+
+2006-12-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - did some of the Mac-specific file moves mentioned in my recent mail to the WebKit list
+
+ * WebCoreSupport/WebFrameBridge.h: Updated for change to WebCoreKeyboardAccess.
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge _retrieveKeyboardUIModeFromPreferences:]): Ditto.
+ (-[WebFrameBridge keyboardUIMode]): Ditto.
+
+2006-12-11 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ WebKit support for editing sub-menu actions.
+
+ * WebCoreSupport/WebContextMenuClient.h: New functions for the
+ speech sub-menu.
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::speak):
+ (WebContextMenuClient::stopSpeaking):
+ * WebCoreSupport/WebEditorClient.h: New functions to toggle
+ spelling/grammar checking.
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::toggleContinuousSpellChecking):
+ (WebEditorClient::toggleGrammarChecking):
+ * WebView/WebUIDelegatePrivate.h: Re-named some of the spelling
+ sub-menu tags.
+
+2006-12-11 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Geoff, Adam.
+
+ switch to use the Editor for copying URLs
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate copyLinkToClipboard:]):
+ Call down to the editor for this.
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+ Add some calls necessary for Pasteboard::writeURL to work
+
+2006-12-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=11794
+ fix lifetime problems affecting Frame's ownerElement pointer
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge finishInitializingWithPage:WebCore::frameName:frameView:ownerElement:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:frameView:]):
+ (-[WebFrameBridge createChildFrameNamed:withURL:referrer:ownerElement:allowsScrolling:marginWidth:marginHeight:]):
+ Use HTMLFrameOwnerElement.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm: Include the relevant headers for the
+ HTMLFormElement class.
+
+ * WebKit.xcodeproj/project.pbxproj: Let Xcode have its way.
+
+ * WebView/WebFrame.mm: (-[WebFrame frameElement]): Update includes and types for the
+ change in return type of ownerElement.
+
+2006-12-11 David Harrison <harrison@apple.com>
+
+ Fix previous checkin where I committed the wrong file.
+
+ <rdar://problem/4863611> Xyle Scope crashes at launch due to WebCore-521.29.3
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame frameElement]):
+ Add nil check.
+
+ * WebView/WebPreferences.m:
+ (-[WebPreferences editableLinkBehavior]):
+ Reverted to previous.
+
+2006-12-08 David Hyatt <hyatt@apple.com>
+
+ Land new ICU abstraction layer. Patch by Lars.
+
+ Reviewed by me
+
+ * ForwardingHeaders/wtf/icu/UnicodeIcu.h: Added.
+ * ForwardingHeaders/wtf/unicode/Unicode.h: Added.
+ * WebKit.xcodeproj/project.pbxproj:
+
+=== Safari-521.32 ===
+
+2006-12-08 Timothy Hatcher <timothy@apple.com>
+
+ Rolling out a change that broke Mail stationary.
+ <rdar://problem/4699166> REGRESSION: Background images in Mail stationery do not load
+
+ * WebView/WebUnarchivingState.m:
+ (-[WebUnarchivingState archivedResourceForURL:]):
+
+2006-12-08 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed and landed by Alexey.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11759:
+ Windows build bustage
+
+ * COM/WebFrame.cpp:
+ (WebFrame::loadDataSource):
+ * COM/WebFrame.h:
+
+2006-12-08 David Harrison <harrison@apple.com>
+
+ Reviewed by Brady.
+
+ <rdar://problem/4863611> Xyle Scope crashes at launch due to WebCore-521.29.3
+
+ * WebView/WebPreferences.m:
+ (-[WebPreferences editableLinkBehavior]):
+ Add nil check.
+
+2006-12-07 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Brady.
+
+ Build fix for WebCore ContextMenus. It got broken by r18046.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray menuForEvent:]):
+
+2006-12-07 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Brady.
+
+ Make some parameters const and const references.
+
+ * WebCoreSupport/WebContextMenuClient.h:
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::contextMenuItemSelected):
+ (WebContextMenuClient::copyLinkToClipboard):
+ (WebContextMenuClient::downloadURL):
+ (WebContextMenuClient::copyImageToClipboard):
+
+2006-12-06 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John Sullivan
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=11675 and <rdar://4857669>
+ Now we need to explicitly set the data source when loading from a page cache
+
+ * History/WebHistoryItem.mm:
+ (-[WebHistoryItem _scheduleRelease]): Enhanced a logging message
+ (+[WebHistoryItem _releasePageCache:]): Ditto
+ (+[WebHistoryItem _releaseAllPendingPageCaches]): Ditto
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::setDocumentViewFromPageCache): Reset the View's DataSource from the cache, effectively reopening it
+ * WebView/WebHTMLView.m:
+ (-[NSArray setDataSource:]): Properly Handle resetting the DataSource and "reopening" the view
+
+2006-12-06 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adam and Oliver
+
+ While working on http://bugs.webkit.org/show_bug.cgi?id=11675 I
+ decided to fix much of the null-deref problems that creeped in via
+ the loader refactoring. This isn't changing behavior, just reintroducing
+ the free nil checking we used to have with pure ObjC
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray menuForEvent:]): Explicitly check for null frames
+ (-[NSArray mouseDown:]): Ditto
+ (-[NSArray mouseDragged:]): Ditto
+ (-[NSArray mouseUp:]): Ditto
+ (-[NSArray performKeyEquivalent:]): Ditto
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): Ditto
+
+2006-12-05 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Beth
+
+ Updated to match Frame -> Editor changes in WebCore
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ guessesForUngrammaticalSelection() is now in Editor
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _isSelectionUngrammatical]):
+ isSelectionUngrammatical() is now in Editor
+ (-[WebHTMLView _isSelectionMisspelled]):
+ isSelectionMisspelled() is now in Editor
+
+ (-[WebHTMLView checkSpelling:]):
+ advanceToNextMisspelling() is now in Editor
+ (-[WebHTMLView showGuessPanel:]):
+ ditto
+
+2006-12-05 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adam
+
+ Old context-menu mechanism fix for:
+ <rdar://problem/4864351> Should leave out "No Guesses Found" from context menu for bad grammar
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ Leave out "No Guesses Found" and separator for grammar-checking case.
+
+2006-12-05 John Sullivan <sullivan@apple.com>
+
+ build fix
+
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.mm:
+ (-[WebView isGrammarCheckingEnabled]):
+ define isGrammarCheckingEnabled whether on Tiger or not (just return NO on Tiger)
+
+2006-12-04 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ WebKit part of fix for:
+ <rdar://problem/4817188> Context menu for bad grammar should include suggestions and "Ignore Grammar"
+
+ The context menu mechanism is currently in flux; the old mechanism is still in place, but an
+ up-and-coming new mechanism is waiting in the wings. I updated both of them, but couldn't
+ test the new mechanism because it doesn't work well enough yet. Most of this WebKit code
+ can be deleted when the new mechanism is in place.
+
+ * WebView/WebUIDelegatePrivate.h:
+ added WebMenuItemTagIgnoreGrammar
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate menuItemWithTag:target:representedObject:]):
+ added case for WebMenuItemTagIgnoreGrammar
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ now considers adding grammar-related items as well as spelling-related items
+
+ * WebView/WebHTMLViewPrivate.h:
+ declared _isSelectionUngrammatical
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _isSelectionUngrammatical]):
+ new method, calls through to WebCore
+ (-[WebHTMLView _ignoreGrammarFromMenu:]):
+ new method, calls _ignoreSpellingFromMenu: since NSSpellChecker has one method for both
+
+ * English.lproj/Localizable.strings:
+ updated for "Ignore Grammar" menu item title
+
+2006-12-04 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::actionDictionary): Changed to use the new
+ findEventWithKeyState function in WebCore instead of a local function
+ in this file.
+
+2006-12-04 Geoffrey Garen <ggaren@apple.com>
+
+ Rolled out the WebDashboardBehaviorUseBackwardCompatibilityModeEnabled
+ part of my last checkin.
+
+ We have to turn on support for backward compatibility mode to avoid Dashboard
+ regressions in the short term.
+
+ * WebView/WebView.mm:
+ (-[WebView _setDashboardBehavior:to:]):
+
+2006-12-02 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Added SPI for enabling Dashboard backward compatibility mode. For now,
+ we enable it unconditionally for Dashboard and Dashcode. Once they
+ implement specific support for the backward compatibility mode behavior,
+ we can change that.
+
+ Set the default WebDashboardBehaviorUseBackwardCompatibilityModeEnabled
+ to YES in order to turn this code on.
+
+ * WebView/WebView.mm:
+ (-[WebView _setDashboardBehavior:to:]):
+ (-[WebView _dashboardBehavior:]):
+ * WebView/WebViewPrivate.h:
+
+2006-12-04 Darin Adler <darin@apple.com>
+
+ Reviewed by Alice.
+
+ * WebCoreSupport/WebEditorClient.h: Removed "_web_" prefix from
+ C++ userVisibleString member function.
+ * WebCoreSupport/WebEditorClient.mm: (WebEditorClient::userVisibleString):
+ Ditto.
+
+ * WebView/WebView.mm: (-[WebView selectedFrame]): Removed extra return statement.
+
+2006-12-04 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed and landed by Alexey.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11738:
+ Make link clicking work again on Windows.
+
+ The WebKit changes are to ignore WM_MOUSEMOVED messages when the mouse
+ hasn't actually moved, which were preventing clicks from actually
+ getting dispatched in many cases. It's a peculiarity of Windows mouse
+ handling that we receive these at all.
+
+ * COM/WebView.cpp:
+ (WebView::WebView):
+ (WebView::mouseMoved):
+ * COM/WebView.h:
+
+2006-12-04 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders
+
+ - fixed <rdar://problem/4857833> REGRESSION: When ctrl-clicking on a misspelled word, "Ignore Spelling" and "Learn Spelling"
+ menu items not displayed in the contextual menu
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _isSelectionMisspelled]):
+ We were computing isSelectionMisspelled by calling WebCore, but then ignoring the result and always
+ returning NO. D'oh!
+
+2006-12-01 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ Changes to support sub-menus in WebCore ContextMenus.
+
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::contextMenuItemSelected):
+ ContextMenuItem::menu() is now called parentMenu()
+ * WebView/WebUIDelegatePrivate.h: New not-yet-API tags.
+
+2006-12-01 Darin Adler <darin@apple.com>
+
+ Reviewed by Mitz.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=11628
+ REGRESSION (r17597): Command-return in native text fields doesn't open a new tab or window
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (findKeyStateEvent): Added. Helper that finds the mouse or keyboard event in a chain
+ of events and their underlying events.
+ (findMouseEvent): Added. Same, but specifically for mouse events.
+ (WebFrameLoaderClient::actionDictionary): Rewrote to use the above functions. This means we
+ use the modifiers from the underlying events rather than just the one from the event itself.
+ So if the event is a DOM activate event, we can still see the modifiers from the original
+ keyboard event that triggered it. Has no effect if the event is already the right type or
+ if there is no underlying event.
+
+ * WebView/WebFrame.mm: Added a newly-needed include.
+
+ * WebKit.xcodeproj/project.pbxproj: Xcode wants what it wants.
+
+2006-12-01 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed by Mitz.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11732:
+ Windows build bustage.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+
+2006-12-01 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Adam.
+
+ <rdar://problem/4841432> 9A312: iWeb crashes on launch; _WebReportError missing from WebKit
+
+ Added back WebReportAssertionFailure and WebReportError for apps that still need these symbols.
+
+ * Misc/OldWebAssertions.c: Added.
+ (WebReportAssertionFailure):
+ (WebReportError):
+ * WebKit.LP64.exp: added the new symbols, and sorted the file
+ * WebKit.exp: added the new symbols, and sorted the file
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-30 Geoffrey Garen <ggaren@apple.com>
+
+ Rubber Stamped by Anders Carlsson.
+
+ Global rename of Document::focusNode to Document::focusedNode. 'focusNode'
+ suggested a command, and conflicted with a different meaning for 'focusNode'
+ in the Mozilla selection API.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray clearFocus]):
+
+2006-11-30 Matt Lilek <pewtermoose@gmail.com>
+
+ Reviewed by Mitz.
+
+ Bug 10698: Scroll wheel causes inspector to shift up
+ http://bugs.webkit.org/show_bug.cgi?id=10698
+
+ Remove size attribute from the tree popup as a workaround for
+ http://bugs.webkit.org/show_bug.cgi?id=11362 Bug 11362: Native popup with size="1" wraps options
+
+ * WebInspector/webInspector/inspector.css:
+ * WebInspector/webInspector/inspector.html:
+
+2006-11-30 Matt Lilek <pewtermoose@gmail.com>
+
+ Reviewed by Tim H.
+
+ Move web inspector style markup to javascript to fix http://bugs.webkit.org/show_bug.cgi?id=6724
+ Bug 6724: Text copied from Web Inspector is different from actual text
+
+ * WebInspector/webInspector/inspector.css:
+ * WebInspector/webInspector/inspector.js:
+
+2006-11-30 Adam Roben <aroben@apple.com>
+
+ Reviewed by Beth.
+
+ Put code in place to use WebCore context menus when they are turned
+ on.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray menuForEvent:]):
+
+2006-11-29 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Oliver.
+
+ Keep preferences separate from the rest of the client, making sure we are using expected preference values.
+ This lets the inspector work when plugins are disabled for the WebView.
+
+ * WebInspector/WebInspector.m:
+ (-[NSWindow window]):
+
+2006-11-29 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Tim.
+
+ Add back methods in WebCoreStatistics that are still used by Tiger Safari.
+
+ * Misc/WebCoreStatistics.h:
+ * Misc/WebCoreStatistics.m:
+ (+[WebCoreStatistics emptyCache]):
+ (+[WebCoreStatistics setCacheDisabled:]):
+
+2006-11-28 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Maciej.
+
+ A fix for a couple failing layout tests involving copy/cut in iframes.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::dataForArchivedSelection):
+ Use the frame parameter instead of using the webview's selectedFrame.
+
+2006-11-28 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Geoffff.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=11691 REGRESSION
+ (r17399, r17511): WebElementDictionary no longer returns nil
+ NSStrings
+
+ String's NSString* operator converts null Strings to empty
+ NSStrings for compatibility with AppKit. We need to work around
+ that here.
+
+ * Misc/WebElementDictionary.m:
+ (NSStringOrNil):
+ (-[WebElementDictionary _altDisplayString]):
+ (-[WebElementDictionary _spellingToolTip]):
+ (-[WebElementDictionary _title]):
+ (-[WebElementDictionary _titleDisplayString]):
+ (-[WebElementDictionary _textContent]):
+
+2006-11-28 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Beth Dakin.
+
+ Fixed <rdar://problem/4844855> Should clarify when to create clients in
+ the WebCore client API
+
+ All clients must now be supplied as constructor arguments. This clarifies
+ when you need to create clients, and also guarantees that objects can't
+ (for the most part) be in a clientless state.
+
+ Layout tests pass. No leaks reported.
+
+ * WebCoreSupport/WebFrameBridge.mm: Shuffled around initialization and changed
+ some arguments to resolve ciruclar dependencies at init time.
+ (-[WebFrame _initWithWebFrameView:webView:bridge:]): We no longer call setClient
+ here, because the client is set up at construction time.
+
+2006-11-28 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ Update for changes to ResourceRequest.
+
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::createWindow):
+ (WebChromeClient::createModalDialog):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::canHandleRequest):
+
+2006-11-28 Adam Roben <aroben@apple.com>
+
+ Reviewed by Beth.
+
+ More WebCore context menu work.
+
+ * DefaultDelegates/WebDefaultUIDelegate.m: New stub delegate method implementation.
+ (-[NSApplication webView:contextMenuItemSelected:forElement:]):
+ * WebCoreSupport/WebContextMenuClient.h: Updated to match ContextMenuClient.h changes.
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::addCustomContextMenuItems): Updated for method name changes.
+ (WebContextMenuClient::contextMenuItemSelected): Added new client method.
+ * WebView/WebUIDelegatePrivate.h: New private delegate method declaration.
+
+2006-11-28 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Justin and Adam.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ added the following
+ (WebEditorClient::smartInsertDeleteEnabled):
+ (WebEditorClient::dataForArchivedSelectionInFrame):
+ (WebEditorClient::_web_userVisibleString):
+ (WebEditorClient::shouldInsertNode):
+
+ * WebKitPrefix.h:
+ Added flags to control whether WebCore cut/copy/paste is enabled.
+ Turned on Cut and Copy, left Paste and Delete off
+
+ * WebView/WebHTMLViewPrivate.h:
+ * WebView/WebHTMLView.m:
+ removed _can[Cut|Copy|Paste|Delete]
+ (-[NSArray validateUserInterfaceItem:]):
+ call the editor for canDHTML[C|C|P|D] and _can[C|C|P|D] instead
+ (-[NSArray delete:]):
+ added code to call the editor's delete instead (not turned on)
+ (-[WebHTMLView copy:]):
+ added code to call the editor's copy (turned on)
+ (-[WebHTMLView cut:]):
+ added code to call the editor's cut (turned on)
+ (-[WebHTMLView paste:]):
+ added code to call the editor's paste (not turned on)
+
+2006-11-28 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Adam.
+
+ Fixed <rdar://problem/4844848> REGRESSION: extra cross-library ref/deref
+ calls cause .5% PLT regression.
+
+ Changed ref/deref calls to a single 'xxxDestroyed' call. Moved EditorClient
+ from the Frame to the Page, since it's only responsible for
+ Webview-level delegate calls.
+
+ I don't really love this design, but it fixes the regression and allows
+ a single WebKit object to implement multiple client interfaces.
+
+ Layout tests pass.
+
+2006-11-27 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ WebKit half of getting rid of the FixMes in ContextMenu.cpp
+
+ * WebCoreSupport/WebFrameLoaderClient.h: canHandleRequest takes a
+ ResourceRequest now.
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::canHandleRequest): Same.
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _isSelectionMisspelled]): Call into WebCore.
+
+2006-11-27 Ada Chan <adachan@apple.com>
+
+ Reviewed by Adam.
+
+ Part of the change to move WebCoreCache into WebKit:
+ Added WebCache which handles emptying and enable/disabling the cache.
+ emptyCache and setCacheDisabled have been removed from WebCoreStatistics.
+
+ * Misc/WebCache.h: Added.
+ * Misc/WebCache.mm: Added.
+ * Misc/WebCoreStatistics.h:
+ * Misc/WebCoreStatistics.m:
+ (+[WebCoreStatistics statistics]):
+ * WebKit.exp:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-27 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ Move addMessageToConsole to Chrome.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::addMessageToConsole):
+ * WebCoreSupport/WebFrameBridge.mm:
+
+2006-11-27 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Anders
+
+ Moved unused Private SPI to Internal and pruned other unused code
+
+ * Misc/WebIconDatabase.m:
+ * Misc/WebIconDatabasePrivate.h:
+
+2006-11-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - make the close method do a more-complete job to prevent world leaks seen when
+ running some of the layout tests
+
+ * WebView/WebHTMLViewInternal.h: Added declaration of -[WebHTMLViewPrivate clear].
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLViewPrivate clear]): Added method to drop references to other objects.
+ We want to do this at "close" time, rather than waiting for deallocation time.
+ This is especially important for the data source, which indirectly keeps a number of
+ objects alive.
+ (-[WebHTMLView close]): Added an explicit call to clear out the data source on the
+ plug-in controller. Without this, we'd see the plug-in controller making calls to
+ a deallocated data source during the layout tests. Added a call to the new clear method
+ on the private object so that we release the objects at close time instead of waiting
+ for deallocation time.
+
+ * WebKit.xcodeproj/project.pbxproj: Let Xcode have its way with the project file,
+ because I can't fight the power.
+
+2006-11-20 Samuel Weinig <sam@webkit.org>
+
+ Reviewed by Alexey.
+
+ Fix for http://bugs.webkit.org/show_bug.cgi?id=11656
+ Fix Windows build
+
+ * WebKit.vcproj/WebKit.vcproj: don't include directories that no
+ longer exist.
+
+2006-11-19 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ WebKit side of new context menu actions.
+
+ * WebCoreSupport/WebContextMenuClient.h: These are for the
+ currently-WebKit-dependent menu actions.
+ * WebCoreSupport/WebContextMenuClient.mm:
+ (WebContextMenuClient::copyLinkToClipboard):
+ (WebContextMenuClient::downloadURL):
+ (WebContextMenuClient::copyImageToClipboard):
+ (WebContextMenuClient::searchWithSpotlight):
+ (WebContextMenuClient::lookUpInDictionary):
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (core): These are to convert between WebViewInsertAction and
+ EditorInsertAction.
+ (kit):
+ (WebEditorClient::shouldInsertText): Added implementation for
+ shouldInsertText.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]): Moved
+ _lookUpInDictionary to be within the implementation of WebHTMLView
+ internal.
+ * WebView/WebHTMLViewInternal.h: Add _lookUpInDictionaryFromMenu
+ * WebView/WebViewInternal.h: Add _searchWithSpotlightFromMenu
+
+2006-11-18 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed by Sam Weinig.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11634:
+ Fix segfault on startup for Windows build. Also fix segfault when
+ typing in a URL.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+
+=== Safari-521.31 ===
+
+2006-11-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/4841044> Temporarily default Mail.app editable link clicking behavior, until they do it themselves
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebView.mm:
+ (+[WebView initialize]):
+ (-[WebView setPreferences:]):
+
+2006-11-16 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed and landed by ap.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11509:
+ Windows build bustage.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+ (WebFrame::loadHTMLString):
+ (WebFrame::stopLoading):
+ (WebFrame::reload):
+ (WebFrame::loadDataSource):
+ (WebFrame::didReceiveData):
+ (WebFrame::receivedResponse):
+ (WebFrame::receivedAllData):
+ * COM/WebFrame.h:
+ * COM/WebView.cpp:
+ (WebView::mouseMoved):
+ (WebView::mouseDown):
+ (WebView::mouseUp):
+ (WebView::mouseDoubleClick):
+ * WebKit.vcproj/WebKit.vcproj:
+
+2006-11-16 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Tim.
+
+ <rdar://problem/4841123>
+ REGRESSION: Crash in WebCore::Range::boundaryPointsValid when replying to a mail Message
+
+ * Misc/WebNSAttributedStringExtras.m:
+ (+[NSAttributedString _web_attributedStringFromRange:]):
+ If the range passed in is null, return null. When this function was in the bridge, it would never get called
+ with a null range when nothing was selected. Instead, the range would just have invalid boundary points.
+
+2006-11-15 Adam Roben <aroben@apple.com>
+
+ Reviewed by Anders.
+
+ Added new WebContextMenuClient class to act as WebCore's ChromeClient,
+ and moved context menu-related code there from WebChromeClient.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ * WebCoreSupport/WebContextMenuClient.h: Added.
+ (WebContextMenuClient::webView):
+ * WebCoreSupport/WebContextMenuClient.mm: Added.
+ (WebContextMenuClient::create):
+ (WebContextMenuClient::WebContextMenuClient):
+ (WebContextMenuClient::ref):
+ (WebContextMenuClient::deref):
+ (WebContextMenuClient::addCustomContextMenuItems):
+ * WebKit.xcodeproj/project.pbxproj: Added new files.
+ * WebView/WebView.mm:
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+
+2006-11-15 Beth Dakin <bdakin@apple.com>
+ & Adam Roben <aroben@apple.com>
+
+ Reviewed by Adam & Beth.
+
+ WebKit side of first cut at engine context menus. Use the client to
+ call into the UIDelegate.
+
+ * WebCoreSupport/WebChromeClient.h:
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::addCustomContextMenuItems):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-15 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Quick change of files to ObjC++ for BF cache re-write
+
+ * History/WebBackForwardList.m: Removed.
+ * History/WebBackForwardList.mm: Added.
+ * History/WebHistoryItem.m: Removed.
+ * History/WebHistoryItem.mm: Added.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-15 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Sarge
+
+ SPI addition
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _recursive_resumeNullEventsForAllNetscapePlugins]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFramePrivate.h:
+
+2006-11-15 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Adele
+
+ <rdar://problem/4838729> - Replace mistakenly removed SPI
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _handleAutoscrollForMouseDragged:]):
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-11-15 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adele.
+
+ isTargetItem is used by DRT, so make it private instead of internal.
+
+ * History/WebHistoryItem.m:
+ (-[WebHistoryItem isTargetItem]):
+ * History/WebHistoryItemInternal.h:
+ * History/WebHistoryItemPrivate.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+
+2006-11-15 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Split much of unused WebHistoryItemPrivate.h SPI into WebHistoryItemInternal.h
+
+ * History/WebBackForwardList.m:
+ * History/WebHistory.m:
+ * History/WebHistoryItem.m:
+ (-[WebHistoryItem initWithURLString:title:lastVisitedTimeInterval:]):
+ (-[WebHistoryItem initWithURL:title:]):
+ (-[WebHistoryItem visitCount]):
+ (-[WebHistoryItem RSSFeedReferrer]):
+ (-[WebHistoryItem setRSSFeedReferrer:]):
+ (-[WebHistoryItem children]):
+ (-[WebHistoryItem dictionaryRepresentation]):
+ (-[WebHistoryItem setAlwaysAttemptToUsePageCache:]):
+ (+[WebHistoryItem _releaseAllPendingPageCaches]):
+ (-[WebHistoryItem URL]):
+ (-[WebHistoryItem target]):
+ (-[WebHistoryItem _setLastVisitedTimeInterval:]):
+ (-[WebHistoryItem _lastVisitedDate]):
+ (-[WebHistoryItem targetItem]):
+ * History/WebHistoryItemInternal.h: Added.
+ * History/WebHistoryItemPrivate.h:
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.mm:
+ * WebView/WebView.mm:
+
+2006-11-14 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Geoff.
+
+ Moving things off the bridge and onto clients.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::selectWordBeforeMenuEvent):
+ (WebEditorClient::isEditable):
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-14 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Harrison.
+
+ <rdar://problem/4766635> Safari should never follow links in editable areas (add a WebKitEditableLinkNeverLive option)
+
+ Adds an Open Link, Open Link in New Window and Copy Link to the editing context menu.
+ Adds a new WebKitEditableLinkNeverLive preference value that maps to WebCore's EditableLinkNeverLive.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate menuItemWithTag:target:representedObject:]):
+ (-[WebDefaultUIDelegate contextMenuItemsForElement:defaultMenuItems:]):
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ (-[WebDefaultUIDelegate requestWithURL:includingReferrerFromFrame:]):
+ (-[WebDefaultUIDelegate openNewWindowWithURL:element:]):
+ (-[WebDefaultUIDelegate openLink:]):
+ * English.lproj/Localizable.strings:
+ * WebKit.exp:
+ * WebView/WebPreferences.m:
+ (-[WebPreferences editableLinkBehavior]):
+ * WebView/WebPreferencesPrivate.h:
+ * WebView/WebUIDelegatePrivate.h:
+
+2006-11-14 Anders Carlsson <acarlsson@apple.com>
+
+ Turns out I wasn't forcing DWARF on the world at all,
+ it's now the default!
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-14 Anders Carlsson <acarlsson@apple.com>
+
+ I must stop trying to force DWARF on the world.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-14 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - update for creation of EventHandler
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::actionDictionary):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ (-[NSArray menuForEvent:]):
+ (-[NSArray scrollWheel:]):
+ (-[NSArray acceptsFirstMouse:]):
+ (-[NSArray shouldDelayWindowOrderingForEvent:]):
+ (-[NSArray mouseDown:]):
+ (-[NSArray mouseDragged:]):
+ (-[NSArray mouseUp:]):
+ (-[NSArray keyDown:]):
+ (-[NSArray keyUp:]):
+ (-[NSArray performKeyEquivalent:]):
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]):
+
+2006-11-14 Anders Carlsson <acarlsson@apple.com>
+
+ Fix build for real this time.
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (-[WebEditCommand initWithEditCommand:WebCore::]):
+ (-[WebEditCommand dealloc]):
+ (-[WebEditCommand finalize]):
+ (+[WebEditCommand commandWithEditCommand:]):
+ (-[WebEditCommand command]):
+
+2006-11-14 Anders Carlsson <acarlsson@apple.com>
+
+ Try fixing the build.
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (-[WebEditorUndoTarget undoEditing:]):
+ (-[WebEditorUndoTarget redoEditing:]):
+
+2006-11-14 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ Move undo/redo handling into WebEditorClient.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::WebEditorClient):
+ (WebEditorClient::~WebEditorClient):
+ (-[WebEditCommand initWithEditCommand:WebCore::]):
+ (-[WebEditCommand dealloc]):
+ (-[WebEditCommand finalize]):
+ (+[WebEditCommand commandWithEditCommand:]):
+ (-[WebEditCommand command]):
+ (-[WebEditorUndoTarget undoEditing:]):
+ (-[WebEditorUndoTarget redoEditing:]):
+ (undoNameForEditAction):
+ (WebEditorClient::registerCommandForUndoOrRedo):
+ (WebEditorClient::registerCommandForUndo):
+ (WebEditorClient::registerCommandForRedo):
+ (WebEditorClient::clearUndoRedoOperations):
+ (WebEditorClient::canUndo):
+ (WebEditorClient::canRedo):
+ (WebEditorClient::undo):
+ (WebEditorClient::redo):
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-14 Alexey Proskuryakov <ap@webkit.org>
+
+ Reviewed by Tim H.
+
+ http://bugs.webkit.org/show_bug.cgi?id=3387
+ Redundant keydown, keypress, keyup events sent for arrow keys
+
+ Added another layer of ugly hacks around AppKit event dispatching.
+
+ 1. For arrow keys, keyDown: is invoked after performKeyEquivalent:, so had to store
+ _private->keyDownEvent in both methods, and make it persist after leaving them.
+
+ 2. For Esc, AppKit calls performKeyEquivalent: with a fake event of some kind,
+ use [NSApp currentEvent] to check for this to prevent it from being passed to WebCore.
+
+ Test: manual-tests/arrow-key-events.html
+
+ * WebView/WebHTMLView.m:
+ (-[NSMutableDictionary dealloc]):
+ (-[NSArray keyDown:]):
+ (-[NSArray keyUp:]):
+ (-[NSArray performKeyEquivalent:]):
+ * WebView/WebHTMLViewInternal.h:
+
+2006-11-12 Brady Eidson <beidson@apple.com>
+
+ Rubberstamped by Anders
+
+ Changed some #includes from <WebKit/foo.h> to "foo.h"
+
+ * History/WebBackForwardList.m:
+ * History/WebHistory.m:
+
+2006-11-11 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej Stachowiak.
+
+ - Fixed loader crash by clarifying ownership of WebKit client objects.
+ WebCore objects own their WebKit clients, and ref and deref through
+ virtual methods, leaving WebKit free to use whatever client / reference-counting
+ implementation it likes.
+
+ WebKit on Mac just uses the same refcounting class that WebCore uses (Shared),
+ but other platforms may choose to do other things.
+
+ * WebCoreSupport/WebChromeClient.h:
+ (WebChromeClient::ref):
+ (WebChromeClient::deref):
+ (WebChromeClient::refCount):
+ * WebCoreSupport/WebEditorClient.h: Nixed commented-out function prototypes.
+ The ones in WebCore make clear what remains to be implemented. Replaced constructor
+ with factory function to avoid leaks.
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::create):
+ (WebEditorClient::WebEditorClient):
+ (WebEditorClient::setWebFrame):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge initMainFrameWithPage:WebCore::frameName:view:webView:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ * WebCoreSupport/WebFrameLoaderClient.h: Replaced constructor with factory
+ function to avoid leaks.
+ (WebFrameLoaderClient::ref):
+ (WebFrameLoaderClient::deref):
+ (WebFrameLoaderClient::refCount):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::create):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _initWithWebFrameView:webView:coreFrame:]):
+
+=== Safari-521.30 ===
+
+2006-11-10 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - remove some unnecessary uses of WebDataProtocol
+
+ * WebView/WebDataSource.mm: Remove the unneeded include.
+ * WebView/WebView.mm:
+ (+[WebView _canHandleRequest:]): Don't bother to check for unreachable URL here.
+ Any request that has one will be an applewebdata: request, which will pass the check anyway.
+
+2006-11-10 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ Update for changes to WebCore
+ * WebView/WebHTMLView.m:
+ (-[NSArray _applyStyleToSelection:withUndoAction:]):
+ (-[NSArray _applyParagraphStyleToSelection:withUndoAction:]):
+ (-[NSArray _toggleBold]):
+ (-[NSArray _toggleItalic]):
+
+2006-11-09 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej, Geoff.
+
+ Call execCommand directly here instead of going through the bridge.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray moveBackward:]):
+ (-[NSArray moveBackwardAndModifySelection:]):
+ (-[NSArray moveDown:]):
+ (-[NSArray moveDownAndModifySelection:]):
+ (-[NSArray moveForward:]):
+ (-[NSArray moveForwardAndModifySelection:]):
+ (-[NSArray moveLeft:]):
+ (-[NSArray moveLeftAndModifySelection:]):
+ (-[NSArray moveRight:]):
+ (-[NSArray moveRightAndModifySelection:]):
+ (-[NSArray moveToBeginningOfDocument:]):
+ (-[NSArray moveToBeginningOfDocumentAndModifySelection:]):
+ (-[NSArray moveToBeginningOfSentence:]):
+ (-[NSArray moveToBeginningOfSentenceAndModifySelection:]):
+ (-[NSArray moveToBeginningOfLine:]):
+ (-[NSArray moveToBeginningOfLineAndModifySelection:]):
+ (-[NSArray moveToBeginningOfParagraph:]):
+ (-[NSArray moveToBeginningOfParagraphAndModifySelection:]):
+ (-[NSArray moveToEndOfDocument:]):
+ (-[NSArray moveToEndOfDocumentAndModifySelection:]):
+ (-[NSArray moveToEndOfSentence:]):
+ (-[NSArray moveToEndOfSentenceAndModifySelection:]):
+ (-[NSArray moveToEndOfLine:]):
+ (-[NSArray moveToEndOfLineAndModifySelection:]):
+ (-[NSArray moveToEndOfParagraph:]):
+ (-[NSArray moveToEndOfParagraphAndModifySelection:]):
+ (-[NSArray moveParagraphBackwardAndModifySelection:]):
+ (-[NSArray moveParagraphForwardAndModifySelection:]):
+ (-[NSArray moveUp:]):
+ (-[NSArray moveUpAndModifySelection:]):
+ (-[NSArray moveWordBackward:]):
+ (-[NSArray moveWordBackwardAndModifySelection:]):
+ (-[NSArray moveWordForward:]):
+ (-[NSArray moveWordForwardAndModifySelection:]):
+ (-[NSArray moveWordLeft:]):
+ (-[NSArray moveWordLeftAndModifySelection:]):
+ (-[NSArray moveWordRight:]):
+ (-[NSArray moveWordRightAndModifySelection:]):
+
+2006-11-10 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ Took out WebIconDatabaseBridge and made WebKit call IconDatabase directly
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase iconForURL:withSize:cache:]):
+ (-[WebIconDatabase iconURLForURL:]):
+ (-[WebIconDatabase defaultIconWithSize:]):
+ (-[WebIconDatabase defaultIconForURL:withSize:]):
+ (-[WebIconDatabase retainIconForURL:]):
+ (-[WebIconDatabase releaseIconForURL:]):
+ (-[WebIconDatabase setDelegate:]):
+ (-[WebIconDatabase removeAllIcons]):
+ (-[WebIconDatabase isIconExpiredForIconURL:]):
+ (-[WebIconDatabase _isEnabled]):
+ (-[WebIconDatabase _setIconData:forIconURL:]):
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _hasEntryForIconURL:]):
+ (-[WebIconDatabase _applicationWillTerminate:]):
+ (-[WebIconDatabase _resetCachedWebPreferences:]):
+ (-[WebIconDatabase _convertToWebCoreFormat]):
+ (webGetNSImage):
+ * Misc/WebIconDatabaseInternal.h: Added.
+ * Misc/WebIconDatabasePrivate.h:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDidReceiveIcon):
+ * WebCoreSupport/WebIconDatabaseBridge.h: Removed.
+ * WebCoreSupport/WebIconDatabaseBridge.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-09 Oliver Hunt <oliver@apple.com>
+
+ Reviewed by Brady.
+
+ Updated to make use of MimeTypeRegistry/bridge
+
+ * Misc/WebNSPasteboardExtras.m:
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _documentFragmentWithArchive:]):
+ * WebView/WebHTMLRepresentation.m:
+ (+[WebHTMLRepresentation supportedNonImageMIMETypes]):
+ (+[WebHTMLRepresentation supportedImageMIMETypes]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _imageExistsAtPaths:]):
+ (-[WebHTMLView _documentFragmentWithPaths:]):
+
+2006-11-09 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ <rdar://problem/4829080>
+ More loader re-factoring cleanup - WebFramePolicyListener was over-released
+
+ * WebCoreSupport/WebFrameLoaderClient.h: Changed vanilla ptr to a RetainPtr<>
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType): Ditto
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction): Ditto
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction): Ditto
+ (WebFrameLoaderClient::dispatchWillSubmitForm): Ditto
+ (WebFrameLoaderClient::setUpPolicyListener): Ditto
+ (-[WebFramePolicyListener receivedPolicyDecision:]): Ditto
+
+2006-11-08 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam, Oliver.
+
+ Update for changes to WebCore. Pass a specific WebFrame to WebEditorClient
+ instead of just passing the WebView.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::WebEditorClient):
+ (WebEditorClient::setWebFrame):
+ (WebEditorClient::isContinuousSpellCheckingEnabled):
+ (WebEditorClient::spellCheckerDocumentTag):
+ (WebEditorClient::shouldDeleteRange):
+ (WebEditorClient::shouldShowDeleteInterface):
+ (WebEditorClient::shouldApplyStyle):
+ (WebEditorClient::shouldBeginEditing):
+ (WebEditorClient::shouldEndEditing):
+ (WebEditorClient::didBeginEditing):
+ (WebEditorClient::respondToChangedContents):
+ (WebEditorClient::didEndEditing):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge initMainFrameWithPage:WebCore::frameName:view:webView:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+
+2006-11-08 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ Move more code into editor.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::shouldBeginEditing):
+ (WebEditorClient::shouldEndEditing):
+ (WebEditorClient::didBeginEditing):
+ (WebEditorClient::didEndEditing):
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebView/WebHTMLView.m:
+ (-[NSArray indent:]):
+ (-[NSArray outdent:]):
+ * WebView/WebView.mm:
+ * WebView/WebViewInternal.h:
+
+2006-11-08 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Adam.
+
+ Add WebElementIsContentEditableKey to the WebElementDictionary, and
+ use it!
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate
+ webView:contextMenuItemsForElement:defaultMenuItems:]): Use new
+ WebElementIsContentEditableKey.
+ * Misc/WebElementDictionary.m:
+ (+[WebElementDictionary initializeLookupTable]):
+ (-[WebElementDictionary _isContentEditable]): Call into
+ HitTestResult::isContentEditable()
+ * WebView/WebView.mm: Add new key.
+ * WebView/WebViewPrivate.h: Add new key.
+
+2006-11-08 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Oliver.
+
+ Call into the WebCore editor object directly.
+
+ * MigrateHeaders.make:
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::shouldDeleteRange):
+ (WebEditorClient::shouldShowDeleteInterface):
+ (WebEditorClient::shouldApplyStyle):
+ * WebView/WebFrame.mm:
+ (core):
+ (kit):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.m:
+ (-[NSArray _applyStyleToSelection:withUndoAction:]):
+ (-[NSArray _applyParagraphStyleToSelection:withUndoAction:]):
+ (-[NSArray _toggleBold]):
+ (-[NSArray _toggleItalic]):
+ (-[NSArray _changeCSSColorUsingSelector:inRange:]):
+ (-[NSArray underline:]):
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]):
+ * WebView/WebView.mm:
+ (-[WebView applyStyle:]):
+
+2006-11-08 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Oliver.
+
+ <rdar://problem/4825370>
+ REGRESSION: Selecting "Look Up In Dictionary" from contextual menu fails to open the Dictionary app
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ Initialize the framework pointer to 0.
+
+2006-11-07 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ - udpated for changes to move from Frame/FrameMac to FrameLoader
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate openNewWindowWithURL:element:]):
+ * Misc/WebNSAttributedStringExtras.m:
+ (+[NSAttributedString _web_attributedStringFromRange:]):
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView requestWithURLCString:]):
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView didStart]):
+ * Plugins/WebNetscapePluginStream.mm:
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController pluginView:receivedResponse:]):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::provisionalLoadStarted):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _canCachePage]):
+ (+[WebFrame _timeOfLastCompletedLoad]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _reloadForPluginChanges]):
+ (-[WebFrame stopLoading]):
+
+2006-11-07 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ Use the WebCore editing enums.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge undoNameForEditAction:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _deleteRange:killRing:prepend:smartDeleteOK:deletionAction:granularity:]):
+ (-[WebHTMLView _deleteSelection]):
+ (-[WebHTMLView moveBackward:]):
+ (-[WebHTMLView moveBackwardAndModifySelection:]):
+ (-[WebHTMLView moveDown:]):
+ (-[WebHTMLView moveDownAndModifySelection:]):
+ (-[WebHTMLView moveForward:]):
+ (-[WebHTMLView moveForwardAndModifySelection:]):
+ (-[WebHTMLView moveLeft:]):
+ (-[WebHTMLView moveLeftAndModifySelection:]):
+ (-[WebHTMLView moveRight:]):
+ (-[WebHTMLView moveRightAndModifySelection:]):
+ (-[WebHTMLView moveToBeginningOfDocument:]):
+ (-[WebHTMLView moveToBeginningOfDocumentAndModifySelection:]):
+ (-[WebHTMLView moveToBeginningOfSentence:]):
+ (-[WebHTMLView moveToBeginningOfSentenceAndModifySelection:]):
+ (-[WebHTMLView moveToBeginningOfLine:]):
+ (-[WebHTMLView moveToBeginningOfLineAndModifySelection:]):
+ (-[WebHTMLView moveToBeginningOfParagraph:]):
+ (-[WebHTMLView moveToBeginningOfParagraphAndModifySelection:]):
+ (-[WebHTMLView moveToEndOfDocument:]):
+ (-[WebHTMLView moveToEndOfDocumentAndModifySelection:]):
+ (-[WebHTMLView moveToEndOfSentence:]):
+ (-[WebHTMLView moveToEndOfSentenceAndModifySelection:]):
+ (-[WebHTMLView moveToEndOfLine:]):
+ (-[WebHTMLView moveToEndOfLineAndModifySelection:]):
+ (-[WebHTMLView moveToEndOfParagraph:]):
+ (-[WebHTMLView moveToEndOfParagraphAndModifySelection:]):
+ (-[WebHTMLView moveParagraphBackwardAndModifySelection:]):
+ (-[WebHTMLView moveParagraphForwardAndModifySelection:]):
+ (-[WebHTMLView moveUp:]):
+ (-[WebHTMLView moveUpAndModifySelection:]):
+ (-[WebHTMLView moveWordBackward:]):
+ (-[WebHTMLView moveWordBackwardAndModifySelection:]):
+ (-[WebHTMLView moveWordForward:]):
+ (-[WebHTMLView moveWordForwardAndModifySelection:]):
+ (-[WebHTMLView moveWordLeft:]):
+ (-[WebHTMLView moveWordLeftAndModifySelection:]):
+ (-[WebHTMLView moveWordRight:]):
+ (-[WebHTMLView moveWordRightAndModifySelection:]):
+ (-[WebHTMLView pageUp:]):
+ (-[WebHTMLView pageDown:]):
+ (-[WebHTMLView pageUpAndModifySelection:]):
+ (-[WebHTMLView pageDownAndModifySelection:]):
+ (-[WebHTMLView _expandSelectionToGranularity:]):
+ (-[WebHTMLView selectParagraph:]):
+ (-[WebHTMLView selectLine:]):
+ (-[WebHTMLView selectSentence:]):
+ (-[WebHTMLView selectWord:]):
+ (-[WebHTMLView _applyStyleToSelection:withUndoAction:]):
+ (-[WebHTMLView _applyParagraphStyleToSelection:withUndoAction:]):
+ (-[WebHTMLView _toggleBold]):
+ (-[WebHTMLView _toggleItalic]):
+ (-[WebHTMLView pasteFont:]):
+ (-[WebHTMLView changeFont:]):
+ (-[WebHTMLView changeAttributes:]):
+ (-[WebHTMLView _undoActionFromColorPanelWithSelector:]):
+ (-[WebHTMLView changeColor:]):
+ (-[WebHTMLView _alignSelectionUsingCSSValue:withUndoAction:]):
+ (-[WebHTMLView alignCenter:]):
+ (-[WebHTMLView alignJustified:]):
+ (-[WebHTMLView alignLeft:]):
+ (-[WebHTMLView alignRight:]):
+ (-[WebHTMLView _deleteWithDirection:SelectionController::granularity:killRing:isTypingAction:]):
+ (-[WebHTMLView deleteForward:]):
+ (-[WebHTMLView deleteBackward:]):
+ (-[WebHTMLView deleteWordForward:]):
+ (-[WebHTMLView deleteWordBackward:]):
+ (-[WebHTMLView deleteToBeginningOfLine:]):
+ (-[WebHTMLView deleteToEndOfLine:]):
+ (-[WebHTMLView deleteToBeginningOfParagraph:]):
+ (-[WebHTMLView deleteToEndOfParagraph:]):
+ (-[WebHTMLView subscript:]):
+ (-[WebHTMLView superscript:]):
+ (-[WebHTMLView unscript:]):
+ (-[WebHTMLView underline:]):
+ (-[WebHTMLView deleteToMark:]):
+ (-[WebHTMLView toggleBaseWritingDirection:]):
+ (-[WebHTMLView changeBaseWritingDirection:]):
+ (-[WebHTMLView _canSmartCopyOrDelete]):
+ (-[WebTextCompleteController doCompletion]):
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]):
+ * WebView/WebView.mm:
+ (-[WebView setTypingStyle:]):
+ (-[WebView applyStyle:]):
+
+2006-11-06 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Removed ScreenClient. It was highly unpopular, risking my midterm re-election.
+
+ None of Screen's responsibilities require up-calls to WebKit or delegates,
+ so WebCore can handle it all.
+
+ * WebCoreSupport/WebChromeClient.mm:
+ (WebChromeClient::setWindowRect):
+ (WebChromeClient::windowRect):
+ * WebCoreSupport/WebScreenClient.h: Removed.
+ * WebCoreSupport/WebScreenClient.mm: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebView.mm:
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+
+2006-11-06 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin.
+
+ Accidentally rolled out this change when removing the WebPageBridge. Now
+ putting it back.
+
+ * WebView/WebView.mm:
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+
+2006-11-05 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej, Darin, Anders.
+
+ Removed the Page bridge. Beefed up Chrome. Added Screen and ScreenClient.
+
+ (WebChromeClient::pageRect): It may seem weird for the page to ask the Chrome/ChromeClient
+ about its own dimensions. The idea here is that we're asking the Chrome how
+ much space it has devoted to the page. We have API for this (-webViewContentRect), but
+ it was documented incorrectly (even Safari used it wrong), so we don't use
+ it anymore. Once we fix our API/documentation, we can return to making a
+ delegate callback to ask for the page's size.
+ (WebChromeClient::createWindow): Changed to take a FrameLoadRequest with
+ an appropriate referrer, instead of making up its own.
+ (WebChromeClient::createModalDialog): Changed to take a FrameLoadRequest with
+ an appropriate referrer, instead of broken out parcels.
+ * WebCoreSupport/WebPageBridge.h: Removed. Dead Code.
+ * WebCoreSupport/WebPageBridge.mm: Removed. Dead Code.
+ * WebCoreSupport/WebScreenClient.h: Added.
+ * WebCoreSupport/WebScreenClient.mm: Added.
+ * WebView/WebView.mm: Added NULL checks for new _private->page, since
+ it's not NULL-safe like the bridge was, and it gets cleared before
+ dealloc.
+
+2006-11-06 Graham Dennis <graham.dennis@gmail.com>
+
+ Reviewed by Tim Hatcher.
+
+ Part of patch for http://bugs.webkit.org/show_bug.cgi?id=11323
+ Link dragging behaviour does not obey WebKitEditableLinkBehavior WebPref
+
+ * DefaultDelegates/WebDefaultUIDelegate.m:
+ (-[NSApplication webView:dragSourceActionMaskForPoint:]): Logic moved to
+ WebHTMLView's _mayStartDragAtEventLocation
+ * Misc/WebElementDictionary.m: added isLiveLink
+ (+[WebElementDictionary initializeLookupTable]):
+ (-[WebElementDictionary _isLiveLink]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _mayStartDragAtEventLocation:]): Editable links should
+ only be followed if isLiveLink is true
+ (-[WebHTMLView _isMoveDrag:]): A drag of a live editable link is not
+ a move
+ (-[WebHTMLView draggingUpdatedWithDraggingInfo:actionMask:]):
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]):
+ * WebView/WebView.mm: added WebElementLinkIsLiveKey
+ * WebView/WebViewPrivate.h: ditto
+
+2006-11-04 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - removed unneeded (and obsolete) header includes
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebView/WebFrame.mm:
+
+2006-11-05 Darin Adler <darin@apple.com>
+
+ - WebKit part of Frame.h check-in (forgot to land it)
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge textViewWasFirstResponderAtMouseDownTime:]):
+ (-[WebFrameBridge shouldInterruptJavaScript]):
+ (-[WebFrameBridge saveDocumentState:]):
+ (-[WebFrameBridge previousKeyViewOutsideWebFrameViews]):
+ (-[WebFrameBridge valueForKey:keys:values:]):
+ (-[WebFrameBridge getObjectCacheSize]):
+ (-[WebFrameBridge startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ (-[WebFrameBridge mayStartDragAtEventLocation:]):
+ (-[WebFrameBridge canGoBackOrForward:]):
+ (-[WebFrameBridge goBackOrForward:]):
+ (-[WebFrameBridge print]):
+ (-[WebFrameBridge getAppletInView:]):
+ (-[WebFrameBridge pollForAppletInView:]):
+ (-[WebFrameBridge respondToChangedContents]):
+ (-[WebFrameBridge respondToChangedSelection]):
+ (-[WebFrameBridge setIsSelected:forView:]):
+
+2006-11-04 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - converted more of the loader machinery to work with cross-platform
+ data structures instead of Macintosh-specific ones
+
+ store the computed user agent string as a WebCore::String instead
+ of an NSString to avoid overhead converting it every time we get it
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+ * ChangeLog:
+ * Misc/WebElementDictionary.m:
+ (-[WebElementDictionary _image]):
+ (-[WebElementDictionary _targetWebFrame]):
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect):
+ (WebFrameLoaderClient::shouldTreatURLAsSameAsCurrent):
+ (WebFrameLoaderClient::setTitle):
+ (WebFrameLoaderClient::userAgent):
+ (WebFrameLoaderClient::actionDictionary):
+ * WebCoreSupport/WebPageBridge.mm:
+ (WebCore::if):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _URL]):
+ (-[WebDataSource _URLForHistory]):
+ (-[WebDataSource unreachableURL]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]):
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView PDFViewWillClickOnLink:withURL:]):
+ (-[WebPDFView _path]):
+ * WebView/WebView.mm:
+ (-[WebViewPrivate init]):
+ (-[WebViewPrivate dealloc]):
+ (-[WebViewPrivate finalize]):
+ (-[WebView _preferencesChangedNotification:]):
+ (-[WebView _cachedResponseForURL:]):
+ (-[WebView setApplicationNameForUserAgent:]):
+ (-[WebView setCustomUserAgent:]):
+ (-[WebView customUserAgent]):
+ (-[WebView userAgentForURL:]):
+ (-[WebView _computeUserAgent]):
+ (-[WebView WebCore::]):
+ * WebView/WebViewInternal.h:
+
+2006-11-04 Bertrand Guiheneuf <guiheneuf@gmail.com>
+
+ Reviewed by Maciej, tweaked and landed by Alexey (using a patch by Don Gibson).
+
+ http://bugs.webkit.org/show_bug.cgi?id=11433
+ Fixes to get WebKit to run on Windows; implemented AffineTransformCairo.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+ (WebFrame::loadDataSource):
+ (WebFrame::receivedRedirect):
+ (WebFrame::receivedResponse):
+ (WebFrame::didReceiveData):
+ (WebFrame::receivedAllData):
+ Use resource handles now. Do not start doc loader by hand anymore.
+ Handle didReceiveData() callback instead of receivedData() which
+ is deprecated in implementation of ResourceHandleClient
+
+ * COM/WebFrame.h:
+ * COM/WebView.cpp:
+ Applied ResourceLoader --> ResourceHandle renaming
+
+ * WebKit.vcproj/WebKit.rc:
+ Got rid of MFC dependencies (build fix for VCExpress).
+
+ * WebKit.vcproj/WebKit.vcproj:
+ Added platform/graphics platform/network and platform/network/win
+ to headers search paths
+
+2006-11-03 Geoffrey Garen <ggaren@apple.com>
+
+ Forgot to add these two files. Oops.
+
+ * WebCoreSupport/WebChromeClient.h: Added.
+ * WebCoreSupport/WebChromeClient.mm: Added.
+
+2006-11-02 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin, Beth.
+
+ First cut at factoring Page's UIDelegate-related functions into Chrome
+ and ChromeClient.
+
+ Layout tests pass.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebPageBridge.mm:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-11-02 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Brady.
+
+ Adding outdent to the WebView responder forwarding list.
+ Also add outdent to WebHTMLView.h and WebViewPrivate.h.
+
+ * WebView/WebHTMLView.h:
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.mm:
+
+2006-11-01 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adam Roben
+
+ - fixed <rdar://problem/4801351> Crash reloading PDF file in new Safari (or closing a window containing a PDF file)
+
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView initWithFrame:]):
+ Retain the PDFSubview in the code path where we just obtain it by asking the PDFPreviewView for it. We were
+ unconditionally releasing it in dealloc, but only retaining it in one of the two code paths.
+
+2006-10-31 Mark Rowe <bdash@webkit.org>
+
+ Reviewed by Maciej.
+
+ Fix null pointer dereference while running editing/pasteboard/drag-drop-modifies-page.html
+
+ * Misc/WebElementDictionary.m:
+ (-[WebElementDictionary _image]): Add null check.
+
+2006-10-31 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Maciej.
+
+ This creates local functions for the remaining WebElementDictionary
+ members that calls into HitTestResult instead of doing magical
+ things with the Objective-C DOM classes.
+
+ * ChangeLog:
+ * Misc/WebElementDictionary.m:
+ (addLookupKey): The values of the dictionary are now just
+ selectors. They used to be WebElementMethods which were
+ WebElementTargetObjects associated with selectors, but none of that
+ is needed any more.
+ (+[WebElementDictionary initializeLookupTable]): All selectors are
+ now local functions, no more WebElementTargetObjects.
+ (-[WebElementDictionary objectForKey:]): No more target objects!
+ (-[WebElementDictionary _domNode]): Call into HitTestResult member
+ variable.
+ (-[WebElementDictionary _altDisplayString]): Same.
+ (-[WebElementDictionary _image]): Same.
+ (-[WebElementDictionary _absoluteImageURL]): Same.
+ (-[WebElementDictionary _title]): Same.
+ (-[WebElementDictionary _absoluteLinkURL]): Same.
+ (-[WebElementDictionary _targetWebFrame]): Same.
+ (-[WebElementDictionary _titleDisplayString]): Same.
+ (-[WebElementDictionary _textContent]): Same.
+
+2006-10-31 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Alice.
+
+ Moved some Editing code from WebKit, the bridge, and WebCore::Frame down
+ to WebCore::Editor.
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _shouldDeleteRange:]):
+ (-[WebHTMLView _canCopy]):
+ (-[WebHTMLView _canCut]):
+ (-[WebHTMLView _canDelete]):
+ (-[WebHTMLView _canPaste]):
+ (-[WebHTMLView _canEdit]):
+ (-[WebHTMLView _canEditRichly]):
+ (-[WebHTMLView _isEditable]):
+ (-[WebHTMLView _isSelectionInPasswordField]):
+ (-[NSArray validateUserInterfaceItem:]):
+ (-[NSArray _expandSelectionToGranularity:]):
+
+2006-10-31 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Beth and Adam
+
+ Display a tooltip when hovering over marked bad grammar.
+
+ * Misc/WebElementDictionary.m:
+ (+[WebElementDictionary initializeLookupTable]):
+ support spelling tool tip
+ (-[WebElementDictionary _spellingToolTip]):
+ new method, calls through to HitTestResult
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ Check for a spelling tool tip; if found, prefer it over the other possible tool tips.
+ Check for empty strings instead of just nil strings being, since values from
+ WebElementDictionary are empty strings.
+
+ * WebView/WebViewPrivate.h:
+ declare new string constant WebElementSpellingToolTipKey
+ * WebView/WebView.mm:
+ define new string constant WebElementSpellingToolTipKey
+
+2006-10-31 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Maciej.
+
+ Small tweaks to WebKit because of http://bugs.webkit.org/
+ show_bug.cgi?id=11461 HitTestResult should be split into
+ HitTestRequest and HitTestResult
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): The
+ HitTestResult initializer now just takes a point.
+
+2006-10-31 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - got "action dictionary" code out of FrameLoader,
+ replacing with a class called NavigationAction
+
+ * WebCoreSupport/WebFrameLoaderClient.h: Changed parameter types to NavigationAction.
+ Made elementForEvent non-virtual. Added actionDictionary function.
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction): Changed parameter type,
+ and used actionDictionary to make the action dictionary.
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction): Ditto.
+ (WebFrameLoaderClient::actionDictionary): Added. Code that was originally in WebCore
+ that creates the action dictionary (from a NavigationAction).
+
+ * WebView/WebFrame.mm: (-[WebFrame _loadItem:withLoadType:]): Use NavigationAction
+ instead of a dictionary for the action parameters.
+
+2006-10-31 Marvin Decker <marv.decker@gmail.com>
+
+ Reviewed by Maciej.
+
+ - fixed "Stop and reload don't work on the WebView"
+ http://bugs.webkit.org/show_bug.cgi?id=11285
+
+ * COM/WebFrame.cpp:
+ (WebFrame::stopLoading): Implement.
+ * COM/WebView.cpp:
+ (WebView::stopLoading): ditto
+ (WebView::reload): ditto
+
+2006-10-30 Darin Adler <darin@apple.com>
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView evaluateJavaScriptPluginRequest:]):
+ Fix comment.
+
+2006-10-30 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Geoff Garen
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray checkSpelling:]):
+ removed code to update spelling panel; WebCore handles that now
+ (-[NSArray showGuessPanel:]):
+ ditto
+
+2006-10-30 John Sullivan <sullivan@apple.com>
+
+ * English.lproj/WebViewEditingContextMenu.nib/info.nib:
+ * English.lproj/WebViewEditingContextMenu.nib/objects.nib:
+ Another wording change to match framework, post-Tiger:
+ "Check Spelling" -> "Check Document Now"
+
+2006-10-30 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Geoff Garen.
+
+ Moved spelling-related methods from bridge to EditorClient. Added one not-yet-used
+ grammar-related method.
+
+ * WebCoreSupport/WebEditorClient.h:
+ declare overrides of isContinuousSpellCheckingEnabled(), spellCheckerDocumentTag(), and new
+ isGrammarCheckingEnabled()
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::isContinuousSpellCheckingEnabled):
+ implement by calling through to WebView
+ (WebEditorClient::isGrammarCheckingEnabled):
+ ditto
+ (WebEditorClient::spellCheckerDocumentTag):
+ ditto
+
+ * WebCoreSupport/WebFrameBridge.mm:
+ removed bridge equivalents of these methods
+
+2006-10-30 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Beth.
+
+ Fixed nil-deref crash that I saw while using TOT (not sure how to repro,
+ but the debugger confirmed the cause).
+
+ * WebView/WebFrame.mm:
+ (core): Added check for NULL bridge.
+
+2006-10-30 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin.
+
+ Removed a number of editing and selection methods from the bridge.
+
+ I moved cross-platform editing and selection code into WebCore::Editor and
+ WebCore::SelectionController, respecitvely.
+
+ All of the seemingly new code here is just code grabbed from WebCore or
+ merged from WebCoreFrameBridge.
+
+ I changed one piece of internal API: we now pass around Ranges in places
+ where we used to pass around broken out components of Ranges.
+
+ I also added WebCore XPATH_SUPPORT AND SVG_SUPPORT #defines to the project.
+ Since we now include WebCore headers that depend on these #defines, we need
+ to keep in sync with them, to avoid binary incompatibility.
+
+2006-10-30 Darin Adler <darin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ - work toward removing Objective-C data types from FrameLoader.h:
+ removed NSDate, NSString, WebCorePageState, WebCoreResourceLoader,
+ and WebCoreResourceHandle
+ - moved bodyBackgroundColor function here from Frame
+
+ * History/WebHistoryItem.m: (+[WebHistoryItem _closeObjectsInPendingPageCaches]):
+ Updated for change in WebCorePageState.
+
+ * WebCoreSupport/WebFrameBridge.mm: Removed saveDocumentToPageCache method.
+
+ * WebCoreSupport/WebFrameLoaderClient.h: Changed NSDate to double.
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::invalidateCurrentItemPageCache): Moved the code that was
+ formerly in invalidatePageCache: on the bridge here.
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect): Added code to make the
+ NSDate here.
+ (WebFrameLoaderClient::createPageCache): Restructured code to create the
+ WebCorePageState object directly instead of calling saveDocumentToPageCache on
+ the bridge.
+
+ * WebView/WebFrame.mm: (-[WebFrame _bodyBackgroundColor]): Rewrote this to work
+ directly with the DOM and renderers rather than using a function on Frame.
+
+2006-10-29 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - added ResourceResponse class and didReceiveResponse delegate call
+
+ * WebCoreSupport/WebFrameBridge.mm: Removed no longer needed
+ expiresTimeForResponse: method.
+
+2006-10-29 Darin Adler <darin@apple.com>
+
+ - update for the WebCore rename
+
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ * WebView/WebFrame.mm:
+
+2006-10-29 Darin Adler <darin@apple.com>
+
+ - update for the WebCore renames
+
+ * Plugins/WebNetscapePluginStream.mm:
+ * Plugins/WebPluginController.mm:
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::willUseArchive):
+ (WebFrameLoaderClient::isArchiveLoadPending):
+ (WebFrameLoaderClient::cancelPendingArchiveLoad):
+ (WebFrameLoaderClient::deliverArchivedResources):
+ * WebCoreSupport/WebPageBridge.mm:
+ (-[WebPageBridge canRunModalNow]):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebFrame.mm:
+ * WebView/WebHTMLRepresentation.m:
+ * WebView/WebView.mm:
+
+2006-10-29 Darin Adler <darin@apple.com>
+
+ Rubber stamped by Adam Roben.
+
+ - renamed WebCore's WebFrameLoaderClient to match the class name inside it
+
+ * WebCoreSupport/WebFrameBridge.mm: Update include.
+ * WebCoreSupport/WebFrameLoaderClient.h: Ditto.
+
+2006-10-29 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - eliminate use of NSArray to carry form data around
+ (the code in this framework was actually using the NSArray to hold a single
+ NSData anyway, so I just went back to an NSData for now)
+
+ - also fixed http://bugs.webkit.org/show_bug.cgi?id=11444
+ REGRESSION (r17378): Exception (-[NSCFDictionary setObject:forKey:]:
+ attempt to insert nil value) when submitting a form with an empty
+ uninitialized field
+
+ * History/WebHistoryItem.m:
+ (-[WebHistoryItem _setFormInfoFromRequest:]):
+ (-[WebHistoryItem formData]):
+ * History/WebHistoryItemPrivate.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadItem:withLoadType:]):
+
+2006-10-28 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - eliminated the use of Objective-C for the policy decider
+ machinery, obviating the need for WebPolicyDeciderMac
+
+ - moved the defersLoading flag from WebView to WebCore::Page
+
+ - removed unused copies of four methods that in the frame bridge;
+ the actually-used copies are in the page bridge
+
+ - updated for rename of PassRefPtr::release to releaseRef
+
+ * WebView/WebPolicyDeciderMac.h: Removed.
+ * WebView/WebPolicyDeciderMac.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj: Updated for removal.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ * Plugins/WebNetscapePluginStream.mm:
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (getWebView):
+ (WebFrameLoaderClient::WebFrameLoaderClient):
+ (WebFrameLoaderClient::willCloseDocument):
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction):
+ (WebFrameLoaderClient::cancelPolicyCheck):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ (WebFrameLoaderClient::setDefersLoading):
+ (WebFrameLoaderClient::setTitle):
+ (WebFrameLoaderClient::deliverArchivedResourcesAfterDelay):
+ (WebFrameLoaderClient::deliverArchivedResources):
+ (WebFrameLoaderClient::setUpPolicyListener):
+ (WebFrameLoaderClient::receivedPolicyDecison):
+ (WebFrameLoaderClient::userAgent):
+ (-[WebFramePolicyListener initWithWebCoreFrame:]):
+ (-[WebFramePolicyListener invalidate]):
+ (-[WebFramePolicyListener dealloc]):
+ (-[WebFramePolicyListener finalize]):
+ (-[WebFramePolicyListener receivedPolicyDecision:]):
+ (-[WebFramePolicyListener ignore]):
+ (-[WebFramePolicyListener download]):
+ (-[WebFramePolicyListener use]):
+ (-[WebFramePolicyListener continue]):
+ * WebCoreSupport/WebPageBridge.mm:
+ (-[WebPageBridge runModal]):
+ * WebView/WebArchiver.m:
+ (+[WebArchiver archiveSelectionInFrame:]):
+ * WebView/WebFormDelegate.h:
+ * WebView/WebFormDelegate.m:
+ (+[WebFormDelegate _sharedWebFormDelegate]):
+ (-[WebFormDelegate textFieldDidBeginEditing:inFrame:]):
+ (-[WebFormDelegate textFieldDidEndEditing:inFrame:]):
+ (-[WebFormDelegate textDidChangeInTextField:inFrame:]):
+ (-[WebFormDelegate textDidChangeInTextArea:inFrame:]):
+ (-[WebFormDelegate frame:sourceFrame:willSubmitForm:withValues:submissionListener:]):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _isFrameSet]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFrameView.mm:
+ (-[WebFrameView _shouldDrawBorder]):
+ * WebView/WebHTMLView.m:
+ (-[NSArray knowsPageRange:]):
+ * WebView/WebView.mm:
+ (-[WebView _formDelegate]):
+ * WebView/WebViewInternal.h:
+ * WebView/WebViewPrivate.h:
+
+2006-10-28 Adam Roben <aroben@apple.com>
+
+ Reviewed by Maciej.
+
+ Fix layout tests that broke after r17399. Mitz discovered that the
+ failures were caused by HitTestResult::m_point being uninitialized
+ much of the time. HitTestResults are now always constructed with a
+ point.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): Pass point to
+ HitTestResult constructor.
+
+2006-10-28 Beth Dakin <bdakin@apple.com>
+
+ Reviewed by Darin.
+
+ This is the WebKit half of pushing the guts of elementAtPoint and
+ WebElementDictionary into WebCore. Among other things, this patch
+ makes WebElementDictionary.m and WebHTMLView.m Objective-C++
+
+ * MigrateHeaders.make: Add DOMElementInternal.h to the list of
+ headers to migrate.
+ * Misc/WebElementDictionary.h: Replaced DOMNode, DOMElement, and
+ NSPoint member variables with a HitTestResult member variable.
+ * Misc/WebElementDictionary.m:
+ (addLookupKey): Formatting.
+ (-[WebElementDictionary initWithHitTestResult:]): Constructor just
+ takes a HitTestResult now and sets the member variable.
+ (-[WebElementDictionary dealloc]): delete HitTestResult.
+ (-[WebElementDictionary finalize]): Address HitTestResult.
+ (-[WebElementDictionary _domNode]): Use HitTestResult and call into
+ WebCore.
+ (-[WebElementDictionary objectForKey:]): Same.
+ (-[WebElementDictionary _webFrame]): Same.
+ (-[WebElementDictionary _targetWebFrame]): Same.
+ (-[WebElementDictionary _title]): Same.
+ (-[WebElementDictionary _imageRect]): Same.
+ (-[WebElementDictionary _isSelected]): Same.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.mm:
+ (core): Convert from DOMNode* to Node*
+ (kit): Convert from Node* to DOMNode*
+ * WebView/WebFrameInternal.h: Support for the above.
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): Call directly
+ into Frame.cpp to get HitTestResult.
+
+2006-10-27 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by John & Adam.
+
+ - various performance improvements for resource delegate dispatch.
+
+ - avoid any ObjC messaging when fetching the WebView
+ - avoid ObjC calls to WebView to get resource load delegate and impl cache
+ - cache actual method pointers, not just the fact that the method is present
+ - added a new SPI resource load delegate method which allows clients to get
+ just one message in case of synchronously loading from memory cache; if this
+ is implemented you don't get the normal delegate calls in that case.
+ - various other minor tweaks
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (getWebView):
+ (WebFrameLoaderClient::hasBackForwardList):
+ (WebFrameLoaderClient::resetBackForwardList):
+ (WebFrameLoaderClient::privateBrowsingEnabled):
+ (WebFrameLoaderClient::updateHistoryForStandardLoad):
+ (WebFrameLoaderClient::resetAfterLoadError):
+ (WebFrameLoaderClient::download):
+ (WebFrameLoaderClient::dispatchDidLoadResourceFromMemoryCache):
+ (WebFrameLoaderClient::dispatchIdentifierForInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::dispatchDidHandleOnloadEvents):
+ (WebFrameLoaderClient::dispatchDidReceiveServerRedirectForProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidCancelClientRedirect):
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect):
+ (WebFrameLoaderClient::dispatchDidChangeLocationWithinPage):
+ (WebFrameLoaderClient::dispatchWillClose):
+ (WebFrameLoaderClient::dispatchDidReceiveIcon):
+ (WebFrameLoaderClient::dispatchDidStartProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidReceiveTitle):
+ (WebFrameLoaderClient::dispatchDidCommitLoad):
+ (WebFrameLoaderClient::dispatchDidFailProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidFailLoad):
+ (WebFrameLoaderClient::dispatchDidFinishLoad):
+ (WebFrameLoaderClient::dispatchDidFirstLayout):
+ (WebFrameLoaderClient::dispatchCreatePage):
+ (WebFrameLoaderClient::dispatchShow):
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction):
+ (WebFrameLoaderClient::dispatchUnableToImplementPolicy):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ (WebFrameLoaderClient::dispatchDidLoadMainResource):
+ (WebFrameLoaderClient::progressStarted):
+ (WebFrameLoaderClient::progressCompleted):
+ (WebFrameLoaderClient::incrementProgress):
+ (WebFrameLoaderClient::completeProgress):
+ (WebFrameLoaderClient::setMainFrameDocumentReady):
+ (WebFrameLoaderClient::startDownload):
+ (WebFrameLoaderClient::willChangeTitle):
+ (WebFrameLoaderClient::didChangeTitle):
+ (WebFrameLoaderClient::mainFrameURL):
+ (WebFrameLoaderClient::frameLoadCompleted):
+ * WebCoreSupport/WebPageBridge.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.mm:
+ (frame):
+ (core):
+ (kit):
+ (getWebView):
+ (-[WebFrame _addBackForwardItemClippedAtTarget:]):
+ (-[WebFrame _canCachePage]):
+ (-[WebFrame _purgePageCache]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _goToItem:withLoadType:]):
+ (-[WebFrame _updateBackground]):
+ (-[WebFrame _clearSelectionInOtherFrames]):
+ (-[WebFrame _isMainFrame]):
+ (-[WebFrame webView]):
+ * WebView/WebResourceLoadDelegatePrivate.h: Added.
+ * WebView/WebView.mm:
+ (-[WebView _cacheResourceLoadDelegateImplementations]):
+ (WebViewGetResourceLoadDelegate):
+ (WebViewGetResourceLoadDelegateImplementations):
+ * WebView/WebViewInternal.h:
+ * WebView/WebViewPrivate.h:
+
+2006-10-27 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej.
+
+ Moved some WebCoreFrameBridge functions into FrameLoader.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _numPendingOrLoadingRequests:]):
+
+2006-10-27 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Beth.
+
+ Make a DerivedSource/Webkit directory to store migrated
+ internal headers from WebCore.
+
+ * MigrateHeaders.make:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.mm: import the new migrated DOM*Internal.h headers
+
+2006-10-27 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders
+
+ - fixed http://bugs.webkit.org/show_bug.cgi?id=11439
+ REGRESSION: Another page loading crash
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame _createItem:]):
+ Handle nil documentLoader the way we did before ObjC->C++ changes
+
+2006-10-27 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray checkSpelling:]):
+ call advanceToNextMisspelling directly on FrameMac, bypassing bridge
+ (-[NSArray showGuessPanel:]):
+ ditto
+
+2006-10-27 Darin Adler <darin@apple.com>
+
+ - build fix
+
+ * WebCoreSupport/WebFrameLoaderClient.mm: Corrected header file name.
+
+2006-10-27 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - moved methods that are there just to be called by the frame loader client into the client
+ in an attempt to get back some of the speed we lost yesterday
+
+ * DefaultDelegates/WebDefaultResourceLoadDelegate.m:
+ (-[WebDefaultResourceLoadDelegate webView:resource:didReceiveAuthenticationChallenge:fromDataSource:]):
+ (-[WebDefaultResourceLoadDelegate webView:resource:didCancelAuthenticationChallenge:fromDataSource:]):
+ * WebCoreSupport/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (dataSource):
+ (decisionListener):
+ (WebFrameLoaderClient::WebFrameLoaderClient):
+ (WebFrameLoaderClient::hasWebView):
+ (WebFrameLoaderClient::hasFrameView):
+ (WebFrameLoaderClient::hasBackForwardList):
+ (WebFrameLoaderClient::resetBackForwardList):
+ (WebFrameLoaderClient::provisionalItemIsTarget):
+ (WebFrameLoaderClient::loadProvisionalItemFromPageCache):
+ (WebFrameLoaderClient::invalidateCurrentItemPageCache):
+ (WebFrameLoaderClient::privateBrowsingEnabled):
+ (WebFrameLoaderClient::makeDocumentView):
+ (WebFrameLoaderClient::makeRepresentation):
+ (WebFrameLoaderClient::setDocumentViewFromPageCache):
+ (WebFrameLoaderClient::forceLayout):
+ (WebFrameLoaderClient::forceLayoutForNonHTML):
+ (WebFrameLoaderClient::updateHistoryForCommit):
+ (WebFrameLoaderClient::updateHistoryForBackForwardNavigation):
+ (WebFrameLoaderClient::updateHistoryForReload):
+ (WebFrameLoaderClient::updateHistoryForStandardLoad):
+ (WebFrameLoaderClient::updateHistoryForInternalLoad):
+ (WebFrameLoaderClient::updateHistoryAfterClientRedirect):
+ (WebFrameLoaderClient::setCopiesOnScroll):
+ (WebFrameLoaderClient::tokenForLoadErrorReset):
+ (WebFrameLoaderClient::resetAfterLoadError):
+ (WebFrameLoaderClient::doNotResetAfterLoadError):
+ (WebFrameLoaderClient::detachedFromParent1):
+ (WebFrameLoaderClient::detachedFromParent2):
+ (WebFrameLoaderClient::detachedFromParent3):
+ (WebFrameLoaderClient::detachedFromParent4):
+ (WebFrameLoaderClient::loadedFromPageCache):
+ (WebFrameLoaderClient::download):
+ (WebFrameLoaderClient::dispatchIdentifierForInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::dispatchDidHandleOnloadEvents):
+ (WebFrameLoaderClient::dispatchDidReceiveServerRedirectForProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidCancelClientRedirect):
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect):
+ (WebFrameLoaderClient::dispatchDidChangeLocationWithinPage):
+ (WebFrameLoaderClient::dispatchWillClose):
+ (WebFrameLoaderClient::dispatchDidReceiveIcon):
+ (WebFrameLoaderClient::dispatchDidStartProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidReceiveTitle):
+ (WebFrameLoaderClient::dispatchDidCommitLoad):
+ (WebFrameLoaderClient::dispatchDidFailProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidFailLoad):
+ (WebFrameLoaderClient::dispatchDidFinishLoad):
+ (WebFrameLoaderClient::dispatchDidFirstLayout):
+ (WebFrameLoaderClient::dispatchCreatePage):
+ (WebFrameLoaderClient::dispatchShow):
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction):
+ (WebFrameLoaderClient::dispatchUnableToImplementPolicy):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ (WebFrameLoaderClient::dispatchDidLoadMainResource):
+ (WebFrameLoaderClient::clearLoadingFromPageCache):
+ (WebFrameLoaderClient::isLoadingFromPageCache):
+ (WebFrameLoaderClient::revertToProvisionalState):
+ (WebFrameLoaderClient::setMainDocumentError):
+ (WebFrameLoaderClient::clearUnarchivingState):
+ (WebFrameLoaderClient::progressStarted):
+ (WebFrameLoaderClient::progressCompleted):
+ (WebFrameLoaderClient::incrementProgress):
+ (WebFrameLoaderClient::completeProgress):
+ (WebFrameLoaderClient::setMainFrameDocumentReady):
+ (WebFrameLoaderClient::startDownload):
+ (WebFrameLoaderClient::willChangeTitle):
+ (WebFrameLoaderClient::didChangeTitle):
+ (WebFrameLoaderClient::committedLoad):
+ (WebFrameLoaderClient::finishedLoading):
+ (WebFrameLoaderClient::finalSetupForReplace):
+ (WebFrameLoaderClient::cancelledError):
+ (WebFrameLoaderClient::cannotShowURLError):
+ (WebFrameLoaderClient::interruptForPolicyChangeError):
+ (WebFrameLoaderClient::cannotShowMIMETypeError):
+ (WebFrameLoaderClient::fileDoesNotExistError):
+ (WebFrameLoaderClient::shouldFallBack):
+ (WebFrameLoaderClient::mainFrameURL):
+ (WebFrameLoaderClient::setDefersCallbacks):
+ (WebFrameLoaderClient::willUseArchive):
+ (WebFrameLoaderClient::isArchiveLoadPending):
+ (WebFrameLoaderClient::cancelPendingArchiveLoad):
+ (WebFrameLoaderClient::clearArchivedResources):
+ (WebFrameLoaderClient::canHandleRequest):
+ (WebFrameLoaderClient::canShowMIMEType):
+ (WebFrameLoaderClient::representationExistsForURLScheme):
+ (WebFrameLoaderClient::generatedMIMETypeForURLScheme):
+ (WebFrameLoaderClient::elementForEvent):
+ (WebFrameLoaderClient::createPolicyDecider):
+ (WebFrameLoaderClient::frameLoadCompleted):
+ (WebFrameLoaderClient::restoreScrollPositionAndViewState):
+ (WebFrameLoaderClient::provisionalLoadStarted):
+ (WebFrameLoaderClient::shouldTreatURLAsSameAsCurrent):
+ (WebFrameLoaderClient::addHistoryItemForFragmentScroll):
+ (WebFrameLoaderClient::didFinishLoad):
+ (WebFrameLoaderClient::prepareForDataSourceReplacement):
+ (WebFrameLoaderClient::createDocumentLoader):
+ (WebFrameLoaderClient::setTitle):
+ (WebFrameLoaderClient::canUseArchivedResource):
+ (WebFrameLoaderClient::deliverArchivedResourcesAfterDelay):
+ (WebFrameLoaderClient::deliverArchivedResources):
+ (WebFrameLoaderClient::createPageCache):
+ * WebView/WebFrame.mm:
+ (-[NSView setWebFrame:]):
+ (-[WebFrame _createItem:]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _recursiveGoToItem:fromItem:withLoadType:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _saveScrollPositionAndViewStateToItem:]):
+ (-[WebFrame _hasSelection]):
+ (-[WebFrame _clearSelection]):
+ (-[WebFrame _setProvisionalItem:]):
+ (-[WebFrame _setPreviousItem:]):
+ (-[WebFrame _setCurrentItem:]):
+ (-[WebFrame loadArchive:]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _topHTMLView]):
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-10-26 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Darin, Maciej.
+
+ Removed many uses of NSString * from WebCore.
+
+ Changed a few files to ObjC++ for compatiblity with new WebCore methods
+ taking WebCore::Strings as arguments.
+
+ Added a static_cast to make the c++ compiler happy.
+
+2006-10-26 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders
+
+ * WebView/WebFrame.mm:
+ now includes <WebCore/Document.h> and <WebCore/DocumentMarker.h>
+ (-[WebFrame _unmarkAllBadGrammar]):
+ filled in guts
+ (-[WebFrame _unmarkAllMisspellings]):
+ rewrote to call Document directly, bypassing bridge
+
+2006-10-26 John Sullivan <sullivan@apple.com>
+
+ * English.lproj/WebViewEditingContextMenu.nib/info.nib:
+ * English.lproj/WebViewEditingContextMenu.nib/objects.nib:
+
+ Changed "Spelling" to "Spelling and Grammar" in context menu for post-Tiger.
+
+=== Safari-521.29 ===
+
+2006-10-26 John Sullivan <sullivan@apple.com>
+
+ No review, just two localized string changes.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray validateUserInterfaceItem:]):
+ changed "Show/Hide Spelling" to "Show/Hide Spelling and Grammar" post-Tiger to match framework change
+
+ * English.lproj/Localizable.strings:
+ updated for these changes
+
+2006-10-25 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - removed 55 methods from WebCoreFrameBridge
+ - changed callers to use Frame directly instead
+ - put FrameLoaderTypes.h types into the WebCore namespace
+ - first steps to get FrameLoader.h ready for cross-platform duty
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate openNewWindowWithURL:element:]):
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView requestWithURLCString:]):
+ (-[WebBaseNetscapePluginView loadPluginRequest:]):
+ (-[WebBaseNetscapePluginView getVariable:value:]):
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView didStart]):
+ * Plugins/WebNetscapePluginStream.mm:
+ * Plugins/WebPluginContainerCheck.m:
+ (-[WebPluginContainerCheck _continueWithPolicy:]):
+ (-[WebPluginContainerCheck _isForbiddenFileLoad]):
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::shouldDeleteRange):
+ (WebEditorClient::shouldShowDeleteInterface):
+ * WebCoreSupport/WebFrameBridge.mm:
+ (-[WebFrameBridge webView]):
+ (-[WebFrameBridge finishInitializingWithFrameName:view:]):
+ (-[WebFrameBridge createWindowWithURL:]):
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ (-[WebFrameBridge windowObjectCleared]):
+ (-[WebFrameBridge createModalDialogWithURL:]):
+ * WebCoreSupport/WebFrameLoaderClient.mm:
+ (WebFrameLoaderClient::dispatchCreatePage):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebArchiver.m:
+ (+[WebArchiver archiveSelectionInFrame:]):
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _documentFragmentWithImageResource:]):
+ (-[WebDataSource _imageElementWithImageResource:]):
+ * WebView/WebEditingDelegatePrivate.h:
+ * WebView/WebFrame.mm:
+ (core):
+ (kit):
+ (-[WebFrame _createItemTreeWithTargetFrame:clippedAtTarget:]):
+ (-[WebFrame _canCachePage]):
+ (-[WebFrame _childFramesMatchItem:]):
+ (-[WebFrame _URLsMatchItem:]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _recursiveGoToItem:fromItem:withLoadType:]):
+ (-[WebFrame _viewWillMoveToHostWindow:]):
+ (-[WebFrame _viewDidMoveToHostWindow]):
+ (-[WebFrame _addChild:]):
+ (-[WebFrame _saveDocumentAndScrollState]):
+ (-[WebFrame _numPendingOrLoadingRequests:]):
+ (-[WebFrame _reloadForPluginChanges]):
+ (-[WebFrame _recursive_pauseNullEventsForAllNetscapePlugins]):
+ (-[WebFrame _recursive_resumeNullEventsForAllNetscapePlugins]):
+ (-[WebFrame _initWithWebFrameView:webView:coreFrame:]):
+ (-[WebFrame _documentViews]):
+ (-[WebFrame _updateBackground]):
+ (-[WebFrame _unmarkAllMisspellings]):
+ (-[WebFrame _hasSelection]):
+ (-[WebFrame _atMostOneFrameHasSelection]):
+ (-[WebFrame _findFrameWithSelection]):
+ (-[WebFrame _frameLoader]):
+ (-[WebFrame _isDescendantOfFrame:]):
+ (-[WebFrame _setShouldCreateRenderers:]):
+ (-[WebFrame _bodyBackgroundColor]):
+ (-[WebFrame init]):
+ (-[WebFrame initWithName:webFrameView:webView:]):
+ (-[WebFrame dealloc]):
+ (-[WebFrame finalize]):
+ (-[WebFrame name]):
+ (-[WebFrame webView]):
+ (-[WebFrame DOMDocument]):
+ (-[WebFrame frameElement]):
+ (-[WebFrame findFrameNamed:]):
+ (-[WebFrame parentFrame]):
+ (-[WebFrame childFrames]):
+ (-[WebFrame _invalidateCurrentItemPageCache]):
+ (-[WebFrame _dispatchCreateWebViewWithRequest:]):
+ (-[WebFrame _dispatchSourceFrame:willSubmitForm:withValues:submissionDecider:]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame _provisionalLoadStarted]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation DOMDocument]):
+ (-[WebHTMLRepresentation attributedText]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _documentRange]):
+ (-[WebHTMLView _documentFragmentWithPaths:]):
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+ (-[WebHTMLView _selectedRange]):
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ (-[WebHTMLView _canEditRichly]):
+ (-[WebHTMLView _hasSelection]):
+ (-[WebHTMLView _hasSelectionOrInsertionPoint]):
+ (-[WebHTMLView _hasInsertionPoint]):
+ (-[WebHTMLView _isEditable]):
+ (-[WebHTMLView _isSelectionInPasswordField]):
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ (-[WebHTMLView _selectionDraggingImage]):
+ (-[WebHTMLView _canIncreaseSelectionListLevel]):
+ (-[WebHTMLView _canDecreaseSelectionListLevel]):
+ (-[WebHTMLView _updateActiveState]):
+ (-[NSArray readSelectionFromPasteboard:]):
+ (-[NSArray validateUserInterfaceItem:]):
+ (-[NSArray maintainsInactiveSelection]):
+ (-[NSArray menuForEvent:]):
+ (-[NSArray scrollWheel:]):
+ (-[NSArray acceptsFirstMouse:]):
+ (-[NSArray shouldDelayWindowOrderingForEvent:]):
+ (-[NSArray mouseDown:]):
+ (-[NSArray mouseDragged:]):
+ (-[NSArray mouseUp:]):
+ (-[NSArray keyDown:]):
+ (-[NSArray keyUp:]):
+ (-[NSArray centerSelectionInVisibleArea:]):
+ (-[NSArray _selectionStartFontAttributesAsRTF]):
+ (-[NSArray _emptyStyle]):
+ (-[NSArray performKeyEquivalent:]):
+ (-[NSArray indent:]):
+ (-[NSArray outdent:]):
+ (-[WebHTMLView cut:]):
+ (-[WebHTMLView paste:]):
+ (-[WebHTMLView _selectRangeInMarkedText:]):
+ (-[WebTextCompleteController doCompletion]):
+ (-[WebHTMLView selectionRect]):
+ (-[WebHTMLView selectionImageForcingWhiteText:]):
+ (-[WebHTMLView selectionImageRect]):
+ (-[WebHTMLView attributedString]):
+ (-[WebHTMLView _isMoveDrag]):
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]):
+ * WebView/WebPolicyDelegate.mm:
+ (-[WebPolicyDecisionListener _usePolicy:]):
+ (-[WebPolicyDecisionListener use]):
+ (-[WebPolicyDecisionListener ignore]):
+ (-[WebPolicyDecisionListener download]):
+ (-[WebPolicyDecisionListener continue]):
+ * WebView/WebScriptDebugDelegate.m:
+ (-[WebScriptCallFrame _initWithFrame:initWithWebFrame:]):
+ (-[WebScriptCallFrame globalObject]):
+ * WebView/WebView.mm:
+ (-[WebView _attachScriptDebuggerToAllFrames]):
+ (-[WebView _detachScriptDebuggerFromAllFrames]):
+ (-[WebView windowScriptObject]):
+ (incrementFrame):
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ (-[WebView writeSelectionWithPasteboardTypes:toPasteboard:]):
+ (-[WebView removeDragCaret]):
+ (-[WebView setScriptDebugDelegate:]):
+ (-[WebView scriptDebugDelegate]):
+ (-[WebView shouldClose]):
+ (-[WebView selectedDOMRange]):
+ (-[WebView styleDeclarationWithText:]):
+
+2006-10-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Adam.
+
+ Renamed WebFrameLoader to FrameLoader, to match class name.
+
+ * Plugins/WebBaseNetscapePluginView.mm:
+ * Plugins/WebNetscapePluginStream.mm:
+ * Plugins/WebPluginController.mm:
+ * WebCoreSupport/WebFrameBridge.mm:
+ * WebView/WebDataSource.mm:
+ * WebView/WebFrame.mm:
+ * WebView/WebPDFView.mm:
+ * WebView/WebPolicyDelegate.mm:
+ * WebView/WebView.mm:
+
+2006-10-25 Mark Rowe <bdash@webkit.org>
+
+ Reviewed by Anders.
+
+ Build fix for the Buildbot.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray _addToStyle:fontA:fontB:]): Explicit cast.
+
+2006-10-25 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ <rdar://problem/4785575> REGRESSION: form resubmission warning occurs twice, then Safari crashes in autorelease pool
+ <rdar://problem/4799383> REGRESSION: Crash occurs when dismissing the "Would you like to save this password" sheet
+
+ * WebView/WebPolicyDeciderMac.m:
+ (-[WebPolicyDeciderMac dealloc]): release the listener, don't dealloc it
+
+2006-10-24 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ * WebKitPrefix.h:
+ Include FastMalloc.h from C++ code.
+
+2006-10-24 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - converted WebFrameLoaderClient to C++
+ - renamed frame->frameLoader() function to frame->loader()
+ - renamed [bridge impl] to [bridge _frame]
+ - removed some bridge methods
+
+ * Plugins/WebNetscapePluginStream.mm:
+ * WebCoreSupport/WebEditorClient.mm:
+ * WebCoreSupport/WebFrameLoaderClient.h: Added.
+ (WebFrameLoaderClient::webFrame):
+ * WebCoreSupport/WebFrameLoaderClient.mm: Added.
+ (WebFrameLoaderClient::detachFrameLoader):
+ (WebFrameLoaderClient::hasWebView):
+ (WebFrameLoaderClient::hasFrameView):
+ (WebFrameLoaderClient::hasBackForwardList):
+ (WebFrameLoaderClient::resetBackForwardList):
+ (WebFrameLoaderClient::provisionalItemIsTarget):
+ (WebFrameLoaderClient::loadProvisionalItemFromPageCache):
+ (WebFrameLoaderClient::invalidateCurrentItemPageCache):
+ (WebFrameLoaderClient::privateBrowsingEnabled):
+ (WebFrameLoaderClient::makeDocumentView):
+ (WebFrameLoaderClient::makeRepresentation):
+ (WebFrameLoaderClient::setDocumentViewFromPageCache):
+ (WebFrameLoaderClient::forceLayout):
+ (WebFrameLoaderClient::forceLayoutForNonHTML):
+ (WebFrameLoaderClient::updateHistoryForCommit):
+ (WebFrameLoaderClient::updateHistoryForBackForwardNavigation):
+ (WebFrameLoaderClient::updateHistoryForReload):
+ (WebFrameLoaderClient::updateHistoryForStandardLoad):
+ (WebFrameLoaderClient::updateHistoryForInternalLoad):
+ (WebFrameLoaderClient::updateHistoryAfterClientRedirect):
+ (WebFrameLoaderClient::setCopiesOnScroll):
+ (WebFrameLoaderClient::tokenForLoadErrorReset):
+ (WebFrameLoaderClient::resetAfterLoadError):
+ (WebFrameLoaderClient::doNotResetAfterLoadError):
+ (WebFrameLoaderClient::detachedFromParent1):
+ (WebFrameLoaderClient::detachedFromParent2):
+ (WebFrameLoaderClient::detachedFromParent3):
+ (WebFrameLoaderClient::detachedFromParent4):
+ (WebFrameLoaderClient::loadedFromPageCache):
+ (WebFrameLoaderClient::download):
+ (WebFrameLoaderClient::dispatchIdentifierForInitialRequest):
+ (WebFrameLoaderClient::dispatchWillSendRequest):
+ (WebFrameLoaderClient::dispatchDidReceiveAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidCancelAuthenticationChallenge):
+ (WebFrameLoaderClient::dispatchDidReceiveResponse):
+ (WebFrameLoaderClient::dispatchDidReceiveContentLength):
+ (WebFrameLoaderClient::dispatchDidFinishLoading):
+ (WebFrameLoaderClient::dispatchDidFailLoading):
+ (WebFrameLoaderClient::dispatchDidHandleOnloadEvents):
+ (WebFrameLoaderClient::dispatchDidReceiveServerRedirectForProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidCancelClientRedirect):
+ (WebFrameLoaderClient::dispatchWillPerformClientRedirect):
+ (WebFrameLoaderClient::dispatchDidChangeLocationWithinPage):
+ (WebFrameLoaderClient::dispatchWillClose):
+ (WebFrameLoaderClient::dispatchDidReceiveIcon):
+ (WebFrameLoaderClient::dispatchDidStartProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidReceiveTitle):
+ (WebFrameLoaderClient::dispatchDidCommitLoad):
+ (WebFrameLoaderClient::dispatchDidFailProvisionalLoad):
+ (WebFrameLoaderClient::dispatchDidFailLoad):
+ (WebFrameLoaderClient::dispatchDidFinishLoad):
+ (WebFrameLoaderClient::dispatchDidFirstLayout):
+ (WebFrameLoaderClient::dispatchCreatePage):
+ (WebFrameLoaderClient::dispatchShow):
+ (WebFrameLoaderClient::dispatchDecidePolicyForMIMEType):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNewWindowAction):
+ (WebFrameLoaderClient::dispatchDecidePolicyForNavigationAction):
+ (WebFrameLoaderClient::dispatchUnableToImplementPolicy):
+ (WebFrameLoaderClient::dispatchWillSubmitForm):
+ (WebFrameLoaderClient::dispatchDidLoadMainResource):
+ (WebFrameLoaderClient::clearLoadingFromPageCache):
+ (WebFrameLoaderClient::isLoadingFromPageCache):
+ (WebFrameLoaderClient::revertToProvisionalState):
+ (WebFrameLoaderClient::setMainDocumentError):
+ (WebFrameLoaderClient::clearUnarchivingState):
+ (WebFrameLoaderClient::progressStarted):
+ (WebFrameLoaderClient::progressCompleted):
+ (WebFrameLoaderClient::incrementProgress):
+ (WebFrameLoaderClient::completeProgress):
+ (WebFrameLoaderClient::setMainFrameDocumentReady):
+ (WebFrameLoaderClient::startDownload):
+ (WebFrameLoaderClient::willChangeTitle):
+ (WebFrameLoaderClient::didChangeTitle):
+ (WebFrameLoaderClient::committedLoad):
+ (WebFrameLoaderClient::finishedLoading):
+ (WebFrameLoaderClient::finalSetupForReplace):
+ (WebFrameLoaderClient::cancelledError):
+ (WebFrameLoaderClient::cannotShowURLError):
+ (WebFrameLoaderClient::interruptForPolicyChangeError):
+ (WebFrameLoaderClient::cannotShowMIMETypeError):
+ (WebFrameLoaderClient::fileDoesNotExistError):
+ (WebFrameLoaderClient::shouldFallBack):
+ (WebFrameLoaderClient::mainFrameURL):
+ (WebFrameLoaderClient::setDefersCallbacks):
+ (WebFrameLoaderClient::willUseArchive):
+ (WebFrameLoaderClient::isArchiveLoadPending):
+ (WebFrameLoaderClient::cancelPendingArchiveLoad):
+ (WebFrameLoaderClient::clearArchivedResources):
+ (WebFrameLoaderClient::canHandleRequest):
+ (WebFrameLoaderClient::canShowMIMEType):
+ (WebFrameLoaderClient::representationExistsForURLScheme):
+ (WebFrameLoaderClient::generatedMIMETypeForURLScheme):
+ (WebFrameLoaderClient::elementForEvent):
+ (WebFrameLoaderClient::createPolicyDecider):
+ (WebFrameLoaderClient::frameLoadCompleted):
+ (WebFrameLoaderClient::restoreScrollPositionAndViewState):
+ (WebFrameLoaderClient::provisionalLoadStarted):
+ (WebFrameLoaderClient::shouldTreatURLAsSameAsCurrent):
+ (WebFrameLoaderClient::addHistoryItemForFragmentScroll):
+ (WebFrameLoaderClient::didFinishLoad):
+ (WebFrameLoaderClient::prepareForDataSourceReplacement):
+ (WebFrameLoaderClient::createDocumentLoader):
+ (WebFrameLoaderClient::setTitle):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource webFrame]):
+ * WebView/WebFrame.mm:
+ (frame):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _reloadForPluginChanges]):
+ (-[WebFrame _initWithWebFrameView:webView:bridge:]):
+ (-[WebFrame _frameLoader]):
+ (-[WebFrame provisionalDataSource]):
+ (-[WebFrame dataSource]):
+ (-[WebFrame parentFrame]):
+ (-[WebFrame _provisionalLoadStarted]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation finishedLoadingWithDataSource:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ (-[NSArray validateUserInterfaceItem:]):
+ (-[NSArray scrollWheel:]):
+ (-[NSArray acceptsFirstMouse:]):
+ (-[NSArray shouldDelayWindowOrderingForEvent:]):
+ (-[NSArray _selectionStartFontAttributesAsRTF]):
+ (-[NSArray changeBaseWritingDirection:]):
+ (-[NSArray indent:]):
+ (-[NSArray outdent:]):
+ (-[WebHTMLView copy:]):
+ (-[WebHTMLView cut:]):
+ (-[WebHTMLView paste:]):
+ * WebView/WebView.mm:
+ (-[WebView _dashboardRegions]):
+ (-[WebView setProhibitsMainFrameScrolling:]):
+ (-[WebView _setInViewSourceMode:]):
+ (-[WebView _inViewSourceMode]):
+ (-[WebView setEditable:]):
+
+2006-10-24 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/4801331> "Spelling..." menu item should be "Show/Hide Spelling" post-Tiger, to match AppKit
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray validateUserInterfaceItem:]):
+ post-Tiger, update the menu item text to "Show Spelling"/"Hide Spelling" based on whether
+ the spelling panel is already showing. Also, removed else's after returns, and removed
+ braces around one-line if clauses.
+ (-[NSArray showGuessPanel:]):
+ post-Tiger, make this item hide the spelling panel if it's already showing
+
+ * English.lproj/Localizable.strings:
+ updated for this change
+
+2006-10-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Anders.
+
+ <rdar://problem/4588878> 'WebHTMLView' may not respond to '-_webView'
+
+ * Misc/WebNSViewExtras.h:
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _webView]):
+
+2006-10-24 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Anders
+
+ http://bugs.webkit.org/show_bug.cgi?id=11406 - Crash in [WebFrame dataSource]
+ In the transition to ObjC++ we lost alot of our free nil checking that we must now do manually
+ to prevent null dereferencing.
+
+ * WebView/WebFrame.mm:
+ (-[WebFrame provisionalDataSource]):
+ (-[WebFrame dataSource]):
+
+2006-10-24 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ Initial plumbing for grammar checking. No actual grammar are checked at this time.
+
+ * English.lproj/WebViewEditingContextMenu.nib/classes.nib:
+ * English.lproj/WebViewEditingContextMenu.nib/info.nib:
+ * English.lproj/WebViewEditingContextMenu.nib/objects.nib:
+ Added grammar-checking item, reworded to match changes in framework. This will be used
+ post-Tiger.
+
+ * English.lproj/WebViewEditingContextMenuOld.nib/classes.nib: Added.
+ * English.lproj/WebViewEditingContextMenuOld.nib/info.nib: Added.
+ * English.lproj/WebViewEditingContextMenuOld.nib/objects.nib: Added.
+ Copy of WebViewEditingContextMenu.nib, unchanged. This will be used on Tiger.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ Choose the right context menu based on BUILDING_ON_TIGER.
+
+ * WebView/WebPreferenceKeysPrivate.h:
+ declare grammar-related NSUserDefault value
+
+ * WebView/WebViewPrivate.h:
+ declare grammar-related methods
+
+ * WebView/WebView.mm:
+ declare static BOOL grammarCheckingEnabled
+ (-[WebViewPrivate init]):
+ initialize grammarCheckingEnabled to NSUserDefaults value
+ (-[WebView validateUserInterfaceItem:]):
+ validate toggleGrammarChecking: menu item
+ (-[WebView isGrammarCheckingEnabled]):
+ return value of grammarCheckingEnabled
+ (-[WebView setGrammarCheckingEnabled:]):
+ set value of grammarCheckingEnabled, call frame to remove existing bad grammar markers
+ (-[WebView toggleGrammarChecking:]):
+ flip the value
+
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFrame.mm:
+ (-[WebFrame _unmarkAllBadGrammar]):
+ new placeholder method, does nothing yet
+
+ * WebView/WebHTMLViewInternal.h:
+ declare grammar-related methods
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray validateUserInterfaceItem:]):
+ validate toggleGrammarChecking: menu item
+ (-[WebHTMLView isGrammarCheckingEnabled]):
+ new method, calls through to WebView
+ (-[WebHTMLView setGrammarCheckingEnabled:]):
+ ditto
+ (-[WebHTMLView toggleGrammarChecking:]):
+ ditto
+
+ * English.lproj/StringsNotToBeLocalized.txt:
+ Updated for these changes
+
+ * WebKit.xcodeproj/project.pbxproj:
+ updated for new files
+
+2006-10-23 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ - converted WebDocumentLoader to C++
+
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController pluginView:receivedResponse:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.mm:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _mainDocumentError]):
+ (-[WebDataSource _URL]):
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource _bridge]):
+ (-[WebDataSource _URLForHistory]):
+ (-[WebDataSource _documentLoader]):
+ (-[WebDataSource _initWithDocumentLoader:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource data]):
+ (-[WebDataSource webFrame]):
+ (-[WebDataSource initialRequest]):
+ (-[WebDataSource request]):
+ (-[WebDataSource response]):
+ (-[WebDataSource textEncodingName]):
+ (-[WebDataSource isLoading]):
+ (-[WebDataSource unreachableURL]):
+ (-[WebDataSource webArchive]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.mm:
+ (WebDocumentLoaderMac::WebDocumentLoaderMac):
+ (WebDocumentLoaderMac::setDataSource):
+ (WebDocumentLoaderMac::dataSource):
+ (WebDocumentLoaderMac::attachToFrame):
+ (WebDocumentLoaderMac::detachFromFrame):
+ * WebView/WebFrame.mm:
+ (-[WebFrame _createItem:]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _addChild:]):
+ (dataSource):
+ (-[WebFrame _dataSourceForDocumentLoader:]):
+ (-[WebFrame _addDocumentLoader:toUnarchiveState:]):
+ (-[WebFrame loadArchive:]):
+ (-[WebFrame _updateHistoryForReload]):
+ (-[WebFrame _updateHistoryForStandardLoad]):
+ (-[WebFrame _updateHistoryForInternalLoad]):
+ (-[WebFrame _dispatchIdentifierForInitialRequest:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:willSendRequest:redirectResponse:fromDocumentLoader:]):
+ (-[WebFrame _dispatchDidReceiveAuthenticationChallenge:forResource:fromDocumentLoader:]):
+ (-[WebFrame _dispatchDidCancelAuthenticationChallenge:forResource:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didReceiveResponse:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didReceiveContentLength:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didFinishLoadingFromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didFailLoadingWithError:fromDocumentLoader:]):
+ (-[WebFrame _dispatchDidLoadMainResourceForDocumentLoader:]):
+ (-[WebFrame _clearLoadingFromPageCacheForDocumentLoader:]):
+ (-[WebFrame _isDocumentLoaderLoadingFromPageCache:]):
+ (-[WebFrame _makeRepresentationForDocumentLoader:]):
+ (-[WebFrame _revertToProvisionalStateForDocumentLoader:]):
+ (-[WebFrame _setMainDocumentError:forDocumentLoader:]):
+ (-[WebFrame _clearUnarchivingStateForLoader:]):
+ (-[WebFrame _willChangeTitleForDocument:]):
+ (-[WebFrame _didChangeTitleForDocument:]):
+ (-[WebFrame _finishedLoadingDocument:]):
+ (-[WebFrame _committedLoadWithDocumentLoader:data:]):
+ (-[WebFrame _documentLoader:setMainDocumentError:]):
+ (-[WebFrame _finalSetupForReplaceWithDocumentLoader:]):
+ (-[WebFrame _createDocumentLoaderWithRequest:]):
+ (-[WebFrame _provisionalLoadStarted]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation title]):
+ * WebView/WebView.mm:
+ (-[WebView _mainFrameOverrideEncoding]):
+
+2006-10-23 Geoffrey Garen <ggaren@apple.com>
+
+ RS by Maciej.
+
+ Gave ObjC++ files .mm extension instead of .m.
+
+ * WebCoreSupport/WebPageBridge.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDocumentLoaderMac.m: Removed.
+
+2006-10-23 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - converted WebFrameLoader to C++
+
+ * History/WebHistoryItem.m:
+ (+[WebHistoryItem _closeObjectsInPendingPageCaches]):
+ * Plugins/WebBaseNetscapePluginView.mm:
+ (-[WebBaseNetscapePluginView loadRequest:inTarget:withNotifyData:sendNotification:]):
+ * Plugins/WebNetscapePluginStream.mm:
+ (-[WebNetscapePluginStream start]):
+ (-[WebNetscapePluginStream stop]):
+ * Plugins/WebPluginController.mm:
+ (-[WebPluginController webPlugInContainerLoadRequest:inFrame:]):
+ (-[WebPluginController pluginView:receivedResponse:]):
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.mm:
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource _webView]):
+ (-[WebDataSource webFrame]):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.m:
+ (-[WebDocumentLoaderMac dealloc]):
+ (-[WebDocumentLoaderMac attachToFrame]):
+ (-[WebDocumentLoaderMac detachFromFrame]):
+ * WebView/WebFrame.mm:
+ (+[WebFrame _timeOfLastCompletedLoad]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _currentBackForwardListItemToResetTo]):
+ (-[WebFrame _itemForRestoringDocState]):
+ (-[WebFrame _frameLoader]):
+ (-[WebFrame _firstLayoutDone]):
+ (-[WebFrame _loadType]):
+ (-[WebFrame provisionalDataSource]):
+ (-[WebFrame dataSource]):
+ (-[WebFrame loadRequest:]):
+ (-[WebFrame loadArchive:]):
+ (-[WebFrame stopLoading]):
+ (-[WebFrame reload]):
+ (-[WebFrame _updateHistoryForCommit]):
+ (-[WebFrame _updateHistoryForReload]):
+ (-[WebFrame _updateHistoryForInternalLoad]):
+ (-[WebFrame _deliverArchivedResourcesAfterDelay]):
+ (-[WebFrame _willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrame _deliverArchivedResources]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame _provisionalLoadStarted]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _clearLastHitViewIfSelf]):
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ (-[NSArray removeMouseMovedObserverUnconditionally]):
+ (-[NSArray removeMouseMovedObserver]):
+ (-[NSArray viewWillMoveToWindow:]):
+ (-[NSArray viewDidMoveToWindow]):
+ (-[WebHTMLView _canMakeTextSmaller]):
+ (-[WebHTMLView _canMakeTextLarger]):
+ (-[WebHTMLView _canMakeTextStandardSize]):
+ * WebView/WebPDFView.mm:
+ (-[WebPDFView PDFViewWillClickOnLink:withURL:]):
+ * WebView/WebView.mm:
+ (-[WebView _close]):
+ (-[WebView setDefersCallbacks:]):
+ (-[WebView setCustomTextEncodingName:]):
+
+2006-10-23 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Bradee.
+
+ Moved some page-level operations from WebFrameBridge to WebPageBridge.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ * WebCoreSupport/WebPageBridge.m:
+ (-[WebPageBridge createModalDialogWithURL:referrer:]):
+ (-[WebPageBridge canRunModal]):
+ (-[WebPageBridge canRunModalNow]):
+ (-[WebPageBridge runModal]):
+ * WebKit.xcodeproj/project.pbxproj: Made WebPageBridge.m ObjC++ to support
+ WebCore #includes.
+
+2006-10-23 John Sullivan <sullivan@apple.com>
+
+ * WebKitPrefix.h:
+ Removed redundant definition of BUILDING_ON_TIGER that I just added. It turns out this had
+ already been added between the last time I updated in this tree and when I needed it locally.
+
+2006-10-23 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Anders
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Move WebKitPrefix.h from Misc group to top level, to match WebCore
+
+ * WebKitPrefix.h:
+ defined BUILDING_ON_TIGER a la WebCore, in preparation for future use of post-Tiger API
+
+2006-10-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Rename the now ObjC++ files to be .mm and remove the explicit file types.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ * English.lproj/StringsNotToBeLocalized.txt:
+ * Plugins/WebBaseNetscapePluginView.m: Removed.
+ * Plugins/WebNetscapePluginStream.m: Removed.
+ * Plugins/WebPluginController.m: Removed.
+ * WebCoreSupport/WebFrameBridge.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m: Removed.
+ * WebView/WebFrame.m: Removed.
+ * WebView/WebFrameView.m: Removed.
+ * WebView/WebPDFView.m: Removed.
+ * WebView/WebPolicyDelegate.m: Removed.
+ * WebView/WebView.m: Removed.
+
+2006-10-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Move the undef try/catch to WebKitPrefix.h and include algorithm so we get
+ exception_defines.h and so the undef of try/catch works.
+
+ Break off the BGRA to ARGB code into WebGraphicsExtras.c, this lets
+ WebBaseNetscapePluginView.m safely compile as ObjC++ and not cause the Accelerate
+ framework to complain about C++ exceptions being disabled.
+
+ * Misc/WebGraphicsExtras.c: Added.
+ (WebConvertBGRAToARGB):
+ * Misc/WebGraphicsExtras.h: Added.
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView _aglOffscreenImageForDrawingInRect:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebKitPrefix.h:
+ * WebView/WebView.m:
+
+2006-10-22 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - Add DOMHTMLFormElementPrivate.h to the project.
+
+ * MigrateHeaders.make:
+
+2006-10-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - convert WebLoader and its 3 subclasses to C++
+
+ * Plugins/WebNetscapePluginStream.h:
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream dealloc]):
+ (-[WebNetscapePluginStream finalize]):
+ (-[WebNetscapePluginStream start]):
+ (-[WebNetscapePluginStream cancelLoadWithError:]):
+ (-[WebNetscapePluginStream stop]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge canRunModalNow]):
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+ (-[WebFramePrivate finalize]):
+ (frame): Changed from uppercase to lowercase so that it won't conflict
+ with the WebCore class named Frame.
+ (-[WebFrame _firstChildFrame]):
+ (-[WebFrame _lastChildFrame]):
+ (-[WebFrame _previousSiblingFrame]):
+ (-[WebFrame _nextSiblingFrame]):
+ (-[WebFrame _traverseNextFrameStayWithin:]):
+ (-[WebFrame _immediateChildFrameNamed:]):
+ (-[WebFrame _nextFrameWithWrap:]):
+ (-[WebFrame _previousFrameWithWrap:]):
+ (-[WebFrame findFrameNamed:]):
+ (-[WebFrame parentFrame]):
+ (-[WebFrame _dispatchSourceFrame:willSubmitForm:withValues:submissionDecider:]):
+ (-[WebFrame _deliverArchivedResourcesAfterDelay]):
+ (-[WebFrame _willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrame _archiveLoadPendingForLoader:]):
+ (-[WebFrame _cancelPendingArchiveLoadForLoader:]):
+ (-[WebFrame _clearArchivedResources]):
+ (-[WebFrame _deliverArchivedResources]):
+
+2006-10-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=10328
+ REGRESSION: frame leak reported by buildbot
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::WebEditorClient): Don't retain the web view.
+ (WebEditorClient::~WebEditorClient): Don't release the web view.
+ (WebEditorClient::setWebView): Ditto.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge finishInitializingWithFrameName:view:]): Added. Common code for use by both
+ init methods below.
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]): Changed to use new method.
+ Also added comment pointing out design flaw -- we attach the client to the web view here,
+ but we need to be sure to detach in case the web view is deallocated first.
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]): Ditto.
+
+2006-10-21 Darin Adler <darin@apple.com>
+
+ Reviewed by Adam.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=11376
+ build scripts should invoke make with "-j" option for multiple processors
+
+ * WebKit.xcodeproj/project.pbxproj: Pass -j `sysctl -n hw.ncpu` to make.
+
+2006-10-21 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/4478625> HTML Editing: Basic table editing and culling
+
+ Initial implementaltion of table deletion user interface:
+ * Adds a new editing delegate method, webView:shouldShowDeleteInterfaceForElement:.
+ * The new delegate method is called from the new shouldShowDeleteInterface EditorClient function.
+
+ * DefaultDelegates/WebDefaultEditingDelegate.m:
+ (-[WebDefaultEditingDelegate webView:shouldShowDeleteInterfaceForElement:]):
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::WebEditorClient):
+ (WebEditorClient::shouldDeleteRange):
+ (WebEditorClient::shouldShowDeleteInterface):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebEditingDelegatePrivate.h: Added.
+
+2006-10-21 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Maciej.
+
+ fix leaks.
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::setWebView):
+ only change webview if its different
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ actually use the client allocated in the line above instead of
+ allocation again, duh.
+
+2006-10-21 Alice Liu <alice.liu@apple.com>
+
+ Build fix.
+
+ * WebCoreSupport/WebEditorClient.h:
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::setWebView):
+
+2006-10-20 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Fixed a problem where the webview passed to the EditorClient wasn't valid yet.
+
+ * WebCoreSupport/WebEditorClient.h:
+ (WebEditorClient::setWebView):
+ added webview setter
+
+ * WebCoreSupport/WebEditorClient.mm:
+ (WebEditorClient::WebEditorClient):
+ add default constructor
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]):
+ use [page webView] since _webview isn't valid yet
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ use webview setter on editorclient
+
+2006-10-20 David Hyatt <hyatt@apple.com>
+
+ Tweak cache sizes so that they are back to the way they were,
+ except for < 512, which will stay doubled.
+
+ Reviewed by Tim H.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge getObjectCacheSize]):
+
+2006-10-20 Alice Liu <alice.liu@apple.com>
+
+ Reviewed by Maciej.
+
+ Adding knowledge of EditorClient to WebKit
+
+ * WebCoreSupport/WebEditorClient.h: Added.
+
+ * WebCoreSupport/WebEditorClient.mm: Added.
+ (WebEditorClient::WebEditorClient):
+ (WebEditorClient::~WebEditorClient):
+ (WebEditorClient::shouldDeleteRange):
+ Implementation of mac EditorClient
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ create an editor client to pass down the chain of constructors
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Added related EditorClient files
+
+ * WebKitPrefix.h:
+ Added tiger build flag in order to make certain private headers from webcore compile successfully
+
+2006-10-20 Darin Adler <darin@apple.com>
+
+ - rolled out my loader change; caused world leak and possibly a plug-in crash
+
+2006-10-20 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - convert WebLoader and its 3 subclasses to C++
+
+ * Plugins/WebNetscapePluginStream.h:
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream dealloc]):
+ (-[WebNetscapePluginStream finalize]):
+ (-[WebNetscapePluginStream start]):
+ (-[WebNetscapePluginStream cancelLoadWithError:]):
+ (-[WebNetscapePluginStream stop]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge canRunModalNow]):
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+ (-[WebFramePrivate finalize]):
+ (frame): Changed from uppercase to lowercase so that it won't conflict
+ with the WebCore class named Frame.
+ (-[WebFrame _firstChildFrame]):
+ (-[WebFrame _lastChildFrame]):
+ (-[WebFrame _previousSiblingFrame]):
+ (-[WebFrame _nextSiblingFrame]):
+ (-[WebFrame _traverseNextFrameStayWithin:]):
+ (-[WebFrame _immediateChildFrameNamed:]):
+ (-[WebFrame _nextFrameWithWrap:]):
+ (-[WebFrame _previousFrameWithWrap:]):
+ (-[WebFrame findFrameNamed:]):
+ (-[WebFrame parentFrame]):
+ (-[WebFrame _dispatchSourceFrame:willSubmitForm:withValues:submissionDecider:]):
+ (-[WebFrame _deliverArchivedResourcesAfterDelay]):
+ (-[WebFrame _willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrame _archiveLoadPendingForLoader:]):
+ (-[WebFrame _cancelPendingArchiveLoadForLoader:]):
+ (-[WebFrame _clearArchivedResources]):
+ (-[WebFrame _deliverArchivedResources]):
+
+2006-10-20 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - fixed <rdar://problem/4794935> setAcceptsMouseMovedEvents: is called for every layout,
+ taking ~1% on the PLT test
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray layoutToMinimumPageWidth:maximumPageWidth:adjustingViewSize:]):
+ Don't call setAcceptsMouseMovedEvents: and WKSetNSWindowShouldPostEventNotifications() here
+ because this is called too often.
+
+ * WebView/WebView.m:
+ (-[WebView viewWillMoveToWindow:]):
+ Do call them here, because this is guaranteed to be called at least once for each window
+ containing a webview, but isn't called too often. Also restructured this method a little.
+
+2006-10-19 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Anders.
+
+ Bug 11366: Web Inspector should show user agent style rules
+ http://bugs.webkit.org/show_bug.cgi?id=11366
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector init]):
+ (-[WebInspector showOptionsMenu]):
+ (-[WebInspector _toggleShowUserAgentStyles:]):
+ * WebInspector/WebInspectorInternal.h:
+ * WebInspector/webInspector/inspector.js:
+
+2006-10-19 Brady Eidson <beidson@apple.com>
+
+ Build fix - 2gig is on that pesky signed/unsigned limit...
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge getObjectCacheSize]):
+
+2006-10-19 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Hyatt.
+
+ Death to 16777216. Long live 33554432.
+ (Cache size changed needs to be reflected in localization file)
+
+ * English.lproj/StringsNotToBeLocalized.txt:
+
+2006-10-19 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Hyatt
+
+ Added an larger in-memory level of cache for machines with 2+gb ram
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge getObjectCacheSize]):
+
+2006-10-19 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Hyatt
+
+ Double the default memory cache size
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+
+2006-10-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin D and Geoff
+
+ * WebKit.xcodeproj/project.pbxproj:
+ version wars
+
+ Cleaned up this file, as follows:
+ - renamed all file-internal methods to start with underscores
+ - moved all file-internal methods into a FileInternal category block, and alphabetized them
+ - grouped all other methods by where/how they were defined (delegate methods, protocol methods, overrides, etc.)
+ - removed unstylish braces around one-line clauses
+
+ * WebView/WebPDFView.m:
+ (_applicationInfoForMIMEType):
+ (_PDFSelectionsAreEqual):
+ (+[WebPDFView supportedMIMETypes]):
+ (-[WebPDFView setPDFDocument:]):
+ (-[WebPDFView dealloc]):
+ (-[WebPDFView centerSelectionInVisibleArea:]):
+ (-[WebPDFView scrollPageDown:]):
+ (-[WebPDFView scrollPageUp:]):
+ (-[WebPDFView scrollLineDown:]):
+ (-[WebPDFView scrollLineUp:]):
+ (-[WebPDFView scrollToBeginningOfDocument:]):
+ (-[WebPDFView scrollToEndOfDocument:]):
+ (-[WebPDFView jumpToSelection:]):
+ (-[WebPDFView acceptsFirstResponder]):
+ (-[WebPDFView becomeFirstResponder]):
+ (-[WebPDFView hitTest:]):
+ (-[WebPDFView initWithFrame:]):
+ (-[WebPDFView menuForEvent:]):
+ (-[WebPDFView setNextKeyView:]):
+ (-[WebPDFView viewDidMoveToWindow]):
+ (-[WebPDFView viewWillMoveToWindow:]):
+ (-[WebPDFView validateUserInterfaceItem:]):
+ (-[WebPDFView copy:]):
+ (-[WebPDFView takeFindStringFromSelection:]):
+ (-[WebPDFView canPrintHeadersAndFooters]):
+ (-[WebPDFView printOperationWithPrintInfo:]):
+ (-[WebPDFView viewWillMoveToHostWindow:]):
+ (-[WebPDFView viewDidMoveToHostWindow]):
+ (-[WebPDFView elementAtPoint:]):
+ (-[WebPDFView elementAtPoint:allowShadowContent:]):
+ (-[WebPDFView searchFor:direction:caseSensitive:wrap:]):
+ (-[WebPDFView viewState]):
+ (-[WebPDFView setViewState:]):
+ (-[WebPDFView writeSelectionWithPasteboardTypes:toPasteboard:]):
+ (-[WebPDFView PDFViewWillClickOnLink:withURL:]):
+ (+[WebPDFView _PDFPreviewViewClass]):
+ (+[WebPDFView _PDFViewClass]):
+ (-[WebPDFView _anyPDFTagsFoundInMenu:]):
+ (-[WebPDFView _applyPDFDefaults]):
+ (-[WebPDFView _fakeKeyEventWithFunctionKey:]):
+ (-[WebPDFView _menuItemsFromPDFKitForEvent:]):
+ (-[WebPDFView _openWithFinder:]):
+ (-[WebPDFView _path]):
+ (-[WebPDFView _PDFSubview]):
+ (-[WebPDFView _pointIsInSelection:]):
+ (-[WebPDFView _receivedPDFKitLaunchNotification:]):
+ (-[WebPDFView _scaledAttributedString:]):
+ (-[WebPDFView _trackFirstResponder]):
+ (-[PDFPrefUpdatingProxy forwardInvocation:]):
+ (-[PDFPrefUpdatingProxy methodSignatureForSelector:]):
+
+2006-10-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker
+
+ - fixed <rdar://problem/4792761> Safari should use fancier embedded PDFKit stuff when it's available
+
+ * WebKit.xcodeproj/project.pbxproj:
+ version wars
+
+ * WebView/WebFrameView.m:
+ (-[WebFrameView _makeDocumentViewForDataSource:]):
+ initialize document view with frame view's rect instead of empty rect. This avoids some problems when
+ constructing view hierarchies from nibs
+
+ * WebView/WebPreferencesPrivate.h:
+ declare new _usePDFPreviewView and _setUsePDFPreviewView:, used for debugging
+ * WebView/WebPreferenceKeysPrivate.h:
+ declare new preference key string
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+ initialize new preference to true (we will by default use the new view if it's available)
+ (-[WebPreferences _usePDFPreviewView]):
+ new accessor for new pref
+ (-[WebPreferences _setUsePDFPreviewView:]):
+ ditto
+
+ * WebView/WebPDFView.h:
+ new previewView ivar
+
+ * WebView/WebPDFView.m:
+ (+[WebPDFView PDFPreviewViewClass]):
+ new method, returns class to use for fancier embedded PDFKit stuff, or nil if fancy stuff isn't available
+ (-[WebPDFView initWithFrame:]):
+ now tries to use fancier embedded PDFKit stuff if it's available and the pref is set to use it; falls back
+ to old behavior otherwise
+ (-[WebPDFView dealloc]):
+ release new previewView ivar (retained in initWithFrame:)
+ (-[WebPDFView viewWillMoveToWindow:]):
+ stop observing PDFKit notification when we're removed from window
+ (-[WebPDFView viewDidMoveToWindow]):
+ start observing PDFKit notification when we're added to window
+ (-[WebPDFView _receivedPDFKitLaunchNotification:]):
+ respond to this new PDFKit notification by opening the document via NSWorkspace
+
+ * English.lproj/StringsNotToBeLocalized.txt:
+ updated for lots of recent changes
+
+2006-10-19 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by ap.
+
+ Win32 build fix.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+ (WebFrame::createNewWindow):
+
+2006-10-19 Mitz Pettel <mitz@webkit.org>
+
+ Reviewed and landed by ap.
+
+ - fixed the inspector's tree popup
+
+ * WebInspector/webInspector/inspector.html:
+
+2006-10-18 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Maciej.
+
+ Win32 build fix.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::createNewWindow):
+ * COM/WebFrame.h:
+
+2006-10-18 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Adam.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11000
+ REGRESSION (r16101): css2.1/t0801-c412-hz-box-00-b-a is failing because the QuickTime plugin is taking over but not rendering the png
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ Return ObjectElementFrame if the MIME type is one of the image ones we support.
+
+2006-10-17 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by harrison
+
+ <rdar://problem/4765600>
+ REGRESSION: Mail.app: smart deletion of words does not work
+
+ Regressed when we pushed selecion expansion down into WebCore. It's OK
+ to try a smart delete from _deleteWithDirection:, which is called by
+ deleteFoward: and deleteBackward: if the current selection is a
+ range.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray _deleteWithDirection:granularity:killRing:isTypingAction:]):
+
+2006-10-13 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by harrison
+
+ <rdar://problem/3655385>
+ Editing: -indent: method unimplemented
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray validateUserInterfaceItem:]): Only allow indent:/outdent: in
+ richly editable areas.
+ (-[NSArray indent:]):
+ (-[NSArray outdent:]):
+
+2006-10-13 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed, build fix.
+
+ * icu/unicode/putil.h: Added - needed for build if you don't have apple internal headers.
+
+2006-10-13 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed, build fix.
+
+ * icu/unicode/ustring.h: Added - needed for build if you don't have apple internal headers.
+
+2006-10-13 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - add a bunch of casts to get this compiling with older Xcode versions
+
+ (I used static_cast so it will be easier to find and remove these once we have completely moved
+ on to a new enough compiler version.)
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (+[WebBaseNetscapePluginView getCarbonEvent:]):
+ (-[WebBaseNetscapePluginView getCarbonEvent:withEvent:]):
+ (-[WebBaseNetscapePluginView fixWindowPort]):
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ (-[WebBaseNetscapePluginView _createWindowlessAGLContext]):
+ (-[WebBaseNetscapePluginView _reshapeAGLWindow]):
+ (-[WebBaseNetscapePluginView _aglOffscreenImageForDrawingInRect:]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-10-13 Kevin McCullough <KMcCullough@apple.com>
+
+ Changed by Darin, reviewed by me.
+
+ * Plugins/WebNetscapePluginStream.m: Fixed case of import so we can compile on
+ case-sensitive file system.
+
+2006-10-13 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - converted WebFormState from Objective-C to C++
+
+ * ForwardingHeaders: Added an entire copy of WebCore's forwarding headers here.
+ We should eventually come up with a more-elegant solution.
+
+ * WebKit.xcodeproj/project.pbxproj: Added ForwardingHeaders to the include paths.
+ Converted many files from Objective-C to Objective-C++. In a later check-in, I'll
+ rename them to .mm instead of .m. Removed C-only warning options for now. In a
+ later check-in I will add these back in a way that omits them for C++.
+
+ * Plugins/WebPluginContainerCheck.m: Updated for header changes.
+
+ * WebView/WebFrameInternal.h: Updated for header changes. Removed WebFrameLoaderClient category
+ so this file can still be used by Objective-C code (not just Objective-C++).
+
+ * WebView/WebFrame.m: Put WebFrameLoaderClient category in here.
+ (-[WebFrame _loadItem:withLoadType:]): Changed to use 0 instead of nil for FormState and fixed
+ enum code for C++ compatibility.
+ (-[WebFrame _initWithWebFrameView:webView:bridge:]): Added call to setFrameLoaderClient: here.
+ (-[WebFrame _updateHistoryForCommit]): Fixed enum code for C++ compatibility.
+ (-[WebFrame _updateHistoryForReload]): Ditto.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]): Removed call to setFrameLoaderClient:.
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]): Ditto.
+ (-[WebFrameBridge _retrieveKeyboardUIModeFromPreferences:]): Fixed enum code for C++ compatibility.
+ (-[WebFrameBridge runModal]): Changed code to not use "namespace" as a local variable name.
+
+ * WebView/WebPDFView.m: Added extern "C" so this can compile as Objective-C++.
+
+2006-10-12 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - liberate more WebKit code down to WebCore
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+
+2006-10-12 Adele Peterson <adele@apple.com>
+
+ Reviewed by Maciej.
+
+ WebKit part of fix for <rdar://problem/4450613> need a means to attach user data to any menu that is popuped up in HTML
+
+ Added private delegate method for clients that want access to a PopupMenu's NSMenu.
+
+ * DefaultDelegates/WebDefaultUIDelegate.m: (-[NSApplication webView:willPopupMenu:]):
+ * WebCoreSupport/WebFrameBridge.m: (-[WebFrameBridge willPopupMenu:]):
+ * WebView/WebUIDelegatePrivate.h:
+
+2006-10-12 MorganL <morganl.webkit@yahoo.com>
+
+ Reviewed/landed by Adam.
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=11264
+ Windows build busted
+
+ * COM/WebFrame.cpp:
+ (WebFrame::receivedResponse):
+
+2006-10-11 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - preparations for making more code C++
+
+ * WebKitPrefix.h: Fixed ifdef so that C++ files get all the precompiled stuff
+ that non-C++ files get.
+
+ * Misc/WebKitLogging.h:
+ * Misc/WebKitSystemBits.h:
+ * Misc/WebLocalizableStrings.h:
+ * WebCoreSupport/WebSystemInterface.h:
+ Added extern "C".
+
+ * Misc/WebNSViewExtras.h:
+ * WebView/WebDataSource.m: (addTypesFromClass):
+ * WebView/WebFrameView.m: (addTypesFromClass):
+ Eliminated use of the identifier "class".
+
+ * WebView/WebView.m: (-[WebView _goToItem:withLoadType:]): Added a type cast.
+
+ * Plugins/WebBaseNetscapePluginView.m: Added lots of type casts.
+
+2006-10-10 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej.
+
+ Moved WebFrameLoader into WebCoreFrameBridge
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ (-[WebFrameBridge dealloc]):
+ (-[WebFrameBridge setTitle:]):
+ (-[WebFrameBridge receivedData:textEncodingName:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:postData:]):
+ (-[WebFrameBridge objectLoadedFromCacheWithURL:response:data:]):
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ (-[WebFrameBridge reportClientRedirectToURL:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameBridge reportClientRedirectCancelled:]):
+ (-[WebFrameBridge close]):
+ (-[WebFrameBridge loadURL:referrer:reload:userGesture:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge tokenizerProcessedData]):
+ (-[WebFrameBridge frameDetached]):
+ (-[WebFrameBridge didFirstLayout]):
+ (-[WebFrameBridge notifyIconChanged:]):
+ (-[WebFrameBridge originalRequestURL]):
+ (-[WebFrameBridge isLoadTypeReload]):
+
+2006-10-10 Adele Peterson <adele@apple.com>
+
+ Reviewed by Beth.
+
+ Removed handleAutoscrollForMouseDragged. Except for autoscroll caused by drag and drop, all other
+ autoscrolling should be done in WebCore instead of in AppKit.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ * WebView/WebHTMLView.m:
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-10-10 Darin Adler <darin@apple.com>
+
+ - corrected an archive regression caused by loader refactoring
+ (pointed out by Graham Dennis)
+
+ * WebView/WebFrame.m: (-[WebFrame _deliverArchivedResourcesAfterDelay]):
+ Fix selector name.
+
+2006-10-10 Maciej Stachowiak <mjs@apple.com>
+
+ Rubber stamped by Eric.
+
+ - moved a whole bunch of stuff over to WebCore - updated includes appropriately
+
+ * Loader/LoaderNSURLExtras.h: Removed.
+ * Loader/LoaderNSURLExtras.m: Removed.
+ * Loader/WebDataProtocol.h: Removed.
+ * Loader/WebDataProtocol.m: Removed.
+ * Loader/WebDocumentLoader.h: Removed.
+ * Loader/WebDocumentLoader.m: Removed.
+ * Loader/WebFormDataStream.h: Removed.
+ * Loader/WebFormDataStream.m: Removed.
+ * Loader/WebFormState.h: Removed.
+ * Loader/WebFormState.m: Removed.
+ * Loader/WebFrameLoader.h: Removed.
+ * Loader/WebFrameLoader.m: Removed.
+ * Loader/WebFrameLoaderClient.h: Removed.
+ * Loader/WebLoader.h: Removed.
+ * Loader/WebLoader.m: Removed.
+ * Loader/WebMainResourceLoader.h: Removed.
+ * Loader/WebMainResourceLoader.m: Removed.
+ * Loader/WebNetscapePlugInStreamLoader.h: Removed.
+ * Loader/WebNetscapePlugInStreamLoader.m: Removed.
+ * Loader/WebPlugInStreamLoaderDelegate.h: Removed.
+ * Loader/WebPolicyDecider.h: Removed.
+ * Loader/WebPolicyDecider.m: Removed.
+ * Loader/WebSubresourceLoader.h: Removed.
+ * Loader/WebSubresourceLoader.m: Removed.
+ * Misc/WebNSURLExtras.m:
+ * Plugins/WebBaseNetscapePluginStream.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+ * Plugins/WebNetscapePluginStream.m:
+ * Plugins/WebPluginContainerCheck.m:
+ * Plugins/WebPluginController.m:
+ * WebCoreSupport/WebFrameBridge.m:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebFrame.m:
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.m:
+ * WebView/WebPolicyDeciderMac.h:
+ * WebView/WebPolicyDelegate.m:
+ * WebView/WebView.m:
+
+2006-10-10 Mark Rowe <bdash@webkit.org>
+
+ Reviewed by Maciej.
+
+ Fix crash on launch in nightly builds after r16965.
+
+ Safari will sometimes call through to -[NSURL _webkit_canonicalize] before creating a WebView. If this happens,
+ InitWebCoreSystemInterface has not yet been called so the call to wkNSURLProtocolClassForReqest is via a garbage
+ pointer.
+
+ * Misc/WebNSURLExtras.m:
+ (-[NSURL _webkit_canonicalize]): Ensure InitWebCoreSystemInterface is called prior to canonicalURL.
+
+2006-10-10 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - split out some NSURL extras to be moved to WebCore
+
+ * Loader/LoaderNSURLExtras.h: Added.
+ * Loader/LoaderNSURLExtras.m: Added.
+ (urlByRemovingComponent):
+ (urlByRemovingFragment):
+ (urlOriginalDataAsString):
+ (urlOriginalData):
+ (urlWithData):
+ (WebCFAutorelease):
+ (urlWithDataRelativeToURL):
+ (urlByRemovingResourceSpecifier):
+ (urlIsFileURL):
+ (stringIsFileURL):
+ (urlIsEmpty):
+ (canonicalURL):
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader shouldReloadForCurrent:andDestination:]):
+ (setHTTPReferrer):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (-[WebFrameLoader _notifyIconChanged:]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:documentLoader:formState:andCall:withSelector:]):
+ (-[WebFrameLoader safeLoadURL:]):
+ * Misc/WebNSURLExtras.m:
+ (+[NSURL _web_URLWithData:]):
+ (+[NSURL _web_URLWithData:relativeToURL:]):
+ (-[NSURL _web_originalData]):
+ (-[NSURL _web_originalDataAsString]):
+ (-[NSURL _web_isEmpty]):
+ (-[NSURL _webkit_canonicalize]):
+ (-[NSURL _webkit_URLByRemovingComponent:]):
+ (-[NSURL _webkit_URLByRemovingFragment]):
+ (-[NSURL _webkit_URLByRemovingResourceSpecifier]):
+ (-[NSURL _webkit_isFileURL]):
+ (-[NSString _webkit_isFileURL]):
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - sever final WebFrame dependencies
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader initWithFrame:client:]):
+ (-[WebFrameLoader defersCallbacksChanged]):
+ (-[WebFrameLoader subframeIsLoading]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader detachChildren]):
+ (-[WebFrameLoader checkLoadComplete]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - convert more WebFrameLoader stuff to be independent of WebFrame
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader stopLoadingSubframes]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader closeOldDataSources]):
+ (-[WebFrameLoader isHostedByObjectElement]):
+ (-[WebFrameLoader isLoadingMainFrame]):
+ (-[WebFrameLoader loadDocumentLoader:withLoadType:formState:]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ (-[WebFrameLoader continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ (-[WebFrameLoader loadRequest:inFrameNamed:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader actionInformationForNavigationType:event:originalURL:]):
+ (-[WebFrameLoader client]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _webView]):
+ (-[WebDataSource webFrame]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _dispatchCreateWebViewWithRequest:]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders and Oliver.
+
+ - move a bunch of WebFrame methods from the Internal category to the WebFrameLoader protocol
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadRequest:]):
+ (-[WebFrameLoader loadRequest:inFrameNamed:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame loadRequest:]):
+ (-[WebFrame _dispatchDidCommitLoadForFrame]):
+ (-[WebFrame _hasFrameView]):
+ (-[WebFrame _frameLoadCompleted]):
+ (-[WebFrame _restoreScrollPositionAndViewState]):
+ (-[WebFrame _setTitle:forURL:]):
+ (-[WebFrame _createDocumentLoaderWithRequest:]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame _didFinishLoad]):
+ (-[WebFrame _addHistoryItemForFragmentScroll]):
+ (-[WebFrame _shouldTreatURLAsSameAsCurrent:]):
+ (-[WebFrame _provisionalLoadStarted]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed, build fix.
+
+ - added forgotten files
+
+ * Loader/WebPolicyDecider.h: Added.
+ * Loader/WebPolicyDecider.m: Added.
+ (-[WebPolicyDecider invalidate]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - add wrapper for WebPolicyDecisionListener so we can remove the dependency from WebFrameLoader.
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _checkContentPolicyForMIMEType:andCall:withSelector:]):
+ (-[WebFrameLoader cancelContentPolicy]):
+ (-[WebFrameLoader invalidatePendingPolicyDecisionCallingDefaultAction:]):
+ (-[WebFrameLoader checkNewWindowPolicyForRequest:action:frameName:formState:andCall:withSelector:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:documentLoader:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueAfterWillSubmitForm:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.m:
+ (-[WebFrame _createPolicyDeciderWithTarget:action:]):
+ (decisionListener):
+ (-[WebFrame _dispatchDecidePolicyForMIMEType:request:decider:]):
+ (-[WebFrame _dispatchDecidePolicyForNewWindowAction:request:newFrameName:decider:]):
+ (-[WebFrame _dispatchDecidePolicyForNavigationAction:request:decider:]):
+ (-[WebFrame _dispatchSourceFrame:willSubmitForm:withValues:submissionDecider:]):
+ * WebView/WebPolicyDeciderMac.h: Added.
+ * WebView/WebPolicyDeciderMac.m: Added.
+ (-[WebPolicyDeciderMac initWithTarget:action:]):
+ (-[WebPolicyDeciderMac dealloc]):
+ (-[WebPolicyDeciderMac decisionListener]):
+ (-[WebPolicyDeciderMac invalidate]):
+
+2006-10-09 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John
+
+ http://bugs.webkit.org/show_bug.cgi?id=11195
+ Added the WebIconDatabaseDelegate. This allows the ability to allow customization of
+ IconDatabase behavior in the future, starting now with the ability to override the
+ default icon fairly flexibly
+
+ * Misc/WebIconDatabase.h: Added setIconDatabaseDelegate:
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase iconForURL:withSize:cache:]): Call the delegate for the default icon if delegate is set
+ (-[WebIconDatabase defaultIconForURL:withSize:]): Get the default icon through the delegate if available, built-in if not
+ (-[WebIconDatabase setDelegate:]):
+ (-[WebIconDatabase delegate]):
+ * Misc/WebIconDatabaseDelegate.h: Added.
+ * Misc/WebIconDatabasePrivate.h: Added the delegate, nuked an unused class definition
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-10-09 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - eliminated uses of WebResource and WebView from WebFrameLoader
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader setDefersCallbacks:]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrameLoader archiveLoadPendingForLoader:]):
+ (-[WebFrameLoader cancelPendingArchiveLoadForLoader:]):
+ (-[WebFrameLoader _canShowMIMEType:]):
+ (-[WebFrameLoader _representationExistsForURLScheme:]):
+ (-[WebFrameLoader _generatedMIMETypeForURLScheme:]):
+ (-[WebFrameLoader loadDocumentLoader:]):
+ (-[WebFrameLoader continueAfterNavigationPolicy:]):
+ (-[WebFrameLoader sendRemainingDelegateMessagesWithIdentifier:response:length:error:]):
+ (-[WebFrameLoader actionInformationForNavigationType:event:originalURL:]):
+ * Loader/WebFrameLoaderClient.h:
+ * Loader/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ (-[WebMainResourceLoader loadWithRequestNow:]):
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+ (-[WebFrame loadRequest:]):
+ (-[WebFrame loadArchive:]):
+ (-[WebFrame _canUseResourceForRequest:]):
+ (-[WebFrame _canUseResourceWithResponse:]):
+ (-[WebFrame _deliverArchivedResourcesAfterDelay]):
+ (-[WebFrame _willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrame _archiveLoadPendingForLoader:]):
+ (-[WebFrame _cancelPendingArchiveLoadForLoader:]):
+ (-[WebFrame _clearArchivedResources]):
+ (-[WebFrame _deliverArchivedResources]):
+ (-[WebFrame _setDefersCallbacks:]):
+ (-[WebFrame _canHandleRequest:]):
+ (-[WebFrame _canShowMIMEType:]):
+ (-[WebFrame _representationExistsForURLScheme:]):
+ (-[WebFrame _generatedMIMETypeForURLScheme:]):
+ (-[WebFrame _elementForEvent:]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - do all the stuff that setting the referrer should
+
+ * Loader/WebFrameLoader.m:
+ (setHTTPReferrer):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-10-09 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Fix to elminate WebIconDatabaseBridge.h from WebFrameLoader
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _notifyIconChanged:]):
+ * WebCoreSupport/WebIconDatabaseBridge.m:
+ (+[WebIconDatabaseBridge createInstance]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ (Was reviewed as part of a larger patch but it looks like Darin already did the rest of it)
+
+ - avoid a needless use of WebFrame
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadDocumentLoader:withLoadType:formState:]):
+
+2006-10-09 Brady Eidson <beidson@apple.com>
+
+ A *real* fake fix for the layouttest problem until the real fix
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _notifyIconChanged:]):
+
+2006-10-09 Brady Eidson <beidson@apple.com>
+
+ Quick layouttest fix until I make the real fix
+
+ * Loader/WebFrameLoader.m:
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - wean WebFrameLoader from WebDataSource private stuff
+
+ (actually just tweaks tot he above to make merging my future
+ patches easier since Darin did a lot of the same stuff)
+
+ * Loader/WebDocumentLoader.h:
+ * Loader/WebDocumentLoader.m:
+ (-[WebDocumentLoader URLForHistory]):
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader revertToProvisionalWithDocumentLoader:]):
+ (-[WebFrameLoader documentLoader:setMainDocumentError:]):
+ (-[WebFrameLoader finalSetupForReplaceWithDocumentLoader:]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ (-[WebFrameLoader loadDocumentLoader:withLoadType:formState:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _URLForHistory]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _addDocumentLoader:toUnarchiveState:]):
+ (-[WebFrame _revertToProvisionalStateForDocumentLoader:]):
+ (-[WebFrame _setMainDocumentError:forDocumentLoader:]):
+ (-[WebFrame _clearUnarchivingStateForLoader:]):
+
+2006-10-09 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - eliminated WebFrameLoader dependency on WebDataSourceInternal.h,
+ WebIconDatabasePrivate.h, and WebKitErrorsPrivate.h, along with
+ most but not all references to WebView
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader _notifyIconChanged:]):
+ (-[WebFrameLoader cancelledErrorWithRequest:]):
+ (-[WebFrameLoader fileDoesNotExistErrorWithResponse:]):
+ (-[WebFrameLoader handleUnimplementablePolicyWithError:]):
+ (-[WebFrameLoader cannotShowMIMETypeWithResponse:]):
+ (-[WebFrameLoader interruptForPolicyChangeErrorWithRequest:]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader finishedLoadingDocument:]):
+ (-[WebFrameLoader committedLoadWithDocumentLoader:data:]):
+ (-[WebFrameLoader revertToProvisionalWithDocumentLoader:]):
+ (-[WebFrameLoader documentLoader:setMainDocumentError:]):
+ (-[WebFrameLoader finalSetupForReplaceWithDocumentLoader:]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ (-[WebFrameLoader continueAfterNavigationPolicy:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader loadDocumentLoader:withLoadType:formState:]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ (-[WebFrameLoader requestFromDelegateForRequest:identifier:error:]):
+ (-[WebFrameLoader addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ (-[WebFrameLoader checkLoadComplete]):
+ * Loader/WebFrameLoaderClient.h:
+ * Loader/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _addDocumentLoader:toUnarchiveState:]):
+ (-[WebFrame _formDelegate]):
+ (-[WebFrame _finishedLoadingDocument:]):
+ (-[WebFrame _committedLoadWithDocumentLoader:data:]):
+ (-[WebFrame _revertToProvisionalWithDocumentLoader:]):
+ (-[WebFrame _documentLoader:setMainDocumentError:]):
+ (-[WebFrame _finalSetupForReplaceWithDocumentLoader:]):
+ (-[WebFrame _URLForHistoryForDocumentLoader:]):
+ (-[WebFrame _cancelledErrorWithRequest:]):
+ (-[WebFrame _cannotShowURLErrorWithRequest:]):
+ (-[WebFrame _interruptForPolicyChangeErrorWithRequest:]):
+ (-[WebFrame _cannotShowMIMETypeErrorWithResponse:]):
+ (-[WebFrame _fileDoesNotExistErrorWithResponse:]):
+ (-[WebFrame _shouldFallBackForError:]):
+ (-[WebFrame _hasWebView]):
+ (-[WebFrame _mainFrameURL]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed, landed, tweaked a bit by Darin.
+
+ - removed most uses of WebFrameBridge from WebFrameLoader
+ (WebCoreFrameBridge use is OK)
+
+ * Loader/WebDocumentLoader.m:
+ (-[WebDocumentLoader bridge]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader initWithFrame:client:]):
+ (-[WebFrameLoader defersCallbacksChanged]):
+ (-[WebFrameLoader defersCallbacks]):
+ (-[WebFrameLoader provisionalLoadStarted]):
+ (-[WebFrameLoader stopLoadingSubframes]):
+ (-[WebFrameLoader _willSendRequest:forResource:redirectResponse:]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader closeOldDataSources]):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (-[WebFrameLoader bridge]):
+ (-[WebFrameLoader _handleFallbackContent]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:documentLoader:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ (-[WebFrameLoader loadRequest:inFrameNamed:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader detachFromParent]):
+ (-[WebFrameLoader addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ (-[WebFrameLoader safeLoadURL:]):
+ (-[WebFrameLoader actionInformationForLoadType:isFormSubmission:event:originalURL:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _atMostOneFrameHasSelection]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-09 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - removed almost all direct use of WebView from WebFrameLoader
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader defersCallbacksChanged]):
+ (-[WebFrameLoader defersCallbacks]):
+ (-[WebFrameLoader clearProvisionalLoad]):
+ (-[WebFrameLoader _willSendRequest:forResource:redirectResponse:]):
+ (-[WebFrameLoader _didReceiveResponse:forResource:]):
+ (-[WebFrameLoader _didReceiveData:contentLength:forResource:]):
+ (-[WebFrameLoader _didFinishLoadingForResource:]):
+ (-[WebFrameLoader _didFailLoadingWithError:forResource:]):
+ (-[WebFrameLoader closeOldDataSources]):
+ (-[WebFrameLoader _notifyIconChanged:]):
+ (-[WebFrameLoader prepareForLoadStart]):
+ (-[WebFrameLoader willChangeTitleForDocument:]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ (-[WebFrameLoader continueAfterNewWindowPolicy:]):
+ (-[WebFrameLoader continueAfterNavigationPolicy:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader didFirstLayout]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ (-[WebFrameLoader addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.m:
+ (-[WebFrame _currentBackForwardListItemToResetTo]):
+ (-[WebFrame _hasBackForwardList]):
+ (-[WebFrame _resetBackForwardList]):
+ (-[WebFrame _dispatchDidReceiveIcon:]):
+ (-[WebFrame _dispatchDidStartProvisionalLoadForFrame]):
+ (-[WebFrame _dispatchDidCommitLoadForFrame]):
+ (-[WebFrame _dispatchDidFailProvisionalLoadWithError:]):
+ (-[WebFrame _dispatchDidFailLoadWithError:]):
+ (-[WebFrame _dispatchDidFinishLoadForFrame]):
+ (-[WebFrame _progressStarted]):
+ (-[WebFrame _progressCompleted]):
+ (-[WebFrame _incrementProgressForIdentifier:response:]):
+ (-[WebFrame _incrementProgressForIdentifier:data:]):
+ (-[WebFrame _completeProgressForIdentifier:]):
+ (-[WebFrame _setMainFrameDocumentReady:]):
+ (-[WebFrame _willChangeTitleForDocument:]):
+ (-[WebFrame _didChangeTitleForDocument:]):
+ (-[WebFrame _startDownloadWithRequest:]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Alice.
+
+ - moved WebFormState into Loader directory and tweaked to avoid WebKit dependencies
+
+ * Loader/WebDocumentLoader.h:
+ * Loader/WebFormState.h: Added.
+ * Loader/WebFormState.m: Added.
+ (-[WebFormState initWithForm:values:sourceFrame:]):
+ (-[WebFormState dealloc]):
+ (-[WebFormState form]):
+ (-[WebFormState values]):
+ (-[WebFormState sourceFrame]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrame.m:
+ * WebView/WebFrameInternal.h:
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - remove dependency on WebNSURLRequestExtras.h
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - removed unneeded logging code so I can take WebKitLogging.h out and remove a WebKit dependency
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader setState:]):
+ (-[WebFrameLoader clientRedirectCancelledOrFinished:]):
+ (-[WebFrameLoader clientRedirectedTo:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Oliver.
+
+ - remove WebDataSource from the WebFrameLoader interface (and thereby from a lot of internal use)
+
+ * Loader/WebDocumentLoader.h:
+ * Loader/WebDocumentLoader.m:
+ (-[WebDocumentLoader dealloc]):
+ (-[WebDocumentLoader initialRequest]):
+ (-[WebDocumentLoader URL]):
+ (-[WebDocumentLoader unreachableURL]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader setState:]):
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader startProvisionalLoad:]):
+ (-[WebFrameLoader clientRedirectedTo:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader opened]):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (-[WebFrameLoader initialRequest]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader _notifyIconChanged:]):
+ (-[WebFrameLoader _URL]):
+ (-[WebFrameLoader willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrameLoader _checkNavigationPolicyForRequest:andCall:withSelector:]):
+ (-[WebFrameLoader shouldReloadToHandleUnreachableURLFromRequest:]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:documentLoader:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader loadDocumentLoader:withLoadType:formState:]):
+ (-[WebFrameLoader frameLoadCompleted]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ (-[WebFrameLoader safeLoadURL:]):
+ * Loader/WebFrameLoaderClient.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView loadRequest:inTarget:withNotifyData:sendNotification:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge originalRequestURL]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _URL]):
+ (-[WebDataSource dealloc]):
+ (-[WebDataSource initialRequest]):
+ (-[WebDataSource unreachableURL]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame provisionalDataSource]):
+ (-[WebFrame dataSource]):
+ (-[WebFrame _makeDocumentView]):
+ (-[WebFrame _updateHistoryForReload]):
+ (-[WebFrame _updateHistoryForStandardLoad]):
+ (-[WebFrame _updateHistoryForInternalLoad]):
+ (-[WebFrame _forceLayoutForNonHTML]):
+ (-[WebFrame _clearLoadingFromPageCacheForDocumentLoader:]):
+ (-[WebFrame _isDocumentLoaderLoadingFromPageCache:]):
+ (-[WebFrame _archivedSubresourceForURL:fromDocumentLoader:]):
+ (-[WebFrame _makeRepresentationForDocumentLoader:]):
+
+2006-10-09 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - removed need for WebFrameLoader to now about WebDocumentLoaderMac
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadDataSource:withLoadType:formState:]):
+ * WebView/WebDocumentLoaderMac.h:
+ * WebView/WebDocumentLoaderMac.m:
+ (-[WebDocumentLoaderMac setFrameLoader:]):
+ (-[WebDocumentLoaderMac detachFromFrameLoader]):
+
+2006-10-09 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - passed calls that require WebScriptDebugServer across the client interface
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader documentLoader:mainReceivedCompleteError:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _dispatchDidLoadMainResourceForDocumentLoader:]):
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - passed calls that require WebHTMLView or WebFrameView calls across
+ the client interface
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (isCaseInsensitiveEqual):
+ (isBackForwardLoadType):
+ (-[WebFrameLoader opened]):
+ (-[WebFrameLoader cancelledErrorWithRequest:]):
+ (-[WebFrameLoader fileDoesNotExistErrorWithResponse:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _forceLayout]):
+ (-[WebFrame _setDocumentViewFromPageCache:]):
+ (-[WebFrame _setCopiesOnScroll]):
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - pass remaining delegate methods across client interface
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _checkContentPolicyForMIMEType:andCall:withSelector:]):
+ (-[WebFrameLoader checkNewWindowPolicyForRequest:action:frameName:formState:andCall:withSelector:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ (-[WebFrameLoader handleUnimplementablePolicyWithErrorCode:forURL:]):
+ (-[WebFrameLoader didFirstLayout]):
+ (-[WebFrameLoader continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _dispatchDidFirstLayoutInFrame]):
+ (-[WebFrame _dispatchCreateWebViewWithRequest:]):
+ (-[WebFrame _dispatchShow]):
+ (-[WebFrame _dispatchDecidePolicyForMIMEType:request:decisionListener:]):
+ (-[WebFrame _dispatchDecidePolicyForNewWindowAction:request:newFrameName:decisionListener:]):
+ (-[WebFrame _dispatchDecidePolicyForNavigationAction:request:decisionListener:]):
+ (-[WebFrame _dispatchUnableToImplementPolicyWithError:]):
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - use WebCoreSystemInterface instead of WebSystemInterface in Loader directory
+
+ * Loader/WebFrameLoader.m: Update includes.
+ (-[WebFrameLoader commitProvisionalLoad:]): Use wk calls istead of WK.
+ (-[WebFrameLoader _canUseResourceWithResponse:]): Ditto.
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface):
+ Added the three new symbols, and resorted the list.
+
+ * Loader/WebDataProtocol.m:
+ * Loader/WebLoader.m:
+ * Loader/WebMainResourceLoader.h:
+ * Loader/WebMainResourceLoader.m:
+ * Loader/WebNetscapePlugInStreamLoader.h:
+ * Loader/WebNetscapePlugInStreamLoader.m:
+ * Loader/WebSubresourceLoader.h:
+ * Loader/WebSubresourceLoader.m:
+ Changed import statements to consistently use the "" format.
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed.
+
+ - fix accidental build break due to editing while committing
+
+ * Loader/WebFrameLoader.m:
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - move all WebFrameLoadDelegate methods across client interface
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader clientRedirectCancelledOrFinished:]):
+ (-[WebFrameLoader clientRedirectedTo:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameLoader continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader closeOldDataSources]):
+ (-[WebFrameLoader _notifyIconChanged:]):
+ (-[WebFrameLoader prepareForLoadStart]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _dispatchDidCancelClientRedirectForFrame]):
+ (-[WebFrame _dispatchWillPerformClientRedirectToURL:delay:fireDate:]):
+ (-[WebFrame _dispatchDidChangeLocationWithinPageForFrame]):
+ (-[WebFrame _dispatchWillCloseFrame]):
+ (-[WebFrame _dispatchDidReceiveIcon:]):
+ (-[WebFrame _dispatchDidStartProvisionalLoadForFrame]):
+ (-[WebFrame _dispatchDidReceiveTitle:]):
+ (-[WebFrame _dispatchDidCommitLoadForFrame]):
+ (-[WebFrame _dispatchDidFailProvisionalLoadWithError:]):
+ (-[WebFrame _dispatchDidFailLoadWithError:]):
+ (-[WebFrame _dispatchDidFinishLoadForFrame]):
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - removed some of the WebKit dependencies in WebFrameLoader
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader _downloadWithLoadingConnection:request:response:proxy:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _setTitle:forURL:]):
+ (-[WebFrame _downloadWithLoadingConnection:request:response:proxy:]):
+ * WebView/WebFrameInternal.h:
+
+ - some other tweaks
+
+ * Misc/WebNSURLRequestExtras.m:
+ (-[NSMutableURLRequest _web_setHTTPReferrer:]):
+ (-[NSMutableURLRequest _web_setHTTPUserAgent:]):
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - pass all WebResourceLoadDelegate methods across client, removing need to include related headers
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _willSendRequest:forResource:redirectResponse:]):
+ (-[WebFrameLoader _didReceiveAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didCancelAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didReceiveResponse:forResource:]):
+ (-[WebFrameLoader _didReceiveData:contentLength:forResource:]):
+ (-[WebFrameLoader _didFinishLoadingForResource:]):
+ (-[WebFrameLoader _didFailLoadingWithError:forResource:]):
+ (-[WebFrameLoader sendRemainingDelegateMessagesWithIdentifier:response:length:error:]):
+ (-[WebFrameLoader requestFromDelegateForRequest:identifier:error:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _dispatchDidHandleOnloadEventsForFrame]):
+ (-[WebFrame _dispatchDidReceiveServerRedirectForProvisionalLoadForFrame]):
+ (-[WebFrame _dispatchIdentifierForInitialRequest:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:willSendRequest:redirectResponse:fromDocumentLoader:]):
+ (-[WebFrame _dispatchDidReceiveAuthenticationChallenge:forResource:fromDocumentLoader:]):
+ (-[WebFrame _dispatchDidCancelAuthenticationChallenge:forResource:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didReceiveResponse:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didReceiveContentLength:fromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didFinishLoadingFromDocumentLoader:]):
+ (-[WebFrame _dispatchResource:didFailLoadingWithError:fromDocumentLoader:]):
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - started adding some _dispatch methods to WebFrameLoaderClient for delegate dispatch
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader didReceiveServerRedirectForProvisionalLoadForFrame]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge handledOnloadEvents]):
+ * WebView/WebFrame.m:
+ (dataSource):
+ (-[WebFrame _dataSourceForDocumentLoader:]):
+ (-[WebFrame _dispatchDidHandleOnloadEventsForFrame]):
+ (-[WebFrame _dispatchDidReceiveServerRedirectForProvisionalLoadForFrame]):
+ (-[WebFrame _dispatchIdentifierForInitialRequest:fromDocumentLoader:]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - moved more methods to WebFrameLoader from WebFrame
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader defersCallbacksChanged]):
+ (-[WebFrameLoader startLoadingMainResourceWithRequest:identifier:]):
+ (-[WebFrameLoader setState:]):
+ (-[WebFrameLoader clearProvisionalLoad]):
+ (-[WebFrameLoader markLoadComplete]):
+ (-[WebFrameLoader commitProvisionalLoad]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader startProvisionalLoad:]):
+ (-[WebFrameLoader setupForReplace]):
+ (-[WebFrameLoader _identifierForInitialRequest:]):
+ (-[WebFrameLoader _finishedLoadingResource]):
+ (-[WebFrameLoader _receivedError:]):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader opened]):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader documentLoader:mainReceivedCompleteError:]):
+ (-[WebFrameLoader subframeIsLoading]):
+ (-[WebFrameLoader checkNewWindowPolicyForRequest:action:frameName:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueAfterNewWindowPolicy:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ (-[WebFrameLoader sendRemainingDelegateMessagesWithIdentifier:response:length:error:]):
+ (-[WebFrameLoader loadRequest:inFrameNamed:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader detachChildren]):
+ (-[WebFrameLoader detachFromParent]):
+ (-[WebFrameLoader addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ (-[WebFrameLoader safeLoadURL:]):
+ (-[WebFrameLoader actionInformationForLoadType:isFormSubmission:event:originalURL:]):
+ (-[WebFrameLoader actionInformationForNavigationType:event:originalURL:]):
+ (-[WebFrameLoader checkLoadComplete]):
+ * Loader/WebFrameLoaderClient.h:
+ * Loader/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge close]):
+ (-[WebFrameBridge tokenizerProcessedData]):
+ (-[WebFrameBridge frameDetached]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame _detachedFromParent1]):
+ (-[WebFrame _detachedFromParent2]):
+ (-[WebFrame _detachedFromParent3]):
+ (-[WebFrame _detachedFromParent4]):
+ (-[WebFrame _updateHistoryAfterClientRedirect]):
+ (-[WebFrame _loadedFromPageCache]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebPDFView.m:
+ (-[WebPDFView PDFViewWillClickOnLink:withURL:]):
+ * WebView/WebView.m:
+ (-[WebView _close]):
+ (-[WebView setDefersCallbacks:]):
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - avoid need for WebKitSystemInterface in loader code, via WebCore cover for wkSupportsMultipartXMixedReplace
+
+ * Loader/WebDocumentLoader.m:
+ (-[WebDocumentLoader initWithRequest:]):
+ * Loader/WebMainResourceLoader.m:
+ * Loader/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]):
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _initWithDocumentLoader:]):
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ - build fix (also a fix for a crasher I forgot to commit before)
+
+ * Loader/WebFrameLoader.m: Added some missing includes.
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ Added a needed retain/release.
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - quick fix to loader problem causing layout test failures
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _finishedLoading]): Use a local variable for the bridge
+ that we retain/release.
+ (-[WebFrameLoader continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ Same here.
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adam.
+
+ - removed a few includes from WebFrameLoader, fixed up as appropriate
+ - segregated header includes into ones that need to go away to move the code and ones that don't
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _privateBrowsingEnabled]):
+ (-[WebFrameLoader willUseArchiveForRequest:originalURL:loader:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _privateBrowsingEnabled]):
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - moved a few methods from WebFrame to WebFrameLoader
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader stopLoadingSubframes]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader closeOldDataSources]):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (-[WebFrameLoader _finishedLoading]):
+ (isBackForwardLoadType):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader didFirstLayout]):
+ (-[WebFrameLoader frameLoadCompleted]):
+ (-[WebFrameLoader transitionToCommitted:]):
+ (-[WebFrameLoader checkLoadCompleteForThisFrame]):
+ (-[WebFrameLoader continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ (-[WebFrameLoader sendRemainingDelegateMessagesWithIdentifier:response:length:error:]):
+ (-[WebFrameLoader requestFromDelegateForRequest:identifier:error:]):
+ (-[WebFrameLoader loadRequest:inFrameNamed:]):
+ (-[WebFrameLoader postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ * Loader/WebFrameLoaderClient.h:
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController webPlugInContainerLoadRequest:inFrame:]):
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ (-[WebFrameBridge dealloc]):
+ (-[WebFrameBridge frameLoader]):
+ (-[WebFrameBridge setTitle:]):
+ (-[WebFrameBridge receivedData:textEncodingName:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:postData:]):
+ (-[WebFrameBridge objectLoadedFromCacheWithURL:response:data:]):
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ (-[WebFrameBridge reportClientRedirectToURL:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameBridge reportClientRedirectCancelled:]):
+ (-[WebFrameBridge loadURL:referrer:reload:userGesture:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge didFirstLayout]):
+ (-[WebFrameBridge notifyIconChanged:]):
+ (-[WebFrameBridge originalRequestURL]):
+ (-[WebFrameBridge isLoadTypeReload]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _opened]):
+ (-[WebFrame _checkLoadComplete]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _actionInformationForLoadType:isFormSubmission:event:originalURL:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _currentBackForwardListItemToResetTo]):
+ (-[WebFrame _updateBackground]):
+ (-[WebFrame _frameLoader]):
+ (-[WebFrame _frameLoadCompleted]):
+ (-[WebFrame _makeDocumentView]):
+ (-[WebFrame _updateHistoryForCommit]):
+ (-[WebFrame _updateHistoryForReload]):
+ (-[WebFrame _updateHistoryForStandardLoad]):
+ (-[WebFrame _updateHistoryForBackForwardNavigation]):
+ (-[WebFrame _updateHistoryForInternalLoad]):
+ (-[WebFrame _tokenForLoadErrorReset]):
+ (-[WebFrame _resetAfterLoadError:]):
+ (-[WebFrame _doNotResetAfterLoadError:]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-09 Mark Rowe <bdash@webkit.org>
+
+ Rubber-stamped by Darin.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge imageTitleForFilename:size:]): Revert accidental change to a UI_STRING that
+ is triggering an assertion failure.
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - remove unneeded non-Loader header includes from WebFrameLoader.h (split WebFrameLoadType into
+ two coincidentally matching enums)
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (isBackForwardLoadType):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader isReplacing]):
+ (-[WebFrameLoader setReplacing]):
+ (-[WebFrameLoader loadType]):
+ (-[WebFrameLoader setLoadType:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader loadDataSource:withLoadType:formState:]):
+ (-[WebFrameLoader didFirstLayout]):
+ * WebCoreSupport/WebFrameBridge.m:
+ * WebView/WebFrame.m:
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame _opened]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _recursiveGoToItem:fromItem:withLoadType:]):
+ (-[WebFrame _goToItem:withLoadType:]):
+ (-[WebFrame _actionInformationForLoadType:isFormSubmission:event:originalURL:]):
+ (-[WebFrame _continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrame _currentBackForwardListItemToResetTo]):
+ (-[WebFrame _itemForRestoringDocState]):
+ (-[WebFrame _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ (-[WebFrame _loadType]):
+ (-[WebFrame loadRequest:]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebView.m:
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - move WebFrameLoader creation and ownership from WebFrame to WebFrameBridge
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader stopLoadingSubframes]):
+ (-[WebFrameLoader closeOldDataSources]):
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]):
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ (-[WebFrameBridge dealloc]):
+ (-[WebFrameBridge loader]):
+ (-[WebFrameBridge setTitle:]):
+ (-[WebFrameBridge receivedData:textEncodingName:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:postData:]):
+ (-[WebFrameBridge reportClientRedirectToURL:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameBridge reportClientRedirectCancelled:]):
+ (-[WebFrameBridge loadURL:referrer:reload:userGesture:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge didFirstLayout]):
+ (-[WebFrameBridge imageTitleForFilename:size:]):
+ (-[WebFrameBridge notifyIconChanged:]):
+ (-[WebFrameBridge originalRequestURL]):
+ (-[WebFrameBridge isLoadTypeReload]):
+ * WebView/WebFrame.m:
+ (-[NSView setWebFrame::]):
+ (-[WebFramePrivate dealloc]):
+ (-[WebFramePrivate setWebFrameView:]):
+ (-[WebFramePrivate setProvisionalItem:]):
+ (-[WebFrame _webDataRequestForData:MIMEType:textEncodingName:baseURL:unreachableURL:]):
+ (-[WebFrame _createItem:]):
+ (-[WebFrame _createItemTreeWithTargetFrame:clippedAtTarget:]):
+ (-[WebFrame _detachFromParent]):
+ (-[WebFrame _makeDocumentView]):
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame _opened]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _recursiveGoToItem:fromItem:withLoadType:]):
+ (-[WebFrame _continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrame _setTitle:]):
+ (-[WebFrame _defersCallbacksChanged]):
+ (-[WebFrame _currentBackForwardListItemToResetTo]):
+ (-[WebFrame _itemForSavingDocState]):
+ (-[WebFrame _itemForRestoringDocState]):
+ (-[WebFrame _saveDocumentAndScrollState]):
+ (-[WebFrame _shouldTreatURLAsSameAsCurrent:]):
+ (-[WebFrame _loadRequest:inFrameNamed:]):
+ (-[WebFrame _initWithWebFrameView:webView:bridge:]):
+ (-[WebFrame _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ (-[WebFrame _frameLoader]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame _restoreScrollPositionAndViewState]):
+ (-[WebFrame _firstLayoutDone]):
+ (-[WebFrame _loadType]):
+ (-[WebFrame frameView]):
+ (-[WebFrame provisionalDataSource]):
+ (-[WebFrame dataSource]):
+ (-[WebFrame loadRequest:]):
+ (-[WebFrame loadArchive:]):
+ (-[WebFrame stopLoading]):
+ (-[WebFrame reload]):
+ (-[WebFrame _resetBackForwardList]):
+ (-[WebFrame _invalidateCurrentItemPageCache]):
+ (-[WebFrame _provisionalItemIsTarget]):
+ (-[WebFrame _loadProvisionalItemFromPageCache]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - move remaining movable data fields from WebFrameLoader to WebFrame
+
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState commitIfReady]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader provisionalLoadStarted]):
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader stopLoadingSubframes]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader clientRedirectCancelledOrFinished:]):
+ (-[WebFrameLoader clientRedirectedTo:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameLoader shouldReloadForCurrent:andDestination:]):
+ (-[WebFrameLoader loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameLoader continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader closeOldDataSources]):
+ (-[WebFrameLoader commitProvisionalLoad:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader isQuickRedirectComing]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge frameLoader]):
+ (-[WebFrameBridge setTitle:]):
+ (-[WebFrameBridge reportClientRedirectToURL:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ (-[WebFrameBridge reportClientRedirectCancelled:]):
+ (-[WebFrameBridge loadURL:referrer:reload:userGesture:target:triggeringEvent:form:formValues:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _loadFromPageCache:]):
+ * WebView/WebFrame.m:
+ (-[NSView setWebFrame::]):
+ (-[WebFrame _addHistoryItemForFragmentScroll]):
+ (-[WebFrame _didFinishLoad]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _frameLoadCompleted]):
+ (-[WebFrame stopLoading]):
+ (-[WebFrame _invalidateCurrentItemPageCache]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Rubber stamped by Maciej.
+
+ - changed "document load state" to "document loader"
+
+ * Loader/WebDocumentLoadState.h: Removed.
+ * Loader/WebDocumentLoadState.m: Removed.
+ * Loader/WebDocumentLoader.h: Added.
+ * Loader/WebDocumentLoader.m: Added.
+ (-[WebDocumentLoader setMainDocumentError:]):
+ (-[WebDocumentLoader mainReceivedError:complete:]):
+ (-[WebDocumentLoader finishedLoading]):
+ (-[WebDocumentLoader commitLoadWithData:]):
+ (-[WebDocumentLoader setupForReplaceByMIMEType:]):
+ (-[WebDocumentLoader updateLoading]):
+ (-[WebDocumentLoader setTitle:]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader dealloc]):
+ (-[WebFrameLoader activeDocumentLoader]):
+ (-[WebFrameLoader activeDataSource]):
+ (-[WebFrameLoader addPlugInStreamLoader:]):
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader removeSubresourceLoader:]):
+ (-[WebFrameLoader dataSource]):
+ (-[WebFrameLoader setDocumentLoader:]):
+ (-[WebFrameLoader documentLoader]):
+ (-[WebFrameLoader policyDataSource]):
+ (-[WebFrameLoader setPolicyDocumentLoader:]):
+ (-[WebFrameLoader clearDataSource]):
+ (-[WebFrameLoader provisionalDataSource]):
+ (-[WebFrameLoader provisionalDocumentLoader]):
+ (-[WebFrameLoader setProvisionalDocumentLoader:]):
+ (-[WebFrameLoader _clearProvisionalDataSource]):
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader clearProvisionalLoad]):
+ (-[WebFrameLoader commitProvisionalLoad]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader startProvisionalLoad:]):
+ (-[WebFrameLoader setupForReplace]):
+ (-[WebFrameLoader _didReceiveResponse:forResource:]):
+ (-[WebFrameLoader _originalRequest]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader _receivedData:]):
+ (-[WebFrameLoader _setRequest:]):
+ (-[WebFrameLoader _isStopping]):
+ (-[WebFrameLoader _setupForReplaceByMIMEType:]):
+ (-[WebFrameLoader _setResponse:]):
+ (-[WebFrameLoader _mainReceivedError:complete:]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader _checkContentPolicyForMIMEType:andCall:withSelector:]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader finishedLoadingDocument:]):
+ (-[WebFrameLoader committedLoadWithDocumentLoader:data:]):
+ (-[WebFrameLoader revertToProvisionalWithDocumentLoader:]):
+ (-[WebFrameLoader documentLoader:setMainDocumentError:]):
+ (-[WebFrameLoader documentLoader:mainReceivedCompleteError:]):
+ (-[WebFrameLoader finalSetupForReplaceWithDocumentLoader:]):
+ (-[WebFrameLoader willChangeTitleForDocument:]):
+ (-[WebFrameLoader didChangeTitleForDocument:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader loadDataSource:withLoadType:formState:]):
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController pluginView:receivedResponse:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge setTitle:]):
+ (-[WebFrameBridge receivedData:textEncodingName:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _mainDocumentError]):
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource _bridge]):
+ (-[WebDataSource _webView]):
+ (-[WebDataSource _URLForHistory]):
+ (-[WebDataSource _documentLoader]):
+ (-[WebDataSource _initWithDocumentLoader:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource dealloc]):
+ (-[WebDataSource data]):
+ (-[WebDataSource webFrame]):
+ (-[WebDataSource initialRequest]):
+ (-[WebDataSource request]):
+ (-[WebDataSource response]):
+ (-[WebDataSource textEncodingName]):
+ (-[WebDataSource isLoading]):
+ (-[WebDataSource unreachableURL]):
+ (-[WebDataSource webArchive]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebDocumentLoadStateMac.h: Removed.
+ * WebView/WebDocumentLoadStateMac.m: Removed.
+ * WebView/WebDocumentLoaderMac.h: Added.
+ * WebView/WebDocumentLoaderMac.m: Added.
+ * WebView/WebFrame.m:
+ (-[WebFrame _createItem:]):
+ (-[WebFrame _receivedMainResourceError:]):
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _opened]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrame _addChild:]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame _dataSourceForDocumentLoader:]):
+ (-[WebFrame _createDocumentLoaderWithRequest:]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation title]):
+ * WebView/WebView.m:
+ (-[WebView _mainFrameOverrideEncoding]):
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Mitz.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=11218
+ REGRESSION: Assertion failure in WebFrameLoader when going back from a file: or data: URL
+
+ Also added a helper function in WebFrameLoader so that checks for back/forward load types
+ are easier to read.
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setPolicyDocumentLoadState:]): Fixed line of code that was setting the load
+ state to nil instead of the passed-in object.
+ (isBackForwardLoadType): Added.
+ (-[WebFrameLoader shouldReloadToHandleUnreachableURLFromRequest:]): Use isBackForwardLoadType.
+ (-[WebFrameLoader checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ Ditto.
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]): Ditto.
+
+2006-10-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - fix two recently introduced leaks: one of an NSString, the other of a WebDataSource
+
+ * Loader/WebDocumentLoadState.m: (-[WebDocumentLoadState setTitle:]):
+ Rearranged code to avoid storage leak in case of identical title.
+
+ * Loader/WebFrameLoader.h: Removed _setPolicyDocumentLoadState: method
+ from the header.
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setPolicyDocumentLoadState:]): Added logic to call detachFromFrameLoader
+ as needed if this load state is going away rather than moving on to become the provisional
+ load state.
+ (-[WebFrameLoader shouldReloadToHandleUnreachableURLFromRequest:]): Tweaked formatting.
+ (-[WebFrameLoader _loadRequest:archive:]): Added an assertion.
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]): Added an assertion.
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]): Added an assertion.
+ (-[WebFrameLoader reload]): Added an assertion.
+ (-[WebFrameLoader loadDataSource:withLoadType:formState:]): Added a local variable to avoid
+ calling _documentLoadState over and over again.
+
+2006-10-07 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed/landed by Adam.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11199
+ Update Session History when a load is committed rather than completed.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::receivedResponse):
+ (WebFrame::receivedAllData):
+
+2006-10-07 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=11198
+ Auto-generate a few more Objective-C DOM interfaces
+
+ * MigrateHeaders.make:
+
+2006-10-07 Mark Rowe <bdash@webkit.org>
+
+ Reviewed by Mitz.
+
+ Fix memory leak from -[WebDocumentLoadState setTitle:].
+
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState setTitle:]): Ensure 'trimmed' is released even when length is
+ zero, and untangle the confusing logic around this case.
+
+2006-10-06 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ Refactored a whole bunch of WebFramePrivate.h SPI to WebFrameInternal
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ * History/WebHistoryItem.m:
+ * Loader/WebFrameLoader.h:
+ * Misc/WebCoreStatistics.m:
+ * Misc/WebElementDictionary.m:
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ * Plugins/WebPluginController.m:
+ * WebCoreSupport/WebViewFactory.m:
+ * WebView/WebArchiver.m:
+ * WebView/WebDataSource.m:
+ * WebView/WebFrame.m:
+ (-[WebFrame _isDescendantOfFrame:]):
+ (-[WebFrame _setShouldCreateRenderers:]):
+ (-[WebFrame _bodyBackgroundColor]):
+ (-[WebFrame _isFrameSet]):
+ (-[WebFrame _firstLayoutDone]):
+ (-[WebFrame _loadType]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFramePrivate.h:
+ * WebView/WebHTMLRepresentation.m:
+ * WebView/WebScriptDebugDelegate.m:
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - Move all delegate dispatching code out of WebDataSource.
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader _identifierForInitialRequest:]):
+ (-[WebFrameLoader _willSendRequest:forResource:redirectResponse:]):
+ (-[WebFrameLoader _didReceiveAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didCancelAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didReceiveResponse:forResource:]):
+ (-[WebFrameLoader _didReceiveData:contentLength:forResource:]):
+ (-[WebFrameLoader _didFinishLoadingForResource:]):
+ (-[WebFrameLoader _didFailLoadingWithError:forResource:]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader _downloadWithLoadingConnection:request:response:proxy:]):
+ (-[WebFrameLoader _checkContentPolicyForMIMEType:andCall:withSelector:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setLoadingFromPageCache:]):
+ (-[WebDataSource _stopLoadingWithError:]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-10-06 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - moved firstLayoutDone BOOL from WebFrame to WebFrameLoader
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader didFirstLayout]):
+ (-[WebFrameLoader provisionalLoadStarted]):
+ (-[WebFrameLoader frameLoadCompleted]):
+ (-[WebFrameLoader firstLayoutDone]):
+ * WebCoreSupport/WebFrameBridge.m: (-[WebFrameBridge didFirstLayout]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _firstLayoutDone]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame _frameLoadCompleted]):
+ (-[WebFrame _restoreScrollPositionAndViewState]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-06 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - moved more data and the corresponding code from WebFrame to WebFrameLoader
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader cannotShowMIMETypeForURL:]):
+ (-[WebFrameLoader _checkNavigationPolicyForRequest:andCall:withSelector:]):
+ (-[WebFrameLoader shouldReloadToHandleUnreachableURLFromRequest:]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader invalidatePendingPolicyDecisionCallingDefaultAction:]):
+ (-[WebFrameLoader checkNewWindowPolicyForRequest:action:frameName:formState:andCall:withSelector:]):
+ (-[WebFrameLoader _continueAfterNewWindowPolicy:]):
+ (-[WebFrameLoader checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ (-[WebFrameLoader continueAfterNavigationPolicy:]):
+ (-[WebFrameLoader continueAfterWillSubmitForm:]):
+ (-[WebFrameLoader continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrameLoader loadDataSource:withLoadType:formState:]):
+ (-[WebFrameLoader handleUnimplementablePolicyWithErrorCode:forURL:]):
+ (-[WebFrameLoader delegateIsHandlingProvisionalLoadError]):
+ (-[WebFrameLoader setDelegateIsHandlingProvisionalLoadError:]):
+ * Loader/WebFrameLoaderClient.h:
+ * WebView/WebFrame.m:
+ (-[NSView setWebFrame::]):
+ (-[WebFramePrivate dealloc]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrame _postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrame _loadRequest:inFrameNamed:]):
+ (-[WebFrame stopLoading]):
+ (-[WebFrame _resetBackForwardList]):
+ (-[WebFrame _quickRedirectComing]):
+ (-[WebFrame _provisionalItemIsTarget]):
+ (-[WebFrame _loadProvisionalItemFromPageCache]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFramePrivate.h:
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Rubber stamped by Darin.
+
+ - removed includes of unused headers.
+
+ * WebView/WebDataSource.m:
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed.
+
+ - fix build breakage
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader willChangeTitleForDocumentLoadState:]):
+ (-[WebFrameLoader didChangeTitleForDocumentLoadState:]):
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - move remaining movable WebDataSource fields to WebDocumentLoadState
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState dealloc]):
+ (-[WebDocumentLoadState isLoadingInAPISense]):
+ (-[WebDocumentLoadState addResponse:]):
+ (-[WebDocumentLoadState stopRecordingResponses]):
+ (-[WebDocumentLoadState title]):
+ (-[WebDocumentLoadState setLastCheckedRequest:]):
+ (-[WebDocumentLoadState lastCheckedRequest]):
+ (-[WebDocumentLoadState triggeringAction]):
+ (-[WebDocumentLoadState setTriggeringAction:]):
+ (-[WebDocumentLoadState responses]):
+ (-[WebDocumentLoadState setOverrideEncoding:]):
+ (-[WebDocumentLoadState overrideEncoding]):
+ (-[WebDocumentLoadState setTitle:]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ (-[WebFrameLoader willChangeTitleForDocumentLoadState:]):
+ (-[WebFrameLoader didChangeTitleForDocumentLoadState:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge setTitle:]):
+ (-[WebFrameBridge receivedData:textEncodingName:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _didReceiveResponse:forResource:]):
+ (-[WebDataSource textEncodingName]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _opened]):
+ (-[WebFrame _checkNavigationPolicyForRequest:dataSource:formState:andCall:withSelector:]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrame _addChild:]):
+ (-[WebFrame _loadDataSource:withLoadType:formState:]):
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation title]):
+ * WebView/WebView.m:
+ (-[WebView _mainFrameOverrideEncoding]):
+
+2006-10-06 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - moved loadType into WebFrameLoader
+
+ * WebView/WebFramePrivate.h: Removed _setLoadType, but not _loadType because it's
+ currently used by Safari.
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader isReplacing]):
+ (-[WebFrameLoader setReplacing]):
+ (-[WebFrameLoader loadType]):
+ (-[WebFrameLoader setLoadType:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge isLoadTypeReload]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadType]):
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _commitProvisionalLoad:]):
+ (-[WebFrame _opened]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrame _loadURL:referrer:intoChild:]):
+ (-[WebFrame _currentBackForwardListItemToResetTo]):
+ (-[WebFrame _itemForRestoringDocState]):
+ (-[WebFrame _continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrame _didFirstLayout]):
+ (-[WebFrame _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame loadRequest:]):
+
+2006-10-06 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - added WebFrameLoaderClient protocol -- to be used to make WebFrameLoader forget all about WebFrame
+
+ * Loader/WebDocumentLoadState.h: Added comment about Maciej's planned renaming here.
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m: Renamed webFrame to client and added the new protocol.
+ Eventually we'll be removing the dependency on WebFrame entirely.
+ * WebView/WebFrame.m: (-[WebFrame _initWithWebFrameView:webView:bridge:]): Update to call the method
+ by its new name.
+
+ * Loader/WebFrameLoaderClient.h: Added.
+ * WebKit.xcodeproj/project.pbxproj: Updated for new file, sorted things.
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - segregate WebFrame methods into ones that should be moved into WebFrameLoader and ones that don't need to
+
+ Also removed useless WebFrameLoader part
+
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - moved more data from WebDataSource to WebDocumentLoadState
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState commitLoadWithData:]):
+ (-[WebDocumentLoadState prepareForLoadStart]):
+ (-[WebDocumentLoadState loadingStartedTime]):
+ (-[WebDocumentLoadState setIsClientRedirect:]):
+ (-[WebDocumentLoadState isClientRedirect]):
+ (-[WebDocumentLoadState setPrimaryLoadComplete:]):
+ (-[WebDocumentLoadState isLoadingInAPISense]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader documentLoadState:mainReceivedCompleteError:]):
+ (-[WebFrameLoader prepareForLoadStart]):
+ (-[WebFrameLoader subframeIsLoading]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _fileWrapperForURL:]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource isLoading]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _opened]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+
+2006-10-06 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11183
+ REGRESSION: Safari loads error pages unstyled
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadHTMLString:baseURL:unreachableURL:]):
+ Use utf-8 encoding instead of the string's "fastest" encoding.
+
+2006-10-06 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adam.
+
+ - fixed the following bugs:
+
+ http://bugs.webkit.org/show_bug.cgi?id=11136
+ "REGRESSION: Safari snippet editor doesn't work"
+ http://bugs.webkit.org/show_bug.cgi?id=11140
+ "REGRESSION: view source window blank"
+ http://bugs.webkit.org/show_bug.cgi?id=11146
+ "REGRESSION: Instead of showing the error page, Safari opens its Resources folder in the Finder"
+
+ Possibly more.
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState actualRequest]): New method.
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _startLoading]): We need to make sure not to start loading the main
+ resource with the fake external request for an applewebdata: request.
+
+2006-10-05 Adele Peterson <adele@apple.com>
+
+ Reviewed by the letter 'B'.
+
+ More build fixes.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDynamicScrollBarsView.h:
+ * WebView/WebDynamicScrollBarsView.m:
+ (-[WebDynamicScrollBarsView updateScrollers]):
+ (-[WebDynamicScrollBarsView setAllowsScrolling:]):
+ (-[WebDynamicScrollBarsView allowsScrolling]):
+ (-[WebDynamicScrollBarsView setAllowsHorizontalScrolling:]):
+ (-[WebDynamicScrollBarsView setAllowsVerticalScrolling:]):
+ (-[WebDynamicScrollBarsView allowsHorizontalScrolling]):
+ (-[WebDynamicScrollBarsView allowsVerticalScrolling]):
+ (-[WebDynamicScrollBarsView horizontalScrollingMode]):
+ (-[WebDynamicScrollBarsView verticalScrollingMode]):
+ (-[WebDynamicScrollBarsView setHorizontalScrollingMode:]):
+ (-[WebDynamicScrollBarsView setVerticalScrollingMode:]):
+ (-[WebDynamicScrollBarsView setScrollingMode:]):
+ * WebView/WebView.m:
+ (-[WebView setAlwaysShowVerticalScroller:]):
+ (-[WebView alwaysShowVerticalScroller]):
+ (-[WebView setAlwaysShowHorizontalScroller:]):
+ (-[WebView alwaysShowHorizontalScroller]):
+
+2006-10-05 Vladimir Olexa <vladimir.olexa@gmail.com>
+
+ Reviewed by Timothy.
+
+ Bug: http://bugs.webkit.org/show_bug.cgi?id=9887
+ Continuous spell checking now remembers user's setting. The change is applied globally,
+ meaning, both TextArea and TextField are affected when either of them enables/disables
+ spell checking.
+
+ * WebView/WebPreferenceKeysPrivate.h: added a define for WebContinuousSpellCheckingEnabled
+ * WebView/WebView.m:
+ (-[WebViewPrivate init]): reads WebContinuousSpellCheckingEnabled from NSUserDefaults
+ (-[WebView setContinuousSpellCheckingEnabled:]):
+ (-[WebView isContinuousSpellCheckingEnabled]):
+
+2006-10-05 MorganL <morganl.webkit@yahoo.com>
+
+ Reviewed by Darin.
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=11162
+
+ * COM/WebFrame.cpp:
+ (WebFrame::loadDataSource):
+ (WebFrame::receivedResponse):
+
+2006-10-05 Don Gibson <dgibson77@gmail.com>
+
+ Reviewed by Darin, landed by Adam.
+
+ http://bugs.webkit.org/show_bug.cgi?id=11176
+ Fix win32 build, adapt to Maciej's ResourceLoader changes.
+
+ * COM/WebFrame.cpp:
+ (WebFrame::loadDataSource):
+
+2006-10-05 Marvin Decker <marv.decker@gmail.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=10989
+ Provide a way for embedders to implement BrowserExtensionWin
+
+ * COM/Interfaces/IWebUIDelegate.idl:
+ * COM/WebFrame.cpp:
+ (WebFrame::createNewWindow):
+ * COM/WebFrame.h:
+
+2006-10-04 Mark Rowe <bdash@webkit.org>
+
+ Reviewed by NOBODY (build fix).
+
+ * WebView/WebView.m:
+ (-[WebView scrollDOMRangeToVisible:]): Move scrollDOMRangeToVisible: into the correct category.
+
+2006-09-26 David Smith <catfish.man@gmail.com>
+
+ Reviewed by Timothy.
+
+ http://bugs.webkit.org/show_bug.cgi?id=3723
+ Add -scrollDOMRangeToVisible:
+
+ * WebView/WebView.m:
+ (-[WebView scrollDOMRangeToVisible:]):
+ * WebView/WebViewPrivate.h:
+
+2006-10-03 Graham Dennis <graham.dennis@gmail.com>
+
+ Reviewed by Timothy.
+
+ <http://bugs.webkit.org/show_bug.cgi?id=10338>
+ When contentEditable, cursor doesn't change to hand
+
+ Allow the behaviour of editable links to be specified by a WebPreference
+ The preference WebKitEditableLinkBehavior has four options:
+ - AlwaysLive: Safari 2.0 behaviour
+ - OnlyLiveWithShiftKey: Firefox/WinIE behaviour (and prior WebKit-ToT behaviour)
+ - LiveWhenNotFocused: Editable links are live only when their editable block is not
+ focused, or when the shift key is pressed
+ - DefaultBehavior: This is the same as OnlyLiveWithShiftKey.
+
+ No layout tests, just a modification of a manual-test as it isn't possible to test
+ this automatically.
+
+ * WebView/WebPreferenceKeysPrivate.h:
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+ (-[WebPreferences editableLinkBehavior]):
+ (-[WebPreferences setEditableLinkBehavior:]):
+ * WebView/WebPreferencesPrivate.h:
+ * WebView/WebView.m:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2006-10-03 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by harrison
+
+ execCommand("Cut"/"Copy"/"Paste") broken in editable subframes.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge issueCutCommand]): Issue the command on the WebHTMLView, not the WebView.
+ (-[WebFrameBridge issueCopyCommand]): Ditto.
+ (-[WebFrameBridge issuePasteCommand]): Ditto.
+ (-[WebFrameBridge issuePasteAndMatchStyleCommand]): Ditto.
+ (-[WebFrameBridge issueTransposeCommand]): Fixed formatting.
+ (-[WebFrameBridge canPaste]): Ask the WebHTMLView, not the WebView.
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView copy:]): Moved to WebInternal
+ (-[WebHTMLView cut:]): Ditto.
+ (-[WebHTMLView paste:]): Ditto.
+ (-[WebHTMLView pasteAsPlainText:]): Ditto.
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebView.m: Removed the now unused _canPaste.
+ * WebView/WebViewInternal.h: Ditto.
+
+2006-10-03 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by geoff
+
+ <rdar://problem/4763519> REGRESSION: Multipart/x-mixed-replace sub-resources fail to load
+
+ * Loader/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]):
+ Enable multipart/x-mixed-replace support on the request. This line was accidently removed during
+ some loader refactoring.
+
+2006-10-02 Adam Roben <aroben@apple.com>
+
+ Reviewed by Maciej.
+
+ Add message paramter to WebView::mouse* methods to pass down to
+ PlatformMouseEvent.
+
+ * COM/WebView.cpp:
+ (WebView::mouseMoved):
+ (WebView::mouseDown):
+ (WebView::mouseUp):
+ (WebView::mouseDoubleClick):
+ (WebViewWndProc):
+ * COM/WebView.h:
+
+2006-10-02 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Alice.
+
+ - take away direct knowledge of WebFrame from WebDataSource
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState setFrameLoader:]):
+ (-[WebDocumentLoadState detachFromFrameLoader]):
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setDocumentLoadState:]):
+ (-[WebFrameLoader _setProvisionalDocumentLoadState:]):
+ * WebView/WebDataSource.m:
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebDocumentLoadStateMac.m:
+ (-[WebDocumentLoadStateMac detachFromFrameLoader]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadDataSource:withLoadType:formState:]):
+
+2006-10-02 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - move a big slice of data and logic from WebDataSource to WebDocumentLoadState
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState initWithRequest:]):
+ (-[WebDocumentLoadState dealloc]):
+ (-[WebDocumentLoadState originalRequestCopy]):
+ (-[WebDocumentLoadState request]):
+ (-[WebDocumentLoadState replaceRequestURLForAnchorScrollWithURL:]):
+ (-[WebDocumentLoadState setRequest:]):
+ (-[WebDocumentLoadState setResponse:]):
+ (-[WebDocumentLoadState isStopping]):
+ (-[WebDocumentLoadState bridge]):
+ (-[WebDocumentLoadState setMainDocumentError:]):
+ (-[WebDocumentLoadState mainDocumentError]):
+ (-[WebDocumentLoadState clearErrors]):
+ (-[WebDocumentLoadState mainReceivedError:complete:]):
+ (-[WebDocumentLoadState stopLoading]):
+ (-[WebDocumentLoadState setupForReplace]):
+ (-[WebDocumentLoadState commitIfReady]):
+ (-[WebDocumentLoadState finishedLoading]):
+ (-[WebDocumentLoadState setCommitted:]):
+ (-[WebDocumentLoadState isCommitted]):
+ (-[WebDocumentLoadState setLoading:]):
+ (-[WebDocumentLoadState isLoading]):
+ (-[WebDocumentLoadState commitLoadWithData:]):
+ (-[WebDocumentLoadState doesProgressiveLoadWithMIMEType:]):
+ (-[WebDocumentLoadState receivedData:]):
+ (-[WebDocumentLoadState setupForReplaceByMIMEType:]):
+ (-[WebDocumentLoadState updateLoading]):
+ (-[WebDocumentLoadState response]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader activeDocumentLoadState]):
+ (-[WebFrameLoader activeDataSource]):
+ (-[WebFrameLoader _archivedSubresourceForURL:]):
+ (-[WebFrameLoader addPlugInStreamLoader:]):
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader removeSubresourceLoader:]):
+ (-[WebFrameLoader documentLoadState]):
+ (-[WebFrameLoader provisionalDocumentLoadState]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader _originalRequest]):
+ (-[WebFrameLoader _receivedData:]):
+ (-[WebFrameLoader _setRequest:]):
+ (-[WebFrameLoader bridge]):
+ (-[WebFrameLoader _handleFallbackContent]):
+ (-[WebFrameLoader _isStopping]):
+ (-[WebFrameLoader _setupForReplaceByMIMEType:]):
+ (-[WebFrameLoader _setResponse:]):
+ (-[WebFrameLoader _mainReceivedError:complete:]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader didReceiveServerRedirectForProvisionalLoadForFrame]):
+ (-[WebFrameLoader finishedLoadingDocumentLoadState:]):
+ (-[WebFrameLoader commitProvisitionalLoad]):
+ (-[WebFrameLoader committedLoadWithDocumentLoadState:data:]):
+ (-[WebFrameLoader isReplacing]):
+ (-[WebFrameLoader setReplacing]):
+ (-[WebFrameLoader revertToProvisionalWithDocumentLoadState:]):
+ (-[WebFrameLoader documentLoadState:setMainDocumentError:]):
+ (-[WebFrameLoader documentLoadState:mainReceivedCompleteError:]):
+ (-[WebFrameLoader finalSetupForReplaceWithDocumentLoadState:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _prepareForLoadStart]):
+ (-[WebDataSource _mainDocumentError]):
+ (-[WebDataSource _finishedLoading]):
+ (-[WebDataSource _receivedData:]):
+ (-[WebDataSource _setMainDocumentError:]):
+ (-[WebDataSource _clearUnarchivingState]):
+ (-[WebDataSource _revertToProvisionalState]):
+ (-[WebDataSource _receivedMainResourceError:complete:]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource _bridge]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource _URLForHistory]):
+ (-[WebDataSource _setTitle:]):
+ (-[WebDataSource _initWithDocumentLoadState:]):
+ (-[WebDataSource request]):
+ (-[WebDataSource response]):
+ (-[WebDataSource isLoading]):
+ (-[WebDataSource webArchive]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebDocumentLoadStateMac.m:
+ (-[WebDocumentLoadStateMac initWithRequest:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _createItem:]):
+ (-[WebFrame _receivedMainResourceError:]):
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _commitProvisionalLoad:]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _continueFragmentScrollAfterNavigationPolicy:formState:]):
+ (-[WebFrame _didReceiveServerRedirectForProvisionalLoadForFrame]):
+ (-[WebFrame _provisionalLoadStarted]):
+ * WebView/WebFrameInternal.h:
+
+2006-10-02 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by john
+
+ <rdar://problem/4757583>
+ REGRESSION: tabbing into page focuses wrong control on 2nd pass
+ <rdar://problem/4757594>
+ REGRESSION: Form field is left with secondary selection after tabbing out of WebView
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray maintainsInactiveSelection]): Replace code that I removed in error in the patch
+ for 9642. Only leave inactive editable selections in the WebHTMLView if the nextResponder
+ is in the same WebView.
+
+2006-10-02 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - remove webFrame field from WebDataSourcePrivate, it can get it from WebDocumentLoadState now
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState frameLoader]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _revertToProvisionalState]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ (-[WebDataSource _updateLoading]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _setWebFrame:]):
+ (-[WebDataSource _defersCallbacksChanged]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _webView]):
+ (-[WebDataSource _stopLoadingWithError:]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource dealloc]):
+ (-[WebDataSource webFrame]):
+ (-[WebDataSource isLoading]):
+
+2006-10-02 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - fix crash on back/forward - reattach WebDocumentLoadState to data source when needed
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setWebFrame:]):
+ (-[WebDataSource _initWithDocumentLoadState:]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-10-02 Maciej Stachowiak <mjs@apple.com>
+
+ Build fix, not reviewed.
+
+ - Added missing files to fix build.
+
+ * WebView/WebDocumentLoadStateMac.h: Added.
+ * WebView/WebDocumentLoadStateMac.m: Added.
+ (-[WebDocumentLoadStateMac initWithRequest:]):
+ (-[WebDocumentLoadStateMac dealloc]):
+ (-[WebDocumentLoadStateMac setDataSource:]):
+ (-[WebDocumentLoadStateMac dataSource]):
+ (-[WebDocumentLoadStateMac setFrameLoader:]):
+
+2006-10-01 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady and Oliver.
+
+ - move things around so that WebDataSource and WebDocumentLoadState know about each other in
+ the right way. This lines things up to move nearly all functionality down to WebDocumentLoadState.
+
+ * Loader/WebDocumentLoadState.h:
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState initWithRequest:]):
+ (-[WebDocumentLoadState dealloc]):
+ (-[WebDocumentLoadState originalRequest]):
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader dealloc]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader startLoadingMainResourceWithRequest:identifier:]):
+ (-[WebFrameLoader dataSource]):
+ (-[WebFrameLoader _setDocumentLoadState:]):
+ (-[WebFrameLoader policyDataSource]):
+ (-[WebFrameLoader _setPolicyDocumentLoadState:]):
+ (-[WebFrameLoader clearDataSource]):
+ (-[WebFrameLoader provisionalDataSource]):
+ (-[WebFrameLoader _setProvisionalDocumentLoadState:]):
+ (-[WebFrameLoader _clearProvisionalDataSource]):
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader clearProvisionalLoad]):
+ (-[WebFrameLoader commitProvisionalLoad]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader startProvisionalLoad:]):
+ (-[WebFrameLoader setupForReplace]):
+ (-[WebFrameLoader activeDocumentLoadState]):
+ (-[WebFrameLoader activeDataSource]):
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _setWebFrame:]):
+ (-[WebDataSource _documentLoadState]):
+ (-[WebDataSource _initWithDocumentLoadState:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource initialRequest]):
+ (-[WebDataSource unreachableURL]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+ (-[WebFrame _continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrame _loadDataSource:withLoadType:formState:]):
+ (-[WebFrame _policyDataSource]):
+ (-[WebFrame _shouldReloadToHandleUnreachableURLFromRequest:]):
+ (-[WebFrame _dataSourceForDocumentLoadState:]):
+ (-[WebFrame _createDocumentLoadStateWithRequest:]):
+ * WebView/WebFrameInternal.h:
+
+2006-09-29 David Hyatt <hyatt@apple.com>
+
+ Change the default minimum font size pref to 0 in order to allow
+ font-size:0 to work.
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+
+2006-09-28 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ Switch the inspector over to use border-image with styled buttons and selects.
+
+ * WebInspector/WebInspector.m:
+ (-[NSWindow window]):
+ (-[NSWindow setWebFrame:]):
+ (-[WebInspector _updateRoot]):
+ * WebInspector/webInspector/Images/button.png: Added.
+ * WebInspector/webInspector/Images/buttonDivider.png: Added.
+ * WebInspector/webInspector/Images/buttonPressed.png: Added.
+ * WebInspector/webInspector/Images/popup.png: Added.
+ * WebInspector/webInspector/Images/popupFill.png: Removed.
+ * WebInspector/webInspector/Images/popupFillPressed.png: Removed.
+ * WebInspector/webInspector/Images/popupLeft.png: Removed.
+ * WebInspector/webInspector/Images/popupLeftPressed.png: Removed.
+ * WebInspector/webInspector/Images/popupPressed.png: Added.
+ * WebInspector/webInspector/Images/popupRight.png: Removed.
+ * WebInspector/webInspector/Images/popupRightPressed.png: Removed.
+ * WebInspector/webInspector/Images/squareButtonRight.png: Removed.
+ * WebInspector/webInspector/Images/squareButtonRightPressed.png: Removed.
+ * WebInspector/webInspector/inspector.css:
+ * WebInspector/webInspector/inspector.html:
+ * WebInspector/webInspector/inspector.js:
+
+2006-09-28 Alice Liu <alice.liu@apple.com>
+
+ fixing the windows build
+
+ * COM/WebView.cpp:
+ (WebView::mouseMoved):
+ (WebView::mouseDown):
+ (WebView::mouseUp):
+ (WebView::mouseDoubleClick):
+
+2006-09-27 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by thatcher
+
+ <rdar://problem/4044271>
+ Writing Direction menu doesn't reflect the current writing direction (9773)
+
+ * English.lproj/Localizable.strings: Added "Right to Left" and "Left to Right"
+ * WebView/WebHTMLView.m:
+ (-[NSArray validateUserInterfaceItem:]): Validate menu items that perform
+ toggleBaseWritingDirection and changeBaseWritingDirection.
+ Disable the menu item that changes the writing direction to NSWritingDirectionNautral
+ because NSWritingDirectionNatural's behavior can't be implemented with CSS.
+ Take control of the title of the menu item that performs toggleBaseWritingDirection:
+ instead of checking/unchecking it, otherwise we wouldn't know what a check means.
+ (-[NSArray changeBaseWritingDirection:]): ASSERT that the requested writing
+ direction is not NSWritingDirectionNatural, since we've disabled the
+ menu item that performs it.
+
+2006-09-27 MorganL <morganl.webkit@yahoo.com>
+
+ Reviewed by Maciej, landed by Brady
+
+ Update URL request associated with provisional data source on redirect.
+ Notify IWebFrameLoadDelegate of redirects for the provisional load.
+ Notify IWebFrameLoadDelegate of a provisional load being commited.
+
+ * COM/WebDataSource.cpp:
+ (WebDataSource::replaceRequest):
+ * COM/WebDataSource.h:
+ * COM/WebFrame.cpp:
+ (WebFrame::receivedRedirect):
+ (WebFrame::receivedResponse):
+ (WebFrame::receivedData):
+
+2006-09-26 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ * WebView/WebHTMLViewPrivate.h:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView markAllMatchesForText:caseSensitive:limit:]):
+ Added limit parameter, passed over the bridge. Stop the search if it hits limit.
+
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.m:
+ (-[WebView markAllMatchesForText:caseSensitive:highlight:limit:]):
+ Added limit parameter, passed to WebHTMLView.
+
+2006-09-26 David Harrison <harrison@apple.com>
+
+ Reviewed by John and TimH.
+
+ <rdar://problem/4743256> Seed: Ctrl-Y key binding does nothing when kill ring is empty
+
+ Use deleteBackward: when the killring string is empty. Was always using insertText:,
+ but that ends up early-returning if the string to insert is empty.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray yank:]):
+ (-[NSArray yankAndSelect:]):
+
+2006-09-25 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Brady.
+
+ Use the non-deprecated method names for getComputedStyle, setEnd and setStart.
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector _highlightNode:]):
+ * WebView/WebHTMLView.m:
+ (unionDOMRanges):
+ (-[WebHTMLView _selectRangeInMarkedText:]):
+ (-[WebTextCompleteController doCompletion]):
+ * WebView/WebView.m:
+ (-[WebView computedStyleForElement:pseudoElement:]):
+
+2006-09-22 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Pass all headers through unifdef to filter out BUILDING_ON_TIGER blocks
+ if MACOSX_DEPLOYMENT_TARGET is 10.4.
+
+ * MigrateHeaders.make:
+
+2006-09-20 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by john
+
+ <http://bugs.webkit.org/show_bug.cgi?id=7165>
+ TinyMCE: Dragging & dropping content always leaves a copy when editing inside a subframe
+
+ The top level WebHTMLView is responsible for performing dragging operations, but
+ the inner view, the view that holds the drag caret, should be consulted to determine
+ if the drag is a move drag.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.m:
+ (-[NSArray dragImage:at:offset:event:pasteboard:source:slideBack:]): Don't set initatedDrag here, because
+ it's only the top level WebHTMLView that performs this operation.
+ (-[WebHTMLView _setInitiatedDrag:]): Added.
+ (-[WebHTMLView _initiatedDrag]): Ditto.
+ (-[WebHTMLView _canProcessDragWithDraggingInfo:]): Ask the innerView if it initiated the drag,
+ not the top level view.
+ (-[WebHTMLView _isMoveDrag]): The top level view asks the innerView if it should perform
+ a move drag, so don't ASSERT _isTopHTMLView.
+ (-[WebHTMLView draggingUpdatedWithDraggingInfo:actionMask:]): Ask the innerView if _isMoveDrag.
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]): Ditto.
+ * WebView/WebHTMLViewInternal.h: Added two private SPI so that
+ the top level WebHTMLView can set and get the initiatedDrag BOOL.
+
+=== Safari-521.27 ===
+
+2006-09-20 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim Omernick
+
+ Fixing part of a crash Tim O showed me. [WebIconDatabase init] should finish
+ gracefully even if we can't open the database
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+
+2006-09-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Tim O.
+
+ <rdar://problem/4741392> Develop a system to find what version of WebKit an app was linked with
+
+ * Misc/WebKitVersionChecks.h: Added.
+ * Misc/WebKitVersionChecks.m: Added.
+ (WebKitLinkedOnOrAfter): Added.
+ (WebKitLinkTimeVersion): Added.
+ (WebKitRunTimeVersion): Added.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-09-20 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ Fixed a typo.
+
+2006-09-20 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ Preparing to make the WebIconDatabase disabled by default - this patch tells the bridge whether its enabled or not
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+
+2006-09-19 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Sarge Decker
+
+ <rdar://problem/4739892> and <rdar://problem/4729797>
+ - WebCore::IconDatabase needs to have and respect an enabled() flag
+ - Mail on ToT WebKit crashes in IconDatabase code when mailing a page from Safari
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]): If preference says icons are disabled, tell the bridge
+ (-[WebIconDatabase _isEnabled]): Ask the bridge if the database is enabled
+
+2006-09-19 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Tim O.
+
+ http://bugs.webkit.org/show_bug.cgi?id=10661
+ REGRESSION: CFM plug-ins (Shockwave, SVG) are not loaded
+
+ * Plugins/WebBasePluginPackage.m:
+ (-[WebBasePluginPackage initWithPath:]): On 32-bit PowerPC, don't bail out if
+ the bundle is nil - it can be a CFM plugin.
+
+2006-09-18 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Anders
+
+ Implement a bridge method so WebCore can find the reload type of a frame load
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge isLoadTypeReload]):
+
+2006-09-18 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=10903
+ Yet Another Objective-C Bindings Patch
+
+ * MigrateHeaders.make:
+
+2006-09-17 David Harrison <harrison@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4494340> REGRESSION: Making the font size bigger/smaller in an HTML message doesn't affect the body until you reopen it
+
+ Problem was the public API -[WebView setTextSizeMultiplier] did not notify anyone that the value changed.
+
+ * WebView/WebDocumentInternal.h:
+ Add _textSizeMultiplierChanged to the _WebDocumentTextSizing protocol.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _textSizeMultiplierChanged]):
+ Send [self _updateTextSizeMultiplier].
+
+ * WebView/WebPDFView.m:
+ (-[WebPDFView _textSizeMultiplierChanged]):
+ ASSERT_NOT_REACHED() because WebPDFView does not track the common multiplier.
+
+ * WebView/WebView.m:
+ (-[WebView setTextSizeMultiplier:]):
+ Send [self _notifyTextSizeMultiplierChanged];
+
+ (-[WebView _performTextSizingSelector:withObject:onTrackingDocs:selForNonTrackingDocs:newScaleFactor:]):
+ Alter the _textSizeMultiplier directly so that notification is not sent.
+ Minor formatting.
+
+ (-[WebView _notifyTextSizeMultiplierChanged]):
+ New. Send _textSizeMultiplierChanged to all document views that track the common multiplier.
+
+2006-09-16 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Hyatt
+
+ WebIconLoader is dead, long live WebCore::IconLoader
+ (code prune)
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader dealloc]):
+ (-[WebFrameLoader commitProvisionalLoad]):
+ * Loader/WebIconLoader.h: Removed.
+ * Loader/WebIconLoader.m: Removed.
+ * Misc/WebIconDatabase.h:
+ * Misc/WebIconDatabase.m:
+ * Misc/WebIconDatabasePrivate.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge notifyIconChanged:]):
+ * WebCoreSupport/WebIconDatabaseBridge.h:
+ * WebCoreSupport/WebIconDatabaseBridge.m:
+ (-[WebIconDatabaseBridge _init]):
+ (-[WebIconDatabaseBridge _setIconData:forIconURL:]):
+ (-[WebIconDatabaseBridge _setHaveNoIconForIconURL:]):
+ * WebKit.exp:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-09-16 Mark Rowe <opendarwin.org@bdash.net.nz>
+
+ Reviewed by Anders.
+
+ http://bugs.webkit.org/show_bug.cgi?id=10887
+ Fix build error
+
+ * MigrateHeaders.make: Remove reference to DOMEventPrivate.h.
+
+2006-09-15 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Brady.
+
+ Make new style ObjC methods public API.
+
+ * MigrateHeaders.make:
+
+2006-09-15 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=10870
+ Auto-generate DOMNode for the Objective-C bindings
+
+ * MigrateHeaders.make:
+
+2006-09-15 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Justin.
+
+ Call the bridge directly for alter selection calls. All of this logic is now
+ in WebCore's SelectionController.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray moveBackward:]):
+ (-[NSArray moveBackwardAndModifySelection:]):
+ (-[NSArray moveDown:]):
+ (-[NSArray moveDownAndModifySelection:]):
+ (-[NSArray moveForward:]):
+ (-[NSArray moveForwardAndModifySelection:]):
+ (-[NSArray moveLeft:]):
+ (-[NSArray moveLeftAndModifySelection:]):
+ (-[NSArray moveRight:]):
+ (-[NSArray moveRightAndModifySelection:]):
+ (-[NSArray moveToBeginningOfDocument:]):
+ (-[NSArray moveToBeginningOfDocumentAndModifySelection:]):
+ (-[NSArray moveToBeginningOfSentence:]):
+ (-[NSArray moveToBeginningOfSentenceAndModifySelection:]):
+ (-[NSArray moveToBeginningOfLine:]):
+ (-[NSArray moveToBeginningOfLineAndModifySelection:]):
+ (-[NSArray moveToBeginningOfParagraph:]):
+ (-[NSArray moveToBeginningOfParagraphAndModifySelection:]):
+ (-[NSArray moveToEndOfDocument:]):
+ (-[NSArray moveToEndOfDocumentAndModifySelection:]):
+ (-[NSArray moveToEndOfSentence:]):
+ (-[NSArray moveToEndOfSentenceAndModifySelection:]):
+ (-[NSArray moveToEndOfLine:]):
+ (-[NSArray moveToEndOfLineAndModifySelection:]):
+ (-[NSArray moveToEndOfParagraph:]):
+ (-[NSArray moveToEndOfParagraphAndModifySelection:]):
+ (-[NSArray moveParagraphBackwardAndModifySelection:]):
+ (-[NSArray moveParagraphForwardAndModifySelection:]):
+ (-[NSArray moveUp:]):
+ (-[NSArray moveUpAndModifySelection:]):
+ (-[NSArray moveWordBackward:]):
+ (-[NSArray moveWordBackwardAndModifySelection:]):
+ (-[NSArray moveWordForward:]):
+ (-[NSArray moveWordForwardAndModifySelection:]):
+ (-[NSArray moveWordLeft:]):
+ (-[NSArray moveWordLeftAndModifySelection:]):
+ (-[NSArray moveWordRight:]):
+ (-[NSArray moveWordRightAndModifySelection:]):
+ (-[NSArray pageUp:]):
+ (-[NSArray pageDown:]):
+ (-[NSArray pageUpAndModifySelection:]):
+ (-[NSArray pageDownAndModifySelection:]):
+
+2006-09-15 Adam Roben <aroben@apple.com>
+
+ Reviewed by eseidel.
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=10876
+ containsItemForURLUnicode uses matchLetter instead of
+ matchUnicodeLetter
+
+ Small fixes for _WebCoreHistoryProvider.
+
+ * History/WebHistory.m: Consistently use BUFFER_SIZE #define
+ (-[_WebCoreHistoryProvider containsItemForURLLatin1:length:]):
+ (-[_WebCoreHistoryProvider containsItemForURLUnicode:length:]):
+ Replace incorrect call to matchLetter to matchUnicodeLetter
+
+2006-09-13 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Add infrastructure to support icon loads taking place in WebCore
+ Will remove WebKit icon loaders in a later patch
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge notifyIconChanged:]):
+ (-[WebFrameBridge originalRequestURL]):
+ - Nuked two old, obsolete methods
+ - Added bridge for notifying of an icon change
+ - Added bridge for getting the "original request URL" which is still needed
+ until that info is available in the WebCore loaders
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _loadIcon]):
+ - Empty body just for now, as it still gets called - next patch will prune all the old impl out
+
+2006-09-13 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Tim O.
+
+ <rdar://problem/4726416> obsolete confusing "ADVISORY NOTE" comment in WebHistory.h
+
+ Removed the "ADVISORY NOTE: This method may change for the 1.0 SDK" comments.
+
+ * History/WebHistory.h:
+
+=== Safari-521.26 ===
+
+2006-09-11 MorganL <morlmor@yahoo.com>
+
+ Reviewed/landed by aroben.
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=10765
+ Windows build busted due to std::copy usage in Vector.h
+
+ * WebKit.vcproj/WebKit.vcproj: Define _SCL_SECURE_NO_DEPRECATE to get
+ rid of deprecation warnings on std::copy
+
+2006-09-11 Brady Eidson <beidson@apple.com>
+
+ Despite the fact that some people built okay without this change, it sure was biting me,
+ probably because I just wiped my build directory for a fresh build -
+ Today's earlier removal of DOMList.h needed to occur in MigrateHeaders.make, as well
+
+ * MigrateHeaders.make: removed DOMList.h
+
+2006-09-10 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=10547
+ REGRESSION: Links that should open in a new window open in the same window,
+ while opening another blank window
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ Changed a mistaken "self" to "frame", which was the cause of the bug. Also
+ fixed the method so that it won't crash if createWebViewWithRequest does
+ something that has a side effect of releasing this WebView or this frame
+ by retaining "self" and "frame" as needed. Also fixed a problem where the
+ code to set "opener" was backwards, and would set the opener of the old
+ frame to point to the new frame instead of vice versa.
+
+2006-09-09 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Eric.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=10795
+ Auto-generate the Objective-C DOM XPath bindings
+
+ * MigrateHeaders.make:
+
+2006-09-09 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Eric.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=10791
+ Even More Objective-C DOM auto-generation cleanup
+
+ * MigrateHeaders.make:
+
+2006-09-08 Tim Omernick <timo@apple.com>
+
+ Reviewed by Brady Eidson.
+
+ Rolled out Maciej's code cleanup from 8/22. It turns out that keeping the "loading" flag
+ is a useful optimization, as it avoids many Objective-C method calls while polling resources
+ for their load state.
+
+ This fixes a 3-4% PLT performance regression (as measured on my MacBook Pro).
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader addPlugInStreamLoader:]):
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader removeSubresourceLoader:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _prepareForLoadStart]):
+ (-[WebDataSource _setLoading:]):
+ (-[WebDataSource _updateLoading]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource isLoading]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-09-07 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Darin and Tim H.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=10774
+ Auto-generate the Objective-C DOM Traversal bindings
+
+ * MigrateHeaders.make:
+
+2006-09-07 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Darin.
+
+ Patch for http://bugs.webkit.org/show_bug.cgi?id=10766
+ Auto-generate the Objective-C DOM Events bindings
+
+ * MigrateHeaders.make:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-09-06 Alexey Proskuryakov <ap@nypop.com>
+
+ * MigrateHeaders.make: Fixed a double slash in
+ "$(PRIVATE_HEADERS_DIR)//DOMCharacterDataPrivate.h" (this was reported
+ to cause a build failure under certain circumstances).
+
+2006-09-05 MorganL <morlmor@yahoocom>
+
+ Reviewed/landed by aroben.
+
+ Fixes bug 10743: Windows build is busted.
+
+ * COM/WebView.cpp:
+ (WebView::keyPress):
+
+2006-09-05 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Drastically simplified the makefile for migrating headers from
+ WebCore and JavaScriptCore. The old version was always copying the files.
+
+ * MigrateHeaders.make:
+
+2006-09-05 Darin Adler <darin@apple.com>
+
+ Reviewed by Alexey.
+
+ - WebKit side of changes to encoding
+
+ * WebView/WebHTMLRepresentation.m: (-[WebHTMLRepresentation documentSource]):
+ Changed to call new -[WebCoreFrameBridge stringWithData:] instead of the calling
+ the old methods that used a CFStringEncoding: -[WebCoreFrameBridge textEncoding]
+ and +[WebCoreFrameBridge stringWithData:textEncoding:].
+
+ * WebView/WebResource.m: (-[WebResource _stringValue]): Removed special case for
+ nil encoding name. The bridge itself now has the rule that "nil encoding name
+ means Latin-1", so we don't need to check for nil.
+
+ * WebView/WebFrame.m: (-[WebFrame _checkLoadComplete]): Retain the frame until
+ we get the parent frame while walking up parent frames, because it's possible
+ for _checkLoadCompleteForThisFrame to release the last reference to the frame.
+ (Not reviewed; needed to run performance tests successfully.)
+
+2006-09-05 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Tim O.
+
+ <rdar://problem/4682225> conflicting typedefs in Netscape plug-in headers
+
+ * Plugins/npfunctions.h: fix the return type for NPN_IntFromIdentifierProcPtr to be int32_t
+
+2006-09-04 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 10714: ObjC autogeneration needs safe-guards against easily modifying the public API
+ http://bugs.webkit.org/show_bug.cgi?id=10714
+
+ - Added the new private DOM headers.
+ - Factored out the common commands into variables.
+ - Made WebDashboardRegion.h private again.
+ - Rename DOMDOMImplementation.h to DOMImplementation.h when files
+ are migrated. Also fixes up #imports.
+
+ * MigrateHeaders.make:
+
+2006-09-03 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Darin and Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10711
+ Auto-generate the Objective-C DOM Stylesheet bindings
+
+ * MigrateHeaders.make:
+
+2006-09-02 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10684
+ Auto-generate the Objective-C DOM CSS bindings
+
+ * MigrateHeaders.make:
+
+2006-09-01 MorganL <morlmor@yahoo.com>
+
+ Reviewed by Darin. Updated/landed by Adam.
+
+ Fixes http://bugs.webkit.org/show_bug.cgi?id=10553
+ Windows build fixes
+
+ * COM/WebFrame.cpp:
+ (WebFrame::initWithName):
+
+2006-09-01 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ A "never should be reached" method was reached - lets not release the shared database bridge, esp
+ since we never retain it!
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _applicationWillTerminate:]): Don't release the bridge
+
+2006-09-01 Darin Adler <darin@apple.com>
+
+ Reviewed by Brady.
+
+ - a few small tweaks to the icon database bridge
+
+ * Misc/WebIconDatabase.m: (-[WebIconDatabase init]): Updated for name change.
+
+ * WebCoreSupport/WebIconDatabaseBridge.h: Removed unneeded declarations.
+ * WebCoreSupport/WebIconDatabaseBridge.m:
+ (-[WebIconDatabaseBridge init]): Added. Always returns nil since you're not supposed
+ to allocate one of these.
+ (-[WebIconDatabaseBridge _init]): Renamed from init. Used internally to make the
+ shared instance. Added the "self = [super init]" idiom even though it's not important
+ in this case just to be consistent.
+ (-[WebIconDatabaseBridge releaseCachedLoaderForIconURL:]): Moved this up in the file
+ so it can be called without declaring it in the header.
+ (+[WebIconDatabaseBridge sharedInstance]): Renamed. Calls the new _init. Also use
+ CFRetain for compatibility.
+ (-[WebIconDatabaseBridge dealloc]): Emptied this out and made it just assert (false).
+ (-[WebIconDatabaseBridge finalize]): Added and made it assert (false) too.
+
+2006-09-01 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Adele.
+
+ Bug 10677: Omit "-webkit-text-security: none;" from the computed style list
+ http://bugs.webkit.org/show_bug.cgi?id=10677
+
+ * WebInspector/webInspector/inspector.js:
+
+2006-08-31 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10669
+ Auto-generate the remaining Objective-C HTML DOM bindings
+
+ * MigrateHeaders.make:
+
+2006-08-31 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ WebKit part of fix for http://bugs.webkit.org/show_bug.cgi?id=10666
+ Password: Disallow Spelling, Font, Speech, and Writing Direction context menu
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m: (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ Check that the selection isn't in a password field before adding these items to the default editing context menu.
+ Search In Google, Search In Spotlight, Look up in Dictionary, Spelling, Font, Speech, Writing Direction
+ * WebView/WebHTMLView.m: (-[WebHTMLView _isSelectionInPasswordField]): Added.
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-08-31 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10653
+ Auto-generate another 20 Objective-C DOM HTML bindings
+
+ * MigrateHeaders.make:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-31 Adele Peterson <adele@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Removed wkSecureEventInput and wkSetSecureEventInput, since this can be done with API.
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface):
+
+2006-08-31 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick
+
+ - fixed <rdar://problem/4711200> Loading history would be faster if it bypassed
+ NSURL API for local files
+
+ * History/WebHistory.m:
+ (-[WebHistoryPrivate _loadHistoryGutsFromURL:savedItemsCount:collectDiscardedItemsInto:error:]):
+ Load file URLs using [NSDictionary dictionaryWithContentsOfFile:]. I also cleaned up some minor
+ style issues in this method, and I removed the support for old NSArray-style history files (which we
+ stopped using before Safari 1.0).
+
+2006-08-30 Adele Peterson <adele@apple.com>
+
+ Reviewed by Hyatt.
+
+ WebKit part of fix for http://bugs.webkit.org/show_bug.cgi?id=10575
+ Enable secure input mode for new password fields
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface):
+
+2006-08-30 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John
+
+ <rdar://problem/4707718> Change behavior so if the WebCore::IconDatabase can't open, WebKit releases the bridge and
+ continues on as if the IconDatabase is disabled.
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]): Release the bridge on failure to open
+ * WebCoreSupport/WebIconDatabaseBridge.m:
+ (+[WebIconDatabaseBridge sharedBridgeInstance]): Moved static shared instance out as a global
+ (-[WebIconDatabaseBridge dealloc]): Clear pointer to the shared instance
+
+2006-08-30 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Simplify the header copies from WebCore and JavaScriptCore.
+ Headers that need to be migrated from the other projects need
+ to be added to MigrateHeaders.make.
+
+ * MigrateHeaders.make: Added.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-30 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10640
+ Auto-generate 10 more Objective-C DOM HTML bindings
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-30 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ WebKit part of fix for:
+ http://bugs.webkit.org/show_bug.cgi?id=10576
+ Disallow copy from new password fields
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _canCopy]): Now also calls across the bridge to ask if it mayCopy.
+ (-[WebHTMLView _canCut]): Calls _canCopy now.
+ (-[NSArray validateUserInterfaceItem:]): Calls _canCut when validating the "Cut" menu item.
+ This used to call _canDelete (which used to be the same as _canCut), but now _canCut also checks _canCopy.
+
+2006-08-30 Karl Adam <karladam@yahoo-inc.com>
+
+ Reviewed by Eric and Tim H.
+
+ Bug 10634: -webView:dragDestinationActionMaskForDraggingInfo: is ignored
+ http://bugs.webkit.org/show_bug.cgi?id=10634
+
+ Remove the check for canShowFile: from _web_bestURL: since
+ it shouldn't be concerned with whether or not the view
+ can show the URL, merely return the most appropriate URL.
+
+ * Misc/WebNSPasteboardExtras.m:
+ (-[NSPasteboard _web_bestURL]):
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_dragOperationForDraggingInfo:]):
+
+2006-08-29 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Kevin Decker (Sarge)
+
+ <rdar://problem/4678414> - New IconDB needs to delete icons when asked
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase removeAllIcons]): Call through to WebCore to remove icons, then send notification
+
+2006-08-29 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Alice
+
+ Added a truth value check for to setIconURL:forURL so WebKit can avoid sending a notification
+ This is a win on the iBench
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _setIconURL:forURL:]):
+
+2006-08-29 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim Hatchers rubber stamp
+
+ Removed some accidentally left-in console spew during the conversion to the new DB
+
+ * Misc/WebIconDatabase.m:
+ (objectFromPathForKey): Nuked some NSLogs
+
+2006-08-29 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin Adler.
+
+ <rdar://problem/4688618> REGRESSION(10.4.7-9A241): JMol java applet fails in Safari not Firefox
+
+ No layout test for now because Java doesn't work in DumpRenderTree.
+
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase refresh]):
+ Add each plug-in MIME type to registeredMIMETypes, even if we don't register a document view class for the
+ MIME type. This fixes -[WebPluginDatabase isMIMETypeRegistered:] and thus fallback content for Java applets
+ (we were always rendering fallback content, if any, for Java applets).
+
+2006-08-29 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10628
+ Auto-generate the remaining Objective-C DOM bindings
+
+ Auto-generates DOMHTMLCollection, DOMHTMLElement, DOMHTMLFormElement,
+ and DOMHTMLOptionsCollection.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-28 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Darin
+
+ Short of a few small snippets that still need to be pushed to WebCore, this
+ is a final prune of WebIconDatabase. WebFileDatabase and WebLRUFileList are gone
+ and the small remaining snippets of WebFileDatabase code that were still important
+ are now in static functions in WebIconDatabase.m
+
+ * Loader/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]): Removed the flag
+ * Misc/WebFileDatabase.h: Removed.
+ * Misc/WebFileDatabase.m: Removed.
+ * Misc/WebIconDatabase.m:
+ (+[WebIconDatabase sharedIconDatabase]):
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase iconForURL:withSize:cache:]):
+ (-[WebIconDatabase iconURLForURL:]):
+ (-[WebIconDatabase defaultIconWithSize:]):
+ (-[WebIconDatabase retainIconForURL:]):
+ (-[WebIconDatabase releaseIconForURL:]):
+ (-[WebIconDatabase _isEnabled]):
+ (-[WebIconDatabase _setIconData:forIconURL:]):
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _hasEntryForIconURL:]):
+ (-[WebIconDatabase _applicationWillTerminate:]):
+ (-[WebIconDatabase _resetCachedWebPreferences:]):
+ (uniqueFilePathForKey): Added from WebFileDatabase
+ (objectFromPathForKey): Added from WebFileDatabase
+ (iconDataFromPathForIconURL):
+ (-[WebIconDatabase _convertToWebCoreFormat]): Make use of static functions and local variables
+ instead of using WebFileDatabase and WebIconDatabase variables that are now obsolete
+ * Misc/WebIconDatabasePrivate.h: Removed alot of obsoleted members
+ * Misc/WebLRUFileList.h: Removed.
+ * Misc/WebLRUFileList.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj: Deleted 4 files
+ * WebKitPrefix.h: Removed ICONDEBUG
+
+2006-08-28 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin Adler.
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView createPluginScriptableObject]):
+ Removed a bogus typecast.
+
+2006-08-28 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Part of <rdar://problem/4481553> NetscapeMoviePlugIn example code scripting doesn't work in Firefox (4319)
+ <http://bugs.webkit.org/show_bug.cgi?id=4319>: NetscapeMoviePlugIn example code scripting doesn't work
+ in Firefox
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView createPluginScriptableObject]):
+ Renamed this method (see corresponding WebCore ChangeLog entry for an explanation).
+ Style changes.
+
+2006-08-28 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim Hatcher's rubberstamp
+
+ Rolled out my last change (16070 - pruning WebFileDatabase code) as it caused a difficult-to-track down
+ failure in layout tests on a release build.
+
+ * Misc/WebFileDatabase.h:
+ * Misc/WebFileDatabase.m:
+ (+[WebFileDatabaseOp opWithCode:key:object:]):
+ (-[WebFileDatabaseOp initWithCode:key:object:]):
+ (-[WebFileDatabaseOp opcode]):
+ (-[WebFileDatabaseOp key]):
+ (-[WebFileDatabaseOp object]):
+ (-[WebFileDatabaseOp perform:]):
+ (-[WebFileDatabaseOp dealloc]):
+ (SetThreadPriority):
+ (-[WebFileDatabase _createLRUList:]):
+ (-[WebFileDatabase _truncateToSizeLimit:]):
+ (+[WebFileDatabase _syncLoop:]):
+ (databaseInit):
+ (-[WebFileDatabase setTimer]):
+ (-[WebFileDatabase setObject:forKey:]):
+ (-[WebFileDatabase removeObjectForKey:]):
+ (-[WebFileDatabase removeAllObjects]):
+ (-[WebFileDatabase objectForKey:]):
+ (-[WebFileDatabase performSetObject:forKey:]):
+ (-[WebFileDatabase performRemoveObjectForKey:]):
+ (-[WebFileDatabase open]):
+ (-[WebFileDatabase close]):
+ (-[WebFileDatabase lazySync:]):
+ (-[WebFileDatabase sync]):
+ (-[WebFileDatabase sizeLimit]):
+ (-[WebFileDatabase count]):
+ (-[WebFileDatabase usage]):
+ (-[WebFileDatabase setSizeLimit:]):
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _createFileDatabase]):
+ (-[WebIconDatabase _loadIconDictionaries]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-28 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ * WebInspector/webInspector/inspector.js: Add "resize: none" to the list of
+ default values for CSS properties so it will be omitted from most displays
+ of computed style.
+
+2006-08-28 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Major prune of unnecessary WebFileDatabase code. In the end, what
+ useful code that remains in WebFileDatabase will likely be moved directly
+ into WebIconDatabase
+
+ * Misc/WebFileDatabase.h:
+ * Misc/WebFileDatabase.m:
+ (-[WebFileDatabase initWithPath:]):
+ (-[WebFileDatabase objectForKey:]):
+ (-[WebFileDatabase open]):
+ (-[WebFileDatabase close]):
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _createFileDatabase]):
+ (-[WebIconDatabase _loadIconDictionaries]):
+ * Misc/WebLRUFileList.h: Removed.
+ * Misc/WebLRUFileList.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-27 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Tim H.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=4624
+ WebCore needs autogenerated Obj-C DOM bindings
+
+ First round of auto-generated Objective C DOM bindings, starting
+ with the DOM Core.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-25 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ Fixed up some leaks on [WebIconDatabase init]
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+
+2006-08-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _updateBackground]): reworded the comment about scroll view and setDrawsBackground:YES
+ * WebView/WebView.m:
+ (-[WebViewPrivate dealloc]): release the background color
+
+2006-08-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Hyatt.
+
+ WebView API to allow changing the background color that draws under transparent page backgrounds.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _makeDocumentView]):
+ (-[WebFrame _updateBackground]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFrameView.m:
+ (-[WebFrameView drawRect:]):
+ * WebView/WebView.m:
+ (-[WebView setBackgroundColor:]):
+ (-[WebView backgroundColor]):
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ (-[WebView setDrawsBackground:]):
+ * WebView/WebViewPrivate.h:
+
+2006-08-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Fix for Mail stationary. Selecting a stationary item would cause this exception.
+ *** -[WebSubresourceLoader copyWithZone:]: selector not recognized
+ Uncaught exception - *** -[WebSubresourceLoader copyWithZone:]: selector not recognized
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader willUseArchiveForRequest:originalURL:loader:]):
+ Use _webkit_setObject:forUncopiedKey: when addign the resource to pendingArchivedResources.
+
+2006-08-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele.
+
+ - fix assertion which I accidentally changed to one that sometimes fails
+ http://bugs.webkit.org/show_bug.cgi?id=10531
+
+ * Loader/WebDocumentLoadState.m:
+ (-[WebDocumentLoadState dealloc]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource dealloc]):
+
+2006-08-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - move WebFrame code that creates WebDataSources down to WebFrameLoader, in preparation
+ for WebFrameLoader just holding on to WebDocumentLoadState
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _loadRequest:archive:]):
+ (-[WebFrameLoader _loadRequest:triggeringAction:loadType:formState:]):
+ (-[WebFrameLoader _reloadAllowingStaleDataWithOverrideEncoding:]):
+ (-[WebFrameLoader reload]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _continueLoadRequestAfterNewWindowPolicy:frameName:formState:]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrame _postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrame _shouldReloadToHandleUnreachableURLFromRequest:]):
+ (-[WebFrame loadRequest:]):
+ (-[WebFrame loadArchive:]):
+ (-[WebFrame reload]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFramePrivate.h:
+ * WebView/WebView.m:
+ (-[WebView setCustomTextEncodingName:]):
+
+2006-08-23 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ First pass at pruning unused WebIconDatabase code. Focus on removing methods that simply
+ have no place in the new DB at all. A few renames and a few important FIXMEs result, but no
+ functionality changes.
+
+ * Loader/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]): Call to WebIconDatabase instead of directly to the bridge
+ * Misc/WebIconDatabase.h:
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase iconForURL:withSize:cache:]):
+ (-[WebIconDatabase iconURLForURL:]):
+ (-[WebIconDatabase defaultIconWithSize:]):
+ (-[WebIconDatabase retainIconForURL:]):
+ (-[WebIconDatabase releaseIconForURL:]):
+ (-[WebIconDatabase removeAllIcons]):
+ (-[WebIconDatabase _setIconData:forIconURL:]):
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _hasEntryForIconURL:]):
+ (-[WebIconDatabase _applicationWillTerminate:]):
+ (-[WebIconDatabase _resetCachedWebPreferences:]):
+ * Misc/WebIconDatabasePrivate.h: Changed setIcon: to setIconData:
+
+2006-08-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele.
+
+ - started factoring most of the guts of WebDataSource into a new class
+
+ WebDocumentLoadState is decoupled from the rest of WebKit and will
+ be moved down to WebCore. I only moved one of the data fields of
+ WebDataSource for now.
+
+ * Loader/WebDocumentLoadState.h: Added.
+ * Loader/WebDocumentLoadState.m: Added.
+ (-[WebDocumentLoadState initWithRequest:]): New class.
+ (-[WebDocumentLoadState dealloc]):
+ (-[WebDocumentLoadState setFrameLoader:]):
+ (-[WebDocumentLoadState setMainResourceData:]):
+ (-[WebDocumentLoadState mainResourceData]):
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _setDataSource:]): Remove redundant _setWebFrame: call,
+ it would have been called already by this point.
+ (-[WebFrameLoader _setProvisionalDataSource:]): ditto.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _setWebFrame:]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource data]):
+
+2006-08-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele.
+
+ - refactoring of WebDataSource in preparation for moving a bunch of it to a new class
+
+ - minimize WebDataSourceInternal.h to be only methods called from outside WebDataSource
+ - reduce Private category implementation to be only the SPI methods
+ - make new Internal and FileInternal categories which contain the
+ remainder (depending on whether they are called from outside of
+ WebDataSource)
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setMainDocumentError:]):
+ (addTypesFromClass):
+ (+[WebDataSource _representationClassForMIMEType:]):
+ (-[WebDataSource _commitIfReady]):
+ (-[WebDataSource _commitLoadWithData:]):
+ (-[WebDataSource _doesProgressiveLoadWithMIMEType:]):
+ (-[WebDataSource _addResponse:]):
+ (-[WebDataSource _revertToProvisionalState]):
+ (-[WebDataSource _mainDocumentError]):
+ (-[WebDataSource _addSubframeArchives:]):
+ (-[WebDataSource _fileWrapperForURL:]):
+ (+[WebDataSource _repTypesAllowImageTypeOmission:]):
+ (-[WebDataSource _decidePolicyForMIMEType:decisionListener:]):
+ (-[WebDataSource _finishedLoading]):
+ (-[WebDataSource _setResponse:]):
+ (-[WebDataSource _setRequest:]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ (-[WebDataSource _receivedMainResourceError:complete:]):
+ (-[WebDataSource _mainReceivedError:complete:]):
+ (-[WebDataSource _defersCallbacks]):
+ (-[WebDataSource _downloadWithLoadingConnection:request:response:proxy:]):
+ (-[WebDataSource _didFailLoadingWithError:forResource:]):
+ (-[WebDataSource _didFinishLoadingForResource:]):
+ (-[WebDataSource _didReceiveData:contentLength:forResource:]):
+ (-[WebDataSource _didReceiveResponse:forResource:]):
+ (-[WebDataSource _didCancelAuthenticationChallenge:forResource:]):
+ (-[WebDataSource _didReceiveAuthenticationChallenge:forResource:]):
+ (-[WebDataSource _willSendRequest:forResource:redirectResponse:]):
+ (-[WebDataSource _identifierForInitialRequest:]):
+ (-[WebDataSource _archivedSubresourceForURL:]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _stopRecordingResponses]):
+ (-[WebDataSource _loadingStartedTime]):
+ (-[WebDataSource _replaceSelectionWithArchive:selectReplacement:]):
+ (-[WebDataSource _documentFragmentWithArchive:]):
+ (-[WebDataSource _documentFragmentWithImageResource:]):
+ (-[WebDataSource _imageElementWithImageResource:]):
+ (-[WebDataSource _title]):
+ (-[WebDataSource _isStopping]):
+ (-[WebDataSource _setWebFrame:]):
+ (-[WebDataSource _URL]):
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource _popSubframeArchiveWithName:]):
+ (-[WebDataSource _setIsClientRedirect:]):
+ (-[WebDataSource _setURL:]):
+ (-[WebDataSource _setLastCheckedRequest:]):
+ (-[WebDataSource _defersCallbacksChanged]):
+ (-[WebDataSource _lastCheckedRequest]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _bridge]):
+ (-[WebDataSource _webView]):
+ (-[WebDataSource _triggeringAction]):
+ (-[WebDataSource _setTriggeringAction:]):
+ (-[WebDataSource __adoptRequest:]):
+ (-[WebDataSource _isDocumentHTML]):
+ (-[WebDataSource _stopLoadingWithError:]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource _responses]):
+ (-[WebDataSource _makeRepresentation]):
+ (-[WebDataSource _isClientRedirect]):
+ (-[WebDataSource _originalRequest]):
+ (-[WebDataSource _URLForHistory]):
+ (-[WebDataSource _addToUnarchiveState:]):
+ (-[WebDataSource _setOverrideEncoding:]):
+ (-[WebDataSource _setIconURL:]):
+ (-[WebDataSource _setIconURL:withType:]):
+ (-[WebDataSource _overrideEncoding]):
+ (-[WebDataSource _setTitle:]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-08-23 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John Sullivan
+
+ /me crosses fingers
+ Flip the switch to the new Icon Database
+ Massive code pruning is coming up
+
+ * WebKitPrefix.h: Flipped the switch
+
+2006-08-23 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Beth
+ Since I just pushed the default URL icon from WebKit to WebCore, but
+ WebKit was still using its version of the default icon, this patch makes it
+ use the WebCore version
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase defaultIconWithSize:]):
+
+2006-08-22 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - remove "loading" flag from WebDataSource and code that manages it; it is redundat.
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader addPlugInStreamLoader:]):
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader removeSubresourceLoader:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _prepareForLoadStart]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource isLoading]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-08-22 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/4683948> REGRESSION: Assertion failure in [FrameProgressEntry addChild:forDataSource:] (fandango.com)
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader addSubresourceLoader:]): Add a WebKit-level assertion that should fire when this bad
+ situation occurs.
+ * Loader/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]): Prevent
+ the situation from occuring.
+
+2006-08-22 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - pull more WebDataSource code into WebFrameLoader
+ - make WebMainResourceLoader not depend on WebKit or on SPI
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _downloadWithLoadingConnection:request:response:proxy:]):
+ (-[WebFrameLoader _updateIconDatabaseWithURL:]):
+ (-[WebFrameLoader _notifyIconChanged:]):
+ (-[WebFrameLoader _iconLoaderReceivedPageIcon:]):
+ (-[WebFrameLoader _checkNavigationPolicyForRequest:andCall:withSelector:]):
+ (-[WebFrameLoader _checkContentPolicyForMIMEType:andCall:withSelector:]):
+ (-[WebFrameLoader cancelContentPolicy]):
+ * Loader/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]):
+ * Loader/WebLoader.m:
+ (-[NSURLProtocol loadWithRequest:]):
+ (-[NSURLProtocol setDefersCallbacks:]):
+ * Loader/WebMainResourceLoader.h:
+ * Loader/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader initWithFrameLoader:]):
+ (-[WebMainResourceLoader dealloc]):
+ (-[WebMainResourceLoader cancelWithError:]):
+ (-[WebMainResourceLoader continueAfterNavigationPolicy:formState:]):
+ (-[WebMainResourceLoader willSendRequest:redirectResponse:]):
+ (-[WebMainResourceLoader continueAfterContentPolicy:]):
+ (-[WebMainResourceLoader checkContentPolicy]):
+ (-[WebMainResourceLoader didReceiveResponse:]):
+ * Plugins/WebPluginContainerCheck.m:
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _cancelledError]):
+ (+[WebDataSource _repTypesAllowImageTypeOmission:]):
+ (+[WebDataSource _representationClassForMIMEType:]):
+ (-[WebDataSource _commitLoadWithData:]):
+ (-[WebDataSource _isDocumentHTML]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFramePrivate.h:
+ * WebView/WebPolicyDelegate.m:
+ * WebView/WebPolicyDelegatePrivate.h:
+
+2006-08-21 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - move more code from WebDataSource to WebFrameLoader
+
+ Also marked a few more methods in WebDataSource as likely MOVABLE in a future round, since they do not
+ use any of WebDataSource's private data.
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader addPlugInStreamLoader:]):
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader removeSubresourceLoader:]):
+ (-[WebFrameLoader _didReceiveAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didCancelAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didReceiveResponse:forResource:]):
+ (-[WebFrameLoader _didReceiveData:contentLength:forResource:]):
+ (-[WebFrameLoader _didFinishLoadingForResource:]):
+ (-[WebFrameLoader _didFailLoadingWithError:forResource:]):
+ (-[WebFrameLoader _privateBrowsingEnabled]):
+ (-[WebFrameLoader _finishedLoadingResource]):
+ (-[WebFrameLoader _receivedError:]):
+ (-[WebFrameLoader _finishedLoading]):
+ * Loader/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader didReceiveData:lengthReceived:allAtOnce:]):
+ (-[WebMainResourceLoader didFinishLoading]):
+ * Loader/WebNetscapePlugInStreamLoader.m:
+ (-[WebNetscapePlugInStreamLoader didFinishLoading]):
+ (-[WebNetscapePlugInStreamLoader didFailWithError:]):
+ (-[WebNetscapePlugInStreamLoader cancelWithError:]):
+ * Loader/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]):
+ (-[WebSubresourceLoader signalFinish]):
+ (-[WebSubresourceLoader didFailWithError:]):
+ (-[WebSubresourceLoader cancel]):
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream start]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _replaceSelectionWithArchive:selectReplacement:]):
+ (-[WebDataSource _updateIconDatabaseWithURL:]):
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource _cancelledError]):
+ (+[WebDataSource _repTypesAllowImageTypeOmission:]):
+ (+[WebDataSource _representationClassForMIMEType:]):
+ (-[WebDataSource _commitLoadWithData:]):
+ (-[WebDataSource _receivedMainResourceError:complete:]):
+ (-[WebDataSource _iconLoaderReceivedPageIcon:]):
+ (-[WebDataSource _isDocumentHTML]):
+ * WebView/WebDataSourceInternal.h:
+
+2006-08-21 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John
+
+ Quick ICONDEBUG flag fix
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _applicationWillTerminate:]):
+
+2006-08-21 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Anders
+
+ -Renamed an internal only method for clarity
+ -Tweaked WebDataSource for notification purposes with the new expiring icons
+ -Fixed a bug with the ICONDEBUG flag
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase iconForURL:withSize:cache:]): #ifdef bug fixed
+ (-[WebIconDatabase _hasEntryForIconURL:]): Renamed for clarity
+ * Misc/WebIconDatabasePrivate.h:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _updateIconDatabaseWithURL:]):
+ (-[WebDataSource _notifyIconChanged:]):
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _iconLoaderReceivedPageIcon:]):
+
+2006-08-17 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - pull a bit of WebDataSource code into WebFrameLoader
+
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _receivedError:]):
+ (-[WebFrameLoader webFrame]):
+ (-[WebFrameLoader _handleFallbackContent]):
+ (+[WebFrameLoader _canShowMIMEType:]):
+ (+[WebFrameLoader _representationExistsForURLScheme:]):
+ (+[WebFrameLoader _generatedMIMETypeForURLScheme:]):
+ * WebView/WebDataSource.m:
+ * WebView/WebDataSourceInternal.h:
+
+2006-08-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/4606857> WebKit: WebPreferencesChangedNotification not exported in 64-bit
+
+ * WebKit.LP64.exp:
+
+2006-08-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/4633896> -[WebView close] should clear all delegates and call setHostWindow:nil
+ <rdar://problem/4649759> Crash when selecting View Source menu using Chinese (-[WebView _close])
+
+ Check to make sure _private is not null. A WebView can be dealloced before _private is setup.
+ Set the _private->closed flag at the beginning of _close to prevent reentry.
+ Set the host window and all the delegates to nil in _close.
+
+ * WebView/WebView.m:
+ (-[WebView _close]):
+
+2006-08-16 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ * Misc/WebIconDatabase.m: Pruned unused method
+ * Misc/WebIconDatabasePrivate.h: Ditto
+
+
+2006-08-15 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele (preliminary version) and later by Kevin.
+
+ - remove most WebKit dependencies from WebMainResourceLoader.
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader cannotShowMIMETypeForURL:]):
+ (-[WebFrameLoader interruptForPolicyChangeErrorWithRequest:]):
+ (-[WebFrameLoader isHostedByObjectElement]):
+ (-[WebFrameLoader isLoadingMainFrame]):
+ (+[WebFrameLoader _canShowMIMEType:]):
+ (+[WebFrameLoader _representationExistsForURLScheme:]):
+ (+[WebFrameLoader _generatedMIMETypeForURLScheme:]):
+ * Loader/WebMainResourceLoader.h:
+ * Loader/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader interruptForPolicyChangeError]):
+ (-[WebMainResourceLoader willSendRequest:redirectResponse:]):
+ (isCaseInsensitiveEqual):
+ (shouldLoadAsEmptyDocument):
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ (-[WebMainResourceLoader didReceiveResponse:]):
+ (-[WebMainResourceLoader didReceiveData:lengthReceived:allAtOnce:]):
+ (-[WebMainResourceLoader didFinishLoading]):
+ (-[WebMainResourceLoader loadWithRequestNow:]):
+ (-[WebMainResourceLoader loadWithRequest:]):
+
+2006-08-15 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage _unloadWithShutdown:]):
+ Fixed a subtle problem with the 64-bit debug build -- as written, this would LOG() on 64-bit and do nothing on
+ 32-bit!
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase _scanForNewPlugins]):
+ Use +[NSMutableSet set] here.
+
+2006-08-15 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin Adler.
+
+ <http://bugs.webkit.org/show_bug.cgi?id=8980>
+ ASSERTION FAILED: !isLoaded (WebKit/WebKit/Plugins/WebBasePluginPackage.m:228 -[WebBasePluginPackage dealloc])
+
+ <rdar://problem/4526052> intermittent assertion failure in -[WebBasePluginPackage dealloc] running layout tests (8980)
+
+ * Plugins/WebPluginDatabase.h:
+ * Plugins/WebPluginDatabase.m:
+ (+[WebPluginDatabase installedPlugins]):
+ Observe NSApplicationWillTerminateNotification so we can unload plug-ins on quit.
+ (-[WebPluginDatabase plugins]):
+ 'plugins' is now a dictionary.
+ (-[WebPluginDatabase close]):
+ Call new -_removePlugin: method.
+ (-[WebPluginDatabase refresh]):
+ Moved parts of this method out into other methods: -_addPlugin:, -_removePlugin:, and -_scanForNewPlugins.
+ (-[WebPluginDatabase _plugInPaths]):
+ No changes; just moved in file.
+ (-[WebPluginDatabase _addPlugin:]):
+ New method. Refactored from -refresh. Adds a plug-in to the database.
+ (-[WebPluginDatabase _removePlugin:]):
+ New method. Refactored from -refresh. Remove a plug-in from the database.
+ (-[WebPluginDatabase _scanForNewPlugins]):
+ New method. Refactored from -refresh. Returns the list of plug-in packages on disk.
+ (-[WebPluginDatabase _applicationWillTerminate]):
+ New method. Called when the application terminates. Closes the plug-in database so that all plug-ins are
+ removed from the DB (and unloaded if necessary).
+
+ * Plugins/WebBasePluginPackage.h:
+ * Plugins/WebBasePluginPackage.m:
+ (-[WebBasePluginPackage initWithPath:]):
+ Try to create the NSBundle first, so if the file is not a valid bundle we bail out early. This
+ avoids some stat()s and allocations during the plug-in refresh process.
+ (-[WebBasePluginPackage isLoaded]):
+ Removed.
+ (-[WebBasePluginPackage load]):
+ Base class for plug-in packages now always loads "successfully".
+ (-[WebBasePluginPackage dealloc]):
+ Removed this assertion. The base plug-in package class has no concept of
+ "unloading".
+ (-[WebBasePluginPackage finalize]):
+ ditto.
+ (-[WebBasePluginPackage wasRemovedFromPluginDatabase:]):
+ Moved code to unload plug-in package to WebNetscapePluginPackage. Not all plug-in
+ packages can be "unloaded".
+
+ * Plugins/WebNetscapePluginPackage.h:
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage _unloadWithShutdown:]):
+ Combined old -unload and -unloadWithoutShutdown methods into this new one.
+ (-[WebNetscapePluginPackage initWithPath:]):
+ Call new unload method.
+ (-[WebNetscapePluginPackage load]):
+ ditto
+ (-[WebNetscapePluginPackage wasRemovedFromPluginDatabase:]):
+ ditto
+ (-[WebNetscapePluginPackage open]):
+ New method. Called when a plug-in instance starts running.
+ (-[WebNetscapePluginPackage close]):
+ New method. Called when a plug-in instance stops running. When all plug-in instances
+ close the plug-in package, and the plug-in package is removed from the database, the plug-in
+ is unloaded.
+
+ * Plugins/WebPluginPackage.m:
+ (-[WebPluginPackage initWithPath:]):
+ (-[WebPluginPackage load]):
+ Made this a bit more efficient by checking if the bundle is already loaded.
+ (-[WebBasePluginPackage unload]):
+ Removed.
+ (-[WebBasePluginPackage isLoaded]):
+ Removed.
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView start]):
+ Open the plug-in package so it remains loaded while this instance uses it.
+ (-[WebBaseNetscapePluginView stop]):
+ Close the plug-in package when the plug-in instance is stopped.
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:]):
+ This check is not necessary. Netscape plug-in packages are never unloaded until all their instances have
+ been stopped, and a Netscape plug-in instance will stop its streams when it is stopped.
+ (-[WebBaseNetscapePluginStream _destroyStream]):
+ ditto
+ (-[WebBaseNetscapePluginStream finishedLoadingWithData:]):
+ ditto
+ (-[WebBaseNetscapePluginStream _deliverData]):
+ ditto
+
+2006-08-15 Mark Rowe <opendarwin.org@bdash.net.nz>
+
+ Reviewed by Tim H.
+
+ Build fix: DWARF and -gfull are incompatible with symbol separation.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-15 Mark Rowe <opendarwin.org@bdash.net.nz>
+
+ Reviewed by Tim H.
+
+ http://bugs.webkit.org/show_bug.cgi?id=10394
+ Bug 10394: WebKit Release and Production configurations should enable dead code stripping
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-15 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - remove WebKit dependencies from WebPlugInStreamLoader via a protocol veil of ignorance
+
+ * Loader/WebNetscapePlugInStreamLoader.h:
+ * Loader/WebNetscapePlugInStreamLoader.m:
+ (-[WebNetscapePlugInStreamLoader initWithDelegate:frameLoader:]):
+ * Loader/WebPlugInStreamLoaderDelegate.h: Added.
+ * Plugins/WebBaseNetscapePluginStream.h:
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream initWithRequest:pluginPointer:notifyData:sendNotification:]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-15 Mark Rowe <opendarwin.org@bdash.net.nz>
+
+ Reviewed by Tim H.
+
+ http://bugs.webkit.org/show_bug.cgi?id=10384
+ Bug 10384: Switch to DWARF for Release configuration
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-15 Graham Dennis <graham.dennis@gmail.com>
+
+ Reviewed by Darin.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10314
+ WebUnarchivingState archivedResourceForURL: doesn't work
+
+ * WebView/WebUnarchivingState.m:
+ (-[WebUnarchivingState archivedResourceForURL:]):
+ Fixed to get objects from the archived resources dictionary using
+ the URL as a string instead of as the URL itself (as this is how
+ the data is put into the dictionary).
+
+2006-08-14 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Beth.
+
+ - remove many (but not all) WebKit dependencies from WebNetscapePlugInStreamLoader (it still
+ depends on WebNetscapePluginStream).
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader fileDoesNotExistErrorWithResponse:]):
+ * Loader/WebNetscapePlugInStreamLoader.h:
+ * Loader/WebNetscapePlugInStreamLoader.m:
+ (-[WebNetscapePlugInStreamLoader initWithStream:frameLoader:]):
+ (-[WebNetscapePlugInStreamLoader releaseResources]):
+ (-[WebNetscapePlugInStreamLoader didReceiveResponse:]):
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream initWithRequest:pluginPointer:notifyData:sendNotification:]):
+
+2006-08-14 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed REGRESSION: crash when leaving youtube page while movie is still loading
+ http://bugs.webkit.org/show_bug.cgi?id=10398
+
+ * Loader/WebNetscapePlugInStreamLoader.m:
+ (-[WebNetscapePlugInStreamLoader initWithStream:view:]): Set the frame loader for this stream.
+ (-[WebNetscapePlugInStreamLoader cancelWithError:]): Make sure to destroy the stream as well;
+ otherwise, when we try to clean up later, we won't have the right context.
+
+2006-08-14 David Hyatt <hyatt@apple.com>
+
+ Fix for Radar bug 4478840, Safari should not reduce null events sent to
+ plug-ins in windows that are inactive but visible.
+
+ With this fix you can view videos in visible background windows on YouTube
+ (for example) and not see any drop in frame rate.
+
+ Reviewed by timo
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView restartNullEvents]):
+
+2006-08-14 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - removed WebKit-level dependencies from WebFormDataStream. Use WebCore version of system interface
+
+ * Loader/WebFormDataStream.m:
+ (formCanRead):
+ (formEventCallback):
+ (webSetHTTPBody):
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+
+2006-08-14 Maciej Stachowiak <mjs@apple.com>
+
+ Rubber stamped by Brady.
+
+ - move WebFormDataStream from WebView to Loader
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFormDataStream.h: Removed.
+ * WebView/WebFormDataStream.m: Removed.
+
+2006-08-13 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ - remove WebKit dependencies from WebSubresourceLoader, except WebFormDataStream
+
+ (WebFormDataStream will be moved into the Loader directory soon)
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ * Loader/WebSubresourceLoader.m:
+ (isConditionalRequest):
+ (hasCaseInsensitivePrefix):
+ (isFileURLString):
+ (setHTTPReferrer):
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]):
+
+2006-08-13 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Relocated the WebIconLoaders
+
+ * Misc/WebIconLoader.h: Moved to Loader/
+ * Misc/WebIconLoader.m: Moved to Loader/
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-13 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Beth.
+
+ - removed non-Loader WebKit dependencies from WebDataProtocol for
+ real (whoops) and fix some typos.
+
+ * Loader/WebDataProtocol.m:
+ (isCaseInsensitiveEqual): Added.
+ (+[WebDataProtocol _webIsDataProtocolURL:]): Avoid WebKit calls.
+ (-[WebDataProtocol startLoading]): ditto
+ * Loader/WebFrameLoader.m:
+ (isCaseInsensitiveEqual): Fixed spelling from isCaseSensitiveEqual.
+ (-[WebFrameLoader _canUseResourceForRequest:]): Use proper call.
+
+2006-08-13 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ The way of detecting a failed icon load before was to try and construct
+ an image from the icon and if that image construction failed, mark the icon
+ as missing.
+ A much more efficient way is to check for an error response. We'll still
+ check for invalid image data, but most servers will correctly return an HTTP
+ error on a missing icon.
+
+ * Misc/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]): Added check for http error response
+
+2006-08-13 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - remove all non-Loader dependencies from WebLoader
+
+ As part of this I moved WebDataProtocol to the loader directory
+ and removed dependencies on the rest of WebKit from that too.
+
+ * Loader/WebFrameLoader.h:
+ * Loader/WebFrameLoader.m:
+ (-[WebFrameLoader setDefersCallbacks:]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader cancelledErrorWithRequest:]):
+ (-[WebFrameLoader clearArchivedResources]):
+ (-[WebFrameLoader deliverArchivedResources]):
+ (-[WebFrameLoader deliverArchivedResourcesAfterDelay]):
+ (isCaseSensitiveEqual):
+ (-[WebFrameLoader _canUseResourceForRequest:]):
+ (-[WebFrameLoader _canUseResourceWithResponse:]):
+ (-[WebFrameLoader pendingArchivedResources]):
+ (-[WebFrameLoader willUseArchiveForRequest:originalURL:loader:]):
+ (-[WebFrameLoader archiveLoadPendingForLoader:]):
+ (-[WebFrameLoader cancelPendingArchiveLoadForLoader:]):
+ * Loader/WebLoader.h:
+ * Loader/WebLoader.m:
+ (-[NSURLProtocol releaseResources]):
+ (-[NSURLProtocol loadWithRequest:]):
+ (-[NSURLProtocol setDefersCallbacks:]):
+ (-[NSURLProtocol addData:allAtOnce:]):
+ (-[NSURLProtocol resourceData]):
+ (-[NSURLProtocol didReceiveData:lengthReceived:allAtOnce:]):
+ (-[NSURLProtocol connection:didReceiveData:lengthReceived:]):
+ (-[NSURLProtocol cancelWithError:]):
+ (-[NSURLProtocol cancelledError]):
+ * Loader/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader addData:allAtOnce:]):
+ (-[WebMainResourceLoader didReceiveData:lengthReceived:allAtOnce:]):
+ * Loader/WebNetscapePlugInStreamLoader.m:
+ (-[WebNetscapePlugInStreamLoader didReceiveData:lengthReceived:allAtOnce:]):
+ * Loader/WebSubresourceLoader.m:
+ (-[WebSubresourceLoader didReceiveData:lengthReceived:allAtOnce:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataProtocol.h: Removed.
+ * WebView/WebDataProtocol.m: Removed.
+
+2006-08-11 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ <http://bugs.webkit.org/show_bug.cgi?id=10111> - Menu flickers over Flash content
+ <rdar://problem/3052546> Plugins don't work with z-index (overlapping elements, etc.)
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ Don't just clip to the dirty region for "transparent" plug-ins -- do it for all plug-ins. This is a
+ generally useful thing to do, as it prevents the plug-in from drawing over parts of the window that
+ have already been drawn and are not expected to be redrawn in the same update.
+
+2006-08-11 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John, Timo, Adele, and Darin
+
+ In addition to a few style/good-practice cleanups, this patch will convert the old icon database
+ format to the WebCore format if the WebCore db is empty (implying this conversion has yet to take
+ place). After the conversion, it will delete all traces of the old format to free the unneeded space
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase _setIconURL:forURL:]): Changed the bridge's name for this method to be more clear
+ (-[WebIconDatabase _createFileDatabase]):
+ (-[WebIconDatabase _iconDataForIconURL:]): This grabs the raw data for use in the conversion function
+ (-[WebIconDatabase _convertToWebCoreFormat]): This does the actual conversion
+
+2006-08-11 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Needed for <rdar://problem/4678070>.
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ Changed an assertion to an early return. It should be possible to send events, especially updateEvt (for image capturing
+ purposes), to off-screen plug-ins. It just doesn't work right now. See <rdar://problem/4318269>.
+
+2006-08-11 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin
+
+ - fixed <rdar://problem/4522894> Would be nice if Safari shrank pages a little if necessary
+ to avoid printing an almost-empty page
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray knowsPageRange:]):
+ If the last page has a short-enough orphan (< 1/10 of the page height is the number I pulled
+ out of ... the air), then we adjust the scale factor slightly and check whether this reduces
+ the page count and thus eliminates the orphan.
+
+2006-08-07 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Anders and John
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ (-[WebIconDatabase isIconExpiredForIconURL:]): Get if an icon expired
+ (-[WebIconDatabase isIconExpiredForPageURL:]): Ditto
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _sendNotificationForURL:]): Moved to WebKitPendingPublic for use outside of WebIconDatabase
+ (-[WebIconDatabase loadIconFromURL:]): Allow a load outside the context of a page load
+ * Misc/WebIconDatabasePrivate.h:
+
+ * Misc/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]): fixed up the "flipping the switch" #defs a bit
+ (-[WebIconLoader willSendRequest:redirectResponse:]): override to allow a load
+ outside of the context of a page load
+
+ * WebCoreSupport/WebIconDatabaseBridge.h: Added.
+ * WebCoreSupport/WebIconDatabaseBridge.m: Added.
+ (-[WebIconDatabaseBridge init]):
+ (-[WebIconDatabaseBridge dealloc]):
+ (-[WebIconDatabaseBridge loadIconFromURL:]): Kick off a load on an icon outside
+ of the context of any page load
+ (-[WebIconDatabaseBridge _setIconData:forIconURL:]): WebKit side of bridge method
+ (-[WebIconDatabaseBridge _setHaveNoIconForIconURL:]): WebKit side of bridge method
+ (-[WebIconDatabaseBridge releaseCachedLoaderForIconURL:]):
+ (+[WebIconDatabaseBridge sharedBridgeInstance]): Moved this from WebCore to WebKit
+ so both sides of the bridge get the WebKit version
+ * WebKit.xcodeproj/project.pbxproj: Added some files
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _loadIcon]): Added check for reload/expired icon to force
+ a load even if we already have it
+
+2006-08-04 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Darin.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10192
+ Make WebCore (and friends) compile with -Wshorten-64-to-32
+
+ * Adds 'f' to float literals where expecting a float.
+ * Use ceilf() instead of ceil() when assigning to a float.
+ * Adds explicit casts where OK.
+
+ NOTE: The -Wshorten-64-to-32 flag was not added for WebKit
+ because there are still a few places where no error handling
+ is in place. The flag can be added as soon as those are worked
+ out.
+
+ * Misc/WebNSControlExtras.m:
+ (-[NSControl sizeToFitAndAdjustWindowHeight]):
+ * Misc/WebNSImageExtras.m:
+ (-[NSImage _web_scaleToMaxSize:]):
+ * Misc/WebNSViewExtras.h:
+ * Misc/WebNSViewExtras.m:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ (-[WebBaseNetscapePluginView drawRect:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge expiresTimeForResponse:]):
+ * WebInspector/WebInspector.m:
+ (-[NSWindow window]):
+ (-[WebInspector treeViewScrollTo:]):
+ (-[WebInspector _updateSystemColors]):
+ (-[WebInspector webView:plugInViewWithArguments:]):
+ (-[WebInspector outlineView:objectValueForTableColumn:byItem:]):
+ * WebInspector/WebInspectorOutlineView.m:
+ (-[WebInspectorOutlineView _highlightRow:clipRect:]):
+ * WebInspector/WebNodeHighlight.m:
+ (-[WebNodeHighlight initWithBounds:andRects:forView:]):
+ * WebInspector/WebNodeHighlightView.m:
+ (-[WebNodeHighlightView roundedRect:withRadius:]):
+ (-[WebNodeHighlightView initWithHighlight:andRects:forView:]):
+ (-[WebNodeHighlightView drawRect:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _opened]):
+ * WebView/WebFrameView.m:
+ (-[WebFrameView initWithFrame:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _dragImageForLinkElement:]):
+ (-[WebHTMLView _web_setPrintingModeRecursive]):
+ (-[WebHTMLView _web_clearPrintingModeRecursive]):
+ (-[NSArray layout]):
+ (-[NSArray _setPrinting:minimumPageWidth:maximumPageWidth:adjustViewSize:]):
+ (-[NSArray adjustPageHeightNew:top:bottom:limit:]):
+ (-[NSArray _scaleFactorForPrintOperation:]):
+ (-[NSArray setPageWidthForPrinting:]):
+ (-[NSArray _endPrintMode]):
+ (-[NSArray knowsPageRange:]):
+ (-[NSArray _originalFontA]):
+ (-[NSArray _originalFontB]):
+ (-[WebTextCompleteController _buildUI]):
+ (-[WebTextCompleteController _placePopupWindow:]):
+ * WebView/WebPDFView.m:
+ (-[WebPDFView _makeTextStandardSize:]):
+ (-[WebPDFView selectionImageForcingWhiteText:]):
+ (-[PDFPrefUpdatingProxy forwardInvocation:]):
+ * WebView/WebPreferences.m:
+ (-[WebPreferences _floatValueForKey:]):
+ * WebView/WebView.m:
+ (-[WebView makeTextSmaller:]):
+ (-[WebView canMakeTextStandardSize]):
+ (-[WebView makeTextStandardSize:]):
+
+2006-08-04 David Kilzer <ddkilzer@kilzer.net>
+
+ Reviewed by NOBODY (build fix).
+
+ * WebCoreSupport/WebSubresourceLoader.m: REALLY moved to Loader/
+ * WebView/WebFrameLoader.h: REALLY moved to Loader/
+ * WebView/WebFrameLoader.m: REALLY moved to Loader/
+ * WebView/WebLoader.h: REALLY moved to Loader/
+ * WebView/WebLoader.m: REALLY moved to Loader/
+ * WebView/WebMainResourceLoader.m: REALLY moved to Loader/
+
+2006-08-03 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - moved all loader code that is slated to be moved down to WebCore to a new Loader directory
+
+ (next step is to remove dependencies on the rest of WebKit from this directory)
+
+ * Loader/WebNetscapePlugInStreamLoader.h: Added.
+ * Loader/WebNetscapePlugInStreamLoader.m: Added. Cut out of WebNetscapePluginStream.m
+ (-[WebNetscapePlugInStreamLoader initWithStream:view:]):
+ (-[WebNetscapePlugInStreamLoader isDone]):
+ (-[WebNetscapePlugInStreamLoader releaseResources]):
+ (-[WebNetscapePlugInStreamLoader didReceiveResponse:]):
+ (-[WebNetscapePlugInStreamLoader didReceiveData:lengthReceived:]):
+ (-[WebNetscapePlugInStreamLoader didFinishLoading]):
+ (-[WebNetscapePlugInStreamLoader didFailWithError:]):
+ (-[WebNetscapePlugInStreamLoader cancelWithError:]):
+ * Plugins/WebNetscapePluginStream.m:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebCoreSupport/WebSubresourceLoader.h: Moved to Loader/
+ * WebCoreSupport/WebSubresourceLoader.m: Moved to Loader/
+ * WebView/WebFrameLoader.h: Moved to Loader/
+ * WebView/WebFrameLoader.m: Moved to Loader/
+ * WebView/WebLoader.h: Moved to Loader/
+ * WebView/WebLoader.m: Moved to Loader/
+ * WebView/WebMainResourceLoader.h: Moved to Loader/
+ * WebView/WebMainResourceLoader.m: Moved to Loader/
+
+2006-08-03 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/4667460> Windowless OpenGL plug-ins render incorrectly on PowerPC
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView _aglOffscreenImageForDrawingInRect:]):
+ Fixed color component swapping so that it works on both x86 and PPC. See comments.
+
+2006-08-03 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Tim Hatcher's rubber stamp
+ Fixed Intel build break caused by weinig's -W change in r15781
+
+ * WebView/WebView.m: wrapped cpu-dependent defs with defined() macro
+
+2006-08-03 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by John.
+
+ - fixed problem that could cause assertion failures in Safari
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView loadRequest:inTarget:withNotifyData:sendNotification:]): Don't
+ allow a plugin to start new loads once its document is no longer the one actively loading.
+
+2006-08-03 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by John.
+
+ - remove use of WebDataSource from WebLoader and subclasses, just have them talk to the
+ WebFrameLoader instead.
+
+ For now this is done by forarding all the calls.
+
+ * Misc/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]):
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream initWithRequest:pluginPointer:notifyData:sendNotification:]):
+ (-[WebNetscapePluginStream start]):
+ (-[WebNetscapePlugInStreamLoader didFinishLoading]):
+ (-[WebNetscapePlugInStreamLoader didFailWithError:]):
+ (-[WebNetscapePlugInStreamLoader cancelWithError:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:postData:]):
+ * WebCoreSupport/WebSubresourceLoader.h:
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (-[WebSubresourceLoader initWithLoader:frameLoader:]):
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forFrameLoader:]):
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:referrer:forFrameLoader:]):
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:postData:referrer:forFrameLoader:]):
+ (-[WebSubresourceLoader receivedError:]):
+ (-[WebSubresourceLoader signalFinish]):
+ (-[WebSubresourceLoader didFailWithError:]):
+ (-[WebSubresourceLoader cancel]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _updateLoading]):
+ (-[WebDataSource textEncodingName]):
+ (-[WebDataSource _mainReceivedBytesSoFar:complete:]):
+ * WebView/WebFrameLoader.h:
+ * WebView/WebFrameLoader.m:
+ (-[WebFrameLoader loadIconWithRequest:]):
+ (-[WebFrameLoader startLoadingMainResourceWithRequest:identifier:]):
+ (-[WebFrameLoader clearIconLoader]):
+ (-[WebFrameLoader commitProvisionalLoad]):
+ (-[WebFrameLoader activeDataSource]):
+ (-[WebFrameLoader _archivedSubresourceForURL:]):
+ (-[WebFrameLoader _defersCallbacks]):
+ (-[WebFrameLoader _identifierForInitialRequest:]):
+ (-[WebFrameLoader _willSendRequest:forResource:redirectResponse:]):
+ (-[WebFrameLoader _didReceiveAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didCancelAuthenticationChallenge:forResource:]):
+ (-[WebFrameLoader _didReceiveResponse:forResource:]):
+ (-[WebFrameLoader _didReceiveData:contentLength:forResource:]):
+ (-[WebFrameLoader _didFinishLoadingForResource:]):
+ (-[WebFrameLoader _didFailLoadingWithError:forResource:]):
+ (-[WebFrameLoader _privateBrowsingEnabled]):
+ (-[WebFrameLoader _addPlugInStreamLoader:]):
+ (-[WebFrameLoader _removePlugInStreamLoader:]):
+ (-[WebFrameLoader _finishedLoadingResource]):
+ (-[WebFrameLoader _receivedError:]):
+ (-[WebFrameLoader _addSubresourceLoader:]):
+ (-[WebFrameLoader _removeSubresourceLoader:]):
+ (-[WebFrameLoader _originalRequest]):
+ (-[WebFrameLoader webFrame]):
+ (-[WebFrameLoader _receivedMainResourceError:complete:]):
+ (-[WebFrameLoader initialRequest]):
+ (-[WebFrameLoader _receivedData:]):
+ (-[WebFrameLoader _setRequest:]):
+ (-[WebFrameLoader _downloadWithLoadingConnection:request:response:proxy:]):
+ (-[WebFrameLoader _handleFallbackContent]):
+ (-[WebFrameLoader _isStopping]):
+ (-[WebFrameLoader _decidePolicyForMIMEType:decisionListener:]):
+ (-[WebFrameLoader _setupForReplaceByMIMEType:]):
+ (-[WebFrameLoader _setResponse:]):
+ (-[WebFrameLoader _mainReceivedError:complete:]):
+ (-[WebFrameLoader _finishedLoading]):
+ (-[WebFrameLoader _mainReceivedBytesSoFar:complete:]):
+ (-[WebFrameLoader _iconLoaderReceivedPageIcon:]):
+ (-[WebFrameLoader _URL]):
+ * WebView/WebLoader.h:
+ * WebView/WebLoader.m:
+ (-[NSURLProtocol releaseResources]):
+ (-[NSURLProtocol loadWithRequest:]):
+ (-[NSURLProtocol setFrameLoader:]):
+ (-[NSURLProtocol frameLoader]):
+ (-[NSURLProtocol willSendRequest:redirectResponse:]):
+ (-[NSURLProtocol didReceiveAuthenticationChallenge:]):
+ (-[NSURLProtocol didCancelAuthenticationChallenge:]):
+ (-[NSURLProtocol didReceiveResponse:]):
+ (-[NSURLProtocol didReceiveData:lengthReceived:]):
+ (-[NSURLProtocol signalFinish]):
+ (-[NSURLProtocol didFailWithError:]):
+ (-[NSURLProtocol willCacheResponse:]):
+ (-[NSURLProtocol cancelWithError:]):
+ * WebView/WebMainResourceLoader.h:
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader initWithFrameLoader:]):
+ (-[WebMainResourceLoader receivedError:]):
+ (-[WebMainResourceLoader cancelWithError:]):
+ (-[WebMainResourceLoader _isPostOrRedirectAfterPost:redirectResponse:]):
+ (-[WebMainResourceLoader addData:]):
+ (-[WebMainResourceLoader willSendRequest:redirectResponse:]):
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ (-[WebMainResourceLoader continueAfterContentPolicy:]):
+ (-[WebMainResourceLoader checkContentPolicyForResponse:]):
+ (-[WebMainResourceLoader didReceiveResponse:]):
+ (-[WebMainResourceLoader didReceiveData:lengthReceived:]):
+ (-[WebMainResourceLoader didFinishLoading]):
+ (-[WebMainResourceLoader didFailWithError:]):
+ (-[WebMainResourceLoader loadWithRequestNow:]):
+
+2006-08-03 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Darin.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10176
+ Make WebCore compile with -Wundef
+
+ * Adds -Wundef flag to Xcode project
+ * Converts #ifs to #ifdef and #ifndefs where needed.
+
+ * Carbon/CarbonUtils.m:
+ * Carbon/CarbonWindowAdapter.m:
+ * Carbon/HIViewAdapter.m:
+ (+[NSView bindHIViewToNSView:nsView:]):
+ * Carbon/HIWebView.m:
+ (HIWebViewEventHandler):
+ * Misc/WebFileDatabase.m:
+ (UniqueFilePathForKey):
+ * Misc/WebNSWindowExtras.m:
+ (swizzleInstanceMethod):
+ * Misc/WebTypesInternal.h:
+ * Plugins/WebNetscapeDeprecatedFunctions.c:
+ * Plugins/WebNetscapeDeprecatedFunctions.h:
+ * Plugins/WebNetscapePluginPackage.h:
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage unloadWithoutShutdown]):
+ (-[WebNetscapePluginPackage load]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-08-03 Darin Adler <darin@apple.com>
+
+ Reviewed by Eric Seidel.
+
+ - fix storage leak
+
+ * WebView/WebFrame.m: (-[WebFramePrivate dealloc]): Release the frame loader.
+
+2006-08-02 Timothy Hatcher <timothy@apple.com>
+
+ Rubber stamped by Maciej.
+
+ Adding back resultsWithXpathQuery, removed by Darin's earlier change.
+ This function is called from ObjC, but not used from JavaScript.
+
+ * WebInspector/webInspector/inspector.js:
+
+2006-08-02 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 10200: [Drosera] Deadlock between Drosera and Safari while loading page
+ http://bugs.webkit.org/show_bug.cgi?id=10200
+
+ Prevent reentrancy in our debugger callbacks. This was causing a deadlock in Drosera because
+ suspendProcessIfPaused was being called during a DO call into Safari.
+
+ Preventing reentrancy also prevents scripts that Drosera injects and evaluates from showing
+ up in rare cases (such as a iframe loading about:blank). I thought this would prevent cases
+ where you call a function from the console and expect it to break on a breakpoint in them, but
+ this appears to never have worked even without this change. When that is figured out we can
+ reconsider a better solution to reentrancy. I have filed that as bug 10214.
+
+ I also removed the NSRunLoop runMode:beforeDate: calls since DO handles this for us since
+ we don't use "onway void" as the return type for the callbacks. Note: using onway void for
+ the listener callbacks causes bad synchronization issues and obscure crashes.
+
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer webView:didLoadMainResourceForDataSource:]):
+ (-[WebScriptDebugServer webView:didParseSource:baseLineNumber:fromURL:sourceId:forWebFrame:]):
+ (-[WebScriptDebugServer webView:failedToParseSource:baseLineNumber:fromURL:withError:forWebFrame:]):
+ (-[WebScriptDebugServer webView:didEnterCallFrame:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:willExecuteStatement:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:willLeaveCallFrame:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:exceptionWasRaised:sourceId:line:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServerPrivate.h:
+
+2006-08-02 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by John.
+
+ - fix assertion failure on layout tests by stopping plugins from loading at a clearly defined time
+ - add more assertions for safety
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]): Removed obsolete comment.
+ (-[WebDataSource _updateLoading]): Add assertion ensuring this method is only called
+ at a time when this data source is the one that might be loading for a frame.
+ (-[WebDataSource _stopLoading]): Stop loading plugins as a FIXME suggests we should.
+ * WebView/WebFrameLoader.m:
+ (-[WebFrameLoader isLoadingPlugIns]): New helper method.
+ (-[WebFrameLoader isLoading]): Consider plugin loads too - otherwise we won't stop them
+ at stopLoading time.
+
+2006-08-02 Adam Roben <aroben@apple.com>
+
+ Reviewed by Brady.
+
+ - Rename TransferJob to ResourceLoader (this file was forgotten in an
+ earlier change by Maciej)
+
+ * COM/WebView.cpp:
+
+2006-08-01 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele.
+
+ - Change things around so WebFrameLoader tracks the main and provisional data source,
+ as well as the frame load state, pulling much code out of WebFrame along the way.
+
+ The most significant aspects of this change are:
+
+ - management of WebDataSources and WebFrameState was moved into WebFrameLoader
+ - there is now just one WebFrameLoader shared between the primary and provisional data source
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _updateLoading]):
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _addSubresourceLoader:]):
+ (-[WebDataSource _removeSubresourceLoader:]):
+ (-[WebDataSource _addPlugInStreamLoader:]):
+ (-[WebDataSource _removePlugInStreamLoader:]):
+ (-[WebDataSource _defersCallbacksChanged]):
+ (-[WebDataSource _stopLoadingWithError:]):
+ (-[WebDataSource _revertToProvisionalState]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource data]):
+ (-[WebDataSource isLoading]):
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate init]):
+ (-[WebFramePrivate dealloc]):
+ (-[WebFrame _closeOldDataSources]):
+ (-[WebFrame _detachFromParent]):
+ (-[WebFrame _makeDocumentView]):
+ (-[WebFrame _receivedMainResourceError:]):
+ (-[WebFrame _transitionToCommitted:]):
+ (+[WebFrame _timeOfLastCompletedLoad]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _continueAfterWillSubmitForm:]):
+ (-[WebFrame _continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrame _initWithWebFrameView:webView:bridge:]):
+ (-[WebFrame _frameLoader]):
+ (-[WebFrame _provisionalLoadStarted]):
+ (-[WebFrame _prepareForDataSourceReplacement]):
+ (-[WebFrame _frameLoadCompleted]):
+ (-[WebFrame provisionalDataSource]):
+ (-[WebFrame dataSource]):
+ (-[WebFrame stopLoading]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFrameLoader.h:
+ * WebView/WebFrameLoader.m:
+ (-[WebFrameLoader initWithWebFrame:]):
+ (-[WebFrameLoader dealloc]):
+ (-[WebFrameLoader dataSource]):
+ (-[WebFrameLoader _setDataSource:]):
+ (-[WebFrameLoader clearDataSource]):
+ (-[WebFrameLoader provisionalDataSource]):
+ (-[WebFrameLoader _setProvisionalDataSource:]):
+ (-[WebFrameLoader _clearProvisionalDataSource]):
+ (-[WebFrameLoader state]):
+ (+[WebFrameLoader timeOfLastCompletedLoad]):
+ (-[WebFrameLoader _setState:]):
+ (-[WebFrameLoader clearProvisionalLoad]):
+ (-[WebFrameLoader markLoadComplete]):
+ (-[WebFrameLoader commitProvisionalLoad]):
+ (-[WebFrameLoader stopLoading]):
+ (-[WebFrameLoader startLoading]):
+ (-[WebFrameLoader startProvisionalLoad:]):
+ (-[WebFrameLoader setupForReplace]):
+ * WebView/WebFramePrivate.h:
+
+2006-08-01 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4480737> Flash crashes after it replaces itself via a document.write()
+
+ I kind of hate to do this, but this is the best way to work around buggy plug-ins like Flash that assume that
+ NPP_Destroy() cannot be called while the browser is calling one of its other plug-in functions. The classic
+ situation is a plug-in that replaces itself via an NPN_Invoke() that executes a document.write().
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ Call -willCallPlugInFunction and -didCallPlugInFunction around calls to the NPP_* functions.
+ (-[WebBaseNetscapePluginView setWindowIfNecessary]):
+ ditto
+ (-[WebBaseNetscapePluginView start]):
+ It should not be possible to start a plug-in instance while we are calling into it (one of those chicken/egg
+ problems). Added a sanity-checking assertion.
+ (-[WebBaseNetscapePluginView stop]):
+ If we're already calling a plug-in function, do not call NPP_Destroy(). The plug-in function we are calling
+ may assume that its instance->pdata, or other memory freed by NPP_Destroy(), is valid and unchanged until said
+ plugin-function returns.
+ (-[WebBaseNetscapePluginView pluginScriptableObject]):
+ Call -willCallPlugInFunction and -didCallPlugInFunction around calls to the NPP_* functions.
+ (-[WebBaseNetscapePluginView willCallPlugInFunction]):
+ Increment plug-in function call depth.
+ (-[WebBaseNetscapePluginView didCallPlugInFunction]):
+ Decrement plug-in function call depth. Stop if we're supposed to stop.
+ (-[WebBaseNetscapePluginView evaluateJavaScriptPluginRequest:]):
+ Call -willCallPlugInFunction and -didCallPlugInFunction around calls to the NPP_* functions.
+ (-[WebBaseNetscapePluginView webFrame:didFinishLoadWithReason:]):
+ ditto
+ (-[WebBaseNetscapePluginView _printedPluginBitmap]):
+ ditto
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:]):
+ Call -willCallPlugInFunction and -didCallPlugInFunction around calls to the NPP_* functions.
+ (-[WebBaseNetscapePluginStream _destroyStream]):
+ ditto
+ (-[WebBaseNetscapePluginStream _deliverData]):
+ ditto
+
+2006-08-01 Maciej Stachowiak <mjs@apple.com>
+
+ - fix build after last change
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+
+2006-08-01 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Beth.
+
+ - revert part of my last fix that broke the Safari bookmarks view
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _checkLoadCompleteForThisFrame]): still send layout message for non-HTML views
+
+2006-08-01 Tim Omernick <timo@apple.com>
+
+ Reviewed by Anders.
+
+ Fixed an assertion failure I ran into while debugging <rdar://problem/4652683>.
+
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView redeliverStream]):
+ Don't clear the "instance" ivar here. This code was refactored here from the old WebNetscapePluginRepresentation,
+ which also had an "instance" ivar. It is never appropriate to clear a plug-in view's instance. That is done when
+ the plug-in is destroyed.
+
+2006-08-01 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Geoff.
+
+ - some refactoring in preparation for moving more stuff to WebFrameLoader.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _clearDataSource]):
+ (-[WebFrame _detachFromParent]):
+ (-[WebFrame _commitProvisionalLoad]):
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _clearProvisionalLoad]):
+ (-[WebFrame _markLoadComplete]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _startProvisionalLoad:]):
+ (-[WebFrame _continueLoadRequestAfterNavigationPolicy:formState:]):
+ (-[WebFrame stopLoading]):
+
+2006-07-31 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - renamed TransferJob to ResourceLoader in WebCore
+
+ * COM/WebFrame.cpp:
+ (WebFrame::loadDataSource):
+ (WebFrame::receivedRedirect):
+ (WebFrame::receivedResponse):
+ (WebFrame::receivedData):
+ (WebFrame::receivedAllData):
+ (WebFrame::setStatusText):
+ * COM/WebFrame.h:
+
+2006-07-31 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - omit the margin and padding boxes for display types where they are ignored
+ - use CSS instead of properties for table spacing and padding as suggested by Tim H.
+
+ * WebInspector/webInspector/inspector.css: Added rules for spacing and padding.
+ Added rules that hide the margin and padding boxes (borders and all but the center cell)
+ when the hide attribute is present.
+ * WebInspector/webInspector/inspector.html: Added classes for the rules above.
+ Removed cellpadding and cellspacing attributes.
+ * WebInspector/webInspector/inspector.js: Added code to hide/show the margin and
+ padding boxes based on the display type.
+
+2006-07-31 Duncan Wilcox <duncan@mclink.it>
+
+ Reviewed by Darin.
+
+ Fixes <http://bugs.webkit.org/show_bug.cgi?id=10159>
+ "REGRESSION: delegate returning no menu elements crashes webkit"
+
+ No automated test, because there's no way to programmatically open a context menu,
+ no manual test because there's no way to customize the context menu delegate.
+
+ * WebView/WebView.m:
+ (-[WebView _menuForElement:defaultItems:]): Make sure the context menu returned
+ some menu items before accessing the first one.
+
+2006-07-31 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/4658194> REGRESSION: "Search in Google"
+ and "Search in Spotlight" fail to work on text selected in a frame
+
+ Use selectedFrame to get the frame with the text selection.
+
+ * WebView/WebView.m:
+ (-[WebView _searchWithGoogleFromMenu:]):
+ (-[WebView _searchWithSpotlightFromMenu:]):
+
+2006-07-31 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=10168
+ add a first cut at a Metrics pane to the inspector
+
+ * WebInspector/webInspector/inspector.css: Add styles for the new metrics pane.
+ * WebInspector/webInspector/inspector.html: Add the new metrics pane, starting with
+ the table to show the box model.
+ * WebInspector/webInspector/inspector.js: Add the new metrics pane. Add back some
+ "title" attributes so we have more tooltips. Removed the optional parameter to
+ getComputedStyle.
+
+2006-07-31 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by John.
+
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase refresh]):
+ Create a mutable set instead of a mutable array.
+
+2006-07-30 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ * WebInspector/webInspector/inspector.js: Fix bug where a null property value
+ leads to an empty style pane.
+
+2006-07-30 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=10163
+ some improvements for the inspector
+
+ * WebInspector/WebInspector.m:
+ (+[WebInspector sharedWebInspector:]): Fixed bug that could cause the inspector
+ to be garbage collected if used in an application with GC enabled.
+ (-[WebInspector dealloc]): Removed a call to a non-existent close method.
+ (-[WebInspector window]): Added a custom WebPreferences object and called
+ setPrivateBrowsingEnabled:YES so the inspector won't appear in the history menu.
+ Also call setProhibitsMainFrameScrolling:YES to try to get rid of trouble where
+ the inspector scrolls when dragging.
+
+ * WebInspector/webInspector/inspector.css: Added style for the new color swatch,
+ and JavaScript properties. More of the style should be shared between the panes,
+ but this should be OK for now.
+
+ * WebInspector/webInspector/inspector.html: Added a first cut at a JavaScript
+ properties pane. Needs work, but better than nothing.
+
+ * WebInspector/webInspector/inspector.js: Lots of improvements:
+ - Omit "typical" property values from computed style display, making it much shorter.
+ - Use the words "black", "white", and "transparent" when appropriate for color values.
+ - Refactored the loaded() function to get rid of repetitive scrollbar setup.
+ - Added a new scrollarea for the JavaScript properties pane.
+ - Simplified refreshScrollbars() -- we now refresh all scrollbars every time, which does no harm.
+ - Removed unused resultsWithXpathQuery().
+ - Use [] instead of "new Array()" and {} instead of "new Object()".
+ - Removed unused xpathForNode().
+ - Changed style pane to display the style for a text node's parent instead of saying
+ it can't display the style for text.
+ - Fixed regression I caused a while back by checking the length of a computed style
+ and not trying to display anything if its length is 0. Before this change and the
+ corresponding change in WebCore, we'd see a complete list of all styles with the
+ empty string as the value for each one.
+ - Changed the name of the computedStyle flag on the style rules array to isComputedStyle
+ to make it easier to understand it's a boolean.
+ - Fixed an error in the code that does !important scanning where it was trying to
+ do a special case for computed style, but was checking the computed style flag on
+ the wrong object.
+ - Added populateStyleListItem() function to factor out things in common between the
+ items in the top level list and the expanded tree for shorthand properties.
+ - Added code to make a color swatch next to the textual representation for any
+ property that contains a color.
+ - Implemented a first cut at a simple JavaScript properties pane.
+
+2006-07-29 Darin Adler <darin@apple.com>
+
+ - Removed tabs from these source files that still had them.
+ We don't use them; that way source files look fine in editors
+ that have tabs set to 8 spaces or to 4 spaces.
+ - Removed allow-tabs Subversion property from the files too.
+
+ * DefaultDelegates/WebDefaultPolicyDelegate.m:
+ * History/WebHistory.m:
+ * Misc/WebDownload.m:
+ * Misc/WebIconDatabase.m:
+ * Misc/WebKitErrors.m:
+ * Misc/WebKitLogging.m:
+ * Misc/WebNSDataExtras.m:
+ * Misc/WebNSFileManagerExtras.m:
+ * Panels/WebPanelAuthenticationHandler.m:
+ * Plugins/WebBaseNetscapePluginView.m:
+ * Plugins/npfunctions.h:
+ * WebCoreSupport/WebSubresourceLoader.m:
+ * WebView/WebMainResourceLoader.m:
+ * WebView/WebView.h:
+ * WebView/WebView.m:
+
+2006-07-29 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Darin.
+
+ - patch for http://bugs.webkit.org/show_bug.cgi?id=10080
+ Adopt pedantic changes from the Unity project to improve
+ cross-compiler compatibility
+
+ Changes include:
+ * Adding missing newline to the end of the file.
+ * Turning on gcc warning for missing newline at the end of a source file
+ (GCC_WARN_ABOUT_MISSING_NEWLINE in Xcode, -Wnewline in gcc).
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebResourcePrivate.h:
+
+2006-07-29 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by John Sullivan.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9984
+ ASSERTION FAILURE: _private->mouseDownEvent != nil
+ (WebKit/WebView/WebHTMLView.m:4863 -[WebHTMLView(WebInternal) _delegateDragSourceActionMask])
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _setMouseDownEvent:]): Moved into the WebHTMLViewFileInternal category and changed
+ to accept nil.
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ Copy the hit HTMLView's mouse down event to the top HTMLView.
+ (-[WebHTMLView acceptsFirstMouse:]): Added a call to _setMouseDownEvent:nil before returning.
+ (-[WebHTMLView shouldDelayWindowOrderingForEvent:]): Added a call to _setMouseDownEvent:nil
+ before returning.
+ (-[WebHTMLView mouseUp:]): Added a call to _setMouseDownEvent:nil to clear the event set in
+ mouseDown: (and used during dragging).
+ (-[WebHTMLView _delegateDragSourceActionMask]): Copy the hit HTMLView's mouse down event to
+ the top HTMLView.
+
+2006-07-28 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/4657473> REGRESSION: Spell check not available from contextual menu in Mail
+
+ The context menu code should be checking isContentEditable
+ on DOMNode not just DOMElement. This is needed because DOMText
+ will be the node class of any text that is clicked.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate webView:contextMenuItemsForElement:defaultMenuItems:]):
+
+2006-07-25 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by Maciej, inspired by John.
+
+ - Fixed <rdar://problem/4651931> 1% REGRESSION on iBench HTML due to
+ repeated requests for non-existent favicon
+
+ An optimization to avoid serializing favicon data for missing icons had stomped an
+ optimization to avoid GETing a missing favicon more than once. The solution
+ is a happy marriage of optimizations, ensuring that we *retain* the missing
+ favicon's "i am missing" data without posting a notification or saving it to disk.
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _setIconURL:forURL:]):
+
+2006-07-25 David Harrison <harrison@apple.com>
+
+ Reviewed by timo and Darin.
+
+ <rdar://problem/4618584> "Paste and Match Style" is not working in Mail (add SPI)
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebView.m:
+ (-[WebView replaceSelectionWithNode:]):
+ (-[WebView _replaceSelectionWithNode:matchStyle:]):
+ * WebView/WebViewPrivate.h:
+ (-[WebView _replaceSelectionWithNode:matchStyle::]):
+ New SPI that is same as replaceSelectionWithNode: with added parameter whether to match existing style.
+
+2006-07-24 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele and Justin.
+
+ - update for change to require context when creating fragments from text
+ (needed to handle whitespace properly)
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _documentFragmentFromPasteboard:inContext:allowPlainText:chosePlainText:]):
+ Added context parameter, pass through to bridge.
+ (-[WebHTMLView _pasteWithPasteboard:allowPlainText:]): Pass selection range as context
+ when calling above method.
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]): Pass drag caret as context when
+ calling above method.
+
+2006-07-24 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Geoff.
+
+ - fix <rdar://problem/4609195> Help Viewer loads empty window (not getting didFailLoadingWithError: callback)
+ (without re-introducing http://bugs.webkit.org/show_bug.cgi?id=10062 )
+
+ * WebView/WebLoader.h:
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader receivedError:]): Copy in some code from the base class to do it in the proper
+ order, surrounding the call to [ds _receivedMainResourceError:error complete:YES].
+
+2006-07-24 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Tim O.
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase removeAllIcons]):
+ Make an array of the keys and iterate through it to avoid modifying the
+ dictionary while enumerating it.
+
+2006-07-24 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John and Darin.
+
+ <rdar://problem/4634290> Cannot selectively install a custom
+ scroller that differs from the default Aqua frame size.
+
+ Adds two new private methods to WebFrameView that allows
+ an application to set a custom scroll view class. This is needed
+ if the application wants to install a custom scroller that is wider
+ than the typical scroller, because NSScrollView does the content
+ rect calculations in a class method (ignoring custom scrollers.)
+ The _setScrollViewClass method requires the class to be a subclass
+ of WebDynamicScrollBarView, or nil can be passed to reset to the default class.
+ A new scroll view of the specified class will then replace the previous
+ one without the need to reload content of the frame.
+
+ * WebView/WebFrameView.m:
+ (-[WebFrameView _customScrollViewClass]):
+ (-[WebFrameView _setCustomScrollViewClass:]):
+ * WebView/WebFrameViewPrivate.h:
+
+2006-07-24 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ Fix http://bugs.webkit.org/show_bug.cgi?id=10009
+ REGRESSION: Schubert-IT PDF Plug-in not working for full page (works in frames)
+
+ * WebView/WebView.m:
+ (+[WebView _viewClass:andRepresentationClass:forMIMEType:]): If we've got a type supported by WebPDFView,
+ make sure to initialize the plugin database, in case a plugin wants to handle it.
+
+2006-07-23 Mark Rowe <opendarwin.org@bdash.net.nz>
+
+ Reviewed by Maciej.
+
+ Bug 9686: [Drosera] Need the ability to break into Drosera on Javascript exceptions
+ http://bugs.webkit.org/show_bug.cgi?id=9686
+
+ WebKit portion of the fix.
+
+ * DefaultDelegates/WebDefaultScriptDebugDelegate.m:
+ (-[WebDefaultScriptDebugDelegate webView:exceptionWasRaised:sourceId:line:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServer.h:
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer webView:exceptionWasRaised:sourceId:line:forWebFrame:]): Notify
+ listeners that an exception has been raised.
+ * WebView/WebScriptDebugDelegate.h:
+ * WebView/WebScriptDebugDelegate.m:
+ (-[WebScriptCallFrame exceptionRaised:sourceId:line:]): Dispatch through to delegate and
+ WebScriptDebugServer.
+
+2006-07-23 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ - Fix for <rdar://problem/4646276> CrashTracer: 7 crashes in Safari at com.apple.WebCore: WebCore::RenderTableSection::paint + 155
+
+ * WebView/WebHTMLView.m: (-[WebHTMLView _web_layoutIfNeededRecursive:testDirtyRect:]):
+ needsDisplay was returning NO even though the view has a dirty rect (see <rdar://problem/4647062>). Since we know about
+ the dirty rect, we don't actually need to check needsDisplay.
+
+2006-07-22 Timothy Hatcher <timothy@apple.com>
+
+ Rolling out r15572.
+
+ Bug 10062: REGRESSION: dom/xhtml/level2/html/HTMLIFrameElement11.xhtml asserts/crashes
+ http://bugs.webkit.org/show_bug.cgi?id=10062
+
+ 2006-07-21 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4609195> Help Viewer loads empty window
+ (not getting didFailLoadingWithError: callback)
+
+ Call super's didFailWithError before _receivedMainResourceError
+ because _receivedMainResourceError will cause the datasource's
+ frame to be set to nil before the didFailLoadingWithError delegate
+ callback is sent. (This order is needed now that WebDataSource does
+ not hold on to the WebView; it uses the WebFrame to get to the WebView.
+ If the WebFrame is nil we can't get to the WebView's resource load delegate.)
+
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader receivedError:]):
+
+
+2006-07-22 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Adele.
+
+ <rdar://problem/4646318> REGRESSION: Ctrl-clicking on a selection containing a word doesn't display a complete contextual menu
+
+ Show the editing context menu if the WebView is editible.
+ The original change only checked if the DOM element was editable,
+ and isContentEditable returns NO if entire WebView is editable.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate webView:contextMenuItemsForElement:defaultMenuItems:]):
+
+2006-07-21 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4609195> Help Viewer loads empty window
+ (not getting didFailLoadingWithError: callback)
+
+ Call super's didFailWithError before _receivedMainResourceError
+ because _receivedMainResourceError will cause the datasource's
+ frame to be set to nil before the didFailLoadingWithError delegate
+ callback is sent. (This order is needed now that WebDataSource does
+ not hold on to the WebView; it uses the WebFrame to get to the WebView.
+ If the WebFrame is nil we can't get to the WebView's resource load delegate.)
+
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader receivedError:]):
+
+=== Safari-521.20 ===
+
+2006-07-21 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by John.
+
+ <rdar://problem/4607572> REGRESSION (521.10.1 - 521.13): most context menu items missing when a form field is focused (common on google.com) (9680)
+
+ Do not use _isEditable call since that only checks if the current
+ selection or frame is editible. We now check if the currently clicked element
+ is a content editible area, a textarea, an isindex or an input element that
+ return YES to _isTextField.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate webView:contextMenuItemsForElement:defaultMenuItems:]):
+
+2006-07-20 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Maciej
+
+ - WebKit part of fix for:
+ <rdar://problem/4557386> REGRESSION (419.3-521.19): repro Safari world leak involving
+ closing tabs after clicking in a web page
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge textViewWasFirstResponderAtMouseDownTime:]):
+ renamed to be more specific (formerly wasFirstResponderAtMouseDownTime:)
+
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLView.m:
+ (-[WebTextCompleteController dealloc]):
+ updated for name change
+ (-[NSArray _setMouseDownEvent:]):
+ Now only retains the first responder if it's a textView, since that's the only case that the only client
+ actually cares about. This avoids a reference cycle caused by retaining self. This is the only substantive
+ part of the patch; all the rest is just renaming for clarity, and comments.
+ (-[NSArray mouseDown:]):
+ updated for name change
+ (-[WebHTMLView _textViewWasFirstResponderAtMouseDownTime:]):
+ renamed to be more specific (formerly _wasFirstResponderAtMouseDownTime:)
+
+2006-07-19 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4523432> safari crashed right after disabling "block pop up windows" (or other WebPreferences changes)
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView viewWillMoveToSuperview:]):
+ Stop the plug-in when it is removed from its superview. It is not sufficient to do this in -viewWillMoveToWindow:nil, because
+ the WebView might still has a hostWindow at that point, which prevents the plug-in from being destroyed.
+ There is no need to start the plug-in when moving into a superview. -viewDidMoveToWindow takes care of that.
+
+=== Safari-521.19 ===
+
+2006-07-17 Tim Omernick <timo@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4612079> need a way to prevent pages from scrolling to reveal elements that are focused
+ by script
+
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.m:
+ (-[WebView setProhibitsMainFrameScrolling:]):
+ New method. Prohibits scrolling in the WebView's main frame. Used to "lock" a WebView to a specific
+ scroll position.
+
+2006-07-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4635311> REGRESSION: WebKit should call windowScriptObjectAvailable before attaching the script debugger
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge windowObjectCleared]):
+
+2006-07-17 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4634874> WebScriptObject and WebUndefined are no longer defined by WebKit
+
+ Copy WebScriptObject.h from WebCore's private headers, not JavaScriptCore.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-07-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed <rdar://problem/4604366> Orange Find highlight displays text in wrong size on PDF pages
+ if they're not at "actual size"
+
+ To match WebHTMLView, I made the methods that return attributed strings take the view's scale
+ factor into account.
+
+ * WebView/WebPDFView.m:
+ (-[WebPDFView _scaledAttributedString:]):
+ new helper method, takes an attributed string and returns one that's scaled by the view's
+ current scale factor
+ (-[WebPDFView attributedString]):
+ pass result through _scaledAttributedString:
+ (-[WebPDFView selectedAttributedString]):
+ ditto
+
+2006-07-17 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by levi
+
+ Rolled the first fix for:
+ <http://bugs.webkit.org/show_bug.cgi?id=9642>
+ GMail Editor: Operations that use drop down menus blow away the selection
+ back in and removed the call to _clearSelectionInOtherFrames from
+ -[WebHTMLView becomeFirstResponder] to fix the bug.
+
+ * WebView/WebHTMLView.m:
+ (-[NSArray maintainsInactiveSelection]):
+ (-[NSArray becomeFirstResponder]):
+ * WebView/WebView.m:
+ (-[WebView maintainsInactiveSelection]):
+
+2006-07-15 Darin Adler <darin@apple.com>
+
+ Reviewed by John Sullivan.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9928
+ REGRESSION: Text Encoding menu inoperative (after gcc protocol build fix)
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _documentRange]): Moved into WebHTMLViewFileInternal category.
+ (-[WebHTMLView selectionRect]): Moved into WebDocumentPrivateProtocols category.
+ (-[WebHTMLView selectionView]): Ditto.
+ (-[WebHTMLView selectionImageForcingWhiteText:]): Ditto.
+ (-[WebHTMLView selectionImageRect]): Ditto.
+ (-[WebHTMLView pasteboardTypesForSelection]): Ditto.
+ (-[WebHTMLView selectAll]): Ditto.
+ (-[WebHTMLView deselectAll]): Ditto.
+ (-[WebHTMLView string]): Ditto.
+ (-[WebHTMLView _attributeStringFromDOMRange:]): Ditto.
+ (-[WebHTMLView attributedString]): Ditto.
+ (-[WebHTMLView selectedString]): Ditto.
+ (-[WebHTMLView selectedAttributedString]): Ditto.
+ (-[WebHTMLView supportsTextEncoding]): Ditto.
+ (-[WebHTMLView _canProcessDragWithDraggingInfo:]): Moved into WebDocumentInternalProtocols.
+ (-[WebHTMLView _isMoveDrag]): Ditto.
+ (-[WebHTMLView _isNSColorDrag:]): Ditto.
+ (-[WebHTMLView draggingUpdatedWithDraggingInfo:actionMask:]): Ditto.
+ (-[WebHTMLView draggingCancelledWithDraggingInfo:]): Ditto.
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]): Ditto.
+ (-[WebHTMLView elementAtPoint:]): Ditto.
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): Ditto.
+
+ * WebKit.xcodeproj/project.pbxproj: Let Xcode 2.3 do its thing.
+
+=== Safari-521.17 ===
+
+2006-07-14 Timothy Hatcher <timothy@apple.com>
+
+ Rolling out this fix from r15358 since it isn't resolved.
+
+ 2006-07-11 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by levi & thatcher
+
+ <http://bugs.webkit.org/show_bug.cgi?id=9642>
+ GMail Editor: Operations that use drop down menus blow away the selection
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView maintainsInactiveSelection]): Maintain an inactive selection
+ when resigning as first responder if the selection is editable
+ or if the WebView tells us to.
+ * WebView/WebView.m:
+ (-[WebView maintainsInactiveSelection]): Just because a WebView is
+ editable doesn't mean selections inside subframes will be. Return
+ NO by default.
+
+2006-07-14 Timothy Hatcher <timothy@apple.com>
+
+ <rdar://problem/4623957> SWB: gcc-5412 (new?) objc warning causes WebCore project failure
+
+ Build fix with the new GCC. Removes forward declarations of protocols.
+
+ * Misc/WebSearchableTextView.h:
+ * WebCoreSupport/WebSubresourceLoader.h:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDocumentInternal.h:
+ * WebView/WebDocumentPrivate.h:
+ * WebView/WebHTMLView.h:
+ * WebView/WebPDFView.h:
+ * WebView/WebScriptDebugDelegatePrivate.h:
+
+2006-06-28 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9625
+ <rdar://problem/4604703>
+ REGRESSION: Focus not removed from password field after ctrl-click in text field
+
+ * WebView/WebHTMLView.m: (-[WebHTMLView menuForEvent:]): Set handlingMouseDownEvent to
+ YES while calling sendContextMenuEvent: on the bridge.
+
+2006-07-14 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ Moved JavaScriptCore to be a public framework.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-07-13 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9795
+ REGRESSION: Crash in [WebHTMLView(WebPrivate)
+ _updateMouseoverWithEvent:]
+ and http://bugs.webkit.org/show_bug.cgi?id=9850
+ REGRESSION: Assertion failure (SHOULD NEVER BE REACHED) in -
+ [WebHTMLView(WebPrivate) removeTrackingRect:]
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateMouseoverWithEvent:]): Return immediately if
+ the view has already been closed.
+
+2006-07-13 David Harrison <harrison@apple.com>
+
+ Reviewed by Justin and Levi.
+
+ <rdar://problem/4620743> REGRESSION: Option-Delete doesn't delete words during typing
+
+ * Tests:
+ editing/deleting/delete-by-word-001.html
+ editing/deleting/delete-by-word-002.html
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _deleteRange:killRing:prepend:smartDeleteOK:deletionAction:granularity:]):
+
+2006-07-13 Timothy Hatcher <timothy@apple.com>
+
+ Rolling out this earlier change (r15378) now that it is fixed on AGL's end.
+ Fixes <rdar://problem/4624865> Restore 64-bit OpenGL plug-in support once AGL is 64-bit
+
+ <rdar://problem/4624858> AGL isn't 64-bit yet; temporarily remove it from WebKit 64-bit build
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+
+2006-07-13 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4616920> REGRESSION: tabbing in mail moves focus
+ to next control instead of inserting a tab space.
+
+ Change editible WebView's tabKeyCyclesThroughElements to NO only
+ if the setTabKeyCyclesThroughElements SPI wasn't called.
+
+ * WebView/WebView.m:
+ (-[WebView setEditable:]):
+
+2006-07-12 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=9624
+ REGRESSION: After ctrl-clicking in a EMPTY input or textarea field, the contextual menu shows "Search in Google" and "Search in Spotlight" as active menu items
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ Don't create Dictionary, Spotlight or Google lookup items if there's no selection.
+
+2006-07-12 Mark Rowe <opendarwin.org@bdash.net.nz>
+
+ Reviewed by Timothy.
+
+ http://bugs.webkit.org/show_bug.cgi?id=9868
+ Applications shown in Drosera's "Attach" window remain after exit
+
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer init]): Register for NSApplicationWillTerminateNotification so we will
+ know when the application is being exited.
+ (-[WebScriptDebugServer dealloc]): Unregister notification before we are deallocated.
+ (-[WebScriptDebugServer applicationTerminating:]): Inform anyone listening that we are going away.
+
+2006-07-12 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/4624858> AGL isn't 64-bit yet; temporarily remove it from WebKit 64-bit build
+
+ Also, fixed a LOG_ERROR() so that it uses the CGL error instead of the AGL error; Tim H missed this in his build fix
+ from earlier.
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+
+2006-07-11 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin and Tim O
+
+ - added support for creating a selection image with white text
+
+ * WebView/WebDocumentPrivate.h:
+ added -selectionImageForcingWhiteText: and -selectionImageRect to the private
+ <WebDocumentSelection> protocol
+
+ * Misc/WebSearchableTextView.m:
+ (-[NSString selectionImageForcingWhiteText:]):
+ added stub for this new method to this obsolete class to satisfy the compiler
+ (-[NSString selectionImageRect]):
+ ditto
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _selectionDraggingImage]):
+ now calls -selectionImageForcingWhiteText:NO instead of just -selectionImage
+ (-[WebHTMLView _selectionDraggingRect]):
+ now calls selectionImageRect, to which the implementation moved
+ (-[WebHTMLView selectionImageForcingWhiteText:]):
+ implemented this new method by calling through to new bridge method selectionImageForcingWhiteText:
+ (-[WebHTMLView selectionImageRect]):
+ implemented this new method by using existing _selectionDraggingRect implementation
+
+ * WebView/WebPDFView.m:
+ (-[WebPDFView selectionImageForcingWhiteText:]):
+ implemented by using code that was formerly in Safari
+ (-[WebPDFView selectionImageRect]):
+ implemented by returning selectionRect
+
+2006-07-11 Tim Omernick <timo@apple.com>
+
+ Reviewed by Geoff.
+
+ <http://bugs.webkit.org/show_bug.cgi?id=9843>:
+ Give Netscape plug-ins access to their own DOM element
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView dealloc]):
+ Release DOM element.
+ (-[WebBaseNetscapePluginView getVariable:value:]):
+ Return NPObject for plugin DOM element.
+
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView initWithFrame:plugin:URL:baseURL:MIMEType:attributeKeys:attributeValues:loadManually:DOMElement:]):
+ Now takes a DOMElement, in much the same way that WebKit plug-in views take a DOMElement.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ Pass DOMElement to Netscape plug-ins.
+ (-[WebFrameBridge viewForJavaAppletWithFrame:attributeNames:attributeValues:baseURL:DOMElement:]):
+ ditto
+
+2006-07-11 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by levi & thatcher
+
+ <http://bugs.webkit.org/show_bug.cgi?id=9642>
+ GMail Editor: Operations that use drop down menus blow away the selection
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView maintainsInactiveSelection]): Maintain an inactive selection
+ when resigning as first responder if the selection is editable
+ or if the WebView tells us to.
+ * WebView/WebView.m:
+ (-[WebView maintainsInactiveSelection]): Just because a WebView is
+ editable doesn't mean selections inside subframes will be. Return
+ NO by default.
+
+2006-07-11 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/4622748> WebKit now uses deprecated AGL functions
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView _createWindowedAGLContext]):
+ aglSetDrawable() is deprecated in AGL 3.0. Use aglSetWindowRef() instead.
+ (-[WebBaseNetscapePluginView _createWindowlessAGLContext]):
+ aglSetOffScreen() is deprecated in AGL 3.0. Use CGLSetOffScreen(), which does the same thing.
+
+2006-07-11 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Tim O.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=7808
+ Assertion failure in -[WebBaseNetscapePluginStream dealloc] when requesting an invalid URL
+
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePluginStream initWithRequest:pluginPointer:notifyData:sendNotification:]):
+ Remove the early return when requesting an invalid (unsupported) URL.
+
+=== Safari-521.16 ===
+
+2006-07-10 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by John Sullivan.
+
+ - fix <rdar://problem/4621541>, aka <http://bugs.webkit.org/show_bug.cgi?id=9838>
+ REGRESSION (r14968-r14977): View Source doesn't work for pages from the back/forward cache
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setPrimaryLoadComplete:]): Set our data only if the frame loader is
+ has just loaded it (when coming from the back/forward cache, it hasn't).
+
+2006-07-10 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Alexey
+
+ Resolved the console error messages people got from the new DB even if they didn't have it enabled
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase init]):
+ Disabled initializing the IconDatabaseBridge if user is living on the old DB
+
+2006-07-10 Darin Adler <darin@apple.com>
+
+ - try to fix Windows build
+
+ * COM/WebFrame.h: Qualify DeprecatedString and KURL with WebCore:: prefixes.
+
+2006-07-09 Darin Adler <darin@apple.com>
+
+ - try to fix Windows build
+
+ * COM/WebFrame.cpp: Rename QChar to DeprecatedChar.
+
+2006-07-09 Darin Adler <darin@apple.com>
+
+ - fix newlines to be consistent for all files in the COM directory
+ (many had mixed style) and set the EOL style to "native" on them.
+
+ * COM/*: Set properties and changed files.
+
+2006-07-09 Tim Omernick <timo@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4404652> Netscape plug-in mouse events broken in HiDPI
+
+ Multiply global mouse coordinates by the window scale factor so that plug-ins can use GlobalToLocal() in HiDPI.
+ This fixes many bugs involving plug-in mouse event handling in HiDPI. Most notably, the Flash player will now
+ correctly respond to clicks.
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (+[WebBaseNetscapePluginView getCarbonEvent:]):
+ (-[WebBaseNetscapePluginView getCarbonEvent:withEvent:]):
+
+2006-07-09 Darin Adler <darin@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - fix assertion firing in plug-in layout tests
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView restartNullEvents]):
+ Don't start null events if the plug-in is not in the
+ started state. This happens when the plug-in moves within
+ its view hierarchy after it has been stopped.
+
+2006-07-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 9820: Move new DOM API that has been through API review to public headers
+ http://bugs.webkit.org/show_bug.cgi?id=9820
+
+ * Misc/WebElementDictionary.m: include DOMExtensions.h
+ * Misc/WebNSViewExtras.m: include DOMExtensions.h
+ * WebKit.xcodeproj/project.pbxproj: make DOMXPath.h public
+
+2006-07-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Kevin.
+
+ Bug 9818: move new UIDelegate API that has been through API review to public headers
+ http://bugs.webkit.org/show_bug.cgi?id=9818
+
+ <rdar://problem/4387541> API: Remove webView:setContentRect: & webViewContentRect: delegate methods?
+ The fix for 4310363 removed the only use of webViewContentRect: in our code. webView:setContentRect:
+ was never used to begin with. There's no harm in leaving these around in the API, but they'll cruft it up.
+
+ Also removes the never used webViewPrint: SPI that was replaced by webView:printFrameView:.
+
+ * DefaultDelegates/WebDefaultUIDelegate.m:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge print]):
+ * WebView/WebFrameView.h:
+ * WebView/WebFrameView.m:
+ * WebView/WebFrameViewPrivate.h:
+ * WebView/WebUIDelegate.h:
+ * WebView/WebUIDelegatePrivate.h:
+
+2006-07-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 9814: Move new WebView API that has been through API review to public headers
+ http://bugs.webkit.org/show_bug.cgi?id=9814
+
+ * WebView/WebView.h:
+ * WebView/WebView.m:
+ (-[WebView close]):
+ (-[WebView setShouldCloseWithWindow:]):
+ (-[WebView shouldCloseWithWindow]):
+ (-[WebView selectedFrame]):
+ (-[WebView setMainFrameURL:]):
+ (-[WebView mainFrameURL]):
+ (-[WebView isLoading]):
+ (-[WebView mainFrameTitle]):
+ (-[WebView mainFrameIcon]):
+ (-[WebView mainFrameDocument]):
+ (-[WebView setDrawsBackground:]):
+ (-[WebView drawsBackground]):
+ (-[WebView toggleSmartInsertDelete:]):
+ (-[WebView toggleContinuousSpellChecking:]):
+ (-[WebView canMakeTextStandardSize]):
+ (-[WebView makeTextStandardSize:]):
+ (-[WebView maintainsInactiveSelection]):
+ * WebView/WebViewPrivate.h:
+
+2006-07-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ Bug 9487: The XPath section should be removed and/or moved.
+ http://bugs.webkit.org/show_bug.cgi?id=9487
+
+ * WebInspector/webInspector/inspector.css:
+ * WebInspector/webInspector/inspector.html:
+ * WebInspector/webInspector/inspector.js:
+
+2006-07-09 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Tim O.
+
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+ Initialize wkPathFromFont.
+
+2006-07-09 Darin Adler <darin@apple.com>
+
+ - fix release build
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView restorePortState:]): Cast inside the assertion so
+ that we don't have an unused variable in versions with assertions disabled.
+ The alternative would be to wrap the whole thing in an #if statement.
+
+2006-07-08 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ - Added ivars for OpenGL support. Someday it would be nice to refactor this class so
+ that each drawing model is encapsulated in a class; this would allow
+ WebBaseNetscapePluginView to make more efficient use of space, for example by not
+ keeping OpenGL-related ivars for Quickdraw plug-ins.
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ - Declared a bunch of internal methods for OpenGL support (see below).
+ - Removed "forUpdate" from CoreGraphics port state struct; it was always set to "YES",
+ so I just cleaned up the silly code that used it.
+ - Declared OpenGL port state struct.
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ - Moved a CoreGraphics-related assertion down to the big "switch" statement.
+ - Don't set window.type here -- according to the Netscape Plug-in API docs, the plug-in
+ should default to "windowed" mode, and may call NPN_SetValue() during its NPN_New() to
+ request that the browser use a "windowless" (offscreen) context instead.
+ - Moved the assertion from the top of this method here; removed a less restrictive
+ assertion that is now obsolete.
+ - Removed "forUpdate" flag from CoreGraphics port state struct.
+ - Fill in OpenGL port state struct. Set up the viewport appropriately for both windowed
+ and windowless OpenGL plug-ins. Windowed plug-ins need to have their GL viewport
+ transformed by the amount the plug-in is clipped; windowless plug-ins are drawn off-screen
+ into a surface whose geometry is never changed or clipped, so they may always draw with
+ a viewport origin of (0, 0).
+ (-[WebBaseNetscapePluginView restorePortState:]):
+ - Removed "forUpdate" flag from CoreGraphics port state struct.
+ - Restore the old OpenGL context saved by -saveAndSetNewPortStateForUpdate:.
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ - Updated an assertion to also include OpenGL. To ensure that attached plug-in window movements
+ happen atomically with web page redisplays, we assert that the plug-in's window is set only while
+ the plug-in view is redrawing.
+ - Same deal as with the assertion; only save/set port state when redrawing the plug-in view. Plug-ins
+ that use the new drawing models are only allowed to draw when the web page draws. I might consider
+ changing this for windowed OpenGL plug-ins, since they always obscure the page content anyway.
+ (-[WebBaseNetscapePluginView isNewWindowEqualToOldWindow]):
+ - Compare new NP_GLContext structs.
+ (-[WebBaseNetscapePluginView updateAndSetWindow]):
+ - In OpenGL mode, can only set window when updating plug-in view.
+ (-[WebBaseNetscapePluginView setWindowIfNecessary]):
+ - ditto
+ - Updated logging for OpenGL drawing mode.
+ (-[WebBaseNetscapePluginView addWindowObservers]):
+ - No need to observe frame/bounds change notifications for this and all parent views. See -renewGState
+ comments below.
+ (-[WebBaseNetscapePluginView removeWindowObservers]):
+ - Don't need to remove frame/bounds observers anymore.
+ (-[WebBaseNetscapePluginView start]):
+ - Plug-ins are "windowed" by default. This is not a change from our previous behavior, but this is a
+ better place to set the default value as it allows the plug-in to override it later.
+ (-[WebBaseNetscapePluginView stop]):
+ - Destroy AGL context when the plug-in stops.
+ (-[WebBaseNetscapePluginView dealloc]):
+ - Assert that the AGL stuff has been cleaned up.
+ (-[WebBaseNetscapePluginView drawRect:]):
+ - If this is a windowless OpenGL plugin, blit its contents back into this view.
+ (-[WebBaseNetscapePluginView renewGState]):
+ - This method is called when the view or one of its parents is moved or resized (see comments).
+ (-[WebBaseNetscapePluginView viewWillMoveToWindow:]):
+ - Hide the AGL window if the plug-in view is about to be removed from its window.
+ (-[WebBaseNetscapePluginView viewHasMoved:]):
+ - Renamed and moved to the "Internal" category.
+ (-[WebBaseNetscapePluginView invalidateRegion:]):
+ - Style changes.
+ - Add support for OpenGL (uses the same region type as CoreGraphics).
+ (-[WebBaseNetscapePluginView getVariable:value:]):
+ - Style changes.
+ - Implemented NPNVsupportsOpenGLBool; returns YES since we now support the OpenGL drawing model.
+ (-[WebBaseNetscapePluginView setVariable:value:]):
+ - Implemented NPPVpluginWindowBool, which allows plug-ins to specify whether they should be rendered in
+ "windowed" or "windowless" mode. This is an older part of the Netscape Plug-in API that was never
+ implemented in WebKit. "Windowed" Quickdraw plug-ins do not actually reside in a separate window, and
+ can already do many of the same things (such as transparency) that only "windowless" plug-ins can do on
+ other platforms. However, we need the "windowed" vs. "windowless" distinction for OpenGL plug-ins so
+ that they have some way of specifying whether they should be rendered on an accelerated overlay surface,
+ composited into the browser window.
+ - Support for setting the drawing model to OpenGL.
+ (-[WebBaseNetscapePluginView _viewHasMoved]):
+ - Renamed from -viewHasMoved:, and moved down in the file.
+ - None of this work is necessary when the plug-in is not in a window; the plug-in's state will be properly
+ restored when it is moved back into a window.
+ - Reshape OpenGL surface window here.
+ (-[WebBaseNetscapePluginView _createAGLContextIfNeeded]):
+ - Creates the AGL context of the appropriate type (windowed/windowless).
+ (-[WebBaseNetscapePluginView _createWindowedAGLContext]):
+ - Creates a windowed AGL context, which is an AGL context attached to a child window. This is the only way
+ to get true hardware acceleration.
+ (-[WebBaseNetscapePluginView _createWindowlessAGLContext]):
+ - Creates a windowless AGL context, which is an AGL context attached to an offscreen buffer. This buffer can
+ then be blitted back into the browser window with a different alpha, or scaled, or whatever.
+ (-[WebBaseNetscapePluginView _cglContext]):
+ - Returns the underlying CGL context from the AGL context. We give the plug-in access to the CGL context because
+ CGL is the more primitive of the GL drawable APIs and allows for finer control over the context.
+ (-[WebBaseNetscapePluginView _getAGLOffscreenBuffer:width:height:]):
+ - Returns the buffer allocated for the offscreen AGL context, if there is one.
+ (-[WebBaseNetscapePluginView _destroyAGLContext]):
+ - Destroys the AGL context, as well as the associated offscreen buffer or child window.
+ (-[WebBaseNetscapePluginView _reshapeAGLWindow]):
+ - Positions the AGL window over the browser window.
+ (-[WebBaseNetscapePluginView _hideAGLWindow]):
+ - Hides the AGL window.
+ (-[WebBaseNetscapePluginView _aglOffscreenImageForDrawingInRect:]):
+ - Returns an NSImage representation of the offscreen AGL context's framebuffer. This is used to draw the offscreen
+ bits back into the plug-in view. This is kind of tricky because it has to convert the offscreen buffer in-place
+ from BGRA to RGBA so that it can be wrapped in an NSBitmapImageRep. See comments.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Link OpenGL and AGL.
+
+2006-07-09 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ The ICONDEBUG flag now chooses either the new icon database or the old one
+ No longer any need to live side by side to compare results
+
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary iconURLForURL:]):
+ (-[NSMutableDictionary retainIconForURL:]):
+ (-[NSMutableDictionary releaseIconForURL:]):
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _resetCachedWebPreferences:]):
+
+2006-07-08 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ Bug 5312: comments aren't available via DOM
+ http://bugs.webkit.org/show_bug.cgi?id=5312
+
+ Makes the Web Inspector show comment node contents.
+
+ * WebInspector/WebInspector.m:
+ (-[DOMNode _displayName]): return the contents of the comment
+ * WebInspector/webInspector/inspector.js: check for comment nodes
+
+2006-07-09 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=9572
+ Add application/xhtml+xml to the Accept header
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]): Add an Accept header
+ to main resource requests.
+ * English.lproj/StringsNotToBeLocalized.txt: Added new strings.
+
+2006-07-08 Darin Adler <darin@apple.com>
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate contextMenuItemsForElement:defaultMenuItems:]):
+ Removed misleading old comment.
+
+=== Safari-521.15 ===
+
+2006-07-07 Levi Weintraub <lweintraub@apple.com>
+
+ Reviewed by justin
+
+ Finished moving deletion selection expansion across the bridge... say that 3 times fast.
+
+ * WebView/WebHTMLView.m: Pass granularity to WebCore to handle expansion
+ (-[WebHTMLView _deleteRange:killRing:prepend:smartDeleteOK:deletionAction:granularity:]):
+ (-[WebHTMLView _deleteSelection]):
+ (-[WebHTMLView _deleteWithDirection:granularity:killRing:isTypingAction:]):
+ (-[WebHTMLView deleteToMark:]):
+
+2006-07-07 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John
+
+ Changed an ASSERT to a LOG_ERROR for an error that could be handled gracefully, but
+ whose assertion was reproducibly causing a build bot failure
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _releaseIconForIconURLString:]):
+
+2006-07-06 Levi Weintraub <lweintraub@apple.com>
+
+ Reviewed by justin
+
+ Improved table editing
+
+ * WebCoreSupport/WebFrameBridge.m: Added method to allow WebCore to trigger
+ deletion editing delegate
+ (-[WebFrameBridge shouldDeleteSelectedDOMRange:]):
+ * WebView/WebHTMLView.m: Moved code that expanded a selection when the delete
+ key is pressed over to WebCore so we can be more intelligent about how to handle it
+ (-[WebHTMLView _deleteRange:killRing:prepend:smartDeleteOK:deletionAction:]):
+ (-[WebHTMLView _deleteWithDirection:granularity:killRing:isTypingAction:]):
+
+2006-07-07 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ - fixed <rdar://problem/4606857> WebKit: WebPreferencesChangedNotification not exported
+
+ * WebKit.exp:
+ added surprisingly missing _WebPreferencesChangedNotification, defined in
+ WebPreferences.h
+
+2006-07-06 Brady Eidson <beidson@apple.com>
+
+ Reviewed by John.
+
+ Small fix to my previous small fix that only lets the ASSERT off the hook if the DB
+ is closing
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _releaseIconForIconURLString:]):
+
+2006-07-05 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Small fix that prevents an assertion from triggering if the DB is being cleaned up
+ (ie, the app being shut down)
+
+ * Misc/WebIconDatabase.h:
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary init]):
+ (-[WebIconDatabase _applicationWillTerminate:]):
+ (-[WebIconDatabase _releaseIconForIconURLString:]):
+
+2006-07-05 Adele Peterson <adele@apple.com>
+
+ Reviewed by Maciej and Hyatt.
+
+ WebKit part of initial popup menu implementation.
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface):
+ Initialize WKPopupMenu.
+
+2006-07-05 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ http://bugs.webkit.org/show_bug.cgi?id=3581
+ iFrames set to display:none are Missing from frames array
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initSubframeWithOwnerElement:frameName:view:]):
+ (-[WebFrameBridge createChildFrameNamed:withURL:referrer:ownerElement:allowsScrolling:marginWidth:marginHeight:]):
+ Modify to pass the owner element instead of the owner renderer.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _topHTMLView]):
+ Remove assertion, it's not valid anymore.
+
+2006-07-05 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Harrison.
+
+ <rdar://problem/4608423> HIViewAdapter used but not defined
+ Adds a new export file to fix the build.
+
+ * WebKit.LP64.exp: Added.
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-07-04 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ Bug 9731: [Drosera] crash when trying to access the scope chain
+ http://bugs.webkit.org/show_bug.cgi?id=9731
+
+ Because of <rdar://problem/4608404> the WebScriptObject, _globalObj, that
+ WebCoreScriptDebugger holds is unprotected each time the page changes.
+ This causes Drosera to crash Safari when trying to access the scope chain.
+ We simply need to detach and re-attach the debugger when the window script
+ object is cleared until 4608404 is fixed. This change also attaches the
+ debugger before we call the windowScriptObjectAvailable: delegate method,
+ so the debugger is ready before anyone might use the window object.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge windowObjectCleared]):
+
+2006-07-04 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 9732: [Drosera] calling removeListener to many times will cause
+ WebKit's listener count to underflow/wraparound
+ http://bugs.webkit.org/show_bug.cgi?id=9732
+
+ Adds a check to make sure the listener was in our listeners set before
+ decrementing the global listener count. Also checks for nil in addListner
+ to prevent a possible exception when adding the object to the set.
+
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer addListener:]):
+ (-[WebScriptDebugServer removeListener:]):
+
+2006-07-04 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Maciej.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=8210
+ Conditional XMLHttpRequest gets should pass 304 responses unchanged
+
+ Test: http/tests/xmlhttprequest/cache-override.html
+
+ * Misc/WebNSURLRequestExtras.h: Added _web_isConditionalRequest
+ * Misc/WebNSURLRequestExtras.m:
+ (-[NSURLRequest _web_isConditionalRequest]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ Bypass the cache for conditional requests.
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forDataSource:]): Ditto.
+
+2006-07-01 David Kilzer <ddkilzer@kilzer.net>
+
+ Reviewed by NOBODY (fixed Tim's build fix).
+
+ * WebView/WebView.m: Added back missing '/' at the beginning of the file.
+
+2006-07-01 Tim Omernick <timo@apple.com>
+
+ Reviewed by NOBODY (build fix)
+
+ * WebView/WebView.m:
+ (-[WebView _isMIMETypeRegisteredAsPlugin:]):
+ Changed nil to NO (typo).
+
+=== Safari-521.14 ===
+
+2006-06-30 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Only enable shouldCloseWithWindow when ObjC GC is enabled.
+ This maintains backwards compatibility with applications
+ that expect a WebView to be usable after the window closes.
+
+ * WebView/WebView.m:
+ (-[WebViewPrivate init]):
+
+2006-06-30 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Anders.
+
+ Call _close in dealloc to ensure we cleanup for backwards
+ compatibility. This will safeguard and cleanup even if the
+ application doesn't use the new close API yet, like Mail.
+
+ * WebView/WebView.m:
+ (-[WebView dealloc]):
+
+2006-06-29 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4484405> WebKit leaks, improper tear-down
+ <rdar://problem/3694059> -[WebBackForwardList finalize] is incorrect; design change needed
+ <rdar://problem/3694103> -[WebFrame finalize] is incorrect; design change needed
+ <rdar://problem/3694104> -[WebHTMLView finalize] is incorrect; design change needed
+
+ Adds a close method to WebView, this needs to be called when the
+ WebView is no longer needed. To make this easier for the common cases
+ there is now an "auto close" on WebView that listens to the view's
+ parent window. If the parent window closes and the WebView has no
+ hostWindow then the WebView is automatically closed if autoClose is YES.
+ To manage WebView closing yourself call setAutoClose: and pass NO.
+
+ When a WebView closes it will tear-down and not be usable anymore.
+ Close will will called on various other internal objects as a part
+ of this, to ensure proper tear-down in GC without relying on finalize.
+
+ * History/WebBackForwardList.m:
+ (-[WebBackForwardList dealloc]):
+ (-[WebBackForwardList finalize]):
+ (-[WebBackForwardList _close]):
+ * History/WebHistoryItem.m:
+ (+[WebHistoryItem _closeObjectsInPendingPageCaches]):
+ (+[WebHistoryItem _releaseAllPendingPageCaches]):
+ * History/WebHistoryItemPrivate.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge close]):
+ (-[WebFrameBridge saveDocumentToPageCache:]):
+ (-[WebFrameBridge canGoBackOrForward:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _detachFromParent]):
+ (-[WebFrame dealloc]):
+ (-[WebFrame finalize]):
+ * WebView/WebFrameView.m:
+ (-[WebFrameView _setWebFrame:]):
+ (-[WebFrameView finalize]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView close]):
+ (-[WebHTMLView dealloc]):
+ (-[WebHTMLView finalize]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLViewPrivate.h:
+ * WebView/WebScriptDebugDelegate.m:
+ (-[WebScriptCallFrame _initWithFrame:initWithWebFrame:]):
+ (-[WebScriptCallFrame parsedSource:fromURL:sourceId:startLine:errorLine:errorMessage:]):
+ (-[WebScriptCallFrame enteredFrame:sourceId:line:]):
+ (-[WebScriptCallFrame hitStatement:sourceId:line:]):
+ (-[WebScriptCallFrame leavingFrame:sourceId:line:]):
+ * WebView/WebScriptDebugDelegatePrivate.h:
+ * WebView/WebView.m:
+ (-[WebViewPrivate init]):
+ (-[WebView _close]):
+ (-[WebView dealloc]):
+ (-[WebView finalize]):
+ (-[WebView viewWillMoveToWindow:]):
+ (-[WebView _windowWillClose:]):
+ (-[WebView setPreferencesIdentifier:]):
+ (-[WebView mainFrame]):
+ (-[WebView setHostWindow:]):
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ (-[WebView writeSelectionWithPasteboardTypes:toPasteboard:]):
+ (-[WebView close]):
+ (-[WebView setAutoClose:]):
+ (-[WebView autoClose]):
+ (-[WebView _frameViewAtWindowPoint:]):
+ * WebView/WebViewPrivate.h:
+
+2006-06-29 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by mjs and timo.
+
+ Fixed: <rdar://problem/4609119> handleAuthenticationFromResource was removed; needed by the Dashboard
+
+ * WebView/WebViewPrivate.h: Added handleAuthenticationFromResource back into the header. Needed by the
+ Dashboard, but was removed in r.14028 on 2006-04-23.
+
+2006-06-29 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/4608487> REGRESSION: reproducible crash in +[WebCoreFrameBridge supportedImageMIMETypes]
+
+ * Plugins/WebPluginDatabase.m:
+ (+[WebPluginDatabase setAdditionalWebPlugInPaths:]):
+ One might be tempted to add additionalWebPlugInPaths to the global WebPluginDatabase here.
+ For backward compatibility with earlier versions of the +setAdditionalWebPlugInPaths: SPI,
+ we need to save a copy of the additional paths and not cause a refresh of the plugin DB
+ at this time.
+ (-[WebPluginDatabase _plugInPaths]):
+ Include additionalWebPlugInPaths if this is the global DB.
+ (-[WebPluginDatabase refresh]):
+ Call -_plugInPaths to get the modified array of paths. This is similar to what the old code
+ (before we had per-WebView plugin search paths).
+
+2006-06-29 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ WebHistoryItem now supports getting and setting arbitrary properties via _transientPropertyForKey: and
+ -_setTransientProperty:forKey:.
+ For now, these properties do not persist with the rest of the history data. They are intended to hold transient
+ per-history-item state, which is something that was until now difficult for a WebKit client app to do.
+
+ * History/WebHistoryItemPrivate.h:
+ * History/WebHistoryItem.m:
+ (-[WebHistoryItemPrivate dealloc]):
+ (-[WebHistoryItem _transientPropertyForKey:]):
+ (-[WebHistoryItem _setTransientProperty:forKey:]):
+
+2006-06-29 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Harrison.
+
+ Smart insert and delete, continuous spell checking and autoscroll
+ can now be used for any WebView, not just editable ones. All of
+ these make sense for documents that might contain content editable
+ areas or our new text fields. Autoscroll is usefull for dragging
+ for file input controls also.
+
+ Added a SPI to toggle WebViews tab key behavior, tabKeyCyclesThroughElements.
+ WebHTMLView's _interceptEditingKeyEvent now uses WebView's
+ tabKeyCyclesThroughElements state to determine whether or not
+ to process tab key events. The idea here is that tabKeyCyclesThroughElements
+ will be YES when this WebView is being used in a browser, and we
+ desire the behavior where tab moves to the next element in tab order.
+ If tabKeyCyclesThroughElements is NO, it is likely that the WebView
+ is being embedded as the whole view, as in Mail, and tabs should input
+ tabs as expected in a text editor. Using Option-Tab always cycles
+ through elements.
+
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation finishedLoadingWithDataSource:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _interceptEditingKeyEvent:]):
+ * WebView/WebView.m:
+ (-[WebViewPrivate init]):
+ (-[WebView _autoscrollForDraggingInfo:timeDelta:]):
+ (-[WebView _shouldAutoscrollForDraggingInfo:]):
+ (-[WebView validateUserInterfaceItem:]):
+ (-[WebView toggleSmartInsertDelete:]):
+ (-[WebView toggleContinuousSpellChecking:]):
+ (-[WebView setTabKeyCyclesThroughElements:]):
+ (-[WebView tabKeyCyclesThroughElements]):
+ * WebView/WebViewPrivate.h:
+
+2006-06-29 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Tim O.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Add DOMXPath.h header.
+
+2006-06-28 David Hyatt <hyatt@apple.com>
+
+ Fix custom highlighting so that you can paint the entire line (and go
+ outside the bounds of the line).
+
+ Reviewed by harrison
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge customHighlightRect:forLine:]):
+ (-[WebFrameBridge paintCustomHighlight:forBox:onLine:behindText:entireLine:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-06-28 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - fix Frame leak on layout tests
+
+ * WebCoreSupport/WebPageBridge.m:
+ (-[WebPageBridge outerView]): Return WebFrameView for main frame instead
+ of WebView to avoid reference cycle between WebView and Page.
+
+2006-06-28 Timothy Hatcher <timothy@apple.com>
+
+ Prefer the Stabs debugging symbols format until DWARF bugs are fixed.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-06-28 Levi Weintraub <lweintraub@apple.com>
+
+ Reviewed by justin
+
+ http://bugs.webkit.org/show_bug.cgi?id=7568
+ Bug 7568: Implement Indent/Outdent
+ Added undo action strings and enum values
+
+ * English.lproj/Localizable.strings:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge nameForUndoAction:]):
+
+2006-06-27 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Hookup the new semi-functional SQLite icon database.
+ For now, it is living side-by-side with the old DB so one can compare the
+ two for debugging purposes. Also, it is disabled (in WebKit) by default unless you
+ compile with ICONDEBUG #defined.
+ Note: To repeat that, if you want to try the new DB, #define ICONDEBUG (WebKitPrefix.h is a good place to do it)
+
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary iconForURL:withSize:cache:]):
+ (-[NSMutableDictionary iconURLForURL:]):
+ (-[NSMutableDictionary retainIconForURL:]):
+ (-[NSMutableDictionary releaseIconForURL:]):
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _hasIconForIconURL:]):
+ (-[WebIconDatabase _resetCachedWebPreferences:]):
+ * Misc/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-06-26 David Hyatt <hyatt@apple.com>
+
+ Fix for 9538, support syntax highlighting for HTML source.
+
+ Reviewed by darin
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebView.m:
+ (-[WebView _setInViewSourceMode:]):
+ (-[WebView _inViewSourceMode]):
+ * WebView/WebViewPrivate.h:
+
+2006-06-25 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 9574: Drosera should show inline scripts within the original HTML
+ http://bugs.webkit.org/show_bug.cgi?id=9574
+
+ * Adds a new version of the didParseSource delegate callback with base line number.
+ * Adds a new delegate callback for when a script fails to parse.
+ * These new callbacks use NSURLs for the url parameter.
+ * Adds a new script listener callback to notify when the main resource loads.
+ * Adds a WebScriptErrorDomian and other keys for use with NSError.
+
+ * DefaultDelegates/WebDefaultScriptDebugDelegate.m:
+ (-[WebDefaultScriptDebugDelegate webView:didParseSource:baseLineNumber:fromURL:sourceId:forWebFrame:]):
+ (-[WebDefaultScriptDebugDelegate webView:failedToParseSource:baseLineNumber:fromURL:withError:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServer.h:
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer webView:didLoadMainResourceForDataSource:]):
+ (-[WebScriptDebugServer webView:didParseSource:baseLineNumber:fromURL:sourceId:forWebFrame:]):
+ (-[WebScriptDebugServer webView:failedToParseSource:baseLineNumber:fromURL:withError:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServerPrivate.h:
+ * WebKit.exp:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ * WebView/WebScriptDebugDelegate.h:
+ * WebView/WebScriptDebugDelegate.m:
+ (-[WebScriptCallFrame parsedSource:fromURL:sourceId:startLine:errorLine:errorMessage:]):
+
+2006-06-24 David Kilzer <ddkilzer@kilzer.net>
+
+ Reviewed by Timothy.
+
+ * Info.plist: Fixed copyright to include 2003-2006.
+
+2006-06-24 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=9418
+ WebKit will not build when Space exists in path
+
+ * WebKit.xcodeproj/project.pbxproj: Enclose search paths in quotes.
+
+2006-06-23 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ Fixed a bug I found in the CoreGraphics drawing model that was preventing certain types of
+ events from being dispatched to the plugin, unless the plugin was being updated. The check
+ for portState was only required to call -setWindowIfNecessary, not required for the entire
+ event dispatch.
+ Also, don't paint the green debug rect unless this is a QuickDraw plugin. Otherwise the
+ current QD port is not set, and the green rect fills the entire screen. Pretty awesome
+ looking, but not intended behavior.
+ (-[WebBaseNetscapePluginView setWindowIfNecessary]):
+ Improved the logging here to include the NPWindow's width and height.
+
+2006-06-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Tim O.
+
+ Adds back SPI that Mail is still depending on.
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _addSubframeArchives:]):
+ * WebView/WebDataSourcePrivate.h:
+
+=== WebKit-521.13 ===
+
+2006-06-23 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Geoff.
+
+ script debugger should only attach to JavaScriptCore when there are listeners
+ http://bugs.webkit.org/show_bug.cgi?id=9552
+
+ Attaches the debugger to all WebFrames when the first listener
+ is added. Detaches when the last listener is removed.
+ Also detach when the script debug delegate is set to nil.
+
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (+[WebScriptDebugServer listenerCount]):
+ (-[WebScriptDebugServer dealloc]):
+ (-[WebScriptDebugServer attachScriptDebuggerToAllWebViews]):
+ (-[WebScriptDebugServer detachScriptDebuggerFromAllWebViews]):
+ (-[WebScriptDebugServer listenerConnectionDidDie:]):
+ (-[WebScriptDebugServer addListener:]):
+ (-[WebScriptDebugServer removeListener:]):
+ * DefaultDelegates/WebScriptDebugServerPrivate.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge windowObjectCleared]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _attachScriptDebugger]):
+ (-[WebFrame _detachScriptDebugger]):
+ * WebView/WebFramePrivate.h:
+ * WebView/WebScriptDebugDelegate.m:
+ (-[WebScriptCallFrame parsedSource:fromURL:sourceId:]):
+ (-[WebScriptCallFrame enteredFrame:sourceId:line:]):
+ (-[WebScriptCallFrame hitStatement:sourceId:line:]):
+ (-[WebScriptCallFrame leavingFrame:sourceId:line:]):
+ * WebView/WebView.m:
+ (-[WebView _attachScriptDebuggerToAllFrames]):
+ (-[WebView _detachScriptDebuggerFromAllFrames]):
+ (-[WebView setScriptDebugDelegate:]):
+ * WebView/WebViewPrivate.h:
+
+2006-06-22 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick
+
+ - added support for UIDelegate to be notified of scrolling in any WebHTMLView
+ - cleaned up recently-added UIDelegate code
+
+ * WebView/WebUIDelegatePrivate.h:
+ declared webView:didScrollDocumentInFrameView: method
+
+ * DefaultDelegates/WebDefaultUIDelegate.m:
+ (-[NSApplication webView:didDrawRect:]):
+ provide default (empty) implementation of this recently-added method, so the
+ DelegateForwarder mechanism will work for it
+ (-[NSApplication webView:didScrollDocumentInFrameView:]):
+ same thing for the new method
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _frameOrBoundsChanged]):
+ use _UIDelegateForwarder mechanism to notify delegate that scrolling occurred
+ (-[WebHTMLView drawSingleRect:]):
+ use _UIDelegateForwarder mechanism instead of checking respondsToSelector stuff
+ here (that's packaged up nicely by the forwarder mechanism)
+
+2006-06-22 Tim Omernick <timo@apple.com>
+
+ Reviewed by NOBODY (build fix)
+
+ * WebView/WebFrameLoader.m:
+ Import WebMainResourceLoader instead of using @class so that we can call WebMainResourceLoader
+ methods.
+
+2006-06-22 Tim Omernick <timo@apple.com>
+
+ Reviewed by NOBODY (build fix)
+
+ * WebView/WebFrameLoader.m:
+ Import JavaScriptCore/Assertions.h instead of WebKit/WebAssertions.h (which no longer exists)
+
+2006-06-22 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele.
+
+ - start moving loading logic to new WebFrameLoader class; move management of WebLoaders there
+
+ * Misc/WebIconLoader.h:
+ * Misc/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _updateLoading]):
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _setPrimaryLoadComplete:]):
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _addSubresourceLoader:]):
+ (-[WebDataSource _removeSubresourceLoader:]):
+ (-[WebDataSource _addPlugInStreamLoader:]):
+ (-[WebDataSource _removePlugInStreamLoader:]):
+ (-[WebDataSource _iconLoaderReceivedPageIcon:]):
+ (-[WebDataSource _defersCallbacksChanged]):
+ (-[WebDataSource _stopLoadingWithError:]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource dealloc]):
+ (-[WebDataSource finalize]):
+ (-[WebDataSource data]):
+ (-[WebDataSource isLoading]):
+ * WebView/WebFrameLoader.h: Added.
+ * WebView/WebFrameLoader.m: Added.
+ (-[WebFrameLoader initWithDataSource:]):
+ (-[WebFrameLoader dealloc]):
+ (-[WebFrameLoader hasIconLoader]):
+ (-[WebFrameLoader loadIconWithRequest:]):
+ (-[WebFrameLoader stopLoadingIcon]):
+ (-[WebFrameLoader addPlugInStreamLoader:]):
+ (-[WebFrameLoader removePlugInStreamLoader:]):
+ (-[WebFrameLoader setDefersCallbacks:]):
+ (-[WebFrameLoader stopLoadingPlugIns]):
+ (-[WebFrameLoader isLoadingMainResource]):
+ (-[WebFrameLoader isLoadingSubresources]):
+ (-[WebFrameLoader isLoading]):
+ (-[WebFrameLoader stopLoadingSubresources]):
+ (-[WebFrameLoader addSubresourceLoader:]):
+ (-[WebFrameLoader removeSubresourceLoader:]):
+ (-[WebFrameLoader mainResourceData]):
+ (-[WebFrameLoader releaseMainResourceLoader]):
+ (-[WebFrameLoader cancelMainResourceLoad]):
+ (-[WebFrameLoader startLoadingMainResourceWithRequest:identifier:]):
+ (-[WebFrameLoader stopLoadingWithError:]):
+
+2006-06-21 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ The WebCoreIconDatabaseBridge was getting messages sent to it after it had been closed, resulting in a crash
+ on an ASSERT(). After closing the databaseBridge, we simply set it to nil so this can't happen.
+ anymore.
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _applicationWillTerminate:]):
+
+2006-06-21 Tim Omernick <timo@apple.com>
+
+ Reviewed by Geoff Garen.
+
+ <rdar://problem/4564131> WebPluginDatabase setAdditionalWebPlugInPaths needs to be per WebView
+
+ Added some WebView SPI so that individual WebViews may have different plugin search paths. There are some
+ limitations with the approach taken here:
+
+ - JavaScript may only access the global plugin DB.
+ - When this SPI is in use, certain WebView methods may not give accurate results, such as +canShowMIMEType:.
+ - This only works for plugins referenced using the <object> or <embed> tags; plugins that reside in non-standard
+ file system locations may not be loaded directly into frames.
+
+ None of these issues are important to the client that needs this SPI. Rather than re-architect our entire
+ plugin database, I think it is better to simply accept these limitations for now.
+
+ * Plugins/WebPluginDatabase.h:
+ Added "plugInPaths" ivar, so different plugin databases can have different search paths.
+ * Plugins/WebPluginDatabase.m:
+ (+[WebPluginDatabase installedPlugins]):
+ Give the global plugin database the default plugin search paths.
+ (+[WebPluginDatabase setAdditionalWebPlugInPaths:]):
+ Removed static global; this method now sets the plugin paths on the global plugin database.
+ (-[WebPluginDatabase setPlugInPaths:]):
+ Setter method for plugin paths.
+ (-[WebPluginDatabase close]):
+ New method; called when the plugin database is no longer needed (when its WebView is being destroyed).
+ (-[WebPluginDatabase init]):
+ Don't refresh in -init, so that callers can set the DB's plugin path array before it refreshes.
+ (-[WebPluginDatabase dealloc]):
+ Moved here from near the bottom of the file. Release new ivar.
+ (-[WebPluginDatabase refresh]):
+ Use the plugInPaths ivar instead of calling pluginLocations().
+ Notify plugin packages when they are added to and removed from a plugin database. A plugin package will
+ unload itself when it is removed from all of its plugin databases.
+ The only really tricky thing here is that the global MIME <-> view class registrations are only modified
+ by the shared plugin DB.
+ (+[WebPluginDatabase _defaultPlugInPaths]):
+ Refactored from the old pluginLocations() function; returns the default set of plugin search paths.
+
+ * Plugins/WebBasePluginPackage.h:
+ * Plugins/WebBasePluginPackage.m:
+ (-[WebBasePluginPackage dealloc]):
+ Assert that this package has been removed from all of its containing plugin databases.
+ (-[WebBasePluginPackage finalize]):
+ ditto
+ (-[WebBasePluginPackage wasAddedToPluginDatabase:]):
+ Add plugin database to set.
+ (-[WebBasePluginPackage wasRemovedFromPluginDatabase:]):
+ Remove plugin database from set. If it was the last DB, then unload the plugin package.
+
+ * WebView/WebViewInternal.h:
+ Added instance methods to find the view class or plugin package, given a MIME type or file extension.
+ * WebView/WebViewPrivate.h:
+ Added SPI to set plugin search paths per WebView.
+ * WebView/WebView.m:
+ (-[WebView _viewClass:andRepresentationClass:forMIMEType:]):
+ New method; tries the global MIME <-> view map first; failing that, it checks the WebView's plugin DB.
+ (-[WebView _close]):
+ Close the plugin DB.
+ (-[WebView _setAdditionalWebPlugInPaths:]):
+ Create the plugin DB if necessary, and set its plugin paths.
+ (-[WebView _pluginForMIMEType:]):
+ Checks global plugin DB, falls back on WebView DB.
+ (-[WebView _pluginForExtension:]):
+ ditto
+ (-[WebView _isMIMETypeRegisteredAsPlugin:]):
+ ditto
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ Use new WebView instance methods to look for plugins.
+ (-[WebFrameBridge viewForJavaAppletWithFrame:attributeNames:attributeValues:baseURL:DOMElement:]):
+ ditto
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ ditto
+
+2006-06-20 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej
+
+ Added calls through to the WebCoreIconDatabaseBridge for all the major WebIconDatabase API. For now these calls
+ are wrapped with #ifdef's and are for debugging only.
+
+ * Misc/WebIconDatabase.h:
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary _scaleIcon:toSize:]):
+ (-[NSMutableDictionary init]):
+ (-[NSMutableDictionary iconForURL:withSize:cache:]):
+ (-[NSMutableDictionary iconURLForURL:]):
+ (-[NSMutableDictionary retainIconForURL:]):
+ (-[NSMutableDictionary releaseIconForURL:]):
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ (-[WebIconDatabase _hasIconForIconURL:]):
+ * Misc/WebIconLoader.m:
+ (-[WebIconLoader didFinishLoading]):
+
+ * Misc/WebKitLogging.h: Added a logging channel for WebIconDatabase debugging
+ * Misc/WebKitLogging.m:
+ (WebKitInitializeLoggingChannelsIfNecessary):
+
+2006-06-20 Adele Peterson <adele@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ * WebView/WebMainResourceLoader.m: Added missing header to fix build on Leopard.
+
+2006-06-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Removes the @try/@catch from the callbacks to improve performance,
+ simply check if the proxy object's connection is still valid first.
+ Listener objects are now required to be NSDistantObjects.
+
+ Adds pause, resume and step support. The debugger process use to handle this,
+ but it caused problems when there were multiple listeners.
+
+ Sends the bundle identifier in the notification userInfo dictionary along with
+ process name and process ID.
+
+ * DefaultDelegates/WebScriptDebugServer.h:
+ * DefaultDelegates/WebScriptDebugServer.m:
+ (-[WebScriptDebugServer serverQuery:]):
+ (-[WebScriptDebugServer addListener:]):
+ (-[WebScriptDebugServer removeListener:]):
+ (-[WebScriptDebugServer step]):
+ (-[WebScriptDebugServer pause]):
+ (-[WebScriptDebugServer resume]):
+ (-[WebScriptDebugServer isPaused]):
+ (-[WebScriptDebugServer suspendProcessIfPaused]):
+ (-[WebScriptDebugServer webView:didParseSource:fromURL:sourceId:forWebFrame:]):
+ (-[WebScriptDebugServer webView:didEnterCallFrame:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:willExecuteStatement:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:willLeaveCallFrame:sourceId:line:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServerPrivate.h:
+ * WebKit.exp:
+
+2006-06-19 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=5499
+ Page reload does not send any cache control headers
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]): Set a proper Cache-Control header for
+ reload requests.
+ (-[WebFrame loadRequest:]): Reset loadType to WebFrameLoadTypeStandard (after a reload, it stayed at
+ WebFrameLoadTypeReload, so _addExtraFieldsToRequest erroneously added a Cache-Control header to them).
+
+2006-06-19 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin.
+
+ - added mechanism to notify UIDelegate when part of the webview is redrawn. For now, it only
+ works for HTML views.
+
+ * WebView/WebUIDelegatePrivate.h:
+ Define a new UIDelegate method -webView:didDrawRect:
+ * WebView/WebHTMLView.m:
+ (-[WebView drawSingleRect:]):
+ Call through to UIDelegate if it implements that method. I tested that this does not impact PLT numbers
+ in the case where the delegate implements the method but does nothing in it.
+
+2006-06-19 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9452
+ Assertion failure in -[WebFramePrivate setProvisionalDataSource:]
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _checkLoadCompleteForThisFrame]): Avoid re-entering the delegate's
+ -[webView:didFailProvisionalLoadWithError:forFrame].
+
+2006-06-18 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by xenon.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=9479
+ Disassociate the inspector from the frame when it detaches from its parent
+
+ * WebInspector/WebInspector.m:
+ (-[NSWindow setWebFrame:]): Added code to (de)register with the WebFrame
+ the inspector is (no longer) targeting.
+ (-[WebInspector _webFrameDetached:]): Added. Moved the code that was previously
+ in -[inspectedWindowWillClose:] here. This is called by the WebFrame when it
+ is detached from its parent.
+ * WebInspector/WebInspectorInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+ (-[WebFrame _detachFromParent]): Added code to notify all registered inspectors
+ that the WebFrame is detaching.
+ (-[WebFrame _addInspector:]): Added.
+ (-[WebFrame _removeInspector:]): Added.
+ * WebView/WebFrameInternal.h:
+
+2006-06-18 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge shouldInterruptJavaScript]):
+ Ask the UI delegate if the script should be interrupted.
+
+ * WebView/WebUIDelegatePrivate.h:
+ Declare webViewShouldInterruptJavaScript: delegate method
+
+2006-06-17 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=9466
+ Assertion failure when dragging an image from the document into Safari's address bar
+
+ * WebView/WebFrameView.m:
+ (-[WebFrameView _setDocumentView:]): Reset the WebView's initiatedDrag flag
+ when the document view is changed.
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView draggedImage:endedAt:operation:]): Changed the ASSERT to allow
+ for drags that end after the view has been removed from the WebView.
+
+2006-06-16 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Tim O.
+
+ Exposes a distributed objects server for clients to register for script debugger calls.
+ For preformance concerns this is disabled by default, you will need to enable this per application.
+ To enable for Safari do this: defaults write com.apple.Safari WebKitScriptDebuggerEnabled -bool true
+
+ Clients will need to listen to the following distributed notification to discover servers:
+ WebScriptDebugServerDidLoadNotification
+
+ To discover servers that previously loaded before the client, the client needs to send the following notification:
+ WebScriptDebugServerQueryNotification
+
+ All servers will reply with the WebScriptDebugServerQueryReplyNotification notification that contains the
+ registered server connection name to use with distributed objects.
+
+ * DefaultDelegates/WebScriptDebugServer.h: Added.
+ * DefaultDelegates/WebScriptDebugServer.m: Added.
+ (+[WebScriptDebugServer sharedScriptDebugServer]):
+ (-[WebScriptDebugServer init]):
+ (-[WebScriptDebugServer dealloc]):
+ (-[WebScriptDebugServer serverQuery:]):
+ (-[WebScriptDebugServer listenerConnectionDidDie:]):
+ (-[WebScriptDebugServer addListener:]):
+ (-[WebScriptDebugServer removeListener:]):
+ (-[WebScriptDebugServer webView:didParseSource:fromURL:sourceId:forWebFrame:]):
+ (-[WebScriptDebugServer webView:didEnterCallFrame:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:willExecuteStatement:sourceId:line:forWebFrame:]):
+ (-[WebScriptDebugServer webView:willLeaveCallFrame:sourceId:line:forWebFrame:]):
+ * DefaultDelegates/WebScriptDebugServerPrivate.h: Added.
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge windowObjectCleared]):
+ * WebKit.exp:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebScriptDebugDelegate.m:
+ (-[WebScriptCallFrame parsedSource:fromURL:sourceId:]):
+ (-[WebScriptCallFrame enteredFrame:sourceId:line:]):
+ (-[WebScriptCallFrame hitStatement:sourceId:line:]):
+ (-[WebScriptCallFrame leavingFrame:sourceId:line:]):
+ * WebView/WebView.m:
+ (+[WebView _developerExtrasEnabled]):
+ (+[WebView _scriptDebuggerEnabled]):
+ (-[WebView _menuForElement:defaultItems:]):
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ * WebView/WebViewPrivate.h:
+
+2006-06-16 Adele Peterson <adele@apple.com>
+
+ Reviewed by Alice.
+
+ Added initialization for WKDrawBezeledTextArea.
+
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+
+2006-06-15 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Geoff and Darin.
+
+ Prefer the DWARF debugging symbols format for use in Xcode 2.3.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-06-15 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim O.
+
+ Fixed bug in WebKit support for computing but not highlighting rects for text matches.
+
+ * WebView/WebView.m:
+ (-[WebView rectsForTextMatches]):
+ leave out empty rects, and convert rects to WebView coordinates. Since this makes a batch
+ of autoreleased NSValue objects, use a local autorelease pool
+
+2006-02-11 David Kilzer <ddkilzer@kilzer.net>
+
+ Reviewed by John Sullivan.
+
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController _cancelOutstandingChecks]):
+ add nil check before calling CFSetApplyFunction
+
+2006-06-14 Levi Weintraub <lweintraub@apple.com>
+
+ Reviewed by justin
+
+ <http://bugs.webkit.org/show_bug.cgi?id=7580>
+ TinyMCE: Implement execCommand(formatBlock, ...)
+
+ * English.lproj/Localizable.strings:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge nameForUndoAction:]):
+
+2006-06-14 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4577988> GC: WebPluginController uses inefficient resurrecting enumeration
+
+ * Plugins/WebPluginController.m:
+ (cancelOutstandingCheck):
+ (-[WebPluginController _cancelOutstandingChecks]):
+ Use CFSetApplyFunction() instead of an enumerator to guard against modifications to the set while enumerating.
+
+2006-06-13 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim O.
+
+ - fixed <rdar://problem/4498606> REGRESSION (417.8-420+): 3 missing items (but extra separators) in context
+ menu in Mail message body
+
+ * WebView/WebView.m:
+ (-[WebView _menuForElement:defaultItems:]):
+ Add special-case hackery to recover from this SPI -> API mismatch.
+
+2006-06-13 Tim Omernick <timo@apple.com>
+
+ Reviewed by Anders.
+
+ Fixed a recently-introduced assertion failure when handling 404 errors.
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _handleFallbackContent]):
+ Use the -[WebFrame _bridge] instead of -[WebDataSource _bridge]. The former is not valid until the data
+ source has been committed, which is not the case when the resource fails to load. The latter is safe to call
+ at any time. This broke last night with Maciej's change to WebFrameResourceLoader. The old code used to
+ call -[WebFrame _bridge].
+
+2006-06-13 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Geoff.
+
+ http://bugs.webkit.org/show_bug.cgi?id=9406
+ REGRESSION: fix for bug 9390 broke two layout tests
+
+ * Plugins/WebPluginDatabase.h:
+ (-[WebPluginDatabase isMIMETypeRegistered:]):
+ Add new function isMIMETypeRegistered which returns whether a given MIME type has a
+ plugin registered.
+
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase init]):
+ Init set of registered MIME types.
+
+ (-[WebPluginDatabase refresh]):
+ Add and remove MIME types from the set of registered MIME types when registering and unregistering
+ plugin MIME types.
+
+ (-[WebPluginDatabase dealloc]):
+ Release set of registered MIME types.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ Use isMIMETypeRegistered here.
+
+2006-06-12 Maciej Stachowiak <mjs@apple.com>
+
+ - fix for cocoa exception (whoops)
+
+ * WebView/WebView.m:
+ (+[WebView _generatedMIMETypeForURLScheme:]): put this back
+ * WebView/WebDataSource.m:
+ (+[WebDataSource _generatedMIMETypeForURLScheme:]): call WebView
+
+2006-06-12 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - remove use of WebView and related from WebMainResourceLoader
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (+[WebDataSource _generatedMIMETypeForURLScheme:]):
+ (+[WebDataSource _representationExistsForURLScheme:]):
+ (+[WebDataSource _canShowMIMEType:]):
+ (-[WebDataSource _handleFallbackContent]):
+ (-[WebDataSource _decidePolicyForMIMEType:decisionListener:]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _isMainFrame]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader willSendRequest:redirectResponse:]):
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ (-[WebMainResourceLoader checkContentPolicyForResponse:]):
+ (-[WebMainResourceLoader loadWithRequestNow:]):
+ * WebView/WebView.m:
+
+2006-06-12 Tim Omernick <timo@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4526052> intermittent assertion failure in -[WebBasePluginPackage dealloc] running layout tests
+
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage _initWithPath:]):
+ Renamed from -initWithPath:. Instead of releasing/deallocating self on error, return NO.
+ (-[WebNetscapePluginPackage initWithPath:]):
+ Call the new -_initWithPath:. If it returns NO, unload the plugin package before deallocating it.
+
+2006-06-11 Darin Adler <darin@apple.com>
+
+ - try to fix Windows build
+
+ * COM/WebKitDLL.cpp: (loadResourceIntoArray): Use Vector<char> instead of
+ DeprecatedByteArray.
+
+2006-06-11 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Tim H.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8672
+ Red outline from web inspector reappears after inspector is closed
+
+ * WebInspector/WebInspector.m:
+ (-[NSWindow windowWillClose:]): Added a call to setWebFrame to avoid further
+ load progress notifications.
+ (-[NSWindow setWebFrame:]): Changed to resign the WebView's hostWindow rather
+ than its window for close notifications, to avoid resigning from all windows' close
+ notifications (including the inspector window's) when the WebView is in a hidden tab.
+ Also changed to prevent highlighting the initial focused node.
+
+2006-06-11 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Tim.
+
+ http://bugs.webkit.org/show_bug.cgi?id=9390
+ Move full-frame plugins to WebCore
+
+ * Plugins/WebBaseNetscapePluginStream.h:
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream instance]):
+ Add instance method which returns the plugin instance.
+
+ * Plugins/WebBasePluginPackage.h:
+ Add WebPluginManualLoader protocol
+
+ * Plugins/WebNetscapePluginDocumentView.h: Removed.
+ * Plugins/WebNetscapePluginDocumentView.m: Removed.
+
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView initWithFrame:plugin:URL:baseURL:MIMEType:attributeKeys:attributeValues:loadManually:]):
+ (-[WebNetscapePluginEmbeddedView dealloc]):
+ (-[WebNetscapePluginEmbeddedView didStart]):
+ (-[WebNetscapePluginEmbeddedView pluginView:receivedResponse:]):
+ (-[WebNetscapePluginEmbeddedView pluginView:receivedData:]):
+ (-[WebNetscapePluginEmbeddedView pluginView:receivedError:]):
+ (-[WebNetscapePluginEmbeddedView pluginViewFinishedLoading:]):
+ (-[WebNetscapePluginEmbeddedView redeliverStream]):
+ Make WebNetscapePluginEmbeddedView support the WebPluginManualLoader protocol. It creates a plugin stream and feeds the
+ data manually. Much of this code has been copied from WebNetscapePluginRepresentation.
+
+ * Plugins/WebNetscapePluginRepresentation.h: Removed.
+ * Plugins/WebNetscapePluginRepresentation.m: Removed.
+
+ * Plugins/WebPluginController.h:
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController pluginView:receivedResponse:]):
+ (-[WebPluginController pluginView:receivedData:]):
+ (-[WebPluginController pluginView:receivedError:]):
+ (-[WebPluginController pluginViewFinishedLoading:]):
+ Make WebPluginController support the WebPluginManualLoader protocol so it can feed data manually to WebKit plugins.
+
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase refresh]):
+ Use WebHTMLView and WebHTMLRepresentation when registering/unregistering plug-in MIME types.
+
+ * Plugins/WebPluginDocumentView.h: Removed.
+ * Plugins/WebPluginDocumentView.m: Removed.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge pluginViewWithPackage:attributeNames:attributeValues:baseURL:DOMElement:loadManually:]):
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:loadManually:]):
+ Add loadManually argument.
+
+ (-[WebFrameBridge redirectDataToPlugin:]):
+ Call down to the HTML representation.
+
+ (-[WebFrameBridge viewForJavaAppletWithFrame:attributeNames:attributeValues:baseURL:DOMElement:]):
+ Pass NO to loadManually.
+
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ Explicitly check if the MIME type is supported by a plug-in instead of checking the view class.
+
+ * WebCoreSupport/WebViewFactory.m:
+ (-[WebViewFactory pluginSupportsMIMEType:]):
+ New function which returns whether any plugins support a given MIME type.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Update for removed files.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _reloadForPluginChanges]):
+ Remove view type checks.
+
+ (-[WebFrame _recursive_pauseNullEventsForAllNetscapePlugins]):
+ (-[WebFrame _recursive_resumeNullEventsForAllNetscapePlugins]):
+ Remove FIXME comments.
+
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation _redirectDataToManualLoader:forPluginView:]):
+ New function which redirects incoming data to a manual loader.
+
+ (-[WebHTMLRepresentation receivedData:withDataSource:]):
+ (-[WebHTMLRepresentation receivedError:withDataSource:]):
+ (-[WebHTMLRepresentation finishedLoadingWithDataSource:]):
+ Optionally redirect incoming data.
+
+ * WebView/WebHTMLRepresentationPrivate.h:
+
+2006-06-09 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick and Dave Hyatt.
+
+ WebKit support for computing but not highlighting rects for text matches.
+
+ * WebView/WebHTMLViewPrivate.h:
+ added markedTextMatchesAreHighlighted/setMarkedTextMatchesAreHighlighted and
+ rectsForTextMatches, and renamed related methods for clarity/consistency
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView markAllMatchesForText:caseSensitive:]):
+ renamed, calls similarly-renamed method
+ (-[WebHTMLView setMarkedTextMatchesAreHighlighted:]):
+ new method, calls through to bridge
+ (-[WebHTMLView markedTextMatchesAreHighlighted]):
+ ditto
+ (-[WebHTMLView unmarkAllTextMatches]):
+ renamed
+ (-[WebHTMLView rectsForTextMatches]):
+ new method, calls through to bridge
+
+ * WebView/WebViewPrivate.h:
+ added rectsForTextMatches, renamed other methods (and added highlight: parameter)
+ * WebView/WebView.m:
+ (-[WebView markAllMatchesForText:caseSensitive:highlight:]):
+ renamed for clarity/consistency, and now has highlight: parameter, which is passed down
+ (-[WebView unmarkAllTextMatches]):
+ renamed for clarity/consistency, and calls similarly-renamed method lower down. diff got
+ confused with the end of this and the end of the next method.
+ (-[WebView rectsForTextMatches]):
+ new method, calls through to WebHTMLView as related methods currently do
+
+2006-06-10 Graham Dennis <Graham.Dennis@gmail.com>
+
+ <http://bugs.webkit.org/show_bug.cgi?id=9384>
+ WebView's initWithCoder: method does not set useBackForwardList
+ correctly
+
+ Reviewed by John Sullivan.
+
+ * WebView/WebView.m:
+ (-[WebView initWithCoder:]):
+ Make sure that the function variable useBackForwardList is correctly
+ set, so that the copy in the _private ivar is set.
+
+2006-06-09 David Hyatt <hyatt@apple.com>
+
+ Rename updateFocusState to updateActiveState.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateActiveState]):
+ (-[WebHTMLView viewDidMoveToWindow]):
+ (-[WebHTMLView windowDidBecomeKey:]):
+ (-[WebHTMLView windowDidResignKey:]):
+ (-[WebHTMLView becomeFirstResponder]):
+ (-[WebHTMLView resignFirstResponder]):
+ (-[WebHTMLView _formControlIsBecomingFirstResponder:]):
+ (-[WebHTMLView _formControlIsResigningFirstResponder:]):
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-06-09 David Hyatt <hyatt@apple.com>
+
+ Rename displaysWithFocusAttributes to isActive.
+
+ Reviewed by sfalken
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateFocusState]):
+
+2006-06-08 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by levi
+
+ <http://bugs.webkit.org/show_bug.cgi?id=4468>
+ Implement execCommand(Insert{Un}OrderedList)
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _findFrameWithSelection]): Removed an assertion
+ that we only have one frame with a selection.
+ * WebView/WebView.m:
+ (-[WebView selectedFrame]): Ditto.
+
+2006-06-08 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin and John.
+
+ <rdar://problem/3600734> API: please add a way to turn vertical scrollbar
+ always on (for Mail, to avoid reflow when typing)
+
+ Adds new methods to lock the scrolling mode on WebDynamicScrollBarsView.
+ Locking the scroll mode prevents WebCore from changing it as needed.
+ Also adds an SPI on WebView that will lock the "always on" mode
+ for each scroller.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDynamicScrollBarsView.h:
+ * WebView/WebDynamicScrollBarsView.m:
+ (-[WebDynamicScrollBarsView setAllowsScrolling:]):
+ (-[WebDynamicScrollBarsView allowsScrolling]):
+ (-[WebDynamicScrollBarsView setAllowsHorizontalScrolling:]):
+ (-[WebDynamicScrollBarsView setAllowsVerticalScrolling:]):
+ (-[WebDynamicScrollBarsView setHorizontalScrollingMode:]):
+ (-[WebDynamicScrollBarsView setVerticalScrollingMode:]):
+ (-[WebDynamicScrollBarsView setScrollingMode:]):
+ (-[WebDynamicScrollBarsView setHorizontalScrollingModeLocked:]):
+ (-[WebDynamicScrollBarsView setVerticalScrollingModeLocked:]):
+ (-[WebDynamicScrollBarsView setScrollingModesLocked:]):
+ (-[WebDynamicScrollBarsView horizontalScrollingModeLocked]):
+ (-[WebDynamicScrollBarsView verticalScrollingModeLocked]):
+ * WebView/WebView.m:
+ (-[WebView setAlwaysShowVerticalScroller:]):
+ (-[WebView alwaysShowVerticalScroller]):
+ (-[WebView setAlwaysShowHorizontalScroller:]):
+ (-[WebView alwaysShowHorizontalScroller]):
+ * WebView/WebViewPrivate.h:
+
+2006-06-08 Darin Adler <darin@apple.com>
+
+ Reviewed by Justin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8616
+ REGRESSION: TinyMCE: Crash on Undo
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _topHTMLView]): Added.
+ (-[WebHTMLView _isTopHTMLView]): Added.
+ (-[WebHTMLView _insideAnotherHTMLView]): Changed to use _topHTMLView.
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ Forward to the top HTML view, so that only the top view ever starts a dragging operation.
+ Change dragging code to not assume that the dragged node is in the current view's document.
+ Added checks that the node is an element in a couple places and coordinate conversions.
+ (-[WebHTMLView _mayStartDragAtEventLocation:]): Forward to the top HTML view.
+ (-[WebHTMLView addMouseMovedObserver]): Change to do nothing when the dataSource field is 0,
+ since we now use the dataSource field to get to the WebView.
+ (-[WebHTMLView removeMouseMovedObserver]): Added a comment.
+ (-[WebHTMLView dragImage:at:offset:event:pasteboard:source:slideBack:]):
+ Forward to the top HTML view.
+ (-[WebHTMLView draggingSourceOperationMaskForLocal:]): Assert that it's the top HTML view.
+ (-[WebHTMLView draggedImage:movedTo:]): Ditto.
+ (-[WebHTMLView draggedImage:endedAt:operation:]): Ditto.
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]): Ditto.
+ (-[WebHTMLView _canProcessDragWithDraggingInfo:]): Ditto.
+ (-[WebHTMLView _isMoveDrag]): Ditto.
+ (-[WebHTMLView draggingUpdatedWithDraggingInfo:actionMask:]): Ditto.
+ (-[WebHTMLView draggingCancelledWithDraggingInfo:]): Ditto.
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]): Ditto. Also added code to work
+ with the appropriate bridge when receiving a drag. This fixes the problem where the
+ top level frame got a selection intended for the inner frame; the source of the bug.
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): Added code to convert the coordinates
+ so this works properly when returning an element from an inner frame.
+ (-[WebHTMLView setDataSource:]): Added a call to addMouseMovedObserver, needed now that
+ addMouseMovedObserver won't do anything if called when dataSource is nil.
+ (-[WebHTMLView _delegateDragSourceActionMask]): Forward to the top HTML view.
+
+ * WebView/WebView.m:
+ (-[WebViewPrivate dealloc]): Removed code to release dragCaretBridge since that field
+ is now gone.
+ (-[WebView moveDragCaretToPoint:]): Always call the main frame's bridge, since the
+ drag caret is now a page-level item. Later we'll move it to the page bridge.
+ (-[WebView removeDragCaret]): Ditto.
+
+2006-06-07 David Hyatt <hyatt@apple.com>
+
+ Add support for custom highlighting to WebKit.
+
+ Reviewed by justin
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge paintCustomHighlight:forBox:onLine:behindText:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _highlighterForType:]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-06-07 Adele Peterson <adele@apple.com>
+
+ Reviewed by Hyatt.
+
+ Added resources for missingImage and textAreaResizeCorner.
+
+ * COM/WebKitDLL.cpp:
+ (loadResourceIntoArray): Added. Returns a DeprecatedByteArray with the resource's data.
+ * WebKit.vcproj/WebKit.rc: Added missing image and resize pngs as resources.
+ * WebKit.vcproj/WebKit.vcproj: Added pngs.
+ * WebKit.vcproj/missingImage.png: Added.
+ * WebKit.vcproj/resource.h: Added entries for pngs.
+ * WebKit.vcproj/textAreaResizeCorner.png: Added.
+
+2006-06-07 David Hyatt <hyatt@apple.com>
+
+ Add SPI for setting and removing custom highlighters.
+
+ Reviewed by Tim H
+
+ * WebView/WebHTMLView.m:
+ (-[WebTextCompleteController dealloc]):
+ (-[WebHTMLView _setHighlighter:ofType:]):
+ (-[WebHTMLView _removeHighlighterOfType:]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-06-06 Adele Peterson <adele@apple.com>
+
+ Reviewed by Justin.
+
+ * COM/WebView.cpp:
+ (WebView::keyPress): Added case for VK_RETURN.
+
+2006-06-06 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by John.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _reloadForPluginChanges]):
+ Don't traverse the view hierarchy looking for plugin views. Instead, just
+ ask the frame whether it contains any plugins.
+
+2006-06-03 Steve Falkenburg <sfalken@apple.com>
+
+ Reviewed by hyatt.
+
+ Add implementation of loadHTMLString for Spinneret
+
+ * COM/WebFrame.cpp:
+ (WebFrame::loadHTMLString):
+
+2006-06-02 Steve Falkenburg <sfalken@apple.com>
+
+ Reviewed by darin.
+
+ New hosting for Spinneret to avoid static linking
+
+ * COM: Added.
+ * COM/Interfaces: Added.
+ * COM/Interfaces/DOMCSS.idl: Added.
+ * COM/Interfaces/DOMCore.idl: Added.
+ * COM/Interfaces/DOMHTML.idl: Added.
+ * COM/Interfaces/DOMRange.idl: Added.
+ * COM/Interfaces/IWebArchive.idl: Added.
+ * COM/Interfaces/IWebAttributedString.idl: Added.
+ * COM/Interfaces/IWebBackForwardList.idl: Added.
+ * COM/Interfaces/IWebDataSource.idl: Added.
+ * COM/Interfaces/IWebDocument.idl: Added.
+ * COM/Interfaces/IWebDownload.idl: Added.
+ * COM/Interfaces/IWebEditingDelegate.idl: Added.
+ * COM/Interfaces/IWebError.idl: Added.
+ * COM/Interfaces/IWebFrame.idl: Added.
+ * COM/Interfaces/IWebFrameLoadDelegate.idl: Added.
+ * COM/Interfaces/IWebFrameView.idl: Added.
+ * COM/Interfaces/IWebHistoryItem.idl: Added.
+ * COM/Interfaces/IWebIconDatabase.idl: Added.
+ * COM/Interfaces/IWebImage.idl: Added.
+ * COM/Interfaces/IWebMutableURLRequest.idl: Added.
+ * COM/Interfaces/IWebNotification.idl: Added.
+ * COM/Interfaces/IWebPolicyDelegate.idl: Added.
+ * COM/Interfaces/IWebPreferences.idl: Added.
+ * COM/Interfaces/IWebResource.idl: Added.
+ * COM/Interfaces/IWebResourceLoadDelegate.idl: Added.
+ * COM/Interfaces/IWebScriptObject.idl: Added.
+ * COM/Interfaces/IWebUIDelegate.idl: Added.
+ * COM/Interfaces/IWebURLAuthenticationChallenge.idl: Added.
+ * COM/Interfaces/IWebURLRequest.idl: Added.
+ * COM/Interfaces/IWebURLResponse.idl: Added.
+ * COM/Interfaces/IWebUndoManager.idl: Added.
+ * COM/Interfaces/IWebView.idl: Added.
+ * COM/Interfaces/WebKit.idl: Added.
+ * COM/WebBackForwardList.cpp: Added.
+ (WebBackForwardList::WebBackForwardList):
+ (WebBackForwardList::~WebBackForwardList):
+ (WebBackForwardList::createInstance):
+ (WebBackForwardList::QueryInterface):
+ (WebBackForwardList::AddRef):
+ (WebBackForwardList::Release):
+ (WebBackForwardList::addItem):
+ (WebBackForwardList::goBack):
+ (WebBackForwardList::goForward):
+ (WebBackForwardList::goToItem):
+ (WebBackForwardList::backItem):
+ (WebBackForwardList::currentItem):
+ (WebBackForwardList::forwardItem):
+ (WebBackForwardList::backListWithLimit):
+ (WebBackForwardList::forwardListWithLimit):
+ (WebBackForwardList::capacity):
+ (WebBackForwardList::setCapacity):
+ (WebBackForwardList::backListCount):
+ (WebBackForwardList::forwardListCount):
+ (WebBackForwardList::containsItem):
+ (WebBackForwardList::itemAtIndex):
+ (WebBackForwardList::setPageCacheSize):
+ (WebBackForwardList::pageCacheSize):
+ * COM/WebBackForwardList.h: Added.
+ * COM/WebDataSource.cpp: Added.
+ (WebDataSource::WebDataSource):
+ (WebDataSource::~WebDataSource):
+ (WebDataSource::createInstance):
+ (WebDataSource::QueryInterface):
+ (WebDataSource::AddRef):
+ (WebDataSource::Release):
+ (WebDataSource::initWithRequest):
+ (WebDataSource::data):
+ (WebDataSource::representation):
+ (WebDataSource::webFrame):
+ (WebDataSource::initialRequest):
+ (WebDataSource::request):
+ (WebDataSource::response):
+ (WebDataSource::textEncodingName):
+ (WebDataSource::isLoading):
+ (WebDataSource::pageTitle):
+ (WebDataSource::unreachableURL):
+ (WebDataSource::webArchive):
+ (WebDataSource::mainResource):
+ (WebDataSource::subresources):
+ (WebDataSource::subresourceForURL):
+ (WebDataSource::addSubresource):
+ * COM/WebDataSource.h: Added.
+ * COM/WebFrame.cpp: Added.
+ (WebFrame::WebFramePrivate::WebFramePrivate):
+ (WebFrame::WebFramePrivate::~WebFramePrivate):
+ (WebFrame::WebFrame):
+ (WebFrame::~WebFrame):
+ (WebFrame::createInstance):
+ (WebFrame::QueryInterface):
+ (WebFrame::AddRef):
+ (WebFrame::Release):
+ (WebFrame::initWithName):
+ (WebFrame::name):
+ (WebFrame::webView):
+ (WebFrame::frameView):
+ (WebFrame::DOMDocument):
+ (WebFrame::frameElement):
+ (WebFrame::loadRequest):
+ (WebFrame::loadData):
+ (WebFrame::loadHTMLString):
+ (WebFrame::loadAlternateHTMLString):
+ (WebFrame::loadArchive):
+ (WebFrame::dataSource):
+ (WebFrame::provisionalDataSource):
+ (WebFrame::stopLoading):
+ (WebFrame::reload):
+ (WebFrame::findFrameNamed):
+ (WebFrame::parentFrame):
+ (WebFrame::childFrames):
+ (WebFrame::paint):
+ (WebFrame::impl):
+ (WebFrame::loadDataSource):
+ (WebFrame::loading):
+ (WebFrame::goToItem):
+ (WebFrame::loadItem):
+ (WebSystemMainMemory):
+ (WebFrame::getObjectCacheSize):
+ (WebFrame::receivedRedirect):
+ (WebFrame::receivedResponse):
+ (WebFrame::receivedData):
+ (WebFrame::receivedAllData):
+ (WebFrame::openURL):
+ (WebFrame::submitForm):
+ (WebFrame::setTitle):
+ (WebFrame::setStatusText):
+ * COM/WebFrame.h: Added.
+ * COM/WebHistoryItem.cpp: Added.
+ (WebHistoryItem::WebHistoryItem):
+ (WebHistoryItem::~WebHistoryItem):
+ (WebHistoryItem::createInstance):
+ (WebHistoryItem::QueryInterface):
+ (WebHistoryItem::AddRef):
+ (WebHistoryItem::Release):
+ (WebHistoryItem::initWithURLString):
+ (WebHistoryItem::originalURLString):
+ (WebHistoryItem::URLString):
+ (WebHistoryItem::title):
+ (WebHistoryItem::lastVisitedTimeInterval):
+ (WebHistoryItem::setAlternateTitle):
+ (WebHistoryItem::alternateTitle):
+ (WebHistoryItem::icon):
+ * COM/WebHistoryItem.h: Added.
+ * COM/WebIconDatabase.cpp: Added.
+ (WebIconDatabase::WebIconDatabase):
+ (WebIconDatabase::~WebIconDatabase):
+ (WebIconDatabase::createInstance):
+ (WebIconDatabase::QueryInterface):
+ (WebIconDatabase::AddRef):
+ (WebIconDatabase::Release):
+ (WebIconDatabase::sharedIconDatabase):
+ (WebIconDatabase::iconForURL):
+ (WebIconDatabase::defaultIconWithSize):
+ (WebIconDatabase::retainIconForURL):
+ (WebIconDatabase::releaseIconForURL):
+ (WebIconDatabase::delayDatabaseCleanup):
+ (WebIconDatabase::allowDatabaseCleanup):
+ * COM/WebIconDatabase.h: Added.
+ * COM/WebKitClassFactory.cpp: Added.
+ (WebKitClassFactory::WebKitClassFactory):
+ (WebKitClassFactory::~WebKitClassFactory):
+ (WebKitClassFactory::QueryInterface):
+ (WebKitClassFactory::AddRef):
+ (WebKitClassFactory::Release):
+ (WebKitClassFactory::CreateInstance):
+ (WebKitClassFactory::LockServer):
+ * COM/WebKitClassFactory.h: Added.
+ * COM/WebKitDLL.cpp: Added.
+ (DllMain):
+ (DllGetClassObject):
+ (DllCanUnloadNow):
+ (DllUnregisterServer):
+ (DllRegisterServer):
+ * COM/WebKitDLL.h: Added.
+ * COM/WebMutableURLRequest.cpp: Added.
+ (WebMutableURLRequest::WebMutableURLRequest):
+ (WebMutableURLRequest::~WebMutableURLRequest):
+ (WebMutableURLRequest::createInstance):
+ (WebMutableURLRequest::QueryInterface):
+ (WebMutableURLRequest::AddRef):
+ (WebMutableURLRequest::Release):
+ (WebMutableURLRequest::requestWithURL):
+ (WebMutableURLRequest::allHTTPHeaderFields):
+ (WebMutableURLRequest::cachePolicy):
+ (WebMutableURLRequest::HTTPBody):
+ (WebMutableURLRequest::HTTPBodyStream):
+ (WebMutableURLRequest::HTTPMethod):
+ (WebMutableURLRequest::HTTPShouldHandleCookies):
+ (WebMutableURLRequest::initWithURL):
+ (WebMutableURLRequest::mainDocumentURL):
+ (WebMutableURLRequest::timeoutInterval):
+ (WebMutableURLRequest::URL):
+ (WebMutableURLRequest::valueForHTTPHeaderField):
+ (WebMutableURLRequest::addValue):
+ (WebMutableURLRequest::setAllHTTPHeaderFields):
+ (WebMutableURLRequest::setCachePolicy):
+ (WebMutableURLRequest::setHTTPBody):
+ (WebMutableURLRequest::setHTTPBodyStream):
+ (WebMutableURLRequest::setHTTPMethod):
+ (WebMutableURLRequest::setHTTPShouldHandleCookies):
+ (WebMutableURLRequest::setMainDocumentURL):
+ (WebMutableURLRequest::setTimeoutInterval):
+ (WebMutableURLRequest::setURL):
+ (WebMutableURLRequest::setValue):
+ (WebMutableURLRequest::setFormData):
+ (WebMutableURLRequest::formData):
+ * COM/WebMutableURLRequest.h: Added.
+ * COM/WebView.cpp: Added.
+ (WebView::WebView):
+ (WebView::~WebView):
+ (WebView::createInstance):
+ (WebView::mouseMoved):
+ (WebView::mouseDown):
+ (WebView::mouseUp):
+ (WebView::mouseDoubleClick):
+ (WebView::keyPress):
+ (registerWebView):
+ (WebViewWndProc):
+ (calculateScrollDelta):
+ (scrollMessageForKey):
+ (WebView::goToItem):
+ (WebView::QueryInterface):
+ (WebView::AddRef):
+ (WebView::Release):
+ (WebView::canShowMIMEType):
+ (WebView::canShowMIMETypeAsHTML):
+ (WebView::MIMETypesShownAsHTML):
+ (WebView::setMIMETypesShownAsHTML):
+ (WebView::URLFromPasteboard):
+ (WebView::URLTitleFromPasteboard):
+ (WebView::initWithFrame):
+ (WebView::setUIDelegate):
+ (WebView::uiDelegate):
+ (WebView::setResourceLoadDelegate):
+ (WebView::resourceLoadDelegate):
+ (WebView::setDownloadDelegate):
+ (WebView::downloadDelegate):
+ (WebView::setFrameLoadDelegate):
+ (WebView::frameLoadDelegate):
+ (WebView::setPolicyDelegate):
+ (WebView::policyDelegate):
+ (WebView::mainFrame):
+ (WebView::backForwardList):
+ (WebView::setMaintainsBackForwardList):
+ (WebView::goBack):
+ (WebView::goForward):
+ (WebView::goToBackForwardItem):
+ (WebView::setTextSizeMultiplier):
+ (WebView::textSizeMultiplier):
+ (WebView::setApplicationNameForUserAgent):
+ (WebView::applicationNameForUserAgent):
+ (WebView::setCustomUserAgent):
+ (WebView::customUserAgent):
+ (WebView::userAgentForURL):
+ (WebView::supportsTextEncoding):
+ (WebView::setCustomTextEncodingName):
+ (WebView::customTextEncodingName):
+ (WebView::setMediaStyle):
+ (WebView::mediaStyle):
+ (WebView::stringByEvaluatingJavaScriptFromString):
+ (WebView::windowScriptObject):
+ (WebView::setPreferences):
+ (WebView::preferences):
+ (WebView::setPreferencesIdentifier):
+ (WebView::preferencesIdentifier):
+ (WebView::setHostWindow):
+ (WebView::hostWindow):
+ (WebView::searchFor):
+ (WebView::registerViewClass):
+ (WebView::takeStringURLFrom):
+ (WebView::stopLoading):
+ (WebView::reload):
+ (WebView::canGoBack):
+ (WebView::canGoForward):
+ (WebView::canMakeTextLarger):
+ (WebView::makeTextLarger):
+ (WebView::canMakeTextSmaller):
+ (WebView::makeTextSmaller):
+ (WebView::computedStyleForElement):
+ (WebView::editableDOMRangeForPoint):
+ (WebView::setSelectedDOMRange):
+ (WebView::selectedDOMRange):
+ (WebView::selectionAffinity):
+ (WebView::setEditable):
+ (WebView::isEditable):
+ (WebView::setTypingStyle):
+ (WebView::typingStyle):
+ (WebView::setSmartInsertDeleteEnabled):
+ (WebView::smartInsertDeleteEnabled):
+ (WebView::setContinuousSpellCheckingEnabled):
+ (WebView::isContinuousSpellCheckingEnabled):
+ (WebView::spellCheckerDocumentTag):
+ (WebView::undoManager):
+ (WebView::setEditingDelegate):
+ (WebView::editingDelegate):
+ (WebView::styleDeclarationWithText):
+ (WebView::replaceSelectionWithNode):
+ (WebView::replaceSelectionWithText):
+ (WebView::replaceSelectionWithMarkupString):
+ (WebView::replaceSelectionWithArchive):
+ (WebView::deleteSelection):
+ (WebView::applyStyle):
+ (WebView::copy):
+ (WebView::cut):
+ (WebView::paste):
+ (WebView::copyFont):
+ (WebView::pasteFont):
+ (WebView::delete_):
+ (WebView::pasteAsPlainText):
+ (WebView::pasteAsRichText):
+ (WebView::changeFont):
+ (WebView::changeAttributes):
+ (WebView::changeDocumentBackgroundColor):
+ (WebView::changeColor):
+ (WebView::alignCenter):
+ (WebView::alignJustified):
+ (WebView::alignLeft):
+ (WebView::alignRight):
+ (WebView::checkSpelling):
+ (WebView::showGuessPanel):
+ (WebView::performFindPanelAction):
+ (WebView::startSpeaking):
+ (WebView::stopSpeaking):
+ (WebView::viewWindow):
+ * COM/WebView.h: Added.
+ * WebKit.vcproj: Added.
+ * WebKit.vcproj/Interfaces.vcproj: Added.
+ * WebKit.vcproj/WebKit.def: Added.
+ * WebKit.vcproj/WebKit.rc: Added.
+ * WebKit.vcproj/WebKit.sln: Added.
+ * WebKit.vcproj/WebKit.vcproj: Added.
+ * WebKit.vcproj/WebKitGUID.vcproj: Added.
+ * WebKit.vcproj/autoversion.h: Added.
+ * WebKit.vcproj/resource.h: Added.
+
+2006-06-02 Darin Adler <darin@apple.com>
+
+ * WebCoreSupport/WebImageRendererFactory.m: Fix crash on Safari startup
+ by include NSObject as a superclass (oops!).
+
+2006-06-01 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - WebCore doesn't need to load WebKit images any more; removed code for that
+
+ * Resources/missing_image.tiff: Removed.
+ * WebCoreSupport/WebImageRendererFactory.h: Removed.
+
+ * WebCoreSupport/WebImageRendererFactory.m: Moved @interface in here.
+ Removed all but the "threaded decoding" calls that older Safari calls.
+ This file can go altogether when compatibility with that older Safari
+ is no longer needed.
+
+ * WebKit.xcodeproj/project.pbxproj: Removed WebImageRendererFactory.h
+ and missing_image.tiff.
+
+ * WebView/WebFrameView.m: (-[WebFrameView initWithFrame:]): Removed call
+ to [WebImageRendererFactory createSharedFactory].
+
+2006-06-01 Brady Eidson <beidson@apple.com>
+
+ Reviewed by Maciej.
+
+ Simple changes to hook up the new WebCore based Icon Database
+ for testing.
+
+ * ChangeLog:
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _applicationWillTerminate:]):
+ * Misc/WebIconDatabasePrivate.h:
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-06-01 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=6309
+ multiple problems prevent bookmarking/back button technique for AJAX/DHTML applications from working
+
+ * Misc/WebNSURLExtras.m:
+ (-[NSString _webkit_URLFragment]):
+ Don't include the "#" character in the fragment.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge historyURL:]):
+ New function, returns the history URL for a given position in the back/forward list
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadItem:withLoadType:]):
+ Always call scrollToAnchorWithURL, even if there is no fragment. This way we keep the WebCore frame's
+ URL up-to-date.
+
+2006-06-01 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - fixed "REGRESSION: Can't order from Pizza Hut (ToT, 05/24/06)"
+ http://bugs.webkit.org/show_bug.cgi?id=9103
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _willSendRequest:forResource:redirectResponse:]): Set up the
+ User-Agent header.
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebLoader.m:
+ (-[NSURLProtocol willSendRequest:redirectResponse:]): Pass a mutable URL request
+ so the above can work.
+
+2006-06-01 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ * WebView/WebFrameView.m:
+ (+[WebFrameView _canShowMIMETypeAsHTML:]):
+ Use _webkit_objectForMIMEType here so we'll get an object back for "text/".
+
+2006-05-31 David Hyatt <hyatt@apple.com>
+
+ Make programmatic focus/blur actually work on sub-frames. Make the
+ top-level UI delegate get called for deactivation of windows.
+
+ Reviewed by darin
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge activateWindow]):
+ (-[WebFrameBridge deactivateWindow]):
+ (-[WebFrameBridge loadURL:referrer:reload:userGesture:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+=== WebKit-521.12 ===
+
+2006-05-26 David Harrison <harrison@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4514529> Add a list type parameter and a return value to _increaseSelectionListLevel
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _increaseSelectionListLevel]):
+ - Now returns DOMNode*
+
+ (-[WebHTMLView _increaseSelectionListLevelOrdered]):
+ (-[WebHTMLView _increaseSelectionListLevelUnordered]):
+ - Added. These also return DOMNode*
+
+ * WebView/WebHTMLViewPrivate.h:
+ - Updated as above
+
+2006-05-25 Tim Omernick <timo@apple.com>
+
+ Reviewed by Anders.
+
+ <http://bugs.webkit.org/show_bug.cgi?id=8347>
+ REGRESSION: Flash movie audible but not visible until window is resized
+
+ * Plugins/WebNetscapePluginDocumentView.m:
+ (-[WebNetscapePluginDocumentView dataSourceUpdated:]):
+ Layout if needed here. Maciej recently removed the "LayoutAcceptable" frame state, which used to
+ cause plugin document views to lay out immediately upon receiving data. This call to -layout has
+ the same effect.
+
+=== WebKit-521.11.1 ===
+
+2006-05-25 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Tim O.
+
+ <rdar://problem/4559808> WebKit fails to compile for ppc64
+ <rdar://problem/4522085> 64-bit: WebKit uses FSSpec which is not available in 64-bit
+ Gets WebKit building under 64-bit. Rename WebNSInt and WebNSUInt to WebNSInteger and WebNSUInteger.
+ Start using WebNSInteger where we need to match AppKit API usage of NSInteger.
+
+ HIWebView and a couple of helper functions are disabled until they can be moved off of QuickDraw.
+ <rdar://problem/4561772> HIWebView needs to be reworked to not use QuickDraw, needed for 64-bit
+
+ * Carbon/CarbonUtils.m: disabled this file in 64-bit <rdar://problem/4561772>
+ * Carbon/CarbonWindowAdapter.m:
+ (-[CarbonWindowAdapter initWithCarbonWindowRef:takingOwnership:disableOrdering:carbon:]):
+ * Carbon/CarbonWindowFrame.m:
+ (+[CarbonWindowFrame frameRectForContentRect:styleMask:]):
+ (+[CarbonWindowFrame contentRectForFrameRect:styleMask:]):
+ (+[CarbonWindowFrame minFrameSizeForMinContentSize:styleMask:]):
+ (-[CarbonWindowFrame frameRectForContentRect:styleMask:]):
+ (-[CarbonWindowFrame contentRectForFrameRect:styleMask:]):
+ (-[CarbonWindowFrame minFrameSizeForMinContentSize:styleMask:]):
+ * Carbon/HIViewAdapter.m: disabled this file in 64-bit <rdar://problem/4561772>
+ * Carbon/HIWebView.m: disabled this file in 64-bit <rdar://problem/4561772>
+ (HIWebViewEventHandler):
+ * DefaultDelegates/WebDefaultResourceLoadDelegate.m:
+ (-[WebDefaultResourceLoadDelegate webView:resource:didReceiveContentLength:fromDataSource:]):
+ * History/WebBackForwardList.m:
+ (-[WebBackForwardList removeItem:]):
+ (-[WebBackForwardList goToItem:]):
+ * Misc/WebDownload.m:
+ (-[WebDownloadInternal download:didReceiveDataOfLength:]):
+ * Misc/WebFileDatabase.m:
+ (UniqueFilePathForKey):
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary retainIconForURL:]):
+ (-[NSMutableDictionary releaseIconForURL:]):
+ (-[WebIconDatabase _totalRetainCountForIconURLString:]):
+ (-[WebIconDatabase _retainIconForIconURLString:]):
+ (-[WebIconDatabase _releaseIconForIconURLString:]):
+ * Misc/WebSearchableTextView.m:
+ (-[NSString selectionRect]):
+ * Misc/WebTypesInternal.h: Added.
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream _destroyStream]):
+ (CarbonPathFromPOSIXPath):
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView sendActivateEvent:]):
+ (-[WebBaseNetscapePluginView sendUpdateEvent]):
+ (TSMEventHandler):
+ (-[WebBaseNetscapePluginView _postURL:target:len:buf:file:notifyData:sendNotification:allowHeaders:]):
+ (-[WebBaseNetscapePluginView _printedPluginBitmap]):
+ (-[NSData _web_locationAfterFirstBlankLine]):
+ * Plugins/WebBasePluginPackage.m:
+ (-[WebBasePluginPackage hash]):
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage load]):
+ (functionPointerForTVector):
+ * WebInspector/WebInspector.m:
+ (-[WebInspector _updateSystemColors]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _didReceiveData:contentLength:forResource:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _sendRemainingDelegateMessagesWithIdentifier:response:length:error:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView drawRect:]):
+ (-[WebHTMLView characterIndexForPoint:]):
+ (-[WebHTMLView conversationIdentifier]):
+ * WebView/WebResourceLoadDelegate.h:
+ * WebView/WebUIDelegate.h:
+ * WebView/WebView.h:
+ * WebView/WebView.m:
+ (-[WebView _mouseDidMoveOverElement:modifierFlags:]):
+ (-[WebView spellCheckerDocumentTag]):
+ * WebView/WebViewInternal.h:
+ * WebView/WebViewPrivate.h:
+
+=== WebKit-521.11 ===
+
+2006-05-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Tim.
+
+ - more loader refactoring to simplify things and remove knowledge of WebView from WebSubresourceLoader
+
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forDataSource:]):
+ (-[WebSubresourceLoader didReceiveResponse:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _startLoading]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadRequest:archive:]):
+ (-[WebFrame _loadItem:withLoadType:]):
+ (-[WebFrame _loadURL:referrer:loadType:target:triggeringEvent:form:formValues:]):
+ (-[WebFrame _postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrame _addExtraFieldsToRequest:mainResource:alwaysFromRequest:]):
+ * WebView/WebFrameInternal.h:
+ * WebView/WebFramePrivate.h:
+ * WebView/WebLoader.h:
+ * WebView/WebLoader.m:
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader initWithDataSource:]):
+ (-[WebMainResourceLoader didReceiveResponse:]):
+
+2006-05-23 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4558301> REGRESSION (420+): After clearing history and closing bookmark view window,
+ attempting to select Safari's menu bar results in a crash
+
+ * Misc/WebNSWindowExtras.m:
+ (replacementPostWindowNeedsDisplay):
+ My fix yesterday for 4557117 was not quite good enough. Now that we cancel the display timer for a
+ window *before* it deallocates, we need to make sure that while a window deallocates, no new display
+ timers are scheduled for that window. This is actually possible, as 4558301 demonstrates.
+ Luckily, NSWindow sets a handy "windowDying" flag when it deallocates, so we can just check that flag
+ and bail out of the throttle hack if it is set. This should fix the last of the crashes involving
+ display timers scheduled for deallocated or deallocating windows.
+
+2006-05-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - remove knowledge of WebView from WebLoader in preparation for moving the code down
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _defersCallbacks]):
+ (-[WebDataSource _identifierForInitialRequest:]):
+ (-[WebDataSource _willSendRequest:forResource:redirectResponse:]):
+ (-[WebDataSource _didReceiveAuthenticationChallenge:forResource:]):
+ (-[WebDataSource _didCancelAuthenticationChallenge:forResource:]):
+ (-[WebDataSource _didReceiveResponse:forResource:]):
+ (-[WebDataSource _didReceiveData:contentLength:forResource:]):
+ (-[WebDataSource _didFinishLoadingForResource:]):
+ (-[WebDataSource _didFailLoadingWithError:forResource:]):
+ (-[WebDataSource _downloadWithLoadingConnection:request:response:proxy:]):
+ (-[WebDataSource _privateBrowsingEnabled]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebLoader.h:
+ * WebView/WebLoader.m:
+ (-[WebLoader releaseResources]):
+ (-[WebLoader setDataSource:]):
+ (-[WebLoader willSendRequest:redirectResponse:]):
+ (-[WebLoader didReceiveAuthenticationChallenge:]):
+ (-[WebLoader didCancelAuthenticationChallenge:]):
+ (-[WebLoader didReceiveResponse:]):
+ (-[WebLoader didReceiveData:lengthReceived:]):
+ (-[WebLoader signalFinish]):
+ (-[WebLoader didFinishLoading]):
+ (-[WebLoader didFailWithError:]):
+ (-[WebLoader willCacheResponse:]):
+ (-[WebLoader cancelWithError:]):
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ * WebView/WebView.m:
+ (-[WebView _incrementProgressForIdentifier:response:]):
+ (-[WebView _incrementProgressForIdentifier:data:]):
+ (-[WebView _completeProgressForIdentifier:]):
+ * WebView/WebViewInternal.h:
+
+=== WebKit-521.10 ===
+
+2006-05-22 Tim Omernick <timo@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/4557117> TOT REGRESSION: Repro crash in cancelPendingWindowDisplay --> _timerRelease when
+ opening file from file open dialog
+
+ Note that I could not reproduce this situation at all on any of my machines; I had to debug this on Geoff's
+ machine.
+
+ * Misc/WebNSWindowExtras.m:
+ (replacementDealloc):
+ Cancel display timer before dealloc, not after. Cancelling the timer can cause a message to be sent to the
+ window; best to do that before the window deallocates.
+ (replacementFinalize):
+ ditto
+
+2006-05-20 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Beth.
+
+ - fix assertion failure on layout tests
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _mainReceivedError:complete:]): Don't do anything
+ if this data source is no longer connected to a frame. Used to be
+ this couldn't happen because the WebView would have been nil, but
+ we no longer go through the WebView.
+
+2006-05-20 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Anders.
+
+ Bug 9018: REGRESSION: resizing the top area of the inspector does not grow as expected
+ http://bugs.webkit.org/show_bug.cgi?id=9018
+
+ Use clientHeight now that offsetHeight includes the border and padding.
+ clientHeight should have been used initially.
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector resizeTopArea]):
+
+2006-05-18 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - remove loading-related code from WebView
+ http://bugs.webkit.org/show_bug.cgi?id=8981
+
+ * Plugins/WebNetscapePluginStream.m:
+ (-[WebNetscapePlugInStreamLoader didFinishLoading]):
+ (-[WebNetscapePlugInStreamLoader didFailWithError:]):
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (-[WebSubresourceLoader receivedError:]):
+ (-[WebSubresourceLoader signalFinish]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _stopLoading]):
+ (-[WebDataSource _receivedMainResourceError:complete:]):
+ (-[WebDataSource _finishedLoadingResource]):
+ (-[WebDataSource _mainReceivedBytesSoFar:complete:]):
+ (-[WebDataSource _receivedError:]):
+ (-[WebDataSource _mainReceivedError:complete:]):
+ * WebView/WebDataSourceInternal.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _sendRemainingDelegateMessagesWithIdentifier:response:length:error:]):
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader didReceiveData:lengthReceived:]):
+ (-[WebMainResourceLoader didFinishLoading]):
+ * WebView/WebView.m:
+ * WebView/WebViewInternal.h:
+
+2006-05-18 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4551938> More options needed for window display throttle
+
+ We decided to play it safe and leave our window flushing behavior unchanged from the previous
+ public release. By default, CoreGraphics deferred updates are once again OFF, and the window
+ display throttle is OFF.
+
+ Individual applications should set the WebKitThrottleWindowDisplayPreferenceKey and
+ WebKitEnableDeferredUpdatesPreferenceKey defaults to suit their needs.
+
+ Old behavior (like 10.4.6): WebKitThrottleWindowDisplayPreferenceKey=0 (or unset),
+ WebKitEnableDeferredUpdatesPreferenceKey (or unset).
+
+ Tear-free scrolling/animations: WebKitThrottleWindowDisplayPreferenceKey=0 (or unset),
+ WebKitEnableDeferredUpdatesPreferenceKey=1. While this configuration fixes the tearing issues
+ caused by over-flushing, some applications will experience performance problems as over-flushing
+ with CG deferred updates enabled will cause the app to block.
+
+ Tear-free scrolling/animations, high performance: WebKitThrottleWindowDisplayPreferenceKey=1,
+ WebKitEnableDeferredUpdatesPreferenceKey=1. This is the riskiest configuration in that it
+ enables the window display throttle "feature", potentially breaking applications' assumptions
+ about when displays occur. However, it provides the "best of both worlds", in that updates
+ are tear-free, and performance impact should me minimal.
+
+ * WebView/WebPreferenceKeysPrivate.h:
+ Declared WebKitThrottleWindowDisplayPreferenceKey and WebKitEnableDeferredUpdatesPreferenceKey.
+
+ * WebView/WebFrameView.m:
+ (-[WebFrameView initWithFrame:]):
+ Turn off CG deferred updates if WebKitEnableDeferredUpdatesPreferenceKey is NO or has no value.
+ Added some comments.
+
+2006-05-18 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin Adler.
+
+ - fixed <rdar://problem/4552713> REGRESSION: WebFrameView no longer responds to responder methods sent by Safari code
+
+ * WebView/WebView.m:
+ (-[WebView _responderForResponderOperations]):
+ Treat sibling views of the main frameView the same as views outside of the webview for the purposes of this mechanism.
+
+2006-05-18 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4553450> Make disabling window throttle safer
+
+ * Misc/WebNSWindowExtras.m:
+ (+[NSWindow _webkit_enableWindowDisplayThrottle]):
+ Don't assume that +_webkit_disableWindowDisplayThrottle restored the NSWindow method implementations;
+ now we'll only swizzle them once, and our replacement IMPs will call the old IMPs when the window
+ throttle is disabled. This is a safer approach when other components/"haxies" override the same methods
+ that we are overriding, as it allows the overrides to "chain" properly.
+ Moved the dictionary initialization code down a bit. The order doesn't matter here.
+ (disableWindowDisplayThrottleApplierFunction):
+ Noticed that this could have been written safer with respect to the timer having the last reference to
+ the window. I never experienced a crash here, but this code is definitely safer.
+ (+[NSWindow _webkit_disableWindowDisplayThrottle]):
+ Don't restore NSWindow method implementations; just clear the flag, flush pending displays, and destroy
+ the dictionary.
+ (replacementPostWindowNeedsDisplay):
+ If throttling is disabled, just call the original IMP.
+ (clearWindowDisplayInfo):
+ Added an assert.
+ (replacementDealloc):
+ Don't call clearWindowDisplayInfo() when throttling is disabled.
+ (replacementFinalize):
+ ditto
+ (cancelPendingWindowDisplay):
+ Removed an unnecessary assertion.
+
+2006-05-17 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker and John Sullivan.
+
+ <rdar://problem/4550801> REGRESSION: Window throttle code can sometimes leak NSWindows
+
+ The window display throttle depended on windows being closed before they were deallocated; this is
+ not guaranteed by AppKit. Windows that were being released without being closed were getting stuck
+ in our NSWindow -> WindowDisplayInfo dictionary.
+
+ * Misc/WebNSWindowExtras.m:
+ (+[NSWindow _webkit_enableWindowDisplayThrottle]):
+ Don't retain the NSWindow keys in the window display info dictionary.
+ Instead of overriding -close, override -dealloc and -finalize so that we can remove the NSWindow ->
+ WindowDisplayInfo mapping when a window deallocates.
+ (+[NSWindow _webkit_disableWindowDisplayThrottle]):
+ Restore -dealloc and -finalize.
+ (clearWindowDisplayInfo):
+ Factored the WindowDisplayInfo cleanup code out of the now-defunct replacementClose().
+ (replacementClose):
+ Removed; no longer needed.
+ (replacementDealloc):
+ Clear the WindowDisplayInfo for the window after deallocation.
+ (replacementFinalize):
+ ditto
+ (-[NSWindow _webkit_doPendingPostWindowNeedsDisplay:]):
+ Rewrote this method to be safe in the case where the firing display timer has the last reference to the
+ window.
+ Added comments.
+
+2006-05-17 bradeeoh <beidson@apple.com>
+
+ Reviewed by Tim Hatcher
+
+ Consolidated WebDatabase base class into WebFileDatabase as the inheritance relationship became
+ obsolete. This improves readability and sets the stage for a further in-depth rewrite of the
+ WebIcon* code.
+
+ * Misc/WebDatabase.h: Removed.
+ * Misc/WebDatabase.m: Removed.
+ * Misc/WebFileDatabase.h:
+ * Misc/WebFileDatabase.m:
+ (-[WebFileDatabaseOp dealloc]):
+ (-[WebFileDatabase dealloc]):
+ (-[WebFileDatabase path]):
+ (-[WebFileDatabase isOpen]):
+ (-[WebFileDatabase sizeLimit]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-05-17 Adele Peterson <adele@apple.com>
+
+ Reviewed by Hyatt.
+
+ WebKit part of initial checkin to prepare for http://bugs.webkit.org/show_bug.cgi?id=8948
+ Switch to use new text field implementation for <textarea>
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView insertNewline:]): If we're in plain text mode, insert a line break instead of a paragraph separator.
+ (-[WebHTMLView insertParagraphSeparator:]): ditto.
+ * WebView/WebView.m: (-[WebView _menuForElement:defaultItems:]):
+ Checks for textareas as well as textfields before allowing the delegate to control
+ the context menu. This won't affect the old textareas because AppKit handles those context menus.
+
+2006-05-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Maciej.
+
+ First step towards making text-matching mechanism more flexible; updated for changes
+ to WebCoreFrameBridge calls.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView highlightAllMatchesForString:caseSensitive:]):
+ updated for name change in WebCoreFrameBridge, also now calls setMarkedTextMatchesAreHighlighted:
+ (-[WebHTMLView clearHighlightedMatches]):
+ updated for name change in WebCoreFrameBridge
+
+2006-05-16 Matt Gough <matt@softchaos.com>
+
+ Reviewed by Geoff.
+
+ Ensured all the public headers have a newline at their end.
+
+ Client code can now have 'Missing Newline at end of File' warnings enabled without emitting
+ such warnings against any WebKit includes.
+
+ * Misc/WebDownload.h:
+ * Plugins/npfunctions.h:
+ * WebView/WebResourceLoadDelegate.h:
+ * WebView/WebUIDelegate.h:
+ * WebView/WebView.h:
+
+2006-05-16 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8945 (REGRESSION: Scrolling is very slow when dragging
+ the thumb)
+
+ Rolled out one of my tweaks to the window display throttle hack (remember the last flush time instead
+ of the last display time). While that was technically a better approach, we discovered a problem
+ with how it interacts with NSView scroll tracking. Rather than further complicate this already
+ crazy hack, I'm reverting back to the simple version. This should yield similar numbers on iBench,
+ but not exhibit the nasty scrolling problem.
+
+ * Misc/WebNSWindowExtras.m:
+ (+[NSWindow _webkit_enableWindowDisplayThrottle]):
+ (+[NSWindow _webkit_disableWindowDisplayThrottle]):
+ (getWindowDisplayInfo):
+ (requestWindowDisplay):
+
+2006-05-16 bradeeoh <beidson@apple.com>
+
+ Reviewed by Maciej Stachowiak
+
+ - Fixed an old deprecated method in Misc/WebFileDatabase.m
+
+ * Misc/WebFileDatabase.m:
+ (UniqueFilePathForKey): changed `lossyCString` to `UTF8String`
+
+2006-05-16 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - did the name change from "ImageElement" to "ImageForElement" that I said I would
+ (oops!)
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate copyImageToClipboard:]):
+ * Misc/WebNSPasteboardExtras.h:
+ * Misc/WebNSPasteboardExtras.m:
+ (-[NSPasteboard _web_declareAndWriteDragImageForElement:URL:title:archive:source:]):
+ * Misc/WebNSViewExtras.h:
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_DragImageForElement:rect:event:pasteboard:source:offset:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ * WebView/WebView.m:
+ (-[WebView _writeImageForElement:withPasteboardTypes:toPasteboard:]):
+ (-[WebView writeElement:withPasteboardTypes:toPasteboard:]):
+ * WebView/WebViewInternal.h:
+
+2006-05-16 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=8940
+ remove extra copy of image code
+
+ * English.lproj/StringsNotToBeLocalized.txt: Updated for many recent changes.
+
+ * WebKit.xcodeproj/project.pbxproj: Removed files.
+ * WebCoreSupport/WebImageData.h: Removed.
+ * WebCoreSupport/WebImageData.m: Removed.
+ * WebCoreSupport/WebImageDecodeItem.h: Removed.
+ * WebCoreSupport/WebImageDecodeItem.m: Removed.
+ * WebCoreSupport/WebImageDecoder.h: Removed.
+ * WebCoreSupport/WebImageDecoder.m: Removed.
+ * WebCoreSupport/WebImageRenderer.h: Removed.
+ * WebCoreSupport/WebImageRenderer.m: Removed.
+
+ * WebCoreSupport/WebImageRendererFactory.h:
+ * WebCoreSupport/WebImageRendererFactory.m: Removed everything except for
+ shouldUseThreadedDecoding, setShouldUseThreadedDecoding, and imageDataForName:.
+
+ * Misc/WebNSPasteboardExtras.h: Removed WebImageRenderer parameter from
+ _web_declareAndWriteDragImage and renamed _web_declareAndWriteDragImageElement.
+ * Misc/WebNSPasteboardExtras.m:
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:]): Changed to
+ call +[WebFrameBridge supportedImageResourceMIMETypes] instead of
+ -[WebImageRendererFactory supportedMIMETypes].
+ (-[NSPasteboard _web_declareAndWriteDragImageElement:URL:title:archive:source:]):
+ Removed WebImageRenderer parameter, and updated code since it was always nil.
+
+ * Misc/WebNSViewExtras.h: Removed WebImageRenderer parameter from
+ _web_dragImage and renamed _web_dragImageElement.
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_dragImageElement:rect:event:pasteboard:source:offset:]):
+ Removed WebImageRenderer parameter, and updated code since it was always nil.
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface): Added some new
+ functions now used by WebCore.
+
+ * WebView/WebDataSource.m: (-[WebDataSource _documentFragmentWithArchive:]):
+ Call +[WebFrameBridge supportedImageResourceMIMETypes] instead of
+ -[WebImageRendererFactory supportedMIMETypes].
+
+ * WebView/WebFrameView.m: Removed include of WebImageRenderer.h.
+
+ * WebView/WebHTMLRepresentation.m: (+[WebHTMLRepresentation supportedImageMIMETypes]):
+ Removed call to +[WebImageRendererFactory createSharedFactory].
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _imageExistsAtPaths:]): Call +[WebFrameBridge supportedImageResourceMIMETypes]
+ instead of -[WebImageRendererFactory supportedMIMETypes].
+ (-[WebHTMLView _documentFragmentWithPaths:]): Ditto.
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]): Update
+ to no longer pass nil for an image to _web_declareAndWriteDragImageElement and to
+ _web_dragImageElement.
+ (-[WebHTMLView dealloc]): Remove call to now-unneeded _reset.
+ (-[WebHTMLView finalize]): Ditto.
+ (-[WebHTMLView viewDidMoveToWindow]): Remove logic for calling _reset, including the inWindow
+ boolean field.
+
+ * WebView/WebHTMLViewInternal.h: Removed inWindow boolean.
+ * WebView/WebHTMLViewPrivate.h: Removed _reset method.
+
+2006-05-16 Darin Adler <darin@apple.com>
+
+ Reviewed by Hyatt.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8898
+ REGRESSION: Attempting to right-click image in own tab on website causes crash
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8919
+ REGRESSION: image could not be dragged, subsequent click-drag activity caused crash
+
+ These fixes may become obsolete when Anders lands his standalone image viewer
+ patch, but in my tree they are needed to make Copy Image work after the fix
+ over on the WebCore side to avoid the crashes.
+
+ * Misc/WebNSPasteboardExtras.h: Change _web_writeImage parameter to an NSImage.
+ * Misc/WebNSPasteboardExtras.m:
+ (-[NSPasteboard _web_writeImage:element:URL:title:archive:types:]): Change parameter
+ to an NSImage instead of a WebImageRenderer.
+ (-[NSPasteboard _web_declareAndWriteDragImage:element:URL:title:archive:source:]):
+ Call -[WebImageRenderer image] to get an NSImage to pass to _web_writeImage.
+
+ * WebView/WebView.m: (-[WebView _writeImageElement:withPasteboardTypes:toPasteboard:]):
+ Get the image using WebElementImageKey if WebElementDOMNodeKey is nil.
+
+2006-05-16 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8921
+ Use WebCore to render full-frame images
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge determineObjectFromMIMEType:URL:]):
+ Remove WebImageView handling.
+
+ (-[WebFrameBridge mainResourceURLResponse]):
+ New function which returns the URL response for the main resource. This is used by the
+ manual loading of images.
+
+ (-[WebFrameBridge imageTitleForFilename:size:]):
+ New function which returns a correctly translated image title given a filename and a size.
+
+ * WebCoreSupport/WebImageRenderer.m:
+ (-[WebImageRenderer _startOrContinueAnimationIfNecessary]):
+ Remove WebImageView handling.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Remove WebImageRepresentation and WebImageView.
+
+ * WebView/WebArchiver.h:
+ * WebView/WebArchiver.m:
+ (+[WebArchiver archiveMainResourceForFrame:]):
+ New functions which returns a WebArchive with just the main resource, ignoring any subresources.
+
+ * WebView/WebDataSource.m:
+ (+[WebDataSource _repTypesAllowImageTypeOmission:]):
+ Use MIME types from WebHTMLRepresentation instead of WebImageRepresentation.
+
+ * WebView/WebFrameView.m:
+ (+[WebFrameView _viewTypesAllowImageTypeOmission:]):
+ Use MIME types from WebHTMLRepresentation instead of WebImageRepresentation.
+
+ (+[WebHTMLRepresentation supportedMIMETypes]):
+ Create an array of image and non-image MIME Types.
+
+ (+[WebHTMLRepresentation supportedNonImageMIMETypes]):
+ (+[WebHTMLRepresentation supportedImageMIMETypes]):
+ New functions, separating the list of MIME types into image and non-image ones.
+
+ * WebView/WebHTMLView.m:
+ (+[WebHTMLView supportedImageMIMETypes]):
+ (+[WebHTMLView supportedNonImageMIMETypes]):
+ New functions which call down to WebHTMLRepresentation.
+
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ If the image element comes from an ImageDocument, just use an archive of the main resource
+ instead of the generated HTML document.
+
+ * WebView/WebHTMLViewPrivate.h:
+ Declare new functions.
+
+ * WebView/WebImageRepresentation.h: Removed.
+ * WebView/WebImageRepresentation.m: Removed.
+ * WebView/WebImageView.h: Removed.
+ * WebView/WebImageView.m: Removed.
+
+2006-05-15 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Part of <rdar://problem/4466508> Add 64-bit support to the Netscape Plugin API
+
+ Added to the Netscape Plugin API the concept of "plugin drawing models". The drawing model
+ determines the kind of graphics context created by the browser for the plugin, as well as
+ the Mac types of various Netscape Plugin API data structures.
+
+ There is a drawing model to represent the old QuickDraw-based API. It is used by default
+ if QuickDraw is available on the system, unless the plugin specifies another drawing model.
+
+ The big change is the addition of the CoreGraphics drawing model. A plugin may request this
+ drawing model to obtain access to a CGContextRef for drawing, instead of a QuickDraw CGrafPtr.
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ Added PluginPort union, which wraps a NP_Port and a NP_CGContext. This is to make access to
+ the nPort and lastSetPort ivars more convenient now that the port type differs based on the
+ drawing model.
+ Changed types of nPort and lastSetPort to PluginPort so they can be used with any drawing model.
+ Added drawingModel ivar.
+ * Plugins/WebBaseNetscapePluginView.m:
+ Renamed PortState to PortState_QD. PortState is now an opaque pointer. PortState_QD cannot be
+ used if QuickDraw is unavailable.
+ (-[WebBaseNetscapePluginView fixWindowPort]):
+ Cannot be used if QuickDraw is unavailable.
+ (-[WebBaseNetscapePluginView saveAndSetNewPortStateForUpdate:]):
+ Only fix window port if drawing model is QuickDraw.
+ Re-ordered some code so I could group QuickDraw-specific stuff into switch and if blocks (that's
+ why the diff here is so terrible).
+ Now returns a malloc()'ed PortState that the caller is responsible for freeing. Renamed to
+ better reflect this behavior.
+ Support for the CoreGraphics drawing model -- fill PortState_CG struct, save CGContext state.
+ (-[WebBaseNetscapePluginView restorePortState:]):
+ Switch based on drawing model.
+ Support for the CoreGraphics drawing model -- restore CGContext state saved earlier.
+ (-[WebBaseNetscapePluginView sendEvent:]):
+ Formatting.
+ Don't set save/set port state or set the window in CoreGraphics mode unless the event being
+ sent is an updateEvt. We can't provide the plugin with a CGContext outside of our view display
+ cycle.
+ Don't restore PortState if it's NULL (didn't used to be a pointer). Free when we're done with it.
+ (-[WebBaseNetscapePluginView isNewWindowEqualToOldWindow]):
+ Formatting.
+ Switch how we compare ports based on the drawing model.
+ (-[WebBaseNetscapePluginView updateAndSetWindow]):
+ Fixed for CoreGraphics by triggering a redisplay instead of sending an update event to the plugin
+ outside of the view display cycle.
+ Don't restore PortState if it's NULL (didn't used to be a pointer). Free when we're done with it.
+ (-[WebBaseNetscapePluginView setWindowIfNecessary]):
+ Assert that the window is only set when updating in CoreGraphics mode.
+ Log differently depending on the drawing model.
+ (-[WebBaseNetscapePluginView start]):
+ Fall back on QuickDraw if the plugin does not specify a drawing model.
+ (-[WebBaseNetscapePluginView tellQuickTimeToChill]):
+ Cannot be used if QuickDraw is unavailable.
+ (-[WebBaseNetscapePluginView viewWillMoveToWindow:]):
+ Only call -tellQuickTimeToChill in QuickDraw mode.
+ (-[WebBaseNetscapePluginView viewHasMoved:]):
+ ditto
+ (-[WebBaseNetscapePluginView invalidateRegion:]):
+ NPRegion is a CGPathRef in CoreGraphics mode.
+ (-[WebBaseNetscapePluginView getVariable:value:]):
+ Added support for retriveing the NPNVpluginDrawingModel, NPNVsupportsQuickDrawBool, and
+ NPNVsupportsCoreGraphicsBool browser variables.
+ (-[WebBaseNetscapePluginView setVariable:value:]):
+ Added support for setting the NPNVpluginDrawingModel variable.
+
+2006-05-15 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ Follow-up to my previous PLT fix. I found upon further testing (by dramatically decreasing the
+ allowed display rate) that +_webkit_displayThrottledWindows did not always force a display when
+ necessary. The reason is that I was not giving a proper timeout to CFRunLoopRunInMode(). I was
+ passing 0, which was causing only "expired" timers to fire. This method is actually supposed to
+ block until all currently scheduled display timers fire.
+
+ I tested this change and found that it did not affect my PLT times when the display rate was
+ capped to 60 fps. It also behaves as expected when the display rate is set much lower (say, 1
+ display per second); my previous fix did not work well at such display rates.
+
+ * Misc/WebNSWindowExtras.m:
+ (+[NSWindow _webkit_displayThrottledWindows]):
+ Run the runloop for an amount of time equal to the minimum allowed interval between displays.
+ This ensures that we'll block until all currently scheduled display timers fire (but we won't
+ block for future display timers).
+
+2006-05-15 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - followup to previous fix; I hadn't tested quitting adequately
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView dealloc]):
+ call removeAllToolTips before clearing _private so that removeTrackingRect: override can work
+ properly. Normally removeAllToolTips would be called by super, but that's too late.
+ (-[WebHTMLView finalize]):
+ ditto
+
+2006-05-15 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin.
+
+ - fixed <rdar://problem/4503016> TOT assertion failure in -[WebHTMLView(WebPrivate) removeTrackingRect:]
+
+ We have some tricky code to deal with tracking rects, which succumbed to a fix in AppKit. Updated our
+ tricky code to work with the AppKit fix.
+
+ * WebView/WebHTMLViewInternal.h:
+ new instance variable lastToolTipTag
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView removeTrackingRect:]):
+ handle removing lastToolTipTag by calling super
+ (-[WebHTMLView _setToolTip:]):
+ save tool tip tag in lastToolTipTag; this apparently used to always return 0, so we formerly had no way
+ to distinguish it from the no-tool-tips-yet case.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Xcode removed some old cruft
+
+2006-05-15 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ Safari's Page Load Test (PLT) saturates the runloop with so many sources that timers are not allowed to fire
+ as frequently as they should. This is a general problem with the PLT -- because of this, it does not measure
+ work done in timer callbacks during/after the page load process.
+
+ Unfortunately, this aspect of the PLT interferes with our window display throttle hack. Because we throttle
+ display using timers, and the PLT starves timers, most of the pages loaded by the PLT do not actually display.
+ This makes the PLT run "too fast", yielding ridiculously fast numbers compared to when throttling is disabled.
+
+ I've added a new method that the PLT can call after each page load to force any starved display throttle timers
+ to fire. By doing this, Safari's PLT will be guaranteed to display each page at least once.
+
+ * Misc/WebNSWindowExtras.h:
+ * Misc/WebNSWindowExtras.m:
+ Added a special internal runloop mode for the throttle timers.
+ (+[NSWindow _webkit_displayThrottledWindows]):
+ Run the runloop in our special internal mode until there are no more sources to handle.
+ (requestWindowDisplay):
+ Schedule the timer in the new mode as well as the standard modes.
+
+2006-05-15 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8913
+ REGRESSION: Can view source for text files
+
+ * WebView/WebDocumentPrivate.h:
+ Add canSaveAsWebArchive.
+
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation canProvideDocumentSource]):
+ Call the bridge.
+
+ (-[WebHTMLRepresentation canSaveAsWebArchive]):
+ New function. This will be used in Safari ToT to determine if a page can be saved as an archive.
+
+2006-05-14 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8739
+ Crash in RenderTableSection::paint due to manipulating DOM on resize
+
+ Manual test: manual-tests/dom-manipulation-on-resize.html
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView layoutToMinimumPageWidth:maximumPageWidth:adjustingViewSize:]): Relayout if necessary
+ after sending the resize event.
+
+2006-05-12 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Brady.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8876
+ - move most private WebDataSource methods to uninstalled header
+
+ I put the declarations for the ones only used in WebKit in WebDataSourceInternal.h
+ and removed two entirey unused ones.
+
+ * Plugins/WebNetscapePluginRepresentation.m:
+ * Plugins/WebNetscapePluginStream.m:
+ * Plugins/WebPluginController.m:
+ * Plugins/WebPluginDocumentView.m:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge dataSource]):
+ * WebCoreSupport/WebSubresourceLoader.m:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _updateIconDatabaseWithURL:]):
+ (-[WebDataSource _loadIcon]):
+ (-[WebDataSource _clearErrors]):
+ (-[WebDataSource _commitLoadWithData:]):
+ (-[WebDataSource _doesProgressiveLoadWithMIMEType:]):
+ (-[WebDataSource _addResponse:]):
+ * WebView/WebDataSourceInternal.h: Added.
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebFrame.m:
+ * WebView/WebHTMLRepresentation.m:
+ * WebView/WebHTMLView.m:
+ * WebView/WebImageView.m:
+ * WebView/WebLoader.m:
+ * WebView/WebMainResourceLoader.m:
+ * WebView/WebPDFView.m:
+ * WebView/WebRenderNode.m:
+ * WebView/WebView.m:
+
+2006-05-12 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4542808> REGRESSION: benchjs test 1 has slowed by over 150% (8740)
+ <http://bugs.webkit.org/show_bug.cgi?id=8740>
+
+ Improvement to my NSWindow display throttle hack. Remember the last flush time instead of the last display time.
+ Our goal is to never draw less than 1/60th of a second after the window is flushed in order to avoid blocking on
+ a CG coalesced update. Using the last display time is close, but this is much more accurate. I have verified that
+ this further improves our score on BenchJS Test 1 (by 9.8% with the status bar shown compared to the previous build),
+ as well as on our internal PLT scores by a smaller percentage.
+
+ * Misc/WebNSWindowExtras.m:
+ Renamed lastDisplayTime to lastFlushTime.
+ (+[NSWindow _webkit_enableWindowDisplayThrottle]):
+ Replace -[NSWindow flushWindow] with our own implementation.
+ (+[NSWindow _webkit_disableWindowDisplayThrottle]):
+ Restore -[NSWindow flushWindow].
+ (replacementFlushWindow):
+ Use the last flush time instead of the last display time.
+ (getWindowDisplayInfo):
+ Renamed lastDisplayTime to lastFlushTime.
+ (requestWindowDisplay):
+ Moved some code to replacementFlushWindow().
+
+2006-05-11 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ Bug 8856: Web Inspector should show the Xpath for the selected node
+ http://bugs.webkit.org/show_bug.cgi?id=8856
+
+ Adds an Xpath area to the Node panel.
+
+ * WebInspector/webInspector/inspector.css:
+ * WebInspector/webInspector/inspector.html:
+ * WebInspector/webInspector/inspector.js:
+
+2006-05-11 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Anders.
+
+ Fixes <rdar://problem/4411845> lots of SPOD trying to scroll through
+ Markup & Content inspecting body at apple.com (6614)
+ http://bugs.webkit.org/show_bug.cgi?id=6614
+
+ Removed the Markup & Content pane when viewing a element.
+ This pane was not that useful and made the inspector really slow
+ when the markup was large. Only show this pane for text nodes.
+
+ * WebInspector/webInspector/inspector.css: use -webkit prefix
+ * WebInspector/webInspector/inspector.html:
+ * WebInspector/webInspector/inspector.js:
+
+2006-05-11 Sam Weinig <sam.weinig@gmail.com>
+
+ Reviewed by Timothy.
+
+ Patch for <http://bugs.webkit.org/show_bug.cgi?id=8810>
+ Bug 8810: Scrollbars in WebInspector rendered incorrectly
+
+ * WebInspector/webInspector/inspector.css:
+ Make scroll bars absolutely positioned.
+
+2006-05-10 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4542808> REGRESSION: benchjs test 1 has slowed by over 150% (8740)
+ <http://bugs.webkit.org/show_bug.cgi?id=8740>
+
+ * Misc/WebNSWindowExtras.h:
+ * Misc/WebNSWindowExtras.m:
+ (+[NSWindow _webkit_enableWindowDisplayThrottle]):
+ Overrides certain NSWindow methods so that window autodisplay can be throttled to 60Hz.
+
+ (disableWindowDisplayThrottleApplierFunction):
+ CFDictionary applier function for when the throttle is disabled. Cancels all pending window displays,
+ and calls -displayIfNeeded on each window with a pending display.
+
+ (+[NSWindow _webkit_disableWindowDisplayThrottle]):
+ Restores default NSWindow method implementations and clears pending window displays.
+
+ (swizzleInstanceMethod):
+ Helper function to swizzle ObjC method implementations.
+
+ (replacementPostWindowNeedsDisplay):
+ Don't call into -[NSWindow _postWindowNeedsDisplay] if requestWindowDisplay() returns NO (this is the
+ function that throttles display).
+
+ (replacementClose):
+ Clean up the WindowDisplayInfo struct for the window, since it's about to go away.
+
+ (getWindowDisplayInfo):
+ Gets the WindowDisplayInfo struct for the window, or creates it if absent.
+
+ (requestWindowDisplay):
+ Returns YES if a display is allowed right now. Returns NO otherwise, and schedules a timer to try the
+ display again.
+
+ (cancelPendingWindowDisplay):
+ Cancels the pending display for the window, if any.
+
+ (-[NSWindow _webkit_doPendingPostWindowNeedsDisplay:]):
+ Try to call _postWindowNeedsDisplay again.
+
+ * WebView/WebFrameView.m:
+ (-[WebFrameView initWithFrame:]):
+ If the secret "WebKitThrottleWindowDisplay" default is set, then enable the NSWindow throttle.
+
+2006-05-10 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Maciej.
+
+ * WebView/WebHTMLView.m:
+ (+[WebHTMLView unsupportedTextMIMETypes]):
+ Add text/rtf
+
+2006-05-09 Levi Weintraub <lweintraub@apple.com>
+
+ Reviewed by justin.
+
+ <rdar://problem/4442395>
+ Tiny MCE: Link isn't inserted after dragging into textarea field
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _documentFragmentFromPasteboard:allowPlainText:chosePlainText:]):
+ Modified to create an anchor object with a title as opposed to just the URL as text.
+
+2006-05-09 Tim Omernick <timo@apple.com>
+
+ Reviewed by Dave Harrison.
+
+ <rdar://problem/4523432> safari crashed right after disabling "block pop up windows" (or
+ other WebPreferences changes)
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView viewWillMoveToHostWindow:]):
+ When the plugin view is removed from both its window and its hostWindow, stop observing
+ WebPreferences.
+
+2006-05-09 Anders Carlsson <acarlsson@apple.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8808
+ WebCore should handle text files
+
+ * WebKit.exp:
+ Remove WebTextView.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Get rid of WebTextView and WebTextRepresentation.
+
+ * WebView/WebDataSource.m:
+ (+[WebDataSource _repTypesAllowImageTypeOmission:]):
+ * WebView/WebFrameView.m:
+ (+[WebFrameView _viewTypesAllowImageTypeOmission:]):
+ * WebView/WebHTMLView.m:
+ The text MIME types are now handled by WebHTMLView.
+
+ (+[WebHTMLView unsupportedTextMIMETypes]):
+ New function, moved here from WebTextView.
+
+ * WebView/WebHTMLViewPrivate.h:
+ * WebView/WebTextRepresentation.h: Removed.
+ * WebView/WebTextRepresentation.m: Removed.
+ * WebView/WebTextView.h: Removed.
+ * WebView/WebTextView.m: Removed.
+
+ * WebView/WebView.m:
+ (+[WebView _viewClass:andRepresentationClass:forMIMEType:]):
+ Now special-case WebHTMLView instead of WebTextView for MIME types
+ that shouldn't be shown.
+
+2006-05-09 Maciej Stachowiak <mjs@apple.com>
+
+ Rubber stamped by Anders.
+
+ - renamed kxmlcore to wtf
+
+ kxmlcore --> wtf
+ KXMLCore --> WTF
+ KXC --> WTF
+
+ * Misc/WebKitLogging.h:
+ * Misc/WebKitLogging.m:
+ (initializeLogChannel):
+
+2006-05-09 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Anders.
+
+ Bug 8804: Inspector should support searching by Xpath query
+ http://bugs.webkit.org/show_bug.cgi?id=8804
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector _refreshSearch]):
+ * WebInspector/webInspector/inspector.js:
+
+2006-05-08 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - refactor things so that WebKit doesn't save a WebResource for every loaded URL,
+ but rather retrieves the data from the WebCore cache as needed.
+ http://bugs.webkit.org/show_bug.cgi?id=8802
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge objectLoadedFromCacheWithURL:response:data:]):
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (-[WebSubresourceLoader didReceiveResponse:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ (-[WebDataSource _archivedSubresourceForURL:]):
+ (-[WebDataSource initWithRequest:]):
+ (-[WebDataSource subresources]):
+ (-[WebDataSource subresourceForURL:]):
+ (-[WebDataSource addSubresource:]):
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebFrame.m:
+ * WebView/WebFrameInternal.h:
+ * WebView/WebHTMLView.m:
+ * WebView/WebLoader.h:
+ * WebView/WebLoader.m:
+ (-[NSURLProtocol loadWithRequest:]):
+ (-[NSURLProtocol didFinishLoading]):
+ * WebView/WebUnarchivingState.h:
+ * WebView/WebUnarchivingState.m:
+ (-[WebUnarchivingState addResource:]):
+
+2006-05-04 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8594
+ REGRESSION: Exception on closing a page containing (just) an mp3
+
+ Test: plugins/pluginDocumentView-deallocated-dataSource.html
+
+ * Plugins/WebPluginDocumentView.m:
+ (-[WebPluginDocumentView dealloc]): Release the dataSource.
+ (-[WebPluginDocumentView setDataSource:]): Retain the dataSource.
+
+2006-05-04 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4537606> Give Java WebKit plugin access to its own DOM element
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge viewForJavaAppletWithFrame:attributeNames:attributeValues:baseURL:DOMElement:]):
+ Pass the DOMElement to the plugin if it's a WebKit plugin (we need to handle Netscape plugins
+ differently).
+
+2006-05-04 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4480186> Give WebKit plugins access to their own DOM element
+
+ This does not fix <rdar://problem/4480187> Give Netscape plugins access to their own DOM element --
+ we're not going to use the ObjC DOM API for that, but rather the NP bindings API.
+
+ * Plugins/WebPluginPackage.m:
+ Declared WebPlugInContainingElementKey. This is not a new plugin argument -- it's been in our public
+ headers since all along, but has never been concretely declared -- plugins that referenced it would not
+ link.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge pluginViewWithPackage:attributeNames:attributeValues:baseURL:DOMElement:]):
+ Added DOMElement parameter, which is now included in the plugin arguments dictionary.
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:DOMElement:]):
+ ditto
+
+ * WebKit.exp:
+ Export WebPlugInContainingElementKey.
+
+2006-05-02 Darin Adler <darin@apple.com>
+
+ Reviewed by Eric.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=8677
+ REGRESSION: wkSetUpFontCache() may be called before the SPIs are connected.
+
+ I don't know how reproduce this without one of Rosyna's hacks installed, so I
+ did not include a test.
+
+ * Misc/WebStringTruncator.m: (+[WebStringTruncator initialize]): Add call to
+ InitWebCoreSystemInterface.
+
+ * WebCoreSupport/WebSystemInterface.m: (InitWebCoreSystemInterface): Add a boolean
+ so we will only do this one time.
+
+2006-05-02 Adele Peterson <adele@apple.com>
+
+ Reviewed by Tim O.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=6988
+ REGRESSION: Display correct context menus for new text fields
+
+ * WebView/WebView.m: (-[WebView _menuForElement:defaultItems:]):
+ Don't let the UI delegate have control over the context menu for text fields.
+
+2006-05-01 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8658
+ Assertion failure in -[WebPluginContainerCheck _isForbiddenFileLoad]
+ (bridge is null) when clicking QuickTime object with href
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView setDataSource:]): Set the pluginController's dataSource.
+
+2006-05-01 Maciej Stachowiak <mjs@apple.com>
+
+ - fix build
+
+ * WebKit.exp: Add symbol that the new Safari will need.
+
+2006-05-01 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed <rdar://problem/3126419> history load enforces history limit, but deletes the newest instead of oldest items
+ - added notification reporting items discarded during load because the age limit or item count limit is exceeded
+ - a few other minor tweaks
+
+ * History/WebHistory.h:
+ fixed a typo and an incorrect method name
+
+ * History/WebHistoryPrivate.h:
+ Added declaration of WebHistoryItemsDiscardedWhileLoadingNotification. Also changed signature of
+ WebHistoryPrivate method -loadFromURL:error: to have new collectDiscardedItemsInto: parameter.
+ Also deleted declarations of two methods that didn't actually exist (loadHistory and initWithFile:),
+ and added comments about which methods should become public API, WebKit-internal, or file-internal.
+
+ * History/WebHistory.m:
+ (-[WebHistoryPrivate arrayRepresentation]):
+ This method, called only by _saveHistoryGuts:, used to deliberately leave out items that violated
+ either the age limit or the item count limit. Now all the items are included (and thus saved), and
+ all the pruning is done at load time, so clients can keep track of the pruned items by observing
+ the new WebHistoryItemsDiscardedWhileLoadingNotification
+ (-[WebHistoryPrivate _loadHistoryGutsFromURL:savedItemsCount:collectDiscardedItemsInto:error:]):
+ Now keeps track of all the items that violated the age limit or item count limit in the new
+ collectedDiscardedItemsInto: parameter. Also, now processes items in forward order rather than
+ reverse order to fix 3126419. Now uses compare: rather than _webkit_compareDay: to check against
+ age limit; this is faster and also more correct (most noticeable with small age limits).
+ (-[WebHistoryPrivate loadFromURL:collectDiscardedItemsInto:error:]):
+ new collectDiscardedItemsInto: parameter, passed into _loadHistoryGuts:...
+ (-[WebHistory loadFromURL:error:]):
+ Now sends new WebHistoryItemsDiscardedWhileLoadingNotification if any items were discarded due
+ to age limit or item count limit.
+
+ * WebKit.exp:
+ exported symbol for WebHistoryItemsDiscardedWhileLoadingNotification
+
+2006-04-29 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Maciej.
+
+ Bug 8577: [TabBarView _web_superviewOfClass:stoppingAtClass:]
+ http://bugs.webkit.org/show_bug.cgi?id=8577
+
+ Added back _web_superviewOfClass:stoppingAtClass:.
+ This method was removed in r14032 (bug 8562), but Safari 2.0 still uses it.
+ We should remove this method once Open Source users have a new version
+ to use with TOT WebKit.
+
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_superviewOfClass:stoppingAtClass:]):
+
+2006-04-28 David Hyatt <hyatt@apple.com>
+
+ Double the cache size to account for our revised (more accurate)
+ measurement of the image buffers.
+
+ Reviewed by darin
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+
+2006-04-28 David Hyatt <hyatt@apple.com>
+
+ Fix for 8586, move WebTextRenderer into WebCore.
+
+ Reviewed by darin
+
+ * Misc/WebKitNSStringExtras.m:
+ (-[NSString _web_drawAtPoint:font:textColor:]):
+ (-[NSString _web_widthWithFont:]):
+ * Misc/WebStringTruncator.m:
+ (+[WebStringTruncator centerTruncateString:toWidth:]):
+ (+[WebStringTruncator centerTruncateString:toWidth:withFont:]):
+ (+[WebStringTruncator rightTruncateString:toWidth:withFont:]):
+ (+[WebStringTruncator widthOfString:font:]):
+ * WebCoreSupport/WebSystemInterface.m:
+ (InitWebCoreSystemInterface):
+ * WebCoreSupport/WebTextRenderer.h: Removed.
+ * WebCoreSupport/WebTextRenderer.m: Removed.
+ * WebCoreSupport/WebTextRendererFactory.h: Removed.
+ * WebCoreSupport/WebTextRendererFactory.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrameView.m:
+ (-[WebFrameView initWithFrame:]):
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _addToStyle:fontA:fontB:]):
+ * WebView/WebTextView.m:
+ (-[WebTextView setFixedWidthFont]):
+ * WebView/WebView.m:
+ (+[WebView _setAlwaysUseATSU:]):
+ (+[WebView _setShouldUseFontSmoothing:]):
+ (+[WebView _shouldUseFontSmoothing]):
+
+2006-04-28 Eric Seidel <eseidel@apple.com>
+
+ Reviewed by darin.
+
+ Misc. style cleanup.
+ http://bugs.webkit.org/show_bug.cgi?id=8643
+
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary iconForURL:withSize:cache:]):
+ (-[NSMutableDictionary iconURLForURL:]):
+ (-[NSMutableDictionary retainIconForURL:]):
+ (-[NSMutableDictionary releaseIconForURL:]):
+ (-[WebIconDatabase _setIcon:forIconURL:]):
+ (-[WebIconDatabase _iconsForIconURLString:]):
+ (-[WebIconDatabase _forgetIconForIconURLString:]):
+ (-[WebIconDatabase _releaseIconForIconURLString:]):
+ (-[WebIconDatabase _iconsBySplittingRepresentationsOfIcon:]):
+ * Plugins/WebBasePluginPackage.m:
+ (+[WebBasePluginPackage pluginWithPath:]):
+ (-[WebBasePluginPackage pathByResolvingSymlinksAndAliasesInPath:]):
+ (-[WebBasePluginPackage initWithPath:]):
+ (-[WebBasePluginPackage getPluginInfoFromBundleAndMIMEDictionary:]):
+ (-[WebBasePluginPackage pListForPath:createFile:]):
+ (-[WebBasePluginPackage getPluginInfoFromPLists]):
+ (-[WebBasePluginPackage load]):
+ (-[WebBasePluginPackage setMIMEToExtensionsDictionary:]):
+ (-[WebBasePluginPackage isNativeLibraryData:]):
+ (-[NSArray _web_lowercaseStrings]):
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage openResourceFile]):
+ (-[WebNetscapePluginPackage closeResourceFile:]):
+ (-[WebNetscapePluginPackage stringForStringListID:andIndex:]):
+ (-[WebNetscapePluginPackage getPluginInfoFromResources]):
+ (-[WebNetscapePluginPackage initWithPath:]):
+ (-[WebNetscapePluginPackage executableType]):
+ (-[WebNetscapePluginPackage unloadWithoutShutdown]):
+ (-[WebNetscapePluginPackage load]):
+ (-[WebNetscapePluginPackage unload]):
+ * Plugins/WebNetscapePluginRepresentation.m:
+ (-[WebNetscapePluginRepresentation redeliverStream]):
+ * Plugins/WebPluginDatabase.m:
+ (+[WebPluginDatabase installedPlugins]):
+ (-[WebPluginDatabase pluginForKey:withEnumeratorSelector:]):
+ (-[WebPluginDatabase pluginForExtension:]):
+ (pluginLocations):
+ (-[WebPluginDatabase init]):
+ (-[WebPluginDatabase refresh]):
+ * Plugins/npapi.m:
+ (NPN_MemAlloc):
+ (NPN_MemFree):
+ (pluginViewForInstance):
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withRequest:customHeaders:referrer:forDataSource:]):
+ (-[WebSubresourceLoader willSendRequest:redirectResponse:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource isLoading]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadDataSource:withLoadType:formState:]):
+ (-[WebFrame _subframeIsLoading]):
+ * WebView/WebView.m:
+ (-[WebView initWithFrame:]):
+ (-[WebView initWithFrame:frameName:groupName:]):
+
+2006-04-26 Tim Omernick <timo@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/4525105> Repro TOT crash in [WebBaseNetscapePluginView dealloc] at coachella.com
+ <http://bugs.webkit.org/show_bug.cgi?id=8564> crashed when closing a tab
+
+ * WebView/WebFrame.m:
+ (-[WebFramePrivate dealloc]):
+ Assert that plugInViews has been released.
+ (-[WebFrame _addPlugInView:]):
+ New method. Adds the plug-in view to the plugInViews set and calls -setWebFrame: on it.
+ (-[WebFrame _removeAllPlugInViews]):
+ New method. Calls -setWebFrame:nil on all plug-in views and releases the plugInViews set.
+ (-[WebFrame _willCloseURL]):
+ New method. Dispose of plug-in views when leaving a page (or closing the WebView).
+
+ * WebView/WebFrameInternal.h:
+ Declared -_addPlugInView:, -_removeAllPlugInViews, -_willCloseURL
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:]):
+ Call -[WebFrame _addPlugInView:] instead of directly setting plug-in views' frames. This
+ allows us to keep track of them so that we can explicitly dispose of them when leaving the page.
+ (-[WebFrameBridge closeURL]):
+ Override -[WebCoreFrameBridge closeURL] so that we can perform our own teardown when leaving
+ a page or closing the WebView.
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ Declared -stop so that subclass WebNetscapePluginEmbeddedView can call it.
+
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView setWebFrame:]):
+ Stop the plug-in when it is removed from its WebFrame.
+
+2006-04-25 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4472035> SPI that checks for URL policy fails in plugin documents
+
+ * Plugins/WebPluginController.h:
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController URLPolicyCheckReferrer]):
+ New method. Get the referrer from the frame's data source's NSURLResponse. Note that for
+ document types loaded by WebCore, this URL is the same as -[WebCorePageBridge referrer],
+ since the response URL is what we pass to -[WebCorePageBridge openURL:].
+
+ * Plugins/WebPluginContainerCheck.m:
+ (-[WebPluginContainerCheck _isForbiddenFileLoad]):
+ Use the WebPluginController's -URLPolicyCheckReferrer instead of assuming that the bridge's
+ -referrer is valid. -[WebCorePageBridge referrer] is only set during the normal WebCore page
+ load process, which has nothing to do with loading standalone plugin documents.
+
+2006-04-25 Tim Omernick <timo@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/4526052> intermittent assertion failure in -[WebBasePluginPackage dealloc]
+ running layout tests
+
+ * Plugins/WebPluginPackage.m:
+ (-[WebPluginPackage unload]):
+ Clear isLoaded here. It turns out that only WebNetscapePluginPackage cleared its isLoaded
+ flag in -unload. We need to also do it here, because the superclass (WebBasePluginPackage)
+ asserts in -dealloc that -unload has been called.
+
+2006-04-25 Tim Omernick <timo@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/4526120> -[WebBasePluginPackage finalize] leaks the CFBundle (under GC only)
+
+ * Plugins/WebBasePluginPackage.m:
+ (-[WebBasePluginPackage finalize]):
+ Release the CFBundle here.
+
+2006-04-25 Tim Omernick <timo@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/4472037>
+
+ Private extensions to the WebPlugin interface. A plugin may implement these methods to receive loading callbacks
+ for its main resource. Plug-ins that implement this SPI show better loading progress in the browser, can be saved
+ to disk, and are more efficient by avoiding making duplicate GET or POST requests for the plug-in's main resource.
+
+ I want to provide a solid API for plug-in networking, but time constraints require that I first provide this simple
+ SPI for internal clients.
+
+ * Plugins/WebPluginViewFactoryPrivate.h:
+ Added a new plugin argument, WebPlugInShouldLoadMainResourceKey. If YES, the plugin is responsible
+ for loading its own content. If NO, the plugin should wait for WebKit to send it the data via the
+ new request-sharing SPI.
+
+ * Plugins/WebPluginPrivate.h: Added.
+ Request-sharing SPI. See comments in code.
+
+ * Plugins/WebPluginDocumentView.h:
+ Hang onto the plugin view as an ivar so we can call the new resource loading methods on it.
+ * Plugins/WebPluginDocumentView.m:
+ (-[WebPluginDocumentView dealloc]):
+ Release pluginView ivar.
+ (-[WebPluginDocumentView setDataSource:]):
+ Pass NO for WebPlugInShouldLoadMainResourceKey to indicate to the plugin that it should not
+ load its own main resource -- the data will come from WebKit. This is only necessary for plugin
+ documents. By the time we create the view for a plugin document, we already have fetched some
+ of its main resource's data. Embedded plugins do not have this issue because WebKit is not
+ involved in loading their content.
+ Call -webPlugInMainResourceDidReceivResponse: on the plugin if necessary. This lets the plugin
+ know how much and what kind of data is going to be received.
+ (-[WebPluginDocumentView dataSourceUpdated:]):
+ If the plugin implements the new request-sharing SPI, don't cancel the in-progress request.
+ (-[WebPluginDocumentView receivedData:withDataSource:]):
+ Forward to the plugin via the new request-sharing SPI.
+ (-[WebPluginDocumentView receivedError:withDataSource:]):
+ ditto
+ (-[WebPluginDocumentView finishedLoadingWithDataSource:]):
+ ditto
+
+ * Plugins/WebPluginPackage.m:
+ Added WebPlugInShouldLoadMainResourceKey, tweaked some style a bit.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge pluginViewWithPackage:attributeNames:attributeValues:baseURL:]):
+ Pass YES for WebPlugInShouldLoadMainResourceKey. Embedded plugins must load their own data.
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:]):
+ ditto
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Added WebPluginPrivate.h
+
+2006-04-24 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Geoff.
+
+ <rdar://problem/4525364> REGRESSION (yesterday?): LOG() mechanism is broken
+
+ - initialize WebKit's log channels
+
+ * Misc/WebKitLogging.h:
+ * Misc/WebKitLogging.m:
+ (initializeLogChannel):
+ (WebKitInitializeLoggingChannelsIfNecessary):
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+ * WebView/WebView.m:
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+
+2006-04-24 Maciej Stachowiak <mjs@apple.com>
+
+ Build fix:
+
+ - move some prematurely moved code back
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge fini]):
+ (-[WebFrameBridge _preferences]):
+ (-[WebFrameBridge _retrieveKeyboardUIModeFromPreferences:]):
+ (-[WebFrameBridge keyboardUIMode]):
+
+2006-04-24 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - move more code from WebFrameBridge to WebCoreFrameBridge
+
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge fini]):
+ (-[WebFrameBridge expiresTimeForResponse:]):
+ (-[WebFrameBridge loadURL:referrer:reload:userGesture:target:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge postWithURL:referrer:target:data:contentType:triggeringEvent:form:formValues:]):
+ (-[WebFrameBridge valueForKey:keys:values:]):
+ (-[WebFrameBridge _preferences]):
+
+2006-04-24 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - Remove use of _webSuperviewOfClass: and related
+ http://bugs.webkit.org/show_bug.cgi?id=8562
+
+ I removed all use of these, now objects get at each other via
+ actual pointers, not using the view hierarchy. However, I left two
+ of the calls in because other clients rely on them as SPI (ugh).
+
+ * History/WebHistoryItem.m:
+ * Misc/WebNSViewExtras.h:
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_superviewOfClass:]):
+ (-[NSView _web_parentWebFrameView]):
+ * Plugins/WebNetscapePluginDocumentView.m:
+ (-[WebNetscapePluginDocumentView layout]):
+ * Plugins/WebNetscapePluginEmbeddedView.h:
+ * Plugins/WebNetscapePluginEmbeddedView.m:
+ (-[WebNetscapePluginEmbeddedView setWebFrame:]):
+ (-[WebNetscapePluginEmbeddedView dataSource]):
+ * Plugins/WebNullPluginView.h:
+ * Plugins/WebNullPluginView.m:
+ (-[WebNullPluginView setWebFrame:]):
+ (-[WebNullPluginView viewDidMoveToWindow]):
+ * Plugins/WebPluginController.h:
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController setDataSource:]):
+ (-[WebPluginController webPlugInContainerLoadRequest:inFrame:]):
+ (-[WebPluginController webPlugInContainerShowStatus:]):
+ (-[WebPluginController webPlugInContainerSelectionColor]):
+ (-[WebPluginController webFrame]):
+ * Plugins/WebPluginDocumentView.h:
+ * Plugins/WebPluginDocumentView.m:
+ (-[WebPluginDocumentView setDataSource:]):
+ (-[WebPluginDocumentView layout]):
+ (-[WebPluginDocumentView currentWindow]):
+ (-[WebPluginDocumentView viewWillMoveToWindow:]):
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge formControlIsBecomingFirstResponder:]):
+ (-[WebFrameBridge formControlIsResigningFirstResponder:]):
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:]):
+ * WebCoreSupport/WebViewFactory.m:
+ (-[WebViewFactory bridgeForView:]):
+ * WebView/WebClipView.m:
+ (-[NSView initWithFrame:]):
+ * WebView/WebFrameView.m:
+ (-[WebFrameView _shouldDrawBorder]):
+ (-[WebFrameView webCoreBridge]):
+ * WebView/WebHTMLView.m:
+ (-[WebTextCompleteController dealloc]):
+ (-[WebHTMLView _dataSource]):
+ (-[WebHTMLView _bridge]):
+ (-[WebHTMLView _webView]):
+ (-[WebHTMLView _frameView]):
+ (-[WebHTMLView _web_firstResponderCausesFocusDisplay]):
+ (-[WebHTMLView becomeFirstResponder]):
+ (-[WebHTMLView setDataSource:]):
+ (-[WebHTMLView pageUp:]):
+ (-[WebHTMLView pageDown:]):
+ (-[WebHTMLView pageUpAndModifySelection:]):
+ (-[WebHTMLView pageDownAndModifySelection:]):
+ (-[WebHTMLView _frame]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebImageView.h:
+ * WebView/WebImageView.m:
+ (-[WebImageView drawRect:]):
+ (-[WebImageView adjustFrameSize]):
+ (-[WebImageView setDataSource:]):
+ (-[WebImageView webView]):
+ (-[WebImageView writeImageToPasteboard:types:]):
+ (-[WebImageView copy:]):
+ (-[WebImageView elementAtPoint:]):
+ (-[WebImageView mouseDragged:]):
+ * WebView/WebPDFView.h:
+ * WebView/WebPDFView.m:
+ (-[WebPDFView _applyPDFDefaults]):
+ (-[WebPDFView _trackFirstResponder]):
+ (-[PDFPrefUpdatingProxy forwardInvocation:]):
+ * WebView/WebRenderNode.m:
+ (-[WebRenderNode initWithWebFrameView:]):
+ * WebView/WebTextView.h:
+ * WebView/WebTextView.m:
+ (-[WebTextView _textSizeMultiplierFromWebView]):
+ (-[WebTextView _preferences]):
+ (-[WebTextView setDataSource:]):
+ (-[WebTextView _webFrame]):
+ (-[WebTextView dragSelectionWithEvent:offset:slideBack:]):
+ (-[WebTextView menuForEvent:]):
+ (-[WebTextView resignFirstResponder]):
+ (-[WebTextView drawPageBorderWithSize:]):
+ (-[WebTextView knowsPageRange:]):
+ * WebView/WebView.m:
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ (containingFrameView):
+ (-[WebView _focusedFrame]):
+ (-[WebView _frameViewAtWindowPoint:]):
+
+2006-04-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - push WebFileButton and WebStringTruncator code down to WebCore
+ http://bugs.webkit.org/show_bug.cgi?id=8552
+
+ * Misc/WebStringTruncator.m:
+ (+[WebStringTruncator centerTruncateString:toWidth:]):
+ (+[WebStringTruncator centerTruncateString:toWidth:withFont:]):
+ (+[WebStringTruncator rightTruncateString:toWidth:withFont:]):
+ (+[WebStringTruncator widthOfString:font:]):
+ * WebCoreSupport/WebFileButton.h: Removed.
+ * WebCoreSupport/WebFileButton.m: Removed.
+ * WebCoreSupport/WebFrameBridge.h:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge runOpenPanelForFileButtonWithResultListener:]):
+ * WebCoreSupport/WebViewFactory.m:
+ (-[WebViewFactory fileButtonChooseFileLabel]):
+ (-[WebViewFactory fileButtonNoFileSelectedLabel]):
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-04-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - remove WebCookieAdapter, WebCore can just use Foundation directly.
+
+ * WebCoreSupport/WebCookieAdapter.h: Removed.
+ * WebCoreSupport/WebCookieAdapter.m: Removed.
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebFrameView.m:
+ (-[WebFrameView initWithFrame:]):
+
+2006-04-23 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Adele.
+
+ - prune WebView SPI of unused calls
+
+ Specifically I moved methods that have no callers outside WebKit
+ to WebViewInternal.h or removed them entirely.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ * Plugins/WebBaseNetscapePluginView.m:
+ * Plugins/WebNetscapePluginDocumentView.m:
+ * Plugins/WebNetscapePluginStream.m:
+ * Plugins/WebNullPluginView.m:
+ * Plugins/WebPluginContainerCheck.m:
+ * Plugins/WebPluginController.m:
+ * WebCoreSupport/WebFrameBridge.m:
+ * WebCoreSupport/WebPageBridge.m:
+ * WebCoreSupport/WebSubresourceLoader.m:
+ * WebView/WebDataSource.m:
+ * WebView/WebHTMLView.m:
+ * WebView/WebImageView.m:
+ * WebView/WebLoader.m:
+ * WebView/WebMainResourceLoader.m:
+ * WebView/WebPDFView.m:
+ * WebView/WebScriptDebugDelegate.m:
+ * WebView/WebView.m:
+ (-[WebView _downloadURL:]):
+ * WebView/WebViewInternal.h:
+ * WebView/WebViewPrivate.h:
+
+2006-04-22 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - remove WebKit copy of assertions code, use the assertions
+ stuff from JavaScriptCore instead.
+
+ * Carbon/HIViewAdapter.m:
+ * DOM/WebDOMOperations.m:
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ * DefaultDelegates/WebDefaultPolicyDelegate.m:
+ (-[WebDefaultPolicyDelegate webView:unableToImplementPolicyWithError:frame:]):
+ * History/WebBackForwardList.m:
+ * History/WebHistory.m:
+ (-[WebHistoryPrivate _loadHistoryGuts:URL:error:]):
+ (-[WebHistoryPrivate _saveHistoryGuts:URL:error:]):
+ * History/WebHistoryItem.m:
+ * Misc/WebAssertions.h: Removed.
+ * Misc/WebAssertions.m: Removed.
+ * Misc/WebDatabase.m:
+ * Misc/WebDownload.m:
+ * Misc/WebFileDatabase.m:
+ (SetThreadPriority):
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary iconForURL:withSize:cache:]):
+ (-[NSMutableDictionary releaseIconForURL:]):
+ (-[NSMutableDictionary delayDatabaseCleanup]):
+ (-[NSMutableDictionary allowDatabaseCleanup]):
+ (-[WebIconDatabase _loadIconDictionaries]):
+ (-[WebIconDatabase _updateFileDatabase]):
+ (-[WebIconDatabase _iconsBySplittingRepresentationsOfIcon:]):
+ * Misc/WebIconLoader.m:
+ * Misc/WebKitLogging.h:
+ * Misc/WebKitLogging.m:
+ * Misc/WebKitSystemBits.m:
+ (initCapabilities):
+ * Misc/WebLRUFileList.m:
+ (WebLRUFileListRemoveOldestFileFromList):
+ (WebLRUFileListGetFileSize):
+ * Misc/WebLocalizableStrings.m:
+ * Misc/WebNSCalendarDateExtras.m:
+ * Misc/WebNSDataExtras.m:
+ * Misc/WebNSDictionaryExtras.m:
+ * Misc/WebNSFileManagerExtras.m:
+ * Misc/WebNSPasteboardExtras.m:
+ * Misc/WebNSURLExtras.m:
+ (hexDigit):
+ (hexDigitValue):
+ (allCharactersInIDNScriptWhiteList):
+ * Misc/WebNSURLRequestExtras.m:
+ * Misc/WebNSUserDefaultsExtras.m:
+ * Misc/WebStringTruncator.m:
+ * Panels/WebAuthenticationPanel.m:
+ (-[WebAuthenticationPanel loadNib]):
+ * Panels/WebPanelAuthenticationHandler.m:
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:]):
+ (-[WebBaseNetscapePluginStream finishedLoadingWithData:]):
+ * Plugins/WebBaseNetscapePluginView.m:
+ (TSMEventHandler):
+ (-[WebBaseNetscapePluginView start]):
+ (-[WebBaseNetscapePluginView status:]):
+ (-[WebBaseNetscapePluginView _printedPluginBitmap]):
+ * Plugins/WebBasePluginPackage.m:
+ * Plugins/WebNetscapePluginDocumentView.m:
+ * Plugins/WebNetscapePluginPackage.m:
+ (-[WebNetscapePluginPackage load]):
+ * Plugins/WebNetscapePluginRepresentation.m:
+ * Plugins/WebPluginContainerCheck.m:
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController addPlugin:]):
+ (-[WebPluginController webPlugInContainerLoadRequest:inFrame:]):
+ (-[WebPluginController webPlugInContainerShowStatus:]):
+ * Plugins/WebPluginDatabase.m:
+ * Plugins/WebPluginDocumentView.m:
+ * WebCoreSupport/WebCookieAdapter.m:
+ * WebCoreSupport/WebFileButton.m:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge runModal]):
+ * WebCoreSupport/WebImageData.m:
+ (-[WebImageData _checkSolidColor:]):
+ (-[WebImageData tileInRect:fromPoint:context:]):
+ (-[WebImageData scaleAndTileInRect:fromRect:withHorizontalTileRule:withVerticalTileRule:context:]):
+ * WebCoreSupport/WebImageDecoder.m:
+ * WebCoreSupport/WebImageRenderer.m:
+ (-[WebImageRenderer TIFFRepresentation]):
+ * WebCoreSupport/WebImageRendererFactory.m:
+ * WebCoreSupport/WebJavaScriptTextInputPanel.m:
+ * WebCoreSupport/WebKeyGenerator.m:
+ * WebCoreSupport/WebPageBridge.m:
+ * WebCoreSupport/WebSubresourceLoader.m:
+ * WebCoreSupport/WebTextRenderer.m:
+ (widthForGlyph):
+ (-[WebTextRenderer initWithFont:]):
+ (drawGlyphs):
+ (initializeATSUStyle):
+ (createATSULayoutParameters):
+ (getTextBounds):
+ (ATSU_draw):
+ * WebCoreSupport/WebTextRendererFactory.m:
+ * WebCoreSupport/WebViewFactory.m:
+ * WebKit.exp:
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebKitPrefix.h:
+ * WebView/WebArchiver.m:
+ (+[WebArchiver _archiveWithMarkupString:fromFrame:nodes:]):
+ * WebView/WebClipView.m:
+ * WebView/WebDataProtocol.m:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _startLoading]):
+ * WebView/WebFormDataStream.m:
+ (formEventCallback):
+ (webSetHTTPBody):
+ * WebView/WebFrame.m:
+ (-[WebFrame _transitionToCommitted:]):
+ * WebView/WebFrameView.m:
+ * WebView/WebHTMLRepresentation.m:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _lookUpInDictionaryFromMenu:]):
+ (-[WebHTMLView drawSingleRect:]):
+ (-[WebHTMLView namesOfPromisedFilesDroppedAtDestination:]):
+ (-[WebHTMLView _scaleFactorForPrintOperation:]):
+ (-[WebHTMLView deleteBackwardByDecomposingPreviousCharacter:]):
+ (-[WebHTMLView checkSpelling:]):
+ (-[WebHTMLView showGuessPanel:]):
+ (-[WebHTMLView _changeSpellingToWord:]):
+ (-[WebHTMLView ignoreSpelling:]):
+ (-[WebHTMLView performFindPanelAction:]):
+ (-[WebTextCompleteController doCompletion]):
+ * WebView/WebImageView.m:
+ * WebView/WebLoader.m:
+ (-[NSURLProtocol connection:willCacheResponse:]):
+ * WebView/WebPDFRepresentation.m:
+ (+[WebPDFRepresentation PDFDocumentClass]):
+ * WebView/WebPDFView.m:
+ (+[WebPDFView PDFKitBundle]):
+ (+[WebPDFView PDFViewClass]):
+ (-[WebPDFView _menuItemsFromPDFKitForEvent:]):
+ * WebView/WebTextRepresentation.m:
+ * WebView/WebTextView.m:
+ * WebView/WebUnarchivingState.m:
+ * WebView/WebView.m:
+
+2006-04-22 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Eric.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8514
+ Bug 8514: Web Inspector hides when the app is in the background
+
+ Makes the inspector not hide in the background. Since the inspector is a floating panel
+ we need to call setFloatingPanel:NO when the app is switching into the background. Then
+ call setFloatingPanel:YES when the app is activated again. Without this the inspector
+ would float above all applications.
+
+ * WebInspector/WebInspector.m:
+ (-[NSWindow window]): setHidesOnDeactivate:NO
+ (-[NSWindow windowWillClose:]): de-regiser appliction active notifications
+ (-[NSWindow showWindow:]): register for appliction active notifications
+ (-[WebInspector _applicationWillResignActive]): setFloatingPanel:NO
+ (-[WebInspector _applicationDidBecomeActive]): setFloatingPanel:YES
+
+2006-04-21 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ - Fix for http://bugs.webkit.org/show_bug.cgi?id=8181
+ REGRESSION: After tabbing in page's field, attempting to tab from Google toolbar search to page fails on first try
+
+ Test: manual-tests/tabbing-input-google.html
+
+ * WebView/WebHTMLView.m: (-[WebHTMLView resignFirstResponder]):
+ When resigning first responder, reset willBecomeFirstResponderForNodeFocus, so when the WebHTMLView gets focus again
+ it knows it can start moving through the tab cycle.
+
+2006-04-20 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4476875> Support printing for embedded Netscape plugins
+
+ NOTE: This only works with the Flash plugin right now. It appears that the other
+ major plugins either have awful printing support, or no printing support. If someone
+ can find an example of any other embedded Netscape plugin printing in any browser on
+ the Mac, I will be happy to eat my own words!
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView drawRect:]):
+ When printing, get the printed bitmap via -_printedPluginBitmap, and draw it into the
+ plugin view.
+ (-[WebBaseNetscapePluginView _printedPluginBitmap]):
+ Call NPP_Print on the plugin to render it into a GWorld. This GWorld has the same
+ underlying buffer as an NSBitmapImageRep, which is returned to the caller.
+
+2006-04-20 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ WebKit part of:
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8276
+ REGRESSION (NativeTextField): Pasting a Finder item into a text field results in
+ a file: URL being pasted instead of just the file name
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8283
+ REGRESSION: File's path doesn't appear after dragging file into input field
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _plainTextFromPasteboard:]): Added method that tries to copy AppKit
+ text fields' logic for extracting plain text from the pasteboard.
+ (-[WebHTMLView _pasteAsPlainTextWithPasteboard:]): Added helper method.
+ (-[WebHTMLView _shouldInsertText:replacingDOMRange:givenAction:]):
+ (-[WebHTMLView _shouldReplaceSelectionWithText:givenAction:]):
+ (-[WebHTMLView readSelectionFromPasteboard:]): Paste as plain text if
+ rich text is not allowed.
+ (-[WebHTMLView validateUserInterfaceItem:]): Changed to not allow pasteAsRichText:
+ if the paste is not going to be handled by the DOM and the selection
+ does not allow pasting rich text.
+ (-[WebHTMLView concludeDragForDraggingInfo:actionMask:]): Paste as plain text if
+ rich text is not allowed.
+ (-[WebHTMLView paste:]): Ditto.
+ (-[WebHTMLView pasteAsPlainText:]):
+
+2006-04-20 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - WebKit part of http://bugs.webkit.org/show_bug.cgi?id=8505
+ eliminate WebCoreGraphics bridge, demonstrate new SystemInterface technique
+
+ * WebCoreSupport/WebGraphicsBridge.h: Removed.
+ * WebCoreSupport/WebGraphicsBridge.m: Removed.
+ * WebCoreSupport/WebSystemInterface.h: Added.
+ * WebCoreSupport/WebSystemInterface.m: Added.
+
+ * WebKit.xcodeproj/project.pbxproj: Updated for removed and added files.
+
+ * WebCoreSupport/WebImageData.m: Removed unneeded include of WebGraphicsBridge.h.
+ * WebCoreSupport/WebImageRenderer.m: Ditto.
+ * WebCoreSupport/WebTextRenderer.m: Ditto.
+
+ * WebView/WebFrameView.m: (-[WebFrameView initWithFrame:]): Guarded all the one-time
+ initialization inside a boolean, just in case some things take a little time. Added
+ a call to InitWebCoreSystemInterface to the one-time initialization here. Later, we
+ will need to add it in some other places if we call code that requires the use of
+ WebCoreSystemInterface functions from anywhere that can be invoked before creations
+ of the first WebFrameView, but for now there is no need.
+
+2006-04-19 James G. Speth <speth@end.com>
+
+ Reviewed by Timothy.
+
+ http://bugs.webkit.org/show_bug.cgi?id=8442
+ Bug 8442: improvements to Cocoa bindings support in WebView - code simplification
+
+ Removes the WebController class added earlier; changes NSTreeController and
+ WebView to together without it. Now you can just bind the contentObject binding
+ of the tree controller directly to the mainFrameDocument key of the WebView.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge windowObjectCleared]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setTitle:]):
+ * WebView/WebFrame.m:
+ (-[WebFrame _closeOldDataSources]):
+ * WebView/WebView.m:
+ (-[WebView _progressStarted:]):
+ (-[WebView _finalProgressComplete]):
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+ (-[WebView setMainFrameDocumentReady:]):
+ (-[WebView mainFrameDocument]):
+ * WebView/WebViewPrivate.h:
+
+2006-04-19 James G. Speth <speth@end.com>
+
+ Reviewed by Timothy.
+
+ http://bugs.webkit.org/show_bug.cgi?id=6635
+ Bug 6635: Crash selecting inspector nodes for tabs that aren't foremost
+
+ Stop observing window will close notifications before we tell the highlight window to close,
+ this prevents the crash. Also prevent drawing highlights for hidden tabs.
+
+ * WebInspector/WebInspector.m:
+ (-[WebInspector _highlightNode:]):
+ * WebInspector/WebNodeHighlight.m:
+ (-[WebNodeHighlight expire]):
+
+2006-04-19 James G. Speth <speth@end.com>
+
+ Reviewed by Timothy.
+
+ http://bugs.webkit.org/show_bug.cgi?id=6637
+ Bug 6637: selecting node in Inspector after closing window crashes Safari
+
+ When the window the Web Inspector was inspecting is closed, the inspector goes into its
+ no-selection state. Choosing to inspect another element activates it again. The inspector
+ will also follow the WebView if the URL changes and select the root element on the new page.
+
+ * WebInspector/WebInspector.m:
+ (-[NSWindow setWebFrame:]):
+ (-[NSWindow setRootDOMNode:]):
+ (-[WebInspector _revealAndSelectNodeInTree:]):
+ (-[WebInspector _update]):
+ (-[WebInspector _updateRoot]):
+ (-[WebInspector inspectedWebViewProgressFinished:]):
+ (-[WebInspector inspectedWindowWillClose:]):
+ (-[WebInspector webView:didFinishLoadForFrame:]):
+ * WebInspector/WebInspectorPanel.m:
+ (-[WebInspectorPanel canBecomeMainWindow]):
+
+2006-04-18 Darin Adler <darin@apple.com>
+
+ Reviewed by Beth.
+
+ * WebInspector/webInspector/inspector.css: Add "-webkit-" prefixes to the border
+ radius properties to make the corners rounded again.
+
+2006-04-16 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - WebKit part of fix for http://bugs.webkit.org/show_bug.cgi?id=8324
+ REGRESSION: textarea :focus not applied immediately
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge formControlIsBecomingFirstResponder:]): Added. Calls the ancestor
+ WebHTMLView's _formControlIsBecomingFirstResponder:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateFocusState:]): If a descendant is becoming first responder,
+ enable focused appearance.
+ (-[WebHTMLView _formControlIsBecomingFirstResponder:]): Added. Calls _updateFocusState,
+ causing the frame to display with focus attributes.
+ * WebView/WebHTMLViewInternal.h:
+
+2006-04-14 James G. Speth <speth@end.com>
+
+ Reviewed by Timothy.
+
+ Bug 8389: support for Cocoa bindings - binding an NSTreeController to the WebView's DOM
+ http://bugs.webkit.org/show_bug.cgi?id=8389
+
+ Added a controller class, WebController, that is a subclass of
+ NSTreeController that has a new outlet/binding for the WebView.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge windowObjectCleared]): notify bindings about the document change
+ * WebView/WebView.m:
+ (-[WebView _progressStarted:]): notify bindings about the document change
+ (-[WebView _finalProgressComplete]): notify bindings about the document change
+ (-[WebView _declaredKeys]): added a key for the main frame document
+ (-[WebController init]):
+ (-[WebController exposedBindings]):
+ (-[WebController valueClassForBinding:]):
+ (-[WebController setContent:]):
+ (-[WebController webView]):
+ (-[WebController setWebView:]):
+ (-[WebView mainFrameDocument]): get the main frame's DOMDocument
+ * WebView/WebViewPrivate.h: Adds mainFrameDocument to pending public.
+
+2006-04-12 David Harrison <harrison@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4386640> AX: AXPreviousSentenceStartTextMarkerForTextMarker does not respect paragraph boundary
+ <rdar://problem/4414575> AX: Dictionary popup cannot find some words on Dictionary.app
+
+ (see related changes in WebCore)
+
+ Tests added:
+ * editing/selection/extend-by-sentence-001.html: Added.
+ * fast/dom/inner-text-001.html: Added.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView validateUserInterfaceItem:]):
+ (-[WebHTMLView moveToBeginningOfSentence:]):
+ (-[WebHTMLView moveToBeginningOfSentenceAndModifySelection:]):
+ (-[WebHTMLView moveToEndOfSentence:]):
+ (-[WebHTMLView moveToEndOfSentenceAndModifySelection:]):
+ (-[WebHTMLView selectSentence:]):
+ * WebView/WebView.m:
+ * WebView/WebViewPrivate.h:
+ Add sentence navigation and selection.
+
+2006-04-12 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ Part of <rdar://problem/4482530>
+
+ * WebView/WebView.m:
+ (-[WebView _focusedFrame]):
+ Fixed up the logic here to take into account immediate subviews of WebView, which are not actually in a WebFrameView
+ (they are peers to the main frame's WebFrameView).
+
+2006-04-10 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed <rdar://problem/4139799> Seed: Safari: Private Browsing leaves traces in Icon Cache
+
+ * Misc/WebIconDatabasePrivate.h:
+ new ivars: pageURLsBoundDuringPrivateBrowsing, iconURLsBoundDuringPrivateBrowsing, and privateBrowsingEnabled
+
+ * Misc/WebIconDatabase.m:
+ (-[NSMutableDictionary init]):
+ initialize new ivars, and listen for notifications that WebPreferences changed so we can react to changes
+ to private browsing.
+ (-[NSMutableDictionary iconForURL:withSize:cache:]):
+ Don't remove icon URL from extraRetain dictionary; that's now done in _forgetIconForIconURLString. (I left a
+ comment here earlier about why I was worried about this change, but I convinced myself that it's fine.)
+ (-[WebIconDatabase removeAllIcons]):
+ Removed no-longer-true (and never very clear) comment, and braces. Also remove all objects from the two
+ private-browsing-related dictionaries.
+ (-[WebIconDatabase _setIcon:forIconURL:]):
+ remember icon URL if private browsing is enabled
+ (-[WebIconDatabase _setHaveNoIconForIconURL:]):
+ remember icon URL if private browsing is enabled
+ (-[WebIconDatabase _setIconURL:forURL:]):
+ added an assert that helped me out at one point
+ (-[WebIconDatabase _clearDictionaries]):
+ clear the two new dictionaries too
+ (-[WebIconDatabase _loadIconDictionaries]):
+ made an existing ERROR not fire in the expected case where there are no icons at all on disk
+ (-[WebIconDatabase _updateFileDatabase]):
+ when saving the pageURLToIconURL dictionary to disk, first remove any values that were created during
+ private browsing
+ (-[WebIconDatabase _retainIconForIconURLString:]):
+ skip the code that deals with saving changes to disk if private browsing is enabled
+ (-[WebIconDatabase _forgetIconForIconURLString:]):
+ Remove the icon URL from extraRetain dictionary here. We're forgetting everything about this icon URL
+ so we should forget its former extraRetain count too.
+ (-[WebIconDatabase _resetCachedWebPreferences:]):
+ Cache the new value of private browsing. If it has now been turned off, forget everything we learned
+ while it was on. This causes (e.g.) icons for bookmarks or pre-existing history items to be forgotten
+ if the icon was only learned during private browsing.
+
+ * History/WebHistoryItem.m:
+ removed an unnecessary #import I happened to notice
+
+2006-04-10 David Hyatt <hyatt@apple.com>
+
+ Make the broken CG focus ring painting work when WebCore sets a clip
+ (in addition to respecting the dirty rect clip).
+
+ Reviewed by darin
+
+ * WebCoreSupport/WebGraphicsBridge.m:
+ (-[WebGraphicsBridge drawFocusRingWithPath:radius:color:clipRect:]):
+
+2006-04-10 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8100
+ REGRESSION (NativeTextField): Right-aligned and RTL text jitters in new text fields
+
+ * WebCoreSupport/WebTextRenderer.m:
+ (overrideLayoutOperation): For RTL runs, apply the word-rounding on the left.
+ (CG_floatWidthForRun): For RTL runs, apply the last character's rounding
+ on the left by adjusting the start position.
+ (initializeWidthIterator): Added finalRoundingWidth field to WidthIterator.
+ (advanceWidthIterator): For RTL runs, apply rounding on the left of the character,
+ by increasing the width of the next character (which is the character to the left). For
+ the last character, keep the rounding width in the iterator's finalRoundingWidth, to be used by
+ CG_floatWidthForRun().
+
+2006-04-08 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adele Peterson.
+
+ - fixed http://bugs.webkit.org/show_bug.cgi?id=8260
+ REGRESSION: Assertion failure: ![_private->iconsToSaveWithURLs containsObject:iconURLString]
+ in WebIconDatabase.m:695-[WebIconDatabase(WebInternal) _retainIconForIconURLString:]
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _retainIconForIconURLString:]):
+ This new assertion was one block too high; moved it in.
+
+2006-04-07 David Hyatt <hyatt@apple.com>
+
+ A fix that makes coalesced updates work much better (and makes our
+ single animated GIF timer work better). The new rect painting algorithm
+ for WebHTMLView will use the single unioned rect if the # of rects exceeds
+ a threshold (10 is my initial cut), or if the union has enough "wasted"
+ additional pixels (conservatively set at 75%).
+
+ Reviewed by darin
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView drawSingleRect:]):
+ (-[WebHTMLView drawRect:]):
+
+2006-04-07 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - simplify archive loading
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource representation]): fix whitespace
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation loadArchive]): Use WebFrame's loadArchive: instead
+ of trying to do a manual load here.
+ (-[WebHTMLRepresentation documentSource]): No more special case for WebArchive.
+
+2006-04-07 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed <rdar://problem/4507054> If an icon file is removed from disk behind Safari's back,
+ Safari will not try to refetch it
+
+ In addition to letting WebIconDatabase recover from disk/memory mismatches as per 4507054, I also found
+ a bug in the way icons are remembered that could account for some of the other cases where
+ site icons didn't appear (and you'd get an ERROR on debug builds about WebIconDatabase saying it
+ had some icon when it really doesn't).
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase iconForURL:withSize:cache:]):
+ When the icon file for a previously-saved site icon isn't found, forget about the darn icon URL thoroughly
+ so that this situation is self-correcting. Formerly, once you got into this state WebKit would never find
+ the icon again (short of removing the entire icon database cleanly). Note that this does *not* change
+ the behavior of sites that didn't have a site icon when WebKit checked -- these will continue to not
+ return a site icon indefinitely (that's a separate, possibly performance-sensitive issue).
+ (-[WebIconDatabase _retainIconForIconURLString:]):
+ This code did the wrong thing in the case where an icon was in the process of being forgotten about. In
+ that case, the icon would still be in _private->iconsOnDiskWithURLs, so we wouldn't try to save it here,
+ so the new icon wouldn't stick.
+
+2006-04-07 David Hyatt <hyatt@apple.com>
+
+ Re-enable coalesced updates. Our move to a single timer has essentially
+ implemented coalescing of updates anyway, so the regression has already
+ come back. Since we have to deal with that now anyway, there's no reason
+ to visually tear also. :)
+
+ Reviewed by darin
+
+ * ChangeLog:
+ * WebView/WebView.m:
+ (-[WebView _commonInitializationWithFrameName:groupName:]):
+
+2006-04-05 Darin Adler <darin@apple.com>
+
+ - fixed a storage leak from that last check-in
+
+ * WebView/WebUnarchivingState.m: (-[WebUnarchivingState dealloc]):
+ Release the two dictionaries.
+
+2006-04-05 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - start on factoring WebArchive unpacking more into a separate class.
+ http://bugs.webkit.org/show_bug.cgi?id=8208
+
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebDataSource.m:
+ (-[WebDataSourcePrivate dealloc]):
+ (-[WebDataSource _addToUnarchiveState:]):
+ (-[WebDataSource _popSubframeArchiveWithName:]):
+ (-[WebDataSource _documentFragmentWithArchive:]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ (-[WebDataSource subresourceForURL:]):
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _loadRequest:archive:]):
+ (-[WebFrame loadRequest:]):
+ (-[WebFrame loadArchive:]):
+ * WebView/WebFramePrivate.h:
+ * WebView/WebHTMLRepresentation.m:
+ (-[WebHTMLRepresentation loadArchive]):
+ * WebView/WebUnarchivingState.h: Added.
+ * WebView/WebUnarchivingState.m: Added.
+ (-[WebUnarchivingState init]):
+ (-[WebUnarchivingState addArchive:]):
+ (-[WebUnarchivingState archivedResourceForURL:]):
+ (-[WebUnarchivingState popSubframeArchiveWithFrameName:]):
+
+2006-04-04 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ The Debug and Release frameworks are now built with install paths relative to the build products directory.
+ This removes the need for other projects to build with -framework WebCore and -framework JavaScriptCore.
+
+ * WebKit.xcodeproj/project.pbxproj:
+
+2006-04-04 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Adele Peterson.
+
+ - WebKit part of <rdar://problem/4498418> "Autosaved" searchterms are saved during private browsing
+
+ * WebView/WebView.m:
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+ Pass private browsing setting down to WebCore.
+
+2006-04-03 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ - re-fixed <rdar://problem/4481198> REGRESSION (TOT): search results list in bookmarks view
+ remains when search text is deleted
+
+ * WebView/WebView.m:
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ I fixed this recently, but then broke it again by adding an early bail-out to this method. So
+ now I'm removing the early bail-out.
+
+2006-04-02 Trey Matteson <trey@usa.net>
+
+ Reviewed by Maciej.
+
+ fix http://bugs.webkit.org/show_bug.cgi?id=8121
+ REGRESSION: 404s are not displayed
+
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+ Only cancel failed loads for object elements, not for frames or a whole page.
+
+2006-04-02 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Hyatt.
+
+ - fixed <rdar://problem/4198619> REGRESSION: tabbing through links fails after hitting text field w/ sys's "tab to all controls" off
+ - fixed <rdar://problem/4463760> REGRESSION: Can't tab from old text field (like password fields) to new text field (6811)
+ (http://bugs.webkit.org/show_bug.cgi?id=6811)
+ - fixed tab and shift tab don't select the right things
+ http://bugs.webkit.org/show_bug.cgi?id=5685
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge willMakeFirstResponderForNodeFocus]): New method
+ - let WebHTMLView know that the next time it becomes first
+ responder, it's to change focus within the page and the right node
+ has already been set, so it should not move focus forward or
+ backward inside it.
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView needsPanelToBecomeKey]): Override to return YES, oddly enough this
+ is the right way to tell AppKit that you should be in the tab cycle loop.
+ (-[WebHTMLView becomeFirstResponder]): Don't move forward or back in tab cycle
+ when this becomeFirstResponder is for tabbing from a control in the page.
+ (-[WebHTMLView _willMakeFirstResponderForNodeFocus]): Note that the next
+ time this view becomes first responder, it will be for in-page focus
+ navigation.
+ * WebView/WebHTMLViewInternal.h:
+
+2006-04-01 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=8105
+ REGRESSION (NativeTextField): Option-delete deletes one space before the deleted word
+
+ Test: fast/forms/input-text-option-delete.html
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _deleteWithDirection:granularity:killRing:isTypingAction:]): Pass NO for
+ smartDeleteOK. Smart deletion only applies to deleting a word at a time, and none of
+ the callers of this function that delete a word at a time want smart deletion.
+ (-[WebHTMLView deleteToEndOfLine:]): Fixed tiny formatting glitch.
+
+2006-03-31 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ We need to set reachedTerminalState to YES before we release
+ the resources to prevent a double dealloc of WebView
+
+ Fixes <rdar://problem/4372628> crash deallocating a WebView in -[WebFrame stopLoading]
+
+ * WebView/WebLoader.m:
+ (-[NSURLProtocol releaseResources]): set reachedTerminalState earlier
+
+2006-03-31 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ Some cleanup in the WebIconDatabase code in a fruitless search for the cause
+ of the mysterious -[WebFileDatabase performSetObject:forKey] crash
+
+ * Misc/WebIconDatabase.m:
+ (-[WebIconDatabase _createFileDatabase]):
+ removed obsolete comment
+ (-[WebIconDatabase _loadIconDictionaries]):
+ Added ERRORs for unexpected early returns. Made dictionaries be autoreleased until
+ the end of the method where they are retained, so that the early returns don't leak;
+ added ASSERTs that the _private->dictionary values aren't being leaked.
+ (-[WebIconDatabase _updateFileDatabase]):
+ Added an ERROR for an unexpected early return, and made a trivial style fix.
+
+2006-03-31 Trey Matteson <trey@usa.net>
+
+ Reviewed by Maciej, landed by ap.
+
+ http://bugs.webkit.org/show_bug.cgi?id=7739
+ REGRESSION: Assertion failure loading acid2 test in -[WebCoreFrameBridge installInFrame:]
+
+ Tests: http/tests/misc/acid2.html, http/tests/misc/acid2-pixel.html
+
+ The gist of this change is that we must cancel the load from the Webkit side when we
+ realize we're switching to the fallback content. This is somewhat a temp workaround
+ since control of loading will be moving to WebCore.
+
+ * WebView/WebMainResourceLoader.m:
+ (-[WebMainResourceLoader continueAfterContentPolicy:response:]):
+
+2006-03-30 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by darin
+
+ http://bugs.webkit.org/show_bug.cgi?id=6989
+ REGRESSION: Plain-text mode needed for contenteditable area used in new text field
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _canEditRichly]): Added.
+ (-[WebHTMLView _canIncreaseSelectionListLevel]): Use _canEditRichly
+ (-[WebHTMLView _canDecreaseSelectionListLevel]): Ditto.
+ (-[WebHTMLView _increaseSelectionListLevel]):
+ (-[WebHTMLView _decreaseSelectionListLevel]):
+ (-[WebHTMLView validateUserInterfaceItem:]):
+ Split rich text editing actions off from ones that can be applied anywhere.
+ (-[WebHTMLView _applyStyleToSelection:withUndoAction:]):
+ (-[WebHTMLView _applyParagraphStyleToSelection:withUndoAction:]):
+ (-[WebHTMLView _alignSelectionUsingCSSValue:withUndoAction:]):
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-03-29 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4495316> REGRESSION (420+): After page has loaded, spinning progress indicator is displayed on
+ tab at versiontracker.com
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _receivedMainResourceError:]):
+ Call -_clientRedirectCancelledOrFinished: here so that the frame load delegate is notified that the redirect's
+ status has changed, if there was a redirect. The frame load delegate may have saved some state about
+ the redirect in its -webView:willPerformClientRedirectToURL:delay:fireDate:forFrame:. Since we are definitely
+ not going to use this provisional resource, as it was cancelled, notify the frame load delegate that the redirect
+ has ended.
+ The fix for 4432562 was similar to this, but only took care of the case where the redirect load was actually
+ committed to the frame. The new call to -_clientRedirectCancelledOrFinished: handles the case where the redirect
+ load was successful, but was not committed. This happens with downloads.
+
+2006-03-29 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed these bugs:
+ <rdar://problem/4483806> REGRESSION (417.8-TOT): PDFs don't scale correctly with auto-size (5356)
+ <rdar://problem/3874856> Safari PDF display should be full width by default rather than
+ sized to show the entire page
+
+ * WebView/WebPDFRepresentation.m:
+ (-[WebPDFRepresentation finishedLoadingWithDataSource:]):
+ Let the WebPDFView handle setting the document, because that's the best time to apply
+ the sizing-related preferences.
+
+ * WebView/WebPDFView.h:
+ eliminated firstLayoutDone ivar and -PDFSubview public method; added -setPDFDocument:
+
+ * WebView/WebPDFView.m:
+ (-[WebPDFView initWithFrame:]):
+ eliminate use of obsolete firstLayoutDone ivar
+ (-[WebPDFView _applyPDFDefaults]):
+ renamed from _readPDFDefaults for clarity
+ (-[WebPDFView layout]):
+ removed code that applied the preferences here. This was too early to handle auto-sizing correctly,
+ because -layout can be called before the document exists, and calling setAutoSize:YES at that
+ point confuses PDFView into setting the scale factor to 20 (the maximum).
+ (-[WebPDFView setPDFDocument:]):
+ New method, does what WebPDFRepresentation used to do and also applies the preferences here.
+ This is a good place to apply them because the document is guaranteed to now exist (of course).
+ (-[WebPDFView PDFSubview]):
+ Moved this into a new FileInternal category because it's still needed by another class in
+ this file but no longer needs to be public.
+
+ * WebView/WebPreferences.m:
+ (+[WebPreferences initialize]):
+ Change WebKitPDFScaleFactorPreferenceKey to 0, which represents auto-size. This fixes 3874856,
+ but wasn't feasible until 4483806 was fixed.
+
+2006-03-28 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ - added a build step that checks for init routines
+
+ * WebKit.xcodeproj/project.pbxproj: Added a custom build phase that invokes the
+ check-for-global-initializers script.
+
+2006-03-28 Tim Omernick <timo@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/3694090> -[WebBaseNetscapePluginView finalize] is incorrect; design change needed
+
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView initWithFrame:]):
+ Don't observe preferences changes here -- we only want to observe preferences while the view is
+ installed in the view hierarchy. Plugins will appropriately start and stop themselves when added to
+ or removed from a window.
+ (-[WebBaseNetscapePluginView dealloc]):
+ Don't remove observers here -- they should have been removed when the view was removed from its
+ window.
+ (-[WebBaseNetscapePluginView finalize]):
+ ditto
+ (-[WebBaseNetscapePluginView viewWillMoveToWindow:]):
+ Stop observing preferences when the view is removed from its window.
+ (-[WebBaseNetscapePluginView viewDidMoveToWindow]):
+ Start observing preferences when the view is added to a window.
+
+2006-03-27 Tim Omernick <timo@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/3694090> -[WebBaseNetscapePluginView finalize] is incorrect; design change needed
+
+ * ChangeLog:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView dealloc]):
+ Instead of calling -stop, assert that the plugin is not running. A plugin view cannot be deallocated
+ until it is removed from its window. When a plugin view is removed from its window, it calls -stop
+ on itself. Therefore I believe that this call to -stop is unnecessary; if I'm wrong, then the
+ assertion will help catch any edge cases.
+ (-[WebBaseNetscapePluginView finalize]):
+ ditto
+
+2006-03-27 Tim Omernick <timo@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/3694086> -[WebBaseNetscapePluginStream finalize] is incorrect; design change needed
+
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream dealloc]):
+ Assert that the stream file path either never existed, or was deleted and NULL-ed out. The stream file
+ is now deleted immediately after calling NPP_StreamAsFile().
+ (-[WebBaseNetscapePluginStream finalize]):
+ ditto
+ (-[WebBaseNetscapePluginStream _destroyStream]):
+ Delete the file after calling NPP_StreamAsFile(), instead of in -dealloc/-finalize. It should be OK
+ to delete the file here -- NPP_StreamAsFile() is always called immediately before NPP_DestroyStream()
+ (the stream destruction function), so there can be no expectation that a plugin will read the stream file
+ asynchronously after NPP_StreamAsFile() is called.
+
+2006-03-27 Tim Omernick <timo@apple.com>
+
+ Reviewed by Eric.
+
+ <rdar://problem/3694093> -[WebBasePluginPackage finalize] is incorrect; design change needed
+
+ Call -unload on plug-in packages instead of relying on -dealloc/-finalize to do it. Currently
+ the only place plug-in packages are deallocated is when refreshing the set of plugins, as when
+ handling JavaScript's navigator.plugins.refresh().
+
+ * Plugins/WebBasePluginPackage.m:
+ (-[WebBasePluginPackage dealloc]):
+ Assert that the plug-in has been unloaded by the time -dealloc is called.
+ (-[WebBasePluginPackage finalize]):
+ ditto
+
+ * Plugins/WebPluginDatabase.m:
+ (-[WebPluginDatabase refresh]):
+ Call -unload on the plug-in packages before releasing them.
+
+2006-03-27 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Part of <rdar://problem/4448350> Deprecated ObjC language API used in JavaScriptCore, WebCore,
+ WebKit and WebBrowser
+
+ * Carbon/HIViewAdapter.h:
+ HIViewAdapter is no longer an NSView subclass, since we no longer pose it as NSView.
+ * Carbon/HIViewAdapter.m:
+ (+[NSView bindHIViewToNSView:nsView:]):
+ Replace individual NSView methods instead of posing as NSView.
+ (_webkit_NSView_setNeedsDisplay):
+ Replacement implementation of -[NSView setNeedsDisplay:].
+ (_webkit_NSView_setNeedsDisplayInRect):
+ Replacement implementation of -[NSView setNeedsDisplayInRect:]
+ (_webkit_NSView_nextValidKeyView):
+ Replacement implementation of -[NSView nextValidKeyView]
+
+2006-03-27 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Darin Adler.
+
+ Removed two overzealous assertions that the steps to reproduce 4451831 were running into.
+ Improved comments to match.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge _nextKeyViewOutsideWebFrameViewsWithValidityCheck:]):
+ Remove assertion that _inNextKeyViewOutsideWebFrameViews should always be false here.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView nextValidKeyView]):
+ Removed assertion that the frame should never be the main frame here.
+
+2006-03-27 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ Removed tabs & reformatted code.
+
+ * Carbon/HIViewAdapter.m:
+ (+[NSView bindHIViewToNSView:nsView:]):
+ (+[NSView getHIViewForNSView:]):
+ (+[NSView unbindNSView:]):
+ (-[NSView setNeedsDisplay:]):
+ (-[NSView setNeedsDisplayInRect:]):
+ (-[NSView nextValidKeyView]):
+ (SetViewNeedsDisplay):
+
+2006-03-26 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by darin
+
+ <http://bugs.webkit.org/show_bug.cgi?id=7974>
+ Add EditActions and WebUndoActions for CreateLink and Unlink
+
+ * English.lproj/Localizable.strings:
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge nameForUndoAction:]):
+
+2006-03-23 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ At John's suggestion, renamed a private WebFrame method and tightened up some of the redirect logic I recently touched.
+
+ * WebView/WebFramePrivate.h:
+ Renamed -_clientRedirectCancelled: to -_clientRedirectCancelledOrFinished:, since we call this both when a redirect is
+ cancelled and when a redirect is successfully committed.
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge reportClientRedirectCancelled:]):
+ Call renamed WebFrame method.
+ * WebView/WebFrame.m:
+ Added sentRedirectNotification flag to WebFramePrivate. This flag is set when we notify the frame load delegate that a
+ redirect will occur. We check this flag when committing a provisional load to ensure that the frame load delegate is
+ notified that the redirect finished.
+ (-[WebFrame _commitProvisionalLoad:]):
+ After committing a provisional load, make sure that the frame load delegate is notified that there is no longer a pending
+ redirect.
+ (-[WebFrame _clientRedirectedTo:delay:fireDate:lockHistory:isJavaScriptFormAction:]):
+ Set the new sentRedirectNotification flag.
+ (-[WebFrame _clientRedirectCancelledOrFinished:]):
+ Renamed method.
+ Clear the sentRedirectNotification flag.
+ (-[WebFrame _continueLoadRequestAfterNavigationPolicy:formState:]):
+ Call renamed method.
+
+2006-03-23 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ <rdar://problem/4439752> TinyMCE: "Search in Google" context menu is active but fails to work when selection is active
+ in textarea field.
+
+ * DefaultDelegates/WebDefaultContextMenuDelegate.m:
+ (-[WebDefaultUIDelegate menuItemWithTag:target:representedObject:]):
+ Added a representedObject parameter, which is set on the newly created menu item.
+ (-[WebDefaultUIDelegate contextMenuItemsForElement:defaultMenuItems:]):
+ Instead of setting the representedObject on each menu item after creating them all, pass the element to
+ -menuItemWithTag:target:representedObject:.
+ (-[WebDefaultUIDelegate editingContextMenuItemsForElement:defaultMenuItems:]):
+ ditto. This fixes 4439752 because this method failed to set the representedObject on the menu items as
+ -contextMenuItemsForElement:defaultMenuItems: did.
+
+2006-03-23 Darin Adler <darin@apple.com>
+
+ Reviewed by Eric.
+
+ - fix <rdar://problem/4380465> repro crash when unsuccessfully attempting to import image from Services menu
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _imageElementWithImageResource:]): Quietly do nothing if passed nil.
+ (-[WebDataSource _documentFragmentWithImageResource:]): Ditto.
+
+2006-03-22 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ Even better fix for <rdar://problem/4432562>. We need to notify the frame delegate of a finished redirect for both
+ "fast" and "slow" redirects, after committing the load. My previous change only notified for "fast", history-locking
+ redirects. Now we notify the frame delegate after committing any kind of provisional load, not just in the case of
+ a fast redirect.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _commitProvisionalLoad:]):
+
+2006-03-22 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ Better fix for <rdar://problem/4432562> REGRESSION (TOT): Safari's "stop loading" active, "view source" inactive after page load [7058]
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _transitionToCommitted:]):
+ Cancel the client redirect when we commit the provisional load, if we were waiting for a redirect.
+ This is a better fix for 7058 (<rdar://problem/4432562>). The original fix for 7058 changed the timing of the redirect cancel
+ in such a way that WebKit was precluded from ever reusing back/forward list entries for redirects. Clearing the redirect state
+ here actually makes logical sense, as the redirect's target page is being committed at this point.
+
+2006-03-21 Darin Adler <darin@apple.com>
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=3784
+ <rdar://problem/4483827> JavaScript save dialog disappears right away (sheet triggers blur event) (3784)
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateFocusState]): Treat window as having focus if its sheet is key.
+ (-[WebHTMLView addWindowObservers]): Observe all focus notifications, not just the ones involving this window.
+ (-[WebHTMLView removeWindowObservers]): Ditto.
+ (-[WebHTMLView windowDidBecomeKey:]): Add checks so that we call the methods only when appropriate,
+ since this will now be called for all windows.
+ (-[WebHTMLView windowDidResignKey:]): Ditto.
+
+2006-03-21 Adele Peterson <adele@apple.com>
+
+ Reviewed by Darin.
+
+ - Fix for http://bugs.webkit.org/show_bug.cgi?id=6813
+ elementAtPoint needs to return input element when clicking on new text field
+
+ * WebView/WebDocumentInternal.h: Added elementAtPoint:allowShadowContent:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView elementAtPoint:]): Does not allow shadow content. This way, by default, callers would get the input element instead of the inner div.
+ (-[WebHTMLView elementAtPoint:allowShadowContent:]): Allows callers to specify whether or not the element can be a shadow node.
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]): Allows shadow content when getting element.
+ (-[WebHTMLView _mayStartDragAtEventLocation:]): ditto.
+ (-[WebHTMLView _isSelectionEvent:]): ditto.
+ (-[WebHTMLView _canProcessDragWithDraggingInfo:]): ditto.
+ * WebView/WebFrame.m: (-[WebFrame _actionInformationForNavigationType:event:originalURL:]): Does not allow shadow content when getting element.
+ * WebView/WebImageView.m: (-[WebImageView elementAtPoint:allowShadowContent:]): Added to conform to the WebDocumentElement protocol.
+ * WebView/WebPDFView.m: (-[WebPDFView elementAtPoint:allowShadowContent:]): ditto.
+ * WebView/WebTextView.m: (-[WebTextView elementAtPoint:allowShadowContent:]): ditto.
+
+2006-03-21 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher and Darin.
+
+ <rdar://problem/4427068> LMGetCurApRefNum, CloseConnection and GetDiskFragment deprecated, used in Netscape
+ plugin code
+
+ * Plugins/WebNetscapeDeprecatedFunctions.h: Added.
+ * Plugins/WebNetscapeDeprecatedFunctions.c: Added.
+ Added wrappers for deprecated CFM and LowMem functions. These exist in a separate file so that we can set
+ -Wno-deprecated-declarations on this one file without ignoring other deprecated function usage elsewhere.
+ (WebGetDiskFragment):
+ (WebCloseConnection):
+ (WebLMGetCurApRefNum):
+ (WebLMSetCurApRefNum):
+
+ * Plugins/WebNetscapePluginPackage.h:
+ Don't include connID ivar in 64-bit, since CFM is not supported in 64-bit.
+ * Plugins/WebNetscapePluginPackage.m:
+ (+[WebNetscapePluginPackage initialize]):
+ Don't bother setting the resource refNum in 64-bit, because the API to get and set it does not exist.
+ A theoretical 64-bit plugin couldn't possibly rely this, since there is no API.
+ (-[WebNetscapePluginPackage unloadWithoutShutdown]):
+ No need to close the connID in 64-bit.
+ (-[WebNetscapePluginPackage load]):
+ Don't load CFM bundles in 64-bit, because CFM is not supported.
+
+ * WebKit.xcodeproj/project.pbxproj:
+ Added WebNetscapeDeprecatedFunctions.[hm].
+
+2006-03-21 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ - fixed <rdar://problem/4485637> Implementors of searchFor:direction:caseSensitive:wrap: should bail
+ out early if search string is empty
+
+ This doesn't change any existing behavior, but avoids unnecessary work.
+
+ * Misc/WebSearchableTextView.m:
+ (-[WebSearchableTextView searchFor:direction:caseSensitive:wrap:]):
+ bail out immediately (returning NO) if search string is empty
+
+ * WebView/WebHTMLView.m:
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ ditto
+
+ * WebView/WebPDFView.m:
+ (-[WebPDFView searchFor:direction:caseSensitive:wrap:]):
+ ditto
+
+ * WebView/WebView.m:
+ (-[WebView searchFor:direction:caseSensitive:wrap:]):
+ ditto
+
+2006-03-20 Tim Omernick <timo@apple.com>
+
+ Reviewed by John Sullivan.
+
+ Moved -_contentView from WebFrameViewInternal to WebFrameViewPrivate. Safari
+ needs this.
+
+ * WebView/WebFrameView.m:
+ (-[WebFrameView _contentView]):
+ * WebView/WebFrameViewInternal.h:
+ * WebView/WebFrameViewPrivate.h:
+
+2006-03-17 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Reviewed by Darin, landed by Beth.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=7693
+ WebKit relies on unpredictable timing for onload events
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _receivedMainResourceError:complete:]): Check for
+ completion on the WebCore side before checking on the WebKit side,
+ to ensure that the onload event is emitted before the WebFrame load
+ delegate is sent the webView:didFinishLoadForFrame: message. For
+ DumpRenderTree, this ensures that the render tree is dumped after
+ the onload handler is run.
+ * WebView/WebLoader.m:
+ (-[NSURLProtocol didFailWithError:]): If load has already been
+ cancelled (which could happen if the parent's onload handler caused
+ the frame to detach), do nothing.
+
+2006-03-17 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Beth Dakin
+
+ - fixed <rdar://problem/4239051> Sometimes "Copy Link" in Safari results in a
+ URL on the pasteboard with no usable "title"
+
+ * History/WebURLsWithTitles.m:
+ (+[WebURLsWithTitles writeURLs:andTitles:toPasteboard:]):
+ trim whitespace from titles that are put on pasteboard. This leaves an empty string
+ for the title in cases where there's no displayed text, like an image in an <a> element
+ that happens to have whitespace in the source, e.g. <a href="foo"> <img whatever></a>
+
+2006-03-17 Darin Adler <darin@apple.com>
+
+ - missing bit of my check-in yesterday
+
+ Maciej moved setWindowFrame for me, but I also had removed
+ setWindowContentRect.
+
+ * WebCoreSupport/WebFrameBridge.m: Removed unused setWindowContextRect and
+ windowContentRect methods.
+
+2006-03-17 Adele Peterson <adele@apple.com>
+
+ Reviewed by Hyatt.
+
+ WebKit part of fix for:
+ http://bugs.webkit.org/show_bug.cgi?id=7797
+ Can't set background color on new text fields
+
+ Added function to draw bezeled text field without drawing background.
+
+ * WebCoreSupport/WebGraphicsBridge.m:
+ (-[WebGraphicsBridge drawBezeledTextFieldCell:enabled:]): Added.
+
+2006-03-16 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Eric.
+
+ - move setWindowFrame / windowFrame to WebPageBridge to fix build
+
+ * WebCoreSupport/WebFrameBridge.m:
+ * WebCoreSupport/WebPageBridge.m:
+ (-[WebPageBridge setWindowFrame:]):
+ (-[WebPageBridge windowFrame]):
+
+2006-03-15 Darin Adler <darin@apple.com>
+
+ Fix by Patrick Beard, reviewed by me.
+
+ - fix <rdar://problem/4478181> WebPluginController leaks NSArray and NSMutableSet objects
+
+ * Plugins/WebPluginController.m:
+ (-[WebPluginController initWithDocumentView:]): Call CFMakeCollectable on the CFSet
+ so we can act like it's an NSSet.
+ (-[WebPluginController dealloc]): Release _views and _checksInProgress.
+
+2006-03-13 Tim Omernick <timo@apple.com>
+
+ Reviewed by Maciej.
+
+ <rdar://problem/4476873> Support printing for plugin documents (not embedded plugins)
+
+ * WebView/WebFrameViewPrivate.h:
+ * WebView/WebFrameView.m:
+ (-[WebFrameView documentViewShouldHandlePrint]):
+ Called by the host application before it initializes and runs a print operation. If NO
+ is returned, the host application will abort its print operation and call
+ -printDocumentView on the WebFrameView. The document view is then expected to run its
+ own print operation. If YES is returned, the host application's print operation will
+ continue as normal.
+ (-[WebFrameView printDocumentView]):
+ Called by the host application when the WebFrameView returns YES from -documentViewShouldHandlePrint.
+
+ * Plugins/WebNetscapePluginDocumentView.m:
+ (-[WebNetscapePluginDocumentView documentViewShouldHandlePrint]):
+ Allow the plugin to take over printing if it defines an NPP_Print function
+ (-[WebNetscapePluginDocumentView printDocumentView]):
+ Print the plugin document.
+
+2006-03-13 Geoffrey Garen <ggaren@apple.com>
+
+ Reviewed by timo.
+
+ - Fixed the load progress indicator to give more incremental feedback,
+ and to stop spending so much time near 100%.
+
+ I did two things:
+ (1) Fixed some bugs and a misspelling in the previous heuristic's
+ implementation
+ (2) Added two new rules to the heuristic:
+ (a) Treat the first layout as the half-way point.
+ (b) Just like we jump the first 10% to indicate that a load has
+ started, jump the last 10% to indicate that a load has finished.
+
+ Rule 2a is good for two reasons. First, it seems unnatural for loading
+ to be "more than half done" when you can't even see anything. Second,
+ in the early stages of laading our estimate of how much we'll need to
+ load is often off by as much as 6000% (e.g., cnn.com). So anything that
+ makes the progress indicator more conservative in the early stages of
+ loading is helpful.
+
+ Rule 2b is good because it's confusing for loading to be "100% done"
+ but still ongoing.
+
+ FIXME: The indicator still isn't perfect. For example, the old behavior
+ shows up @ moviefone.com. Two areas for future work:
+ (1) Estimate number of linked resources. Our code estimates the size
+ of a single resource, but does nothing to estimate the number of
+ resources that resource might link to. This is the key to why we're
+ so wrong at the beginning.
+ (2) Improve "when to do first layout" heuristic. A JavaScript query
+ for a style property forces layout, creating a phantom first layout
+ with no content, essentially nullifying 2a for certain pages.
+
+ Filed <rdar://problem/4475834> to track estimating the number of
+ linked resources. Phantom layouts are already on Hyatt's radar.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _setState:]): Update firstLayoutDone
+ (-[WebFrame _numPendingOrLoadingRequests:]): Bug fix: In the recurisve
+ case, query 'frame' instead of 'self', so that we actually recurse.
+ (-[WebFrame _firstLayoutDone]): New method
+ (-[WebFrame _didFirstLayout]): Update firstLayoutDone
+ * WebView/WebFramePrivate.h: Added firstLayoutDone ivar
+ * WebView/WebView.m:
+ (-[WebView _incrementProgressForConnectionDelegate:data:]):
+ (1) Implemented 2a and 2b
+ (2) Bug fix: only update the 'last time I sent a notification' time if
+ we actually send a notification.
+ (3) Don't test for progress < 0 because ensuring progress < max
+ also ensures max - progress > 0. (Do still test for progress > max
+ because rounding errors make that a possibility -- although a very
+ minor one.)
+ (4) Query only the loading frame and its subframes for pending
+ requests instead of defaulting to the main frame. This is a slight
+ optimization in cases where the main frame did not begin the load,
+ and it makes the code more consistent.
+
+2006-03-13 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ - fixed <rdar://problem/4475857> API: Setting a history item limit programmatically doesn't work
+
+ * History/WebHistory.m:
+ (-[WebHistoryPrivate _loadHistoryGuts:URL:error:]):
+ use [self historyItemLimit], which prefers the explicitly-set value and falls back to the
+ NSUserDefaults value, instead of using the NSUserDefaults value explicitly.
+
+2006-03-10 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ * WebCoreSupport/WebFrameBridge.m: Remove unused requestedURLString method.
+
+2006-03-10 Darin Adler <darin@apple.com>
+
+ Reviewed by Geoff.
+
+ - change how frame namespacing works to be more completely on the WebCore side
+
+ * WebView/WebFrameInternal.h: Remove _setFrameNamespace: and _frameNamespace.
+ * WebView/WebFrame.m: Ditto.
+
+ * WebView/WebView.m:
+ (-[WebView setGroupName:]): Call -[WebCorePageBridge setGroupName:].
+ (-[WebView groupName]): Call -[WebCorePageBridge groupName].
+
+2006-03-09 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=7656
+ Query string always appended to Flash URLs, instead of being replaced.
+
+ * Misc/WebNSURLExtras.h: Added _webkit_URLByRemovingResourceSpecifier.
+ * Misc/WebNSURLExtras.m:
+ (+[NSURL _web_URLWithData:relativeToURL:]): Call _webkit_URLByRemovingResourceSpecifier to
+ work around CFURL not removing non-path components from base URLs in some cases.
+ (-[NSURL _webkit_URLByRemovingComponent:]): New generic function for removing URL components.
+ (-[NSURL _webkit_URLByRemovingFragment]): Moved implementation to the above method.
+ (-[NSURL _webkit_URLByRemovingResourceSpecifier]): Added.
+
+2006-03-07 Darin Adler <darin@apple.com>
+
+ Reviewed by Anders.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=7655
+ unwanted output while running layout tests
+
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setRepresentation:]): Clear the flag that records whether we've sent
+ all the data to the representation or not; need this to prevent telling the same representation
+ both that we've succeeded and then later that we've failed.
+ (-[WebDataSource _setMainDocumentError:]): Don't send an error if representationFinishedLoading
+ is already YES. Set representationFinishedLoading.
+ (-[WebDataSource _finishedLoading]): Set representationFinishedLoading.
+ (-[WebDataSource _setupForReplaceByMIMEType:]): Ditto.
+
+2006-03-06 Tim Omernick <timo@apple.com>
+
+ Reviewed by Kevin Decker.
+
+ <rdar://problem/4457574> assertion failure watching trailers at netflix.com -[WebNetscapePluginRepresentation
+ receivedData:withDataSource:] + 684
+
+ * Plugins/WebNetscapePluginRepresentation.m:
+ (-[WebNetscapePluginRepresentation receivedData:withDataSource:]):
+ Moved the ASSERT(instance) to the block that actually requires an assertion -- the plugin view should never
+ have a NULL instance by the time we start the NPStream (by calling -startStreamWithResponse:).
+ Some stream teardown logic changed with my fix to 4153419: when a WebBaseNetscapePluginStream is destroyed,
+ it now clears its NPP instance backpointer. The WebBaseNetscapePluginStream may be destroyed from within
+ -startStreamWithResponse: if NPP_NewStream() returns an error. We can handle this gracefully by changing
+ the assertion before -receivedData: to a simple NULL check.
+ This is unrelated to the Radar, but prior to this fix, we would attempt an NPP_Write() with the initial
+ stream data even if NPP_NewStream() returned an error. Seems like that alone could cause issues, though
+ I'm guessing that plugins handle this in practice.
+
+2006-03-03 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ <rdar://problem/4411822> wrong element shown in Inspector inspecting main image at apple.com
+ <rdar://problem/4411908> in the Web Inspector, state of disclosure triangles should be preserved after search
+ http://bugs.webkit.org/show_bug.cgi?id=6616
+ Bug 6616: Double-clicking on a search result seems broken
+ http://bugs.webkit.org/show_bug.cgi?id=6709
+ Bug 6709: TypeError: Value undefined (result of expression treeScrollbar.refresh) is not object.
+
+ Code clean up and move more code into JavaScript.
+ Removes a few unused ObjC methods.
+ Many search fixes. Reveals the focused node when exiting the search.
+ Shows a "No Selection" screen when there are no search results.
+ Shows a node count for the number of results.
+ Fixes a couple of TypeErrors that show on the console.
+ Uses the system selection color in the Style pane tables.
+
+ * English.lproj/Localizable.strings: removed localized strings
+ * WebInspector.subproj/WebInspector.m:
+ (-[WebInspector init]):
+ (-[WebInspector dealloc]):
+ (-[WebInspector window]):
+ (-[WebInspector setSearchQuery:]):
+ (-[WebInspector resizeTopArea]):
+ (-[WebInspector searchPerformed:]): called from JavaScript when a search happens
+ (-[WebInspector _toggleIgnoreWhitespace:]):
+ (-[WebInspector _exitSearch:]): exit search results on double click
+ (-[WebInspector _focusRootNode:]):
+ (-[WebInspector _revealAndSelectNodeInTree:]):
+ (-[WebInspector _refreshSearch]):
+ (-[WebInspector _update]):
+ (-[WebInspector _updateTraversalButtons]):
+ (-[WebInspector _updateRoot]):
+ (-[WebInspector _updateTreeScrollbar]):
+ (-[WebInspector _updateSystemColors]): update CSS with system colors
+ (-[WebInspector webView:didFinishLoadForFrame:]):
+ (-[WebInspector webView:plugInViewWithArguments:]):
+ (-[WebInspector outlineViewSelectionDidChange:]): test for webViewLoaded
+ (-[WebInspectorPrivate init]): alloc rightArrowImage and downArrowImage
+ (-[WebInspectorPrivate dealloc]): no more matchedRules
+ (-[DOMNode _displayName]): removed localization UI_STRING calls.
+ * WebInspector.subproj/WebInspectorInternal.h:
+ * WebInspector.subproj/webInspector/inspector.css:
+ * WebInspector.subproj/webInspector/inspector.html:
+ * WebInspector.subproj/webInspector/inspector.js:
+
+2006-03-02 Alexey Proskuryakov <ap@nypop.com>
+
+ Fixed a typo in the comments added in the previous checkin.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:referrer:forDataSource:]):
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:postData:referrer:forDataSource:]):
+
+2006-03-02 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=7540
+ REGRESSION: frequent cache-related crashes
+
+ - http://bugs.webkit.org/show_bug.cgi?id=7393
+ A stale comment about XMLHttpRequest responses being never cached
+
+ * WebCoreSupport/WebFrameBridge.m: Don't call setHTTPHeader if the method is GET.
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ * WebCoreSupport/WebSubresourceLoader.m: Ditto. Also removed a stale comment about
+ XMLHTTPRequests.
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:referrer:forDataSource:]):
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:postData:referrer:forDataSource:]):
+
+2006-02-23 David Harrison <harrison@apple.com>
+
+ Reviewed by Justin.
+
+ <rdar://problem/4359736> Support outlining ability with lists
+
+ Added Mail SPI for list level changes. It is SPI because it is not complete support
+ for outlining. See <rdar://problem/4457070> "API for html lists as note outlines".
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _canIncreaseSelectionListLevel]):
+ (-[WebHTMLView _canDecreaseSelectionListLevel]):
+ (-[WebHTMLView _increaseSelectionListLevel]):
+ (-[WebHTMLView _decreaseSelectionListLevel]):
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-03-01 Alexey Proskuryakov <ap@nypop.com>
+
+ Reviewed by Darin.
+
+ - http://bugs.webkit.org/show_bug.cgi?id=3812
+ XMLHttpRequest: PUT, DELETE, HEAD and all other methods but POST actually do a GET.
+
+ All WebKit changes are to use the method parameter passed from WebCore.
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:]):
+ (-[WebFrameBridge startLoadingResource:withMethod:URL:customHeaders:postData:]):
+ (-[WebFrameBridge syncLoadResourceWithMethod:URL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ * WebCoreSupport/WebSubresourceLoader.h:
+ * WebCoreSupport/WebSubresourceLoader.m:
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:referrer:forDataSource:]):
+ (+[WebSubresourceLoader startLoadingResource:withMethod:URL:customHeaders:postData:referrer:forDataSource:]):
+
+2006-03-01 Timothy Hatcher <timothy@apple.com>
+
+ Reviewed by Darin.
+
+ http://bugs.webkit.org/show_bug.cgi?id=7450
+ elementAtPoint is expensive and should return a smart dictionary
+
+ <rdar://problem/2952761> moving the mouse around eats more CPU than I would expect (7450)
+
+ elementAtPoint for WebHTMLView now returns a WebElementDictionary,
+ when objectForKey is called it will lookup in the DOM, cache and return the value
+
+ * Misc/WebElementDictionary.h: Added.
+ * Misc/WebElementDictionary.m: Added.
+ (addLookupKey):
+ (cacheValueForKey):
+ (+[WebElementDictionary initializeLookupTable]):
+ (-[WebElementDictionary initWithInnerNonSharedNode:innerNode:URLElement:andPoint:]):
+ (-[WebElementDictionary dealloc]):
+ (-[WebElementDictionary _fillCache]):
+ (-[WebElementDictionary count]):
+ (-[WebElementDictionary keyEnumerator]):
+ (-[WebElementDictionary objectForKey:]):
+ (-[WebElementDictionary _domNode]):
+ (-[WebElementDictionary _webFrame]):
+ (-[WebElementDictionary _targetWebFrame]):
+ (-[WebElementDictionary _title]):
+ (-[WebElementDictionary _imageRect]):
+ (-[WebElementDictionary _isSelected]):
+ * Misc/WebNSViewExtras.m:
+ (-[NSView _web_dragImage:element:rect:event:pasteboard:source:offset:]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateMouseoverWithEvent:]):
+ (-[WebHTMLView _startDraggingImage:at:operation:event:sourceIsDHTML:DHTMLWroteData:]):
+ (-[WebHTMLView elementAtPoint:]):
+ * WebView/WebView.m:
+ * WebView/WebViewPrivate.h:
+
+2006-02-28 Darin Adler <darin@apple.com>
+
+ Reviewed by Adele.
+
+ - remove obsolete WebCoreScrollView class
+
+ * WebView/WebDynamicScrollBarsView.h: Change base class to NSScrollView instead of WebCoreScrollView.
+ * WebView/WebDynamicScrollBarsView.m: (-[WebDynamicScrollBarsView autoforwardsScrollWheelEvents]): Added.
+
+2006-02-28 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Eric Seidel
+
+ Wean WebKit from one more SPI call. We learned about this new-to-Tiger
+ API from filing Radar 4433222.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _autoscroll]):
+ use public CGEventSourceButtonState() instead of WKMouseIsDown() (which was using SPI internally)
+
+2006-02-27 Tim Omernick <timo@apple.com>
+
+ Reviewed by Adele.
+
+ <rdar://problem/4222043> Safari should reduce null events sent to invisible plugins
+
+ * Plugins/WebBaseNetscapePluginView.h:
+ * Plugins/WebBaseNetscapePluginView.m:
+ (-[WebBaseNetscapePluginView restartNullEvents]):
+ Check to see if the plugin view is completely obscured (scrolled out of view, for example). If it is
+ obscured and it wasn't before, or the other way around, then restart the null event timer so it can
+ fire at the appropriate rate.
+ (-[WebBaseNetscapePluginView viewHasMoved:]):
+ If a plugin is obscured, send it null events as if it were in an inactive window.
+
+2006-02-26 Mitz Pettel <opendarwin.org@mitzpettel.com>
+
+ Test: fast/frames/empty-frame-document.html
+
+ Reviewed by Darin.
+
+ - fix http://bugs.webkit.org/show_bug.cgi?id=7293
+ REGRESSION: Using Javascript Bookmarklets that reference location.href on a blank tab crashes WebKit
+
+ The crash happened because an empty frame did not have a document.
+
+ * WebView/WebFrame.m:
+ (-[WebFrame _commitProvisionalLoad:]): Use "about:blank" instead of an empty URL for empty
+ frames. This causes a document to be created for the frame.
+
+2006-02-21 Kevin Decker <kdecker@apple.com>
+
+ Reviewed by Darin.
+
+ Backed out my previous check in. Since these methods are internal to WebKit (and not private)
+ it's perfectly OK for them to remain as categories.
+ * ChangeLog:
+ * WebView/WebPreferences.m:
+ (-[WebPreferences _integerValueForKey:]):
+ (-[WebPreferences _setIntegerValue:forKey:]):
+ (-[WebPreferences _floatValueForKey:]):
+ (-[WebPreferences _setFloatValue:forKey:]):
+ (-[WebPreferences _boolValueForKey:]):
+ (-[WebPreferences _setBoolValue:forKey:]):
+ * WebView/WebPreferencesPrivate.h:
+
+2006-02-20 Darin Adler <darin@apple.com>
+
+ Collaborated with Graham Dennis <Graham.Dennis@gmail.com> on this.
+
+ - WebKit part of fix for http://bugs.webkit.org/show_bug.cgi?id=6831
+ contentEditable outline darkens as caret moves
+
+ * WebCoreSupport/WebGraphicsBridge.m:
+ (-[WebGraphicsBridge drawFocusRingWithPath:radius:color:]):
+ Replaced the old bridge function that set up style with this one that renders a path.
+
+2006-02-19 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - cut out a little unneeded bridge code
+
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge webView]): Added. Helper, since the WebCore side of the bridge no longer
+ has this method.
+ (-[WebFrameBridge createWindowWithURL:]): Removed the frameName parameter -- this is now
+ handled on the WebCore side. Also return a page bridge instead of a frame bridge.
+ (-[WebFrameBridge createModalDialogWithURL:]): Changed to return a page bridge instead of
+ a frame bridge.
+
+ * WebView/WebFrame.m: (-[WebFrame webView]): Change to get the webView from the page bridge
+ instead of the frame bridge, since it's a per-page thing.
+
+ * WebView/WebView.m: Removed init method since it just does what the default does (calls
+ initWithFrame: with a zero rect).
+ (-[WebView initWithCoder:]): Added checking so that if the obejcts have the wrong type
+ we will fail gracefully instead of hitting "method not found" and the like.
+ (-[WebView setPreferencesIdentifier:]): Fix storage leak. The WebPreferences object was
+ not released.
+ (-[WebView mainFrame]): Removed excess "return nil".
+ (-[WebView _pageBridge]): Added. Helper to let you go from the WebView to the bridge
+ from outside the WebView class.
+ * WebView/WebViewInternal.h: Put _pageBridge into an internal header.
+
+ * WebCoreSupport/WebPageBridge.m: (-[WebPageBridge outerView]): Added. Replaces "webView"
+ as public method to tell the WebCore side about the view everything's embedded in.
+
+ - other cleanup
+
+ * WebCoreSupport/WebPageBridge.h: Removed some unneeded declarations.
+
+ * Plugins/WebBaseNetscapePluginView.m: (-[WebBaseNetscapePluginView loadPluginRequest:]):
+ Rearrange code so it doesn't have to get the main frame twice.
+
+2006-02-18 Maciej Stachowiak <mjs@apple.com>
+
+ Not reviewed.
+
+ - fix build broken by my last checkin, the remaining code was not doing anything.
+
+ * WebView/WebDataSource.m:
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _createPageCacheForItem:]):
+
+2006-02-16 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Darin.
+
+ - removed a few unused fields and methods of WebDataSource
+
+ * WebView/WebDataSource.m:
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebView.m:
+ (+[WebView _MIMETypeForFile:]):
+ (-[WebView _updateWebCoreSettingsFromPreferences:]):
+
+2006-02-15 Justin Garcia <justin.garcia@apple.com>
+
+ Reviewed by darin
+
+ <http://bugs.webkit.org/show_bug.cgi?id=7148>
+ Add drag and drop support to DumpRenderTree
+
+ Added a UI delegate method so that DumpRenderTree can perform dragging on its own.
+ Made _updateFocusState SPI, to allow us to test the behavior and appearance of
+ windows that have or don't have focus.
+
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _updateFocusState]):
+ (-[WebHTMLView viewDidMoveToWindow]):
+ (-[WebHTMLView windowDidBecomeKey:]):
+ (-[WebHTMLView windowDidResignKey:]):
+ (-[WebHTMLView dragImage:at:offset:event:pasteboard:source:slideBack:]):
+ (-[WebHTMLView becomeFirstResponder]):
+ (-[WebHTMLView resignFirstResponder]):
+ (-[WebHTMLView _formControlIsResigningFirstResponder:]):
+ * WebView/WebHTMLViewInternal.h:
+ * WebView/WebHTMLViewPrivate.h:
+ * WebView/WebUIDelegatePrivate.h:
+ * WebView/WebView.m:
+
+2006-02-15 Darin Adler <darin@apple.com>
+
+ * English.lproj/StringsNotToBeLocalized.txt: Updated for recent changes.
+
+2006-02-15 Maciej Stachowiak <mjs@apple.com>
+
+ Rubber stamped by Anders.
+
+ * WebView/WebControllerPolicyHandlerDelegate.h: Removed.
+
+2006-02-15 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ - remove some voodoo code
+
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _setLoading:]): Removed useless ref/deref of self and WebView.
+ A WebDataSource cannot be loading unless it is still connected to the WebView that
+ owns it and retained by it, because getting disconnected stops loading.
+
+2006-02-13 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Anders.
+
+ Improvements to frame loading:
+
+ - remove LayoutAcceptable state entirely
+ - fix WebImageView to work right without LayoutAcceptable state
+ - move guts of commitIfReady: to WebFrame
+ - try to separate page cache loading from normal loading a bit more
+
+ * English.lproj/StringsNotToBeLocalized.txt:
+ * WebView/WebDataSource.m:
+ (-[WebDataSource _prepareForLoadStart]):
+ (-[WebDataSource _loadFromPageCache:]):
+ (-[WebDataSource _startLoading]):
+ (-[WebDataSource _commitIfReady]):
+ (-[WebDataSource _setupForReplaceByMIMEType:]):
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebFrame.m:
+ (-[WebFrame _transitionToCommitted:]):
+ (-[WebFrame _commitProvisionalLoad:]):
+ (-[WebFrame _checkLoadCompleteForThisFrame]):
+ (-[WebFrame _continueLoadRequestAfterNavigationPolicy:formState:]):
+ * WebView/WebFramePrivate.h:
+ * WebView/WebImageRepresentation.h:
+ * WebView/WebImageRepresentation.m:
+ * WebView/WebImageView.m:
+ (-[WebImageView dataSourceUpdated:]):
+ (-[WebImageView setNeedsLayout:]):
+ (-[WebImageView writeImageToPasteboard:types:]):
+ (-[WebImageView copy:]):
+ (-[WebImageView mouseDragged:]):
+ * WebView/WebView.m:
+ (-[WebView _finishedLoadingResourceFromDataSource:]):
+ (-[WebView _mainReceivedBytesSoFar:fromDataSource:complete:]):
+
+2006-02-13 John Sullivan <sullivan@apple.com>
+
+ Reviewed by Tim Omernick.
+
+ Support for highlighting multiple text matches.
+
+ * WebView/WebHTMLViewPrivate.h:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView highlightAllMatchesForString:caseSensitive:]):
+ new method, calls through to bridge
+ (-[WebHTMLView clearHighlightedMatches]):
+ ditto
+
+ * WebView/WebViewPrivate.h:
+ * WebView/WebView.m:
+ (-[WebView highlightAllMatchesForString:caseSensitive:]):
+ new method, calls through to documentView. For now this is hardwired to only work
+ with WebHTMLViews.
+ (-[WebView clearHighlightedMatches]):
+ ditto
+
+2006-02-13 Darin Adler <darin@apple.com>
+
+ Reviewed by Maciej.
+
+ - move pointer from frame to page over to WebCore
+
+ * WebCoreSupport/WebPageBridge.m: (-[WebPageBridge initWithMainFrameName:webView:frameView:]):
+ Call super init to create the page before creating the main frame and calling setMainFrame: with it.
+
+ * WebCoreSupport/WebFrameBridge.h: Remove page pointer, and change init function parameters.
+ * WebCoreSupport/WebFrameBridge.m:
+ (-[WebFrameBridge initMainFrameWithPage:frameName:view:]): New function that is used only for
+ the main frame. Passes the page over to the other side of the bridge.
+ (-[WebFrameBridge initSubframeWithRenderer:frameName:view:]): New function that is used only for
+ subframes. Passes the renderer over to the other side of the bridge.
+ (-[WebFrameBridge mainFrame]):
+ (-[WebFrameBridge webView]):
+ (-[WebFrameBridge createWindowWithURL:frameName:]):
+ (-[WebFrameBridge showWindow]):
+ (-[WebFrameBridge areToolbarsVisible]):
+ (-[WebFrameBridge setToolbarsVisible:]):
+ (-[WebFrameBridge isStatusbarVisible]):
+ (-[WebFrameBridge setStatusbarVisible:]):
+ (-[WebFrameBridge setWindowFrame:]):
+ (-[WebFrameBridge windowFrame]):
+ (-[WebFrameBridge setWindowContentRect:]):
+ (-[WebFrameBridge windowContentRect]):
+ (-[WebFrameBridge setWindowIsResizable:]):
+ (-[WebFrameBridge windowIsResizable]):
+ (-[WebFrameBridge firstResponder]):
+ (-[WebFrameBridge makeFirstResponder:]):
+ (-[WebFrameBridge closeWindowSoon]):
+ (-[WebFrameBridge runJavaScriptAlertPanelWithMessage:]):
+ (-[WebFrameBridge runJavaScriptConfirmPanelWithMessage:]):
+ (-[WebFrameBridge canRunBeforeUnloadConfirmPanel]):
+ (-[WebFrameBridge runBeforeUnloadConfirmPanelWithMessage:]):
+ (-[WebFrameBridge runJavaScriptTextInputPanelWithPrompt:defaultText:returningText:]):
+ (-[WebFrameBridge addMessageToConsole:]):
+ (-[WebFrameBridge runOpenPanelForFileButtonWithResultListener:]):
+ (-[WebFrameBridge setStatusText:]):
+ (-[WebFrameBridge syncLoadResourceWithURL:customHeaders:postData:finalURL:responseHeaders:statusCode:]):
+ (-[WebFrameBridge focusWindow]):
+ (-[WebFrameBridge createChildFrameNamed:withURL:referrer:renderPart:allowsScrolling:marginWidth:marginHeight:]):
+ (-[WebFrameBridge userAgentForURL:]):
+ (-[WebFrameBridge _nextKeyViewOutsideWebFrameViewsWithValidityCheck:]):
+ (-[WebFrameBridge previousKeyViewOutsideWebFrameViews]):
+ (-[WebFrameBridge defersLoading]):
+ (-[WebFrameBridge setDefersLoading:]):
+ (-[WebFrameBridge viewForPluginWithURL:attributeNames:attributeValues:MIMEType:]):
+ (-[WebFrameBridge _preferences]):
+ (-[WebFrameBridge selectWordBeforeMenuEvent]):
+ (-[WebFrameBridge historyLength]):
+ (-[WebFrameBridge canGoBackOrForward:]):
+ (-[WebFrameBridge goBackOrForward:]):
+ (-[WebFrameBridge print]):
+ (-[WebFrameBridge pollForAppletInView:]):
+ (-[WebFrameBridge respondToChangedContents]):
+ (-[WebFrameBridge respondToChangedSelection]):
+ (-[WebFrameBridge undoManager]):
+ (-[WebFrameBridge issueCutCommand]):
+ (-[WebFrameBridge issueCopyCommand]):
+ (-[WebFrameBridge issuePasteCommand]):
+ (-[WebFrameBridge issuePasteAndMatchStyleCommand]):
+ (-[WebFrameBridge canPaste]):
+ (-[WebFrameBridge overrideMediaType]):
+ (-[WebFrameBridge isEditable]):
+ (-[WebFrameBridge shouldChangeSelectedDOMRange:toDOMRange:affinity:stillSelecting:]):
+ (-[WebFrameBridge shouldBeginEditing:]):
+ (-[WebFrameBridge shouldEndEditing:]):
+ (-[WebFrameBridge windowObjectCleared]):
+ (-[WebFrameBridge spellCheckerDocumentTag]):
+ (-[WebFrameBridge isContinuousSpellCheckingEnabled]):
+ (-[WebFrameBridge didFirstLayout]):
+ (-[WebFrameBridge dashboardRegionsChanged:]):
+ (-[WebFrameBridge createModalDialogWithURL:]):
+ (-[WebFrameBridge canRunModal]):
+ (-[WebFrameBridge runModal]):
+ Change all calls to [_page webView] to use [self webView] instead.
+
+=== WebKit-521.7
+
+2006-02-11 Maciej Stachowiak <mjs@apple.com>
+
+ Reviewed by Hyatt.
+
+ - factor WebArchive creation code out of other classes into new WebArchiver
+ http://bugs.webkit.org/show_bug.cgi?id=7208
+
+ * DOM/WebDOMOperations.m:
+ (-[DOMNode webArchive]):
+ (-[DOMRange webArchive]):
+ * WebKit.xcodeproj/project.pbxproj:
+ * WebView/WebArchiver.h: Added.
+ * WebView/WebArchiver.m: Added.
+ (+[WebArchiver _subframeArchivesForFrame:]):
+ (+[WebArchiver archiveFrame:]):
+ (+[WebArchiver _archiveCurrentStateForFrame:]):
+ (+[WebArchiver _archiveWithMarkupString:fromFrame:nodes:]):
+ (+[WebArchiver archiveRange:]):
+ (+[WebArchiver archiveNode:]):
+ (+[WebArchiver archiveSelectionInFrame:]):
+ * WebView/WebDataSource.m:
+ (-[WebDataSource webArchive]):
+ * WebView/WebDataSourcePrivate.h:
+ * WebView/WebHTMLView.m:
+ (-[WebHTMLView _writeSelectionWithPasteboardTypes:toPasteboard:cachedAttributedString:]):
+ (-[WebHTMLView _writeSelectionToPasteboard:]):
+ * WebView/WebHTMLViewPrivate.h:
+
+2006-02-11 Darin Adler <darin@apple.com>
+
+ * English.lproj/StringsNotToBeLocalized.txt: Updated paths for recent changes in directory structure.
+
+2006-02-11 David Kilzer <ddkilzer@kilzer.net>
+
+ Reviewed by John Sullivan.
+
+ - Fix http://bugs.webkit.org/show_bug.cgi?id=7171
+ No description in WebKitErrors.m for WebKitErrorPlugInWillHandleLoad
+
+ * English.lproj/Localizable.strings: Added new UI_STRING().
+ * Misc/WebKitErrors.m: Added #define for description.
+ (registerErrors): Added dictionary entry.
+
+2006-02-09 Tim Omernick <timo@apple.com>
+
+ Reviewed by Tim Hatcher.
+
+ <rdar://problem/4153419> CrashTracer: 576 crashes in Safari at com.apple.WebKit: NPN_DestroyStream + 56
+
+ I never could reproduce this crasher, which seems to be caused by the Speed Download plugin. However,
+ I did find a way to make the affected code more bulletproof for those who are experiencing the crash.
+
+ * Plugins/WebBaseNetscapePluginStream.h:
+ Keep a WebBaseNetscapePluginView instead of the WebNetscapePluginPackage, since the plugin view could
+ potentially be deallocated before the stream finishes loading.
+ * Plugins/WebBaseNetscapePluginStream.m:
+ (-[WebBaseNetscapePluginStream _pluginCancelledConnectionError]):
+ Use pluginView instead of plugin.
+ (-[WebBaseNetscapePluginStream dealloc]):
+ Assert that the plugin instance has been nulled out, since that's now part of the stream's teardown
+ phase.
+ Release pluginView instead of plugin.
+ (-[WebBaseNetscapePluginStream setPluginPointer:]):
+ Retain the plugin view instead of the plugin package, since the plugin view could be deallocated while
+ the stream is running.
+ This method now accepts a NULL argument so that we can easily clear out the pluginView backpointer
+ (and other ivars derived from it).
+ (-[WebBaseNetscapePluginStream startStreamResponseURL:expectedContentLength:lastModifiedDate:MIMEType:]):
+ Use pluginView instead of plugin.
+ (-[WebBaseNetscapePluginStream _destroyStream]):
+ ditto
+ (-[WebBaseNetscapePluginStream finishedLoadingWithData:]):
+ ditto
+ (-[WebBaseNetscapePluginStream cancelLoadAndDestroyStreamWithError]):
+ Set the plugin instance to NULL, so that the pluginView backpointer is released. This method is called
+ for every plugin view's stream when the plugin view is stopped/destroyed.
+ (-[WebBaseNetscapePluginStream _deliverData]):
+ Use pluginView instead of plugin.
+
+== Rolled over to ChangeLog-2006-02-09 ==