Blob Blame History Raw
/* -*- Mode: C++; c-default-style: "k&r"; indent-tabs-mode: nil; tab-width: 2; c-basic-offset: 2 -*- */

/* libstaroffice
 * Version: MPL 2.0 / LGPLv2.1+
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * Major Contributor(s):
 * Copyright (C) 2003-2005 William Lachance (william.lachance@sympatico.ca)
 * Copyright (C) 2003 Marc Maurer (uwog@uwog.net)
 *
 * For minor contributions see the git repository.
 *
 * Alternatively, the contents of this file may be used under the terms
 * of the GNU Lesser General Public License Version 2.1 or later
 * (LGPLv2.1+), in which case the provisions of the LGPLv2.1+ are
 * applicable instead of those above.
 *
 * For further information visit http://libstoff.sourceforge.net
 */


#ifndef STOFFDOCUMENT_HXX
#define STOFFDOCUMENT_HXX

#ifdef _WINDLL
#ifdef BUILD_STOFF
#define STOFFLIB __declspec(dllexport)
#else
#define STOFFLIB __declspec(dllimport)
#endif
#else // !DLL_EXPORT
#ifdef LIBSTAROFFICE_VISIBILITY
#define STOFFLIB __attribute__((visibility("default")))
#else
#define STOFFLIB
#endif
#endif

namespace librevenge
{
class RVNGBinaryData;
class RVNGDrawingInterface;
class RVNGPresentationInterface;
class RVNGSpreadsheetInterface;
class RVNGTextInterface;
class RVNGInputStream;
}

/**
This class provides all the functions an application would need to parse StarOffice documents.
*/
class STOFFDocument
{
public:
  /** an enum which defines if we have confidence that a file is supported */
  enum Confidence {
    STOFF_C_NONE=0/**< not supported */,
    STOFF_C_UNSUPPORTED_ENCRYPTION /** encryption not supported*/,
    STOFF_C_SUPPORTED_ENCRYPTION /** encryption supported */,
    STOFF_C_EXCELLENT /** supported */
  };
  /** an enum to define the kind of document */
  enum Kind {
    STOFF_K_UNKNOWN=0 /**< unknown*/,
    STOFF_K_BITMAP /** bitmap/image */,
    STOFF_K_CHART /** chart */,
    STOFF_K_DATABASE /** database */,
    STOFF_K_DRAW /** vectorized graphic: .sda*/,
    STOFF_K_MATH /** math*/,
    STOFF_K_PRESENTATION /** presentation*/,
    STOFF_K_SPREADSHEET /** spreadsheet: .sdc */,
    STOFF_K_TEXT /** word processing file*/,
    STOFF_K_GRAPHIC /** gallery graphic: .sdg */
  };
  /** an enum which defines the result of the file parsing */
  enum Result {
    STOFF_R_OK=0 /**< conversion ok*/,
    STOFF_R_FILE_ACCESS_ERROR /** problem when accessing file*/,
    STOFF_R_OLE_ERROR /** problem when reading the OLE structure*/,
    STOFF_R_PARSE_ERROR /** problem when parsing the file*/,
    STOFF_R_PASSWORD_MISSMATCH_ERROR /** problem when using the given password*/,
    STOFF_R_UNKNOWN_ERROR /** unknown error*/
  };

  /** Analyzes the content of an input stream to see if it can be parsed
      \param input The input stream
      \param kind The document kind ( filled if the file is supported )
      \return A confidence value which represents the likelyhood that the content from
      the input stream can be parsed */
  static STOFFLIB Confidence isFileFormatSupported(librevenge::RVNGInputStream *input, Kind &kind);

  // ------------------------------------------------------------
  // the different main parsers
  // ------------------------------------------------------------

  /** Parses the input stream content. It will make callbacks to the functions provided by a
     librevenge::RVNGTextInterface class implementation when needed. This is often commonly called the
     'main parsing routine'.
     \param input The input stream
     \param documentInterface A RVNGTextInterface implementation
     \param password The file password

   \note Reserved for future use. Actually, it only returns false */
  static STOFFLIB Result parse(librevenge::RVNGInputStream *input, librevenge::RVNGTextInterface *documentInterface, char const *password=nullptr);

