Jump to content
Wikipedia The Free Encyclopedia

Compound File Binary Format

From Wikipedia, the free encyclopedia
Compound document file format

Compound File Binary Format (CFBF), also called Compound File, Compound Document format,[1] or Composite Document File V2[2] (CDF), is a compound document file format for storing numerous files and streams within a single file on a disk. CFBF is developed by Microsoft and is an implementation of Microsoft COM Structured Storage.[3] [4] [5] The file format is used for storing storage objects and stream objects in a hierarchical structure within a single file.[6]

Microsoft has opened the format for use by others and it is now used in a variety of programs from Microsoft Word and Microsoft Access to Business Objects.[citation needed ] It also forms the basis of the Advanced Authoring Format.[7]

Overview

[edit ]

At its simplest, the Compound File Binary Format is a container, with little restriction on what can be stored within it.

A CFBF file structure loosely resembles a FAT file system. The file is partitioned into Sectors which are chained together with a File Allocation Table (not to be mistaken with the file system of the same name) which contains chains of sectors related to each file, a Directory holds information for contained files with a Sector ID (SID) for the starting sector of a chain and so on.

Structure

[edit ]

The CFBF file consists of a 512-byte header record followed by a number of Sectors whose size is defined in the header. The literature defines Sectors to be either 512 or 4096 bytes in length, although the format is potentially capable of supporting sectors ranging in size from 128 bytes upwards, in powers of two (128, 256, 512, 1024, etc.). The lower limit of 128 is the minimum required to fit a single directory entry in a Directory Sector.[relevant? ]

There are several types of sector that may be present in a CFBF file:

  • File Allocation Table (FAT) Sector – contains chains of sector indices much as a FAT does in the FAT/FAT32 filesystems
  • MiniFAT Sectors – similar to the FAT but storing chains of mini-sectors within the Mini-Stream
  • Double-Indirect FAT (DIFAT) Sector – contains chains of FAT sector indices
  • Directory Sector – contains directory entries
  • Stream Sector – contains arbitrary file data
  • Range Lock Sector – contains the byte-range locking area of a large file

More detail is given below for the header and each sector type.

CFBF header format

[edit ]

