[project @ 2003-04-06 18:09:34 by bursa]

@import, more status messages.

svn path=/import/netsurf/; revision=116
This commit is contained in:
James Bursa 2003-04-06 18:09:34 +00:00
parent 2253e38be8
commit 46edb645e1
10 changed files with 229 additions and 48 deletions

View File

@ -1,5 +1,5 @@
/**
* $Id: content.c,v 1.5 2003/04/05 21:38:06 bursa Exp $
* $Id: content.c,v 1.6 2003/04/06 18:09:34 bursa Exp $
*/
#include <assert.h>
@ -74,6 +74,7 @@ struct content * content_create(content_type type, char *url)
c->type = type;
c->status = CONTENT_LOADING;
c->size = sizeof(struct content);
c->status_callback = 0;
handler_map[type].create(c);
return c;
}

View File

@ -1,5 +1,5 @@
/**
* $Id: content.h,v 1.4 2003/04/05 21:38:06 bursa Exp $
* $Id: content.h,v 1.5 2003/04/06 18:09:34 bursa Exp $
*/
#ifndef _NETSURF_DESKTOP_CONTENT_H_
@ -57,7 +57,6 @@ struct content
unsigned int stylesheet_count;
char **stylesheet_url;
struct content **stylesheet_content;
struct css_stylesheet* stylesheet;
struct css_style* style;
struct {
struct box_position start;
@ -69,7 +68,12 @@ struct content
struct page_elements elements;
} html;
struct css_stylesheet *css;
struct
{
struct css_stylesheet *css;
unsigned int import_count;
struct content **import_content;
} css;
struct
{
@ -84,6 +88,8 @@ struct content
char *title;
unsigned int active;
int error;
void (*status_callback)(void *p, const char *status);
void *status_p;
};

View File

@ -1,5 +1,5 @@
/**
* $Id: fetchcache.c,v 1.5 2003/03/08 20:26:31 bursa Exp $
* $Id: fetchcache.c,v 1.6 2003/04/06 18:09:34 bursa Exp $
*/
#include <assert.h>
@ -24,6 +24,7 @@ struct fetchcache {
static void fetchcache_free(struct fetchcache *fc);
static void fetchcache_callback(fetchcache_msg msg, void *p, char *data, unsigned long size);
static void status_callback(void *p, const char *status);
void fetchcache(const char *url, char *referer,
@ -81,6 +82,8 @@ void fetchcache_callback(fetch_msg msg, void *p, char *data, unsigned long size)
free(fc);
} else {
fc->c = content_create(type, fc->url);
fc->c->status_callback = status_callback;
fc->c->status_p = fc;
}
free(mime_type);
break;
@ -119,6 +122,13 @@ void fetchcache_callback(fetch_msg msg, void *p, char *data, unsigned long size)
}
void status_callback(void *p, const char *status)
{
struct fetchcache *fc = p;
fc->callback(FETCHCACHE_STATUS, fc->c, fc->p, status);
}
#ifdef TEST
#include <unistd.h>

209
css/css.c
View File

