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

Use dom_stack_code enum for dom_stack_callback_T

This commit is contained in:
Jonas Fonseca 2006-01-16 00:55:58 +01:00 committed by Jonas Fonseca
parent 4a2cde1c00
commit eecc22751d
5 changed files with 64 additions and 27 deletions

View File

@ -500,7 +500,7 @@ render_dom_node_enhanced_text(struct dom_renderer *renderer, struct dom_node *no
} }
#endif #endif
static void enum dom_stack_code
render_dom_node_source(struct dom_stack *stack, struct dom_node *node, void *data) render_dom_node_source(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -513,15 +513,15 @@ render_dom_node_source(struct dom_stack *stack, struct dom_node *node, void *dat
|| node->type == DOM_NODE_CDATA_SECTION || node->type == DOM_NODE_CDATA_SECTION
|| node->type == DOM_NODE_COMMENT)) { || node->type == DOM_NODE_COMMENT)) {
render_dom_node_enhanced_text(renderer, node); render_dom_node_enhanced_text(renderer, node);
return; } else
}
#endif #endif
render_dom_node_text(renderer, &renderer->styles[node->type], node);
render_dom_node_text(renderer, &renderer->styles[node->type], node); return DOM_STACK_CODE_OK;
} }
/* This callback is also used for rendering processing instruction nodes. */ /* This callback is also used for rendering processing instruction nodes. */
static void static enum dom_stack_code
render_dom_element_source(struct dom_stack *stack, struct dom_node *node, void *data) render_dom_element_source(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -529,9 +529,11 @@ render_dom_element_source(struct dom_stack *stack, struct dom_node *node, void *
assert(node && renderer && renderer->document); assert(node && renderer && renderer->document);
render_dom_node_text(renderer, &renderer->styles[node->type], node); render_dom_node_text(renderer, &renderer->styles[node->type], node);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
render_dom_element_end_source(struct dom_stack *stack, struct dom_node *node, void *data) render_dom_element_end_source(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -544,7 +546,7 @@ render_dom_element_end_source(struct dom_stack *stack, struct dom_node *node, vo
assert(node && renderer && renderer->document); assert(node && renderer && renderer->document);
if (!string || !length) if (!string || !length)
return; return DOM_STACK_CODE_OK;
if (check_dom_node_source(renderer, string, length)) { if (check_dom_node_source(renderer, string, length)) {
render_dom_flush(renderer, string); render_dom_flush(renderer, string);
@ -553,9 +555,11 @@ render_dom_element_end_source(struct dom_stack *stack, struct dom_node *node, vo
} }
render_dom_text(renderer, &renderer->styles[node->type], string, length); render_dom_text(renderer, &renderer->styles[node->type], string, length);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
render_dom_attribute_source(struct dom_stack *stack, struct dom_node *node, void *data) render_dom_attribute_source(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -620,9 +624,11 @@ render_dom_attribute_source(struct dom_stack *stack, struct dom_node *node, void
render_dom_text(renderer, template, value, valuelen); render_dom_text(renderer, template, value, valuelen);
} }
} }
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
render_dom_cdata_source(struct dom_stack *stack, struct dom_node *node, void *data) render_dom_cdata_source(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -639,9 +645,11 @@ render_dom_cdata_source(struct dom_stack *stack, struct dom_node *node, void *da
} }
render_dom_node_text(renderer, &renderer->styles[node->type], node); render_dom_node_text(renderer, &renderer->styles[node->type], node);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
render_dom_document_end(struct dom_stack *stack, struct dom_node *node, void *data) render_dom_document_end(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -652,6 +660,8 @@ render_dom_document_end(struct dom_stack *stack, struct dom_node *node, void *da
if (check_dom_node_source(renderer, renderer->position, 0)) { if (check_dom_node_source(renderer, renderer->position, 0)) {
render_dom_flush(renderer, renderer->end); render_dom_flush(renderer, renderer->end);
} }
return DOM_STACK_CODE_OK;
} }
static struct dom_stack_context_info dom_source_renderer_context_info = { static struct dom_stack_context_info dom_source_renderer_context_info = {
@ -693,7 +703,7 @@ static struct dom_stack_context_info dom_source_renderer_context_info = {
/* DOM RSS Renderer */ /* DOM RSS Renderer */
static void enum dom_stack_code
dom_rss_push_element(struct dom_stack *stack, struct dom_node *node, void *data) dom_rss_push_element(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -735,9 +745,11 @@ dom_rss_push_element(struct dom_stack *stack, struct dom_node *node, void *data)
renderer->node = node; renderer->node = node;
} }
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
dom_rss_pop_element(struct dom_stack *stack, struct dom_node *node, void *data) dom_rss_pop_element(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -776,9 +788,11 @@ dom_rss_pop_element(struct dom_stack *stack, struct dom_node *node, void *data)
default: default:
break; break;
} }
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
dom_rss_push_content(struct dom_stack *stack, struct dom_node *node, void *data) dom_rss_push_content(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
@ -788,7 +802,7 @@ dom_rss_push_content(struct dom_stack *stack, struct dom_node *node, void *data)
assert(node && renderer && renderer->document); assert(node && renderer && renderer->document);
if (!renderer->node) if (!renderer->node)
return; return DOM_STACK_CODE_OK;
if (node->type == DOM_NODE_ENTITY_REFERENCE) { if (node->type == DOM_NODE_ENTITY_REFERENCE) {
string -= 1; string -= 1;
@ -800,6 +814,8 @@ dom_rss_push_content(struct dom_stack *stack, struct dom_node *node, void *data)
} else { } else {
add_to_dom_string(&renderer->text, string, length); add_to_dom_string(&renderer->text, string, length);
} }
return DOM_STACK_CODE_OK;
} }
static struct dom_string * static struct dom_string *
@ -901,13 +917,13 @@ render_rss_item(struct dom_renderer *renderer, struct dom_node *item)
} }
} }
static void enum dom_stack_code
dom_rss_pop_document(struct dom_stack *stack, struct dom_node *root, void *data) dom_rss_pop_document(struct dom_stack *stack, struct dom_node *root, void *data)
{ {
struct dom_renderer *renderer = stack->current->data; struct dom_renderer *renderer = stack->current->data;
if (!renderer->channel) if (!renderer->channel)
return; return DOM_STACK_CODE_OK;
render_rss_item(renderer, renderer->channel); render_rss_item(renderer, renderer->channel);
@ -927,6 +943,8 @@ dom_rss_pop_document(struct dom_stack *stack, struct dom_node *root, void *data)
mem_free_if(renderer->items); mem_free_if(renderer->items);
done_dom_node(root); done_dom_node(root);
return DOM_STACK_CODE_OK;
} }