  /** Parses the input stream content. It will make callbacks to the functions provided by a
     librevenge::RVNGDrawingInterface class implementation when needed. This is often commonly called the
     'main parsing routine'.
     \param input The input stream
     \param documentInterface A RVNGDrawingInterface implementation
     \param password The file password

     \note Reserved for future use. Actually, it only returns false. */
  static STOFFLIB Result parse(librevenge::RVNGInputStream *input, librevenge::RVNGDrawingInterface *documentInterface, char const *password=nullptr);

  /** Parses the input stream content. It will make callbacks to the functions provided by a
     librevenge::RVNGPresentationInterface class implementation when needed. This is often commonly called the
     'main parsing routine'.
     \param input The input stream
     \param documentInterface A RVNGPresentationInterface implementation
     \param password The file password

     \note Reserved for future use. Actually, it only returns false. */
  static STOFFLIB Result parse(librevenge::RVNGInputStream *input, librevenge::RVNGPresentationInterface *documentInterface, char const *password=nullptr);

  /** Parses the input stream content. It will make callbacks to the functions provided by a
     librevenge::RVNGSpreadsheetInterface class implementation when needed. This is often commonly called the
     'main parsing routine'.
     \param input The input stream
     \param documentInterface A RVNGSpreadsheetInterface implementation
     \param password The file password

   \note Can only convert some basic documents: retrieving more cells' contents but no formating. */
  static STOFFLIB Result parse(librevenge::RVNGInputStream *input, librevenge::RVNGSpreadsheetInterface *documentInterface, char const *password=nullptr);

  // ------------------------------------------------------------
  // decoders of the embedded zones created by libstoff
  // ------------------------------------------------------------

  /** Parses the graphic contained in the binary data and called documentInterface to reconstruct
    a graphic. The input is normally send to a librevenge::RVNGXXXInterface with mimeType="image/stoff-odg",
    ie. it must correspond to a picture created by the STOFFGraphicEncoder class via
    a STOFFPropertyEncoder.

   \param binary a list of librevenge::RVNGDrawingInterface stored in a documentInterface,
   \param documentInterface the RVNGDrawingInterface which will convert the graphic is some specific format.

   \note Reserved for future use. Actually, it only returns false. */
  static STOFFLIB bool decodeGraphic(librevenge::RVNGBinaryData const &binary, librevenge::RVNGDrawingInterface *documentInterface);

  /** Parses the spreadsheet contained in the binary data and called documentInterface to reconstruct
    a spreadsheet. The input is normally send to a librevenge::RVNGXXXInterface with mimeType="image/stoff-ods",
    ie. it must correspond to a spreadsheet created by the STOFFSpreadsheetInterface class via
    a STOFFPropertyEncoder.

   \param binary a list of librevenge::RVNGSpreadsheetInterface stored in a documentInterface,
   \param documentInterface the RVNGSpreadsheetInterface which will convert the spreadsheet is some specific format.

   \note Reserved for future use. Actually, it only returns false. */
  static STOFFLIB bool decodeSpreadsheet(librevenge::RVNGBinaryData const &binary, librevenge::RVNGSpreadsheetInterface *documentInterface);

  /** Parses the text contained in the binary data and called documentInterface to reconstruct
    a text. The input is normally send to a librevenge::RVNGXXXInterface with mimeType="image/stoff-odt",
    ie. it must correspond to a text created by the STOFFTextInterface class via
    a STOFFPropertyEncoder.

   \param binary a list of librevenge::RVNGTextInterface stored in a documentInterface,
   \param documentInterface the RVNGTextInterface which will convert the text is some specific format.

   \note Reserved for future use. Actually, it only returns false. */
  static STOFFLIB bool decodeText(librevenge::RVNGBinaryData const &binary, librevenge::RVNGTextInterface *documentInterface);
};

#endif /* STOFFDOCUMENT_HXX */
// vim: set filetype=cpp tabstop=2 shiftwidth=2 cindent autoindent smartindent noexpandtab: