2008-05-06 Anders Carlsson <andersca@apple.com>
authorandersca@apple.com <andersca@apple.com@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Wed, 7 May 2008 00:52:56 +0000 (00:52 +0000)
committerandersca@apple.com <andersca@apple.com@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Wed, 7 May 2008 00:52:56 +0000 (00:52 +0000)
        Reviewed by Mitz.

        Add NPN_PopUpContextMenu example.

        * NetscapeCocoaPlugin/MenuHandler.h: Added.
        * NetscapeCocoaPlugin/MenuHandler.m: Added.
        (-[MenuHandler _openURL:]):
        (-[MenuHandler _disabledItem:]):
        (-[MenuHandler validateUserInterfaceItem:]):
        (-[MenuHandler initWithBrowserFuncs:instance:]):
        (-[MenuHandler dealloc]):
        (-[MenuHandler menu]):
        * NetscapeCocoaPlugin/NetscapeCocoaPlugin.xcodeproj/project.pbxproj:
        * NetscapeCocoaPlugin/main.m:
        (NPP_Destroy):
        (handleMouseEvent):

git-svn-id: https://svn.webkit.org/repository/webkit/trunk@32931 268f45cc-cd09-0410-ab3c-d52691b4dbfc

WebKitExamplePlugins/ChangeLog
WebKitExamplePlugins/NetscapeCocoaPlugin/MenuHandler.h [new file with mode: 0644]
WebKitExamplePlugins/NetscapeCocoaPlugin/MenuHandler.m [new file with mode: 0644]
WebKitExamplePlugins/NetscapeCocoaPlugin/NetscapeCocoaPlugin.xcodeproj/project.pbxproj
WebKitExamplePlugins/NetscapeCocoaPlugin/main.m

index 0fb771f..d62cbc1 100644 (file)
@@ -1,5 +1,24 @@
 2008-05-06  Anders Carlsson  <andersca@apple.com>
 
+        Reviewed by Mitz.
+
+        Add NPN_PopUpContextMenu example.
+        
+        * NetscapeCocoaPlugin/MenuHandler.h: Added.
+        * NetscapeCocoaPlugin/MenuHandler.m: Added.
+        (-[MenuHandler _openURL:]):
+        (-[MenuHandler _disabledItem:]):
+        (-[MenuHandler validateUserInterfaceItem:]):
+        (-[MenuHandler initWithBrowserFuncs:instance:]):
+        (-[MenuHandler dealloc]):
+        (-[MenuHandler menu]):
+        * NetscapeCocoaPlugin/NetscapeCocoaPlugin.xcodeproj/project.pbxproj:
+        * NetscapeCocoaPlugin/main.m:
+        (NPP_Destroy):
+        (handleMouseEvent):
+
+2008-05-06  Anders Carlsson  <andersca@apple.com>
+
         Reviewed by Jon, Tim and Mark.
 
         Add a sample NPAPI plugin that uses the Cocoa event model.
