From: Martin Jambon <martin.jambon@ens-lyon.org>
To: Basile STARYNKEVITCH <basile@starynkevitch.net>
Cc: Dario Teixeira <darioteixeira@yahoo.com>, caml-list@yquem.inria.fr
Subject: Re: [Caml-list] Long-term storage of values
Date: Fri, 29 Feb 2008 15:45:21 +0100 (CET) [thread overview]
Message-ID: <Pine.LNX.4.64.0802291520190.8856@martin.ec.wink.com> (raw)
In-Reply-To: <47C73121.2060809@starynkevitch.net>
On Thu, 28 Feb 2008, Basile STARYNKEVITCH wrote:
> Dario Teixeira wrote:
>> Hi,
>>
>> Suppose I have a value of type Story.t, fairly complex in its definition.
>> I wish to store this value in a DB (like Postgresql) for posterity.
>> At the moment, I am storing in the DB the marshalled representation
>> of the data; whenever I need to use it again in the Ocaml programme
>> I simply fetch it from the DB and unmarshal it.
>>
>> This works fine; there is however one nagging problem: the marshalled
>> representation is brittle. If Story.t changes even slightly, I will
>> no longer be able to retrieve values marshalled with the old version.
>
>
> It is even theoretically a very difficult problem. There have been some
> publications by Cristal, Moscova, Gallium people at INRIA.
>
> Assuming you have no abstract types, no objects, and no closures, and no
> polymorphisms i.e. that there is a *.ml source file containing all the type
> definitions. Then the types are composed by base types (int, string, ...),
> sums, records, and perhaps arrays.
>
> Then you could consider what are the deltas on the type definition.
>
> In a sum like type sumt = A of t1 | B of t2 | C
> you might consider what happens when you remove let say B, or add let's say a
> choice | D of t3
>
> In a record, consider likewise what happens when adding or removing a field.
>
> Etc....
>
>
> The details are very complex (at least to me, who tried unsucessfully to work
> on this during my year at INRIA).
>
> Maybe a semi-hand-crafted generator could help. Adding polymorphisms,
> closures, objects, abstract types is a big mess.
I sure do believe you.
However, speaking with no experience in this domain, it seems to me that
if we restrict the transition to a certain subset of operations, it can be
possible to define a mapping using some Camlp4 tool such as Deriving
(well, that's what I was told, assuming I interpreted correctly).
For instance:
- adding a record field: a default value is injected
- removing a record field: just remove it
- adding a variant: do nothing since it doesn't exist in the old data
- changing a type arbitrarily (such as changing a type foo1 into foo2
everywhere): provide a map function that would override the default map
function for such nodes.
- functional and abstract values: left as-is
I think I'll soon have to deal with such a problem, so any further
suggestions are welcome.
Martin
--
http://wink.com/profile/mjambon
http://martin.jambon.free.fr
next prev parent reply other threads:[~2008-02-29 14:45 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-02-28 18:41 Dario Teixeira
2008-02-28 20:01 ` [Caml-list] " David MENTRE
2008-02-28 20:01 ` Thomas Fischbacher
2008-02-28 20:05 ` Mathias Kende
2008-02-28 22:09 ` Basile STARYNKEVITCH
2008-02-29 14:45 ` Martin Jambon [this message]
2008-02-29 19:09 ` Jake Donham
2008-02-28 23:42 ` Erik de Castro Lopo
2008-02-29 1:14 ` Brian Hurt
2008-02-29 7:40 ` Gabriel Kerneis
2008-02-29 10:19 ` Berke Durak
2008-02-29 18:05 ` Markus Mottl
2008-02-29 11:44 ` Richard Jones
2008-02-29 14:09 ` Brian Hurt
2008-03-01 14:15 ` Dario Teixeira
2008-03-20 21:03 ` Dario Teixeira
2008-03-20 21:32 ` Martin Jambon
2008-03-20 22:41 ` Dario Teixeira
2008-03-20 23:00 ` Martin Jambon
2008-03-21 14:01 ` Dario Teixeira
2008-03-21 14:28 ` Martin Jambon
2008-03-21 14:34 ` Martin Jambon
2008-03-20 21:42 ` Daniel Bünzli
2008-03-20 22:33 ` Dario Teixeira
2008-03-20 21:43 ` Gerd Stolpmann
2008-03-21 14:37 ` Dario Teixeira
2008-03-21 15:24 ` Richard Jones
2008-03-22 12:14 ` David MENTRE
2008-03-21 16:04 ` Gerd Stolpmann
2008-03-21 10:32 ` Berke Durak
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Pine.LNX.4.64.0802291520190.8856@martin.ec.wink.com \
--to=martin.jambon@ens-lyon.org \
--cc=basile@starynkevitch.net \
--cc=caml-list@yquem.inria.fr \
--cc=darioteixeira@yahoo.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox