MS OLE23GSF LibraryMS OLE2Synopsis
GsfInfileMSOle;
GsfInfile* gsf_infile_msole_new (GsfInput *source,
GError **err);
gboolean gsf_infile_msole_get_class_id (GsfInfileMSOle const *ole,
guint8 *res);
GsfOutfileMSOle;
GsfOutfile* gsf_outfile_msole_new (GsfOutput *sink);
GsfOutfile* gsf_outfile_msole_new_full (GsfOutput *sink,
guint bb_size,
guint sb_size);
gboolean gsf_outfile_msole_set_class_id (GsfOutfileMSOle *ole,
guint8 const *clsid);
GError* gsf_msole_metadata_read (GsfInput *in,
GsfDocMetaData *accum);
gboolean gsf_msole_metadata_write (GsfOutput *out,
GsfDocMetaData const *meta_data,
gboolean doc_not_component);
GIConv gsf_msole_iconv_open_codepages_for_export
(int codepage_to,
char const *from);
GIConv gsf_msole_iconv_open_codepage_for_import
(char const *to,
int codepage);
GIConv gsf_msole_iconv_open_for_export (void);
GIConv gsf_msole_iconv_open_codepage_for_export
(int codepage_to);
GIConv gsf_msole_iconv_open_for_import (int codepage);
int gsf_msole_iconv_win_codepage (void);
guint gsf_msole_codepage_to_lid (int codepage);
int gsf_msole_lid_to_codepage (guint lid);
gchar* gsf_msole_lid_to_codepage_str (guint lid);
guint gsf_msole_lid_for_language (char const *lang);
charconst * gsf_msole_language_for_lid (guint lid);
GByteArray* gsf_msole_inflate (GsfInput *input,
gsf_off_t offset);
#define OLE_HEADER_START_BAT
#define OLE_HEADER_MAJOR_VER
#define OLE_HEADER_METABAT_SIZE
#define OLE_HEADER_DIRENT_START
#define OLE_HEADER_NUM_SBAT
#define OLE_HEADER_BB_SHIFT
#define OLE_HEADER_CSECTDIR
#define OLE_HEADER_NUM_BAT
#define OLE_HEADER_THRESHOLD
#define OLE_HEADER_METABAT_BLOCK
#define OLE_HEADER_SBAT_START
#define OLE_HEADER_SIGNATURE
#define OLE_HEADER_BYTE_ORDER
#define OLE_HEADER_SB_SHIFT
#define OLE_HEADER_NUM_METABAT
#define OLE_HEADER_SIZE
#define OLE_HEADER_CLSID
#define OLE_HEADER_MINOR_VER
#define OLE_DEFAULT_BB_SHIFT
#define OLE_DEFAULT_SB_SHIFT
#define DIRENT_DETAILS_SIZE
#define DIRENT_SIZE
#define DIRENT_NAME_LEN
#define DIRENT_TYPE_PROPERTY
#define DIRENT_TYPE_FILE
#define DIRENT_MAGIC_END
#define DIRENT_TYPE_DIR
#define DIRENT_MAX_NAME_SIZE
#define DIRENT_FILE_SIZE
#define DIRENT_FIRSTBLOCK
#define DIRENT_TYPE_INVALID
#define DIRENT_USERFLAGS
#define DIRENT_COLOUR
#define DIRENT_MODIFY_TIME
#define DIRENT_TYPE_LOCKBYTES
#define DIRENT_CREATE_TIME
#define DIRENT_PREV
#define DIRENT_NEXT
#define DIRENT_CHILD
#define DIRENT_TYPE
#define DIRENT_CLSID
#define DIRENT_TYPE_ROOTDIR
#define BAT_MAGIC_METABAT
#define BAT_MAGIC_BAT
#define BAT_INDEX_SIZE
#define BAT_MAGIC_END_OF_CHAIN
#define BAT_MAGIC_UNUSED
Object Hierarchy
GObject
+----GsfInput
+----GsfInfile
+----GsfInfileMSOle
GObject
+----GsfOutput
+----GsfOutfile
+----GsfOutfileMSOle
DescriptionDetailsGsfInfileMSOleGsfInfileMSOletypedef struct _GsfInfileMSOle GsfInfileMSOle;gsf_infile_msole_new ()gsf_infile_msole_newGsfInfile* gsf_infile_msole_new (GsfInput *source,
GError **err);
Opens the root directory of an MS OLE file.
NOTE : adds a reference to sourcesource :err :Returns :: the new ole file handler
gsf_infile_msole_get_class_id ()gsf_infile_msole_get_class_idgboolean gsf_infile_msole_get_class_id (GsfInfileMSOle const *ole,
guint8 *res);
Retrieves the 16 byte indentifier (often a GUID in MS Windows apps)
stored within the directory associated with ole and stores it in res.ole : a GsfInfileMSOleres : 16 byte identifier (often a GUID in MS Windows apps)
Returns :TRUE on success
GsfOutfileMSOleGsfOutfileMSOletypedef struct _GsfOutfileMSOle GsfOutfileMSOle;gsf_outfile_msole_new ()gsf_outfile_msole_newGsfOutfile* gsf_outfile_msole_new (GsfOutput *sink);
Creates the root directory of an MS OLE file and manages the addition of
children.
NOTE : adds a reference to sinksink : a GsfOutput to hold the OLE2 file
Returns :the new ole file handler
gsf_outfile_msole_new_full ()gsf_outfile_msole_new_fullGsfOutfile* gsf_outfile_msole_new_full (GsfOutput *sink,
guint bb_size,
guint sb_size);
Creates the root directory of an MS OLE file and manages the addition of
children.
NOTE : adds a reference to sinksink : a GsfOutput to hold the OLE2 file.
bb_size : size of large blocks.
sb_size : size of small blocks.
Returns :the new ole file handler
gsf_outfile_msole_set_class_id ()gsf_outfile_msole_set_class_idgboolean gsf_outfile_msole_set_class_id (GsfOutfileMSOle *ole,
guint8 const *clsid);
Write clsid to the directory associated with ole.ole : a GsfOutfileMSOleclsid : 16 byte identifier (often a GUID in MS Windows apps)
Returns :TRUE on success.
gsf_msole_metadata_read ()gsf_msole_metadata_readGError* gsf_msole_metadata_read (GsfInput *in,
GsfDocMetaData *accum);
Read a stream formated as a set of MS OLE properties from in and store the
results in accum.in :GsfInputaccum :GsfDocMetaDataReturns :GError which the caller must free on error.
gsf_msole_metadata_write ()gsf_msole_metadata_writegboolean gsf_msole_metadata_write (GsfOutput *out,
GsfDocMetaData const *meta_data,
gboolean doc_not_component);out :GsfOutputmeta_data :GsfDocMetaDatadoc_not_component : a kludge to differentiate DocumentSummary from Summary
Returns :TRUE on success;
gsf_msole_iconv_open_codepages_for_export ()gsf_msole_iconv_open_codepages_for_exportGIConv gsf_msole_iconv_open_codepages_for_export
(int codepage_to,
char const *from);codepage_to :from :Returns :an iconv converter to go from utf8 -> to our best guess at a useful
windows codepage.
gsf_msole_iconv_open_codepage_for_import ()gsf_msole_iconv_open_codepage_for_importGIConv gsf_msole_iconv_open_codepage_for_import
(char const *to,
int codepage);to :codepage :Returns :an iconv converter for codepage -> utf8.
gsf_msole_iconv_open_for_export ()gsf_msole_iconv_open_for_exportGIConv gsf_msole_iconv_open_for_export (void);Returns :an iconv convert to go from utf8 -> to our best guess at a useful
windows codepage.
gsf_msole_iconv_open_codepage_for_export ()gsf_msole_iconv_open_codepage_for_exportGIConv gsf_msole_iconv_open_codepage_for_export
(int codepage_to);codepage_to :Returns :an iconv converter to go from utf8 -> to our best guess at a useful
windows codepage.
gsf_msole_iconv_open_for_import ()gsf_msole_iconv_open_for_importGIConv gsf_msole_iconv_open_for_import (int codepage);codepage :Returns :an iconv converter for single byte encodings codepage -> utf8.
Attempt to handle the semantics of a specification for multibyte encodings
since this is only supposed to be used for single bytes.
gsf_msole_iconv_win_codepage ()gsf_msole_iconv_win_codepageint gsf_msole_iconv_win_codepage (void);Returns :our best guess at the applicable windows code page based on an
environment variable or the current locale.
gsf_msole_codepage_to_lid ()gsf_msole_codepage_to_lidguint gsf_msole_codepage_to_lid (int codepage);codepage :Returns :gsf_msole_lid_to_codepage ()gsf_msole_lid_to_codepageint gsf_msole_lid_to_codepage (guint lid);lid :Returns :our best guess at the codepage for the given language id
gsf_msole_lid_to_codepage_str ()gsf_msole_lid_to_codepage_strgchar* gsf_msole_lid_to_codepage_str (guint lid);lid :Returns :the Iconv codepage string for the given LID.
Return value must be g_free()'d
gsf_msole_lid_for_language ()gsf_msole_lid_for_languageguint gsf_msole_lid_for_language (char const *lang);lang :Returns :the LID (Language Identifier) for the input language.
If lang is null, return 0x0400 ("-none-"), and not 0x0000 ("no proofing")
gsf_msole_language_for_lid ()gsf_msole_language_for_lidcharconst * gsf_msole_language_for_lid (guint lid);lid :Returns :the xx_YY style string (can be just xx or xxx) for the given LID.
Return value must not be freed. If the LID is not found, is set to 0x0400,
or is set to 0x0000, will return "-none-"
gsf_msole_inflate ()gsf_msole_inflateGByteArray* gsf_msole_inflate (GsfInput *input,
gsf_off_t offset);
Decompresses an LZ compressed stream.input : stream to read from
offset : offset into it for start byte of compresse stream
Returns : A GByteArray that the caller is responsible for freeing
OLE_HEADER_START_BATOLE_HEADER_START_BAT#define OLE_HEADER_START_BAT 0x4c
OLE_HEADER_MAJOR_VEROLE_HEADER_MAJOR_VER#define OLE_HEADER_MAJOR_VER 0x1a /* 0x3 been seen in wild */
OLE_HEADER_METABAT_SIZEOLE_HEADER_METABAT_SIZE#define OLE_HEADER_METABAT_SIZE ((OLE_HEADER_SIZE - OLE_HEADER_START_BAT) / BAT_INDEX_SIZE)
OLE_HEADER_DIRENT_STARTOLE_HEADER_DIRENT_START#define OLE_HEADER_DIRENT_START 0x30
OLE_HEADER_NUM_SBATOLE_HEADER_NUM_SBAT#define OLE_HEADER_NUM_SBAT 0x40
OLE_HEADER_BB_SHIFTOLE_HEADER_BB_SHIFT#define OLE_HEADER_BB_SHIFT 0x1e
OLE_HEADER_CSECTDIROLE_HEADER_CSECTDIR#define OLE_HEADER_CSECTDIR 0x28
OLE_HEADER_NUM_BATOLE_HEADER_NUM_BAT#define OLE_HEADER_NUM_BAT 0x2c
OLE_HEADER_THRESHOLDOLE_HEADER_THRESHOLD#define OLE_HEADER_THRESHOLD 0x38
OLE_HEADER_METABAT_BLOCKOLE_HEADER_METABAT_BLOCK#define OLE_HEADER_METABAT_BLOCK 0x44
OLE_HEADER_SBAT_STARTOLE_HEADER_SBAT_START#define OLE_HEADER_SBAT_START 0x3c
OLE_HEADER_SIGNATUREOLE_HEADER_SIGNATURE#define OLE_HEADER_SIGNATURE 0x00
OLE_HEADER_BYTE_ORDEROLE_HEADER_BYTE_ORDER#define OLE_HEADER_BYTE_ORDER 0x1c /* 0xfe 0xff == Intel Little Endian */
OLE_HEADER_SB_SHIFTOLE_HEADER_SB_SHIFT#define OLE_HEADER_SB_SHIFT 0x20
OLE_HEADER_NUM_METABATOLE_HEADER_NUM_METABAT#define OLE_HEADER_NUM_METABAT 0x48
OLE_HEADER_SIZEOLE_HEADER_SIZE#define OLE_HEADER_SIZE 0x200 /* independent of big block size size */
OLE_HEADER_CLSIDOLE_HEADER_CLSID#define OLE_HEADER_CLSID 0x08 /* See ReadClassStg */
OLE_HEADER_MINOR_VEROLE_HEADER_MINOR_VER#define OLE_HEADER_MINOR_VER 0x18 /* 0x33 and 0x3e have been seen */
OLE_DEFAULT_BB_SHIFTOLE_DEFAULT_BB_SHIFT#define OLE_DEFAULT_BB_SHIFT 9
OLE_DEFAULT_SB_SHIFTOLE_DEFAULT_SB_SHIFT#define OLE_DEFAULT_SB_SHIFT 6
DIRENT_DETAILS_SIZEDIRENT_DETAILS_SIZE#define DIRENT_DETAILS_SIZE 0x40
DIRENT_SIZEDIRENT_SIZE#define DIRENT_SIZE (DIRENT_MAX_NAME_SIZE + DIRENT_DETAILS_SIZE)
DIRENT_NAME_LENDIRENT_NAME_LEN#define DIRENT_NAME_LEN 0x40 /* length in bytes incl 0 terminator */
DIRENT_TYPE_PROPERTYDIRENT_TYPE_PROPERTY#define DIRENT_TYPE_PROPERTY 4 /* ? */
DIRENT_TYPE_FILEDIRENT_TYPE_FILE#define DIRENT_TYPE_FILE 2
DIRENT_MAGIC_ENDDIRENT_MAGIC_END#define DIRENT_MAGIC_END 0xffffffff
DIRENT_TYPE_DIRDIRENT_TYPE_DIR#define DIRENT_TYPE_DIR 1
DIRENT_MAX_NAME_SIZEDIRENT_MAX_NAME_SIZE#define DIRENT_MAX_NAME_SIZE 0x40
DIRENT_FILE_SIZEDIRENT_FILE_SIZE#define DIRENT_FILE_SIZE 0x78
DIRENT_FIRSTBLOCKDIRENT_FIRSTBLOCK#define DIRENT_FIRSTBLOCK 0x74
DIRENT_TYPE_INVALIDDIRENT_TYPE_INVALID#define DIRENT_TYPE_INVALID 0
DIRENT_USERFLAGSDIRENT_USERFLAGS#define DIRENT_USERFLAGS 0x60 /* only for dirs */
DIRENT_COLOURDIRENT_COLOUR#define DIRENT_COLOUR 0x43
DIRENT_MODIFY_TIMEDIRENT_MODIFY_TIME#define DIRENT_MODIFY_TIME 0x6c /* for files */
DIRENT_TYPE_LOCKBYTESDIRENT_TYPE_LOCKBYTES#define DIRENT_TYPE_LOCKBYTES 3 /* ? */
DIRENT_CREATE_TIMEDIRENT_CREATE_TIME#define DIRENT_CREATE_TIME 0x64 /* for files */
DIRENT_PREVDIRENT_PREV#define DIRENT_PREV 0x44
DIRENT_NEXTDIRENT_NEXT#define DIRENT_NEXT 0x48
DIRENT_CHILDDIRENT_CHILD#define DIRENT_CHILD 0x4c
DIRENT_TYPEDIRENT_TYPE#define DIRENT_TYPE 0x42
DIRENT_CLSIDDIRENT_CLSID#define DIRENT_CLSID 0x50 /* only for dirs */
DIRENT_TYPE_ROOTDIRDIRENT_TYPE_ROOTDIR#define DIRENT_TYPE_ROOTDIR 5
BAT_MAGIC_METABATBAT_MAGIC_METABAT#define BAT_MAGIC_METABAT 0xfffffffc /* a metabat block -4 */
BAT_MAGIC_BATBAT_MAGIC_BAT#define BAT_MAGIC_BAT 0xfffffffd /* a bat block, -3 */
BAT_INDEX_SIZEBAT_INDEX_SIZE#define BAT_INDEX_SIZE 4
BAT_MAGIC_END_OF_CHAINBAT_MAGIC_END_OF_CHAIN#define BAT_MAGIC_END_OF_CHAIN 0xfffffffe /* -2 */
BAT_MAGIC_UNUSEDBAT_MAGIC_UNUSED#define BAT_MAGIC_UNUSED 0xffffffff /* -1 */