1
0
mirror of https://github.com/rkd77/elinks.git synced 2024-12-04 14:46:47 -05:00

Make the DOM node creators take dom_string structs

This commit is contained in:
Jonas Fonseca 2005-12-28 16:47:28 +01:00 committed by Jonas Fonseca
parent ec7b293e4e
commit 1bd0c8758e
3 changed files with 26 additions and 27 deletions

View File

@ -247,7 +247,7 @@ get_dom_node_list_index(struct dom_node *parent, struct dom_node *node)
struct dom_node * struct dom_node *
init_dom_node_(unsigned char *file, int line, init_dom_node_(unsigned char *file, int line,
struct dom_node *parent, enum dom_node_type type, struct dom_node *parent, enum dom_node_type type,
unsigned char *string, size_t length) struct dom_string *string)
{ {
#ifdef DEBUG_MEMLEAK #ifdef DEBUG_MEMLEAK
struct dom_node *node = debug_mem_calloc(file, line, 1, sizeof(*node)); struct dom_node *node = debug_mem_calloc(file, line, 1, sizeof(*node));
@ -259,7 +259,7 @@ init_dom_node_(unsigned char *file, int line,
node->type = type; node->type = type;
node->parent = parent; node->parent = parent;
set_dom_string(&node->string, string, length); copy_dom_string(&node->string, string);
if (parent) { if (parent) {
struct dom_node_list **list = get_dom_node_list(parent, node); struct dom_node_list **list = get_dom_node_list(parent, node);

View File

@ -255,34 +255,34 @@ get_dom_node_map_entry(struct dom_node_list *node_map,
struct dom_node * struct dom_node *
init_dom_node_(unsigned char *file, int line, init_dom_node_(unsigned char *file, int line,
struct dom_node *parent, enum dom_node_type type, struct dom_node *parent, enum dom_node_type type,
unsigned char *string, size_t length); struct dom_string *string);
#define init_dom_node(type, string, length) init_dom_node_(__FILE__, __LINE__, NULL, type, string, length) #define init_dom_node(type, string) init_dom_node_(__FILE__, __LINE__, NULL, type, string)
#define add_dom_node(parent, type, string, length) init_dom_node_(__FILE__, __LINE__, parent, type, string, length) #define add_dom_node(parent, type, string) init_dom_node_(__FILE__, __LINE__, parent, type, string)
#define add_dom_element(parent, string, length) \ #define add_dom_element(parent, string) \
add_dom_node(parent, DOM_NODE_ELEMENT, string, length) add_dom_node(parent, DOM_NODE_ELEMENT, string)
static inline struct dom_node * static inline struct dom_node *
add_dom_attribute(struct dom_node *parent, unsigned char *string, int length, add_dom_attribute(struct dom_node *parent, struct dom_string *name,
unsigned char *value, size_t valuelen) struct dom_string *value)
{ {
struct dom_node *node = add_dom_node(parent, DOM_NODE_ATTRIBUTE, string, length); struct dom_node *node = add_dom_node(parent, DOM_NODE_ATTRIBUTE, name);
if (node && value) { if (node && value) {
set_dom_string(&node->data.attribute.value, value, valuelen); copy_dom_string(&node->data.attribute.value, value);
} }
return node; return node;
} }
static inline struct dom_node * static inline struct dom_node *
add_dom_proc_instruction(struct dom_node *parent, unsigned char *string, int length, add_dom_proc_instruction(struct dom_node *parent, struct dom_string *string,
unsigned char *instruction, size_t instructionlen) struct dom_string *instruction)
{ {
struct dom_node *node = add_dom_node(parent, DOM_NODE_PROCESSING_INSTRUCTION, string, length); struct dom_node *node = add_dom_node(parent, DOM_NODE_PROCESSING_INSTRUCTION, string);
if (node && instruction) { if (node && instruction) {
set_dom_string(&node->data.proc_instruction.instruction, instruction, instructionlen); copy_dom_string(&node->data.proc_instruction.instruction, instruction);
} }
return node; return node;

View File

@ -41,7 +41,7 @@ init_sgml_parsing_state(struct sgml_parser *parser, struct dom_string *buffer);
static inline struct dom_node * static inline struct dom_node *
add_sgml_document(struct dom_stack *stack, struct dom_string *string) add_sgml_document(struct dom_stack *stack, struct dom_string *string)
{ {
struct dom_node *node = init_dom_node(DOM_NODE_DOCUMENT, string->string, string->length); struct dom_node *node = init_dom_node(DOM_NODE_DOCUMENT, string);
return node ? push_dom_node(stack, node) : NULL; return node ? push_dom_node(stack, node) : NULL;
} }
@ -56,7 +56,7 @@ add_sgml_element(struct dom_stack *stack, struct dom_scanner_token *token)
struct dom_node *node; struct dom_node *node;
struct sgml_node_info *node_info; struct sgml_node_info *node_info;
node = add_dom_element(parent, token->string.string, token->string.length); node = add_dom_element(parent, &token->string);
if (!node) return NULL; if (!node) return NULL;
node_info = get_sgml_node_info(parser->info->elements, node); node_info = get_sgml_node_info(parser->info->elements, node);
@ -81,13 +81,11 @@ add_sgml_attribute(struct dom_stack *stack,
{ {
struct sgml_parser *parser = get_sgml_parser(stack); struct sgml_parser *parser = get_sgml_parser(stack);
struct dom_node *parent = get_dom_stack_top(stack)->node; struct dom_node *parent = get_dom_stack_top(stack)->node;
unsigned char *value = valtoken ? valtoken->string.string : NULL; struct dom_string *value = valtoken ? &valtoken->string : NULL;
size_t valuelen = valtoken ? valtoken->string.length : 0;
struct sgml_node_info *info; struct sgml_node_info *info;
struct dom_node *node; struct dom_node *node;
node = add_dom_attribute(parent, token->string.string, token->string.length, node = add_dom_attribute(parent, &token->string, value);
value, valuelen);
info = get_sgml_node_info(parser->info->attributes, node); info = get_sgml_node_info(parser->info->attributes, node);
@ -113,14 +111,15 @@ add_sgml_proc_instruction(struct dom_stack *stack, struct dom_scanner_token *tok
unsigned char *separator = memchr(token->string.string, ' ', token->string.length); unsigned char *separator = memchr(token->string.string, ' ', token->string.length);
/* Anything before the separator becomes the target name ... */ /* Anything before the separator becomes the target name ... */
unsigned char *name = token->string.string;
size_t namelen = separator ? separator - token->string.string : token->string.length; size_t namelen = separator ? separator - token->string.string : token->string.length;
struct dom_string name = INIT_DOM_STRING(token->string.string, namelen);
/* ... and everything after the instruction value. */ /* ... and everything after the instruction value. */
unsigned char *value = separator ? separator + 1 : NULL; unsigned char *valuestr = separator ? separator + 1 : NULL;
size_t valuelen = value ? token->string.length - namelen - 1 : 0; size_t valuelen = valuestr ? token->string.length - namelen - 1 : 0;
struct dom_string value = INIT_DOM_STRING(valuestr, valuelen);
node = add_dom_proc_instruction(parent, name, namelen, value, valuelen); node = add_dom_proc_instruction(parent, &name, &value);
if (!node) return NULL; if (!node) return NULL;
switch (token->type) { switch (token->type) {
@ -146,7 +145,7 @@ static inline void
add_sgml_node(struct dom_stack *stack, enum dom_node_type type, struct dom_scanner_token *token) add_sgml_node(struct dom_stack *stack, enum dom_node_type type, struct dom_scanner_token *token)
{ {
struct dom_node *parent = get_dom_stack_top(stack)->node; struct dom_node *parent = get_dom_stack_top(stack)->node;
struct dom_node *node = add_dom_node(parent, type, token->string.string, token->string.length); struct dom_node *node = add_dom_node(parent, type, &token->string);
if (!node) return; if (!node) return;
@ -421,7 +420,7 @@ init_sgml_parsing_state(struct sgml_parser *parser, struct dom_string *buffer)
struct dom_stack_state *state; struct dom_stack_state *state;
struct dom_node *node; struct dom_node *node;
node = init_dom_node(DOM_NODE_TEXT, buffer->string, buffer->length); node = init_dom_node(DOM_NODE_TEXT, buffer);
if (!node || !push_dom_node(&parser->parsing, node)) if (!node || !push_dom_node(&parser->parsing, node))
return NULL; return NULL;