+void traversal_rec(XMLTree* tree, treeNode id){
+ DocID tid;
+ if (id == NULLT)
+ return;
+ // int tag = tree->Tag(id);
+ if (id) {
+ tid = tree->PrevText(id);
+ char * data = (char *) (tree->getTextCollection())->GetText(tid);
+ if (tree->IsLeaf(id)){
+ tid = tree->MyText(id);
+
+ data = (char*) (tree->getTextCollection())->GetText(tid);
+ };
+
+ if (tree->NextSibling(id) == NULLT){
+ tid = tree->NextText(id);
+ data = (char*) (tree->getTextCollection())->GetText(tid);
+ };
+ };
+ traversal_rec(tree,tree->FirstChild(id));
+ traversal_rec(tree,tree->NextSibling(id));
+ return;
+}
+
+extern "C" CAMLprim value caml_cpp_traversal(value tree){
+ CAMLparam1(tree);
+ traversal_rec(XMLTREE(tree),XMLTREE(tree)->Root());
+ CAMLreturn(Val_unit);
+}
+