mirror of
https://github.com/rkd77/elinks.git
synced 2025-01-03 14:57:44 -05:00
DOM: Cleanup the unused parts of the node interface
Take a quick stroll through the unchartered corners of the DOM node data structures: - Remove ununsed struct dom_node_id_item. - Make the document node reference a future struct dom_document. - Describe ideas for node data, e.g. the entity reference node should use it for storing the unicode_val_T.
This commit is contained in:
parent
8448472dcc
commit
4a27637529
@ -399,12 +399,6 @@ done_dom_node_data(struct dom_node *node)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case DOM_NODE_DOCUMENT:
|
case DOM_NODE_DOCUMENT:
|
||||||
if (data->document.element_ids)
|
|
||||||
free_hash(data->document.element_ids);
|
|
||||||
|
|
||||||
if (data->document.meta_nodes)
|
|
||||||
done_dom_node_list(data->document.meta_nodes);
|
|
||||||
|
|
||||||
if (data->document.children)
|
if (data->document.children)
|
||||||
done_dom_node_list(data->document.children);
|
done_dom_node_list(data->document.children);
|
||||||
break;
|
break;
|
||||||
@ -444,7 +438,6 @@ done_dom_node(struct dom_node *node)
|
|||||||
|
|
||||||
switch (parent->type) {
|
switch (parent->type) {
|
||||||
case DOM_NODE_DOCUMENT:
|
case DOM_NODE_DOCUMENT:
|
||||||
del_from_dom_node_list(data->document.meta_nodes, node);
|
|
||||||
del_from_dom_node_list(data->document.children, node);
|
del_from_dom_node_list(data->document.children, node);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -3,9 +3,9 @@
|
|||||||
#define EL_DOM_NODE_H
|
#define EL_DOM_NODE_H
|
||||||
|
|
||||||
#include "dom/string.h"
|
#include "dom/string.h"
|
||||||
#include "util/hash.h"
|
|
||||||
|
|
||||||
struct dom_node_list;
|
struct dom_node_list;
|
||||||
|
struct dom_document;
|
||||||
|
|
||||||
enum dom_node_type {
|
enum dom_node_type {
|
||||||
DOM_NODE_UNKNOWN = 0, /* for internal purpose only */
|
DOM_NODE_UNKNOWN = 0, /* for internal purpose only */
|
||||||
@ -27,27 +27,15 @@ enum dom_node_type {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Following is the node specific datastructures. They may contain no more
|
/* Following is the node specific datastructures. They may contain no more
|
||||||
* than 3 pointers or something equivalent. */
|
* than 4 pointers or something equivalent. */
|
||||||
|
|
||||||
struct dom_node_id_item {
|
|
||||||
/* The attibute node containing the id value */
|
|
||||||
struct dom_node *id_attribute;
|
|
||||||
|
|
||||||
/* The node with the @id attribute */
|
|
||||||
struct dom_node *node;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct dom_document_node {
|
|
||||||
/* The document URI is stored in the string / length members. */
|
/* The document URI is stored in the string / length members. */
|
||||||
/* An id to node hash for fast lookup. */
|
struct dom_document_node {
|
||||||
struct hash *element_ids; /* -> {struct dom_node_id_item} */
|
/* The document. */
|
||||||
|
struct dom_document *document;
|
||||||
/* Any meta data the root node carries such as document type nodes,
|
|
||||||
* entity and notation map nodes and maybe some internal CSS stylesheet
|
|
||||||
* node. */
|
|
||||||
struct dom_node_list *meta_nodes;
|
|
||||||
|
|
||||||
/* The child nodes. May be NULL. Ordered like they where inserted. */
|
/* The child nodes. May be NULL. Ordered like they where inserted. */
|
||||||
|
/* FIXME: Should be just one element (root) node reference. */
|
||||||
struct dom_node_list *children;
|
struct dom_node_list *children;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -176,12 +164,13 @@ union dom_node_data {
|
|||||||
struct dom_id entity;
|
struct dom_id entity;
|
||||||
struct dom_proc_instruction_node proc_instruction;
|
struct dom_proc_instruction_node proc_instruction;
|
||||||
|
|
||||||
/* Node types without a union member yet
|
/* Node types without a union member yet (mostly because it hasn't
|
||||||
|
* been necessary):
|
||||||
*
|
*
|
||||||
* DOM_NODE_CDATA_SECTION,
|
* DOM_NODE_CDATA_SECTION: Use dom_text_node?
|
||||||
* DOM_NODE_COMMENT,
|
* DOM_NODE_DOCUMENT_FRAGMENT: struct dom_node_list children;
|
||||||
* DOM_NODE_DOCUMENT_FRAGMENT,
|
* DOM_NODE_ENTITY_REFERENCE: unicode_val_T
|
||||||
* DOM_NODE_ENTITY_REFERENCE,
|
* DOM_NODE_COMMENT
|
||||||
*/
|
*/
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user