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

Introduce skip_sgml_space() that wraps scan_sgml(..., SGML_SCAN_WHITESPACE)

This commit is contained in:
Jonas Fonseca 2005-12-31 01:57:54 +01:00 committed by Jonas Fonseca
parent 9264221635
commit 0891cda51e

View File

@ -78,6 +78,15 @@ struct dom_scanner_info sgml_scanner_info = {
#define is_sgml_token_start(c) check_sgml_table(c, SGML_CHAR_TOKEN_START) #define is_sgml_token_start(c) check_sgml_table(c, SGML_CHAR_TOKEN_START)
#define is_sgml_attribute(c) !check_sgml_table(c, SGML_CHAR_NOT_ATTRIBUTE | SGML_CHAR_WHITESPACE) #define is_sgml_attribute(c) !check_sgml_table(c, SGML_CHAR_NOT_ATTRIBUTE | SGML_CHAR_WHITESPACE)
static inline void
skip_sgml_space(struct dom_scanner *scanner, unsigned char **string)
{
unsigned char *pos = *string;
scan_sgml(scanner, pos, SGML_CHAR_WHITESPACE);
*string = pos;
}
/* Text token scanning */ /* Text token scanning */
@ -115,7 +124,7 @@ scan_sgml_text_token(struct dom_scanner *scanner, struct dom_scanner_token *toke
} else { } else {
if (is_sgml_space(first_char)) { if (is_sgml_space(first_char)) {
scan_sgml(scanner, string, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &string);
type = string < scanner->end && is_sgml_text(*string) type = string < scanner->end && is_sgml_text(*string)
? SGML_TOKEN_TEXT : SGML_TOKEN_SPACE; ? SGML_TOKEN_TEXT : SGML_TOKEN_SPACE;
} else { } else {
@ -254,7 +263,7 @@ scan_sgml_element_token(struct dom_scanner *scanner, struct dom_scanner_token *t
token->string.string = string++; token->string.string = string++;
if (first_char == '<') { if (first_char == '<') {
scan_sgml(scanner, string, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &string);
if (scanner->state == SGML_STATE_ELEMENT) { if (scanner->state == SGML_STATE_ELEMENT) {
/* Already inside an element so insert a tag end token /* Already inside an element so insert a tag end token
@ -270,7 +279,7 @@ scan_sgml_element_token(struct dom_scanner *scanner, struct dom_scanner_token *t
real_length = string - token->string.string; real_length = string - token->string.string;
scan_sgml(scanner, string, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &string);
if (*string == '>') { if (*string == '>') {
type = SGML_TOKEN_ELEMENT; type = SGML_TOKEN_ELEMENT;
string++; string++;
@ -284,7 +293,7 @@ scan_sgml_element_token(struct dom_scanner *scanner, struct dom_scanner_token *t
enum sgml_token_type base = SGML_TOKEN_NOTATION; enum sgml_token_type base = SGML_TOKEN_NOTATION;
string++; string++;
scan_sgml(scanner, string, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &string);
token->string.string = ident = string; token->string.string = ident = string;
if (string + 1 < scanner->end if (string + 1 < scanner->end
@ -305,7 +314,7 @@ scan_sgml_element_token(struct dom_scanner *scanner, struct dom_scanner_token *t
assert(real_length >= 0); assert(real_length >= 0);
} else { } else {
scan_sgml(scanner, string, SGML_CHAR_IDENT); skip_sgml_space(scanner, &string);
type = map_dom_scanner_string(scanner, ident, string, base); type = map_dom_scanner_string(scanner, ident, string, base);
skip_sgml(scanner, &string, '>', 0); skip_sgml(scanner, &string, '>', 0);
} }
@ -315,7 +324,7 @@ scan_sgml_element_token(struct dom_scanner *scanner, struct dom_scanner_token *t
enum sgml_token_type base = SGML_TOKEN_PROCESS; enum sgml_token_type base = SGML_TOKEN_PROCESS;
string++; string++;
scan_sgml(scanner, string, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &string);
token->string.string = pos = string; token->string.string = pos = string;
scan_sgml(scanner, string, SGML_CHAR_IDENT); scan_sgml(scanner, string, SGML_CHAR_IDENT);
@ -325,7 +334,7 @@ scan_sgml_element_token(struct dom_scanner *scanner, struct dom_scanner_token *t
} else if (*string == '/') { } else if (*string == '/') {
string++; string++;
scan_sgml(scanner, string, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &string);
if (is_sgml_ident(*string)) { if (is_sgml_ident(*string)) {
token->string.string = string; token->string.string = string;
@ -458,7 +467,7 @@ scan_sgml_tokens(struct dom_scanner *scanner)
if (scanner->state == SGML_STATE_ELEMENT if (scanner->state == SGML_STATE_ELEMENT
|| (*scanner->position == '<' || (*scanner->position == '<'
&& scanner->state != SGML_STATE_PROC_INST)) { && scanner->state != SGML_STATE_PROC_INST)) {
scan_sgml(scanner, scanner->position, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &scanner->position);
if (scanner->position >= scanner->end) break; if (scanner->position >= scanner->end) break;
scan_sgml_element_token(scanner, current); scan_sgml_element_token(scanner, current);
@ -472,7 +481,7 @@ scan_sgml_tokens(struct dom_scanner *scanner)
scan_sgml_text_token(scanner, current); scan_sgml_text_token(scanner, current);
} else { } else {
scan_sgml(scanner, scanner->position, SGML_CHAR_WHITESPACE); skip_sgml_space(scanner, &scanner->position);
scan_sgml_proc_inst_token(scanner, current); scan_sgml_proc_inst_token(scanner, current);
} }
} }