[xml] lazy libxml
- From: Nic James Ferrier <nferrier tapsellferrier co uk>
- To: libxml <xml gnome org>
- Subject: [xml] lazy libxml
- Date: Mon, 19 Jun 2006 13:50:42 +0100
I want a lazy implementation of libxml for my XRT project.
I am collecting my thoughts on how to build lazyness into libxml2.
If anyone has any views on how to do it, or has already done any work
on it then please contact me, or make suggestions on this thread.
For those of you who don't know... lazy xml is the introduction of
delayed computation of XML trees inside the dom. This means that you
can have a part of the tree that is not known until the tree is
serialized or until nodes within the tree are required.
For example, pseudo-code:
DOM x = new DOM()
El a = x.new_element_child("a")
El a_b = a.new_element_child(lazy_element("b"))
at this point a_b is not computed, it is present in the tree and it's
type is known but the content, it's length and all the other details
are hidden from view, indeed, they do not yet exist.
If we now do:
print x.content()
then that causes element a_b to be serialized and thus the computation
that produces the tree must be run and we get the correct output.
So, really, lazy XML is just a way of introducing a sub-type into the
libxml2 type definitions to indicate whether an object is computed or
not. A function pointer will have to be stored with the object to
provide the implementation of the node.
This is pretty simple to do at the C level but it gets more
complicated if nodes are implemented in a higher level language,
Python say.
--
Nic Ferrier
http://www.tapsellferrier.co.uk for all your tapsell ferrier needs
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]