Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'bundles/org.eclipse.swt/Eclipse SWT OLE Win32/win32/org/eclipse/swt/ole/win32/OleEventSink.java')
-rwxr-xr-xbundles/org.eclipse.swt/Eclipse SWT OLE Win32/win32/org/eclipse/swt/ole/win32/OleEventSink.java348
1 files changed, 174 insertions, 174 deletions
diff --git a/bundles/org.eclipse.swt/Eclipse SWT OLE Win32/win32/org/eclipse/swt/ole/win32/OleEventSink.java b/bundles/org.eclipse.swt/Eclipse SWT OLE Win32/win32/org/eclipse/swt/ole/win32/OleEventSink.java
index 4405b58521..2481b06144 100755
--- a/bundles/org.eclipse.swt/Eclipse SWT OLE Win32/win32/org/eclipse/swt/ole/win32/OleEventSink.java
+++ b/bundles/org.eclipse.swt/Eclipse SWT OLE Win32/win32/org/eclipse/swt/ole/win32/OleEventSink.java
@@ -1,177 +1,177 @@
-package org.eclipse.swt.ole.win32;
-
-/*
+package org.eclipse.swt.ole.win32;
+
+/*
* Copyright (c) 2000, 2002 IBM Corp. All rights reserved.
* This file is made available under the terms of the Common Public License v1.0
* which accompanies this distribution, and is available at
- * http://www.eclipse.org/legal/cpl-v10.html
- */
-import org.eclipse.swt.*;
-import org.eclipse.swt.internal.ole.win32.*;
-
-final class OleEventSink
-{
- private OleControlSite widget;
-
- private COMObject iDispatch;
- private int refCount;
-
- private IUnknown objIUnknown;
- private int eventCookie;
- private GUID eventGuid;
-
- private OleEventTable eventTable;
-
-OleEventSink(OleControlSite widget, int iUnknown, GUID riid) {
-
- this.widget = widget;
- this.eventGuid = riid;
- this.objIUnknown = new IUnknown(iUnknown);
-
- createCOMInterfaces();
-}
-
-void connect () {
- int[] ppvObject = new int[1];
- if (objIUnknown.QueryInterface(COM.IIDIConnectionPointContainer, ppvObject) == COM.S_OK) {
- IConnectionPointContainer cpc = new IConnectionPointContainer(ppvObject[0]);
- int[] ppCP = new int[1];
- if (cpc.FindConnectionPoint(eventGuid, ppCP) == COM.S_OK) {
- IConnectionPoint cp = new IConnectionPoint(ppCP[0]);
- int[] pCookie = new int[1];
- if (cp.Advise(iDispatch.getAddress(), pCookie) == COM.S_OK)
- eventCookie = pCookie[0];
- cp.Release();
- }
- cpc.Release();
- }
-}
-void addListener(int eventID, OleListener listener) {
- if (listener == null) OLE.error (SWT.ERROR_NULL_ARGUMENT);
- if (eventTable == null) eventTable = new OleEventTable ();
- eventTable.hook(eventID, listener);
-}
-int AddRef() {
- refCount++;
- return refCount;
-}
-private void createCOMInterfaces() {
- iDispatch = new COMObject(new int[]{2, 0, 0, 1, 3, 4, 8}){
- public int method0(int[] args) {return QueryInterface(args[0], args[1]);}
- public int method1(int[] args) {return AddRef();}
- public int method2(int[] args) {return Release();}
- // method3 GetTypeInfoCount - not implemented
- // method4 GetTypeInfo - not implemented
- // method5 GetIDsOfNames - not implemented
- public int method6(int[] args) {return Invoke(args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7]);}
- };
-}
-void disconnect() {
- // disconnect event sink
- if (eventCookie != 0 && objIUnknown != null) {
- int[] ppvObject = new int[1];
- if (objIUnknown.QueryInterface(COM.IIDIConnectionPointContainer, ppvObject) == COM.S_OK) {
- IConnectionPointContainer cpc = new IConnectionPointContainer(ppvObject[0]);
- if (cpc.FindConnectionPoint(eventGuid, ppvObject) == COM.S_OK) {
- IConnectionPoint cp = new IConnectionPoint(ppvObject[0]);
- if (cp.Unadvise(eventCookie) == COM.S_OK) {
- eventCookie = 0;
- }
- cp.Release();
- }
- cpc.Release();
- }
- }
-}
-private void disposeCOMInterfaces() {
- if (iDispatch != null)
- iDispatch.dispose();
- iDispatch = null;
-
-}
-private int Invoke(int dispIdMember, int riid, int lcid, int dwFlags, int pDispParams, int pVarResult, int pExcepInfo, int pArgErr)
-{
- if (eventTable == null || !eventTable.hooks(dispIdMember)) return COM.S_OK;
-
- // Construct an array of the parameters that are passed in
- // Note: parameters are passed in reverse order - here we will correct the order
- Variant[] eventInfo = null;
- if (pDispParams != 0) {
- DISPPARAMS dispParams = new DISPPARAMS();
- COM.MoveMemory(dispParams, pDispParams, DISPPARAMS.sizeof);
- eventInfo = new Variant[dispParams.cArgs];
- int size = Variant.sizeof;
- int offset = (dispParams.cArgs - 1) * size;
-
- for (int j = 0; j < dispParams.cArgs; j++){
- eventInfo[j] = new Variant();
- eventInfo[j].setData(dispParams.rgvarg + offset);
- offset = offset - size;
- }
- }
-
- OleEvent event = new OleEvent();
- event.arguments = eventInfo;
- try {
- notifyListener(dispIdMember,event);
- } catch (Throwable t) {
- }
-
- return COM.S_OK;
-}
-/**
-* Notify listeners of an event.
-* <p>
-* This method notifies all listeners that an event
-* has occurred.
-*
-* @param eventType the desired SWT event
-* @param event the event data
-*
-* @exception SWTError <ul>
-* <li>ERROR_THREAD_INVALID_ACCESS when called from the wrong thread</li>
-* <li>ERROR_WIDGET_DISPOSED when the widget has been disposed</li>
-* <li>ERROR_NULL_ARGUMENT when handler is null</li>
-* </ul>
-*/
-private void notifyListener (int eventType, OleEvent event) {
- if (event == null) OLE.error (SWT.ERROR_NULL_ARGUMENT);
- if (eventTable == null) return;
- event.type = eventType;
- event.widget = widget;
- eventTable.sendEvent (event);
-}
-private int QueryInterface(int riid, int ppvObject) {
-
- if (riid == 0 || ppvObject == 0)
- return COM.E_INVALIDARG;
- GUID guid = new GUID();
- COM.MoveMemory(guid, riid, GUID.sizeof);
-
- if ( COM.IsEqualGUID(guid, COM.IIDIUnknown) || COM.IsEqualGUID(guid, COM.IIDIDispatch) ||
- COM.IsEqualGUID(guid, eventGuid)) {
- COM.MoveMemory(ppvObject, new int[] {iDispatch.getAddress()}, 4);
- AddRef();
- return OLE.S_OK;
- }
-
- COM.MoveMemory(ppvObject, new int[] {0}, 4);
- return COM.E_NOINTERFACE;
-}
-int Release() {
- refCount--;
- if (refCount == 0) {
- disposeCOMInterfaces();
- }
-
- return refCount;
-}
-void removeListener(int eventID, OleListener listener) {
- if (listener == null) OLE.error (SWT.ERROR_NULL_ARGUMENT);
- if (eventTable == null) return;
- eventTable.unhook (eventID, listener);
-}
-boolean hasListeners() {
- return eventTable.hasEntries();
-}
-}
+ * http://www.eclipse.org/legal/cpl-v10.html
+ */
+import org.eclipse.swt.*;
+import org.eclipse.swt.internal.ole.win32.*;
+
+final class OleEventSink
+{
+ private OleControlSite widget;
+
+ private COMObject iDispatch;
+ private int refCount;
+
+ private IUnknown objIUnknown;
+ private int eventCookie;
+ private GUID eventGuid;
+
+ private OleEventTable eventTable;
+
+OleEventSink(OleControlSite widget, int iUnknown, GUID riid) {
+
+ this.widget = widget;
+ this.eventGuid = riid;
+ this.objIUnknown = new IUnknown(iUnknown);
+
+ createCOMInterfaces();
+}
+
+void connect () {
+ int[] ppvObject = new int[1];
+ if (objIUnknown.QueryInterface(COM.IIDIConnectionPointContainer, ppvObject) == COM.S_OK) {
+ IConnectionPointContainer cpc = new IConnectionPointContainer(ppvObject[0]);
+ int[] ppCP = new int[1];
+ if (cpc.FindConnectionPoint(eventGuid, ppCP) == COM.S_OK) {
+ IConnectionPoint cp = new IConnectionPoint(ppCP[0]);
+ int[] pCookie = new int[1];
+ if (cp.Advise(iDispatch.getAddress(), pCookie) == COM.S_OK)
+ eventCookie = pCookie[0];
+ cp.Release();
+ }
+ cpc.Release();
+ }
+}
+void addListener(int eventID, OleListener listener) {
+ if (listener == null) OLE.error (SWT.ERROR_NULL_ARGUMENT);
+ if (eventTable == null) eventTable = new OleEventTable ();
+ eventTable.hook(eventID, listener);
+}
+int AddRef() {
+ refCount++;
+ return refCount;
+}
+private void createCOMInterfaces() {
+ iDispatch = new COMObject(new int[]{2, 0, 0, 1, 3, 4, 8}){
+ public int method0(int[] args) {return QueryInterface(args[0], args[1]);}
+ public int method1(int[] args) {return AddRef();}
+ public int method2(int[] args) {return Release();}
+ // method3 GetTypeInfoCount - not implemented
+ // method4 GetTypeInfo - not implemented
+ // method5 GetIDsOfNames - not implemented
+ public int method6(int[] args) {return Invoke(args[0], args[1], args[2], args[3], args[4], args[5], args[6], args[7]);}
+ };
+}
+void disconnect() {
+ // disconnect event sink
+ if (eventCookie != 0 && objIUnknown != null) {
+ int[] ppvObject = new int[1];
+ if (objIUnknown.QueryInterface(COM.IIDIConnectionPointContainer, ppvObject) == COM.S_OK) {
+ IConnectionPointContainer cpc = new IConnectionPointContainer(ppvObject[0]);
+ if (cpc.FindConnectionPoint(eventGuid, ppvObject) == COM.S_OK) {
+ IConnectionPoint cp = new IConnectionPoint(ppvObject[0]);
+ if (cp.Unadvise(eventCookie) == COM.S_OK) {
+ eventCookie = 0;
+ }
+ cp.Release();
+ }
+ cpc.Release();
+ }
+ }
+}
+private void disposeCOMInterfaces() {
+ if (iDispatch != null)
+ iDispatch.dispose();
+ iDispatch = null;
+
+}
+private int Invoke(int dispIdMember, int riid, int lcid, int dwFlags, int pDispParams, int pVarResult, int pExcepInfo, int pArgErr)
+{
+ if (eventTable == null || !eventTable.hooks(dispIdMember)) return COM.S_OK;
+
+ // Construct an array of the parameters that are passed in
+ // Note: parameters are passed in reverse order - here we will correct the order
+ Variant[] eventInfo = null;
+ if (pDispParams != 0) {
+ DISPPARAMS dispParams = new DISPPARAMS();
+ COM.MoveMemory(dispParams, pDispParams, DISPPARAMS.sizeof);
+ eventInfo = new Variant[dispParams.cArgs];
+ int size = Variant.sizeof;
+ int offset = (dispParams.cArgs - 1) * size;
+
+ for (int j = 0; j < dispParams.cArgs; j++){
+ eventInfo[j] = new Variant();
+ eventInfo[j].setData(dispParams.rgvarg + offset);
+ offset = offset - size;
+ }
+ }
+
+ OleEvent event = new OleEvent();
+ event.arguments = eventInfo;
+ try {
+ notifyListener(dispIdMember,event);
+ } catch (Throwable t) {
+ }
+
+ return COM.S_OK;
+}
+/**
+* Notify listeners of an event.
+* <p>
+* This method notifies all listeners that an event
+* has occurred.
+*
+* @param eventType the desired SWT event
+* @param event the event data
+*
+* @exception SWTError <ul>
+* <li>ERROR_THREAD_INVALID_ACCESS when called from the wrong thread</li>
+* <li>ERROR_WIDGET_DISPOSED when the widget has been disposed</li>
+* <li>ERROR_NULL_ARGUMENT when handler is null</li>
+* </ul>
+*/
+private void notifyListener (int eventType, OleEvent event) {
+ if (event == null) OLE.error (SWT.ERROR_NULL_ARGUMENT);
+ if (eventTable == null) return;
+ event.type = eventType;
+ event.widget = widget;
+ eventTable.sendEvent (event);
+}
+private int QueryInterface(int riid, int ppvObject) {
+
+ if (riid == 0 || ppvObject == 0)
+ return COM.E_INVALIDARG;
+ GUID guid = new GUID();
+ COM.MoveMemory(guid, riid, GUID.sizeof);
+
+ if ( COM.IsEqualGUID(guid, COM.IIDIUnknown) || COM.IsEqualGUID(guid, COM.IIDIDispatch) ||
+ COM.IsEqualGUID(guid, eventGuid)) {
+ COM.MoveMemory(ppvObject, new int[] {iDispatch.getAddress()}, 4);
+ AddRef();
+ return OLE.S_OK;
+ }
+
+ COM.MoveMemory(ppvObject, new int[] {0}, 4);
+ return COM.E_NOINTERFACE;
+}
+int Release() {
+ refCount--;
+ if (refCount == 0) {
+ disposeCOMInterfaces();
+ }
+
+ return refCount;
+}
+void removeListener(int eventID, OleListener listener) {
+ if (listener == null) OLE.error (SWT.ERROR_NULL_ARGUMENT);
+ if (eventTable == null) return;
+ eventTable.unhook (eventID, listener);
+}
+boolean hasListeners() {
+ return eventTable.hasEntries();
+}
+}

Back to the top