Zotero LibreOffice Integration comprises extensions for LibreOffice and Zotero that communicate using local web servers.
- Eclipse
- LibreOffice 5.3+
- Oracle JDK (currently version 18) (NOTE: it won't work with OpenJDK)
LibreOffice SDK is not required.
To build:
- Run
scripts/symlink_sdk
. - Open Eclipse and import this project into your workspace.
- Right-click the project in the Eclipse Package Explorer, click "Properties", select "Java Build Path", then select the "Libraries" tab. Click on "Add JARs" and expand the "Zotero OpenOffice Integration" folder. Make sure there is no "lib" subfolder underneath it. If there is:
- Expand "Zotero OpenOffice Integration" -> "lib" -> "libreoffice-sdk" and select all the JARs underneath it.
- Click "Ok" and then "Apply and Close".
- Double-click Zotero.jardesc. Click "Finish" to build Zotero.jar.
- Run
buildoxt.sh
from within thebuild
directory to buildinstall/Zotero_LibreOffice_Integration.oxt
. - Install
Zotero_LibreOffice_Integration.oxt
into LibreOffice, either by choosing "Reinstall Extension" from within the Zotero preferences, by installing it manually from within LibreOffice, or by usingunopkg
from the command line.- If, when you try to install the extension in LibreOffice, you get an error like "Could not create Java implementation loader", it means that LibreOffice is not configured to use Java. Follow these instructions to set up a Java VM in LibreOffice.
This extension is fairly straightforward. It consists of a LibreOffice UNO based java extension for LibreOffice. The UNO runtime allows various programming languages to interface with a running LibreOffice process. The extension code is initialized by LibreOffice and starts execution in ZoteroOpenOfficeIntegrationImpl.java.
Communication between Zotero and LibreOffice is mediated in zoteroLibreOfficeIntegration.js where a TCP socket is initialized and used for both sending and receiving messages. The complimentary socket connection on the LibreOffice extension end is found in CommServer.java.
The Java extension code can be debugged directly during runtime.
Follow these instructions to enable debugging in LibreOffice. After restarting, LibreOffice will freeze the until a debugging client connects. Create a remote debugging configuration in Eclipse and run it:
- In Eclipse, click on "Run" -> "Debug Configurations...".
- In the left list, select "Remote Java Application".
- In the button bar, press the first button "New launch configuration".
- Use the same port you configured LibreOffice with. The default is port 8000.
- Press "Debug".
LibreOffice will unfreeze. If you add breakpoints in Eclipse they will be triggered freezing the LibreOffice process and allowing you to inspect the execution environment. This technique can be used to debug on remote or virtual machines too.