mirror of
https://gitlab.xiph.org/xiph/icecast-server.git
synced 2025-02-02 15:07:36 -05:00
Feature: Added super basic logic for namespace based render selecting
This commit is contained in:
parent
b44df0da76
commit
c7be3122db
@ -14,13 +14,22 @@
|
|||||||
#include <config.h>
|
#include <config.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
#include "xml2json.h"
|
#include "xml2json.h"
|
||||||
#include "json.h"
|
#include "json.h"
|
||||||
|
|
||||||
#include "logging.h"
|
#include "logging.h"
|
||||||
#define CATMODULE "xml2json"
|
#define CATMODULE "xml2json"
|
||||||
|
|
||||||
static void render_node(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr node, xmlNodePtr parent)
|
struct xml2json_cache {
|
||||||
|
xmlNsPtr ns;
|
||||||
|
void (*render)(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr node, xmlNodePtr parent, struct xml2json_cache *cache);
|
||||||
|
};
|
||||||
|
|
||||||
|
static void render_node(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr node, xmlNodePtr parent, struct xml2json_cache *cache);
|
||||||
|
|
||||||
|
static void render_node_generic(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr node, xmlNodePtr parent, struct xml2json_cache *cache)
|
||||||
{
|
{
|
||||||
json_renderer_begin(renderer, JSON_ELEMENT_TYPE_OBJECT);
|
json_renderer_begin(renderer, JSON_ELEMENT_TYPE_OBJECT);
|
||||||
|
|
||||||
@ -82,7 +91,7 @@ static void render_node(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr nod
|
|||||||
json_renderer_write_key(renderer, "children", JSON_RENDERER_FLAGS_NONE);
|
json_renderer_write_key(renderer, "children", JSON_RENDERER_FLAGS_NONE);
|
||||||
json_renderer_begin(renderer, JSON_ELEMENT_TYPE_ARRAY);
|
json_renderer_begin(renderer, JSON_ELEMENT_TYPE_ARRAY);
|
||||||
do {
|
do {
|
||||||
render_node(renderer, doc, cur, node);
|
render_node(renderer, doc, cur, node, cache);
|
||||||
cur = cur->next;
|
cur = cur->next;
|
||||||
} while (cur);
|
} while (cur);
|
||||||
json_renderer_end(renderer);
|
json_renderer_end(renderer);
|
||||||
@ -91,8 +100,33 @@ static void render_node(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr nod
|
|||||||
json_renderer_end(renderer);
|
json_renderer_end(renderer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void render_node(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr node, xmlNodePtr parent, struct xml2json_cache *cache)
|
||||||
|
{
|
||||||
|
void (*render)(json_renderer_t *renderer, xmlDocPtr doc, xmlNodePtr node, xmlNodePtr parent, struct xml2json_cache *cache) = NULL;
|
||||||
|
|
||||||
|
if (node->ns == cache->ns)
|
||||||
|
render = cache->render;
|
||||||
|
|
||||||
|
if (render == NULL) {
|
||||||
|
if (node->ns) {
|
||||||
|
render = render_node_generic;
|
||||||
|
|
||||||
|
cache->ns = node->ns;
|
||||||
|
cache->render = render;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If nothing found, use generic render.
|
||||||
|
if (render == NULL)
|
||||||
|
render = render_node_generic;
|
||||||
|
|
||||||
|
render(renderer, doc, node, parent, cache);
|
||||||
|
}
|
||||||
|
|
||||||
char * xml2json_render_doc_simple(xmlDocPtr doc)
|
char * xml2json_render_doc_simple(xmlDocPtr doc)
|
||||||
{
|
{
|
||||||
|
struct xml2json_cache cache;
|
||||||
json_renderer_t *renderer;
|
json_renderer_t *renderer;
|
||||||
xmlNodePtr xmlroot;
|
xmlNodePtr xmlroot;
|
||||||
|
|
||||||
@ -107,7 +141,9 @@ char * xml2json_render_doc_simple(xmlDocPtr doc)
|
|||||||
if (!xmlroot)
|
if (!xmlroot)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
render_node(renderer, doc, xmlroot, NULL);
|
memset(&cache, 0, sizeof(cache));
|
||||||
|
|
||||||
|
render_node(renderer, doc, xmlroot, NULL, &cache);
|
||||||
|
|
||||||
return json_renderer_finish(&renderer);
|
return json_renderer_finish(&renderer);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user