/*
- * Copyright (C) 2005-2008 Atsushi Konno All rights reserved.
+ * Copyright (C) 2005-2009 Atsushi Konno All rights reserved.
* Copyright (C) 2005 QSDN,Inc. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
#include "chxj_qr_code.h"
#include "chxj_encoding.h"
#include "chxj_buffered_write.h"
+#include "chxj_header_inf.h"
+#include "chxj_conv_z2h.h"
#define GET_CHTML20(X) ((chtml20_t*)(X))
+#undef W_L
+#undef W_V
#define W_L(X) do { chtml20->out = BUFFERED_WRITE_LITERAL(chtml20->out, &doc->buf, (X)); } while(0)
#define W_V(X) do { chtml20->out = (X) ? BUFFERED_WRITE_VALUE(chtml20->out, &doc->buf, (X)) \
: BUFFERED_WRITE_LITERAL(chtml20->out, &doc->buf, ""); } while(0)
+#undef W_NLCODE
+#define W_NLCODE() do { char *nlcode = TO_NLCODE(chtml20->conf); W_V(nlcode); } while (0)
static char *s_chtml20_start_html_tag (void *pdoc, Node *node);
static char *s_chtml20_end_html_tag (void *pdoc, Node *node);
static char *s_chtml20_start_plaintext_tag (void *pdoc, Node *node);
static char *s_chtml20_start_plaintext_tag_inner (void *pdoc, Node *node);
static char *s_chtml20_end_plaintext_tag (void *pdoc, Node *node);
+static char *s_chtml20_start_blink_tag (void *pdoc, Node *node);
+static char *s_chtml20_end_blink_tag (void *pdoc, Node *node);
+static char *s_chtml20_start_marquee_tag (void *pdoc, Node *node);
+static char *s_chtml20_end_marquee_tag (void *pdoc, Node *node);
+static char *s_chtml20_newline_mark (void *pdoc, Node *node);
static void s_init_chtml20(chtml20_t *chtml, Doc *doc, request_rec *r, device_table *spec);
s_chtml20_start_plaintext_tag,
s_chtml20_end_plaintext_tag,
},
+ /* tagBLINK */
+ {
+ s_chtml20_start_blink_tag,
+ s_chtml20_end_blink_tag,
+ },
+ /* tagMAQUEE */
+ {
+ s_chtml20_start_marquee_tag,
+ s_chtml20_end_marquee_tag,
+ },
+ /* tagNLMARK */
+ {
+ s_chtml20_newline_mark,
+ NULL,
+ },
};
/**
* @return The character string after the converting is returned.
*/
char *
-chxj_exchange_chtml20(
- request_rec *r,
- device_table *spec,
- const char *src,
- apr_size_t srclen,
- apr_size_t *dstlen,
+chxj_convert_chtml20(
+ request_rec *r,
+ device_table *spec,
+ const char *src,
+ apr_size_t srclen,
+ apr_size_t *dstlen,
chxjconvrule_entry *entryp,
- cookie_t *cookie
+ cookie_t *cookie
)
{
- char *dst = NULL;
- char *ss;
+ char *dst = NULL;
+ char *ss;
chtml20_t chtml20;
Doc doc;
chtml20.entryp = entryp;
chtml20.cookie = cookie;
- chxj_set_content_type(r, "text/html; charset=Windows-31J");
+ chxj_set_content_type(r, chxj_header_inf_set_content_type(r, "text/html; charset=Windows-31J"));
/*--------------------------------------------------------------------------*/
/* The character string of the input is analyzed. */
/*--------------------------------------------------------------------------*/
/* It converts it from CHTML to CHTML. */
/*--------------------------------------------------------------------------*/
- chxj_node_exchange(spec,r,(void *)&chtml20, &doc, qs_get_root(&doc), 0);
+ chxj_node_convert(spec,r,(void *)&chtml20, &doc, qs_get_root(&doc), 0);
chtml20.out = chxj_buffered_write_flush(chtml20.out, &doc.buf);
dst = apr_pstrdup(r->pool, chtml20.out);
chxj_buffered_write_terminate(&doc.buf);
doc->r = r;
chtml20->doc = doc;
chtml20->spec = spec;
- chtml20->out = qs_alloc_zero_byte_string(r);
+ chtml20->out = qs_alloc_zero_byte_string(r->pool);
chtml20->conf = chxj_get_module_config(r->per_dir_config, &chxj_module);
chtml20->doc->parse_mode = PARSE_MODE_CHTML;
static int
s_chtml20_search_emoji(chtml20_t *chtml20, char *txt, char **rslt)
{
- emoji_t *ee;
- request_rec *r;
- device_table *spec;
+ emoji_t *ee;
+ request_rec *r;
+ device_table *spec;
int len;
spec = chtml20->spec;
return 0;
}
+char *
+chxj_chtml20_emoji_only_converter(request_rec *r, device_table *spec, const char *src, apr_size_t len)
+{
+ apr_size_t ii;
+ Doc __doc;
+ Doc *doc;
+ chtml20_t __chtml20;
+ chtml20_t *chtml20;
+ char one_byte[2];
+ char two_byte[3];
+ apr_pool_t *pool;
+
+ chtml20 = &__chtml20;
+ doc = &__doc;
+
+ DBG(r, "REQ[%X] start chxj_chtml20_emoji_eonly_converter()", (unsigned int)(apr_size_t)r);
+ memset(doc, 0, sizeof(Doc));
+ memset(chtml20, 0, sizeof(chtml20_t));
+
+ doc->r = r;
+ chtml20->doc = doc;
+ chtml20->spec = spec;
+ chtml20->out = qs_alloc_zero_byte_string(r->pool);
+ chtml20->conf = chxj_get_module_config(r->per_dir_config, &chxj_module);
+ chtml20->doc->parse_mode = PARSE_MODE_CHTML;
+
+ apr_pool_create(&pool, r->pool);
+
+ chxj_buffered_write_init(pool, &doc->buf);
+
+ for (ii=0; ii<len; ii++) {
+ char *out;
+ int rtn;
+
+ rtn = s_chtml20_search_emoji(chtml20, (char *)&src[ii], &out);
+ if (rtn) {
+ W_V(out);
+ ii+=(rtn - 1);
+ continue;
+ }
+
+ if (is_sjis_kanji(src[ii])) {
+ two_byte[0] = src[ii+0];
+ two_byte[1] = src[ii+1];
+ two_byte[2] = 0;
+ W_V(two_byte);
+ ii++;
+ }
+ else {
+ one_byte[0] = src[ii+0];
+ one_byte[1] = 0;
+ W_V(one_byte);
+ }
+ }
+ chtml20->out = chxj_buffered_write_flush(chtml20->out, &doc->buf);
+
+ DBG(r, "REQ[%X] end chxj_chtml20_emoji_eonly_converter()", (unsigned int)(apr_size_t)r);
+ return chtml20->out;
+}
+
/**
* It is a handler who processes the HTML tag.
static char *
s_chtml20_start_html_tag(void *pdoc, Node *UNUSED(node))
{
- Doc *doc;
+ Doc *doc;
request_rec *r;
- chtml20_t *chtml20;
+ chtml20_t *chtml20;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
static char *
s_chtml20_start_meta_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
- int content_type_flag;
- int refresh_flag;
+ Attr *attr;
+ int content_type_flag;
+ int refresh_flag;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
switch(*name) {
case 'h':
case 'H':
- if (strcasecmp(name, "http-equiv") == 0) {
+ if (strcasecmp(name, "http-equiv") == 0 && value && *value) {
/*----------------------------------------------------------------------*/
/* CHTML 2.0 */
/*----------------------------------------------------------------------*/
case 'c':
case 'C':
- if (strcasecmp(name, "content") == 0) {
+ if (strcasecmp(name, "content") == 0 && value && *value) {
if (content_type_flag) {
W_L(" ");
W_V(name);
- W_L("=\"text/html; charset=Windows-31J\"");
+ W_L("=\"");
+ W_V(chxj_header_inf_set_content_type(r, "text/html; charset=SHIFT_JIS"));
+ W_L("\"");
}
else if (refresh_flag) {
char *buf = apr_pstrdup(r->pool, value);
}
}
W_L(">");
+
return chtml20->out;
}
static char *
s_chtml20_end_meta_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
-
- chtml20 = GET_CHTML20(pdoc);
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
return chtml20->out;
}
static char *
s_chtml20_start_head_tag(void *pdoc, Node *UNUSED(node))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
+ chtml20_t *chtml20;
+ Doc *doc;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
- r = doc->r;
W_L("<head>");
+
return chtml20->out;
}
static char *
s_chtml20_end_head_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</head>");
+
return chtml20->out;
}
static char *
s_chtml20_start_title_tag(void *pdoc, Node *UNUSED(node))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("<title>");
+
return chtml20->out;
}
static char *
s_chtml20_end_title_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</title>");
+
return chtml20->out;
}
static char *
s_chtml20_start_base_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('h','H',"href", name)) {
W_L(" href=\"");
W_V(value);
}
}
W_L(">");
+
return chtml20->out;
}
static char *
s_chtml20_end_base_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_start_body_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
switch(*name) {
case 'b':
case 'B':
}
}
W_L(">");
+
return chtml20->out;
}
static char *
s_chtml20_end_body_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</body>");
+
return chtml20->out;
}
static char *
s_chtml20_start_a_tag(void *pdoc, Node *node)
{
- Attr *attr;
- chtml20_t *chtml20;
- Doc *doc;
+ Attr *attr;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
switch(*name) {
case 'n':
case 'N':
/* CHTML1.0 */
/*--------------------------------------------------------------------*/
value = chxj_encoding_parameter(r, value);
- value = chxj_add_cookie_parameter(r, value, chtml20->cookie);
+ if (! chxj_starts_with(value, "mailto:") && ! chxj_starts_with(value, "tel:")) {
+ value = chxj_add_cookie_parameter(r, value, chtml20->cookie);
+ }
W_L(" href=\"");
W_V(value);
W_L("\"");
static char *
s_chtml20_end_a_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</a>");
+
return chtml20->out;
}
static char *
s_chtml20_start_br_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('c','C',"clear",name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('a','A',"all",value))) {
W_L(" clear=\"");
}
}
W_L(">");
+
return chtml20->out;
}
static char *
s_chtml20_end_br_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_start_tr_tag(void *pdoc, Node *UNUSED(node))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_end_tr_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
r = doc->r;
- W_L("<br>\r\n");
+ W_L("<br>");
+
return chtml20->out;
}
static char *
s_chtml20_start_font_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
+ char *color = NULL;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
r = doc->r;
- W_L("<font");
/*--------------------------------------------------------------------------*/
/* Get Attributes */
/*--------------------------------------------------------------------------*/
for (attr = qs_get_attr(doc,node);
- attr;
+ attr && color == NULL;
attr = qs_get_next_attr(doc,attr)) {
-
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
switch(*name) {
case 'c':
case 'C':
- if (strcasecmp(name, "color") == 0) {
- W_L(" color=\"");
- W_V(value);
- W_L("\"");
+ if (strcasecmp(name, "color") == 0 && value && *value) {
+ color = apr_pstrdup(doc->buf.pool, value);
}
break;
break;
}
}
- W_L(">");
+ if (color) {
+ W_L("<font color=\"");
+ W_V(color);
+ W_L("\">");
+ chtml20->font_flag++;
+ }
return chtml20->out;
}
static char *
s_chtml20_end_font_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
r = doc->r;
- W_L("</font>");
+ if (chtml20->font_flag) {
+ W_L("</font>");
+ chtml20->font_flag--;
+ }
return chtml20->out;
}
Doc *doc;
request_rec *r;
Attr *attr;
+ char *new_hidden_tag = NULL;
+ char *attr_method = NULL;
+ char *attr_action = NULL;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
r = doc->r;
- W_L("<form");
/*--------------------------------------------------------------------------*/
/* Get Attributes */
/*--------------------------------------------------------------------------*/
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
char *name;
char *value;
-
name = qs_get_attr_name(doc,attr);
value = qs_get_attr_value(doc,attr);
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
- value = chxj_encoding_parameter(r, value);
- value = chxj_add_cookie_parameter(r, value, chtml20->cookie);
-
- W_L(" action=\"");
- W_V(value);
- W_L("\"");
+ attr_action = chxj_encoding_parameter(r, value);
+ attr_action= chxj_add_cookie_parameter(r, attr_action, chtml20->cookie);
}
break;
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
- W_L(" method=\"");
- W_V(value);
- W_L("\"");
+ attr_method = apr_pstrdup(doc->pool, value);
}
break;
break;
}
}
+
+ int post_flag = (attr_method && strcasecmp(attr_method, "post") == 0) ? 1 : 0;
+
+ W_L("<form");
+ if (attr_action) {
+ char *q;
+ char *new_query_string = NULL;
+ q = strchr(attr_action, '?');
+ if (q) {
+ new_hidden_tag = chxj_form_action_to_hidden_tag(r, doc->pool, attr_action, 0, post_flag, &new_query_string, CHXJ_TRUE, CHXJ_FALSE, chtml20->entryp);
+ if (new_hidden_tag || new_query_string) {
+ *q = 0;
+ }
+ }
+ W_L(" action=\"");
+ W_V(attr_action);
+ if (new_query_string) {
+ W_L("?");
+ W_V(new_query_string);
+ }
+ W_L("\"");
+ }
+ if (attr_method) {
+ W_L(" method=\"");
+ W_V(attr_method);
+ W_L("\"");
+ }
W_L(">");
+ if (new_hidden_tag) {
+ W_V(new_hidden_tag);
+ }
return chtml20->out;
}
static char *
s_chtml20_end_form_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</form>");
+
return chtml20->out;
}
static char *
s_chtml20_start_input_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- char *max_length = NULL;
- char *type = NULL;
- char *name = NULL;
- char *value = NULL;
- char *istyle = NULL;
- char *size = NULL;
- char *checked = NULL;
- char *accesskey = NULL;
+ char *max_length = NULL;
+ char *type = NULL;
+ char *name = NULL;
+ char *value = NULL;
+ char *istyle = NULL;
+ char *size = NULL;
+ char *checked = NULL;
+ char *accesskey = NULL;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
/*--------------------------------------------------------------------------*/
/* Get Attributes */
/*--------------------------------------------------------------------------*/
-
- type = qs_get_type_attr(doc, node, r);
- name = qs_get_name_attr(doc, node, r);
- value = qs_get_value_attr(doc,node,r);
- istyle = qs_get_istyle_attr(doc,node,r);
- max_length = qs_get_maxlength_attr(doc,node,r);
- checked = qs_get_checked_attr(doc,node,r);
- accesskey = qs_get_accesskey_attr(doc, node, r);
- size = qs_get_size_attr(doc, node, r);
+ type = qs_get_type_attr(doc, node, doc->buf.pool);
+ name = qs_get_name_attr(doc, node, doc->buf.pool);
+ value = qs_get_value_attr(doc,node,doc->buf.pool);
+ istyle = qs_get_istyle_attr(doc,node,doc->buf.pool);
+ max_length = qs_get_maxlength_attr(doc,node,doc->buf.pool);
+ checked = qs_get_checked_attr(doc,node,doc->buf.pool);
+ accesskey = qs_get_accesskey_attr(doc, node, doc->buf.pool);
+ size = qs_get_size_attr(doc, node, doc->buf.pool);
if (type) {
type = qs_trim_string(doc->buf.pool, type);
W_L("\"");
}
}
-
if (size && *size) {
W_L(" size=\"");
W_V(size);
W_L("\"");
}
-
if (name && *name) {
W_L(" name=\"");
W_V(name);
W_L("\"");
}
-
if (value && *value) {
+ apr_size_t value_len = strlen(value);
+ value = chxj_conv_z2h(r, value, &value_len, chtml20->entryp);
+
W_L(" value=\"");
- W_V(value);
+ W_V(chxj_add_slash_to_doublequote(doc->pool, value));
W_L("\"");
}
-
if (accesskey && *accesskey) {
W_L(" accesskey=\"");
W_V(accesskey);
W_L("\"");
}
-
if (istyle) {
/*------------------------------------------------------------------------*/
/* CHTML 2.0 */
W_L("\"");
}
}
-
/*--------------------------------------------------------------------------*/
/* The figure is default for the password. */
/*--------------------------------------------------------------------------*/
W_V(vv);
}
}
-
if (checked) {
W_L(" checked");
}
W_L(">");
+
return chtml20->out;
}
static char *
s_chtml20_end_input_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_start_center_tag(void *pdoc, Node *UNUSED(node))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_end_center_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</center>");
+
return chtml20->out;
}
static char *
s_chtml20_start_ul_tag(void *pdoc, Node *UNUSED(node))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("<ul>");
+
return chtml20->out;
}
static char *
s_chtml20_end_ul_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t* chtml20;
- Doc* doc;
- request_rec* r;
+ chtml20_t *chtml20;
+ Doc *doc;
+ request_rec *r;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
r = doc->r;
W_L("</ul>");
+
return chtml20->out;
}
static char *
s_chtml20_start_ol_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
}
}
W_L(">");
+
return chtml20->out;
}
static char *
s_chtml20_end_ol_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
r = doc->r;
W_L("</ol>");
+
return chtml20->out;
}
static char *
s_chtml20_start_li_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
static char *
s_chtml20_start_hr_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
switch(*name) {
case 'a':
case 'A':
static char *
s_chtml20_end_hr_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
-
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
return chtml20->out;
}
static char *
s_chtml20_start_img_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
- Attr *attr;
+ chtml20_t *chtml20;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
#ifndef IMG_NOT_CONVERT_FILENAME
device_table *spec;
#endif
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *name;
- char *value;
-
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
-
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
switch(*name) {
case 's':
case 'S':
#ifdef IMG_NOT_CONVERT_FILENAME
value = chxj_encoding_parameter(r, value);
value = chxj_add_cookie_parameter(r, value, chtml20->cookie);
- if (value) {
- value = apr_psprintf(doc->buf.pool,
- "%s%c%s=true",
- value,
- (strchr(value, '?')) ? '&' : '?',
- CHXJ_COOKIE_NOUPDATE_PARAM);
- }
+ value = chxj_add_cookie_no_update_parameter(r, value);
W_L(" src=\"");
W_V(value);
W_L("\"");
value = chxj_img_conv(r, spec, value);
value = chxj_encoding_parameter(r, value);
value = chxj_add_cookie_parameter(r, value, chtml20->cookie);
- if (value) {
- value = apr_psprintf(doc->buf.pool,
- "%s%c%s=true",
- value,
- (strchr(value, '?')) ? '&' : '?',
- CHXJ_COOKIE_NOUPDATE_PARAM);
- }
+ value = chxj_add_cookie_no_update_parameter(r, value);
W_L(" src=\"");
W_V(value);
W_L("\"");
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
- if (value && (STRCASEEQ('t','T',"top", value) ||
- STRCASEEQ('m','M',"middle",value) ||
- STRCASEEQ('b','B',"bottom",value) ||
- STRCASEEQ('l','L',"left", value) ||
- STRCASEEQ('r','R',"right", value))) {
- W_L(" align=\"");
- W_V(value);
- W_L("\"");
- }
- }
+ if (value) {
+ if (STRCASEEQ('t','T',"top", value) ||
+ STRCASEEQ('m','M',"middle",value) ||
+ STRCASEEQ('b','B',"bottom",value) ||
+ STRCASEEQ('l','L',"left", value) ||
+ STRCASEEQ('r','R',"right", value)) {
+ W_L(" align=\"");
+ W_V(value);
+ W_L("\"");
+ }
+ else if (STRCASEEQ('c','C',"center", value)) {
+ W_L(" align=\"");
+ W_L("middle");
+ W_L("\"");
+ }
+ }
+ }
else if (strcasecmp(name, "alt" ) == 0 && value && *value) {
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
static char *
s_chtml20_end_img_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
return chtml20->out;
}
static char *
s_chtml20_start_select_tag(void *pdoc, Node *child)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
static char *
s_chtml20_end_select_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
+ chtml20_t *chtml20;
+ Doc *doc;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
- r = doc->r;
W_L("</select>");
return chtml20->out;
static char *
s_chtml20_start_option_tag(void *pdoc, Node *child)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,child);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *nm;
- char *val;
-
- nm = qs_get_attr_name(doc,attr);
- val = qs_get_attr_value(doc,attr);
-
+ char *nm = qs_get_attr_name(doc,attr);
+ char *val = qs_get_attr_value(doc,attr);
switch(*nm) {
case 's':
case 'S':
}
}
- if (value && *value) {
+ if (value) {
W_L(" value=\"");
W_V(value);
W_L("\"");
static char *
s_chtml20_end_option_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
/* Don't close */
static char *
s_chtml20_start_div_tag(void *pdoc, Node *child)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
r = doc->r;
- char* align = NULL;
+ char *align = NULL;
W_L("<div");
for (attr = qs_get_attr(doc,child);
attr;
attr = qs_get_next_attr(doc,attr)) {
-
- char *nm;
- char *val;
-
- nm = qs_get_attr_name(doc,attr);
- val = qs_get_attr_value(doc,attr);
-
+ char *nm = qs_get_attr_name(doc,attr);
+ char *val = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A', "align", nm)) {
/*----------------------------------------------------------------------*/
/* CHTML 1.0 (W3C version 3.2) */
}
}
}
-
if (align) {
W_L(" align=\"");
W_V(align);
W_L("\"");
}
-
W_L(">");
return chtml20->out;
}
static char *
s_chtml20_end_div_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</div>");
return chtml20->out;
static char *
s_chtml20_start_h1_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* name;
- char* value;
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A',"align", name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
W_L(" align=\"");
static char *
s_chtml20_end_h1_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
+ chtml20_t *chtml20;
+ Doc *doc;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
- r = doc->r;
W_L("</h1>");
return chtml20->out;
static char *
s_chtml20_start_h2_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* name;
- char* value;
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A',"align", name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
W_L(" align=\"");
static char *
s_chtml20_end_h2_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</h2>");
+
return chtml20->out;
}
static char *
s_chtml20_start_h3_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* name;
- char* value;
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A',"align", name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
W_L(" align=\"");
static char *
s_chtml20_end_h3_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</h3>");
return chtml20->out;
static char *
s_chtml20_start_h4_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* name;
- char* value;
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A',"align", name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
W_L(" align=\"");
static char *
s_chtml20_end_h4_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</h4>");
return chtml20->out;
static char *
s_chtml20_start_h5_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char *name;
- char *value;
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A',"align", name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
W_L(" align=\"");
static char *
s_chtml20_end_h5_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</h5>");
return chtml20->out;
static char *
s_chtml20_start_h6_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char *name;
- char *value;
- name = qs_get_attr_name(doc,attr);
- value = qs_get_attr_value(doc,attr);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
if (STRCASEEQ('a','A',"align", name)) {
if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
W_L(" align=\"");
static char *
s_chtml20_end_h6_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</h6>");
return chtml20->out;
static char *
s_chtml20_start_pre_tag(void *pdoc, Node *UNUSED(node))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
chtml20->pre_flag++;
W_L("<pre>");
static char *
s_chtml20_end_pre_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</pre>");
chtml20->pre_flag--;
static char *
s_chtml20_start_p_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
- char *align = NULL;
+ Attr *attr;
+ char *align = NULL;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
static char *
s_chtml20_end_p_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_chxjif_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
- Node *child;
+ chtml20_t *chtml20;
+ Doc *doc;
+ Node *child;
request_rec *r;
chtml20 = GET_CHTML20(pdoc);
static char *
s_chtml20_start_textarea_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- Attr *attr;
+ Attr *attr;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
static char *
s_chtml20_end_textarea_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- request_rec *r;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
- r = doc->r;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</textarea>");
chtml20->textarea_flag--;
static char *
s_chtml20_text_tag(void *pdoc, Node *child)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20;
+ Doc *doc;
request_rec *r;
- char *textval;
- char *tmp;
- char *tdst;
- char one_byte[2];
- int ii;
- int tdst_len;
+ char *textval;
+ char *tmp;
+ char *tdst;
+ char one_byte[2];
+ int ii;
+ int tdst_len;
+ apr_size_t z2h_input_len;
chtml20 = GET_CHTML20(pdoc);
doc = chtml20->doc;
tmp = apr_palloc(r->pool, qs_get_node_size(doc,child)+1);
memset(tmp, 0, qs_get_node_size(doc,child)+1);
- tdst = qs_alloc_zero_byte_string(r);
+ tdst = qs_alloc_zero_byte_string(doc->buf.pool);
memset(one_byte, 0, sizeof(one_byte));
tdst_len = 0;
for (ii=0; ii<qs_get_node_size(doc,child); ii++) {
- char* out;
+ char *out;
int rtn = s_chtml20_search_emoji(chtml20, &textval[ii], &out);
if (rtn != 0) {
tdst = qs_out_apr_pstrcat(r, tdst, out, &tdst_len);
tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
}
}
+ z2h_input_len = strlen(tdst);
+ tdst = chxj_conv_z2h(r, tdst, &z2h_input_len, chtml20->entryp);
+
W_V(tdst);
return chtml20->out;
}
static char *
s_chtml20_start_blockquote_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("<blockquote>");
return chtml20->out;
}
static char *
s_chtml20_end_blockquote_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
-
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</blockquote>");
return chtml20->out;
}
static char *
s_chtml20_start_dir_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("<dir>");
return chtml20->out;
}
static char *
s_chtml20_end_dir_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
W_L("</dir>");
return chtml20->out;
}
static char *
s_chtml20_start_dl_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("<dl>");
return chtml20->out;
}
static char *
s_chtml20_end_dl_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("</dl>");
return chtml20->out;
}
static char *
s_chtml20_start_dt_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("<dt>");
return chtml20->out;
}
static char *
s_chtml20_end_dt_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- chtml20 = GET_CHTML20(pdoc);
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+
return chtml20->out;
}
static char *
s_chtml20_start_dd_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
W_L("<dd>");
return chtml20->out;
}
static char *
s_chtml20_end_dd_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- chtml20 = GET_CHTML20(pdoc);
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+
return chtml20->out;
}
static char *
s_chtml20_start_menu_tag(void *pdoc, Node *UNUSED(child))
{
- chtml20_t *chtml20;
- Doc *doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+
W_L("<menu>");
return chtml20->out;
}
s_chtml20_end_menu_tag(void *pdoc, Node *UNUSED(child))
{
chtml20_t *chtml20 = GET_CHTML20(pdoc);
- Doc *doc = chtml20->doc;
+ Doc *doc = chtml20->doc;
+
W_L("</menu>");
return chtml20->out;
}
static char *
s_chtml20_start_plaintext_tag(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
W_L("<plaintext>");
s_chtml20_start_plaintext_tag_inner(pdoc,node);
return chtml20->out;
static char *
s_chtml20_start_plaintext_tag_inner(void *pdoc, Node *node)
{
- chtml20_t *chtml20;
- Doc *doc;
- Node *child;
- chtml20 = GET_CHTML20(pdoc);
- doc = chtml20->doc;
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+ Node *child;
+
for (child = qs_get_child_node(doc, node);
child;
child = qs_get_next_node(doc, child)) {
chtml20_t *chtml20 = GET_CHTML20(pdoc);
return chtml20->out;
}
+
+/**
+ * It is a hanblinker who processes the BLINK tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The BLINK tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml20_start_blink_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+ W_L("<blink>");
+ return chtml20->out;
+}
+
+
+/**
+ * It is a hanblinker who processes the BLINK tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The BLINK tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml20_end_blink_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+ W_L("</blink>");
+ return chtml20->out;
+}
+
+
+/**
+ * It is a hanmarqueeer who processes the MARQUEE tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The MARQUEE tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml20_start_marquee_tag(void *pdoc, Node *node)
+{
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+ Attr *attr;
+ W_L("<marquee");
+ /*--------------------------------------------------------------------------*/
+ /* Get Attributes */
+ /*--------------------------------------------------------------------------*/
+ for (attr = qs_get_attr(doc,node);
+ attr;
+ attr = qs_get_next_attr(doc,attr)) {
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ if (STRCASEEQ('d','D',"direction", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value))) {
+ W_L(" direction=\"");
+ W_V(value);
+ W_L("\"");
+ }
+ }
+ else if (STRCASEEQ('b','B',"behavior",name)) {
+ if (value && (STRCASEEQ('s','S',"scroll",value) || STRCASEEQ('s','S',"slide",value) || STRCASEEQ('a','A',"alternate",value))) {
+ W_L(" behavior=\"");
+ W_V(value);
+ W_L("\"");
+ }
+ }
+ else if (STRCASEEQ('l','L',"loop",name)) {
+ if (value && *value) {
+ W_L(" loop=\"");
+ W_V(value);
+ W_L("\"");
+ }
+ }
+ }
+ W_L(">");
+ return chtml20->out;
+}
+
+
+/**
+ * It is a hanmarqueeer who processes the MARQUEE tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The MARQUEE tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml20_end_marquee_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+ W_L("</marquee>");
+ return chtml20->out;
+}
+
+
+/**
+ * * It is handler who processes the New Line Code.
+ * */
+static char *
+s_chtml20_newline_mark(void *pdoc, Node *UNUSED(node))
+{
+ chtml20_t *chtml20 = GET_CHTML20(pdoc);
+ Doc *doc = chtml20->doc;
+ W_NLCODE();
+ return chtml20->out;
+}
/*
* vim:ts=2 et
*/