Versioning friendly, extendible binary file format

Posted by Bas Bossink on Stack Overflow See other posts from Stack Overflow or by Bas Bossink
Published on 2010-03-29T20:33:11Z Indexed on 2010/04/03 4:13 UTC
Read the original article Hit count: 464

Filed under:
|
|

In the project I'm currently working on there is a need to save a sizable data structure to disk (edit: think dozens of MB's). Being an optimist, I thought that there must be a standard solution for such a problem; however, up to now I haven't found a solution that satisfies the following requirements:

  1. .NET 2.0 support, preferably with a FOSS implementation
  2. Version friendly (this should be interpreted as: reading an old version of the format should be relatively simple if the changes in the underlying data structure are simple, say adding/dropping fields)
  3. Ability to do some form of random access where part of the data can be extended after initial creation (think of this as extending intermediate results)
  4. Space and time efficient (XML has been excluded as option given this requirement)

Options considered so far:

  • Protocol Buffers: was turned down by verdict of the documentation about Large Data Sets - since this comment suggested adding another layer on top, this would call for additional complexity which I wish to have handled by the file format itself.
  • HDF5,EXI: do not seem to have .net implementations
  • SQLite/SQL Server Compact edition: the data structure at hand would result in a pretty complex table structure that seems too heavyweight for the intended use
  • BSON: does not appear to support requirement 3.
  • Fast Infoset: only seems to have paid .NET implementations.

Any recommendations or pointers are greatly appreciated. Furthermore if you believe any of the information above is not true, please provide pointers/examples to prove me wrong.

© Stack Overflow or respective owner

Related posts about .NET

Related posts about binary