Re: Changing how we handle attributes: newattr branch



Sorry for miss answer. I had made your serialization implementation work as before and added my new one.

Because last changes are radically different from the ones you review, please take a time to do so.

I've added support for Gee. Now we have serializable TreeMap, ArrayList and one custome DoubleKeyMap. Is really easy to add any other.

This serializable classes allow to serialize any set of GObject (for now) stored on them creating any number of nodes as objects they have. Even that I'm fixing one issues and adding tests cases, they are usable for both serializable implementations.

You can review tests cases to see what we can do now
:-)

El nov 15, 2013 9:04 a.m., "Richard Schwarting" <aquarichy gmail com> escribió:
I like using sugary syntax.  Let's do it!  One important factor is the API still needs to be nice to use from C and _javascript_ though.

I'll merge the newattr branch now.

(Regarding serialization, I've sent a new e-mail; basically never had a response to the Aug 15th review, but can do a new review if that helps)




On Mon, Nov 11, 2013 at 12:13 AM, Daniel Espinosa <esodan gmail com> wrote:

I think is Ok.

We need to stop mimic some 'older' API and focus to take most advantages of Vala sugar syntax and Object Oriented APIs. GLib.HashTable is one of non-GObject  parts of GLib, then is better to use more modern API including add W3C one aside of GObject/Vala one. Look at Gee one.

Using both set_named_item() and just set() and allows to use some Vala sugar syntax like the one at

https://wiki.gnome.org/Vala/Tutorial#Methods_With_Syntax_Support

El oct 23, 2013 2:11 a.m., "Richard Schwarting" <aquarichy gmail com> escribió:
Adam Ples' patch for XPath wanted to use xmlAttrs and GXml.Attrs the same way we use xmlNodes and GXml.Nodes; in that most GXml nodes have a corresponding libxml2 node that they map to. 

GXml.Attrs didn't follow that in part because setting attributes in libxml2 is mostly done by strings (xmlSetProp) and because I thought I didn't want to implement NamedNodeMap. 

Anyway, I thought that Adam's idea was reasonable, especially because if we did, and if we had a NamedNodeMap too, then we could get rid of the GLibHashTable that I was using to store GXml Attrs in, which ended up requiring ugly and error prone synchronisation between GXml and libxml2 every time you wanted to see what the XML document actually looked like (saving/stringification).  And because then Attr.vala would be a bit smaller (yay).

So, there's the newattr branch in git now.  Everything should behave the same except:
GXml.Node.attributes has changed type from a GLib.HashTable to a GXml.NamedAttrMap (which implements GXml.NamedNodeMap<Attr>).

Does anyone have any objections to this?  The consequence for users is that instead of getting GXml.Node.attributes and doing lookup (), size () and insert (), etc., on it, they'll use get_named_item (), length, and set_named_item (), which are the methods that the W3C DOM specifies anyway.  Let me know if you think convenience functions that mimic GLib.HashTable's common used ones would be a good idea (so a developer would just change the type, but not their calls, since we'd have a GXml.NamedNodeMap.lookup (), etc.)

There are a bunch of other API breaks from the summer, so I don't think another one will be the end of the world.

If there aren't any objections, let me know and I'll try to merge it next weekend.

_______________________________________________
gxml-list mailing list
gxml-list gnome org
https://mail.gnome.org/mailman/listinfo/gxml-list




[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]