diff --git a/WebKitExamplePlugins/NetscapeCocoaPlugin/MenuHandler.h b/WebKitExamplePlugins/NetscapeCocoaPlugin/MenuHandler.h
new file mode 100644 (file)
index 0000000..19070f0
--- /dev/null
@@ -0,0 +1,47 @@
+/*
+ IMPORTANT:  This Apple software is supplied to you by Apple Computer, Inc. ("Apple") in
+ consideration of your agreement to the following terms, and your use, installation, 
+ modification or redistribution of this Apple software constitutes acceptance of these 
+ terms.  If you do not agree with these terms, please do not use, install, modify or 
+ redistribute this Apple software.
+ In consideration of your agreement to abide by the following terms, and subject to these 
+ terms, Apple grants you a personal, non-exclusive license, under Apple’s copyrights in 
+ this original Apple software (the "Apple Software"), to use, reproduce, modify and 
+ redistribute the Apple Software, with or without modifications, in source and/or binary 
+ forms; provided that if you redistribute the Apple Software in its entirety and without 
+ modifications, you must retain this notice and the following text and disclaimers in all 
+ such redistributions of the Apple Software.  Neither the name, trademarks, service marks 
+ or logos of Apple Computer, Inc. may be used to endorse or promote products derived from 
+ the Apple Software without specific prior written permission from Apple. Except as expressly
+ stated in this notice, no other rights or licenses, express or implied, are granted by Apple
+ herein, including but not limited to any patent rights that may be infringed by your 
+ derivative works or by other works in which the Apple Software may be incorporated.
+ The Apple Software is provided by Apple on an "AS IS" basis.  APPLE MAKES NO WARRANTIES, 
+ EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, 
+ MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS 
+ USE AND OPERATION ALONE OR IN COMBINATION WITH YOUR PRODUCTS.
+ IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR CONSEQUENTIAL 
+ DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 
+ OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, 
+ REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED AND 
+ WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), STRICT LIABILITY OR 
+ OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#import <Cocoa/Cocoa.h>
+#import <WebKit/npfunctions.h>
+
+@interface MenuHandler : NSObject {
+    NSMenu *menu;
+    NPNetscapeFuncs *browserFuncs;
+    NPP instance;
+}
+
+- (id)initWithBrowserFuncs:(NPNetscapeFuncs *)theBrowserFuncs instance:(NPP)theInstance;
+
+- (NSMenu *)menu;
+
+@end
diff --git a/WebKitExamplePlugins/NetscapeCocoaPlugin/MenuHandler.m b/WebKitExamplePlugins/NetscapeCocoaPlugin/MenuHandler.m
new file mode 100644 (file)
index 0000000..b9feb1c
--- /dev/null
@@ -0,0 +1,99 @@
+/*
+ IMPORTANT:  This Apple software is supplied to you by Apple Computer, Inc. ("Apple") in
+ consideration of your agreement to the following terms, and your use, installation, 
+ modification or redistribution of this Apple software constitutes acceptance of these 
+ terms.  If you do not agree with these terms, please do not use, install, modify or 
+ redistribute this Apple software.
+ In consideration of your agreement to abide by the following terms, and subject to these 
+ terms, Apple grants you a personal, non-exclusive license, under Apple’s copyrights in 
+ this original Apple software (the "Apple Software"), to use, reproduce, modify and 
+ redistribute the Apple Software, with or without modifications, in source and/or binary 
+ forms; provided that if you redistribute the Apple Software in its entirety and without 
+ modifications, you must retain this notice and the following text and disclaimers in all 
+ such redistributions of the Apple Software.  Neither the name, trademarks, service marks 
+ or logos of Apple Computer, Inc. may be used to endorse or promote products derived from 
+ the Apple Software without specific prior written permission from Apple. Except as expressly
+ stated in this notice, no other rights or licenses, express or implied, are granted by Apple
+ herein, including but not limited to any patent rights that may be infringed by your 
+ derivative works or by other works in which the Apple Software may be incorporated.
+ The Apple Software is provided by Apple on an "AS IS" basis.  APPLE MAKES NO WARRANTIES, 
+ EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, 
+ MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS 
+ USE AND OPERATION ALONE OR IN COMBINATION WITH YOUR PRODUCTS.
+ IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR CONSEQUENTIAL 
+ DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 
+ OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, 
+ REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED AND 
+ WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), STRICT LIABILITY OR 
+ OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#import "MenuHandler.h"
+
+@implementation MenuHandler
+
+- (void)_openURL:(id)sender
+{
+    browserFuncs->geturl(instance, "http://www.apple.com/", "_blank");
+}
+
+- (void)_disabledItem:(id)sender
+{
+    // This should never be called
+}
+
+- (BOOL)validateUserInterfaceItem:(id <NSValidatedUserInterfaceItem>)anItem
+{
+    SEL sel = [anItem action];
+    
+    if (sel == @selector(_openURL:))
+        return YES;
+    
+    if (sel == @selector(_disabledItem:))
+        return NO;
+    
+    return NO;
+}
+
+- (id)initWithBrowserFuncs:(NPNetscapeFuncs *)theBrowserFuncs instance:(NPP)theInstance;
+{
+    self = [super init];
+    if (!self)
+        return nil;
+
+    browserFuncs = theBrowserFuncs;
+    instance = theInstance;
+    
+    // Create the menu
+    menu = [[NSMenu alloc] initWithTitle:@"Menu"];
+    
+    NSMenuItem *item = [[NSMenuItem alloc] initWithTitle:@"Open URL" action:@selector(_openURL:) keyEquivalent:@""];
+    [item setTarget:self];   
+    [menu addItem:item];    
+    [item release];
+    
+    item = [[NSMenuItem alloc] initWithTitle:@"Disabled Item" action:@selector(_disabledItem:) keyEquivalent:@""];
+    [item setTarget:self];   
+    [menu addItem:item];    
+    [item release];
+    
+    return self;
+}
+
+- (void)dealloc
+{
+    [menu release];
+    
+    [super dealloc];
+}
+
+
+- (NSMenu *)menu
+{
+    return menu;
+}
+
+@end
index c37216a..1c78769 100644 (file)
@@ -9,6 +9,7 @@
 /* Begin PBXBuildFile section */
                1A624E590DCBC7F6006898C8 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 1A624E580DCBC7F6006898C8 /* main.m */; };
                1A6250420DCBC81B006898C8 /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1A6250410DCBC81B006898C8 /* Cocoa.framework */; };
