2016-12-14 23:21:35 +03:00
|
|
|
/*
|
|
|
|
Copyright (C) 2016 Alexander Borisov
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with this library; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
Author: lex.borisov@gmail.com (Alexander Borisov)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include <myhtml/api.h>
|
|
|
|
|
2017-02-21 22:15:47 +03:00
|
|
|
#include "example.h"
|
|
|
|
|
2017-03-14 11:28:54 +03:00
|
|
|
mystatus_t serialization_callback(const char* data, size_t len, void* ctx)
|
2017-03-11 22:53:26 +03:00
|
|
|
{
|
|
|
|
printf("%.*s", (int)len, data);
|
2017-03-14 11:28:54 +03:00
|
|
|
return MyCORE_STATUS_OK;
|
2017-03-11 22:53:26 +03:00
|
|
|
}
|
|
|
|
|
2016-12-14 23:21:35 +03:00
|
|
|
int main(int argc, const char * argv[])
|
|
|
|
{
|
|
|
|
// basic init
|
|
|
|
myhtml_t* myhtml = myhtml_create();
|
|
|
|
myhtml_init(myhtml, MyHTML_OPTIONS_DEFAULT, 1, 0);
|
|
|
|
|
|
|
|
printf("Init tree\n");
|
|
|
|
|
|
|
|
// init tree
|
|
|
|
myhtml_tree_t* tree = myhtml_tree_create();
|
|
|
|
myhtml_tree_init(tree, myhtml);
|
|
|
|
|
2017-03-03 09:20:23 +03:00
|
|
|
myhtml_encoding_set(tree, MyENCODING_UTF_8);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
|
|
|
// create nodes
|
|
|
|
printf("Create DIV element\n");
|
|
|
|
myhtml_tree_node_t* base_node = myhtml_node_create(tree, MyHTML_TAG_DIV, MyHTML_NAMESPACE_HTML);
|
2017-02-14 14:49:05 +03:00
|
|
|
myhtml_node_insert_to_appropriate_place(myhtml_tree_get_document(tree), base_node);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
|
|
|
printf("Create and append to DIV element 100 000 P elements\n");
|
|
|
|
char tmp_buf_key[128];
|
|
|
|
char tmp_buf_value[128];
|
|
|
|
char tmp_buf_text[128];
|
|
|
|
|
|
|
|
for (size_t i = 1; i < 100001; i++) {
|
|
|
|
myhtml_tree_node_t* new_p_node = myhtml_node_create(tree, MyHTML_TAG_P, MyHTML_NAMESPACE_HTML);
|
2017-02-14 14:49:05 +03:00
|
|
|
myhtml_node_append_child(base_node, new_p_node);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
|
|
|
myhtml_tree_node_t* new_text_node = myhtml_node_create(tree, MyHTML_TAG__TEXT, MyHTML_NAMESPACE_HTML);
|
2017-02-14 14:49:05 +03:00
|
|
|
myhtml_node_append_child(new_p_node, new_text_node);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
2017-03-03 09:20:23 +03:00
|
|
|
sprintf(tmp_buf_key, "best_key_for_" MyCORE_FMT_Z, i);
|
|
|
|
sprintf(tmp_buf_value, "for best value " MyCORE_FMT_Z, i);
|
|
|
|
sprintf(tmp_buf_text, "Text! Entity &#" MyCORE_FMT_Z " = &#" MyCORE_FMT_Z, i, i);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
2017-03-03 09:20:23 +03:00
|
|
|
myhtml_node_text_set_with_charef(new_text_node, tmp_buf_text, strlen(tmp_buf_text), MyENCODING_UTF_8);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
2017-02-14 14:49:05 +03:00
|
|
|
myhtml_attribute_add(new_p_node, tmp_buf_key, strlen(tmp_buf_key),
|
2017-03-03 09:20:23 +03:00
|
|
|
tmp_buf_value, strlen(tmp_buf_value), MyENCODING_UTF_8);
|
2016-12-14 23:21:35 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// print
|
|
|
|
printf("Print result:\n");
|
2017-03-11 22:53:26 +03:00
|
|
|
myhtml_serialization_tree_callback(myhtml_tree_get_document(tree), serialization_callback, NULL);
|
2016-12-14 23:21:35 +03:00
|
|
|
|
|
|
|
// release resources
|
|
|
|
myhtml_tree_destroy(tree);
|
|
|
|
myhtml_destroy(myhtml);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|