summaryrefslogtreecommitdiff
path: root/css/css.c
diff options
context:
space:
mode:
authorJohn Mark Bell <jmb@netsurf-browser.org>2011-08-23 19:59:13 +0000
committerJohn Mark Bell <jmb@netsurf-browser.org>2011-08-23 19:59:13 +0000
commit85ec83636d60fe945bc3df00cb20d9a850ce7ae8 (patch)
treec39131ed6be02df95cc63ddf1cac15b8b943ed2f /css/css.c
parent92d355ed30be7d2210924711c0a6041b55abf32b (diff)
downloadnetsurf-85ec83636d60fe945bc3df00cb20d9a850ce7ae8.tar.gz
netsurf-85ec83636d60fe945bc3df00cb20d9a850ce7ae8.tar.bz2
Reject attempts by a stylesheet to import itself
svn path=/trunk/netsurf/; revision=12644
Diffstat (limited to 'css/css.c')
-rw-r--r--css/css.c21
1 files changed, 15 insertions, 6 deletions
diff --git a/css/css.c b/css/css.c
index 79eda90b8..9d0014ec6 100644
--- a/css/css.c
+++ b/css/css.c
@@ -587,13 +587,22 @@ css_error nscss_handle_import(void *pw, css_stylesheet *parent,
/* Create content */
c->imports[c->import_count].media = media;
- nerror = hlcache_handle_retrieve(lwc_string_data(url),
- 0, referer, NULL, nscss_import, ctx,
- &child, accept,
- &c->imports[c->import_count].c);
- if (nerror != NSERROR_OK) {
+
+ /* Avoid importing ourself */
+ if (strcmp(lwc_string_data(url), referer) == 0) {
+ c->imports[c->import_count].c = NULL;
+ /* No longer require context as we're not fetching anything */
free(ctx);
- return CSS_NOMEM;
+ ctx = NULL;
+ } else {
+ nerror = hlcache_handle_retrieve(lwc_string_data(url),
+ 0, referer, NULL, nscss_import, ctx,
+ &child, accept,
+ &c->imports[c->import_count].c);
+ if (nerror != NSERROR_OK) {
+ free(ctx);
+ return CSS_NOMEM;
+ }
}
#ifdef NSCSS_IMPORT_TRACE