diff options
Diffstat (limited to 'embeddedobj/test/Container1/EmbedContApp.java')
-rw-r--r-- | embeddedobj/test/Container1/EmbedContApp.java | 147 |
1 files changed, 116 insertions, 31 deletions
diff --git a/embeddedobj/test/Container1/EmbedContApp.java b/embeddedobj/test/Container1/EmbedContApp.java index a9f1e7f785f0..1f5aa0fc58bd 100644 --- a/embeddedobj/test/Container1/EmbedContApp.java +++ b/embeddedobj/test/Container1/EmbedContApp.java @@ -19,6 +19,8 @@ import com.sun.star.uno.Any; import com.sun.star.lang.XComponent; import com.sun.star.util.XCloseable; +import com.sun.star.util.XURLTransformer; +import com.sun.star.util.URL; import com.sun.star.beans.PropertyValue; import com.sun.star.beans.NamedValue; @@ -70,6 +72,8 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie private Object m_oInHandlerLock; private boolean m_bInHandler = false; + private XURLTransformer m_xTransformer; + // Constants private final byte DESTROY = 1; private final byte MOUSE_CLICKED = 2; @@ -96,6 +100,11 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie m_aToolkit = Toolkit.getDefaultToolkit(); + try { + Object oTransformer = m_xServiceFactory.createInstance( "com.sun.star.util.URLTransformer" ); + m_xTransformer = (XURLTransformer)UnoRuntime.queryInterface( XURLTransformer.class, oTransformer ); + } catch( Exception e ) { System.exit( 0 ); } + m_pActionsList = new byte[200]; m_nActionsNumber = 0; m_oActionsNumberLock = new Object(); @@ -246,14 +255,14 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( aFile != null ) { // create object from specified file - String aFileURI = aFile.toURI().toASCIIString(); + String aFileURI = getValidURL( aFile.toURI().toASCIIString() ); try { - saveObject(); - + /* if ( m_bLinkObj ) - storeLinkToStorage(); - - saveStorageAsFileURI( aFileURI ); + storeLinkAsFileURI( aFileURI ); + else + */ + saveObjectAsFileURI( aFileURI ); } catch( Exception ex ) { @@ -283,7 +292,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( aFile != null ) { // create object from specified file - String aFileURI = aFile.toURI().toASCIIString(); + String aFileURI = getValidURL( aFile.toURI().toASCIIString() ); // load from specified file loadFileURI( aFileURI ); @@ -360,14 +369,14 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( aFile != null ) { // create object from specified file - String aFileURI = aFile.toURI().toASCIIString(); + String aFileURI = getValidURL( aFile.toURI().toASCIIString() ); try { - saveObject(); - + /* if ( m_bLinkObj ) - storeLinkToStorage(); - - saveStorageAsFileURI( aFileURI ); + storeLinkAsFileURI( aFileURI ); + else + */ + saveObjectAsFileURI( aFileURI ); } catch( Exception ex ) { @@ -447,7 +456,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( aFile != null ) { // create object from specified file - String aFileURI = aFile.toURI().toASCIIString(); + String aFileURI = getValidURL( aFile.toURI().toASCIIString() ); m_xStorage = createTempStorage(); if ( m_xStorage != null ) @@ -489,7 +498,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( aFile != null ) { // create object from specified file - String aFileURI = aFile.toURI().toASCIIString(); + String aFileURI = getValidURL( aFile.toURI().toASCIIString() ); m_xEmbedObj = createLinkObject( aFileURI ); @@ -954,7 +963,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie oEmbedFactory ); if ( xEmbedFactory != null ) { - Object oEmbObj = xEmbedFactory.createInstanceLink( aLinkURL ); + Object oEmbObj = xEmbedFactory.createInstanceLink( m_xStorage, "EmbedSub", aLinkURL, true ); xEmbObj = (XEmbeddedObject)UnoRuntime.queryInterface( XEmbeddedObject.class, oEmbObj ); } else @@ -990,7 +999,8 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie aMedDescr[1].Value = (Object) new Boolean( false ); Object oEmbObj = xEmbedFactory.createInstanceInitFromMediaDescriptor( m_xStorage, "EmbedSub", - aMedDescr ); + aMedDescr, + true ); xEmbObj = (XEmbeddedObject)UnoRuntime.queryInterface( XEmbeddedObject.class, oEmbObj ); } else @@ -1022,9 +1032,9 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie if ( m_xEmbedObj != null ) { try { - XComponent xComponent = (XComponent)UnoRuntime.queryInterface( XComponent.class, m_xEmbedObj ); - if ( xComponent != null ) - xComponent.dispose(); + XCloseable xClose = (XCloseable)UnoRuntime.queryInterface( XCloseable.class, m_xEmbedObj ); + if ( xClose != null ) + xClose.close( true ); } catch ( Exception ex ) {} @@ -1072,7 +1082,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie return xTempStorage; } - public void saveStorageAsFileURI( String aFileURI ) + public void saveObjectAsFileURI( String aFileURI ) { try { Object oStorageFactory = m_xServiceFactory.createInstance( "com.sun.star.embed.StorageFactory" ); @@ -1081,19 +1091,33 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie oStorageFactory ); if ( xStorageFactory != null ) { - Object aArgs[] = new Object[2]; - aArgs[0] = aFileURI; - aArgs[1] = new Integer( ElementModes.ELEMENT_READWRITE ); + XEmbedPersist xPersist = (XEmbedPersist)UnoRuntime.queryInterface( XEmbedPersist.class, m_xEmbedObj ); + if ( xPersist != null ) + { + Object aArgs[] = new Object[2]; + aArgs[0] = aFileURI; + aArgs[1] = new Integer( ElementModes.ELEMENT_READWRITE ); - Object oStorage = xStorageFactory.createInstanceWithArguments( aArgs ); - XStorage xTargetStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oStorage ); - m_xStorage.copyToStorage( xTargetStorage ); + Object oStorage = xStorageFactory.createInstanceWithArguments( aArgs ); + XStorage xTargetStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oStorage ); - XComponent xComponent = (XComponent)UnoRuntime.queryInterface( XComponent.class, m_xStorage ); - xComponent.dispose(); + xPersist.storeAsEntry( xTargetStorage, "EmbedSub", new PropertyValue[0] ); + xPersist.saveCompleted( true ); - m_xStorage = xTargetStorage; - m_bOwnFile = true; + // the object must be already based on new storage + XComponent xComponent = (XComponent)UnoRuntime.queryInterface( XComponent.class, m_xStorage ); + xComponent.dispose(); + + m_xStorage = xTargetStorage; + m_bOwnFile = true; + + XTransactedObject xTransact = (XTransactedObject)UnoRuntime.queryInterface( XTransactedObject.class, + m_xStorage ); + if ( xTransact != null ) + xTransact.commit(); + } + else + JOptionPane.showMessageDialog( m_aFrame, "No XEmbedPersist!", "Error:", JOptionPane.ERROR_MESSAGE ); } else JOptionPane.showMessageDialog( m_aFrame, @@ -1139,6 +1163,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie Object oEmbObj = null; if ( xNameAccess.hasByName( "LinkName" ) && xTargetStorage.isStreamElement( "LinkName" ) ) { + /* XStream xLinkStream = xTargetStorage.openStreamElement( "LinkName", ElementModes.ELEMENT_READ ); if ( xLinkStream != null ) { @@ -1153,6 +1178,7 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie m_bLinkObj = true; } } + */ } else oEmbObj = xEmbedFactory.createInstanceInitFromEntry( xTargetStorage, @@ -1230,5 +1256,64 @@ public class EmbedContApp extends Applet implements MouseListener, XEmbeddedClie } } } + + public void storeLinkAsFileURI( String aFileURI ) + { + try { + Object oStorageFactory = m_xServiceFactory.createInstance( "com.sun.star.embed.StorageFactory" ); + XSingleServiceFactory xStorageFactory = (XSingleServiceFactory)UnoRuntime.queryInterface( + XSingleServiceFactory.class, + oStorageFactory ); + if ( xStorageFactory != null ) + { + Object aArgs[] = new Object[2]; + aArgs[0] = aFileURI; + aArgs[1] = new Integer( ElementModes.ELEMENT_READWRITE ); + + Object oStorage = xStorageFactory.createInstanceWithArguments( aArgs ); + XStorage xTargetStorage = (XStorage)UnoRuntime.queryInterface( XStorage.class, oStorage ); + + XComponent xComponent = (XComponent)UnoRuntime.queryInterface( XComponent.class, m_xStorage ); + xComponent.dispose(); + + m_xStorage = xTargetStorage; + m_bOwnFile = true; + + storeLinkToStorage(); + + XTransactedObject xTransact = (XTransactedObject)UnoRuntime.queryInterface( XTransactedObject.class, + m_xStorage ); + if ( xTransact != null ) + xTransact.commit(); + } + else + JOptionPane.showMessageDialog( m_aFrame, + "Can't create StorageFactory!", + "Error:", + JOptionPane.ERROR_MESSAGE ); + } + catch( Exception e ) + { + JOptionPane.showMessageDialog( m_aFrame, e, "Exception in saveStorageToFileURI():", JOptionPane.ERROR_MESSAGE ); + } + } + + public String getValidURL( String sFileURL ) + { + // m_xTransformer must be set! + URL[] aURLs = { new URL() }; + aURLs[0].Complete = sFileURL; + + try { + if ( !m_xTransformer.parseSmart( aURLs, "" ) ) + throw new Exception(); + } + catch( Exception e ) + { + JOptionPane.showMessageDialog( m_aFrame, e, "Exception in getValidURL():", JOptionPane.ERROR_MESSAGE ); + } + + return aURLs[0].Complete; + } } |