X-Git-Url: http://git.nguyen.vg/gitweb/?a=blobdiff_plain;f=OCamlDriver.cpp;h=e1ddf83c8fcf97758a6538e68752ddd3eb112304;hb=eda0e1062076c3343ab0cfdc10e4d19d6e23c570;hp=723f9d9c64aa54a6112192f19e7dd188d7bdb332;hpb=9abf8a6f78264fbf4eec1676b4a26018967c97e6;p=SXSI%2Fxpathcomp.git diff --git a/OCamlDriver.cpp b/OCamlDriver.cpp index 723f9d9..e1ddf83 100644 --- a/OCamlDriver.cpp +++ b/OCamlDriver.cpp @@ -125,10 +125,32 @@ extern "C" CAMLprim value caml_cpp_traversal(value tree){ } extern "C" CAMLprim value caml_text_collection_get_text(value tree, value id){ - CAMLparam2(tree,id); - const char* txt = (const char*) (XMLTREE(tree)->GetText((DocID) Int_val(id))); - CAMLreturn (caml_copy_string(txt)); + CAMLparam2(tree,id); + CAMLlocal1(str); + uchar* txt = XMLTREE(tree)->GetText((DocID) Int_val(id)); + str = caml_copy_string((const char*)txt); + delete (txt); + CAMLreturn (str); +} + +extern "C" CAMLprim value caml_text_collection_get_cached_text(value tree, value id){ + CAMLparam2(tree,id); + CAMLlocal1(str); + char* txt = (char*) XMLTREE(tree)->GetCachedText((DocID) Int_val(id)); + str = caml_copy_string(txt); + free(txt); + CAMLreturn (str); } + +extern "C" CAMLprim value caml_text_collection_size(value tree){ + CAMLparam1(tree); + // CAMLreturn (Val_int( XMLTREE(tree)->CachedText.size())); + NOT_IMPLEMENTED("text_collection_size"); + CAMLreturn (Val_unit); +} + + + extern "C" CAMLprim value caml_text_collection_empty_text(value tree,value id){ CAMLparam2(tree,id); CAMLreturn ( Val_int((XMLTREE(tree))->EmptyText((DocID) Int_val(id)))); @@ -145,6 +167,13 @@ extern "C" CAMLprim value caml_text_collection_count_contains(value tree,value s uchar * cstr = (uchar *) String_val(str); CAMLreturn (Val_int((XMLTREE(tree)->CountContains(cstr)))); +} +extern "C" CAMLprim value caml_text_collection_count(value tree,value str){ + CAMLparam2(tree,str); + //uchar * cstr = (uchar *) String_val(str); + NOT_IMPLEMENTED("text_collection_count"); + CAMLreturn (Val_unit); + } extern "C" CAMLprim value caml_text_collection_contains(value tree,value str){ @@ -153,7 +182,7 @@ extern "C" CAMLprim value caml_text_collection_contains(value tree,value str){ uchar * cstr = (uchar *) String_val(str); std::vector results; results = XMLTREE(tree)->Contains(cstr); - + //free(cstr); resarray = caml_alloc_tuple(results.size()); for (unsigned int i=0; iParentNode(TREENODEVAL(id)))); + CAMLreturn(Val_int (XMLTREE(tree)->ParentNode((DocID) Int_val(id)))); } extern "C" CAMLprim value caml_xml_tree_is_ancestor(value tree,value id1, value id2) { @@ -208,11 +237,35 @@ extern "C" CAMLprim value caml_xml_tree_is_leaf(value tree, value id){ CAMLreturn(Val_bool (XMLTREE(tree)->IsLeaf(TREENODEVAL(id)))); } +extern "C" CAMLprim value caml_xml_tree_tagged_desc(value tree, value id, value tag){ + CAMLparam3(tree,id,tag); + CAMLreturn(Val_int (XMLTREE(tree)->TaggedDesc(TREENODEVAL(id),(TagType) Int_val(tag)))); +} + +extern "C" CAMLprim value caml_xml_tree_tagged_next(value tree, value id, value tag){ + CAMLparam3(tree,id,tag); + CAMLreturn(Val_int (XMLTREE(tree)->TaggedNext(TREENODEVAL(id),(TagType) Int_val(tag)))); +} + + + + +extern "C" CAMLprim value caml_xml_tree_tagged_foll(value tree, value id, value tag){ + CAMLparam3(tree,id,tag); + CAMLreturn(Val_int (XMLTREE(tree)->TaggedFoll(TREENODEVAL(id),(TagType) Int_val(tag)))); +} + + extern "C" CAMLprim value caml_xml_tree_next_sibling(value tree, value id){ CAMLparam2(tree,id); CAMLreturn(Val_int (XMLTREE(tree)->NextSibling(TREENODEVAL(id)))); } +extern "C" CAMLprim value caml_xml_tree_prev_sibling(value tree, value id){ + CAMLparam2(tree,id); + CAMLreturn(Val_int (XMLTREE(tree)->PrevSibling(TREENODEVAL(id)))); +} + extern "C" CAMLprim value caml_xml_tree_prev_text(value tree, value id){ CAMLparam2(tree,id); CAMLlocal1(res); @@ -236,20 +289,14 @@ extern "C" CAMLprim value caml_xml_tree_node_xml_id(value tree, value id){ CAMLparam2(tree,id); CAMLreturn(Val_int((XMLTREE(tree)->NodeXMLId(TREENODEVAL(id))))); } -extern "C" CAMLprim value caml_xml_tree_tag(value tree, value id){ - CAMLparam2(tree,id); - const char* tag; - tag =(const char*) XMLTREE(tree)->GetTagName(XMLTREE(tree)->Tag(TREENODEVAL(id))); - - CAMLreturn (caml_copy_string(tag)); -} extern "C" CAMLprim value caml_xml_tree_tag_name(value tree, value tagid){ CAMLparam2(tree,tagid); - const char* tag; - tag = (const char*) XMLTREE(tree)->GetTagName((TagType) (Int_val(tagid))); - - CAMLreturn (caml_copy_string(tag)); + CAMLlocal1(str); + char* tag; + tag = (char*) XMLTREE(tree)->GetTagNameByRef((TagType) (Int_val(tagid))); + str = caml_copy_string((const char*) tag); + CAMLreturn (str); } @@ -258,6 +305,12 @@ extern "C" CAMLprim value caml_xml_tree_tag_id(value tree,value id){ CAMLreturn (Val_int(XMLTREE(tree)->Tag(TREENODEVAL(id)))); } +extern "C" CAMLprim value caml_xml_tree_subtree_tags(value tree,value id,value tag){ + CAMLparam3(tree,id,tag); + CAMLreturn (Val_int(XMLTREE(tree)->SubtreeTags(TREENODEVAL(id),Int_val(tag)))); +} + + extern "C" CAMLprim value caml_xml_tree_register_tag(value tree,value str){ CAMLparam2(tree,str); CAMLlocal1(id);