diff options
-rw-r--r-- | embeddedobj/test/Container1/EmbedContApp.java | 126 | ||||
-rw-r--r-- | embeddedobj/test/Container1/makefile.mk | 6 | ||||
-rw-r--r-- | embeddedobj/test/MainThreadExecutor/xexecutor.cxx | 13 |
3 files changed, 118 insertions, 27 deletions
diff --git a/embeddedobj/test/Container1/EmbedContApp.java b/embeddedobj/test/Container1/EmbedContApp.java index 8712fc9b3f3e..a9f1e7f785f0 100644 --- a/embeddedobj/test/Container1/EmbedContApp.java +++ b/embeddedobj/test/Container1/EmbedContApp.java @@ -14,10 +14,14 @@ import com.sun.star.uno.UnoRuntime; import com.sun.star.uno.XInterface; import com.sun.star.uno.AnyConverter; import com.sun.star.uno.Type; +import com.sun.star.uno.Any; import com.sun.star.lang.XComponent; +import com.sun.star.util.XCloseable; + import com.sun.star.beans.PropertyValue; +import com.sun.star.beans.NamedValue; import com.sun.star.datatransfer.DataFlavor; import com.sun.star.datatransfer.XTransferable; @@ -29,12 +33,17 @@ import com.sun.star.io.XInputStream; import com.sun.star.io.XOutputStream; import com.sun.star.io.XTruncate; +import com.sun.star.task.XJob; + import com.sun.star.embed.*; -public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClient, ActionListener +public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClient, ActionListener, XJob { private XMultiServiceFactory m_xServiceFactory; + private XJob m_xMainThreadExecutor; + private NamedValue[] m_pValuesForExecutor; + private XEmbeddedObject m_xEmbedObj; private XStorage m_xStorage; @@ -42,18 +51,25 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie private Menu m_aFileMenu; private Menu m_aObjectMenu; private Toolkit m_aToolkit; + private Image m_aImage; + private Object m_oImageLock; private boolean m_bOwnFile = false; private boolean m_bLinkObj = false; private String m_aLinkURI; - private byte[] m_pActionsList; + private Object m_oActionsNumberLock; private int m_nActionsNumber; + private byte[] m_pActionsList; + private Timer m_aTimer; private boolean m_bDestroyed = false; + private Object m_oInHandlerLock; + private boolean m_bInHandler = false; + // Constants private final byte DESTROY = 1; private final byte MOUSE_CLICKED = 2; @@ -82,6 +98,24 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie m_pActionsList = new byte[200]; m_nActionsNumber = 0; + m_oActionsNumberLock = new Object(); + + m_oInHandlerLock = new Object(); + m_oImageLock = new Object(); + + try { + Object oJob = m_xServiceFactory.createInstance( "com.sun.star.comp.thread.MainThreadExecutor" ); + m_xMainThreadExecutor = (XJob)UnoRuntime.queryInterface( XJob.class, oJob ); + } catch( Exception e ) {} + + if ( m_xMainThreadExecutor == null ) + { + System.out.println( "Can't create MainThreadExecutor! The application is unusable!" ); + System.exit( 0 ); + } + + m_pValuesForExecutor = new NamedValue[1]; + m_pValuesForExecutor[0] = new NamedValue( "JobToExecute", (Object)this ); m_aTimer = new Timer( 100, this ); m_aTimer.start(); @@ -135,7 +169,37 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie public void actionPerformed( ActionEvent evt ) { - synchronized( this ) + synchronized( m_oInHandlerLock ) + { + if ( m_bInHandler ) + return; + m_bInHandler = true; + } + + synchronized( m_oActionsNumberLock ) + { + if ( m_nActionsNumber > 0 ) + { + try { + m_xMainThreadExecutor.execute( m_pValuesForExecutor ); + } + catch( Exception e ) + { + System.out.println( "Exception in actionPerformed() : " + e ); + } + } + else + { + synchronized( m_oInHandlerLock ) + { + m_bInHandler = false; + } + } + } + } + + public Object execute( NamedValue[] pValues ) + { { for( int nInd = 0; nInd < m_nActionsNumber; nInd++ ) { @@ -227,7 +291,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( m_xEmbedObj != null ) { try { - m_xEmbedObj.setClientSite( EmbedContApp.this ); + m_xEmbedObj.setClientSite( this ); } catch( Exception ex ) { @@ -257,7 +321,13 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie "No storage for oned file!", "Error:", JOptionPane.ERROR_MESSAGE ); - return; + + synchronized( m_oInHandlerLock ) + { + m_bInHandler = false; + } + + return Any.VOID; } try { @@ -347,7 +417,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( m_xEmbedObj != null ) { try { - m_xEmbedObj.setClientSite( EmbedContApp.this ); + m_xEmbedObj.setClientSite( this ); } catch( Exception ex ) { @@ -386,7 +456,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( m_xEmbedObj != null ) { try { - m_xEmbedObj.setClientSite( EmbedContApp.this ); + m_xEmbedObj.setClientSite( this ); } catch( Exception ex ) { @@ -429,7 +499,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie m_bLinkObj = true; try { - m_xEmbedObj.setClientSite( EmbedContApp.this ); + m_xEmbedObj.setClientSite( this ); } catch( Exception ex ) { @@ -450,7 +520,12 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( !m_bLinkObj ) { JOptionPane.showMessageDialog( m_aFrame, "The object is not a link!", "Error:", JOptionPane.ERROR_MESSAGE ); - return; + synchronized( m_oInHandlerLock ) + { + m_bInHandler = false; + } + + return Any.VOID; } if ( m_xEmbedObj != null ) @@ -495,15 +570,24 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie m_nActionsNumber = 0; } + + synchronized( m_oInHandlerLock ) + { + m_bInHandler = false; + } + + return Any.VOID; } public void actionRegister( byte nActionID ) { - synchronized( this ) + synchronized( m_oActionsNumberLock ) { if ( m_nActionsNumber < 199 && ( m_nActionsNumber == 0 || m_pActionsList[ m_nActionsNumber - 1 ] != DESTROY ) ) + { m_pActionsList[ m_nActionsNumber++ ] = nActionID; + } } } @@ -539,10 +623,10 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( m_xEmbedObj != null ) { - synchronized( this ) + synchronized( m_oImageLock ) { if ( m_aImage != null ) - g.drawImage( m_aImage, 0, 0, EmbedContApp.this ); + g.drawImage( m_aImage, 0, 0, this ); } } } @@ -567,10 +651,10 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie m_xEmbedObj ); if ( xCompProv != null ) { - XComponent xComp = xCompProv.getComponent(); + XCloseable xCloseable = xCompProv.getComponent(); XTransferable xTransfer = (XTransferable)UnoRuntime.queryInterface( XTransferable.class, - xComp ); + xCloseable ); if ( xTransfer != null ) { DataFlavor aFlavor = new DataFlavor(); @@ -578,12 +662,16 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie aFlavor.HumanPresentableName = "Portable Network Graphics"; aFlavor.DataType = new Type( byte[].class ); - byte[] aPNGData = (byte[])AnyConverter.toArray( xTransfer.getTransferData( aFlavor ) ); - if ( aPNGData != null && aPNGData.length != 0 ) + Object aAny = xTransfer.getTransferData( aFlavor ); + if ( aAny != null && AnyConverter.isArray( aAny ) ) { - synchronized( this ) + byte[] aPNGData = (byte[])AnyConverter.toArray( aAny ); + if ( aPNGData != null && aPNGData.length != 0 ) { - m_aImage = m_aToolkit.createImage( aPNGData ); + synchronized( m_oImageLock ) + { + m_aImage = m_aToolkit.createImage( aPNGData ); + } } } } @@ -921,7 +1009,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie public void clearObjectAndStorage() { - synchronized( this ) + synchronized( m_oImageLock ) { m_aImage = null; } diff --git a/embeddedobj/test/Container1/makefile.mk b/embeddedobj/test/Container1/makefile.mk index eaab01939d8a..f6f64fa21d26 100644 --- a/embeddedobj/test/Container1/makefile.mk +++ b/embeddedobj/test/Container1/makefile.mk @@ -3,9 +3,9 @@ # # $RCSfile: makefile.mk,v $ # -# $Revision: 1.1 $ +# $Revision: 1.2 $ # -# last change: $Date: 2003-10-29 13:05:55 $ +# last change: $Date: 2003-11-20 15:55:19 $ # # The Contents of this file are made available subject to the terms of # either of the following licenses @@ -95,7 +95,7 @@ JavaStorageTestExample : $(CLASSFILES) @echo -------------------------------------------------------------------------------- run: $(CLASSFILES) - java -classpath "$(CLASSPATH)" EmbedContFrame + jdb -classpath "$(CLASSPATH)" EmbedContFrame clean : -$(DELRECURSIVE) $(subst /,$(PS),$(OUT_COMP_CLASS)) diff --git a/embeddedobj/test/MainThreadExecutor/xexecutor.cxx b/embeddedobj/test/MainThreadExecutor/xexecutor.cxx index 2bf2de5cca54..2dd14333b7f8 100644 --- a/embeddedobj/test/MainThreadExecutor/xexecutor.cxx +++ b/embeddedobj/test/MainThreadExecutor/xexecutor.cxx @@ -2,9 +2,9 @@ * * $RCSfile: xexecutor.cxx,v $ * - * $Revision: 1.1 $ + * $Revision: 1.2 $ * - * last change: $Author: mav $ $Date: 2003-11-20 09:16:28 $ + * last change: $Author: mav $ $Date: 2003-11-20 15:55:19 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -61,6 +61,7 @@ #include "xexecutor.hxx" #include <vcl/svapp.hxx> +#include <osl/thread.hxx> using namespace ::com::sun::star; @@ -79,6 +80,8 @@ IMPL_LINK( MainThreadExecutor_Impl, executor, void*, pDummyParam ) } m_bExecuted = sal_True; + delete this; + return 0; } @@ -111,11 +114,11 @@ uno::Any SAL_CALL UNOMainThreadExecutor::execute( const uno::Sequence< beans::Na MainThreadExecutor_Impl* pExecutor = new MainThreadExecutor_Impl( xJob, aArgsForJob ); pExecutor->execute(); - while( !pExecutor->isExecuted() ) - Application::Yield(); + // it is not a main thread, so it can be blocked + // while( !pExecutor->isExecuted() ) + // ::osl::Thread::yield(); // TODO: implement transfering of the return values and exceptions - delete pExecutor; return uno::Any(); } |