office-gobmx/lotuswordpro
jpuronah 6201b6468f tdf#143148: Use pragma once instead of include guards
Change-Id: I8369e0bdb6a01838d87e7cddc1cbaed911fe461a
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/149952
Tested-by: Jenkins
Tested-by: Ilmari Lauhakangas <ilmari.lauhakangas@libreoffice.org>
Reviewed-by: Ilmari Lauhakangas <ilmari.lauhakangas@libreoffice.org>
2023-04-03 12:32:47 +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