php-src/Zend/zend_highlight.c

231 lines
5.7 KiB
C
Raw Normal View History

1999-04-08 02:10:10 +08:00
/*
+----------------------------------------------------------------------+
| Zend Engine |
+----------------------------------------------------------------------+
2019-01-30 17:23:29 +08:00
| Copyright (c) Zend Technologies Ltd. (http://www.zend.com) |
1999-04-08 02:10:10 +08:00
+----------------------------------------------------------------------+
2001-12-11 23:16:21 +08:00
| This source file is subject to version 2.00 of the Zend license, |
2015-01-03 17:22:58 +08:00
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
2001-12-11 23:16:21 +08:00
| http://www.zend.com/license/2_00.txt. |
1999-07-16 22:58:16 +08:00
| 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. |
1999-04-08 02:10:10 +08:00
+----------------------------------------------------------------------+
| Authors: Andi Gutmans <andi@php.net> |
| Zeev Suraski <zeev@php.net> |
1999-04-08 02:10:10 +08:00
+----------------------------------------------------------------------+
*/
#include "zend.h"
#include <zend_language_parser.h>
1999-04-08 02:10:10 +08:00
#include "zend_compile.h"
#include "zend_highlight.h"
#include "zend_ptr_stack.h"
#include "zend_globals.h"
2015-12-11 23:04:32 +08:00
#include "zend_exceptions.h"
1999-04-08 02:10:10 +08:00
2010-03-12 18:28:59 +08:00
ZEND_API void zend_html_putc(char c)
1999-04-08 02:10:10 +08:00
{
switch (c) {
case '\n':
ZEND_PUTS("<br />");
1999-04-08 02:10:10 +08:00
break;
case '<':
ZEND_PUTS("&lt;");
break;
case '>':
ZEND_PUTS("&gt;");
break;
case '&':
ZEND_PUTS("&amp;");
break;
case ' ':
ZEND_PUTS("&nbsp;");
break;
case '\t':
ZEND_PUTS("&nbsp;&nbsp;&nbsp;&nbsp;");
break;
default:
ZEND_PUTC(c);
break;
}
}
2010-03-12 18:28:59 +08:00
2014-12-14 06:06:14 +08:00
ZEND_API void zend_html_puts(const char *s, size_t len)
1999-04-08 02:10:10 +08:00
{
const unsigned char *ptr = (const unsigned char*)s, *end = ptr + len;
2014-02-23 21:55:29 +08:00
unsigned char *filtered = NULL;
size_t filtered_len;
if (LANG_SCNG(output_filter)) {
2014-12-14 06:06:14 +08:00
LANG_SCNG(output_filter)(&filtered, &filtered_len, ptr, len);
ptr = filtered;
end = filtered + filtered_len;
}
1999-04-08 02:10:10 +08:00
while (ptr<end) {
2002-05-12 23:59:29 +08:00
if (*ptr==' ') {
do {
zend_html_putc(*ptr);
} while ((++ptr < end) && (*ptr==' '));
2002-05-12 23:59:29 +08:00
} else {
zend_html_putc(*ptr++);
}
1999-04-08 02:10:10 +08:00
}
if (LANG_SCNG(output_filter)) {
efree(filtered);
}
1999-04-08 02:10:10 +08:00
}
2010-03-12 18:28:59 +08:00
2014-12-14 06:06:14 +08:00
ZEND_API void zend_highlight(zend_syntax_highlighter_ini *syntax_highlighter_ini)
1999-04-08 02:10:10 +08:00
{
zval token;
int token_type;
char *last_color = syntax_highlighter_ini->highlight_html;
char *next_color;
zend_printf("<code>");
zend_printf("<span style=\"color: %s\">\n", last_color);
1999-04-08 02:10:10 +08:00
/* highlight stuff coming back from zendlex() */
while ((token_type=lex_scan(&token, NULL))) {
1999-04-08 02:10:10 +08:00
switch (token_type) {
case T_INLINE_HTML:
1999-04-08 02:10:10 +08:00
next_color = syntax_highlighter_ini->highlight_html;
break;
case T_COMMENT:
case T_DOC_COMMENT:
1999-04-08 02:10:10 +08:00
next_color = syntax_highlighter_ini->highlight_comment;
break;
case T_OPEN_TAG:
2000-03-10 00:02:05 +08:00
case T_OPEN_TAG_WITH_ECHO:
case T_CLOSE_TAG:
case T_LINE:
case T_FILE:
case T_DIR:
case T_TRAIT_C:
case T_METHOD_C:
case T_FUNC_C:
case T_NS_C:
case T_CLASS_C:
1999-04-08 02:10:10 +08:00
next_color = syntax_highlighter_ini->highlight_default;
break;
case '"':
case T_ENCAPSED_AND_WHITESPACE:
case T_CONSTANT_ENCAPSED_STRING:
1999-04-08 02:10:10 +08:00
next_color = syntax_highlighter_ini->highlight_string;
break;
case T_WHITESPACE:
2014-12-14 06:06:14 +08:00
zend_html_puts((char*)LANG_SCNG(yy_text), LANG_SCNG(yy_leng)); /* no color needed */
ZVAL_UNDEF(&token);
1999-04-08 02:10:10 +08:00
continue;
break;
default:
if (Z_TYPE(token) == IS_UNDEF) {
1999-04-08 02:10:10 +08:00
next_color = syntax_highlighter_ini->highlight_keyword;
} else {
next_color = syntax_highlighter_ini->highlight_default;
1999-04-08 02:10:10 +08:00
}
break;
}
if (last_color != next_color) {
if (last_color != syntax_highlighter_ini->highlight_html) {
zend_printf("</span>");
1999-04-08 02:10:10 +08:00
}
last_color = next_color;
if (last_color != syntax_highlighter_ini->highlight_html) {
zend_printf("<span style=\"color: %s\">", last_color);
1999-04-08 02:10:10 +08:00
}
}
2014-12-14 06:06:14 +08:00
zend_html_puts((char*)LANG_SCNG(yy_text), LANG_SCNG(yy_leng));
1999-04-08 02:10:10 +08:00
if (Z_TYPE(token) == IS_STRING) {
1999-04-08 02:10:10 +08:00
switch (token_type) {
case T_OPEN_TAG:
2000-03-10 00:02:05 +08:00
case T_OPEN_TAG_WITH_ECHO:
case T_CLOSE_TAG:
case T_WHITESPACE:
2001-01-12 14:55:57 +08:00
case T_COMMENT:
case T_DOC_COMMENT:
break;
default:
zval_ptr_dtor_str(&token);
break;
1999-04-08 02:10:10 +08:00
}
}
ZVAL_UNDEF(&token);
1999-04-08 02:10:10 +08:00
}
1999-04-08 02:10:10 +08:00
if (last_color != syntax_highlighter_ini->highlight_html) {
zend_printf("</span>\n");
1999-04-08 02:10:10 +08:00
}
zend_printf("</span>\n");
zend_printf("</code>");
2015-12-11 23:04:32 +08:00
/* Discard parse errors thrown during tokenization */
zend_clear_exception();
1999-04-08 02:10:10 +08:00
}
2014-12-14 06:06:14 +08:00
ZEND_API void zend_strip(void)
{
zval token;
int token_type;
int prev_space = 0;
while ((token_type=lex_scan(&token, NULL))) {
switch (token_type) {
case T_WHITESPACE:
if (!prev_space) {
zend_write(" ", sizeof(" ") - 1);
prev_space = 1;
}
ZEND_FALLTHROUGH;
case T_COMMENT:
case T_DOC_COMMENT:
ZVAL_UNDEF(&token);
continue;
2015-01-03 17:22:58 +08:00
case T_END_HEREDOC:
zend_write((char*)LANG_SCNG(yy_text), LANG_SCNG(yy_leng));
/* read the following character, either newline or ; */
if (lex_scan(&token, NULL) != T_WHITESPACE) {
zend_write((char*)LANG_SCNG(yy_text), LANG_SCNG(yy_leng));
}
zend_write("\n", sizeof("\n") - 1);
prev_space = 1;
ZVAL_UNDEF(&token);
continue;
default:
zend_write((char*)LANG_SCNG(yy_text), LANG_SCNG(yy_leng));
break;
}
if (Z_TYPE(token) == 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:
case T_DOC_COMMENT:
break;
default:
zval_ptr_dtor_str(&token);
break;
}
}
prev_space = 0;
ZVAL_UNDEF(&token);
}
2016-03-12 05:45:38 +08:00
/* Discard parse errors thrown during tokenization */
zend_clear_exception();
}