View File

@ -897,7 +897,7 @@ match_element_selector(struct dom_select_node *selector, struct dom_node *node,
#define get_dom_select_data(stack) ((stack)->current->data) #define get_dom_select_data(stack) ((stack)->current->data)
/* Matches an element node being visited against the current selector stack. */ /* Matches an element node being visited against the current selector stack. */
static void enum dom_stack_code
dom_select_push_element(struct dom_stack *stack, struct dom_node *node, void *data) dom_select_push_element(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_select_data *select_data = get_dom_select_data(stack); struct dom_select_data *select_data = get_dom_select_data(stack);
@ -921,11 +921,13 @@ dom_select_push_element(struct dom_stack *stack, struct dom_node *node, void *da
if (selector) if (selector)
push_dom_node(&select_data->stack, &selector->node); push_dom_node(&select_data->stack, &selector->node);
} }
return DOM_STACK_CODE_OK;
} }
/* Ensures that nodes, no longer 'reachable' on the stack do not have any /* Ensures that nodes, no longer 'reachable' on the stack do not have any
* states associated with them on the select data stack. */ * states associated with them on the select data stack. */
static void enum dom_stack_code
dom_select_pop_element(struct dom_stack *stack, struct dom_node *node, void *data) dom_select_pop_element(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_select_data *select_data = get_dom_select_data(stack); struct dom_select_data *select_data = get_dom_select_data(stack);
@ -944,12 +946,14 @@ dom_select_pop_element(struct dom_stack *stack, struct dom_node *node, void *dat
continue; continue;
} }
} }
return DOM_STACK_CODE_OK;
} }
/* For now this is only for matching the ':contains(<string>)' pseudo-class. /* For now this is only for matching the ':contains(<string>)' pseudo-class.
* Any node which can contain text and thus characters from the given <string> * Any node which can contain text and thus characters from the given <string>
* are handled in this common callback. */ * are handled in this common callback. */
static void enum dom_stack_code
dom_select_push_text(struct dom_stack *stack, struct dom_node *node, void *data) dom_select_push_text(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_select_data *select_data = get_dom_select_data(stack); struct dom_select_data *select_data = get_dom_select_data(stack);
@ -961,7 +965,7 @@ dom_select_push_text(struct dom_stack *stack, struct dom_node *node, void *data)
WDBG("Text node: %d chars", node->string.length); WDBG("Text node: %d chars", node->string.length);
if (!text_sel) if (!text_sel)
return; return DOM_STACK_CODE_OK;
text = &text_sel->node.string; text = &text_sel->node.string;
@ -973,6 +977,8 @@ dom_select_push_text(struct dom_stack *stack, struct dom_node *node, void *data)
default: default:
ERROR("Unhandled type"); ERROR("Unhandled type");
} }
return DOM_STACK_CODE_OK;
} }
/* Context info for interacting with the DOM tree or stream stack. */ /* Context info for interacting with the DOM tree or stream stack. */