+               1AAD6A090DD0DC52003985DA /* MenuHandler.m in Sources */ = {isa = PBXBuildFile; fileRef = 1AAD6A080DD0DC52003985DA /* MenuHandler.m */; };
                8D5B49A804867FD3000E48DA /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 8D5B49A704867FD3000E48DA /* InfoPlist.strings */; };
 /* End PBXBuildFile section */
 
@@ -16,6 +17,8 @@
                089C167EFE841241C02AAC07 /* English */ = {isa = PBXFileReference; fileEncoding = 10; lastKnownFileType = text.plist.strings; name = English; path = English.lproj/InfoPlist.strings; sourceTree = "<group>"; };
                1A624E580DCBC7F6006898C8 /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = "<group>"; };
                1A6250410DCBC81B006898C8 /* Cocoa.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Cocoa.framework; path = /System/Library/Frameworks/Cocoa.framework; sourceTree = "<absolute>"; };
+               1AAD6A070DD0DC52003985DA /* MenuHandler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MenuHandler.h; sourceTree = "<group>"; };
+               1AAD6A080DD0DC52003985DA /* MenuHandler.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = MenuHandler.m; sourceTree = "<group>"; };
                8D576316048677EA00EA77CD /* NetscapeCocoaPlugin.plugin */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = NetscapeCocoaPlugin.plugin; sourceTree = BUILT_PRODUCTS_DIR; };
                8D576317048677EA00EA77CD /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist; path = Info.plist; sourceTree = "<group>"; };
 /* End PBXFileReference section */
@@ -64,6 +67,8 @@
                        isa = PBXGroup;
                        children = (
                                1A624E580DCBC7F6006898C8 /* main.m */,
+                               1AAD6A070DD0DC52003985DA /* MenuHandler.h */,
+                               1AAD6A080DD0DC52003985DA /* MenuHandler.m */,
                        );
                        name = Source;
                        sourceTree = "<group>";
                        buildActionMask = 2147483647;
                        files = (
                                1A624E590DCBC7F6006898C8 /* main.m in Sources */,
+                               1AAD6A090DD0DC52003985DA /* MenuHandler.m in Sources */,
                        );
                        runOnlyForDeploymentPostprocessing = 0;
                };
index 2e18693..4073f8a 100644 (file)
@@ -25,7 +25,7 @@
  
  IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR CONSEQUENTIAL 
  DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 
         OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, 
+ OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, 
  REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED AND 
  WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), STRICT LIABILITY OR 
  OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
@@ -37,6 +37,8 @@
 
 #import <Cocoa/Cocoa.h>
 
+#import "MenuHandler.h"
+
 // Browser function table
 static NPNetscapeFuncs* browser;
 
@@ -50,6 +52,8 @@ typedef struct PluginObject
     NSString *string;
     bool hasFocus;
     bool mouseIsInsidePlugin;
+    
+    MenuHandler *menuHandler;
 } PluginObject;
 
 NPError NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode, int16 argc, char* argn[], char* argv[], NPSavedData* saved);
@@ -145,6 +149,8 @@ NPError NPP_Destroy(NPP instance, NPSavedData** save)
     PluginObject *obj = instance->pdata;
     
     [obj->string release];
+    [obj->menuHandler release];
+    
     free(obj);
     
     return NPERR_NO_ERROR;
@@ -220,6 +226,8 @@ static void handleDraw(PluginObject *obj)
 static NSString *eventType(NPCocoaEventType type)
 {
     switch (type) {
+        case NPCocoaEventScrollWheel:
+            return @"NPCocoaEventScrollWheel";
         case NPCocoaEventMouseDown:
             return @"NPCocoaEventMouseDown";
         case NPCocoaEventMouseUp:
@@ -276,6 +284,14 @@ static void handleMouseEvent(PluginObject *obj, NPCocoaEvent *event)
     obj->string = [string retain];
  
     invalidatePlugin(obj);
+    
+    if (event->event.mouse.buttonNumber == 1) {
+        if (!obj->menuHandler)
+            obj->menuHandler = [[MenuHandler alloc] initWithBrowserFuncs:browser instance:obj->npp];
+        
+        browser->popupcontextmenu(obj->npp, (NPNSMenu *)[obj->menuHandler menu]);
+        NSLog(@"foo");
+    }
 }
 
 static void handleKeyboardEvent(PluginObject *obj, NPCocoaEvent *event)