office-gobmx/lotuswordpro
Stephan Bergmann e0c33ec15f loplugin:ostr: automatic rewrite
Change-Id: I2d09b2b83e1b50493ec88d0b2c323a83c0c86395
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/157647
Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
Tested-by: Jenkins
2023-10-07 00:47:20 +02:00
..
inc
qa/cppunit
source/filter
util
CppunitTest_lotuswordpro_import_test.mk
CppunitTest_lotuswordpro_test_lotuswordpro.mk
IwyuFilter_lotuswordpro.yaml
Library_lwpft.mk
Makefile
Module_lotuswordpro.mk
README.md

Import Filter for File Format of Lotus Word Pro (lwp)

Description

⚠️ Import Filter supports only Lotus Word Pro 97 and next versions

The import is not direct, but via an intermediate format: StarOffice XML, the predecessor of ODF (yes, the code is old). The entry point to the filter is class LotusWordProImportFilter (refer to Source code section), but that just hooks up the necessary machinery for processing StarOffice XML produced by the filter. The real fun starts in function ReadWordproFile() (source/filter/lwpfilter.cxx); this function initializes the parser (class Lwp9Reader) and the SAX XML handler that produces the output (class XFSaxStream). The Lwp9Reader class then does the actual parsing.

If the module is built with debug level greater than 0, it is possible to examine the intermediate XML: set environment variable DBG_LWPIMPORT_DIR= to an existing directory. During opening an .lwp document, a file named lwpimport.xml will be created in DBG_LWPIMPORT_DIR directory.

Source Code

Module Contents

  • inc: module-global headers (can be included by any file in source)
  • qa: cppunit tests
  • source: the filter itself
  • util: UNO passive registration config

Source Contents

  • filter: lwp document format parser
  • filter/LotusWordProImportFilter.cxx: the entry point to the filter
  • filter/xfilter: export to StarOffice XML