Difference between revisions of "Documentation/DevGuide/AdvUNO/Advanced UNO"
OOoWikiBot (talk | contribs) m (Robot: Changing Category:Advanced UNO) |
|||
(11 intermediate revisions by 6 users not shown) | |||
Line 4: | Line 4: | ||
|NextPage=Documentation/DevGuide/AdvUNO/Language Bindings | |NextPage=Documentation/DevGuide/AdvUNO/Language Bindings | ||
}} | }} | ||
+ | {{Documentation/DevGuideLanguages|Documentation/DevGuide/AdvUNO/{{SUBPAGENAME}}}} | ||
{{DISPLAYTITLE:Advanced UNO}} | {{DISPLAYTITLE:Advanced UNO}} | ||
__NOTOC__ | __NOTOC__ | ||
+ | {{Download_Collection|MediaWiki:Collections/Developer's Guide - Advanced UNO}} | ||
=== Choosing an Implementation Language === | === Choosing an Implementation Language === | ||
− | The UNO technology provides a framework for cross-platform and language independent programming. All the {{ | + | The UNO technology provides a framework for cross-platform and language independent programming. All the {{AOo}} components can be implemented in any language supported by UNO, as long as they only communicate with other components through their IDL interfaces. |
− | {{ | + | {{Note|Note: The condition "as long as they only communicate with other components through their IDL interfaces" is to be strictly taken. In fact, a lot of implementations within {{AOo}} export UNO interfaces and still use private C++ interfaces. This is a tribute to older implementations that cannot be rewritten in an acceptable timeframe.}} |
A developer can customize the office to their needs with this flexibility, but they will have to decide which implementation language should be selected for a specific problem. | A developer can customize the office to their needs with this flexibility, but they will have to decide which implementation language should be selected for a specific problem. | ||
Line 15: | Line 17: | ||
==== Supported Programming Environments ==== | ==== Supported Programming Environments ==== | ||
− | The support for programming languages in UNO and {{ | + | The support for programming languages in UNO and {{AOo}} is divided into three different categories. |
# Languages that invoke calls on existing UNO objects are possibly implemented in other programming languages. Additionally, it may be possible to implement certain UNO interfaces, but not UNO components that can be instantiated by the service manager. | # Languages that invoke calls on existing UNO objects are possibly implemented in other programming languages. Additionally, it may be possible to implement certain UNO interfaces, but not UNO components that can be instantiated by the service manager. | ||
− | # Languages that implement UNO components. UNO objects implemented in such a language are accessible from any other language that UNO supports, just by instantiating a service by name at the servicemanager. For instance, the developer can implement a {{ | + | # Languages that implement UNO components. UNO objects implemented in such a language are accessible from any other language that UNO supports, just by instantiating a service by name at the servicemanager. For instance, the developer can implement a {{AOo}} Calc addin (see [[Documentation/DevGuide/Spreadsheets/Spreadsheet Documents|Spreadsheet Documents]]). |
− | # Languages that are used to write code to be delivered within {{ | + | # Languages that are used to write code to be delivered within {{AOo}} documents and utilize dialogs designed with the {{AOo}} dialog editor. |
The following table lists programming languages currently supported by UNO. 'Yes' in the table columns denotes full support, 'no' denotes that there is no support and is not even planned in the future. 'Maybe in future' means there is currently no support, but this may change with future releases. | The following table lists programming languages currently supported by UNO. 'Yes' in the table columns denotes full support, 'no' denotes that there is no support and is not even planned in the future. 'Maybe in future' means there is currently no support, but this may change with future releases. | ||
Line 27: | Line 29: | ||
!UNO scripting | !UNO scripting | ||
!UNO components | !UNO components | ||
− | !Deployment with {{ | + | !Deployment with {{AOo}} documents |
|- | |- | ||
|C++ | |C++ | ||
Line 62: | Line 64: | ||
===== Java ===== | ===== Java ===== | ||
− | Java is a an accepted programming language offering a standard library with a large set of features and available extensions. Additional extensions will be available in the future, such as JAX-RPC for calling webservices. It is a typesafe language with a typesafe UNO binding. Although interfaces have to be queried explicitly, the type safety makes it suitable for larger projects. UNO components can be implemented with Java, that is, the Java VM is started on demand inside the office process when a Java component is instantiated. The OfficeBean allows embedding {{ | + | Java is a an accepted programming language offering a standard library with a large set of features and available extensions. Additional extensions will be available in the future, such as JAX-RPC for calling webservices. It is a typesafe language with a typesafe UNO binding. Although interfaces have to be queried explicitly, the type safety makes it suitable for larger projects. UNO components can be implemented with Java, that is, the Java VM is started on demand inside the office process when a Java component is instantiated. The OfficeBean allows embedding {{AOo}} documents in Java Applets and Applications. |
− | There is a constant runtime overhead of about 1 to 2 ms per call that is caused by the bridge conversion routines when calling UNO objects implemented in other language bindings. Since {{ | + | There is a constant runtime overhead of about 1 to 2 ms per call that is caused by the bridge conversion routines when calling UNO objects implemented in other language bindings. Since {{AOo}} consists of C++ code, every Java call into the office needs to be bridged. This poses no problems if there are a few calls per user interaction. The runtime overhead will hurt the application when routines produce hundreds or thousands of calls. |
===== C++ ===== | ===== C++ ===== | ||
− | C++ is an accepted programming language offering third-party products. In addition to C++ being fast since it is compiled locally, it offers the fastest communication with {{ | + | C++ is an accepted programming language offering third-party products. In addition to C++ being fast since it is compiled locally, it offers the fastest communication with {{AOo}} because most of the essential parts of office have been developed in C++. This advantage becomes less important as you call into the office through the interprocess bridge, because every remote call means a constant loss of 1 to 2 ms. The fastest code to extend the office can be implemented as a C++ UNO component. It is appropriate for larger projects due to its strong type safety at compile time. |
C++ is difficult to learn and coding, in general, takes longer, for example, in Java. The components must be built for every platform, that leads to a higher level of complexity during development and deployment. | C++ is difficult to learn and coding, in general, takes longer, for example, in Java. The components must be built for every platform, that leads to a higher level of complexity during development and deployment. | ||
− | ===== | + | ===== OpenOffice Basic ===== |
− | {{ | + | {{AOo}} Basic is the scripting language developed for and integrated directly into {{AOo}}. It currently offers the best integration with {{AOo}}, because you can insert code into documents, attach arbitrary office events, such as document loading, keyboard shortcuts or menu entries, to Basic code and use dialogs designed within the {{AOo}} IDE. In Basic, calls are invoked on an object rather than on a specific interface. Interfaces, such as <idl>com.sun.star.beans.XPropertySet</idl> are integrated as Basic object properties. Basic always runs in the office process and thus avoids costly interprocess calls. |
− | The language is type unsafe, that is, only a minimal number of errors are found during compilation. Most errors appear at runtime, therefore it is not the best choice for large projects. The language is {{ | + | The language is type unsafe, that is, only a minimal number of errors are found during compilation. Most errors appear at runtime, therefore it is not the best choice for large projects. The language is {{AOo}} specific and only offers a small set of runtime functionality with little third-party support. All office functionality is used through UNO. UNO components cannot be implemented with Basic. The only UNO objects that can be implemented are listeners. Finally, Basic does not offer any thread support. |
===== OLE Automation Bridge ===== | ===== OLE Automation Bridge ===== | ||
− | The OLE Automation bridge opens the UNO world to programming environments that support OLE automation, such as Visual Basic, JScript, Delphi or C++ Builder. Programmers working on the Windows platform can write programs for {{ | + | The OLE Automation bridge opens the UNO world to programming environments that support OLE automation, such as Visual Basic, JScript, Delphi or C++ Builder. Programmers working on the Windows platform can write programs for {{AOo}} without leaving their language by learning a new API. These programmers have access to the libraries provided by their language. It is possible to implement UNO objects, if the programming language supports object implementation. |
− | This bridge is only useful on a Win32 machine, thereby being a disadvantage . Scripts always run in a different process so that every UNO call has at least the usual interprocess overhead of 1 to 2 ms. Currently Automation UNO components cannot be implemented for the service manager, but this may change in the future. | + | This bridge is only useful on a Win32 machine, thereby being a disadvantage. Scripts always run in a different process so that every UNO call has at least the usual interprocess overhead of 1 to 2 ms. Currently Automation UNO components cannot be implemented for the service manager, but this may change in the future. |
===== Python ===== | ===== Python ===== | ||
− | A Python scripting bridge (PyUNO) is currently developed by Ralph Thomas. It is available in an experimental alpha state with known limitations. For details, see PyUNO on [ | + | A Python scripting bridge (PyUNO) is currently developed by Ralph Thomas. It is available in an experimental alpha state with known limitations. For details, see PyUNO on [https://www.openoffice.org/udk/ www.openoffice.org/udk/]. |
==== Use Cases ==== | ==== Use Cases ==== | ||
Line 103: | Line 105: | ||
* Filters reading document data and generating Office Documents through UNO calls | * Filters reading document data and generating Office Documents through UNO calls | ||
− | |||
* Database Drivers | * Database Drivers | ||
* Calc add-ins | * Calc add-ins | ||
* Chart add-ins | * Chart add-ins | ||
− | ===== | + | ===== OpenOffice Basic ===== |
* Office Automation | * Office Automation | ||
Line 123: | Line 124: | ||
==== Recommendation ==== | ==== Recommendation ==== | ||
− | All languages have their advantages and disadvantages as previously discussed , but there is not one language for all purposes, depending on your use. Consider carefully before starting a new project and evaluate the language to use so that it saves you time. | + | All languages have their advantages and disadvantages as previously discussed, but there is not one language for all purposes, depending on your use. Consider carefully before starting a new project and evaluate the language to use so that it saves you time. |
− | Sometimes it may be useful to use multiple languages to gain the advantages of both languages. For instance, currently it is not possible to attach a keyboard event to a | + | Sometimes it may be useful to use multiple languages to gain the advantages of both languages. For instance, currently it is not possible to attach a keyboard event to a Java method, therefore, write a small Basic function, which forwards the event to a Java component. |
− | The number of languages supported by UNO may increase and some | + | The number of languages supported by UNO may increase and some limitations shown in the table above may disappear. |
{{PDL1}} | {{PDL1}} | ||
− | [[Category:Documentation/ | + | [[Category:Documentation/Developer's Guide/Advanced UNO]] |
Latest revision as of 17:09, 2 January 2021
Download as a PDF or ODT
Choosing an Implementation Language
The UNO technology provides a framework for cross-platform and language independent programming. All the Apache OpenOffice components can be implemented in any language supported by UNO, as long as they only communicate with other components through their IDL interfaces.
A developer can customize the office to their needs with this flexibility, but they will have to decide which implementation language should be selected for a specific problem.
Supported Programming Environments
The support for programming languages in UNO and Apache OpenOffice is divided into three different categories.
- Languages that invoke calls on existing UNO objects are possibly implemented in other programming languages. Additionally, it may be possible to implement certain UNO interfaces, but not UNO components that can be instantiated by the service manager.
- Languages that implement UNO components. UNO objects implemented in such a language are accessible from any other language that UNO supports, just by instantiating a service by name at the servicemanager. For instance, the developer can implement a Apache OpenOffice Calc addin (see Spreadsheet Documents).
- Languages that are used to write code to be delivered within Apache OpenOffice documents and utilize dialogs designed with the Apache OpenOffice dialog editor.
The following table lists programming languages currently supported by UNO. 'Yes' in the table columns denotes full support, 'no' denotes that there is no support and is not even planned in the future. 'Maybe in future' means there is currently no support, but this may change with future releases.
Language | UNO scripting | UNO components | Deployment with Apache OpenOffice documents |
---|---|---|---|
C++ | yes | yes | no |
C | maybe in future | maybe in future | no |
Java | yes | yes | maybe in future |
StarBasic | yes | no | yes |
OLE automation (win32 only) | yes | maybe in future | maybe in future |
Python | maybe in future (under development) | maybe in future (under development) | maybe in future |
Java
Java is a an accepted programming language offering a standard library with a large set of features and available extensions. Additional extensions will be available in the future, such as JAX-RPC for calling webservices. It is a typesafe language with a typesafe UNO binding. Although interfaces have to be queried explicitly, the type safety makes it suitable for larger projects. UNO components can be implemented with Java, that is, the Java VM is started on demand inside the office process when a Java component is instantiated. The OfficeBean allows embedding Apache OpenOffice documents in Java Applets and Applications.
There is a constant runtime overhead of about 1 to 2 ms per call that is caused by the bridge conversion routines when calling UNO objects implemented in other language bindings. Since Apache OpenOffice consists of C++ code, every Java call into the office needs to be bridged. This poses no problems if there are a few calls per user interaction. The runtime overhead will hurt the application when routines produce hundreds or thousands of calls.
C++
C++ is an accepted programming language offering third-party products. In addition to C++ being fast since it is compiled locally, it offers the fastest communication with Apache OpenOffice because most of the essential parts of office have been developed in C++. This advantage becomes less important as you call into the office through the interprocess bridge, because every remote call means a constant loss of 1 to 2 ms. The fastest code to extend the office can be implemented as a C++ UNO component. It is appropriate for larger projects due to its strong type safety at compile time.
C++ is difficult to learn and coding, in general, takes longer, for example, in Java. The components must be built for every platform, that leads to a higher level of complexity during development and deployment.
OpenOffice Basic
Apache OpenOffice Basic is the scripting language developed for and integrated directly into Apache OpenOffice. It currently offers the best integration with Apache OpenOffice, because you can insert code into documents, attach arbitrary office events, such as document loading, keyboard shortcuts or menu entries, to Basic code and use dialogs designed within the Apache OpenOffice IDE. In Basic, calls are invoked on an object rather than on a specific interface. Interfaces, such as com.sun.star.beans.XPropertySet are integrated as Basic object properties. Basic always runs in the office process and thus avoids costly interprocess calls.
The language is type unsafe, that is, only a minimal number of errors are found during compilation. Most errors appear at runtime, therefore it is not the best choice for large projects. The language is Apache OpenOffice specific and only offers a small set of runtime functionality with little third-party support. All office functionality is used through UNO. UNO components cannot be implemented with Basic. The only UNO objects that can be implemented are listeners. Finally, Basic does not offer any thread support.
OLE Automation Bridge
The OLE Automation bridge opens the UNO world to programming environments that support OLE automation, such as Visual Basic, JScript, Delphi or C++ Builder. Programmers working on the Windows platform can write programs for Apache OpenOffice without leaving their language by learning a new API. These programmers have access to the libraries provided by their language. It is possible to implement UNO objects, if the programming language supports object implementation.
This bridge is only useful on a Win32 machine, thereby being a disadvantage. Scripts always run in a different process so that every UNO call has at least the usual interprocess overhead of 1 to 2 ms. Currently Automation UNO components cannot be implemented for the service manager, but this may change in the future.
Python
A Python scripting bridge (PyUNO) is currently developed by Ralph Thomas. It is available in an experimental alpha state with known limitations. For details, see PyUNO on www.openoffice.org/udk/.
Use Cases
The following list gives typical UNO applications for the various language environments.
Java
- Servlets creating Office Documents on the fly, Java Server Pages
- Server-Based Collaboration Platforms, Document Management Systems
- Calc add-ins
- Chart add-ins
- Database Drivers
C++
- Filters reading document data and generating Office Documents through UNO calls
- Database Drivers
- Calc add-ins
- Chart add-ins
OpenOffice Basic
- Office Automation
- Event-driven data-aware forms
OLE Automation
- Office Automation, creating and controlling Office Documents from other applications and from Active Server Pages
Python
- Calc add-ins
Recommendation
All languages have their advantages and disadvantages as previously discussed, but there is not one language for all purposes, depending on your use. Consider carefully before starting a new project and evaluate the language to use so that it saves you time.
Sometimes it may be useful to use multiple languages to gain the advantages of both languages. For instance, currently it is not possible to attach a keyboard event to a Java method, therefore, write a small Basic function, which forwards the event to a Java component.
The number of languages supported by UNO may increase and some limitations shown in the table above may disappear.
Content on this page is licensed under the Public Documentation License (PDL). |