diff options
Diffstat (limited to 'WebKit/mac/Plugins/Hosted/WebHostedNetscapePluginView.mm')
| -rw-r--r-- | WebKit/mac/Plugins/Hosted/WebHostedNetscapePluginView.mm | 339 | 
1 files changed, 339 insertions, 0 deletions
| diff --git a/WebKit/mac/Plugins/Hosted/WebHostedNetscapePluginView.mm b/WebKit/mac/Plugins/Hosted/WebHostedNetscapePluginView.mm new file mode 100644 index 0000000..c17d249 --- /dev/null +++ b/WebKit/mac/Plugins/Hosted/WebHostedNetscapePluginView.mm @@ -0,0 +1,339 @@ +/* + * Copyright (C) 2008 Apple Inc. All Rights Reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + *    notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + *    notice, this list of conditions and the following disclaimer in the + *    documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY + * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.  + */ +#if USE(PLUGIN_HOST_PROCESS) + +#import "WebHostedNetscapePluginView.h" + +#import "NetscapePluginInstanceProxy.h" +#import "NetscapePluginHostManager.h" +#import "NetscapePluginHostProxy.h" +#import "WebTextInputWindowController.h" +#import "WebView.h" +#import "WebViewInternal.h" +#import "WebUIDelegate.h" + +#import <CoreFoundation/CoreFoundation.h> +#import <WebCore/HTMLPlugInElement.h> +#import <WebCore/runtime.h> +#import <WebCore/runtime_root.h> +#import <WebCore/WebCoreObjCExtras.h> +#import <runtime/InitializeThreading.h> +#import <wtf/Assertions.h> + +using namespace WebKit; + +extern "C" { +#include "WebKitPluginClientServer.h" +#include "WebKitPluginHost.h" +} + +@implementation WebHostedNetscapePluginView + ++ (void)initialize +{ +    JSC::initializeThreading(); +#ifndef BUILDING_ON_TIGER +    WebCoreObjCFinalizeOnMainThread(self); +#endif +    WKSendUserChangeNotifications(); +} + +- (id)initWithFrame:(NSRect)frame +      pluginPackage:(WebNetscapePluginPackage *)pluginPackage +                URL:(NSURL *)URL +            baseURL:(NSURL *)baseURL +           MIMEType:(NSString *)MIME +      attributeKeys:(NSArray *)keys +    attributeValues:(NSArray *)values +       loadManually:(BOOL)loadManually +            element:(PassRefPtr<WebCore::HTMLPlugInElement>)element +{ +    self = [super initWithFrame:frame pluginPackage:pluginPackage URL:URL baseURL:baseURL MIMEType:MIME attributeKeys:keys attributeValues:values loadManually:loadManually element:element]; +    if (!self) +        return nil; +     +    return self; +}     + +- (void)handleMouseMoved:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->mouseEvent(self, event, NPCocoaEventMouseMoved); +} + +- (void)setAttributeKeys:(NSArray *)keys andValues:(NSArray *)values +{ +    ASSERT(!_attributeKeys && !_attributeValues); +     +    _attributeKeys.adoptNS([keys copy]); +    _attributeValues.adoptNS([values copy]); +}     + +- (BOOL)createPlugin +{ +    ASSERT(!_proxy); + +    NSString *userAgent = [[self webView] userAgentForURL:_baseURL.get()]; + +    _proxy = NetscapePluginHostManager::shared().instantiatePlugin(_pluginPackage.get(), self, _MIMEType.get(), _attributeKeys.get(), _attributeValues.get(), userAgent, _sourceURL.get()); +    if (!_proxy)  +        return NO; + +    if (_proxy->useSoftwareRenderer()) +        _softwareRenderer = WKSoftwareCARendererCreate(_proxy->renderContextID()); +    else { +        _pluginLayer = WKMakeRenderLayer(_proxy->renderContextID()); +        self.wantsLayer = YES; +    } +     +    // Update the window frame. +    _proxy->windowFrameChanged([[self window] frame]); +     +    return YES; +} + +- (void)setLayer:(CALayer *)newLayer +{ +    [super setLayer:newLayer]; +     +    if (_pluginLayer) +        [newLayer addSublayer:_pluginLayer.get()]; +} + +- (void)loadStream +{ +} + +- (void)updateAndSetWindow +{ +    if (!_proxy) +        return; +     +    // Use AppKit to convert view coordinates to NSWindow coordinates. +    NSRect boundsInWindow = [self convertRect:[self bounds] toView:nil]; +    NSRect visibleRectInWindow = [self convertRect:[self visibleRect] toView:nil]; +     +    // Flip Y to convert NSWindow coordinates to top-left-based window coordinates. +    float borderViewHeight = [[self currentWindow] frame].size.height; +    boundsInWindow.origin.y = borderViewHeight - NSMaxY(boundsInWindow); +    visibleRectInWindow.origin.y = borderViewHeight - NSMaxY(visibleRectInWindow); + +    _proxy->resize(boundsInWindow, visibleRectInWindow); +} + +- (void)windowFocusChanged:(BOOL)hasFocus +{ +    if (_proxy) +        _proxy->windowFocusChanged(hasFocus); +} + +- (BOOL)shouldStop +{ +    if (!_proxy) +        return YES; +     +    return _proxy->shouldStop(); +} + +- (void)destroyPlugin +{ +    if (_proxy) { +        if (_softwareRenderer) { +            WKSoftwareCARendererDestroy(_softwareRenderer); +            _softwareRenderer = 0; +        } +         +        _proxy->destroy(); +        _proxy = 0; +    } +     +    _pluginLayer = 0; +} + +- (void)startTimers +{ +    if (_proxy) +        _proxy->startTimers(_isCompletelyObscured); +} + +- (void)stopTimers +{ +    if (_proxy) +        _proxy->stopTimers(); +} + +- (void)focusChanged +{ +    if (_proxy) +        _proxy->focusChanged(_hasFocus); +} + +- (void)windowFrameDidChange:(NSNotification *)notification  +{ +    if (_proxy && [self window]) +        _proxy->windowFrameChanged([[self window] frame]); +} + +- (void)addWindowObservers +{ +    [super addWindowObservers]; +     +    ASSERT([self window]); +     +    NSWindow *window = [self window]; +     +    NSNotificationCenter *notificationCenter = [NSNotificationCenter defaultCenter]; +    [notificationCenter addObserver:self selector:@selector(windowFrameDidChange:)  +                               name:NSWindowDidMoveNotification object:window]; +    [notificationCenter addObserver:self selector:@selector(windowFrameDidChange:) +                               name:NSWindowDidResizeNotification object:window];     + +    if (_proxy) +        _proxy->windowFrameChanged([window frame]); +    [self updateAndSetWindow]; +} + +- (void)removeWindowObservers +{ +    [super removeWindowObservers]; +     +    NSNotificationCenter *notificationCenter = [NSNotificationCenter defaultCenter]; +    [notificationCenter removeObserver:self name:NSWindowDidMoveNotification object:nil]; +    [notificationCenter removeObserver:self name:NSWindowDidResizeNotification object:nil]; +} + +- (void)mouseDown:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->mouseEvent(self, event, NPCocoaEventMouseDown); +} + +- (void)mouseUp:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->mouseEvent(self, event, NPCocoaEventMouseUp); +} + +- (void)mouseDragged:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->mouseEvent(self, event, NPCocoaEventMouseDragged); +} + +- (void)mouseEntered:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->mouseEvent(self, event, NPCocoaEventMouseEntered); +} + +- (void)mouseExited:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->mouseEvent(self, event, NPCocoaEventMouseExited); +} + +- (NSTextInputContext *)inputContext +{ +    return [[WebTextInputWindowController sharedTextInputWindowController] inputContext]; +} + +- (void)keyDown:(NSEvent *)event +{ +    if (!_isStarted || !_proxy) +        return; +     +    NSString *string = nil; +    if ([[WebTextInputWindowController sharedTextInputWindowController] interpretKeyEvent:event string:&string]) { +        if (string) +            _proxy->insertText(string); +        return; +    } +     +    _proxy->keyEvent(self, event, NPCocoaEventKeyDown); +} + +- (void)keyUp:(NSEvent *)event +{ +    if (_isStarted && _proxy) +        _proxy->keyEvent(self, event, NPCocoaEventKeyUp); +} + +- (void)pluginHostDied +{ +    _pluginHostDied = YES; + +    _pluginLayer = nil; +    _proxy = 0; +     +    // No need for us to be layer backed anymore +    self.wantsLayer = NO; +     +    [self setNeedsDisplay:YES]; +} + + +- (void)drawRect:(NSRect)rect +{ +    if (_proxy) { +        if (_softwareRenderer) { +            if ([NSGraphicsContext currentContextDrawingToScreen]) +                WKSoftwareCARendererRender(_softwareRenderer, (CGContextRef)[[NSGraphicsContext currentContext] graphicsPort], NSRectToCGRect(rect)); +            else +                _proxy->print(reinterpret_cast<CGContextRef>([[NSGraphicsContext currentContext] graphicsPort]), [self bounds].size.width, [self bounds].size.height); +        } +             +        return; +    } +     +    if (_pluginHostDied) { +        static NSImage *nullPlugInImage; +        if (!nullPlugInImage) { +            NSBundle *bundle = [NSBundle bundleForClass:[WebHostedNetscapePluginView class]]; +            nullPlugInImage = [[NSImage alloc] initWithContentsOfFile:[bundle pathForResource:@"nullplugin" ofType:@"tiff"]]; +            [nullPlugInImage setFlipped:YES]; +        } +         +        if (!nullPlugInImage) +            return; +         +        NSSize imageSize = [nullPlugInImage size]; +        NSSize viewSize = [self bounds].size; +         +        NSPoint point = NSMakePoint((viewSize.width - imageSize.width) / 2.0, (viewSize.height - imageSize.height) / 2.0); +        [nullPlugInImage drawAtPoint:point fromRect:NSZeroRect operation:NSCompositeSourceOver fraction:1.0]; +    } +} + +- (PassRefPtr<JSC::Bindings::Instance>)createPluginBindingsInstance:(PassRefPtr<JSC::Bindings::RootObject>)rootObject +{ +    if (!_proxy) +        return 0; +     +    return _proxy->createBindingsInstance(rootObject); +} + +@end + +#endif | 
