aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/html.cc8
-rw-r--r--src/html_common.hh1
2 files changed, 6 insertions, 3 deletions
diff --git a/src/html.cc b/src/html.cc
index 896700ec..9e11a05a 100644
--- a/src/html.cc
+++ b/src/html.cc
@@ -542,6 +542,8 @@ int DilloHtml::getCurTagLineNumber()
const char *p = Start_Buf;
dReturn_val_if_fail(p != NULL, -1);
+ /* Disable line counting for META hack. Buffers differ. */
+ dReturn_val_if((InFlags & IN_META_HACK), -1);
ofs = CurrTagOfs;
line = OldTagLine;
@@ -2865,7 +2867,7 @@ static void Html_tag_open_meta(DilloHtml *html, const char *tag, int tagsize)
} else {
mr_url = dStrdup(content);
}
- new_url = a_Url_new(mr_url, URL_STR(html->base_url));
+ new_url = a_Html_url_new(html, mr_url, NULL, 0);
if (a_Url_cmp(html->base_url, new_url) == 0) {
/* redirection loop, or empty url string: ignore */
@@ -2881,11 +2883,11 @@ static void Html_tag_open_meta(DilloHtml *html, const char *tag, int tagsize)
* TODO: This is a hairy hack,
* It'd be much better to build a widget. */
Dstr *ds_msg = dStr_sized_new(256);
- dStr_sprintf(ds_msg, meta_template, mr_url, delay_str);
+ dStr_sprintf(ds_msg, meta_template, URL_STR(new_url), delay_str);
{
int o_InFlags = html->InFlags;
int o_TagSoup = html->TagSoup;
- html->InFlags = IN_BODY;
+ html->InFlags = IN_BODY + IN_META_HACK;
html->TagSoup = false;
Html_write_raw(html, ds_msg->str, ds_msg->len, 0);
html->TagSoup = o_TagSoup;
diff --git a/src/html_common.hh b/src/html_common.hh
index 44730a57..98553439 100644
--- a/src/html_common.hh
+++ b/src/html_common.hh
@@ -86,6 +86,7 @@ typedef enum {
IN_MAP = 1 << 9,
IN_PRE = 1 << 10,
IN_LI = 1 << 11,
+ IN_META_HACK = 1 << 12,
} DilloHtmlProcessingState;
/*