2 * Copyright (C) 2005-2008 Atsushi Konno All rights reserved.
3 * Copyright (C) 2005 QSDN,Inc. All rights reserved.
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
18 #include "chxj_encoding.h"
19 #include "chxj_xhtml_mobile_1_0.h"
20 #include "chxj_hdml.h"
21 #include "chxj_dump.h"
22 #include "chxj_img_conv.h"
23 #include "chxj_qr_code.h"
24 #include "chxj_buffered_write.h"
25 #include "chxj_str_util.h"
26 #include "chxj_header_inf.h"
28 #define GET_XHTML(X) ((xhtml_t*)(X))
31 #define W_L(X) do { xhtml->out = BUFFERED_WRITE_LITERAL(xhtml->out, &doc->buf, (X)); } while(0)
32 #define W_V(X) do { xhtml->out = (X) ? BUFFERED_WRITE_VALUE(xhtml->out, &doc->buf, (X)) \
33 : BUFFERED_WRITE_LITERAL(xhtml->out, &doc->buf, ""); } while(0)
35 #define W_NLCODE() do { char *nlcode = TO_NLCODE(xhtml->conf); W_V(nlcode); } while (0)
37 static char *s_xhtml_1_0_start_html_tag (void *pdoc, Node *node);
38 static char *s_xhtml_1_0_end_html_tag (void *pdoc, Node *node);
39 static char *s_xhtml_1_0_start_p_tag (void *pdoc, Node *node);
40 static char *s_xhtml_1_0_end_p_tag (void *pdoc, Node *node);
41 static char *s_xhtml_1_0_start_pre_tag (void *pdoc, Node *node);
42 static char *s_xhtml_1_0_end_pre_tag (void *pdoc, Node *node);
43 static char *s_xhtml_1_0_start_ul_tag (void *pdoc, Node *node);
44 static char *s_xhtml_1_0_end_ul_tag (void *pdoc, Node *node);
45 static char *s_xhtml_1_0_start_h1_tag (void *pdoc, Node *node);
46 static char *s_xhtml_1_0_end_h1_tag (void *pdoc, Node *node);
47 static char *s_xhtml_1_0_start_h2_tag (void *pdoc, Node *node);
48 static char *s_xhtml_1_0_end_h2_tag (void *pdoc, Node *node);
49 static char *s_xhtml_1_0_start_h3_tag (void *pdoc, Node *node);
50 static char *s_xhtml_1_0_end_h3_tag (void *pdoc, Node *node);
51 static char *s_xhtml_1_0_start_h4_tag (void *pdoc, Node *node);
52 static char *s_xhtml_1_0_end_h4_tag (void *pdoc, Node *node);
53 static char *s_xhtml_1_0_start_h5_tag (void *pdoc, Node *node);
54 static char *s_xhtml_1_0_end_h5_tag (void *pdoc, Node *node);
55 static char *s_xhtml_1_0_start_h6_tag (void *pdoc, Node *node);
56 static char *s_xhtml_1_0_end_h6_tag (void *pdoc, Node *node);
57 static char *s_xhtml_1_0_start_ol_tag (void *pdoc, Node *node);
58 static char *s_xhtml_1_0_end_ol_tag (void *pdoc, Node *node);
59 static char *s_xhtml_1_0_start_li_tag (void *pdoc, Node *node);
60 static char *s_xhtml_1_0_end_li_tag (void *pdoc, Node *node);
61 static char *s_xhtml_1_0_start_meta_tag (void *pdoc, Node *node);
62 static char *s_xhtml_1_0_end_meta_tag (void *pdoc, Node *node);
63 static char *s_xhtml_1_0_start_head_tag (void *pdoc, Node *node);
64 static char *s_xhtml_1_0_end_head_tag (void *pdoc, Node *node);
65 static char *s_xhtml_1_0_start_title_tag (void *pdoc, Node *node);
66 static char *s_xhtml_1_0_end_title_tag (void *pdoc, Node *node);
67 static char *s_xhtml_1_0_start_base_tag (void *pdoc, Node *node);
68 static char *s_xhtml_1_0_end_base_tag (void *pdoc, Node *node);
69 static char *s_xhtml_1_0_start_body_tag (void *pdoc, Node *node);
70 static char *s_xhtml_1_0_end_body_tag (void *pdoc, Node *node);
71 static char *s_xhtml_1_0_start_a_tag (void *pdoc, Node *node);
72 static char *s_xhtml_1_0_end_a_tag (void *pdoc, Node *node);
73 static char *s_xhtml_1_0_start_br_tag (void *pdoc, Node *node);
74 static char *s_xhtml_1_0_end_br_tag (void *pdoc, Node *node);
75 static char *s_xhtml_1_0_start_tr_tag (void *pdoc, Node *node);
76 static char *s_xhtml_1_0_end_tr_tag (void *pdoc, Node *node);
77 static char *s_xhtml_1_0_start_font_tag (void *pdoc, Node *node);
78 static char *s_xhtml_1_0_end_font_tag (void *pdoc, Node *node);
79 static char *s_xhtml_1_0_start_form_tag (void *pdoc, Node *node);
80 static char *s_xhtml_1_0_end_form_tag (void *pdoc, Node *node);
81 static char *s_xhtml_1_0_start_input_tag (void *pdoc, Node *node);
82 static char *s_xhtml_1_0_end_input_tag (void *pdoc, Node *node);
83 static char *s_xhtml_1_0_start_center_tag (void *pdoc, Node *node);
84 static char *s_xhtml_1_0_end_center_tag (void *pdoc, Node *node);
85 static char *s_xhtml_1_0_start_hr_tag (void *pdoc, Node *node);
86 static char *s_xhtml_1_0_end_hr_tag (void *pdoc, Node *node);
87 static char *s_xhtml_1_0_start_img_tag (void *pdoc, Node *node);
88 static char *s_xhtml_1_0_end_img_tag (void *pdoc, Node *node);
89 static char *s_xhtml_1_0_start_select_tag (void *pdoc, Node *node);
90 static char *s_xhtml_1_0_end_select_tag (void *pdoc, Node *node);
91 static char *s_xhtml_1_0_start_option_tag (void *pdoc, Node *node);
92 static char *s_xhtml_1_0_end_option_tag (void *pdoc, Node *node);
93 static char *s_xhtml_1_0_start_div_tag (void *pdoc, Node *node);
94 static char *s_xhtml_1_0_end_div_tag (void *pdoc, Node *node);
95 static char *s_xhtml_1_0_start_textarea_tag (void *pdoc, Node *node);
96 static char *s_xhtml_1_0_end_textarea_tag (void *pdoc, Node *node);
97 static char *s_xhtml_1_0_start_b_tag (void *pdoc, Node *node);
98 static char *s_xhtml_1_0_end_b_tag (void *pdoc, Node *node);
99 static char *s_xhtml_1_0_chxjif_tag (void *pdoc, Node *node);
100 static char *s_xhtml_1_0_start_blockquote_tag(void *pdoc, Node *node);
101 static char *s_xhtml_1_0_end_blockquote_tag (void *pdoc, Node *node);
102 static char *s_xhtml_1_0_start_dir_tag (void *pdoc, Node *node);
103 static char *s_xhtml_1_0_end_dir_tag (void *pdoc, Node *node);
104 static char *s_xhtml_1_0_start_dl_tag (void *pdoc, Node *node);
105 static char *s_xhtml_1_0_end_dl_tag (void *pdoc, Node *node);
106 static char *s_xhtml_1_0_start_dt_tag (void *pdoc, Node *node);
107 static char *s_xhtml_1_0_end_dt_tag (void *pdoc, Node *node);
108 static char *s_xhtml_1_0_start_dd_tag (void *pdoc, Node *node);
109 static char *s_xhtml_1_0_end_dd_tag (void *pdoc, Node *node);
110 static char *s_xhtml_1_0_start_menu_tag (void *pdoc, Node *node);
111 static char *s_xhtml_1_0_end_menu_tag (void *pdoc, Node *node);
112 static char *s_xhtml_1_0_start_plaintext_tag (void *pdoc, Node *node);
113 static char *s_xhtml_1_0_start_plaintext_tag_inner (void *pdoc, Node *node);
114 static char *s_xhtml_1_0_end_plaintext_tag (void *pdoc, Node *node);
115 static char *s_xhtml_1_0_start_blink_tag (void *pdoc, Node *node);
116 static char *s_xhtml_1_0_end_blink_tag (void *pdoc, Node *node);
117 static char *s_xhtml_1_0_start_marquee_tag (void *pdoc, Node *node);
118 static char *s_xhtml_1_0_end_marquee_tag (void *pdoc, Node *node);
119 static char *s_xhtml_1_0_newline_mark (void *pdoc, Node *node);
121 static void s_init_xhtml(xhtml_t *xhtml, Doc *doc, request_rec *r, device_table *spec);
122 static int s_xhtml_search_emoji(xhtml_t *xhtml, char *txt, char **rslt);
123 static char *s_xhtml_1_0_text_tag(void *pdoc, Node *child);
126 tag_handler xhtml_handler[] = {
129 s_xhtml_1_0_start_html_tag,
130 s_xhtml_1_0_end_html_tag,
134 s_xhtml_1_0_start_meta_tag,
135 s_xhtml_1_0_end_meta_tag,
139 s_xhtml_1_0_start_textarea_tag,
140 s_xhtml_1_0_end_textarea_tag,
144 s_xhtml_1_0_start_p_tag,
145 s_xhtml_1_0_end_p_tag,
149 s_xhtml_1_0_start_pre_tag,
150 s_xhtml_1_0_end_pre_tag,
154 s_xhtml_1_0_start_ul_tag,
155 s_xhtml_1_0_end_ul_tag,
159 s_xhtml_1_0_start_li_tag,
160 s_xhtml_1_0_end_li_tag,
164 s_xhtml_1_0_start_ol_tag,
165 s_xhtml_1_0_end_ol_tag,
169 s_xhtml_1_0_start_h1_tag,
170 s_xhtml_1_0_end_h1_tag,
174 s_xhtml_1_0_start_h2_tag,
175 s_xhtml_1_0_end_h2_tag,
179 s_xhtml_1_0_start_h3_tag,
180 s_xhtml_1_0_end_h3_tag,
184 s_xhtml_1_0_start_h4_tag,
185 s_xhtml_1_0_end_h4_tag,
189 s_xhtml_1_0_start_h5_tag,
190 s_xhtml_1_0_end_h5_tag,
194 s_xhtml_1_0_start_h6_tag,
195 s_xhtml_1_0_end_h6_tag,
199 s_xhtml_1_0_start_head_tag,
200 s_xhtml_1_0_end_head_tag,
204 s_xhtml_1_0_start_title_tag,
205 s_xhtml_1_0_end_title_tag,
209 s_xhtml_1_0_start_base_tag,
210 s_xhtml_1_0_end_base_tag,
214 s_xhtml_1_0_start_body_tag,
215 s_xhtml_1_0_end_body_tag,
219 s_xhtml_1_0_start_a_tag,
220 s_xhtml_1_0_end_a_tag,
224 s_xhtml_1_0_start_br_tag,
225 s_xhtml_1_0_end_br_tag,
234 s_xhtml_1_0_start_tr_tag,
235 s_xhtml_1_0_end_tr_tag,
249 s_xhtml_1_0_start_font_tag,
250 s_xhtml_1_0_end_font_tag,
254 s_xhtml_1_0_start_form_tag,
255 s_xhtml_1_0_end_form_tag,
259 s_xhtml_1_0_start_input_tag,
260 s_xhtml_1_0_end_input_tag,
264 s_xhtml_1_0_start_center_tag,
265 s_xhtml_1_0_end_center_tag,
269 s_xhtml_1_0_start_hr_tag,
270 s_xhtml_1_0_end_hr_tag,
274 s_xhtml_1_0_start_img_tag,
275 s_xhtml_1_0_end_img_tag,
279 s_xhtml_1_0_start_select_tag,
280 s_xhtml_1_0_end_select_tag,
284 s_xhtml_1_0_start_option_tag,
285 s_xhtml_1_0_end_option_tag,
289 s_xhtml_1_0_start_div_tag,
290 s_xhtml_1_0_end_div_tag,
294 s_xhtml_1_0_chxjif_tag,
319 s_xhtml_1_0_text_tag,
329 s_xhtml_1_0_start_b_tag,
330 s_xhtml_1_0_end_b_tag,
339 s_xhtml_1_0_start_dt_tag,
340 s_xhtml_1_0_end_dt_tag,
354 s_xhtml_1_0_start_blockquote_tag,
355 s_xhtml_1_0_end_blockquote_tag,
359 s_xhtml_1_0_start_dir_tag,
360 s_xhtml_1_0_end_dir_tag,
364 s_xhtml_1_0_start_dl_tag,
365 s_xhtml_1_0_end_dl_tag,
369 s_xhtml_1_0_start_dd_tag,
370 s_xhtml_1_0_end_dd_tag,
374 s_xhtml_1_0_start_menu_tag,
375 s_xhtml_1_0_end_menu_tag,
379 s_xhtml_1_0_start_plaintext_tag,
380 s_xhtml_1_0_end_plaintext_tag,
384 s_xhtml_1_0_start_blink_tag,
385 s_xhtml_1_0_end_blink_tag,
389 s_xhtml_1_0_start_marquee_tag,
390 s_xhtml_1_0_end_marquee_tag,
394 s_xhtml_1_0_newline_mark,
400 * converts from CHTML to XHTML.
402 * @param r [i] Requet_rec is appointed.
403 * @param spec [i] The result of the device specification processing which
404 * was done in advance is appointed.
405 * @param src [i] The character string before the converting is appointed.
406 * @return The character string after the converting is returned.
409 chxj_convert_xhtml_mobile_1_0(
415 chxjconvrule_entry *entryp,
424 DBG(r,"start chxj_convert_xhtml_mobile_1_0()");
425 /*--------------------------------------------------------------------------*/
427 /*--------------------------------------------------------------------------*/
429 dst = chxj_qr_code_blob_handler(r, src, (size_t*)dstlen);
431 DBG(r,"end chxj_convert_xhtml_mobile_1_0() (found qrcode.xml)");
435 /*--------------------------------------------------------------------------*/
436 /* The XHTML structure is initialized. */
437 /*--------------------------------------------------------------------------*/
438 s_init_xhtml(&xhtml, &doc, r, spec);
440 xhtml.entryp = entryp;
441 xhtml.cookie = cookie;
443 chxj_set_content_type(r, chxj_header_inf_set_content_type(r, "text/html; charset=Windows-31J"));
445 /*--------------------------------------------------------------------------*/
446 /* The character string of the input is analyzed. */
447 /*--------------------------------------------------------------------------*/
448 qs_init_malloc(&doc);
449 qs_init_root_node(&doc);
451 ss = apr_pcalloc(r->pool, srclen + 1);
452 memset(ss, 0, srclen + 1);
453 memcpy(ss, src, srclen);
456 chxj_dump_out("[src] CHTML->XHTML", ss, srclen);
458 qs_parse_string(&doc,ss, strlen(ss));
460 chxj_buffered_write_init(r->pool, &doc.buf);
461 /*--------------------------------------------------------------------------*/
462 /* It converts it from CHTML to XHTML. */
463 /*--------------------------------------------------------------------------*/
464 chxj_node_convert(spec,r,(void *)&xhtml, &doc, qs_get_root(&doc), 0);
465 xhtml.out = chxj_buffered_write_flush(xhtml.out, &doc.buf);
466 dst = apr_pstrdup(r->pool, xhtml.out);
467 chxj_buffered_write_terminate(&doc.buf);
469 qs_all_free(&doc,QX_LOGMARK);
472 return apr_pstrdup(r->pool,ss);
476 dst = apr_psprintf(r->pool, "\n");
478 *dstlen = strlen(dst);
481 chxj_dump_out("[dst] CHTML->XHTML", dst, *dstlen);
484 DBG(r,"end chxj_convert_xhtml_mobile_1_0()");
490 * The XHTML structure is initialized.
492 * @param xhtml [i/o] The pointer to the HDML structure that wants to be
493 * initialized is specified.
494 * @param doc [i] The Doc structure that should be set to the initialized
495 * HDML structure is specified.
496 * @param r [i] To use POOL, the pointer to request_rec is specified.
497 * @param spec [i] The pointer to the device_table
500 s_init_xhtml(xhtml_t *xhtml, Doc *doc, request_rec *r, device_table *spec)
502 memset(doc, 0, sizeof(Doc));
503 memset(xhtml, 0, sizeof(xhtml_t));
508 xhtml->out = qs_alloc_zero_byte_string(r->pool);
509 xhtml->conf = chxj_get_module_config(r->per_dir_config, &chxj_module);
510 xhtml->doc->parse_mode = PARSE_MODE_CHTML;
515 * Corresponding EMOJI to a current character-code is retrieved.
516 * The substitution character string is stored in the rslt pointer if agreeing.
518 * @param xhtml [i] The pointer to the XHTML structure is specified.
519 * @param txt [i] The character string to want to examine whether it is
520 * EMOJI is specified.
521 * @param rslt [o] The pointer to the pointer that stores the result is
523 * @return When corresponding EMOJI exists, it returns it excluding 0.
526 s_xhtml_search_emoji(xhtml_t *xhtml, char *txt, char **rslt)
539 DBG(r,"spec is NULL");
542 for (ee = xhtml->conf->emoji;
545 unsigned char hex1byte;
546 unsigned char hex2byte;
548 DBG(r,"emoji->imode is NULL");
552 if (ee->imode->string != NULL
553 && strlen(ee->imode->string) > 0
554 && strncasecmp(ee->imode->string, txt, strlen(ee->imode->string)) == 0) {
555 if (spec == NULL || spec->emoji_type == NULL) {
556 *rslt = apr_psprintf(r->pool,
559 return strlen(ee->imode->string);
562 if (strcasecmp(xhtml->spec->emoji_type, "a") == 0) {
563 *rslt = apr_psprintf(r->pool,
566 return strlen(ee->imode->string);
569 if (strcasecmp(xhtml->spec->emoji_type, "b") == 0) {
570 *rslt = apr_psprintf(r->pool,
573 return strlen(ee->imode->string);
576 if (strcasecmp(xhtml->spec->emoji_type, "c") == 0) {
577 *rslt = apr_psprintf(r->pool,
580 return strlen(ee->imode->string);
583 if (strcasecmp(xhtml->spec->emoji_type, "d") == 0) {
584 *rslt = apr_psprintf(r->pool,
587 return strlen(ee->imode->string);
590 *rslt = apr_psprintf(r->pool,
593 return strlen(ee->imode->string);
597 hex1byte = ee->imode->hex1byte & 0xff;
598 hex2byte = ee->imode->hex2byte & 0xff;
600 && ((unsigned char)txt[0] & 0xff) == ((unsigned char)hex1byte)
601 && ((unsigned char)txt[1] & 0xff) == ((unsigned char)hex2byte)) {
602 if (spec == NULL || spec->emoji_type == NULL) {
603 *rslt = apr_psprintf(r->pool,
604 "<img localsrc=\"%s\">",
609 if (strcasecmp(xhtml->spec->emoji_type, "a") == 0) {
610 *rslt = apr_psprintf(r->pool,
611 "<img localsrc=\"%s\">",
616 if (strcasecmp(xhtml->spec->emoji_type, "b") == 0) {
617 *rslt = apr_psprintf(r->pool,
618 "<img localsrc=\"%s\">",
623 if (strcasecmp(xhtml->spec->emoji_type, "c") == 0) {
624 *rslt = apr_psprintf(r->pool,
625 "<img localsrc=\"%s\">",
630 if (strcasecmp(xhtml->spec->emoji_type, "d") == 0) {
631 *rslt = apr_psprintf(r->pool,
632 "<img localsrc=\"%s\">",
637 *rslt = apr_psprintf(r->pool,
638 "<img localsrc=\"%s\">",
650 * It is a handler who processes the HTML tag.
652 * @param pdoc [i/o] The pointer to the XHTML structure at the output
653 * destination is specified.
654 * @param node [i] The HTML tag node is specified.
655 * @return The conversion result is returned.
658 s_xhtml_1_0_start_html_tag(void *pdoc, Node *node)
660 xhtml_t *xhtml = GET_XHTML(pdoc);
662 Doc *doc = xhtml->doc;
664 /*--------------------------------------------------------------------------*/
665 /* Add XML Declare */
666 /*--------------------------------------------------------------------------*/
667 W_L("<?xml version=\"1.0\" encoding=\"Windows-31J\"?>");
669 /*--------------------------------------------------------------------------*/
671 /*--------------------------------------------------------------------------*/
672 W_L("<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML Basic 1.0//EN\"");
674 W_L(" \"http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd\">");
676 /*--------------------------------------------------------------------------*/
678 /*--------------------------------------------------------------------------*/
679 W_L("<html xmlns=\"http://www.w3.org/1999/xhtml\"");
680 /*--------------------------------------------------------------------------*/
682 /*--------------------------------------------------------------------------*/
683 for (attr = qs_get_attr(doc,node);
685 attr = qs_get_next_attr(doc,attr)) {
686 char* name = qs_get_attr_name(doc,attr);
687 char* value = qs_get_attr_value(doc,attr);
688 if (STRCASEEQ('l','L',"lang", name)) {
693 else if (STRCASEEQ('v','V',"version", name)) {
694 W_L(" version=\"-//OPENWAVE//DTD XHTML Mobile 1.0//EN\"");
703 * It is a handler who processes the HTML tag.
705 * @param pdoc [i/o] The pointer to the XHTML structure at the output
706 * destination is specified.
707 * @param node [i] The HTML tag node is specified.
708 * @return The conversion result is returned.
711 s_xhtml_1_0_end_html_tag(void *pdoc, Node *UNUSED(child))
713 xhtml_t *xhtml = GET_XHTML(pdoc);
714 Doc *doc = xhtml->doc;
721 * It is a handler who processes the META tag.
723 * @param pdoc [i/o] The pointer to the XHTML structure at the output
724 * destination is specified.
725 * @param node [i] The META tag node is specified.
726 * @return The conversion result is returned.
729 s_xhtml_1_0_start_meta_tag(void *pdoc, Node *node)
731 xhtml_t *xhtml = GET_XHTML(pdoc);
733 Doc *doc = xhtml->doc;
734 int content_type_flag = 0;
735 request_rec *r = doc->r;
738 /*--------------------------------------------------------------------------*/
740 /*--------------------------------------------------------------------------*/
741 for (attr = qs_get_attr(doc,node);
743 attr = qs_get_next_attr(doc,attr)) {
744 char *name = qs_get_attr_name(doc,attr);
745 char *value = qs_get_attr_value(doc,attr);
746 if (STRCASEEQ('n','N',"name", name) && value && *value) {
753 else if (STRCASEEQ('h','H',"http-equiv", name) && value && *value) {
759 if (STRCASEEQ('c','C', "content-type", value)) {
760 content_type_flag = 1;
763 else if (STRCASEEQ('c','C',"content", name) && value && *value) {
764 if (content_type_flag) {
768 W_V(chxj_header_inf_set_content_type(r, "text/html; charset=Windows-31J"));
786 * It is a handler who processes the META tag.
788 * @param pdoc [i/o] The pointer to the XHTML structure at the output
789 * destination is specified.
790 * @param node [i] The META tag node is specified.
791 * @return The conversion result is returned.
794 s_xhtml_1_0_end_meta_tag(void *pdoc, Node *UNUSED(child))
796 xhtml_t *xhtml = GET_XHTML(pdoc);
803 * It is a handler who processes the HEAD tag.
805 * @param pdoc [i/o] The pointer to the XHTML structure at the output
806 * destination is specified.
807 * @param node [i] The HEAD tag node is specified.
808 * @return The conversion result is returned.
811 s_xhtml_1_0_start_head_tag(void *pdoc, Node *UNUSED(node))
813 xhtml_t *xhtml = GET_XHTML(pdoc);
814 Doc *doc = xhtml->doc;
822 * It is a handler who processes the HEAD tag.
824 * @param pdoc [i/o] The pointer to the XHTML structure at the output
825 * destination is specified.
826 * @param node [i] The HEAD tag node is specified.
827 * @return The conversion result is returned.
830 s_xhtml_1_0_end_head_tag(void *pdoc, Node *UNUSED(child))
832 xhtml_t *xhtml = GET_XHTML(pdoc);
833 Doc *doc = xhtml->doc;
841 * It is a handler who processes the TITLE tag.
843 * @param pdoc [i/o] The pointer to the XHTML structure at the output
844 * destination is specified.
845 * @param node [i] The TITLE tag node is specified.
846 * @return The conversion result is returned.
849 s_xhtml_1_0_start_title_tag(void *pdoc, Node *UNUSED(node))
851 xhtml_t *xhtml = GET_XHTML(pdoc);
852 Doc *doc = xhtml->doc;
860 * It is a handler who processes the TITLE tag.
862 * @param pdoc [i/o] The pointer to the XHTML structure at the output
863 * destination is specified.
864 * @param node [i] The TITLE tag node is specified.
865 * @return The conversion result is returned.
868 s_xhtml_1_0_end_title_tag(void *pdoc, Node *UNUSED(child))
870 xhtml_t *xhtml = GET_XHTML(pdoc);
871 Doc *doc = xhtml->doc;
880 * It is a handler who processes the BASE tag.
882 * @param pdoc [i/o] The pointer to the XHTML structure at the output
883 * destination is specified.
884 * @param node [i] The BASE tag node is specified.
885 * @return The conversion result is returned.
888 s_xhtml_1_0_start_base_tag(void *pdoc, Node *node)
890 xhtml_t *xhtml = GET_XHTML(pdoc);
892 Doc *doc = xhtml->doc;
895 /*--------------------------------------------------------------------------*/
897 /*--------------------------------------------------------------------------*/
898 for (attr = qs_get_attr(doc,node);
900 attr = qs_get_next_attr(doc,attr)) {
901 char *name = qs_get_attr_name(doc,attr);
902 char *value = qs_get_attr_value(doc,attr);
903 if (STRCASEEQ('h','H',"href",name)) {
917 * It is a handler who processes the BASE tag.
919 * @param pdoc [i/o] The pointer to the XHTML structure at the output
920 * destination is specified.
921 * @param node [i] The BASE tag node is specified.
922 * @return The conversion result is returned.
925 s_xhtml_1_0_end_base_tag(void *pdoc, Node *UNUSED(child))
927 xhtml_t *xhtml = GET_XHTML(pdoc);
934 * It is a handler who processes the BODY tag.
936 * @param pdoc [i/o] The pointer to the XHTML structure at the output
937 * destination is specified.
938 * @param node [i] The BODY tag node is specified.
939 * @return The conversion result is returned.
942 s_xhtml_1_0_start_body_tag(void *pdoc, Node *node)
944 xhtml_t *xhtml = GET_XHTML(pdoc);
945 Doc *doc = xhtml->doc;
949 /*--------------------------------------------------------------------------*/
951 /*--------------------------------------------------------------------------*/
952 for (attr = qs_get_attr(doc,node);
954 attr = qs_get_next_attr(doc,attr)) {
955 char *name = qs_get_attr_name(doc,attr);
956 char *value = qs_get_attr_value(doc,attr);
957 if (STRCASEEQ('b','B',"bgcolor", name) && value && *value) {
962 else if (STRCASEEQ('t','T',"text",name) && value && *value) {
967 else if (STRCASEEQ('l','L',"link", name) && value && *value) {
972 else if (STRCASEEQ('a','A',"alink", name)) {
975 else if (STRCASEEQ('v','V',"vlink",name)) {
985 * It is a handler who processes the BODY tag.
987 * @param pdoc [i/o] The pointer to the XHTML structure at the output
988 * destination is specified.
989 * @param node [i] The BODY tag node is specified.
990 * @return The conversion result is returned.
993 s_xhtml_1_0_end_body_tag(void *pdoc, Node *UNUSED(child))
995 xhtml_t *xhtml = GET_XHTML(pdoc);
996 Doc *doc = xhtml->doc;
1004 * It is a handler who processes the A tag.
1006 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1007 * destination is specified.
1008 * @param node [i] The A tag node is specified.
1009 * @return The conversion result is returned.
1012 s_xhtml_1_0_start_a_tag(void *pdoc, Node *node)
1014 xhtml_t *xhtml = GET_XHTML(pdoc);
1015 Doc *doc = xhtml->doc;
1016 request_rec *r = doc->r;
1020 /*--------------------------------------------------------------------------*/
1021 /* Get Attributes */
1022 /*--------------------------------------------------------------------------*/
1023 for (attr = qs_get_attr(doc,node);
1025 attr = qs_get_next_attr(doc,attr)) {
1026 char* name = qs_get_attr_name(doc,attr);
1027 char* value = qs_get_attr_value(doc,attr);
1028 if (STRCASEEQ('n','N',"name",name) && value && *value) {
1033 else if (STRCASEEQ('h','H',"href", name) && value && *value) {
1034 value = chxj_encoding_parameter(r, value);
1035 if (! chxj_starts_with(value, "mailto:") && ! chxj_starts_with(value, "tel:")) {
1036 value = chxj_add_cookie_parameter(r, value, xhtml->cookie);
1042 else if (STRCASEEQ('a','A',"accesskey", name)) {
1043 W_L(" accesskey=\"");
1047 else if (STRCASEEQ('c','C',"cti",name)) {
1050 else if (STRCASEEQ('i','I',"ijam", name)) {
1053 else if (STRCASEEQ('u','U',"utn", name)) {
1056 else if (STRCASEEQ('t','T',"telbook",name)) {
1059 else if (STRCASEEQ('k','K',"kana",name)) {
1062 else if (STRCASEEQ('e','E',"email",name)) {
1065 else if (STRCASEEQ('i','I',"ista",name)) {
1068 else if (STRCASEEQ('i','I',"ilet",name)) {
1071 else if (STRCASEEQ('i','I',"iswf",name)) {
1074 else if (STRCASEEQ('i','I',"irst",name)) {
1084 * It is a handler who processes the A tag.
1086 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1087 * destination is specified.
1088 * @param node [i] The A tag node is specified.
1089 * @return The conversion result is returned.
1092 s_xhtml_1_0_end_a_tag(void *pdoc, Node *UNUSED(child))
1094 xhtml_t *xhtml = GET_XHTML(pdoc);
1095 Doc *doc = xhtml->doc;
1104 * It is a handler who processes the BR tag.
1106 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1107 * destination is specified.
1108 * @param node [i] The BR tag node is specified.
1109 * @return The conversion result is returned.
1112 s_xhtml_1_0_start_br_tag(void *pdoc, Node *node)
1114 xhtml_t *xhtml = GET_XHTML(pdoc);
1115 Doc *doc = xhtml->doc;
1119 /*--------------------------------------------------------------------------*/
1120 /* Get Attributes */
1121 /*--------------------------------------------------------------------------*/
1122 for (attr = qs_get_attr(doc,node);
1124 attr = qs_get_next_attr(doc,attr)) {
1125 char *name = qs_get_attr_name(doc,attr);
1126 char *value = qs_get_attr_value(doc,attr);
1127 if (STRCASEEQ('c','C',"clear",name)) {
1128 if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('a','A',"all",value))) {
1142 * It is a handler who processes the BR tag.
1144 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1145 * destination is specified.
1146 * @param node [i] The BR tag node is specified.
1147 * @return The conversion result is returned.
1150 s_xhtml_1_0_end_br_tag(void *pdoc, Node *UNUSED(child))
1152 xhtml_t *xhtml = GET_XHTML(pdoc);
1159 * It is a handler who processes the TR tag.
1161 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1162 * destination is specified.
1163 * @param node [i] The TR tag node is specified.
1164 * @return The conversion result is returned.
1167 s_xhtml_1_0_start_tr_tag(void *pdoc, Node *UNUSED(node))
1169 xhtml_t *xhtml = GET_XHTML(pdoc);
1170 Doc *doc = xhtml->doc;
1179 * It is a handler who processes the TR tag.
1181 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1182 * destination is specified.
1183 * @param node [i] The TR tag node is specified.
1184 * @return The conversion result is returned.
1187 s_xhtml_1_0_end_tr_tag(void *pdoc, Node *UNUSED(child))
1189 xhtml_t *xhtml = GET_XHTML(pdoc);
1196 * It is a handler who processes the FONT tag.
1198 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1199 * destination is specified.
1200 * @param node [i] The FONT tag node is specified.
1201 * @return The conversion result is returned.
1204 s_xhtml_1_0_start_font_tag(void *pdoc, Node *node)
1206 xhtml_t *xhtml = GET_XHTML(pdoc);
1207 Doc *doc = xhtml->doc;
1212 /*=========================================================================*/
1213 /* Get Attributes */
1214 /*=========================================================================*/
1215 for (attr = qs_get_attr(doc,node);
1217 attr = qs_get_next_attr(doc,attr)) {
1218 char *name = qs_get_attr_name(doc,attr);
1219 char *value = qs_get_attr_value(doc,attr);
1220 if (STRCASEEQ('c','C',"color",name) && value && *value) {
1221 color = apr_pstrdup(doc->buf.pool, value);
1223 else if (STRCASEEQ('s','S',"size",name) && value && *value) {
1224 size = apr_pstrdup(doc->buf.pool, value);
1228 W_L("<font color=\"");
1231 xhtml->font_color_flag++;
1234 xhtml->font_size_flag++;
1236 case '1': W_L("<span style=\"font-size: xx-small\">"); break;
1237 case '2': W_L("<span style=\"font-size: x-small\">"); break;
1238 case '3': W_L("<span style=\"font-size: small\">"); break;
1239 case '4': W_L("<span style=\"font-size: medium\">"); break;
1240 case '5': W_L("<span style=\"font-size: large\">"); break;
1241 case '6': W_L("<span style=\"font-size: x-large\">"); break;
1242 case '7': W_L("<span style=\"font-size: xx-large\">"); break;
1244 if (*(size + 1) == '1') {
1245 W_L("<span style=\"font-size: small\">");
1248 if (*(size + 1) == '2') {
1249 W_L("<span style=\"font-size: x-small\">");
1252 if (*(size + 1) == '3') {
1253 W_L("<span style=\"font-size: xx-small\">");
1256 xhtml->font_size_flag--;
1260 if (*(size + 1) == '1') {
1261 W_L("<span style=\"font-size: large\">");
1264 if (*(size + 1) == '2') {
1265 W_L("<span style=\"font-size: x-large\">");
1268 if (*(size + 1) == '3') {
1269 W_L("<span style=\"font-size: xx-large\">");
1272 xhtml->font_size_flag--;
1276 WRN(doc->r, "invlalid font size. [%s] != (1|2|3|4|5|6|7|+1|+2|+3|-1|-2|-3)", size);
1277 xhtml->font_size_flag--;
1285 * It is a handler who processes the FONT tag.
1287 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1288 * destination is specified.
1289 * @param node [i] The FONT tag node is specified.
1290 * @return The conversion result is returned.
1293 s_xhtml_1_0_end_font_tag(void *pdoc, Node *UNUSED(child))
1295 xhtml_t *xhtml = GET_XHTML(pdoc);
1296 Doc *doc = xhtml->doc;
1298 if (xhtml->font_size_flag) {
1300 xhtml->font_size_flag--;
1302 if (xhtml->font_color_flag) {
1304 xhtml->font_color_flag--;
1311 * It is a handler who processes the FORM tag.
1313 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1314 * destination is specified.
1315 * @param node [i] The FORM tag node is specified.
1316 * @return The conversion result is returned.
1319 s_xhtml_1_0_start_form_tag(void *pdoc, Node *node)
1321 xhtml_t *xhtml = GET_XHTML(pdoc);
1322 Doc *doc = xhtml->doc;
1323 request_rec *r = doc->r;
1325 char *new_hidden_tag = NULL;
1326 char *attr_action = NULL;
1327 char *attr_method = NULL;
1328 char *attr_name = NULL;
1330 /*--------------------------------------------------------------------------*/
1331 /* Get Attributes */
1332 /*--------------------------------------------------------------------------*/
1333 for (attr = qs_get_attr(doc,node);
1335 attr = qs_get_next_attr(doc,attr)) {
1336 char *name = qs_get_attr_name(doc,attr);
1337 char *value = qs_get_attr_value(doc,attr);
1338 if (STRCASEEQ('a','A',"action",name)) {
1339 attr_action = chxj_encoding_parameter(r, value);
1340 attr_action = chxj_add_cookie_parameter(r, attr_action, xhtml->cookie);
1342 else if (STRCASEEQ('m','M',"method",name)) {
1343 attr_method = apr_pstrdup(doc->pool, value);
1345 else if (STRCASEEQ('u','U',"utn",name)) {
1348 else if (STRCASEEQ('n','N',"name",name)) {
1349 attr_name = apr_pstrdup(doc->pool, value);
1353 int post_flag = (attr_method && strcasecmp(attr_method, "post") == 0) ? 1 : 0;
1358 char *old_qs = NULL;
1359 q = strchr(attr_action, '?');
1361 new_hidden_tag = chxj_form_action_to_hidden_tag(r, doc->pool, attr_action, 1, post_flag, &old_qs, CHXJ_FALSE, CHXJ_FALSE, xhtml->entryp);
1362 if (new_hidden_tag || old_qs) {
1385 if (new_hidden_tag) {
1386 W_V(new_hidden_tag);
1393 * It is a handler who processes the FORM tag.
1395 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1396 * destination is specified.
1397 * @param node [i] The FORM tag node is specified.
1398 * @return The conversion result is returned.
1401 s_xhtml_1_0_end_form_tag(void *pdoc, Node *UNUSED(child))
1403 xhtml_t *xhtml = GET_XHTML(pdoc);
1404 Doc *doc = xhtml->doc;
1413 * It is a handler who processes the INPUT tag.
1415 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1416 * destination is specified.
1417 * @param node [i] The INPUT tag node is specified.
1418 * @return The conversion result is returned.
1421 s_xhtml_1_0_start_input_tag(void *pdoc, Node *node)
1423 xhtml_t *xhtml = GET_XHTML(pdoc);
1424 Doc *doc = xhtml->doc;
1425 request_rec *r = doc->r;
1426 char *max_length = NULL;
1430 char *istyle = NULL;
1432 char *checked = NULL;
1433 char *accesskey = NULL;
1436 /*--------------------------------------------------------------------------*/
1437 /* Get Attributes */
1438 /*--------------------------------------------------------------------------*/
1439 type = qs_get_type_attr(doc, node, doc->buf.pool);
1440 name = qs_get_name_attr(doc, node, doc->buf.pool);
1441 value = qs_get_value_attr(doc,node, doc->buf.pool);
1442 istyle = qs_get_istyle_attr(doc,node,doc->buf.pool);
1443 max_length = qs_get_maxlength_attr(doc,node,doc->buf.pool);
1444 checked = qs_get_checked_attr(doc,node, doc->buf.pool);
1445 accesskey = qs_get_accesskey_attr(doc, node, doc->buf.pool);
1446 size = qs_get_size_attr(doc, node, doc->buf.pool);
1449 type = qs_trim_string(doc->buf.pool, type);
1450 if (type && (STRCASEEQ('t','T',"text", type) ||
1451 STRCASEEQ('p','P',"password",type) ||
1452 STRCASEEQ('c','C',"checkbox",type) ||
1453 STRCASEEQ('r','R',"radio", type) ||
1454 STRCASEEQ('h','H',"hidden", type) ||
1455 STRCASEEQ('s','S',"submit", type) ||
1456 STRCASEEQ('r','R',"reset", type))) {
1462 if (size && *size) {
1467 if (name && *name) {
1472 if (value && *value) {
1474 W_V(chxj_add_slash_to_doublequote(doc->pool, value));
1477 if (accesskey && *accesskey) {
1478 W_L(" accesskey=\"");
1482 if (istyle && *istyle && (*istyle == '1' || *istyle == '2' || *istyle == '3' || *istyle == '4')) {
1483 char *fmt = qs_conv_istyle_to_format(r,istyle);
1484 if (max_length && *max_length) {
1486 for (ii=0; (unsigned int)ii<strlen(max_length); ii++) {
1487 if (max_length[ii] < '0' || max_length[ii] > '9') {
1488 max_length = apr_psprintf(r->pool, "0");
1493 if (strcmp(max_length, "0")) {
1494 char *vv = apr_psprintf(r->pool, " FORMAT=\"%d%s\"", atoi(max_length), fmt);
1506 if (max_length && *max_length) {
1507 if (chxj_chk_numeric(max_length) != 0) {
1508 max_length = apr_psprintf(r->pool, "0");
1510 if (strcmp(max_length, "0")) {
1511 char *vv = apr_psprintf(r->pool, " FORMAT=\"%dm\"", atoi(max_length));
1516 /*--------------------------------------------------------------------------*/
1517 /* The figure is default for the password. */
1518 /*--------------------------------------------------------------------------*/
1519 if (type && (istyle == NULL || *istyle == 0) && STRCASEEQ('p','P',"password", type) && ! xhtml->entryp->pc_flag) {
1526 W_L(" FORMAT=\"*N\"");
1530 W_L(" checked=\"checked\"");
1539 * It is a handler who processes the INPUT tag.
1541 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1542 * destination is specified.
1543 * @param node [i] The INPUT tag node is specified.
1544 * @return The conversion result is returned.
1547 s_xhtml_1_0_end_input_tag(void *pdoc, Node *UNUSED(child))
1549 xhtml_t *xhtml = GET_XHTML(pdoc);
1556 * It is a handler who processes the CENTER tag.
1558 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1559 * destination is specified.
1560 * @param node [i] The CENTER tag node is specified.
1561 * @return The conversion result is returned.
1564 s_xhtml_1_0_start_center_tag(void *pdoc, Node *UNUSED(node))
1566 xhtml_t *xhtml = GET_XHTML(pdoc);
1567 Doc *doc = xhtml->doc;
1575 * It is a handler who processes the CENTER tag.
1577 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1578 * destination is specified.
1579 * @param node [i] The CENTER tag node is specified.
1580 * @return The conversion result is returned.
1583 s_xhtml_1_0_end_center_tag(void *pdoc, Node *UNUSED(child))
1585 xhtml_t *xhtml = GET_XHTML(pdoc);
1586 Doc *doc = xhtml->doc;
1594 * It is a handler who processes the HR tag.
1596 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1597 * destination is specified.
1598 * @param node [i] The HR tag node is specified.
1599 * @return The conversion result is returned.
1602 s_xhtml_1_0_start_hr_tag(void *pdoc, Node *node)
1604 xhtml_t *xhtml = GET_XHTML(pdoc);
1605 Doc *doc = xhtml->doc;
1610 for (attr = qs_get_attr(doc,node);
1612 attr = qs_get_next_attr(doc,attr)) {
1613 char *name = qs_get_attr_name(doc,attr);
1614 char *value = qs_get_attr_value(doc,attr);
1615 if (STRCASEEQ('a','A',"align", name)) {
1616 /*----------------------------------------------------------------------*/
1618 /*----------------------------------------------------------------------*/
1619 if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value) || STRCASEEQ('c','C',"center",value))) {
1625 else if (STRCASEEQ('s','S',"size", name)) {
1626 /*----------------------------------------------------------------------*/
1628 /*----------------------------------------------------------------------*/
1629 if (value && *value) {
1635 else if (STRCASEEQ('w','W',"width", name)) {
1636 /*----------------------------------------------------------------------*/
1638 /*----------------------------------------------------------------------*/
1639 if (value && *value) {
1645 else if (STRCASEEQ('n','N',"noshade", name)) {
1646 /*----------------------------------------------------------------------*/
1648 /*----------------------------------------------------------------------*/
1651 else if (STRCASEEQ('c','C',"color", name) && value && *value) {
1652 /*----------------------------------------------------------------------*/
1654 /*----------------------------------------------------------------------*/
1666 * It is a handler who processes the HR tag.
1668 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1669 * destination is specified.
1670 * @param node [i] The HR tag node is specified.
1671 * @return The conversion result is returned.
1674 s_xhtml_1_0_end_hr_tag(void *pdoc, Node *UNUSED(child))
1676 xhtml_t *xhtml = GET_XHTML(pdoc);
1683 * It is a handler who processes the PRE tag.
1685 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1686 * destination is specified.
1687 * @param node [i] The PRE tag node is specified.
1688 * @return The conversion result is returned.
1691 s_xhtml_1_0_start_pre_tag(void* pdoc, Node* UNUSED(node))
1693 xhtml_t *xhtml = GET_XHTML(pdoc);
1694 Doc *doc = xhtml->doc;
1703 * It is a handler who processes the PRE tag.
1705 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1706 * destination is specified.
1707 * @param node [i] The PRE tag node is specified.
1708 * @return The conversion result is returned.
1711 s_xhtml_1_0_end_pre_tag(void *pdoc, Node *UNUSED(child))
1713 xhtml_t *xhtml = GET_XHTML(pdoc);
1714 Doc *doc = xhtml->doc;
1724 * It is a handler who processes the P tag.
1726 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1727 * destination is specified.
1728 * @param node [i] The P tag node is specified.
1729 * @return The conversion result is returned.
1732 s_xhtml_1_0_start_p_tag(void *pdoc, Node *node)
1734 xhtml_t *xhtml = GET_XHTML(pdoc);
1735 Doc *doc = xhtml->doc;
1740 for (attr = qs_get_attr(doc,node);
1742 attr = qs_get_next_attr(doc,attr)) {
1743 char *nm = qs_get_attr_name(doc,attr);
1744 char *val = qs_get_attr_value(doc,attr);
1745 if (STRCASEEQ('a','A',"align", nm)) {
1746 /*----------------------------------------------------------------------*/
1747 /* CHTML 1.0 (W3C version 3.2) */
1748 /*----------------------------------------------------------------------*/
1749 if (val && (STRCASEEQ('l','L',"left",val) || STRCASEEQ('r','R',"right",val) || STRCASEEQ('c','C',"center",val))) {
1750 align = apr_pstrdup(doc->buf.pool, val);
1766 * It is a handler who processes the P tag.
1768 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1769 * destination is specified.
1770 * @param node [i] The P tag node is specified.
1771 * @return The conversion result is returned.
1774 s_xhtml_1_0_end_p_tag(void *pdoc, Node *UNUSED(child))
1776 xhtml_t *xhtml = GET_XHTML(pdoc);
1777 Doc *doc = xhtml->doc;
1785 * It is a handler who processes the UL tag.
1787 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1788 * destination is specified.
1789 * @param node [i] The UL tag node is specified.
1790 * @return The conversion result is returned.
1793 s_xhtml_1_0_start_ul_tag(void *pdoc, Node *node)
1795 xhtml_t *xhtml = GET_XHTML(pdoc);
1796 Doc *doc = xhtml->doc;
1799 /*--------------------------------------------------------------------------*/
1800 /* Get Attributes */
1801 /*--------------------------------------------------------------------------*/
1802 for (attr = qs_get_attr(doc,node);
1804 attr = qs_get_next_attr(doc,attr)) {
1805 char *name = qs_get_attr_name(doc,attr);
1806 char *value = qs_get_attr_value(doc,attr);
1807 if (STRCASEEQ('t','T',"type",name)) {
1808 if (value && (STRCASEEQ('d','D',"disc",value) || STRCASEEQ('c','C',"circle",value) || STRCASEEQ('s','S',"square",value))) {
1821 * It is a handler who processes the UL tag.
1823 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1824 * destination is specified.
1825 * @param node [i] The UL tag node is specified.
1826 * @return The conversion result is returned.
1829 s_xhtml_1_0_end_ul_tag(void *pdoc, Node *UNUSED(child))
1831 xhtml_t *xhtml = GET_XHTML(pdoc);
1832 Doc *doc = xhtml->doc;
1840 * It is a handler who processes the H1 tag.
1842 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1843 * destination is specified.
1844 * @param node [i] The H1 tag node is specified.
1845 * @return The conversion result is returned.
1848 s_xhtml_1_0_start_h1_tag(void *pdoc, Node *node)
1850 xhtml_t *xhtml = GET_XHTML(pdoc);
1851 Doc *doc = xhtml->doc;
1855 for (attr = qs_get_attr(doc,node);
1857 attr = qs_get_next_attr(doc,attr)) {
1860 name = qs_get_attr_name(doc,attr);
1861 value = qs_get_attr_value(doc,attr);
1862 if (STRCASEEQ('a','A',"align", name)) {
1864 if (STRCASEEQ('l','L',"left",value)) {
1866 W_L("text-align:left");
1869 else if (STRCASEEQ('r','R',"right",value)) {
1871 W_L("text-align:right");
1874 else if (STRCASEEQ('c','C',"center",value)) {
1876 W_L("text-align:center");
1889 * It is a handler who processes the H1 tag.
1891 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1892 * destination is specified.
1893 * @param node [i] The H1 tag node is specified.
1894 * @return The conversion result is returned.
1897 s_xhtml_1_0_end_h1_tag(void *pdoc, Node *UNUSED(child))
1899 xhtml_t *xhtml = GET_XHTML(pdoc);
1900 Doc *doc = xhtml->doc;
1908 * It is a handler who processes the H2 tag.
1910 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1911 * destination is specified.
1912 * @param node [i] The H2 tag node is specified.
1913 * @return The conversion result is returned.
1916 s_xhtml_1_0_start_h2_tag(void *pdoc, Node *node)
1918 xhtml_t *xhtml = GET_XHTML(pdoc);
1919 Doc *doc = xhtml->doc;
1923 for (attr = qs_get_attr(doc,node);
1925 attr = qs_get_next_attr(doc,attr)) {
1928 name = qs_get_attr_name(doc,attr);
1929 value = qs_get_attr_value(doc,attr);
1930 if (STRCASEEQ('a','A',"align", name)) {
1932 if (STRCASEEQ('l','L',"left",value)) {
1934 W_L("text-align:left");
1937 else if (STRCASEEQ('r','R',"right",value)) {
1939 W_L("text-align:right");
1942 else if (STRCASEEQ('c','C',"center",value)) {
1944 W_L("text-align:center");
1957 * It is a handler who processes the H2 tag.
1959 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1960 * destination is specified.
1961 * @param node [i] The H2 tag node is specified.
1962 * @return The conversion result is returned.
1965 s_xhtml_1_0_end_h2_tag(void *pdoc, Node *UNUSED(child))
1967 xhtml_t *xhtml = GET_XHTML(pdoc);
1968 Doc *doc = xhtml->doc;
1976 * It is a handler who processes the H3 tag.
1978 * @param pdoc [i/o] The pointer to the XHTML structure at the output
1979 * destination is specified.
1980 * @param node [i] The H3 tag node is specified.
1981 * @return The conversion result is returned.
1984 s_xhtml_1_0_start_h3_tag(void *pdoc, Node *node)
1986 xhtml_t *xhtml = GET_XHTML(pdoc);
1987 Doc *doc = xhtml->doc;
1991 for (attr = qs_get_attr(doc,node);
1993 attr = qs_get_next_attr(doc,attr)) {
1996 name = qs_get_attr_name(doc,attr);
1997 value = qs_get_attr_value(doc,attr);
1998 if (STRCASEEQ('a','A',"align", name)) {
2000 if (STRCASEEQ('l','L',"left",value)) {
2002 W_L("text-align:left");
2005 else if (STRCASEEQ('r','R',"right",value)) {
2007 W_L("text-align:right");
2010 else if (STRCASEEQ('c','C',"center",value)) {
2012 W_L("text-align:center");
2025 * It is a handler who processes the H3 tag.
2027 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2028 * destination is specified.
2029 * @param node [i] The H3 tag node is specified.
2030 * @return The conversion result is returned.
2033 s_xhtml_1_0_end_h3_tag(void *pdoc, Node *UNUSED(child))
2035 xhtml_t *xhtml = GET_XHTML(pdoc);
2036 Doc *doc = xhtml->doc;
2044 * It is a handler who processes the H4 tag.
2046 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2047 * destination is specified.
2048 * @param node [i] The H4 tag node is specified.
2049 * @return The conversion result is returned.
2052 s_xhtml_1_0_start_h4_tag(void *pdoc, Node *node)
2054 xhtml_t *xhtml = GET_XHTML(pdoc);
2055 Doc *doc = xhtml->doc;
2059 for (attr = qs_get_attr(doc,node);
2061 attr = qs_get_next_attr(doc,attr)) {
2064 name = qs_get_attr_name(doc,attr);
2065 value = qs_get_attr_value(doc,attr);
2066 if (STRCASEEQ('a','A',"align", name)) {
2068 if (STRCASEEQ('l','L',"left",value)) {
2070 W_L("text-align:left");
2073 else if (STRCASEEQ('r','R',"right",value)) {
2075 W_L("text-align:right");
2078 else if (STRCASEEQ('c','C',"center",value)) {
2080 W_L("text-align:center");
2093 * It is a handler who processes the H4 tag.
2095 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2096 * destination is specified.
2097 * @param node [i] The H4 tag node is specified.
2098 * @return The conversion result is returned.
2101 s_xhtml_1_0_end_h4_tag(void *pdoc, Node *UNUSED(child))
2103 xhtml_t *xhtml = GET_XHTML(pdoc);
2104 Doc *doc = xhtml->doc;
2112 * It is a handler who processes the H5 tag.
2114 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2115 * destination is specified.
2116 * @param node [i] The H5 tag node is specified.
2117 * @return The conversion result is returned.
2120 s_xhtml_1_0_start_h5_tag(void *pdoc, Node *node)
2122 xhtml_t *xhtml = GET_XHTML(pdoc);
2123 Doc *doc = xhtml->doc;
2127 for (attr = qs_get_attr(doc,node);
2129 attr = qs_get_next_attr(doc,attr)) {
2132 name = qs_get_attr_name(doc,attr);
2133 value = qs_get_attr_value(doc,attr);
2134 if (STRCASEEQ('a','A',"align", name)) {
2136 if (STRCASEEQ('l','L',"left",value)) {
2138 W_L("text-align:left");
2141 else if (STRCASEEQ('r','R',"right",value)) {
2143 W_L("text-align:right");
2146 else if (STRCASEEQ('c','C',"center",value)) {
2148 W_L("text-align:center");
2161 * It is a handler who processes the H5 tag.
2163 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2164 * destination is specified.
2165 * @param node [i] The H5 tag node is specified.
2166 * @return The conversion result is returned.
2169 s_xhtml_1_0_end_h5_tag(void *pdoc, Node *UNUSED(child))
2171 xhtml_t *xhtml = GET_XHTML(pdoc);
2172 Doc *doc = xhtml->doc;
2180 * It is a handler who processes the H6 tag.
2182 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2183 * destination is specified.
2184 * @param node [i] The H6 tag node is specified.
2185 * @return The conversion result is returned.
2188 s_xhtml_1_0_start_h6_tag(void *pdoc, Node *node)
2190 xhtml_t *xhtml = GET_XHTML(pdoc);
2191 Doc *doc = xhtml->doc;
2195 for (attr = qs_get_attr(doc,node);
2197 attr = qs_get_next_attr(doc,attr)) {
2200 name = qs_get_attr_name(doc,attr);
2201 value = qs_get_attr_value(doc,attr);
2202 if (STRCASEEQ('a','A',"align", name)) {
2204 if (STRCASEEQ('l','L',"left",value)) {
2206 W_L("text-align:left");
2209 else if (STRCASEEQ('r','R',"right",value)) {
2211 W_L("text-align:right");
2214 else if (STRCASEEQ('c','C',"center",value)) {
2216 W_L("text-align:center");
2229 * It is a handler who processes the H6 tag.
2231 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2232 * destination is specified.
2233 * @param node [i] The H6 tag node is specified.
2234 * @return The conversion result is returned.
2237 s_xhtml_1_0_end_h6_tag(void *pdoc, Node *UNUSED(child))
2239 xhtml_t *xhtml = GET_XHTML(pdoc);
2240 Doc *doc = xhtml->doc;
2248 * It is a handler who processes the OL tag.
2250 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2251 * destination is specified.
2252 * @param node [i] The OL tag node is specified.
2253 * @return The conversion result is returned.
2256 s_xhtml_1_0_start_ol_tag(void *pdoc, Node *node)
2258 xhtml_t *xhtml = GET_XHTML(pdoc);
2259 Doc *doc = xhtml->doc;
2263 /*--------------------------------------------------------------------------*/
2264 /* Get Attributes */
2265 /*--------------------------------------------------------------------------*/
2266 for (attr = qs_get_attr(doc,node);
2268 attr = qs_get_next_attr(doc,attr)) {
2269 char *name = qs_get_attr_name(doc,attr);
2270 char *value = qs_get_attr_value(doc,attr);
2271 if (STRCASEEQ('t','T',"type",name) && value && (*value == '1' || *value == 'a' || *value == 'A')) {
2276 else if (STRCASEEQ('s','S',"start",name) && value && *value) {
2288 * It is a handler who processes the OL tag.
2290 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2291 * destination is specified.
2292 * @param node [i] The OL tag node is specified.
2293 * @return The conversion result is returned.
2296 s_xhtml_1_0_end_ol_tag(void *pdoc, Node *UNUSED(child))
2298 xhtml_t *xhtml = GET_XHTML(pdoc);
2299 Doc *doc = xhtml->doc;
2307 * It is a handler who processes the LI tag.
2309 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2310 * destination is specified.
2311 * @param node [i] The LI tag node is specified.
2312 * @return The conversion result is returned.
2315 s_xhtml_1_0_start_li_tag(void *pdoc, Node *node)
2317 xhtml_t *xhtml = GET_XHTML(pdoc);
2318 Doc *doc = xhtml->doc;
2322 /*--------------------------------------------------------------------------*/
2323 /* Get Attributes */
2324 /*--------------------------------------------------------------------------*/
2325 for (attr = qs_get_attr(doc,node);
2327 attr = qs_get_next_attr(doc,attr)) {
2328 char *name = qs_get_attr_name(doc,attr);
2329 char *value = qs_get_attr_value(doc,attr);
2330 if (STRCASEEQ('t','T',"type",name)) {
2331 if (value && (*value == '1' || *value == 'a' || *value == 'A' || STRCASEEQ('d','D',"disc",value) || STRCASEEQ('c','C',"circle",value) || STRCASEEQ('s','S',"square",value))) {
2337 else if (STRCASEEQ('v','V',"value", name) && value && *value) {
2349 ** It is a handler who processes the LI tag.
2351 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2352 * destination is specified.
2353 * @param node [i] The LI tag node is specified.
2354 * @return The conversion result is returned.
2357 s_xhtml_1_0_end_li_tag(void *pdoc, Node *UNUSED(child))
2359 xhtml_t *xhtml = GET_XHTML(pdoc);
2360 Doc *doc = xhtml->doc;
2367 * It is a handler who processes the IMG tag.
2369 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2370 * destination is specified.
2371 * @param node [i] The IMG tag node is specified.
2372 * @return The conversion result is returned.
2375 s_xhtml_1_0_start_img_tag(void *pdoc, Node *node)
2377 xhtml_t *xhtml = GET_XHTML(pdoc);
2378 Doc *doc = xhtml->doc;
2379 request_rec *r = doc->r;
2382 #ifndef IMG_NOT_CONVERT_FILENAME
2383 device_table *spec = xhtml->spec;
2387 /*--------------------------------------------------------------------------*/
2388 /* Get Attributes */
2389 /*--------------------------------------------------------------------------*/
2390 for (attr = qs_get_attr(doc,node);
2392 attr = qs_get_next_attr(doc,attr)) {
2393 char *name = qs_get_attr_name(doc,attr);
2394 char *value = qs_get_attr_value(doc,attr);
2396 if (STRCASEEQ('s','S',"src",name)) {
2397 value = chxj_encoding_parameter(r, value);
2398 value = chxj_add_cookie_parameter(r, value, xhtml->cookie);
2399 value = chxj_add_cookie_no_update_parameter(r, value);
2400 #ifdef IMG_NOT_CONVERT_FILENAME
2410 char *vv = chxj_img_conv(r,spec,value);
2418 if (STRCASEEQ('a','A',"align",name)) {
2420 if (STRCASEEQ('t','T',"top", value) ||
2421 STRCASEEQ('m','M',"middle",value) ||
2422 STRCASEEQ('b','B',"bottom",value) ||
2423 STRCASEEQ('l','L',"left", value) ||
2424 STRCASEEQ('r','R',"right", value)) {
2429 else if (STRCASEEQ('c','C',"center", value)) {
2436 else if (STRCASEEQ('a','A',"alt",name) && value && *value) {
2441 else if (STRCASEEQ('w','W',"width",name) && value && *value) {
2446 else if (STRCASEEQ('h','H',"height",name) && value && *value) {
2451 else if (STRCASEEQ('h','H',"hspace",name) && value && *value) {
2456 else if (STRCASEEQ('v','V',"vspace",name) && value && *value) {
2468 * It is a handler who processes the IMG tag.
2470 * @param xhtml [i/o] The pointer to the XHTML structure at the output
2471 * destination is specified.
2472 * @param node [i] The IMG tag node is specified.
2473 * @return The conversion result is returned.
2476 s_xhtml_1_0_end_img_tag(void *pdoc, Node *UNUSED(child))
2478 xhtml_t *xhtml = GET_XHTML(pdoc);
2485 * It is a handler who processes the SELECT tag.
2487 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2488 * destination is specified.
2489 * @param node [i] The SELECT tag node is specified.
2490 * @return The conversion result is returned.
2493 s_xhtml_1_0_start_select_tag(void *pdoc, Node *child)
2495 xhtml_t *xhtml = GET_XHTML(pdoc);
2496 Doc *doc = xhtml->doc;
2499 char *multiple = NULL;
2504 for (attr = qs_get_attr(doc,child);
2506 attr = qs_get_next_attr(doc,attr)) {
2507 char *nm = qs_get_attr_name(doc,attr);
2508 char *val = qs_get_attr_value(doc,attr);
2509 if (STRCASEEQ('s','S',"size",nm)) {
2510 /*----------------------------------------------------------------------*/
2511 /* CHTML 1.0 version 2.0 */
2512 /*----------------------------------------------------------------------*/
2513 size = apr_pstrdup(doc->buf.pool, val);
2515 else if (STRCASEEQ('n','N',"name",nm)) {
2516 /*----------------------------------------------------------------------*/
2517 /* CHTML 1.0 version 2.0 */
2518 /*----------------------------------------------------------------------*/
2519 name = apr_pstrdup(doc->buf.pool, val);
2521 else if (STRCASEEQ('m','M',"multiple",nm)) {
2522 /*----------------------------------------------------------------------*/
2523 /* CHTML 1.0 version 2.0 */
2524 /*----------------------------------------------------------------------*/
2525 multiple = apr_pstrdup(doc->buf.pool, val);
2528 if (size && *size) {
2533 if (name && *name) {
2539 /* "true" is *NOT* W3C. it is specification of WAP2.0 for EZWEB */
2540 W_L(" multiple=\"true\"");
2548 * It is a handler who processes the SELECT tag.
2550 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2551 * destination is specified.
2552 * @param node [i] The SELECT tag node is specified.
2553 * @return The conversion result is returned.
2556 s_xhtml_1_0_end_select_tag(void *pdoc, Node *UNUSED(child))
2558 xhtml_t *xhtml = GET_XHTML(pdoc);
2559 Doc *doc = xhtml->doc;
2567 * It is a handler who processes the OPTION tag.
2569 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2570 * destination is specified.
2571 * @param node [i] The OPTION tag node is specified.
2572 * @return The conversion result is returned.
2575 s_xhtml_1_0_start_option_tag(void *pdoc, Node *child)
2577 xhtml_t *xhtml = GET_XHTML(pdoc);
2578 Doc *doc = xhtml->doc;
2581 char *selected = NULL;
2585 for (attr = qs_get_attr(doc,child);
2587 attr = qs_get_next_attr(doc,attr)) {
2588 char *nm = qs_get_attr_name(doc,attr);
2589 char *val = qs_get_attr_value(doc,attr);
2590 if (STRCASEEQ('s','S',"selected",nm)) {
2591 /* CHTML version 2.0 */
2592 selected = apr_pstrdup(doc->buf.pool, val);
2594 else if (STRCASEEQ('v','V',"value",nm)) {
2595 /* CHTML version 2.0 */
2596 value = apr_pstrdup(doc->buf.pool, val);
2605 W_L(" selected=\"selected\"");
2613 * It is a handler who processes the OPTION tag.
2615 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2616 * destination is specified.
2617 * @param node [i] The OPTION tag node is specified.
2618 * @return The conversion result is returned.
2621 s_xhtml_1_0_end_option_tag(void *pdoc, Node *UNUSED(child))
2623 xhtml_t *xhtml = GET_XHTML(pdoc);
2624 Doc *doc = xhtml->doc;
2632 * It is a handler who processes the DIV tag.
2634 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2635 * destination is specified.
2636 * @param node [i] The DIV tag node is specified.
2637 * @return The conversion result is returned.
2640 s_xhtml_1_0_start_div_tag(void *pdoc, Node *child)
2642 xhtml_t *xhtml = GET_XHTML(pdoc);
2643 Doc *doc = xhtml->doc;
2648 for (attr = qs_get_attr(doc,child);
2650 attr = qs_get_next_attr(doc,attr)) {
2651 char *nm = qs_get_attr_name(doc,attr);
2652 char *val = qs_get_attr_value(doc,attr);
2653 if (STRCASEEQ('a','A',"align",nm)) {
2654 /*=====================================================================*/
2655 /* CHTML version 3.2 */
2656 /*=====================================================================*/
2657 if (val && (STRCASEEQ('l','L',"left",val) || STRCASEEQ('r','R',"right",val) || STRCASEEQ('c','C',"center",val))) {
2658 align = apr_pstrdup(doc->buf.pool, val);
2673 * It is a handler who processes the DIV tag.
2675 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2676 * destination is specified.
2677 * @param node [i] The DIV tag node is specified.
2678 * @return The conversion result is returned.
2681 s_xhtml_1_0_end_div_tag(void *pdoc, Node *UNUSED(child))
2683 xhtml_t *xhtml = GET_XHTML(pdoc);
2684 Doc *doc = xhtml->doc;
2691 * It is a handler who processes the B tag.
2693 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2694 * destination is specified.
2695 * @param node [i] The B tag node is specified.
2696 * @return The conversion result is returned.
2699 s_xhtml_1_0_start_b_tag(void *pdoc, Node *UNUSED(child))
2701 xhtml_t *xhtml = GET_XHTML(pdoc);
2702 Doc *doc = xhtml->doc;
2704 W_L("<div style=\"font-weight:bold\">");
2710 * It is a handler who processes the B tag.
2712 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2713 * destination is specified.
2714 * @param node [i] The B tag node is specified.
2715 * @return The conversion result is returned.
2718 s_xhtml_1_0_end_b_tag(void *pdoc, Node *UNUSED(child))
2720 xhtml_t *xhtml = GET_XHTML(pdoc);
2721 Doc *doc = xhtml->doc;
2729 * It is a handler who processes the CHXJ:IF tag.
2731 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2732 * destination is specified.
2733 * @param node [i] The CHXJ:IF tag node is specified.
2736 s_xhtml_1_0_chxjif_tag(void *pdoc, Node *node)
2738 xhtml_t *xhtml = GET_XHTML(pdoc);
2739 Doc *doc = xhtml->doc;
2742 for (child = qs_get_child_node(doc, node);
2744 child = qs_get_next_node(doc, child)) {
2746 s_xhtml_1_0_chxjif_tag(xhtml, child);
2754 * It is a handler who processes the TEXTARE tag.
2756 * @param pdoc [i/o] The pointer to the CHTML structure at the output
2757 * destination is specified.
2758 * @param node [i] The TEXTAREA tag node is specified.
2759 * @return The conversion result is returned.
2762 s_xhtml_1_0_start_textarea_tag(void *pdoc, Node *node)
2764 xhtml_t *xhtml = GET_XHTML(pdoc);
2765 Doc *doc = xhtml->doc;
2768 xhtml->textarea_flag++;
2770 for (attr = qs_get_attr(doc,node);
2772 attr = qs_get_next_attr(doc,attr)) {
2773 char *name = qs_get_attr_name(doc,attr);
2774 char *value = qs_get_attr_value(doc,attr);
2775 if (STRCASEEQ('n','N',"name",name) && value && *value) {
2780 else if (STRCASEEQ('r','R',"rows",name) && value && *value) {
2785 else if (STRCASEEQ('c','C',"cols",name) && value && *value) {
2790 else if (STRCASEEQ('i','I',"istyle", name) && value && (*value == '1' || *value == '2' || *value == '3' || *value == '4')) {
2791 char *fmt = qs_conv_istyle_to_format(doc->r,value);
2796 else if (STRCASEEQ('a','A',"accesskey",name) && value && *value != 0) {
2797 W_L(" accesskey=\"");
2808 * It is a handler who processes the TEXTAREA tag.
2810 * @param pdoc [i/o] The pointer to the CHTML structure at the output
2811 * destination is specified.
2812 * @param node [i] The TEXTAREA tag node is specified.
2813 * @return The conversion result is returned.
2816 s_xhtml_1_0_end_textarea_tag(void *pdoc, Node *UNUSED(child))
2818 xhtml_t *xhtml = GET_XHTML(pdoc);
2819 Doc *doc = xhtml->doc;
2822 xhtml->textarea_flag--;
2828 s_xhtml_1_0_text_tag(void *pdoc, Node *child)
2830 xhtml_t *xhtml = GET_XHTML(pdoc);
2831 Doc *doc = xhtml->doc;
2832 request_rec *r = doc->r;
2840 textval = qs_get_node_value(doc,child);
2841 if (strlen(textval) == 0) {
2845 tmp = apr_palloc(r->pool, qs_get_node_size(doc,child)+1);
2846 memset(tmp, 0, qs_get_node_size(doc,child)+1);
2848 tdst = qs_alloc_zero_byte_string(doc->buf.pool);
2849 memset(one_byte, 0, sizeof(one_byte));
2852 for (ii=0; ii<qs_get_node_size(doc,child); ii++) {
2854 int rtn = s_xhtml_search_emoji(xhtml, &textval[ii], &out);
2856 DBG(r,"[%s][%d]", out, rtn);
2857 tdst = qs_out_apr_pstrcat(r, tdst, out, &tdst_len);
2861 if (is_sjis_kanji(textval[ii])) {
2862 one_byte[0] = textval[ii+0];
2863 tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
2864 one_byte[0] = textval[ii+1];
2865 tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
2868 else if (xhtml->pre_flag) {
2869 one_byte[0] = textval[ii+0];
2870 tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
2872 else if (xhtml->textarea_flag) {
2873 one_byte[0] = textval[ii+0];
2874 tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
2876 else if (textval[ii] != '\r' && textval[ii] != '\n') {
2877 one_byte[0] = textval[ii+0];
2878 tdst = qs_out_apr_pstrcat(r, tdst, one_byte, &tdst_len);
2887 * It is a handler who processes the BLOCKQUOTE tag.
2889 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2890 * destination is specified.
2891 * @param node [i] The BLOCKQUOTE tag node is specified.
2892 * @return The conversion result is returned.
2895 s_xhtml_1_0_start_blockquote_tag(void *pdoc, Node *UNUSED(child))
2897 xhtml_t *xhtml = GET_XHTML(pdoc);
2898 Doc *doc = xhtml->doc;
2899 W_L("<blockquote>");
2905 * It is a handler who processes the BLOCKQUOTE tag.
2907 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2908 * destination is specified.
2909 * @param node [i] The BLOCKQUOTE tag node is specified.
2910 * @return The conversion result is returned.
2913 s_xhtml_1_0_end_blockquote_tag(void *pdoc, Node *UNUSED(child))
2915 xhtml_t *xhtml = GET_XHTML(pdoc);
2916 Doc *doc = xhtml->doc;
2917 W_L("</blockquote>");
2923 * It is a handler who processes the DIR tag.
2925 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2926 * destination is specified.
2927 * @param node [i] The DIR tag node is specified.
2928 * @return The conversion result is returned.
2931 s_xhtml_1_0_start_dir_tag(void *pdoc, Node *node)
2933 xhtml_t *xhtml = GET_XHTML(pdoc);
2934 Doc *doc = xhtml->doc;
2937 for (attr = qs_get_attr(doc,node);
2939 attr = qs_get_next_attr(doc,attr)) {
2940 char *name = qs_get_attr_name(doc,attr);
2941 char *value = qs_get_attr_value(doc,attr);
2942 if (STRCASEEQ('t','T',"type",name)) {
2943 if (value && (STRCASEEQ('d','D',"disc",value) || STRCASEEQ('c','C',"circle",value) || STRCASEEQ('s','S',"square",value))) {
2956 * It is a handler who processes the DIR tag.
2958 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2959 * destination is specified.
2960 * @param node [i] The DIR tag node is specified.
2961 * @return The conversion result is returned.
2964 s_xhtml_1_0_end_dir_tag(void *pdoc, Node *UNUSED(child))
2966 xhtml_t *xhtml = GET_XHTML(pdoc);
2967 Doc *doc = xhtml->doc;
2974 * It is a handler who processes the DL tag.
2976 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2977 * destination is specified.
2978 * @param node [i] The DL tag node is specified.
2979 * @return The conversion result is returned.
2982 s_xhtml_1_0_start_dl_tag(void *pdoc, Node *UNUSED(child))
2984 xhtml_t *xhtml = GET_XHTML(pdoc);
2985 Doc *doc = xhtml->doc;
2992 * It is a handler who processes the DL tag.
2994 * @param pdoc [i/o] The pointer to the XHTML structure at the output
2995 * destination is specified.
2996 * @param node [i] The DL tag node is specified.
2997 * @return The conversion result is returned.
3000 s_xhtml_1_0_end_dl_tag(void *pdoc, Node *UNUSED(child))
3002 xhtml_t *xhtml = GET_XHTML(pdoc);
3003 Doc *doc = xhtml->doc;
3010 * It is a handter who processes the DT tag.
3012 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3013 * destination is specified.
3014 * @param node [i] The DT tag node is specified.
3015 * @return The conversion result is returned.
3018 s_xhtml_1_0_start_dt_tag(void *pdoc, Node *UNUSED(child))
3020 xhtml_t *xhtml = GET_XHTML(pdoc);
3021 Doc *doc = xhtml->doc;
3028 * It is a handter who processes the DT tag.
3030 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3031 * destination is specified.
3032 * @param node [i] The DT tag node is specified.
3033 * @return The conversion result is returned.
3036 s_xhtml_1_0_end_dt_tag(void *pdoc, Node *UNUSED(child))
3038 xhtml_t *xhtml = GET_XHTML(pdoc);
3039 Doc *doc = xhtml->doc;
3046 * It is a handder who processes the DD tag.
3048 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3049 * destination is specified.
3050 * @param node [i] The DD tag node is specified.
3051 * @return The conversion result is returned.
3054 s_xhtml_1_0_start_dd_tag(void *pdoc, Node *UNUSED(child))
3056 xhtml_t *xhtml = GET_XHTML(pdoc);
3057 Doc *doc = xhtml->doc;
3064 * It is a handder who processes the DD tag.
3066 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3067 * destination is specified.
3068 * @param node [i] The DD tag node is specified.
3069 * @return The conversion result is returned.
3072 s_xhtml_1_0_end_dd_tag(void *pdoc, Node *UNUSED(child))
3074 xhtml_t *xhtml = GET_XHTML(pdoc);
3075 Doc *doc = xhtml->doc;
3082 * It is a handler who processes the MENU tag.
3084 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3085 * destination is specified.
3086 * @param node [i] The MENU tag node is specified.
3087 * @return The conversion result is returned.
3090 s_xhtml_1_0_start_menu_tag(void *pdoc, Node *node)
3092 xhtml_t *xhtml = GET_XHTML(pdoc);
3093 Doc *doc = xhtml->doc;
3096 /*--------------------------------------------------------------------------*/
3097 /* Get Attributes */
3098 /*--------------------------------------------------------------------------*/
3099 for (attr = qs_get_attr(doc,node);
3101 attr = qs_get_next_attr(doc,attr)) {
3102 char *name = qs_get_attr_name(doc,attr);
3103 char *value = qs_get_attr_value(doc,attr);
3104 if (STRCASEEQ('t','T',"type",name)) {
3105 if (value && (STRCASEEQ('d','D',"disc",value) || STRCASEEQ('c','C',"circle",value) || STRCASEEQ('s','S',"square",value))) {
3118 * It is a hanmenuer who processes the MENU tag.
3120 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3121 * destination is specified.
3122 * @param node [i] The MENU tag node is specified.
3123 * @return The conversion result is returned.
3126 s_xhtml_1_0_end_menu_tag(void *pdoc, Node *UNUSED(child))
3128 xhtml_t *xhtml = GET_XHTML(pdoc);
3129 Doc *doc = xhtml->doc;
3136 * It is a handler who processes the PLAINTEXT tag.
3138 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3139 * destination is specified.
3140 * @param node [i] The PLAINTEXT tag node is specified.
3141 * @return The conversion result is returned.
3144 s_xhtml_1_0_start_plaintext_tag(void *pdoc, Node *node)
3146 xhtml_t *xhtml = GET_XHTML(pdoc);
3147 Doc *doc = xhtml->doc;
3149 s_xhtml_1_0_start_plaintext_tag_inner(pdoc,node);
3154 s_xhtml_1_0_start_plaintext_tag_inner(void *pdoc, Node *node)
3156 xhtml_t *xhtml = GET_XHTML(pdoc);
3157 Doc *doc = xhtml->doc;
3159 for (child = qs_get_child_node(doc, node);
3161 child = qs_get_next_node(doc, child)) {
3163 s_xhtml_1_0_start_plaintext_tag_inner(pdoc, child);
3170 * It is a handler who processes the PLAINTEXT tag.
3172 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3173 * destination is specified.
3174 * @param node [i] The PLAINTEXT tag node is specified.
3175 * @return The conversion result is returned.
3178 s_xhtml_1_0_end_plaintext_tag(void *pdoc, Node *UNUSED(child))
3180 xhtml_t *xhtml = GET_XHTML(pdoc);
3181 Doc *doc = xhtml->doc;
3182 W_L("</plaintext>");
3188 * It is a hanblinker who processes the BLINK tag.
3190 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3191 * destination is specified.
3192 * @param node [i] The BLINK tag node is specified.
3193 * @return The conversion result is returned.
3196 s_xhtml_1_0_start_blink_tag(void *pdoc, Node *UNUSED(child))
3198 xhtml_t *xhtml = GET_XHTML(pdoc);
3199 Doc *doc = xhtml->doc;
3206 * It is a hanblinker who processes the BLINK tag.
3208 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3209 * destination is specified.
3210 * @param node [i] The BLINK tag node is specified.
3211 * @return The conversion result is returned.
3214 s_xhtml_1_0_end_blink_tag(void *pdoc, Node *UNUSED(child))
3216 xhtml_t *xhtml = GET_XHTML(pdoc);
3217 Doc *doc = xhtml->doc;
3224 * It is a handler who processes the MARQUEE tag.
3226 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3227 * destination is specified.
3228 * @param node [i] The MARQUEE tag node is specified.
3229 * @return The conversion result is returned.
3232 s_xhtml_1_0_start_marquee_tag(void *pdoc, Node *node)
3234 xhtml_t *xhtml = GET_XHTML(pdoc);
3235 Doc *doc = xhtml->doc;
3238 /*--------------------------------------------------------------------------*/
3239 /* Get Attributes */
3240 /*--------------------------------------------------------------------------*/
3241 for (attr = qs_get_attr(doc,node);
3243 attr = qs_get_next_attr(doc,attr)) {
3244 char *name = qs_get_attr_name(doc,attr);
3245 char *value = qs_get_attr_value(doc,attr);
3246 if (STRCASEEQ('d','D',"direction", name)) {
3247 if (value && (STRCASEEQ('l','L',"left",value) || STRCASEEQ('r','R',"right",value))) {
3248 W_L(" direction=\"");
3253 else if (STRCASEEQ('b','B',"behavior",name)) {
3254 if (value && (STRCASEEQ('s','S',"scroll",value) || STRCASEEQ('s','S',"slide",value) || STRCASEEQ('a','A',"alternate",value))) {
3255 W_L(" behavior=\"");
3260 else if (STRCASEEQ('l','L',"loop",name)) {
3261 if (value && *value) {
3267 else if (STRCASEEQ('b','B',"bgcolor",name)) {
3268 if (value && *value) {
3281 * It is a handler who processes the MARQUEE tag.
3283 * @param pdoc [i/o] The pointer to the XHTML structure at the output
3284 * destination is specified.
3285 * @param node [i] The MARQUEE tag node is specified.
3286 * @return The conversion result is returned.
3289 s_xhtml_1_0_end_marquee_tag(void *pdoc, Node *UNUSED(child))
3291 xhtml_t *xhtml = GET_XHTML(pdoc);
3292 Doc *doc = xhtml->doc;
3299 * It is handler who processes the New Line Code.
3302 s_xhtml_1_0_newline_mark(void *pdoc, Node *UNUSED(node))
3304 xhtml_t *xhtml = GET_XHTML(pdoc);
3305 Doc *doc = xhtml->doc;