From f05b935882198ccf7d81675736e3aeb089c5113a Mon Sep 17 00:00:00 2001 From: Ben Murdoch Date: Thu, 5 May 2011 14:36:32 +0100 Subject: Merge WebKit at r74534: Initial merge by git. Change-Id: I6ccd1154fa1b19c2ec2a66878eb675738735f1eb --- .../English.lproj/InfoPlist.strings | Bin 0 -> 92 bytes Examples/NetscapeInputMethodPlugin/Info.plist | 36 ++ .../project.pbxproj | 243 +++++++++++++ Examples/NetscapeInputMethodPlugin/main.m | 398 +++++++++++++++++++++ Examples/NetscapeInputMethodPlugin/test.html | 11 + 5 files changed, 688 insertions(+) create mode 100644 Examples/NetscapeInputMethodPlugin/English.lproj/InfoPlist.strings create mode 100644 Examples/NetscapeInputMethodPlugin/Info.plist create mode 100644 Examples/NetscapeInputMethodPlugin/NetscapeInputMethodPlugin.xcodeproj/project.pbxproj create mode 100644 Examples/NetscapeInputMethodPlugin/main.m create mode 100644 Examples/NetscapeInputMethodPlugin/test.html (limited to 'Examples/NetscapeInputMethodPlugin') diff --git a/Examples/NetscapeInputMethodPlugin/English.lproj/InfoPlist.strings b/Examples/NetscapeInputMethodPlugin/English.lproj/InfoPlist.strings new file mode 100644 index 0000000..5e45963 Binary files /dev/null and b/Examples/NetscapeInputMethodPlugin/English.lproj/InfoPlist.strings differ diff --git a/Examples/NetscapeInputMethodPlugin/Info.plist b/Examples/NetscapeInputMethodPlugin/Info.plist new file mode 100644 index 0000000..a09cb1f --- /dev/null +++ b/Examples/NetscapeInputMethodPlugin/Info.plist @@ -0,0 +1,36 @@ + + + + + CFBundleDevelopmentRegion + English + CFBundleExecutable + NetscapeInputMethodPlugin + CFBundleIconFile + + CFBundleIdentifier + com.apple.netscapeinputmethodplugin + CFBundleInfoDictionaryVersion + 6.0 + CFBundlePackageType + BRPL + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1.0 + WebPluginDescription + Simple Netscape plug-in that shows how to use input methods + WebPluginMIMETypes + + test/x-netscape-input-method-plugin + + WebPluginTypeDescription + Netscape Input Method Plug-in + + + WebPluginName + Netscape Input Method Plug-in + + diff --git a/Examples/NetscapeInputMethodPlugin/NetscapeInputMethodPlugin.xcodeproj/project.pbxproj b/Examples/NetscapeInputMethodPlugin/NetscapeInputMethodPlugin.xcodeproj/project.pbxproj new file mode 100644 index 0000000..474c2cb --- /dev/null +++ b/Examples/NetscapeInputMethodPlugin/NetscapeInputMethodPlugin.xcodeproj/project.pbxproj @@ -0,0 +1,243 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 42; + objects = { + +/* 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 */; }; + 8D5B49A804867FD3000E48DA /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 8D5B49A704867FD3000E48DA /* InfoPlist.strings */; }; +/* End PBXBuildFile section */ + +/* Begin PBXFileReference section */ + 089C167EFE841241C02AAC07 /* English */ = {isa = PBXFileReference; fileEncoding = 10; lastKnownFileType = text.plist.strings; name = English; path = English.lproj/InfoPlist.strings; sourceTree = ""; }; + 1A624E580DCBC7F6006898C8 /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = ""; }; + 1A6250410DCBC81B006898C8 /* Cocoa.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Cocoa.framework; path = /System/Library/Frameworks/Cocoa.framework; sourceTree = ""; }; + 8D576316048677EA00EA77CD /* NetscapeInputMethodPlugin.plugin */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = NetscapeInputMethodPlugin.plugin; sourceTree = BUILT_PRODUCTS_DIR; }; + 8D576317048677EA00EA77CD /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist; path = Info.plist; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 8D576313048677EA00EA77CD /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 1A6250420DCBC81B006898C8 /* Cocoa.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 089C166AFE841209C02AAC07 /* NetscapeInputMethodPlugin */ = { + isa = PBXGroup; + children = ( + 08FB77AFFE84173DC02AAC07 /* Source */, + 089C167CFE841241C02AAC07 /* Resources */, + 089C1671FE841209C02AAC07 /* External Frameworks and Libraries */, + 19C28FB6FE9D52B211CA2CBB /* Products */, + ); + name = NetscapeInputMethodPlugin; + sourceTree = ""; + }; + 089C1671FE841209C02AAC07 /* External Frameworks and Libraries */ = { + isa = PBXGroup; + children = ( + 1A6250410DCBC81B006898C8 /* Cocoa.framework */, + ); + name = "External Frameworks and Libraries"; + sourceTree = ""; + }; + 089C167CFE841241C02AAC07 /* Resources */ = { + isa = PBXGroup; + children = ( + 8D576317048677EA00EA77CD /* Info.plist */, + 8D5B49A704867FD3000E48DA /* InfoPlist.strings */, + ); + name = Resources; + sourceTree = ""; + }; + 08FB77AFFE84173DC02AAC07 /* Source */ = { + isa = PBXGroup; + children = ( + 1A624E580DCBC7F6006898C8 /* main.m */, + ); + name = Source; + sourceTree = ""; + }; + 19C28FB6FE9D52B211CA2CBB /* Products */ = { + isa = PBXGroup; + children = ( + 8D576316048677EA00EA77CD /* NetscapeInputMethodPlugin.plugin */, + ); + name = Products; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 8D57630D048677EA00EA77CD /* NetscapeInputMethodPlugin */ = { + isa = PBXNativeTarget; + buildConfigurationList = 149C298308902C53008A9EFC /* Build configuration list for PBXNativeTarget "NetscapeInputMethodPlugin" */; + buildPhases = ( + 8D576311048677EA00EA77CD /* Sources */, + 8D57630F048677EA00EA77CD /* Resources */, + 8D576313048677EA00EA77CD /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = NetscapeInputMethodPlugin; + productInstallPath = "$(HOME)/Library/Bundles"; + productName = NetscapeInputMethodPlugin; + productReference = 8D576316048677EA00EA77CD /* NetscapeInputMethodPlugin.plugin */; + productType = "com.apple.product-type.bundle"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 089C1669FE841209C02AAC07 /* Project object */ = { + isa = PBXProject; + buildConfigurationList = 149C298708902C53008A9EFC /* Build configuration list for PBXProject "NetscapeInputMethodPlugin" */; + compatibilityVersion = "Xcode 2.4"; + developmentRegion = English; + hasScannedForEncodings = 1; + knownRegions = ( + English, + Japanese, + French, + German, + ); + mainGroup = 089C166AFE841209C02AAC07 /* NetscapeInputMethodPlugin */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 8D57630D048677EA00EA77CD /* NetscapeInputMethodPlugin */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 8D57630F048677EA00EA77CD /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 8D5B49A804867FD3000E48DA /* InfoPlist.strings in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 8D576311048677EA00EA77CD /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 1A624E590DCBC7F6006898C8 /* main.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXVariantGroup section */ + 8D5B49A704867FD3000E48DA /* InfoPlist.strings */ = { + isa = PBXVariantGroup; + children = ( + 089C167EFE841241C02AAC07 /* English */, + ); + name = InfoPlist.strings; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 149C298408902C53008A9EFC /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DEBUGGING_SYMBOLS = full; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INFOPLIST_FILE = Info.plist; + INSTALL_PATH = "$(HOME)/Library/Bundles"; + PRODUCT_NAME = NetscapeInputMethodPlugin; + WRAPPER_EXTENSION = plugin; + ZERO_LINK = YES; + }; + name = Debug; + }; + 149C298508902C53008A9EFC /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ARCHS = ( + ppc, + i386, + ); + GCC_DEBUGGING_SYMBOLS = full; + GCC_GENERATE_DEBUGGING_SYMBOLS = NO; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INFOPLIST_FILE = Info.plist; + INSTALL_PATH = "$(HOME)/Library/Bundles"; + PRODUCT_NAME = NetscapeInputMethodPlugin; + WRAPPER_EXTENSION = plugin; + }; + name = Release; + }; + 149C298808902C53008A9EFC /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ARCHS = "$(ARCHS_STANDARD_32_64_BIT_PRE_XCODE_3_1)"; + ARCHS_STANDARD_32_64_BIT_PRE_XCODE_3_1 = "ppc i386 ppc64 x86_64"; + GCC_C_LANGUAGE_STANDARD = c99; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + PREBINDING = NO; + SDKROOT = /Developer/SDKs/MacOSX10.5.sdk; + }; + name = Debug; + }; + 149C298908902C53008A9EFC /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ARCHS = "$(ARCHS_STANDARD_32_64_BIT_PRE_XCODE_3_1)"; + ARCHS_STANDARD_32_64_BIT_PRE_XCODE_3_1 = "ppc i386 ppc64 x86_64"; + GCC_C_LANGUAGE_STANDARD = c99; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + PREBINDING = NO; + SDKROOT = /Developer/SDKs/MacOSX10.5.sdk; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 149C298308902C53008A9EFC /* Build configuration list for PBXNativeTarget "NetscapeInputMethodPlugin" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 149C298408902C53008A9EFC /* Debug */, + 149C298508902C53008A9EFC /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 149C298708902C53008A9EFC /* Build configuration list for PBXProject "NetscapeInputMethodPlugin" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 149C298808902C53008A9EFC /* Debug */, + 149C298908902C53008A9EFC /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 089C1669FE841209C02AAC07 /* Project object */; +} diff --git a/Examples/NetscapeInputMethodPlugin/main.m b/Examples/NetscapeInputMethodPlugin/main.m new file mode 100644 index 0000000..0adc21b --- /dev/null +++ b/Examples/NetscapeInputMethodPlugin/main.m @@ -0,0 +1,398 @@ +/* + 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 +#import +#import + +#import + +// Browser function table +static NPNetscapeFuncs* browser; + +// Structure for per-instance storage +typedef struct PluginObject +{ + NPP npp; + + NPWindow window; + + bool pluginHasFocus; + + bool textFieldHasFocus; + NSRect textFieldRect; + + NSRange selectedRange; + NSTextStorage *textStorage; + NSLayoutManager *layoutManager; + NSTextContainer *textContainer; + +} PluginObject; + +NPError NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode, int16 argc, char* argn[], char* argv[], NPSavedData* saved); +NPError NPP_Destroy(NPP instance, NPSavedData** save); +NPError NPP_SetWindow(NPP instance, NPWindow* window); +NPError NPP_NewStream(NPP instance, NPMIMEType type, NPStream* stream, NPBool seekable, uint16* stype); +NPError NPP_DestroyStream(NPP instance, NPStream* stream, NPReason reason); +int32 NPP_WriteReady(NPP instance, NPStream* stream); +int32 NPP_Write(NPP instance, NPStream* stream, int32 offset, int32 len, void* buffer); +void NPP_StreamAsFile(NPP instance, NPStream* stream, const char* fname); +void NPP_Print(NPP instance, NPPrint* platformPrint); +int16 NPP_HandleEvent(NPP instance, void* event); +void NPP_URLNotify(NPP instance, const char* URL, NPReason reason, void* notifyData); +NPError NPP_GetValue(NPP instance, NPPVariable variable, void* value); +NPError NPP_SetValue(NPP instance, NPNVariable variable, void* value); + +#pragma export on +// Mach-o entry points +NPError NP_Initialize(NPNetscapeFuncs* browserFuncs); +NPError NP_GetEntryPoints(NPPluginFuncs* pluginFuncs); +void NP_Shutdown(void); +#pragma export off + +NPError NP_Initialize(NPNetscapeFuncs* browserFuncs) +{ + browser = browserFuncs; + return NPERR_NO_ERROR; +} + +NPError NP_GetEntryPoints(NPPluginFuncs* pluginFuncs) +{ + pluginFuncs->version = 11; + pluginFuncs->size = sizeof(pluginFuncs); + pluginFuncs->newp = NPP_New; + pluginFuncs->destroy = NPP_Destroy; + pluginFuncs->setwindow = NPP_SetWindow; + pluginFuncs->newstream = NPP_NewStream; + pluginFuncs->destroystream = NPP_DestroyStream; + pluginFuncs->asfile = NPP_StreamAsFile; + pluginFuncs->writeready = NPP_WriteReady; + pluginFuncs->write = (NPP_WriteProcPtr)NPP_Write; + pluginFuncs->print = NPP_Print; + pluginFuncs->event = NPP_HandleEvent; + pluginFuncs->urlnotify = NPP_URLNotify; + pluginFuncs->getvalue = NPP_GetValue; + pluginFuncs->setvalue = NPP_SetValue; + + return NPERR_NO_ERROR; +} + +void NP_Shutdown(void) +{ +} + +NPError NPP_New(NPMIMEType pluginType, NPP instance, uint16 mode, int16 argc, char* argn[], char* argv[], NPSavedData* saved) +{ + // Create per-instance storage + PluginObject* obj = (PluginObject*)malloc(sizeof(PluginObject)); + bzero(obj, sizeof(PluginObject)); + + obj->npp = instance; + instance->pdata = obj; + + // Ask the browser if it supports the CoreGraphics drawing model + NPBool supportsCoreGraphics; + if (browser->getvalue(instance, NPNVsupportsCoreGraphicsBool, &supportsCoreGraphics) != NPERR_NO_ERROR) + supportsCoreGraphics = FALSE; + + if (!supportsCoreGraphics) + return NPERR_INCOMPATIBLE_VERSION_ERROR; + + // If the browser supports the CoreGraphics drawing model, enable it. + browser->setvalue(instance, NPPVpluginDrawingModel, (void*)NPDrawingModelCoreGraphics); + + // If the browser supports the Cocoa event model, enable it. + NPBool supportsCocoa; + if (browser->getvalue(instance, NPNVsupportsCocoaBool, &supportsCocoa) != NPERR_NO_ERROR) + supportsCocoa = FALSE; + + if (!supportsCocoa) + return NPERR_INCOMPATIBLE_VERSION_ERROR; + + browser->setvalue(instance, NPPVpluginEventModel, (void*)NPEventModelCocoa); + + obj->textFieldRect = NSMakeRect(10, 10, 200, 100); + + obj->textStorage = [[NSTextStorage alloc] initWithString:@""]; + obj->layoutManager = [[NSLayoutManager alloc] init]; + [obj->textStorage addLayoutManager:obj->layoutManager]; + + obj->textContainer = [[NSTextContainer alloc] initWithContainerSize:obj->textFieldRect.size]; + [obj->layoutManager addTextContainer:obj->textContainer]; + + obj->selectedRange.location = [obj->textStorage length]; + + return NPERR_NO_ERROR; +} + +NPError NPP_Destroy(NPP instance, NPSavedData** save) +{ + // Free per-instance storage + PluginObject* obj = instance->pdata; + + [obj->textStorage release]; + [obj->layoutManager release]; + + free(obj); + + return NPERR_NO_ERROR; +} + +NPError NPP_SetWindow(NPP instance, NPWindow* window) +{ + PluginObject* obj = instance->pdata; + obj->window = *window; + + return NPERR_NO_ERROR; +} + + +NPError NPP_NewStream(NPP instance, NPMIMEType type, NPStream* stream, NPBool seekable, uint16* stype) +{ + *stype = NP_ASFILEONLY; + return NPERR_NO_ERROR; +} + +NPError NPP_DestroyStream(NPP instance, NPStream* stream, NPReason reason) +{ + return NPERR_NO_ERROR; +} + +int32 NPP_WriteReady(NPP instance, NPStream* stream) +{ + return 0; +} + +int32 NPP_Write(NPP instance, NPStream* stream, int32 offset, int32 len, void* buffer) +{ + return 0; +} + +void NPP_StreamAsFile(NPP instance, NPStream* stream, const char* fname) +{ +} + +void NPP_Print(NPP instance, NPPrint* platformPrint) +{ + +} + +static void handleDraw(PluginObject* obj, NPCocoaEvent *event) +{ + NSGraphicsContext *oldContext = [[NSGraphicsContext currentContext] retain]; + + NSGraphicsContext *context = [NSGraphicsContext graphicsContextWithGraphicsPort:event->data.draw.context + flipped:YES]; + + + [NSGraphicsContext setCurrentContext:context]; + + NSRect rect = NSMakeRect(0, 0, obj->window.width, obj->window.height); + + [[NSColor lightGrayColor] set]; + [NSBezierPath fillRect:rect]; + + if (obj->pluginHasFocus) { + [[NSColor blackColor] set]; + [NSBezierPath strokeRect:rect]; + } + + [[NSColor whiteColor] set]; + [NSBezierPath fillRect:obj->textFieldRect]; + + // Draw the text + NSRange glyphRange = [obj->layoutManager glyphRangeForTextContainer:obj->textContainer]; + if (glyphRange.length > 0) { + [obj->layoutManager drawBackgroundForGlyphRange:glyphRange atPoint:obj->textFieldRect.origin]; + [obj->layoutManager drawGlyphsForGlyphRange:glyphRange atPoint:obj->textFieldRect.origin]; + } + + NSBezierPath *textInputBorder = [NSBezierPath bezierPathWithRect:obj->textFieldRect]; + [[NSColor blackColor] set]; + + if (obj->pluginHasFocus && obj->textFieldHasFocus) + [textInputBorder setLineWidth:2]; + else + [textInputBorder setLineWidth:1]; + + [textInputBorder stroke]; + + if (obj->pluginHasFocus && obj->textFieldHasFocus) { + NSUInteger rectCount; + NSRect *rectArray = [obj->layoutManager rectArrayForCharacterRange:obj->selectedRange + withinSelectedCharacterRange:obj->selectedRange + inTextContainer:obj->textContainer + rectCount:&rectCount]; + + [[NSColor blackColor] set]; + for (unsigned i = 0; i < rectCount; i++) { + NSRect rect = rectArray[i]; + rect.origin.x += obj->textFieldRect.origin.x; + rect.origin.y += obj->textFieldRect.origin.y; + + [NSBezierPath strokeRect:rect]; + } + } + + [NSGraphicsContext setCurrentContext:oldContext]; +} + +static void invalidatePlugin(PluginObject* obj) +{ + NPRect rect; + rect.left = 0; + rect.top = 0; + rect.right = obj->window.width; + rect.bottom = obj->window.height; + + browser->invalidaterect(obj->npp, &rect); +} + +static void handleFocusChanged(NPCocoaEvent* cocoaEvent, PluginObject* obj) +{ + obj->pluginHasFocus = cocoaEvent->data.focus.hasFocus; + + invalidatePlugin(obj); +} + +static void handleMouseMoved(NPCocoaEvent* cocoaEvent, PluginObject* obj) +{ + NSPoint point = NSMakePoint(cocoaEvent->data.mouse.pluginX, cocoaEvent->data.mouse.pluginY); + + if (NSPointInRect(point, obj->textFieldRect)) + [[NSCursor IBeamCursor] set]; + else + [[NSCursor arrowCursor] set]; +} + +static void handleMouseDown(NPCocoaEvent* cocoaEvent, PluginObject* obj) +{ + NSPoint point = NSMakePoint(cocoaEvent->data.mouse.pluginX, cocoaEvent->data.mouse.pluginY); + + obj->textFieldHasFocus = NSPointInRect(point, obj->textFieldRect); + + invalidatePlugin(obj); +} + +static int16_t handleTextFieldKeyDown(NPCocoaEvent* event, PluginObject* obj) +{ + NSString *string = (NSString *)event->data.key.charactersIgnoringModifiers; + + unichar c = [string length] > 0 ? [string characterAtIndex:0] : 0; + + switch (c) { + case NSLeftArrowFunctionKey: + if (obj->selectedRange.location > 0) { + obj->selectedRange.location--; + invalidatePlugin(obj); + } + return 1; + + case NSRightArrowFunctionKey: + if (obj->selectedRange.location < [obj->textStorage length]) { + obj->selectedRange.location++; + invalidatePlugin(obj); + } + + return 1; + + default: + // Return 0 and let the text input system handle it. + return 0; + } +} + + +static int16_t handleTextInput(NPCocoaEvent* event, PluginObject* obj) +{ + NSString *string = (NSString *)event->data.text.text; + NSRange range = obj->selectedRange; + + [obj->textStorage replaceCharactersInRange:range withString:string]; + + obj->selectedRange.location = range.location + [string length]; + obj->selectedRange.length = 0; + + invalidatePlugin(obj); + + return 1; +} + +int16 NPP_HandleEvent(NPP instance, void* event) +{ + PluginObject* obj = instance->pdata; + + NPCocoaEvent* cocoaEvent = event; + + switch (cocoaEvent->type) { + case NPCocoaEventDrawRect: + handleDraw(obj, cocoaEvent); + return 1; + case NPCocoaEventFocusChanged: + handleFocusChanged(cocoaEvent, obj); + return 1; + case NPCocoaEventMouseMoved: + handleMouseMoved(cocoaEvent, obj); + return 1; + case NPCocoaEventMouseDown: + handleMouseDown(cocoaEvent, obj); + return 1; + case NPCocoaEventKeyDown: + // If the text field has focus we ignore the event, causing it + // to be sent to the input manager. + if (obj->textFieldHasFocus) + return handleTextFieldKeyDown(cocoaEvent, obj); + else + return 1; + case NPCocoaEventTextInput: + return handleTextInput(cocoaEvent, obj); + return 1; + + } + + return 0; +} + +void NPP_URLNotify(NPP instance, const char* url, NPReason reason, void* notifyData) +{ +} + +NPError NPP_GetValue(NPP instance, NPPVariable variable, void* value) +{ + return NPERR_GENERIC_ERROR; +} + +NPError NPP_SetValue(NPP instance, NPNVariable variable, void* value) +{ + return NPERR_GENERIC_ERROR; +} diff --git a/Examples/NetscapeInputMethodPlugin/test.html b/Examples/NetscapeInputMethodPlugin/test.html new file mode 100644 index 0000000..d41a4c0 --- /dev/null +++ b/Examples/NetscapeInputMethodPlugin/test.html @@ -0,0 +1,11 @@ + + + +Netscape Input Method Plug-In + + +
+ +
+ + -- cgit v1.1