/* +----------------------------------------------------------------------+ | Zend Engine | +----------------------------------------------------------------------+ | Copyright (c) 1998-2002 Zend Technologies Ltd. (http://www.zend.com) | +----------------------------------------------------------------------+ | This source file is subject to version 2.00 of the Zend license, | | that is bundled with this package in the file LICENSE, and is | | available at through the world-wide-web at | | http://www.zend.com/license/2_00.txt. | | If you did not receive a copy of the Zend license and are unable to | | obtain it through the world-wide-web, please send a note to | | license@zend.com so we can mail you a copy immediately. | +----------------------------------------------------------------------+ | Authors: Andi Gutmans | | Zeev Suraski | +----------------------------------------------------------------------+ */ #include "zend.h" #include "zend_language_parser.h" #include "zend_compile.h" #include "zend_highlight.h" #include "zend_ptr_stack.h" #include "zend_globals.h" ZEND_API void zend_html_putc(char c) { switch (c) { case '\n': ZEND_PUTS("
"); break; case '<': ZEND_PUTS("<"); break; case '>': ZEND_PUTS(">"); break; case '&': ZEND_PUTS("&"); break; case ' ': ZEND_PUTS(" "); break; case '\t': ZEND_PUTS("    "); break; default: ZEND_PUTC(c); break; } } ZEND_API void zend_html_puts(const char *s, uint len TSRMLS_DC) { const char *ptr=s, *end=s+len; while (ptrhighlight_html; char *next_color; int in_string=0; zend_printf(""); zend_printf("\n", last_color); /* highlight stuff coming back from zendlex() */ token.type = 0; while ((token_type=lex_scan(&token TSRMLS_CC))) { switch (token_type) { case T_INLINE_HTML: next_color = syntax_highlighter_ini->highlight_html; break; case T_COMMENT: next_color = syntax_highlighter_ini->highlight_comment; break; case T_OPEN_TAG: case T_OPEN_TAG_WITH_ECHO: next_color = syntax_highlighter_ini->highlight_default; break; case T_CLOSE_TAG: next_color = syntax_highlighter_ini->highlight_default; break; case T_CONSTANT_ENCAPSED_STRING: next_color = syntax_highlighter_ini->highlight_string; break; case '"': next_color = syntax_highlighter_ini->highlight_string; in_string = !in_string; break; case T_WHITESPACE: zend_html_puts(LANG_SCNG(yy_text), LANG_SCNG(yy_leng) TSRMLS_CC); /* no color needed */ token.type = 0; continue; break; default: if (token.type==0) { next_color = syntax_highlighter_ini->highlight_keyword; } else { if (in_string) { next_color = syntax_highlighter_ini->highlight_string; } else { next_color = syntax_highlighter_ini->highlight_default; } } break; } if (last_color != next_color) { if (last_color != syntax_highlighter_ini->highlight_html) { zend_printf(""); } last_color = next_color; if (last_color != syntax_highlighter_ini->highlight_html) { zend_printf("", last_color); } } switch (token_type) { case T_END_HEREDOC: zend_html_puts(token.value.str.val, token.value.str.len TSRMLS_CC); break; default: zend_html_puts(LANG_SCNG(yy_text), LANG_SCNG(yy_leng) TSRMLS_CC); break; } if (token.type == IS_STRING) { switch (token_type) { case T_OPEN_TAG: case T_OPEN_TAG_WITH_ECHO: case T_CLOSE_TAG: case T_WHITESPACE: case T_COMMENT: break; default: efree(token.value.str.val); break; } } else if (token_type == T_END_HEREDOC) { zend_bool has_semicolon=(strchr(token.value.str.val, ';')?1:0); efree(token.value.str.val); if (has_semicolon) { /* the following semicolon was unput(), ignore it */ lex_scan(&token TSRMLS_CC); } } token.type = 0; } if (last_color != syntax_highlighter_ini->highlight_html) { zend_printf("\n"); } zend_printf("\n"); zend_printf(""); } ZEND_API void zend_strip(TSRMLS_D) { zval token; int token_type; token.type = 0; while ((token_type=lex_scan(&token TSRMLS_CC))) { switch (token_type) { case T_COMMENT: token.type = 0; continue; case T_WHITESPACE: if (token.type) { putchar(' '); token.type = 0; } continue; } switch (token_type) { case 349: break; default: { char c, *ptr=LANG_SCNG(yy_text), *end=LANG_SCNG(yy_text)+LANG_SCNG(yy_leng); while (ptr