/*
+ * Copyright (C) 2005-2008 Atsushi Konno All rights reserved.
* Copyright (C) 2005 QSDN,Inc. All rights reserved.
- * Copyright (C) 2005 Atsushi Konno All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
#include "chxj_img_conv.h"
#include "chxj_qr_code.h"
#include "chxj_cookie.h"
+#include "chxj_encoding.h"
+#include "chxj_str_util.h"
+#include "chxj_buffered_write.h"
#define GET_CHTML10(X) ((chtml10_t*)(X))
-
-static char* s_chtml10_start_html_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_html_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_meta_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_meta_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_textarea_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_textarea_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_p_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_p_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_pre_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_pre_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_ul_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_ul_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_li_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_li_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_ol_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_ol_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_h1_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_h1_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_h2_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_h2_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_h3_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_h3_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_h4_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_h4_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_h5_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_h5_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_h6_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_h6_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_head_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_head_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_title_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_title_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_base_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_base_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_body_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_body_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_a_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_a_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_br_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_br_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_tr_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_tr_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_font_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_font_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_input_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_input_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_form_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_form_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_center_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_center_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_hr_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_hr_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_img_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_img_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_select_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_select_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_option_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_option_tag (void* pdoc, Node* node);
-static char* s_chtml10_start_div_tag (void* pdoc, Node* node);
-static char* s_chtml10_end_div_tag (void* pdoc, Node* node);
-
-static void s_init_chtml10(chtml10_t* chtml, Doc* doc, request_rec* r, device_table* spec);
-
-static int s_chtml10_search_emoji(chtml10_t* chtml, char* txt, char** rslt);
-static char* s_chtml10_chxjif_tag (void* pdoc, Node* node);
-static char* s_chtml10_text (void* pdoc, Node* node);
+#define W10_L(X) do { chtml10->out = BUFFERED_WRITE_LITERAL(chtml10->out, &doc->buf, (X)); } while(0)
+#define W10_V(X) do { chtml10->out = (X) ? BUFFERED_WRITE_VALUE(chtml10->out, &doc->buf, (X)) \
+ : BUFFERED_WRITE_LITERAL(chtml10->out, &doc->buf, ""); } while(0)
+
+static char *s_chtml10_start_html_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_html_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_meta_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_meta_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_textarea_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_textarea_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_p_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_p_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_pre_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_pre_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_ul_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_ul_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_li_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_li_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_ol_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_ol_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_h1_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_h1_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_h2_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_h2_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_h3_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_h3_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_h4_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_h4_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_h5_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_h5_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_h6_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_h6_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_head_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_head_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_title_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_title_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_base_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_base_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_body_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_body_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_a_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_a_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_br_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_br_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_tr_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_tr_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_font_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_font_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_input_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_input_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_form_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_form_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_center_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_center_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_hr_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_hr_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_img_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_img_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_select_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_select_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_option_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_option_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_div_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_div_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_blockquote_tag(void *pdoc, Node *node);
+static char *s_chtml10_end_blockquote_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_dir_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_dir_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_dl_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_dl_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_dt_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_dt_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_dd_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_dd_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_menu_tag (void *pdoc, Node *node);
+static char *s_chtml10_end_menu_tag (void *pdoc, Node *node);
+static char *s_chtml10_start_plaintext_tag(void *pdoc, Node *node);
+static char *s_chtml10_start_plaintext_tag_inner(void *pdoc, Node *node);
+static char *s_chtml10_end_plaintext_tag (void *pdoc, Node *node);
+
+static void s_init_chtml10(chtml10_t *chtml, Doc *doc, request_rec *r, device_table *spec);
+
+static int s_chtml10_search_emoji(chtml10_t *chtml, char *txt, char **rslt);
+static char *s_chtml10_chxjif_tag (void *pdoc, Node *node);
+static char *s_chtml10_text (void *pdoc, Node *node);
tag_handler chtml10_handler[] = {
/* tagHTML */
NULL,
NULL,
},
+ /* tagFIELDSET */
+ {
+ NULL,
+ NULL,
+ },
+ /* tagDT */
+ {
+ s_chtml10_start_dt_tag,
+ s_chtml10_end_dt_tag,
+ },
+ /* tagLEGEND */
+ {
+ NULL,
+ NULL,
+ },
+ /* tagLABEL */
+ {
+ NULL,
+ NULL,
+ },
+ /* tagBLOCKQUOTE */
+ {
+ s_chtml10_start_blockquote_tag,
+ s_chtml10_end_blockquote_tag,
+ },
+ /* tagDIR */
+ {
+ s_chtml10_start_dir_tag,
+ s_chtml10_end_dir_tag,
+ },
+ /* tagDL */
+ {
+ s_chtml10_start_dl_tag,
+ s_chtml10_end_dl_tag,
+ },
+ /* tagDD */
+ {
+ s_chtml10_start_dd_tag,
+ s_chtml10_end_dd_tag,
+ },
+ /* tagMENU */
+ {
+ s_chtml10_start_menu_tag,
+ s_chtml10_end_menu_tag,
+ },
+ /* tagPLAINTEXT */
+ {
+ s_chtml10_start_plaintext_tag,
+ s_chtml10_end_plaintext_tag,
+ },
+ /* tagBLINK */
+ {
+ NULL,
+ NULL,
+ },
+ /* tagMARQUEE */
+ {
+ NULL,
+ NULL,
+ },
};
* @param src [i] The character string before the converting is appointed.
* @return The character string after the converting is returned.
*/
-char*
+char *
chxj_exchange_chtml10(
- request_rec* r,
- device_table* spec,
- const char* src,
+ request_rec *r,
+ device_table *spec,
+ const char *src,
apr_size_t srclen,
- apr_size_t* dstlen,
- chxjconvrule_entry* entryp,
- const char* cookie_id
+ apr_size_t *dstlen,
+ chxjconvrule_entry *entryp,
+ cookie_t* cookie
)
{
- char* dst;
- char* ss;
+ char *dst;
+ char *ss;
chtml10_t chtml10;
Doc doc;
+ apr_time_t t;
dst = NULL;
- DBG1(r, "start chxj_exchange_chtml10() cookie_id=[%s]", cookie_id);
+ t = apr_time_now();
+ DBG(r, "start chxj_exchange_chtml10() cookie_id=[%s]", (cookie) ? cookie->cookie_id : "");
/*--------------------------------------------------------------------------*/
/* If qrcode xml */
/*--------------------------------------------------------------------------*/
s_init_chtml10(&chtml10, &doc, r, spec);
chtml10.entryp = entryp;
- chtml10.cookie_id = (char*)cookie_id;
+ chtml10.cookie = cookie;
- ap_set_content_type(r, "text/html; charset=Windows-31J");
+ chxj_set_content_type(r, "text/html; charset=Windows-31J");
/*--------------------------------------------------------------------------*/
/* The character string of the input is analyzed. */
qs_parse_string(&doc,ss, strlen(ss));
+ chxj_buffered_write_init(r->pool, &doc.buf);
/*--------------------------------------------------------------------------*/
/* It converts it from CHTML to CHTML. */
/*--------------------------------------------------------------------------*/
chxj_node_exchange(spec,r,(void*)&chtml10, &doc, qs_get_root(&doc), 0);
- dst = chtml10.out;
-
+ chtml10.out = chxj_buffered_write_flush(chtml10.out, &doc.buf);
+ dst = apr_pstrdup(r->pool, chtml10.out);
+ chxj_buffered_write_terminate(&doc.buf);
qs_all_free(&doc,QX_LOGMARK);
- if (!dst)
+ if (!dst) {
return apr_pstrdup(r->pool,ss);
+ }
if (strlen(dst) == 0) {
dst = apr_psprintf(r->pool, "\n");
chxj_dump_out("[dst] CHTML -> CHTML1.0", dst, *dstlen);
#endif
- DBG1(r, "end chxj_exchange_chtml10() cookie_id=[%s]", cookie_id);
+ DBG(r, "end chxj_exchange_chtml10() cookie_id=[%s] time=[%" APR_INT64_T_FMT "]", (cookie) ? cookie->cookie_id : "", apr_time_now() - t);
return dst;
}
*/
static void
s_init_chtml10(
- chtml10_t* chtml10,
- Doc* doc,
- request_rec* r,
- device_table* spec)
+ chtml10_t *chtml10,
+ Doc *doc,
+ request_rec *r,
+ device_table *spec)
{
memset(doc, 0, sizeof(Doc));
memset(chtml10, 0, sizeof(chtml10_t));
chtml10->doc = doc;
chtml10->spec = spec;
chtml10->out = qs_alloc_zero_byte_string(r);
- chtml10->conf = ap_get_module_config(r->per_dir_config, &chxj_module);
+ chtml10->conf = chxj_get_module_config(r->per_dir_config, &chxj_module);
chtml10->doc->parse_mode = PARSE_MODE_CHTML;
}
* @return When corresponding EMOJI exists, it returns it excluding 0.
*/
static int
-s_chtml10_search_emoji(chtml10_t* chtml10, char* txt, char** rslt)
+s_chtml10_search_emoji(chtml10_t *chtml10, 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 = chtml10->spec;
* @param node [i] The HTML tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_html_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_html_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
/*--------------------------------------------------------------------------*/
/* start HTML tag */
/*--------------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<html>\n", NULL);
+ W10_L("<html>");
return chtml10->out;
}
* @param node [i] The HTML tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_html_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_html_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</html>\n", NULL);
+ W10_L("</html>");
return chtml10->out;
}
* @param node [i] The META tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_meta_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_meta_tag(void *pdoc, Node *UNUSED(node))
{
- chtml10_t* chtml10;
-
- chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
/* ignore */
* @param node [i] The META tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_meta_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_meta_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
-
- chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The HEAD tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_head_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_head_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<head>\r\n", NULL);
+ W10_L("<head>");
return chtml10->out;
}
* @param node [i] The HEAD tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_head_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_head_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</head>\r\n", NULL);
+ W10_L("</head>");
return chtml10->out;
}
* @param node [i] The OL tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_ol_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_ol_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<ol>\r\n", NULL);
+ W10_L("<ol>");
return chtml10->out;
}
* @param node [i] The OL tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_ol_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_ol_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</ol>\r\n", NULL);
+ W10_L("</ol>");
return chtml10->out;
}
* @param node [i] The UL tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_ul_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_ul_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<ul>\r\n", NULL);
+ W10_L("<ul>");
return chtml10->out;
}
* @param node [i] The UL tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_ul_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_ul_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</ul>\r\n", NULL);
+ W10_L("</ul>");
return chtml10->out;
}
* @param node [i] The LI tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_li_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_li_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<li>\r\n", NULL);
+ W10_L("<li>");
return chtml10->out;
}
* @param node [i] The LI tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_li_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_li_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
-
- chtml10 = GET_CHTML10(pdoc);
- doc = chtml10->doc;
- r = doc->r;
-
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</li>\r\n", NULL);
-
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The H1 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_h1_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_h1_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<h1>\r\n", NULL);
+ W10_L("<h1");
+ 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('a','A',"align", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ break;
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The H1 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_h1_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_h1_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</h1>\r\n", NULL);
+ W10_L("</h1>");
return chtml10->out;
}
* @param node [i] The H2 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_h2_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_h2_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ Attr *attr;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<h2>\r\n", NULL);
+ W10_L("<h2");
+ 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);
+ if (STRCASEEQ('a','A',"align", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ break;
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The H2 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_h2_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_h2_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</h2>\r\n", NULL);
+ W10_L("</h2>");
return chtml10->out;
}
* @param node [i] The H3 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_h3_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_h3_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ Attr *attr;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<h3>\r\n", NULL);
+ W10_L("<h3");
+ 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('a','A',"align", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ break;
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The H3 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_h3_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_h3_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</h3>\r\n", NULL);
+ W10_L("</h3>");
return chtml10->out;
}
* @param node [i] The H4 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_h4_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_h4_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Attr *attr;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<h4>\r\n", NULL);
+ W10_L("<h4");
+ 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);
+ if (STRCASEEQ('a','A',"align", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ break;
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The H4 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_h4_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_h4_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</h4>\r\n", NULL);
+ W10_L("</h4>");
return chtml10->out;
}
* @param node [i] The H5 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_h5_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_h5_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
+ Attr *attr;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<h5>\r\n", NULL);
+ W10_L("<h5");
+ 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('a','A',"align", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ break;
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The H5 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_h5_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_h5_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</h5>\r\n", NULL);
+ W10_L("</h5>");
return chtml10->out;
}
* @param node [i] The H6 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_h6_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_h6_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
+ Attr *attr;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<h6>\r\n", NULL);
+ W10_L("<h6");
+ 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('a','A',"align", name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ break;
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The H6 tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_h6_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_h6_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</h6>\r\n", NULL);
+ W10_L("</h6>");
return chtml10->out;
}
* @param node [i] The TITLE tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_title_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_title_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<title>", NULL);
+ W10_L("<title>");
return chtml10->out;
}
* @param node [i] The TITLE tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_title_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_title_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</title>\r\n", NULL);
+ W10_L("</title>");
return chtml10->out;
}
* @param node [i] The BASE tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_base_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_base_tag(void *pdoc, Node *node)
{
- Attr* attr;
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ Attr *attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
-
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<base", NULL);
+ W10_L("<base");
/*--------------------------------------------------------------------------*/
/* 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 ((*name == 'h' || *name == 'H') && strcasecmp(name, "href") == 0) {
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " href=\"",
- value,
- "\"",
- NULL);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ if (STRCASEEQ('h','H',"href", name)) {
+ W10_L(" href=\"");
+ W10_V(value);
+ W10_L("\"");
}
}
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, " >\r\n", NULL);
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The BASE tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_base_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_base_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The BODY tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_body_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_body_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<body", NULL);
+
+ W10_L("<body");
/*--------------------------------------------------------------------------*/
/* 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);
- if ((*name == 'b' || *name == 'B') && strcasecmp(name, "bgcolor") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 2.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 't' || *name == 'T') && strcasecmp(name, "text") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 2.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'l' || *name == 'L') && strcasecmp(name, "link") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 2.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'a' || *name == 'A') && strcasecmp(name, "alink") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 4.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'v' || *name == 'V') && strcasecmp(name, "vlink") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 4.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
+ char *name = qs_get_attr_name(doc,attr);
+ switch(*name) {
+ case 'a':
+ case 'A':
+ if (strcasecmp(name, "alink") == 0) {
+ /*----------------------------------------------------------------------*/
+ /* CHTML 4.0 */
+ /*----------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'b':
+ case 'B':
+ if (strcasecmp(name, "bgcolor") == 0) {
+ /*----------------------------------------------------------------------*/
+ /* CHTML 2.0 */
+ /*----------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 't':
+ case 'T':
+ if (strcasecmp(name, "text") == 0) {
+ /*----------------------------------------------------------------------*/
+ /* CHTML 2.0 */
+ /*----------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'l':
+ case 'L':
+ if (strcasecmp(name, "link") == 0) {
+ /*----------------------------------------------------------------------*/
+ /* CHTML 2.0 */
+ /*----------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'v':
+ case 'V':
+ if (strcasecmp(name, "vlink") == 0) {
+ /*----------------------------------------------------------------------*/
+ /* CHTML 4.0 */
+ /*----------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ default:
+ break;
}
}
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">\r\n", NULL);
+
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The BODY tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_body_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_body_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</body>\r\n", NULL);
+ W10_L("</body>");
return chtml10->out;
}
* @param node [i] The A tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_a_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_a_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<a", NULL);
+ W10_L("<a");
/*--------------------------------------------------------------------------*/
/* 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);
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ switch(*name) {
+ case 'n':
+ case 'N':
+ if (strcasecmp(name, "name") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML1.0 */
+ /*--------------------------------------------------------------------*/
+ W10_L(" name=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
- if ((*name == 'n' || *name == 'N') && strcasecmp(name, "name") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " name=\"",
- value,
- "\"",
- NULL);
- }
- else
- if ((*name == 'h' || *name == 'H') && strcasecmp(name, "href") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML1.0 */
- /*----------------------------------------------------------------------*/
- value = chxj_add_cookie_parameter(r, value, chtml10->cookie_id);
-
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " href=\"",
- value,
- "\"",
- NULL);
- }
- else
- if ((*name == 'a' || *name == 'A') && strcasecmp(name, "accesskey") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " accesskey=\"",
- value,
- "\"",
- NULL);
- }
- else
- if ((*name == 'c' || *name == 'C') && strcasecmp(name, "cti") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 2.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'i' || *name == 'I') && strcasecmp(name, "ijam") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 3.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'u' || *name == 'U') && strcasecmp(name, "utn") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 3.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 't' || *name == 'T') && strcasecmp(name, "telbook") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 3.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'k' || *name == 'K') && strcasecmp(name, "kana") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 3.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'e' || *name == 'E') && strcasecmp(name, "email") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 3.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'i' || *name == 'I') && strcasecmp(name, "ista") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 4.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'i' || *name == 'I') && strcasecmp(name, "ilet") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 5.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'i' || *name == 'I') && strcasecmp(name, "iswf") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 5.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- else
- if ((*name == 'i' || *name == 'I') && strcasecmp(name, "irst") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 5.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
+ case 'h':
+ case 'H':
+ if (strcasecmp(name, "href") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML1.0 */
+ /*--------------------------------------------------------------------*/
+ value = chxj_encoding_parameter(r, value);
+ value = chxj_add_cookie_parameter(r, value, chtml10->cookie);
+ W10_L(" href=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
+
+ case 'a':
+ case 'A':
+ if (strcasecmp(name, "accesskey") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML1.0 */
+ /*--------------------------------------------------------------------*/
+ W10_L(" accesskey=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
+
+ case 'c':
+ case 'C':
+ if (strcasecmp(name, "cti") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 2.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'u':
+ case 'U':
+ if (strcasecmp(name, "utn") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 3.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 't':
+ case 'T':
+ if (strcasecmp(name, "telbook") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 3.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'k':
+ case 'K':
+ if (strcasecmp(name, "kana") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 3.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'e':
+ case 'E':
+ if (strcasecmp(name, "email") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 3.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ case 'i':
+ case 'I':
+ if (strcasecmp(name, "ista") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 4.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ else
+ if (strcasecmp(name, "ilet") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 5.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ else
+ if (strcasecmp(name, "iswf") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 5.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ else
+ if (strcasecmp(name, "irst") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 5.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ else
+ if (strcasecmp(name, "ijam") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 3.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ default:
+ break;
}
}
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">", NULL);
-
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The A tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_a_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_a_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</a>", NULL);
-
+ W10_L("</a>");
return chtml10->out;
}
* @param node [i] The BR tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_br_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_br_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr = NULL;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<br>\r\n", NULL);
+ W10_L("<br");
+ /*--------------------------------------------------------------------------*/
+ /* 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('c','C',"clear",name)) {
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('a','A',"all",value))) {
+ W10_L(" clear=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The BR tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_br_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_br_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The TR tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_tr_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_tr_tag(void *pdoc, Node *UNUSED(node))
{
- chtml10_t* chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The TR tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_tr_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_tr_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<br>\r\n", NULL);
+ W10_L("<br>\r\n");
return chtml10->out;
}
* @param node [i] The FONT tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_font_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_font_tag(void *pdoc, Node *UNUSED(node))
{
- chtml10_t* chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
/* Ignore */
* @param node [i] The FONT tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_font_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_font_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
/* ignore */
* @param node [i] The FORM tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_form_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_form_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
+ char *new_hidden_tag = NULL;
+ char *attr_value = NULL;
+ char *attr_method = NULL;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<form", NULL);
/*--------------------------------------------------------------------------*/
/* 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 ((*name == 'a' || *name == 'A') && strcasecmp(name, "action") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- value = chxj_add_cookie_parameter(r, value, chtml10->cookie_id);
-
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " action=\"",
- value,
- "\"",
- NULL);
- }
- else
- if ((*name == 'm' || *name == 'M') && strcasecmp(name, "method") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " method=\"",
- value,
- "\"",
- NULL);
- }
- else
- if ((*name == 'u' || *name == 'U') && strcasecmp(name, "utn") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 3.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
+ char *name = qs_get_attr_name(doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ switch(*name) {
+ case 'a':
+ case 'A':
+ if (strcasecmp(name, "action") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ attr_value = chxj_encoding_parameter(r, value);
+ attr_value = chxj_add_cookie_parameter(r, attr_value, chtml10->cookie);
+ }
+ break;
+
+ case 'm':
+ case 'M':
+ if (strcasecmp(name, "method") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ attr_method = apr_pstrdup(doc->pool, value);
+ }
+ break;
+
+ case 'u':
+ case 'U':
+ if (strcasecmp(name, "utn") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 3.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+
+ default:
+ break;
}
}
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">", NULL);
+ int post_flag = (attr_method && strcasecmp(attr_method, "post") == 0) ? 1 : 0;
+
+ W10_L("<form");
+ if (attr_value) {
+ char *q;
+ q = strchr(attr_value, '?');
+ if (q) {
+ new_hidden_tag = chxj_form_action_to_hidden_tag(r, doc->pool, attr_value, 0, post_flag);
+ if (new_hidden_tag) {
+ *q = 0;
+ }
+ }
+ W10_L(" action=\"");
+ W10_V(attr_value);
+ W10_L("\"");
+ }
+ if (attr_method) {
+ W10_L(" method=\"");
+ W10_V(attr_method);
+ W10_L("\"");
+ }
+ W10_L(">");
+ if (new_hidden_tag) {
+ W10_V(new_hidden_tag);
+ }
return chtml10->out;
}
* @param node [i] The FORM tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_form_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_form_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</form>", NULL);
+ W10_L("</form>");
return chtml10->out;
}
* @param node [i] The INPUT tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_input_tag(void* pdoc, Node* node)
-{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- char* max_length;
- char* type;
- char* name;
- char* value;
- char* istyle;
- char* size;
- char* checked;
- char* accesskey;
+static char *
+s_chtml10_start_input_tag(void *pdoc, Node *node)
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ char *max_length;
+ char *type;
+ char *name;
+ char *value;
+ char *istyle;
+ char *size;
+ char *checked;
+ char *accesskey;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
checked = NULL;
accesskey = NULL;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<input", NULL);
+ W10_L("<input");
/*--------------------------------------------------------------------------*/
/* Get Attributes */
accesskey = qs_get_accesskey_attr(doc, node, r);
size = qs_get_size_attr(doc, node, r);
- if (type)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " type=\"",
- type,
- "\" ",
- NULL);
-
- if (size)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " size=\"",
- size,
- "\" ",
- NULL);
-
- if (name)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " name=\"",
- name,
- "\" ",
- NULL);
-
- if (value)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " value=\"",
- value,
- "\" ",
- NULL);
-
- if (accesskey)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " accesskey=\"",
- accesskey, "\" ",
- NULL);
+ if (type) {
+ type = qs_trim_string(doc->buf.pool, type);
+ if (type && (STRCASEEQ('t','T',"text", type) ||
+ STRCASEEQ('p','P',"password",type) ||
+ STRCASEEQ('c','C',"checkbox",type) ||
+ STRCASEEQ('r','R',"radio", type) ||
+ STRCASEEQ('h','H',"hidden", type) ||
+ STRCASEEQ('s','S',"submit", type) ||
+ STRCASEEQ('r','R',"reset", type))) {
+ W10_L(" type=\"");
+ W10_V(type);
+ W10_L("\"");
+ }
+ }
+
+ if (size && *size != 0) {
+ W10_L(" size=\"");
+ W10_V(size);
+ W10_L("\"");
+ }
+
+ if (name && *name != 0) {
+ W10_L(" name=\"");
+ W10_V(name);
+ W10_L("\"");
+ }
+
+ if (value && *value != 0) {
+ W10_L(" value=\"");
+ W10_V(chxj_add_slash_to_doublequote(doc->pool,value));
+ W10_L("\"");
+ }
+
+ if (accesskey && *accesskey != 0) {
+ W10_L(" accesskey=\"");
+ W10_V(accesskey);
+ W10_L("\"");
+ }
if (istyle) {
/*------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------*/
/* The figure is default for the password. */
/*--------------------------------------------------------------------------*/
- if (max_length)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " maxlength=\"",
- max_length,
- "\"",
- NULL);
-
- if (checked)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " checked ", NULL);
+ if (max_length && *max_length != 0) {
+ W10_L(" maxlength=\"");
+ W10_V(max_length);
+ W10_L("\"");
+ }
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, " >", NULL);
+ if (checked) {
+ W10_L(" checked");
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The INPUT tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_input_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_input_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The CENTER tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_center_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_center_tag(void *pdoc, Node *UNUSED(node))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<center>", NULL);
+ W10_L("<center>");
return chtml10->out;
}
* @param node [i] The CENTER tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_center_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_center_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</center>", NULL);
+ W10_L("</center>");
return chtml10->out;
}
* @param node [i] The HR tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_hr_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_hr_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<hr ", NULL);
+ W10_L("<hr");
for (attr = qs_get_attr(doc,node);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* name;
- char* value;
+ char *name = qs_get_attr_name (doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ switch(*name) {
+ case 'a':
+ case 'A':
+ if (strcasecmp(name, "align") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ }
+ break;
- name = qs_get_attr_name (doc,attr);
- value = qs_get_attr_value(doc,attr);
+ case 's':
+ case 'S':
+ if (strcasecmp(name, "size") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ if (value && value[0] != '\0') {
+ W10_L(" size=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ }
+ break;
- if ((*name == 'a' || *name == 'A') && strcasecmp(name, "align") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " align=\"", value, "\" ", NULL);
- }
- else
- if ((*name == 's' || *name == 'S') && strcasecmp(name, "size") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " size=\"", value, "\" ", NULL);
- }
- else
- if ((*name == 'w' || *name == 'W') && strcasecmp(name, "width") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " width=\"", value, "\" ", NULL);
- }
- else
- if ((*name == 'n' || *name == 'N') && strcasecmp(name, "noshade") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " noshade ", NULL);
- }
- else
- if ((*name == 'c' || *name == 'C') && strcasecmp(name, "color") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 4.0 */
- /*----------------------------------------------------------------------*/
- /* ignore */
- }
- }
+ case 'w':
+ case 'W':
+ if (strcasecmp(name, "width") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ if (value && value[0] != '\0') {
+ W10_L(" width=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ }
+ break;
+
+ case 'n':
+ case 'N':
+ if (strcasecmp(name, "noshade") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ W10_L(" noshade");
+ }
+ break;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, " >", NULL);
+ case 'c':
+ case 'C':
+ if (strcasecmp(name, "color") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 4.0 */
+ /*--------------------------------------------------------------------*/
+ /* ignore */
+ }
+ break;
+ default:
+ break;
+ }
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The HR tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_hr_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_hr_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
- chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The IMG tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_img_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_img_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
#ifndef IMG_NOT_CONVERT_FILENAME
- device_table_t* spec;
+ device_table *spec;
#endif
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<img", NULL);
-
-
+ W10_L("<img");
/*--------------------------------------------------------------------------*/
/* 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);
-
- if ((*name == 's' || *name == 'S') && strcasecmp(name, "src") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
+ char *name = qs_get_attr_name (doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ switch(*name) {
+ case 's':
+ case 'S':
+ if (strcasecmp(name, "src") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
#ifdef IMG_NOT_CONVERT_FILENAME
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " src=\"",value,"\"", NULL);
+ value = chxj_encoding_parameter(r, value);
+ value = chxj_add_cookie_parameter(r, value, chtml10->cookie);
+ if (value) {
+ value = apr_psprintf(doc->buf.pool,
+ "%s%c%s=true",
+ value,
+ (strchr(value, '?')) ? '&' : '?',
+ CHXJ_COOKIE_NOUPDATE_PARAM);
+ }
+ W10_L(" src=\"");
+ W10_V(value);
+ W10_L("\"");
#else
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " src=\"",
- chxj_img_conv(r, spec, value), NULL);
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "\"", NULL);
+ value = chxj_img_conv(r, spec, value);
+ value = chxj_encoding_parameter(r, value);
+ value = chxj_add_cookie_parameter(r, value, chtml10->cookie);
+ if (value) {
+ value = apr_psprintf(doc->buf.pool,
+ "%s%c%s=true",
+ value,
+ (strchr(value, '?')) ? '&' : '?',
+ CHXJ_COOKIE_NOUPDATE_PARAM);
+ }
+ W10_L(" src=\"");
+ W10_V(value);
+ W10_L("\"");
#endif
- }
- else
- if (*name == 'a' || *name == 'A') {
+ }
+ break;
+
+ case 'a':
+ case 'A':
if (strcasecmp(name, "align" ) == 0) {
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
/* CHTML 4.0 */
/*--------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " align=\"",value,"\"", NULL);
+ 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))) {
+ W10_L(" align=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
}
- else
- if (strcasecmp(name, "alt" ) == 0) {
+ else if (strcasecmp(name, "alt" ) == 0) {
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " alt=\"",value,"\"", NULL);
+ if (value && value[0] != '\0') {
+ W10_L(" alt=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
}
- }
- else
- if ((*name == 'w' || *name == 'W') && strcasecmp(name, "width" ) == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " width=\"",value,"\"", NULL);
- }
- else
- if (*name == 'h' || *name == 'H') {
+ break;
+
+ case 'w':
+ case 'W':
+ if (strcasecmp(name, "width" ) == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ if (value && value[0] != '\0') {
+ W10_L(" width=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ }
+ break;
+
+ case 'h':
+ case 'H':
if (strcasecmp(name, "height") == 0) {
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " height=\"",value,"\"", NULL);
+ if (value && value[0] != '\0') {
+ W10_L(" height=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
}
else
if (strcasecmp(name, "hspace") == 0) {
/*--------------------------------------------------------------------*/
/* CHTML 1.0 */
/*--------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " hspace=\"",value,"\"", NULL);
+ if (value && value[0] != '\0') {
+ W10_L(" hspace=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
}
- }
- else
- if ((*name == 'v' || *name == 'V') && strcasecmp(name, "vspace") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 */
- /*----------------------------------------------------------------------*/
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " vspace=\"",value,"\"", NULL);
+ break;
+
+ case 'v':
+ case 'V':
+ if (strcasecmp(name, "vspace") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 */
+ /*--------------------------------------------------------------------*/
+ if (value && value[0] != '\0') {
+ W10_L(" vspace=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ }
+ break;
+
+ default:
+ break;
}
}
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">", NULL);
-
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The IMG tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_img_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_img_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
-
- chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
* @param node [i] The SELECT tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_select_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_start_select_tag(void *pdoc, Node *child)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
- char* size;
- char* name;
+ char *size;
+ char *name;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
size = NULL;
name = NULL;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<select", NULL);
+ W10_L("<select");
for (attr = qs_get_attr(doc,child);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* nm;
- char* val;
+ char *nm = qs_get_attr_name (doc,attr);
+ char *val = qs_get_attr_value(doc,attr);
+ switch(*nm) {
+ case 's':
+ case 'S':
+ if (strcasecmp(nm, "size") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 version 2.0 */
+ /*--------------------------------------------------------------------*/
+ size = apr_pstrdup(doc->buf.pool, val);
+ }
+ break;
- nm = qs_get_attr_name (doc,attr);
- val = qs_get_attr_value(doc,attr);
+ case 'n':
+ case 'N':
+ if (strcasecmp(nm, "name") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 version 2.0 */
+ /*--------------------------------------------------------------------*/
+ name = apr_pstrdup(doc->buf.pool, val);
+ }
+ break;
- if ((*nm == 's' || *nm == 'S') && strcasecmp(nm, "size") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 version 2.0 */
- /*----------------------------------------------------------------------*/
- size = apr_pstrdup(r->pool, val);
- }
- else
- if ((*nm == 'n' || *nm == 'N') && strcasecmp(nm, "name") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 version 2.0 */
- /*----------------------------------------------------------------------*/
- name = apr_pstrdup(r->pool, val);
- }
- else
- if ((*nm == 'm' || *nm == 'M') && strcasecmp(nm, "multiple") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 version 2.0 */
- /*----------------------------------------------------------------------*/
- /* Ignore */
+ case 'm':
+ case 'M':
+ if (strcasecmp(nm, "multiple") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 version 2.0 */
+ /*--------------------------------------------------------------------*/
+ /* Ignore */
+ }
+ break;
+
+ default:
+ break;
}
}
- if (size)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " size=\"",
- size,
- "\"",
- NULL);
-
- if (name)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " name=\"",
- name,
- "\"",
- NULL);
+ if (size && *size != 0) {
+ W10_L(" size=\"");
+ W10_V(size);
+ W10_L("\"");
+ }
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">\n", NULL);
+ if (name && *name != 0) {
+ W10_L(" name=\"");
+ W10_V(name);
+ W10_L("\"");
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The SELECT tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_select_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_select_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</select>\n", NULL);
-
+ W10_L("</select>");
return chtml10->out;
}
* @param node [i] The OPTION tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_option_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_start_option_tag(void *pdoc, Node *child)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
-
- char* selected;
- char* value;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
+ char *selected;
+ char *value;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
selected = NULL;
value = NULL;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<option", NULL);
+ W10_L("<option");
+
for (attr = qs_get_attr(doc,child);
attr;
attr = qs_get_next_attr(doc,attr)) {
- char* nm;
- char* val;
+ char *nm = qs_get_attr_name (doc,attr);
+ char *val = qs_get_attr_value(doc,attr);
+ switch(*nm) {
+ case 's':
+ case 'S':
+ if (strcasecmp(nm, "selected") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 version 2.0 */
+ /*--------------------------------------------------------------------*/
+ selected = apr_pstrdup(doc->buf.pool, val);
+ }
+ break;
- nm = qs_get_attr_name (doc,attr);
- val = qs_get_attr_value(doc,attr);
+ case 'v':
+ case 'V':
+ if (strcasecmp(nm, "value") == 0) {
+ /*--------------------------------------------------------------------*/
+ /* CHTML 1.0 version 2.0 */
+ /*--------------------------------------------------------------------*/
+ value = apr_pstrdup(doc->buf.pool, val);
+ }
+ break;
- if ((*nm == 's' || *nm == 'S') && strcasecmp(nm, "selected") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 version 2.0 */
- /*----------------------------------------------------------------------*/
- selected = apr_pstrdup(r->pool, val);
- }
- else
- if ((*nm == 'v' || *nm == 'V') && strcasecmp(nm, "value") == 0) {
- /*----------------------------------------------------------------------*/
- /* CHTML 1.0 version 2.0 */
- /*----------------------------------------------------------------------*/
- value = apr_pstrdup(r->pool, val);
+ default:
+ break;
}
}
- if (value)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " value=\"",
- value,
- "\"",
- NULL);
- else
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " value=\"\"",
- NULL);
-
- if (selected)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out,
- " selected ",
- NULL);
+ if (value && *value != 0) {
+ W10_L(" value=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">", NULL);
+ if (selected) {
+ W10_L(" selected");
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The OPTION tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_option_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_option_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
-
- chtml10 = GET_CHTML10(pdoc);
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
/* Don't close */
* @param node [i] The DIV tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_div_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_start_div_tag(void *pdoc, Node *child)
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
- Attr* attr;
-
- char* align;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
+ Attr *attr;
+ char *align;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
align = NULL;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<div", NULL);
+ W10_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);
-
- if ((*nm == 'a' || *nm == 'A') && strcasecmp(nm, "align") == 0) {
+ 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) */
/*----------------------------------------------------------------------*/
- align = apr_pstrdup(r->pool, val);
+ if (val && (STRCASEEQ('l','L',"left",val) || STRCASEEQ('r','R',"right",val) || STRCASEEQ('c','C',"center",val))) {
+ align = apr_pstrdup(doc->buf.pool, val);
+ }
}
}
- if (align)
- chtml10->out = apr_pstrcat(r->pool,
- chtml10->out, " align=\"", align, "\"", NULL);
-
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">", NULL);
+ if (align) {
+ W10_L(" align=\"");
+ W10_V(align);
+ W10_L("\"");
+ }
+ W10_L(">");
return chtml10->out;
}
* @param node [i] The DIV tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_div_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_div_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</div>\n", NULL);
-
+ W10_L("</div>");
return chtml10->out;
}
* @param node [i] The CHXJ:IF tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_chxjif_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_chxjif_tag(void *pdoc, Node *node)
{
- chtml10_t* chtml10;
- Doc* doc;
- Node* child;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ Node *child;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
for (child = qs_get_child_node(doc, node);
child;
child = qs_get_next_node(doc, child)) {
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, child->otext, NULL);
+ W10_V(child->otext);
s_chtml10_chxjif_tag(chtml10, child);
}
* @param node [i] The PRE tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_pre_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_pre_tag(void *pdoc, Node *UNUSED(node))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
chtml10->pre_flag++;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<pre>", NULL);
-
+ W10_L("<pre>");
return chtml10->out;
}
* @param node [i] The PRE tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_pre_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_pre_tag(void *pdoc, Node *UNUSED(child))
{
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</pre>", NULL);
+ W10_L("</pre>");
chtml10->pre_flag--;
return chtml10->out;
* @param node [i] The P tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_p_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_p_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
+ Attr *attr;
+ char *align = NULL;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<p>", NULL);
+ W10_L("<p");
+ for (attr = qs_get_attr(doc,node);
+ attr;
+ attr = qs_get_next_attr(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 (val && (STRCASEEQ('l','L',"left",val) || STRCASEEQ('r','R',"right",val) || STRCASEEQ('c','C',"center",val))) {
+ align = apr_pstrdup(doc->buf.pool, val);
+ break;
+ }
+ }
+ }
+ if (align) {
+ W10_L(" align=\"");
+ W10_V(align);
+ W10_L("\"");
+ }
+ W10_L(">");
return chtml10->out;
}
+
/**
* It is a handler who processes the P tag.
*
* @param node [i] The P tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_p_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_p_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</p>", NULL);
-
+ W10_L("</p>");
return chtml10->out;
}
+
/**
* It is a handler who processes the TEXTARE tag.
*
* @param node [i] The TEXTAREA tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_start_textarea_tag(void* pdoc, Node* node)
+static char *
+s_chtml10_start_textarea_tag(void *pdoc, Node *node)
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
- Attr* attr;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
+ Attr *attr;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
chtml10->textarea_flag++;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "<textarea ", NULL);
+
+ W10_L("<textarea");
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 ((*name == 'n' || *name == 'N') && strcasecmp(name, "name") == 0) {
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, " name=\"",value,"\"", NULL);
- }
- else
- if ((*name == 'r' || *name == 'R') && strcasecmp(name, "rows") == 0) {
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, " rows=\"",value,"\"", NULL);
- }
- else
- if ((*name == 'c' || *name == 'C') && strcasecmp(name, "cols") == 0) {
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, " cols=\"",value,"\"", NULL);
+ char *name = qs_get_attr_name (doc,attr);
+ char *value = qs_get_attr_value(doc,attr);
+ switch(*name) {
+ case 'a':
+ case 'A':
+ if (strcasecmp(name, "accesskey") == 0 && value && *value != 0) {
+ W10_L(" accesskey=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
+
+ case 'n':
+ case 'N':
+ if (strcasecmp(name, "name") == 0 && value && *value != 0) {
+ W10_L(" name=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
+
+ case 'r':
+ case 'R':
+ if (strcasecmp(name, "rows") == 0 && value && *value != 0) {
+ W10_L(" rows=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
+
+ case 'c':
+ case 'C':
+ if (strcasecmp(name, "cols") == 0 && value && *value != 0) {
+ W10_L(" cols=\"");
+ W10_V(value);
+ W10_L("\"");
+ }
+ break;
+
+ default:
+ break;
}
}
-
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, ">\r\n", NULL);
-
+ W10_L(">");
return chtml10->out;
}
+
/**
* It is a handler who processes the TEXTAREA tag.
*
* @param node [i] The TEXTAREA tag node is specified.
* @return The conversion result is returned.
*/
-static char*
-s_chtml10_end_textarea_tag(void* pdoc, Node* child)
+static char *
+s_chtml10_end_textarea_tag(void *pdoc, Node *UNUSED(child))
{
- Doc* doc;
- request_rec* r;
- chtml10_t* chtml10;
+ Doc *doc;
+ request_rec *r;
+ chtml10_t *chtml10;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, "</textarea>\r\n", NULL);
+ W10_L("</textarea>");
chtml10->textarea_flag--;
return chtml10->out;
}
-static char*
-s_chtml10_text(void* pdoc, Node* child)
+static char *
+s_chtml10_text(void *pdoc, Node *child)
{
- char* textval;
- char* tmp;
- char* tdst;
- char one_byte[2];
- int ii;
- int tdst_len;
- chtml10_t* chtml10;
- Doc* doc;
- request_rec* r;
+ char *textval;
+ char *tmp;
+ char *tdst;
+ char one_byte[2];
+ int ii;
+ int tdst_len;
+ chtml10_t *chtml10;
+ Doc *doc;
+ request_rec *r;
chtml10 = GET_CHTML10(pdoc);
doc = chtml10->doc;
r = doc->r;
-
+
textval = qs_get_node_value(doc,child);
- textval = qs_trim_string(r, textval);
- if (strlen(textval) == 0)
+ if (strlen(textval) == 0) {
return chtml10->out;
+ }
tmp = apr_palloc(r->pool, qs_get_node_size(doc,child)+1);
memset(tmp, 0, qs_get_node_size(doc,child)+1);
tdst_len = 0;
for (ii=0; ii<qs_get_node_size(doc,child); ii++) {
- char* out;
- int rtn = s_chtml10_search_emoji(chtml10, &textval[ii], &out);
+ char *out;
+ int rtn;
+
+ rtn = s_chtml10_search_emoji(chtml10, &textval[ii], &out);
if (rtn) {
tdst = qs_out_apr_pstrcat(r, tdst, out, &tdst_len);
ii+=(rtn - 1);
tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
}
}
- chtml10->out = apr_pstrcat(r->pool, chtml10->out, tdst, NULL);
+ W10_V(tdst);
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handler who processes the BLOCKQUOTE tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The BLOCKQUOTE tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_blockquote_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<blockquote>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handler who processes the BLOCKQUOTE tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The BLOCKQUOTE tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_blockquote_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("</blockquote>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handler who processes the DIR tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DIR tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_dir_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<dir>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handler who processes the DIR tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DIR tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_dir_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("</dir>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handler who processes the DL tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DL tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_dl_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<dl>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handler who processes the DL tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DL tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_dl_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("</dl>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handter who processes the DT tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DT tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_dt_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<dt>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handter who processes the DT tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DT tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_dt_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ chtml10 = GET_CHTML10(pdoc);
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handder who processes the DD tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DD tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_dd_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<dd>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a handder who processes the DD tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The DD tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_dd_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ chtml10 = GET_CHTML10(pdoc);
+ return chtml10->out;
+}
+
+
+/**
+ * It is a hanmenuer who processes the MENU tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The MENU tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_menu_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<menu>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a hanmenuer who processes the MENU tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The MENU tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_menu_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
+ Doc *doc = chtml10->doc;
+ W10_L("</menu>");
+ return chtml10->out;
+}
+
+
+/**
+ * It is a hanplaintexter who processes the PLAINTEXT tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The PLAINTEXT tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_start_plaintext_tag(void *pdoc, Node *node)
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ W10_L("<plaintext>");
+ s_chtml10_start_plaintext_tag_inner(pdoc,node);
+ return chtml10->out;
+}
+
+static char *
+s_chtml10_start_plaintext_tag_inner(void *pdoc, Node *node)
+{
+ chtml10_t *chtml10;
+ Doc *doc;
+ Node *child;
+ chtml10 = GET_CHTML10(pdoc);
+ doc = chtml10->doc;
+ for (child = qs_get_child_node(doc, node);
+ child;
+ child = qs_get_next_node(doc, child)) {
+ W10_V(child->otext);
+ s_chtml10_start_plaintext_tag_inner(pdoc, child);
+ }
+ return chtml10->out;
+}
+
+
+/**
+ * It is a hanplaintexter who processes the PLAINTEXT tag.
+ *
+ * @param pdoc [i/o] The pointer to the CHTML structure at the output
+ * destination is specified.
+ * @param node [i] The PLAINTEXT tag node is specified.
+ * @return The conversion result is returned.
+ */
+static char *
+s_chtml10_end_plaintext_tag(void *pdoc, Node *UNUSED(child))
+{
+ chtml10_t *chtml10 = GET_CHTML10(pdoc);
return chtml10->out;
}
/*