diff options
Diffstat (limited to 'jurt/demo/com/sun')
-rw-r--r-- | jurt/demo/com/sun/star/demo/DemoServer.java | 101 | ||||
-rw-r--r-- | jurt/demo/com/sun/star/demo/TestOffice.java | 193 | ||||
-rw-r--r-- | jurt/demo/com/sun/star/demo/makefile.mk | 57 |
3 files changed, 351 insertions, 0 deletions
diff --git a/jurt/demo/com/sun/star/demo/DemoServer.java b/jurt/demo/com/sun/star/demo/DemoServer.java new file mode 100644 index 000000000000..53f258b5bd46 --- /dev/null +++ b/jurt/demo/com/sun/star/demo/DemoServer.java @@ -0,0 +1,101 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ +package com.sun.star.demo; + +import com.sun.star.bridge.XBridge; +import com.sun.star.bridge.XBridgeFactory; +import com.sun.star.bridge.XInstanceProvider; + +import com.sun.star.comp.servicemanager.ServiceManager; + +import com.sun.star.connection.XAcceptor; +import com.sun.star.connection.XConnection; + +import com.sun.star.uno.UnoRuntime; + +public class DemoServer { + static String neededServices[] = new String[] { + "com.sun.star.comp.servicemanager.ServiceManager", + "com.sun.star.comp.loader.JavaLoader", + "com.sun.star.comp.connections.Acceptor", + "com.sun.star.comp.bridgefactory.BridgeFactory" + }; + + static class InstanceProvider implements XInstanceProvider { + public Object getInstance( /*IN*/String sInstanceName ) throws com.sun.star.container.NoSuchElementException, com.sun.star.uno.RuntimeException { + System.err.println("##### " + getClass().getName() + ".getInstance:" + sInstanceName); + + return null; + } + } + + static public void main(String args[]) throws Exception { + if(args.length != 1) { + System.err.println("usage : SCalc uno:connection;protocol;objectName"); + System.exit(-1); + } + + String conDcp = null; + String protDcp = null; + String rootOid = null; + + String dcp = args[0]; + + if(dcp.indexOf(';') == -1) {// use old style + conDcp = dcp; + protDcp = "iiop"; + rootOid = "classic_uno"; + } + else { // new style + int index = dcp.indexOf(':'); + String url = dcp.substring(0, index).trim(); + dcp = dcp.substring(index + 1).trim(); + + index = dcp.indexOf(';'); + conDcp = dcp.substring(0, index).trim(); + dcp = dcp.substring(index + 1).trim(); + + index = dcp.indexOf(';'); + protDcp = dcp.substring(0, index).trim(); + dcp = dcp.substring(index + 1).trim(); + + rootOid = dcp.trim().trim(); + } + + ServiceManager serviceManager = new ServiceManager(); + serviceManager.addFactories(neededServices); + + XAcceptor xAcceptor = UnoRuntime.queryInterface(XAcceptor.class, serviceManager.createInstance("com.sun.star.connection.Acceptor")); + + System.err.println("waiting for connect..."); + XConnection xConnection = xAcceptor.accept(conDcp); + + XBridgeFactory xBridgeFactory = UnoRuntime.queryInterface(XBridgeFactory.class, serviceManager.createInstance("com.sun.star.bridge.BridgeFactory")); + XBridge xBridge = xBridgeFactory.createBridge(conDcp + ";" + protDcp, protDcp, xConnection, new InstanceProvider()); + + } +} diff --git a/jurt/demo/com/sun/star/demo/TestOffice.java b/jurt/demo/com/sun/star/demo/TestOffice.java new file mode 100644 index 000000000000..5ff3fa77d9e8 --- /dev/null +++ b/jurt/demo/com/sun/star/demo/TestOffice.java @@ -0,0 +1,193 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +package com.sun.star.demo; + + +import java.io.IOException; + + +import com.sun.star.beans.PropertyValue; +import com.sun.star.beans.PropertyState; + +import com.sun.star.bridge.XUnoUrlResolver; + +import com.sun.star.io.BufferSizeExceededException; +import com.sun.star.io.NotConnectedException; +import com.sun.star.io.XInputStream; +import com.sun.star.io.XOutputStream; + +import com.sun.star.frame.XComponentLoader; + +import com.sun.star.lang.XComponent; +import com.sun.star.lang.XMultiServiceFactory; +import com.sun.star.lang.XServiceInfo; + +import com.sun.star.text.XSimpleText; +import com.sun.star.text.XText; +import com.sun.star.text.XTextCursor; +import com.sun.star.text.XTextDocument; +import com.sun.star.text.XTextRange; + +import com.sun.star.uno.IBridge; +import com.sun.star.uno.UnoRuntime; +import com.sun.star.uno.XInterface; +import com.sun.star.uno.XNamingService; + + +public class TestOffice { + static void testPipe(XMultiServiceFactory rSmgr) throws com.sun.star.uno.Exception { + XOutputStream rOut = (XOutputStream) rSmgr.createInstance("com.sun.star.io.Pipe"); + + { + byte bytes[] = new byte[10]; + bytes[0] = 42; + rOut.writeBytes(bytes); + } + + + { + byte bytes[][] = new byte[1][]; + + XInputStream rIn = UnoRuntime.queryInterface(XInputStream.class, rOut); + if(rIn.available() != 10) + System.err.println("wrong bytes available\n"); + + if(rIn.readBytes(bytes, 10) != 10) + System.err.println("wrong bytes read\n"); + + if(42 != bytes[0][0]) + System.err.println("wrong element in sequence\n"); + } + } + + + static void testWriter(XComponent rCmp) throws IOException { + XTextDocument rTextDoc = UnoRuntime.queryInterface(XTextDocument.class, rCmp); + + XText rText = UnoRuntime.queryInterface(XText.class, rTextDoc.getText()); + XTextCursor rCursor = UnoRuntime.queryInterface(XTextCursor.class, rText.createTextCursor()); + XTextRange rRange = UnoRuntime.queryInterface(XTextRange.class, rCursor); + + byte pcText[] = new byte[1024]; + pcText[0] = 0; + System.err.println("pleast type any text\n"); + while(true) { + System.in.read(pcText); + + String string = new String(pcText); + if(string.equals("end")) break; + + string += " "; + + rText.insertString(rRange , string, false); + } + } + + static void testDocument(XMultiServiceFactory rSmgr) throws com.sun.star.uno.Exception, IOException { + XComponentLoader rLoader = UnoRuntime.queryInterface(XComponentLoader.class, rSmgr.createInstance("com.sun.star.frame.Desktop")); + + String urls[] = new String[] { + "private:factory/swriter", + "private:factory/scalc", + "private:factory/sdraw", + "http://www.heise.de", + }; + + String docu[] = new String[] { + "a new writer document ...\n", + "a new calc document ...\n", + "a new draw document ...\n", + "www.heise.de\n", + }; + + for(int i = 0; i < urls.length; ++ i) { + System.err.println("press any key to open " + docu[i]); + + System.in.read(); + while(System.in.available() > 0) + System.in.read(); + + XComponent rComponent = rLoader.loadComponentFromURL(urls[i], "_blank", 0, new PropertyValue[0]); + +// testWriter(rComponent); + System.err.println("press any key to close the document"); + System.in.read(); + while(System.in.available() > 0) + System.in.read(); + + rComponent.dispose(); + } + } + + static void doSomething(Object r) throws com.sun.star.uno.Exception, IOException { + XNamingService rName = UnoRuntime.queryInterface(XNamingService.class, r); + + if(rName != null) { + System.err.println("got the remote naming service !"); + Object rXsmgr = rName.getRegisteredObject("StarOffice.ServiceManager"); + + XMultiServiceFactory rSmgr = UnoRuntime.queryInterface(XMultiServiceFactory.class, rXsmgr); + if(rSmgr != null) { + System.err.println("got the remote service manager !"); +// testPipe(rSmgr); + testDocument(rSmgr); + } + } + } + + + + static String neededServices[] = new String[] { + "com.sun.star.comp.servicemanager.ServiceManager", + "com.sun.star.comp.loader.JavaLoader", + "com.sun.star.comp.connections.Connector", + "com.sun.star.comp.bridgefactory.BridgeFactory", + "com.sun.star.comp.urlresolver.UrlResolver" + }; + + public static void main(String argv[]) throws Exception { + if(argv.length != 1) { + System.err.println("usage : testoffice uno:connection;protocol;objectName"); + System.exit(-1); + } + + com.sun.star.comp.servicemanager.ServiceManager smgr = new com.sun.star.comp.servicemanager.ServiceManager(); + smgr.addFactories(neededServices); + + Object resolver = smgr.createInstance("com.sun.star.bridge.UnoUrlResolver" ); + XUnoUrlResolver resolver_xUnoUrlResolver = UnoRuntime.queryInterface(XUnoUrlResolver.class, resolver); + + Object rInitialObject = resolver_xUnoUrlResolver.resolve(argv[0]); + + if(rInitialObject != null) { + System.err.println("got the remote object"); + doSomething(rInitialObject); + } + } +} + diff --git a/jurt/demo/com/sun/star/demo/makefile.mk b/jurt/demo/com/sun/star/demo/makefile.mk new file mode 100644 index 000000000000..6bc3e1ae9da7 --- /dev/null +++ b/jurt/demo/com/sun/star/demo/makefile.mk @@ -0,0 +1,57 @@ +#************************************************************************* +# +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# Copyright 2000, 2010 Oracle and/or its affiliates. +# +# OpenOffice.org - a multi-platform office productivity suite +# +# This file is part of OpenOffice.org. +# +# OpenOffice.org is free software: you can redistribute it and/or modify +# it under the terms of the GNU Lesser General Public License version 3 +# only, as published by the Free Software Foundation. +# +# OpenOffice.org is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Lesser General Public License version 3 for more details +# (a copy is included in the LICENSE file that accompanied this code). +# +# You should have received a copy of the GNU Lesser General Public License +# version 3 along with OpenOffice.org. If not, see +# <http://www.openoffice.org/license.html> +# for a copy of the LGPLv3 License. +# +#************************************************************************* + +PRJ=..$/..$/..$/..$/.. + +PRJNAME := jurt +PACKAGE := com$/sun$/star$/demo +TARGET := com_sun_star_demo + +RDB=$(SOLARBINDIR)$/applicat.rdb + +# --- Settings ----------------------------------------------------- +.INCLUDE : settings.mk + +#Files -------------------------------------------------------- + +JARFILES = unoil.jar ridl.jar + +GENJAVACLASSFILES = + +JAVACLASSFILES= \ + $(CLASSDIR)$/$(PACKAGE)$/DemoServer.class \ + $(CLASSDIR)$/$(PACKAGE)$/TestOffice.class + +TYPES={$(subst,.class, $(subst,$/,. $(subst,$(CLASSDIR)$/,-T $(GENJAVACLASSFILES))))} +GENJAVAFILES = {$(subst,.class,.java $(subst,$/class, $(GENJAVACLASSFILES)))} + +JAVAFILES= $(subst,$(CLASSDIR)$/$(PACKAGE)$/, $(subst,.class,.java $(JAVACLASSFILES))) $(GENJAVAFILES) + +# --- Targets ------------------------------------------------------ + + +.INCLUDE : target.mk |