@ -1,5 +1,5 @@
/**
* $Id: css.c,v 1.4 2003/04/05 21:38:06 bursa Exp $
* $Id: css.c,v 1.5 2003/04/06 18:09:34 bursa Exp $
*/
#include <assert.h>
@ -7,10 +7,13 @@
#include <string.h>
#include <strings.h>
#define CSS_INTERNALS
#define NDEBUG
#undef NDEBUG
#include "netsurf/content/content.h"
#include "netsurf/content/fetch.h"
#include "netsurf/content/fetchcache.h"
#include "netsurf/css/css.h"
#include "netsurf/css/parser.h"
#include "netsurf/desktop/gui.h"
#include "netsurf/utils/log.h"
#include "netsurf/utils/utils.h"
@ -23,6 +26,13 @@ struct decl {
struct rule * rule;
};
struct fetch_data {
struct content *c;
unsigned int i;
};
void css_atimport_callback(fetchcache_msg msg, struct content *css,
void *p, const char *error);
void css_dump_style(const struct css_style * const style);
@ -78,11 +88,14 @@ void css_create(struct content *c)
{
unsigned int i;
LOG(("content %p", c));
c->data.css = xcalloc(1, sizeof(*c->data.css));
css_lex_init(&c->data.css->lexer);
c->data.css->parser = css_parser_Alloc(malloc);
c->data.css.css = xcalloc(1, sizeof(*c->data.css.css));
css_lex_init(&c->data.css.css->lexer);
c->data.css.css->parser = css_parser_Alloc(malloc);
for (i = 0; i != HASH_SIZE; i++)
c->data.css->rule[i] = 0;
c->data.css.css->rule[i] = 0;
c->data.css.import_count = 0;
c->data.css.import_content = xcalloc(0, sizeof(*c->data.css.import_content));
c->active = 0;
}
@ -90,30 +103,36 @@ void css_process_data(struct content *c, char *data, unsigned long size)
{
int token;
YY_BUFFER_STATE buffer;
struct parse_params param = {0, c->data.css, 0};
struct parse_params param = {0, c, 0};
LOG(("content %p, size %lu", c, size));
buffer = css__scan_bytes(data, size, c->data.css->lexer);
while ((token = css_lex(c->data.css->lexer))) {
css_parser_(c->data.css->parser, token,
strdup(css_get_text(c->data.css->lexer)),
buffer = css__scan_bytes(data, size, c->data.css.css->lexer);
while ((token = css_lex(c->data.css.css->lexer))) {
css_parser_(c->data.css.css->parser, token,
strdup(css_get_text(c->data.css.css->lexer)),
&param);
}
css__delete_buffer(buffer, c->data.css->lexer);
css__delete_buffer(buffer, c->data.css.css->lexer);
}
int css_convert(struct content *c, unsigned int width, unsigned int height)
{
struct parse_params param = {0, c->data.css, 0};
struct parse_params param = {0, c, 0};
LOG(("content %p", c));
css_parser_(c->data.css->parser, 0, 0, &param);
css_parser_(c->data.css.css->parser, 0, 0, &param);
css_parser_Free(c->data.css->parser, free);
css_lex_destroy(c->data.css->lexer);
css_parser_Free(c->data.css.css->parser, free);
css_lex_destroy(c->data.css.css->lexer);
/* complete fetch of any imported stylesheets */
while (c->active != 0) {
fetch_poll();
gui_multitask();
}
return 0;
}
@ -131,7 +150,21 @@ void css_reformat(struct content *c, unsigned int width, unsigned int height)
void css_destroy(struct content *c)
{
xfree(c->data.css);
unsigned int i;
struct node *r;
for (i = 0; i != HASH_SIZE; i++) {
for (r = c->data.css.css->rule[i]; r != 0; r = r->next)
xfree(r->style);
css_free_node(c->data.css.css->rule[i]);
}
xfree(c->data.css.css);
/* imported stylesheets */
for (i = 0; i != c->data.css.import_count; i++)
if (c->data.css.import_content[i] != 0)
cache_free(c->data.css.import_content[i]);
xfree(c->data.css.import_content);
}
@ -169,14 +202,131 @@ void css_free_node(struct node *node)
}
void css_atimport(struct content *c, struct node *node)
{
char *s, *url;
int string = 0, screen = 1;
struct fetch_data *fetch_data;
void css_get_style(struct css_stylesheet * stylesheet, struct css_selector * selector,
LOG(("@import rule"));
/* uri(...) or "..." */
switch (node->type) {
case NODE_URI:
LOG(("URI '%s'", node->data));
for (s = node->data + 4;
*s == ' ' || *s == '\t' || *s == '\r' ||
*s == '\n' || *s == '\f';
s++)
;
if (*s == '\'' || *s == '"') {
string = 1;
s++;
}
url = xstrdup(s);
for (s = url + strlen(url) - 2;
*s == ' ' || *s == '\t' || *s == '\r' ||
*s == '\n' || *s == '\f';
s--)
;
if (string)
*s = 0;
else
*(s + 1) = 0;
break;
case NODE_STRING:
LOG(("STRING '%s'", node->data));
url = xstrdup(node->data + 1);
*(url + strlen(url) - 1) = 0;
break;
default:
return;
}
/* media not specified, 'screen', or 'all' */
for (node = node->next; node != 0; node = node->next) {
screen = 0;
if (node->type != NODE_IDENT) {
free(url);
return;
}
LOG(("medium '%s'", node->data));
if (strcmp(node->data, "screen") == 0 || strcmp(node->data, "all") == 0) {
screen = 1;
break;
}
node = node->next;
if (node == 0 || node->type != NODE_COMMA) {
free(url);
return;
}
}
if (!screen) {
free(url);
return;
}
/* start the fetch */
c->data.css.import_count++;
c->data.css.import_content = xrealloc(c->data.css.import_content,
c->data.css.import_count * sizeof(*c->data.css.import_content));
fetch_data = xcalloc(1, sizeof(*fetch_data));
fetch_data->c = c;
fetch_data->i = c->data.css.import_count - 1;
c->active++;
fetchcache(url_join(url, c->url), c->url, css_atimport_callback,
fetch_data, c->width, c->height);
free(url);
}
void css_atimport_callback(fetchcache_msg msg, struct content *css,
void *p, const char *error)
{
struct fetch_data *data = p;
struct content *c = data->c;
unsigned int i = data->i;
switch (msg) {
case FETCHCACHE_OK:
free(data);
LOG(("got imported stylesheet '%s'", css->url));
c->data.css.import_content[i] = css;
/*css_dump_stylesheet(css->data.css);*/
c->active--;
break;
case FETCHCACHE_BADTYPE:
case FETCHCACHE_ERROR:
free(data);
c->data.css.import_content[i] = 0;
c->active--;
c->error = 1;
break;
case FETCHCACHE_STATUS:
/* TODO: need to add a way of sending status to the
* owning window */
break;
default:
assert(0);
}
}
void css_get_style(struct content *c, struct css_selector * selector,
unsigned int selectors, struct css_style * style)
{
struct css_stylesheet *stylesheet = c->data.css.css;
struct node *r, *n, *m;
unsigned int hash, i, done_empty = 0;
LOG(("stylesheet %p, selectors %u", stylesheet, selectors));
/*LOG(("stylesheet '%s'", c->url));*/
hash = css_hash(selector[selectors - 1].element);
for (r = stylesheet->rule[hash]; ; r = r->next) {
@ -185,31 +335,30 @@ void css_get_style(struct css_stylesheet * stylesheet, struct css_selector * sel
done_empty = 1;
}
if (r == 0)
return;
break;
i = selectors - 1;
n = r;
/* compare element */
if (n->data != 0)
if (strcasecmp(selector[i].element, n->data) != 0)
goto not_matched;
LOG(("top element '%s' matched", selector[i].element));
/*LOG(("top element '%s' matched", selector[i].element));*/
while (1) {
/* class and id */
for (m = n->left; m != 0; m = m->next) {
if (m->type == NODE_ID) {
/* TODO: check if case sensitive */
if (strcmp(selector[i].id, m->data) != 0)
if (strcmp(selector[i].id, m->data + 1) != 0)
goto not_matched;
} else if (m->type == NODE_CLASS) {
/* TODO: check if case sensitive */
LOG(("comparing class '%s' against '%s'", selector[i].class, m->data));
if (strcmp(selector[i].class, m->data) != 0)
goto not_matched;
} else {
goto not_matched;
}
}
LOG(("class and id matched"));
/*LOG(("class and id matched"));*/
/* ancestors etc. */
if (n->comb == COMB_NONE)
goto matched; /* match successful */
@ -219,13 +368,13 @@ void css_get_style(struct css_stylesheet * stylesheet, struct css_selector * sel
n = n->right;
if (n->data == 0)
goto not_matched; /* TODO: handle this case */
LOG(("searching for ancestor '%s'", n->data));
/*LOG(("searching for ancestor '%s'", n->data));*/
while (i != 0 && strcasecmp(selector[i - 1].element, n->data) != 0)
i--;
if (i == 0)
goto not_matched;
i--;
LOG(("found"));
/*LOG(("found"));*/
} else {
/* TODO: COMB_PRECEDED, COMB_PARENT */
goto not_matched;
@ -234,12 +383,18 @@ void css_get_style(struct css_stylesheet * stylesheet, struct css_selector * sel
matched:
/* TODO: sort by specificity */
LOG(("matched rule %p", r));
/*LOG(("matched rule %p", r));*/
css_merge(style, r->style);
not_matched:
}
/* imported stylesheets */
for (i = 0; i != c->data.css.import_count; i++)
if (c->data.css.import_content[i] != 0)
css_get_style(c->data.css.import_content[i], selector,
selectors, style);
}

View File

@ -1,5 +1,5 @@
/**
* $Id: css.h,v 1.4 2003/04/05 21:38:06 bursa Exp $
* $Id: css.h,v 1.5 2003/04/06 18:09:34 bursa Exp $
*/
#ifndef _NETSURF_CSS_CSS_H_
@ -146,7 +146,7 @@ struct css_stylesheet {
struct parse_params {
int ruleset_only;
struct css_stylesheet *stylesheet;
struct content *stylesheet;
struct node *declaration;
};
@ -170,7 +170,8 @@ void css_destroy(struct content *c);
struct node * css_new_node(node_type type, char *data,
struct node *left, struct node *right);
void css_free_node(struct node *node);
void css_add_ruleset(struct css_stylesheet *stylesheet,
void css_atimport(struct content *c, struct node *node);
void css_add_ruleset(struct content *c,
struct node *selector,
struct node *declaration);
void css_add_declarations(struct css_style *style, struct node *declaration);
@ -184,7 +185,7 @@ void css_parser_(void *yyp, int yymajor, char* yyminor,
#endif
void css_get_style(struct css_stylesheet * stylesheet, struct css_selector * selector,
void css_get_style(struct content *c, struct css_selector * selector,
unsigned int selectors, struct css_style * style);
void css_cascade(struct css_style * const style, const struct css_style * const apply);
void css_merge(struct css_style * const style, const struct css_style * const apply);

View File

@ -1,5 +1,5 @@
/**
* $Id: parser.y,v 1.5 2003/04/05 16:24:43 bursa Exp $
* $Id: parser.y,v 1.6 2003/04/06 18:09:34 bursa Exp $
*/
/*
@ -36,7 +36,10 @@ statement ::= ruleset.
statement ::= at_rule.
at_rule ::= ATKEYWORD any_list block.
at_rule ::= ATKEYWORD any_list SEMI.
at_rule ::= ATKEYWORD(A) any_list(B) SEMI.
{ if (strcasecmp(A, "@import") == 0)
css_atimport(param->stylesheet, B);
free(A); css_free_node(B); }
block ::= LBRACE block_body RBRACE.
block_body ::= .

View File

@ -1,5 +1,5 @@
/**
* $Id: ruleset.c,v 1.4 2003/04/05 21:38:06 bursa Exp $
* $Id: ruleset.c,v 1.5 2003/04/06 18:09:34 bursa Exp $
*/
#include <assert.h>
@ -7,6 +7,7 @@
#include <string.h>
#include <strings.h>
#define CSS_INTERNALS
#define NDEBUG
#include "netsurf/css/css.h"
#include "netsurf/utils/log.h"
#include "netsurf/utils/utils.h"
@ -99,10 +100,11 @@ static const struct font_size_entry font_size_table[] = {
* css_add_ruleset -- add a ruleset to a stylesheet
*/
void css_add_ruleset(struct css_stylesheet *stylesheet,
void css_add_ruleset(struct content *c,
struct node *selector,
struct node *declaration)
{
struct css_stylesheet *stylesheet = c->data.css.css;
struct node *n, *sel, *next_sel;
struct css_style *style;
unsigned int hash;

View File

@ -1,4 +1,4 @@
# $Id: makefile,v 1.16 2003/04/04 15:19:31 bursa Exp $
# $Id: makefile,v 1.17 2003/04/06 18:09:34 bursa Exp $
all: !NetSurf/!RunImage,ff8
clean:
@ -62,7 +62,7 @@ utils/arm-riscos-aof/%.o: utils/%.c $(HEADERS)
css/css_enum.c css/css_enum.h: css/css_enums css/makeenum
cd ..; /usr/bin/perl netsurf/css/makeenum netsurf/css/css_enum < netsurf/css/css_enums
css/parser.c css/parser.h: css/parser.y
css/parser.c: css/parser.y
-cd css; lemon parser.y
css/scanner.c css/scanner.h: css/scanner.l

View File

@ -1,5 +1,5 @@
/**
* $Id: box.c,v 1.37 2003/04/05 21:38:06 bursa Exp $
* $Id: box.c,v 1.38 2003/04/06 18:09:34 bursa Exp $
*/
#include <assert.h>
@ -424,7 +424,7 @@ struct css_style * box_get_style(struct content ** stylesheet,
for (i = 0; i != stylesheet_count; i++) {
if (stylesheet[i] != 0) {
assert(stylesheet[i]->type == CONTENT_CSS);
css_get_style(stylesheet[i]->data.css, selector, depth, style_new);
css_get_style(stylesheet[i], selector, depth, style_new);
}
}
css_cascade(style, style_new);

View File

@ -1,5 +1,5 @@
/**
* $Id: html.c,v 1.8 2003/04/05 21:38:06 bursa Exp $
* $Id: html.c,v 1.9 2003/04/06 18:09:34 bursa Exp $
*/
#include <assert.h>
@ -33,7 +33,6 @@ void html_create(struct content *c)
c->data.html.document = NULL;
c->data.html.markup = NULL;
c->data.html.layout = NULL;
c->data.html.stylesheet = NULL;
c->data.html.style = NULL;
c->data.html.fonts = NULL;
}
@ -57,6 +56,7 @@ int html_convert(struct content *c, unsigned int width, unsigned int height)
struct css_selector* selector = xcalloc(1, sizeof(struct css_selector));
struct fetch_data *fetch_data;
unsigned int i;
char status[80];
htmlParseChunk(c->data.html.parser, "", 0, 1);
c->data.html.document = c->data.html.parser->myDoc;
@ -101,6 +101,10 @@ int html_convert(struct content *c, unsigned int width, unsigned int height)
}
while (c->active != 0) {
if (c->status_callback != 0) {
sprintf(status, "Loading %u stylesheets", c->active);
c->status_callback(c->status_p, status);
}
fetch_poll();
gui_multitask();
}
@ -110,8 +114,6 @@ int html_convert(struct content *c, unsigned int width, unsigned int height)
return 1;
}
c->data.html.stylesheet = c->data.html.stylesheet_content[0]->data.css;
LOG(("Copying base style"));
c->data.html.style = xcalloc(1, sizeof(struct css_style));
memcpy(c->data.html.style, &css_base_style, sizeof(struct css_style));
@ -123,6 +125,7 @@ int html_convert(struct content *c, unsigned int width, unsigned int height)
c->data.html.fonts = font_new_set();
c->status_callback(c->status_p, "Formatting document");
LOG(("XML to box"));
xml_to_box(c->data.html.markup, c->data.html.style,
c->data.html.stylesheet_content, c->data.html.stylesheet_count,