1 #include <unordered_set>
2 #include "xml-tree.hpp"
3 #include "common_stub.hpp"
8 static xml_tree*& XMLTREE(value v)
10 return Obj_val<xml_tree*>(v);
13 static xml_tree::node_t TREENODE(value i)
15 return static_cast<xml_tree::node_t>(Int_val(i));
18 static xml_tree::tag_t TAG(value i)
20 return static_cast<xml_tree::tag_t>(Int_val(i));
23 static std::unordered_set<xml_tree::tag_t>*& HSET(value x)
25 return Obj_val<std::unordered_set<xml_tree::tag_t>*>(x);
29 NoAlloc extern "C" value caml_unordered_set_length(value hset)
31 return (Val_int((HSET(hset))->size()));
34 extern "C" value caml_unordered_set_alloc(value unit)
38 hset = sxsi_alloc_custom<std::unordered_set<xml_tree::tag_t>*>();
39 HSET(hset) = new std::unordered_set<xml_tree::tag_t>();
43 NoAlloc extern "C" value caml_unordered_set_set(value set, value v)
45 HSET(set)->insert(TAG(v));
49 extern "C" value caml_xml_tree_save(value tree, value fd, value prefix)
51 CAMLparam3(tree, fd, prefix);
52 XMLTREE(tree)->save(Int_val(fd), String_val(prefix));
53 CAMLreturn (Val_unit);
57 caml_xml_tree_load(value fd, value prefix, value load_tc, value sf)
59 CAMLparam4(fd, prefix, load_tc, sf);
64 tree = xml_tree::load(Int_val(fd),
69 result = sxsi_alloc_custom<xml_tree*>();
70 XMLTREE(result) = tree;
73 catch (const std::exception& e){ sxsi_raise_msg(e.what()); }
74 catch (std::string msg){ sxsi_raise_msg(msg.c_str()); }
75 catch (char const * msg){ sxsi_raise_msg(msg); };
80 NoAlloc extern "C" value caml_xml_tree_root(value tree)
82 return (Val_int(XMLTREE(tree)->root()));
85 NoAlloc extern "C" value caml_xml_tree_size(value tree)
87 return (Val_int(XMLTREE(tree)->size()));
90 NoAlloc extern "C" value caml_xml_tree_num_tags(value tree)
92 return (Val_int(XMLTREE(tree)->num_tags()));
95 NoAlloc extern "C" value caml_xml_tree_subtree_size(value tree, value node)
97 return (Val_int(XMLTREE(tree)->subtree_size(TREENODE(node))));
100 NoAlloc extern "C" value
101 caml_xml_tree_subtree_tags(value tree, value node, value tag)
103 return (Val_int(XMLTREE(tree)->subtree_tags(TREENODE(node),
107 NoAlloc extern "C" value caml_xml_tree_subtree_elements(value tree, value node)
109 return (Val_int(XMLTREE(tree)->subtree_elements(TREENODE(node))));
112 NoAlloc extern "C" value caml_xml_tree_is_leaf(value tree, value node){
113 return (Val_bool(XMLTREE(tree)->is_leaf(TREENODE(node))));
116 NoAlloc extern "C" value
117 caml_xml_tree_is_ancestor(value tree, value node1, value node2)
119 return (Val_bool(XMLTREE(tree)->is_ancestor(TREENODE(node1),
123 NoAlloc extern "C" value
124 caml_xml_tree_is_child(value tree, value node1, value node2)
126 return (Val_bool(XMLTREE(tree)->is_child(TREENODE(node1),
130 NoAlloc extern "C" value caml_xml_tree_is_first_child(value tree, value node)
132 return (Val_bool(XMLTREE(tree)->is_first_child(TREENODE(node))));
135 NoAlloc extern "C" value
136 caml_xml_tree_is_right_descendant(value tree, value x, value y)
138 return (Val_bool(XMLTREE(tree)->is_right_descendant(TREENODE(x),
142 NoAlloc extern "C" value caml_xml_tree_num_children(value tree, value node)
144 return (Val_int(XMLTREE(tree)->num_children(TREENODE(node))));
147 NoAlloc extern "C" value caml_xml_tree_child_pos(value tree, value node)
149 return (Val_int(XMLTREE(tree)->child_pos(TREENODE(node))));
152 NoAlloc extern "C" value caml_xml_tree_depth(value tree, value node)
154 return (Val_int(XMLTREE(tree)->depth(TREENODE(node))));
157 NoAlloc extern "C" value caml_xml_tree_preorder(value tree, value node)
159 return (Val_int(XMLTREE(tree)->preorder(TREENODE(node))));
162 NoAlloc extern "C" value caml_xml_tree_postorder(value tree, value node)
164 return (Val_int(XMLTREE(tree)->postorder(TREENODE(node))));
167 NoAlloc extern "C" value caml_xml_tree_tag(value tree, value node)
169 return (Val_int(XMLTREE(tree)->tag(TREENODE(node))));
172 NoAlloc extern "C" value caml_xml_tree_parent(value tree, value node)
174 return (Val_int(XMLTREE(tree)->parent(TREENODE(node))));
177 NoAlloc extern "C" value caml_xml_tree_child(value tree, value node, value idx)
179 return (Val_int(XMLTREE(tree)->child(TREENODE(node), Int_val(idx))));
182 NoAlloc extern "C" value caml_xml_tree_first_child(value tree, value node)
184 return (Val_int(XMLTREE(tree)->first_child(TREENODE(node))));
187 NoAlloc extern "C" value caml_xml_tree_first_element(value tree, value node)
189 return (Val_int(XMLTREE(tree)->first_element(TREENODE(node))));
192 NoAlloc extern "C" value caml_xml_tree_last_child(value tree, value node)
194 return (Val_int(XMLTREE(tree)->last_child(TREENODE(node))));
197 NoAlloc extern "C" value caml_xml_tree_next_sibling(value tree, value node)
199 return (Val_int(XMLTREE(tree)->next_sibling(TREENODE(node))));
202 NoAlloc extern "C" value caml_xml_tree_next_element(value tree, value node)
204 return (Val_int(XMLTREE(tree)->next_element(TREENODE(node))));
207 NoAlloc extern "C" value caml_xml_tree_prev_sibling(value tree, value node)
209 return (Val_int(XMLTREE(tree)->prev_sibling(TREENODE(node))));
212 NoAlloc extern "C" value
213 caml_xml_tree_tagged_child(value tree, value node, value tag)
215 return (Val_int(XMLTREE(tree)->tagged_child(TREENODE(node),
219 NoAlloc extern "C" value
220 caml_xml_tree_select_child(value tree, value node, value tags)
222 return (Val_int(XMLTREE(tree)->select_child(TREENODE(node), HSET(tags))));
225 NoAlloc extern "C" value
226 caml_xml_tree_tagged_sibling(value tree, value node, value tag)
228 return (Val_int(XMLTREE(tree)->tagged_sibling(TREENODE(node),
232 NoAlloc extern "C" value
233 caml_xml_tree_select_sibling(value tree, value node, value tags)
235 return (Val_int(XMLTREE(tree)->select_sibling(TREENODE(node),
239 NoAlloc extern "C" value
240 caml_xml_tree_tagged_descendant(value tree, value node, value tag)
242 return (Val_int(XMLTREE(tree)->tagged_descendant(TREENODE(node),
246 NoAlloc extern "C" value
247 caml_xml_tree_tagged_next(value tree, value node, value tag)
249 return (Val_int(XMLTREE(tree)->tagged_next(TREENODE(node),
253 NoAlloc extern "C" value
254 caml_xml_tree_select_descendant(value tree, value node, value tags)
256 return (Val_int(XMLTREE(tree)->select_descendant(TREENODE(node),
260 NoAlloc extern "C" value caml_xml_tree_tagged_following_before(value tree,
265 return (Val_int(XMLTREE(tree)->tagged_following_before(TREENODE(node),
267 TREENODE(closing))));
270 NoAlloc extern "C" value caml_xml_tree_select_following_before(value tree,
275 return (Val_int(XMLTREE(tree)->select_following_before(TREENODE(node),
277 TREENODE(closing))));
282 extern "C" value caml_xml_tree_get_text_collection(value tree)
286 text = sxsi_alloc_custom<TextCollection*>();
287 Obj_val<TextCollection*>(text) = XMLTREE(tree)->get_text_collection();
291 NoAlloc extern "C" value caml_xml_tree_closing(value tree, value node)
293 return (Val_int(XMLTREE(tree)->closing(TREENODE(node))));
296 NoAlloc extern "C" value caml_xml_tree_nullt(value unit){
297 return (Val_int(xml_tree::NIL));
301 extern "C" value caml_xml_tree_print(value tree, value node, value fd)
303 CAMLparam3(tree, node, fd);
304 XMLTREE(tree)->print(TREENODE(node), Int_val(fd));
305 CAMLreturn(Val_unit);
309 extern "C" value caml_xml_tree_get_tag_name(value tree, value tag)
311 CAMLparam2(tree, tag);
313 const char* s = XMLTREE(tree)->get_tag_name_by_ref(TAG(tag));
314 res = caml_copy_string(s);
318 NoAlloc extern "C" value caml_xml_tree_flush(value tree, value fd)
320 XMLTREE(tree)->flush(Int_val(fd));
324 extern "C" value caml_xml_tree_register_tag(value tree, value str)
326 CAMLparam2(tree, str);
328 res = Val_int(XMLTREE(tree)->register_tag(String_val(str)));
333 /** Full reporting into a bit vector
335 static std::vector<int32_t> sort_results(std::vector<int32_t> v)
337 std::vector<int32_t> res;
338 std::sort(v.begin(), v.end());
340 for(auto i = v.begin(); i != v.end(); ++i){
343 if (i == v.end()) return res;
351 #define BV_QUERY(pref, Pref) \
352 extern "C" value caml_text_collection_## pref ##_bv(value tree, value str, value dobvv){ \
353 CAMLparam3(tree, str, dobvv); \
354 CAMLlocal3(res, res_bv, res_array); \
356 uchar * cstr = (uchar *) strdup(String_val(str)); \
357 std::vector<int32_t> uresults = XMLTREE(tree)->Pref(cstr); \
358 std::vector<int32_t> results = sort_results(uresults); \
359 bool dobv = Bool_val(dobvv); \
360 res_bv = caml_alloc_string(dobv ? ((XMLTREE(tree)->size() / 4) + 2) : 0); \
361 unsigned long slen = caml_string_length(res_bv); \
363 memset(&(Byte(res_bv,0)), 0, slen); \
364 res_array = caml_alloc_shr(results.size(), 0); \
365 for (unsigned int i = 0; i < results.size(); ++i) { \
366 j = XMLTREE(tree)->parent_node(results[i]); \
368 Byte(res_bv, j >> 3) |= (1 << (j & 7)); \
370 caml_initialize(&Field(res_array, i), Val_int(j)); \
373 res = caml_alloc(2, 0); \
374 Store_field(res, 0, res_bv); \
375 Store_field(res, 1, res_array); \
380 BV_QUERY(prefix, prefix)
381 BV_QUERY(suffix, suffix)
382 BV_QUERY(equals, equals)
383 BV_QUERY(contains, contains)
384 BV_QUERY(lessthan, less_than)