The CFBF header occupies the first 512 bytes of the file and information required to interpret the rest of the file. The C-style structure declaration below (extracted from the AAFA's Low-Level Container Specification) shows the members of the CFBF header and their purpose:

typedefunsignedlongULONG;// 4 bytes
typedefunsignedshortUSHORT;// 2 bytes
typedefshortOFFSET;// 2 bytes
typedefULONGSECT;// 4 bytes
typedefULONGFSINDEX;// 4 bytes
typedefUSHORTFSOFFSET;// 2 bytes
typedefUSHORTWCHAR;// 2 bytes
typedefULONGDFSIGNATURE;// 4 bytes
typedefunsignedcharBYTE;// 1 byte
typedefunsignedshortWORD;// 2 bytes
typedefunsignedlongDWORD;// 4 bytes
typedefULONGSID;// 4 bytes
typedefGUIDCLSID;// 16 bytes
structStructuredStorageHeader{// [offset from start (bytes), length (bytes)]
BYTE_abSig[8];// [00H,08] {0xd0, 0xcf, 0x11, 0xe0, 0xa1, 0xb1,
// 0x1a, 0xe1} for current version
CLSID_clsid;// [08H,16] reserved must be zero (WriteClassStg/
// GetClassFile uses root directory class id)
USHORT_uMinorVersion;// [18H,02] minor version of the format: 33 is
// written by reference implementation
USHORT_uDllVersion;// [1AH,02] major version of the dll/format: 3 for
// 512-byte sectors, 4 for 4 KB sectors
USHORT_uByteOrder;// [1CH,02] 0xFFFE: indicates Intel byte-ordering
USHORT_uSectorShift;// [1EH,02] size of sectors in power-of-two;
// typically 9 indicating 512-byte sectors
USHORT_uMiniSectorShift;// [20H,02] size of mini-sectors in power-of-two;
// typically 6 indicating 64-byte mini-sectors
USHORT_usReserved;// [22H,02] reserved, must be zero
ULONG_ulReserved1;// [24H,04] reserved, must be zero
FSINDEX_csectDir;// [28H,04] must be zero for 512-byte sectors,
// number of SECTs in directory chain for 4 KB
// sectors
FSINDEX_csectFat;// [2CH,04] number of SECTs in the FAT chain
SECT_sectDirStart;// [30H,04] first SECT in the directory chain
DFSIGNATURE_signature;// [34H,04] signature used for transactions; must
// be zero. The reference implementation
// does not support transactions
ULONG_ulMiniSectorCutoff;// [38H,04] maximum size for a mini stream;
// typically 4096 bytes
SECT_sectMiniFatStart;// [3CH,04] first SECT in the MiniFAT chain
FSINDEX_csectMiniFat;// [40H,04] number of SECTs in the MiniFAT chain
SECT_sectDifStart;// [44H,04] first SECT in the DIFAT chain
FSINDEX_csectDif;// [48H,04] number of SECTs in the DIFAT chain
SECT_sectFat[109];// [4CH,436] the SECTs of first 109 FAT sectors
};

File Allocation Table (FAT) sectors

[edit ]

When taken together as a single stream the collection of FAT sectors define the status and linkage of every sector in the file. Each entry in the FAT is 4 bytes in length and contains the sector number of the next sector in a FAT chain or one of the following special values:

  • FREESECT (0xFFFFFFFF) – denotes an unused sector
  • ENDOFCHAIN (0xFFFFFFFE) – marks the last sector in a FAT chain
  • FATSECT (0xFFFFFFFD) – marks a sector used to store part of the FAT
  • DIFSECT (0xFFFFFFFC) – marks a sector used to store part of the DIFAT

Range Lock Sector

[edit ]
[icon]
This section needs expansion. You can help by adding to it. (November 2009)

The Range Lock Sector must exist in files greater than 2 GB in size, and must not exist in files smaller than 2 GB. The Range Lock Sector must contain the byte range 0x7FFFFF00 to 0x7FFFFFFF in the file. This area is reserved by Microsoft's COM implementation for storing byte-range locking information for concurrent access.

Glossary

[edit ]
  • FAT – File Allocation Table; also known as SAT – Sector Allocation Table
  • DIFAT – Double-Indirect File Allocation Table
  • FAT Chain – a group of FAT entries which indicate the Sectors allocated to a Stream in the file
  • Stream – a virtual file which occupies a number of Sectors within the CFBF
  • Sector – the unit of allocation within the CFBF, usually 512 or 4096 Bytes in length

See also

[edit ]

References

[edit ]
  1. ^ "Apache POI – POIFS". POI Project. Archived from the original on 26 April 2011. Retrieved 10 May 2011.
  2. ^ "How to convert documents between LibreOffice and Microsoft Office file formats on Linux". Archived from the original on 21 September 2019. Retrieved 25 November 2016.
  3. ^ "Compound Files (Windows)". Microsoft Developers Network (MSDN) library – COM SDK. Microsoft Corporation. 20 November 2008. Retrieved 23 September 2009.
  4. ^ "Containers: Compound Files". Microsoft Developers Network (MSDN) library – Visual Studio 2008 documentation. Microsoft Corporation. Retrieved 23 September 2009.
  5. ^ "Understand Compound Files". Microsoft Developers Network (MSDN) library – ActiveDirectory Rights Management. 25 June 2009. Retrieved 23 September 2009.
  6. ^ "Microsoft Compound File Binary File Format, Version 4". www.loc.gov. 28 January 2020. Retrieved 13 June 2024.
  7. ^ AMW Association (formerly AAF Association) Archived 15 August 2000 at the Wayback Machine
[edit ]

AltStyle によって変換されたページ (->オリジナル) /