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