summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--embeddedobj/test/Container1/EmbedContApp.java126
-rw-r--r--embeddedobj/test/Container1/makefile.mk6
-rw-r--r--embeddedobj/test/MainThreadExecutor/xexecutor.cxx13
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();
}