Normalizing Office Documents

From Archivematica
Jump to navigation Jump to search


This page is no longer being maintained and may contain inaccurate information. Please see the Archivematica documentation for up-to-date information.

This is a developement page, not to be confused with the Media type preservation plans.


The typical open source approach to transcoding MS Office documents of various formats is to use unoconv to interface with Open Office. Unfortunately, our experiences with unoconv and our system have not been great.


In Archivematica 0.6 we faced a problem where on boot, the first one or two conversions would fail, due to the server not being initialised. We got around that by creating a daemon to start a unoconv listener.


In Archivematica 0.6.2, with stricter error checking, and the implementation of the MCP we came across further problems with unoconv. It would appear to hang while processing, and occasionally report errors, like 139 segmentation fault. After much testing and we replaced unoconv with some alternative scripts we found online. Issue 304 was used to track this problem: . After unoconv was replaced, the occasional segmentation fault would still appear. I believe the segmentation fault problem is in Open Office: it may be collisions of temporary files/memory between returns and cleanups, but I'm only guessing. The problem seems less frequent when longer sleeps between calls are implemented.


We are aware that MS Office has the ability to save documents into pdf format, which may be able to be scripted/automated. Our concern is that this doesn't keep with the archivematica goal of being a completely open source utility. Future revisions of Archivematica may provide the option to normalize in this manner, but we would like to provide an open source alternative.


Notes On Replacement[edit]

Source: http://www.oooninja.com/2008/02/batch-command-line-file-conversion-with.html
In archivematica: http://code.google.com/p/archivematica/source/browse/trunk/src/MCPClient/runArchivematicaMCPClient.sh#
Called by: user, as part of starting client

Source: http://www.artofsolving.com/files/DocumentConverter.py
In archivematica: http://code.google.com/p/archivematica/source/browse/trunk/src/transcoder/lib/transcoderScripts/DocumentConverter.py
Called by: http://code.google.com/p/archivematica/source/browse/trunk/src/transcoder/lib/transcoderScripts/unoconvAlternativeSupport.sh