View File

@ -432,7 +432,7 @@ struct sgml_parsing_state {
size_t depth; size_t depth;
}; };
static void enum dom_stack_code
sgml_parsing_push(struct dom_stack *stack, struct dom_node *node, void *data) sgml_parsing_push(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct sgml_parser *parser = get_sgml_parser(stack); struct sgml_parser *parser = get_sgml_parser(stack);
@ -448,9 +448,11 @@ sgml_parsing_push(struct dom_stack *stack, struct dom_node *node, void *data)
SGML_STATE_TEXT, count_lines, complete, incremental, SGML_STATE_TEXT, count_lines, complete, incremental,
detect_errors); detect_errors);
parser->code = parse_sgml_plain(&parser->stack, &parsing->scanner); parser->code = parse_sgml_plain(&parser->stack, &parsing->scanner);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
sgml_parsing_pop(struct dom_stack *stack, struct dom_node *node, void *data) sgml_parsing_pop(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct sgml_parser *parser = get_sgml_parser(stack); struct sgml_parser *parser = get_sgml_parser(stack);
@ -464,6 +466,8 @@ sgml_parsing_pop(struct dom_stack *stack, struct dom_node *node, void *data)
} }
assert(parsing->depth == parser->stack.depth); assert(parsing->depth == parser->stack.depth);
return DOM_STACK_CODE_OK;
} }
static struct dom_stack_context_info sgml_parsing_context_info = { static struct dom_stack_context_info sgml_parsing_context_info = {

View File

@ -489,7 +489,7 @@ static unsigned char indent_string[] =
#define get_indent_offset(stack) \ #define get_indent_offset(stack) \
((stack)->depth < sizeof(indent_string)/2 ? (stack)->depth * 2 : sizeof(indent_string)) ((stack)->depth < sizeof(indent_string)/2 ? (stack)->depth * 2 : sizeof(indent_string))
static void enum dom_stack_code
dom_stack_trace_tree(struct dom_stack *stack, struct dom_node *node, void *data) dom_stack_trace_tree(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_string *value = &node->string; struct dom_string *value = &node->string;
@ -500,9 +500,11 @@ dom_stack_trace_tree(struct dom_stack *stack, struct dom_node *node, void *data)
get_indent_offset(stack), indent_string, get_indent_offset(stack), indent_string,
name->length, name->string, name->length, name->string,
value->length, value->string); value->length, value->string);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
dom_stack_trace_id_leaf(struct dom_stack *stack, struct dom_node *node, void *data) dom_stack_trace_id_leaf(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_string value; struct dom_string value;
@ -523,9 +525,11 @@ dom_stack_trace_id_leaf(struct dom_stack *stack, struct dom_node *node, void *da
if (is_dom_string_set(&value)) if (is_dom_string_set(&value))
done_dom_string(&value); done_dom_string(&value);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
dom_stack_trace_leaf(struct dom_stack *stack, struct dom_node *node, void *data) dom_stack_trace_leaf(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_string *name; struct dom_string *name;
@ -544,9 +548,11 @@ dom_stack_trace_leaf(struct dom_stack *stack, struct dom_node *node, void *data)
if (is_dom_string_set(&value)) if (is_dom_string_set(&value))
done_dom_string(&value); done_dom_string(&value);
return DOM_STACK_CODE_OK;
} }
static void enum dom_stack_code
dom_stack_trace_branch(struct dom_stack *stack, struct dom_node *node, void *data) dom_stack_trace_branch(struct dom_stack *stack, struct dom_node *node, void *data)
{ {
struct dom_string *name; struct dom_string *name;
@ -561,6 +567,8 @@ dom_stack_trace_branch(struct dom_stack *stack, struct dom_node *node, void *dat
empty_string_or_(stack->current->data), empty_string_or_(stack->current->data),
get_indent_offset(stack), indent_string, get_indent_offset(stack), indent_string,
id->length, id->string, name->length, name->string); id->length, id->string, name->length, name->string);
return DOM_STACK_CODE_OK;
} }
struct dom_stack_context_info dom_stack_trace_context_info = { struct dom_stack_context_info dom_stack_trace_context_info = {

View File

@ -22,7 +22,8 @@ enum dom_stack_code {
/** DOM stack callback /** DOM stack callback
* *
* Used by contexts, for 'hooking' into the node traversing. */ * Used by contexts, for 'hooking' into the node traversing. */
typedef void (*dom_stack_callback_T)(struct dom_stack *, struct dom_node *, void *); typedef enum dom_stack_code
(*dom_stack_callback_T)(struct dom_stack *, struct dom_node *, void *);
#define DOM_STACK_MAX_DEPTH 4096 #define DOM_STACK_MAX_DEPTH 4096