mirror of
https://github.com/php/php-src.git
synced 2024-11-24 18:34:21 +08:00
Merge sapi/phpdbg into PHP-5.6
This commit is contained in:
commit
6adc30028c
1
sapi/phpdbg/.gitignore
vendored
1
sapi/phpdbg/.gitignore
vendored
@ -2,4 +2,5 @@
|
||||
phpdbg
|
||||
*.lo
|
||||
*.o
|
||||
*.output
|
||||
build
|
||||
|
@ -8,14 +8,17 @@ $(BUILD_SHARED): $(PHP_GLOBAL_OBJS) $(PHP_BINARY_OBJS) $(PHP_PHPDBG_OBJS)
|
||||
$(BUILD_BINARY): $(PHP_GLOBAL_OBJS) $(PHP_BINARY_OBJS) $(PHP_PHPDBG_OBJS)
|
||||
$(BUILD_PHPDBG)
|
||||
|
||||
$(builddir)/sapi/phpdbg/phpdbg_lexer.lo: $(srcdir)/sapi/phpdbg/phpdbg_parser.h
|
||||
%.c: %.y
|
||||
%.c: %.l
|
||||
|
||||
$(srcdir)/sapi/phpdbg/phpdbg_lexer.c: $(srcdir)/sapi/phpdbg/phpdbg_lexer.l
|
||||
@(cd $(top_srcdir); $(RE2C) $(RE2C_FLAGS) --no-generation-date -cbdFo sapi/phpdbg/phpdbg_lexer.c sapi/phpdbg/phpdbg_lexer.l)
|
||||
$(builddir)/phpdbg_lexer.lo: $(srcdir)/phpdbg_parser.h
|
||||
|
||||
$(srcdir)/sapi/phpdbg/phpdbg_parser.h: $(srcdir)/sapi/phpdbg/phpdbg_parser.c
|
||||
$(srcdir)/sapi/phpdbg/phpdbg_parser.c: $(srcdir)/sapi/phpdbg/phpdbg_parser.y
|
||||
@$(YACC) -p phpdbg_ -v -d $(srcdir)/sapi/phpdbg/phpdbg_parser.y -o $@
|
||||
$(srcdir)/phpdbg_lexer.c: $(srcdir)/phpdbg_lexer.l
|
||||
@(cd $(top_srcdir); $(RE2C) $(RE2C_FLAGS) --no-generation-date -cbdFo $(srcdir)/phpdbg_lexer.c $(srcdir)/phpdbg_lexer.l)
|
||||
|
||||
$(srcdir)/phpdbg_parser.h: $(srcdir)/phpdbg_parser.c
|
||||
$(srcdir)/phpdbg_parser.c: $(srcdir)/phpdbg_parser.y
|
||||
@$(YACC) -p phpdbg_ -v -d $(srcdir)/phpdbg_parser.y -o $@
|
||||
|
||||
install-phpdbg: $(BUILD_BINARY)
|
||||
@echo "Installing phpdbg binary: $(INSTALL_ROOT)$(bindir)/"
|
||||
|
@ -28,7 +28,7 @@ if test "$PHP_PHPDBG" != "no"; then
|
||||
PHP_SUBST(PHP_PHPDBG_FILES)
|
||||
PHP_SUBST(PHPDBG_EXTRA_LIBS)
|
||||
|
||||
PHP_ADD_MAKEFILE_FRAGMENT([$abs_srcdir/sapi/phpdbg/Makefile.frag])
|
||||
PHP_ADD_MAKEFILE_FRAGMENT([$abs_srcdir/sapi/phpdbg/Makefile.frag], [$abs_srcdir/sapi/phpdbg], [$abs_builddir/sapi/phpdbg])
|
||||
PHP_SELECT_SAPI(phpdbg, program, $PHP_PHPDBG_FILES, $PHP_PHPDBG_CFLAGS, [$(SAPI_PHPDBG_PATH)])
|
||||
|
||||
BUILD_BINARY="sapi/phpdbg/phpdbg"
|
||||
|
@ -69,11 +69,14 @@
|
||||
# include <readline/history.h>
|
||||
#endif
|
||||
|
||||
#include "phpdbg_lexer.h"
|
||||
#include "phpdbg_cmd.h"
|
||||
#include "phpdbg_utils.h"
|
||||
#include "phpdbg_btree.h"
|
||||
#include "phpdbg_watch.h"
|
||||
|
||||
int phpdbg_do_parse(phpdbg_param_t *stack, char *input TSRMLS_DC);
|
||||
|
||||
#ifdef ZTS
|
||||
# define PHPDBG_G(v) TSRMG(phpdbg_globals_id, zend_phpdbg_globals *, v)
|
||||
#else
|
||||
@ -176,10 +179,12 @@ ZEND_BEGIN_MODULE_GLOBALS(phpdbg)
|
||||
phpdbg_frame_t frame; /* frame */
|
||||
zend_uint last_line; /* last executed line */
|
||||
|
||||
phpdbg_lexer_data lexer; /* lexer data */
|
||||
phpdbg_param_t *parser_stack; /* param stack during lexer / parser phase */
|
||||
|
||||
#ifndef _WIN32
|
||||
struct sigaction old_sigsegv_signal; /* segv signal handler */
|
||||
#endif
|
||||
|
||||
phpdbg_btree watchpoint_tree; /* tree with watchpoints */
|
||||
phpdbg_btree watch_HashTables; /* tree with original dtors of watchpoints */
|
||||
HashTable watchpoints; /* watchpoints */
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,348 +1,41 @@
|
||||
#ifndef yyHEADER_H
|
||||
#define yyHEADER_H 1
|
||||
#define yyIN_HEADER 1
|
||||
/*
|
||||
+----------------------------------------------------------------------+
|
||||
| PHP Version 5 |
|
||||
+----------------------------------------------------------------------+
|
||||
| Copyright (c) 1997-2014 The PHP Group |
|
||||
+----------------------------------------------------------------------+
|
||||
| This source file is subject to version 3.01 of the PHP license, |
|
||||
| that is bundled with this package in the file LICENSE, and is |
|
||||
| available through the world-wide-web at the following url: |
|
||||
| http://www.php.net/license/3_01.txt |
|
||||
| If you did not receive a copy of the PHP license and are unable to |
|
||||
| obtain it through the world-wide-web, please send a note to |
|
||||
| license@php.net so we can mail you a copy immediately. |
|
||||
+----------------------------------------------------------------------+
|
||||
| Authors: Felipe Pena <felipe@php.net> |
|
||||
| Authors: Joe Watkins <joe.watkins@live.co.uk> |
|
||||
| Authors: Bob Weinand <bwoebi@php.net> |
|
||||
+----------------------------------------------------------------------+
|
||||
*/
|
||||
|
||||
#line 6 "sapi/phpdbg/phpdbg_lexer.h"
|
||||
#ifndef PHPDBG_LEXER_H
|
||||
#define PHPDBG_LEXER_H
|
||||
|
||||
#line 8 "sapi/phpdbg/phpdbg_lexer.h"
|
||||
#include "phpdbg_cmd.h"
|
||||
|
||||
#define YY_INT_ALIGNED short int
|
||||
typedef struct {
|
||||
unsigned int len;
|
||||
unsigned char *text;
|
||||
unsigned char *cursor;
|
||||
unsigned char *marker;
|
||||
int state;
|
||||
} phpdbg_lexer_data;
|
||||
|
||||
/* A lexical scanner generated by flex */
|
||||
#define yyparse phpdbg_parse
|
||||
#define yylex phpdbg_lex
|
||||
|
||||
#define FLEX_SCANNER
|
||||
#define YY_FLEX_MAJOR_VERSION 2
|
||||
#define YY_FLEX_MINOR_VERSION 5
|
||||
#define YY_FLEX_SUBMINOR_VERSION 37
|
||||
#if YY_FLEX_SUBMINOR_VERSION > 0
|
||||
#define FLEX_BETA
|
||||
#endif
|
||||
void phpdbg_init_lexer (phpdbg_param_t *stack, char *input TSRMLS_DC);
|
||||
|
||||
/* First, we deal with platform-specific or compiler-specific issues. */
|
||||
|
||||
/* begin standard C headers. */
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <errno.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
/* end standard C headers. */
|
||||
|
||||
/* flex integer type definitions */
|
||||
|
||||
#ifndef FLEXINT_H
|
||||
#define FLEXINT_H
|
||||
|
||||
/* C99 systems have <inttypes.h>. Non-C99 systems may or may not. */
|
||||
|
||||
#if defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
|
||||
|
||||
/* C99 says to define __STDC_LIMIT_MACROS before including stdint.h,
|
||||
* if you want the limit (max/min) macros for int types.
|
||||
*/
|
||||
#ifndef __STDC_LIMIT_MACROS
|
||||
#define __STDC_LIMIT_MACROS 1
|
||||
#endif
|
||||
|
||||
#include <inttypes.h>
|
||||
typedef int8_t flex_int8_t;
|
||||
typedef uint8_t flex_uint8_t;
|
||||
typedef int16_t flex_int16_t;
|
||||
typedef uint16_t flex_uint16_t;
|
||||
typedef int32_t flex_int32_t;
|
||||
typedef uint32_t flex_uint32_t;
|
||||
#else
|
||||
typedef signed char flex_int8_t;
|
||||
typedef short int flex_int16_t;
|
||||
typedef int flex_int32_t;
|
||||
typedef unsigned char flex_uint8_t;
|
||||
typedef unsigned short int flex_uint16_t;
|
||||
typedef unsigned int flex_uint32_t;
|
||||
|
||||
/* Limits of integral types. */
|
||||
#ifndef INT8_MIN
|
||||
#define INT8_MIN (-128)
|
||||
#endif
|
||||
#ifndef INT16_MIN
|
||||
#define INT16_MIN (-32767-1)
|
||||
#endif
|
||||
#ifndef INT32_MIN
|
||||
#define INT32_MIN (-2147483647-1)
|
||||
#endif
|
||||
#ifndef INT8_MAX
|
||||
#define INT8_MAX (127)
|
||||
#endif
|
||||
#ifndef INT16_MAX
|
||||
#define INT16_MAX (32767)
|
||||
#endif
|
||||
#ifndef INT32_MAX
|
||||
#define INT32_MAX (2147483647)
|
||||
#endif
|
||||
#ifndef UINT8_MAX
|
||||
#define UINT8_MAX (255U)
|
||||
#endif
|
||||
#ifndef UINT16_MAX
|
||||
#define UINT16_MAX (65535U)
|
||||
#endif
|
||||
#ifndef UINT32_MAX
|
||||
#define UINT32_MAX (4294967295U)
|
||||
#endif
|
||||
|
||||
#endif /* ! C99 */
|
||||
|
||||
#endif /* ! FLEXINT_H */
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
||||
/* The "const" storage-class-modifier is valid. */
|
||||
#define YY_USE_CONST
|
||||
|
||||
#else /* ! __cplusplus */
|
||||
|
||||
/* C99 requires __STDC__ to be defined as 1. */
|
||||
#if defined (__STDC__)
|
||||
|
||||
#define YY_USE_CONST
|
||||
|
||||
#endif /* defined (__STDC__) */
|
||||
#endif /* ! __cplusplus */
|
||||
|
||||
#ifdef YY_USE_CONST
|
||||
#define yyconst const
|
||||
#else
|
||||
#define yyconst
|
||||
#endif
|
||||
|
||||
/* An opaque pointer. */
|
||||
#ifndef YY_TYPEDEF_YY_SCANNER_T
|
||||
#define YY_TYPEDEF_YY_SCANNER_T
|
||||
typedef void* yyscan_t;
|
||||
#endif
|
||||
|
||||
/* For convenience, these vars (plus the bison vars far below)
|
||||
are macros in the reentrant scanner. */
|
||||
#define yyin yyg->yyin_r
|
||||
#define yyout yyg->yyout_r
|
||||
#define yyextra yyg->yyextra_r
|
||||
#define yyleng yyg->yyleng_r
|
||||
#define yytext yyg->yytext_r
|
||||
#define yylineno (YY_CURRENT_BUFFER_LVALUE->yy_bs_lineno)
|
||||
#define yycolumn (YY_CURRENT_BUFFER_LVALUE->yy_bs_column)
|
||||
#define yy_flex_debug yyg->yy_flex_debug_r
|
||||
|
||||
/* Size of default input buffer. */
|
||||
#ifndef YY_BUF_SIZE
|
||||
#define YY_BUF_SIZE 16384
|
||||
#endif
|
||||
|
||||
#ifndef YY_TYPEDEF_YY_BUFFER_STATE
|
||||
#define YY_TYPEDEF_YY_BUFFER_STATE
|
||||
typedef struct yy_buffer_state *YY_BUFFER_STATE;
|
||||
#endif
|
||||
|
||||
#ifndef YY_TYPEDEF_YY_SIZE_T
|
||||
#define YY_TYPEDEF_YY_SIZE_T
|
||||
typedef size_t yy_size_t;
|
||||
#endif
|
||||
|
||||
#ifndef YY_STRUCT_YY_BUFFER_STATE
|
||||
#define YY_STRUCT_YY_BUFFER_STATE
|
||||
struct yy_buffer_state
|
||||
{
|
||||
FILE *yy_input_file;
|
||||
|
||||
char *yy_ch_buf; /* input buffer */
|
||||
char *yy_buf_pos; /* current position in input buffer */
|
||||
|
||||
/* Size of input buffer in bytes, not including room for EOB
|
||||
* characters.
|
||||
*/
|
||||
yy_size_t yy_buf_size;
|
||||
|
||||
/* Number of characters read into yy_ch_buf, not including EOB
|
||||
* characters.
|
||||
*/
|
||||
yy_size_t yy_n_chars;
|
||||
|
||||
/* Whether we "own" the buffer - i.e., we know we created it,
|
||||
* and can realloc() it to grow it, and should free() it to
|
||||
* delete it.
|
||||
*/
|
||||
int yy_is_our_buffer;
|
||||
|
||||
/* Whether this is an "interactive" input source; if so, and
|
||||
* if we're using stdio for input, then we want to use getc()
|
||||
* instead of fread(), to make sure we stop fetching input after
|
||||
* each newline.
|
||||
*/
|
||||
int yy_is_interactive;
|
||||
|
||||
/* Whether we're considered to be at the beginning of a line.
|
||||
* If so, '^' rules will be active on the next match, otherwise
|
||||
* not.
|
||||
*/
|
||||
int yy_at_bol;
|
||||
|
||||
int yy_bs_lineno; /**< The line count. */
|
||||
int yy_bs_column; /**< The column count. */
|
||||
|
||||
/* Whether to try to fill the input buffer when we reach the
|
||||
* end of it.
|
||||
*/
|
||||
int yy_fill_buffer;
|
||||
|
||||
int yy_buffer_status;
|
||||
|
||||
};
|
||||
#endif /* !YY_STRUCT_YY_BUFFER_STATE */
|
||||
|
||||
void yyrestart (FILE *input_file ,yyscan_t yyscanner );
|
||||
void yy_switch_to_buffer (YY_BUFFER_STATE new_buffer ,yyscan_t yyscanner );
|
||||
YY_BUFFER_STATE yy_create_buffer (FILE *file,int size ,yyscan_t yyscanner );
|
||||
void yy_delete_buffer (YY_BUFFER_STATE b ,yyscan_t yyscanner );
|
||||
void yy_flush_buffer (YY_BUFFER_STATE b ,yyscan_t yyscanner );
|
||||
void yypush_buffer_state (YY_BUFFER_STATE new_buffer ,yyscan_t yyscanner );
|
||||
void yypop_buffer_state (yyscan_t yyscanner );
|
||||
|
||||
YY_BUFFER_STATE yy_scan_buffer (char *base,yy_size_t size ,yyscan_t yyscanner );
|
||||
YY_BUFFER_STATE yy_scan_string (yyconst char *yy_str ,yyscan_t yyscanner );
|
||||
YY_BUFFER_STATE yy_scan_bytes (yyconst char *bytes,yy_size_t len ,yyscan_t yyscanner );
|
||||
|
||||
void *yyalloc (yy_size_t ,yyscan_t yyscanner );
|
||||
void *yyrealloc (void *,yy_size_t ,yyscan_t yyscanner );
|
||||
void yyfree (void * ,yyscan_t yyscanner );
|
||||
|
||||
/* Begin user sect3 */
|
||||
|
||||
#define yywrap(yyscanner) 1
|
||||
#define YY_SKIP_YYWRAP
|
||||
|
||||
#define yytext_ptr yytext_r
|
||||
|
||||
#ifdef YY_HEADER_EXPORT_START_CONDITIONS
|
||||
#define INITIAL 0
|
||||
#define RAW 1
|
||||
#define NORMAL 2
|
||||
int phpdbg_lex (phpdbg_param_t* yylval);
|
||||
|
||||
#endif
|
||||
|
||||
#ifndef YY_NO_UNISTD_H
|
||||
/* Special case for "unistd.h", since it is non-ANSI. We include it way
|
||||
* down here because we want the user's section 1 to have been scanned first.
|
||||
* The user has a chance to override it with an option.
|
||||
*/
|
||||
#include <unistd.h>
|
||||
#endif
|
||||
|
||||
#ifndef YY_EXTRA_TYPE
|
||||
#define YY_EXTRA_TYPE void *
|
||||
#endif
|
||||
|
||||
int yylex_init (yyscan_t* scanner);
|
||||
|
||||
int yylex_init_extra (YY_EXTRA_TYPE user_defined,yyscan_t* scanner);
|
||||
|
||||
/* Accessor methods to globals.
|
||||
These are made visible to non-reentrant scanners for convenience. */
|
||||
|
||||
int yylex_destroy (yyscan_t yyscanner );
|
||||
|
||||
int yyget_debug (yyscan_t yyscanner );
|
||||
|
||||
void yyset_debug (int debug_flag ,yyscan_t yyscanner );
|
||||
|
||||
YY_EXTRA_TYPE yyget_extra (yyscan_t yyscanner );
|
||||
|
||||
void yyset_extra (YY_EXTRA_TYPE user_defined ,yyscan_t yyscanner );
|
||||
|
||||
FILE *yyget_in (yyscan_t yyscanner );
|
||||
|
||||
void yyset_in (FILE * in_str ,yyscan_t yyscanner );
|
||||
|
||||
FILE *yyget_out (yyscan_t yyscanner );
|
||||
|
||||
void yyset_out (FILE * out_str ,yyscan_t yyscanner );
|
||||
|
||||
yy_size_t yyget_leng (yyscan_t yyscanner );
|
||||
|
||||
char *yyget_text (yyscan_t yyscanner );
|
||||
|
||||
int yyget_lineno (yyscan_t yyscanner );
|
||||
|
||||
void yyset_lineno (int line_number ,yyscan_t yyscanner );
|
||||
|
||||
int yyget_column (yyscan_t yyscanner );
|
||||
|
||||
void yyset_column (int column_no ,yyscan_t yyscanner );
|
||||
|
||||
YYSTYPE * yyget_lval (yyscan_t yyscanner );
|
||||
|
||||
void yyset_lval (YYSTYPE * yylval_param ,yyscan_t yyscanner );
|
||||
|
||||
/* Macros after this point can all be overridden by user definitions in
|
||||
* section 1.
|
||||
*/
|
||||
|
||||
#ifndef YY_SKIP_YYWRAP
|
||||
#ifdef __cplusplus
|
||||
extern "C" int yywrap (yyscan_t yyscanner );
|
||||
#else
|
||||
extern int yywrap (yyscan_t yyscanner );
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#ifndef yytext_ptr
|
||||
static void yy_flex_strncpy (char *,yyconst char *,int ,yyscan_t yyscanner);
|
||||
#endif
|
||||
|
||||
#ifdef YY_NEED_STRLEN
|
||||
static int yy_flex_strlen (yyconst char * ,yyscan_t yyscanner);
|
||||
#endif
|
||||
|
||||
#ifndef YY_NO_INPUT
|
||||
|
||||
#endif
|
||||
|
||||
/* Amount of stuff to slurp up with each read. */
|
||||
#ifndef YY_READ_BUF_SIZE
|
||||
#define YY_READ_BUF_SIZE 8192
|
||||
#endif
|
||||
|
||||
/* Number of entries by which start-condition stack grows. */
|
||||
#ifndef YY_START_STACK_INCR
|
||||
#define YY_START_STACK_INCR 25
|
||||
#endif
|
||||
|
||||
/* Default declaration of generated scanner - a define so the user can
|
||||
* easily add parameters.
|
||||
*/
|
||||
#ifndef YY_DECL
|
||||
#define YY_DECL_IS_OURS 1
|
||||
|
||||
extern int yylex \
|
||||
(YYSTYPE * yylval_param ,yyscan_t yyscanner);
|
||||
|
||||
#define YY_DECL int yylex \
|
||||
(YYSTYPE * yylval_param , yyscan_t yyscanner)
|
||||
#endif /* !YY_DECL */
|
||||
|
||||
/* yy_get_previous_state - get the state just before the EOB char was reached */
|
||||
|
||||
#undef YY_NEW_FILE
|
||||
#undef YY_FLUSH_BUFFER
|
||||
#undef yy_set_bol
|
||||
#undef yy_new_buffer
|
||||
#undef yy_set_interactive
|
||||
#undef YY_DO_BEFORE_ACTION
|
||||
|
||||
#ifdef YY_DECL_IS_OURS
|
||||
#undef YY_DECL_IS_OURS
|
||||
#undef YY_DECL
|
||||
#endif
|
||||
|
||||
#line 131 "/usr/src/php-src/sapi/phpdbg/phpdbg_lexer.l"
|
||||
|
||||
|
||||
#line 347 "sapi/phpdbg/phpdbg_lexer.h"
|
||||
#undef yyIN_HEADER
|
||||
#endif /* yyHEADER_H */
|
||||
|
@ -1,131 +1,169 @@
|
||||
%{
|
||||
|
||||
/*
|
||||
* phpdbg_lexer.l
|
||||
*/
|
||||
|
||||
#include "phpdbg.h"
|
||||
#include "phpdbg_cmd.h"
|
||||
#define YYSTYPE phpdbg_param_t
|
||||
|
||||
#include "phpdbg_parser.h"
|
||||
|
||||
%}
|
||||
#define LEX(v) (PHPDBG_G(lexer).v)
|
||||
|
||||
%s RAW
|
||||
%s NORMAL
|
||||
#define YYCTYPE unsigned char
|
||||
#define YYSETCONDITION(x) LEX(state) = x;
|
||||
#define YYGETCONDITION() LEX(state)
|
||||
#define YYCURSOR LEX(cursor)
|
||||
#define YYMARKER LEX(marker)
|
||||
#define yyleng LEX(len)
|
||||
#define yytext ((char*) LEX(text))
|
||||
#undef YYDEBUG
|
||||
#define YYDEBUG(a, b)
|
||||
#define YYFILL(n)
|
||||
|
||||
%option outfile="sapi/phpdbg/phpdbg_lexer.c" header-file="sapi/phpdbg/phpdbg_lexer.h"
|
||||
%option warn nodefault
|
||||
|
||||
%option reentrant noyywrap never-interactive nounistd
|
||||
%option bison-bridge
|
||||
#define NORMAL 0
|
||||
#define RAW 1
|
||||
#define INITIAL 2
|
||||
|
||||
T_TRUE "true"
|
||||
T_YES "yes"
|
||||
T_ON "on"
|
||||
T_ENABLED "enabled"
|
||||
T_FALSE "false"
|
||||
T_NO "no"
|
||||
T_OFF "off"
|
||||
T_DISABLED "disabled"
|
||||
T_EVAL "ev"
|
||||
T_SHELL "sh"
|
||||
T_IF "if"
|
||||
T_RUN "run"
|
||||
T_RUN_SHORT "r"
|
||||
ZEND_EXTERN_MODULE_GLOBALS(phpdbg);
|
||||
|
||||
WS [ \r\n\t]+
|
||||
DIGITS [0-9\.]+
|
||||
ID [^ \r\n\t:#]+
|
||||
ADDR 0x[a-fA-F0-9]+
|
||||
OPCODE (ZEND_|zend_)([A-Za-z])+
|
||||
INPUT [^\n]+
|
||||
%%
|
||||
void phpdbg_init_lexer (phpdbg_param_t *stack, char *input TSRMLS_DC) {
|
||||
PHPDBG_G(parser_stack) = stack;
|
||||
|
||||
<INITIAL>{
|
||||
{T_EVAL} {
|
||||
BEGIN(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_EVAL;
|
||||
}
|
||||
{T_SHELL} {
|
||||
BEGIN(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_SHELL;
|
||||
}
|
||||
{T_RUN}|{T_RUN_SHORT} {
|
||||
BEGIN(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_RUN;
|
||||
}
|
||||
YYSETCONDITION(INITIAL);
|
||||
|
||||
.+ {
|
||||
BEGIN(NORMAL);
|
||||
REJECT;
|
||||
}
|
||||
LEX(text) = YYCURSOR = (unsigned char *) input;
|
||||
LEX(len) = strlen(input);
|
||||
}
|
||||
|
||||
<NORMAL>{
|
||||
{T_IF} {
|
||||
BEGIN(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_IF;
|
||||
}
|
||||
int phpdbg_lex (phpdbg_param_t* yylval) {
|
||||
TSRMLS_FETCH(); /* Slow, but this is not a major problem here. TODO: Use TSRMLS_DC */
|
||||
|
||||
restart:
|
||||
LEX(text) = YYCURSOR;
|
||||
|
||||
/*!re2c
|
||||
re2c:yyfill:check = 0;
|
||||
T_TRUE "true"
|
||||
T_YES "yes"
|
||||
T_ON "on"
|
||||
T_ENABLED "enabled"
|
||||
T_FALSE "false"
|
||||
T_NO "no"
|
||||
T_OFF "off"
|
||||
T_DISABLED "disabled"
|
||||
T_EVAL "ev"
|
||||
T_SHELL "sh"
|
||||
T_IF "if"
|
||||
T_RUN "run"
|
||||
T_RUN_SHORT "r"
|
||||
WS [ \r\n\t]+
|
||||
DIGITS [0-9\.]+
|
||||
ID [^ \r\n\t:#\000]+
|
||||
ADDR [0][x][a-fA-F0-9]+
|
||||
OPCODE (ZEND_|zend_)([A-Za-z])+
|
||||
INPUT [^\n\000]+
|
||||
|
||||
<!*> := yyleng = (size_t) YYCURSOR - (size_t) yytext;
|
||||
|
||||
<*>[\n\000] {
|
||||
return 0;
|
||||
}
|
||||
|
||||
<INITIAL,NORMAL>{
|
||||
{ID}[:]{1}[//]{2} {
|
||||
phpdbg_init_param(yylval, STR_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
return T_PROTO;
|
||||
}
|
||||
[#]{1} { return T_POUND; }
|
||||
[:]{2} { return T_DCOLON; }
|
||||
[:]{1} { return T_COLON; }
|
||||
|
||||
{T_YES}|{T_ON}|{T_ENABLED}|{T_TRUE} {
|
||||
phpdbg_init_param(yylval, NUMERIC_PARAM);
|
||||
yylval->num = 1;
|
||||
return T_TRUTHY;
|
||||
}
|
||||
{T_NO}|{T_OFF}|{T_DISABLED}|{T_FALSE} {
|
||||
phpdbg_init_param(yylval, NUMERIC_PARAM);
|
||||
yylval->num = 0;
|
||||
return T_FALSY;
|
||||
}
|
||||
{DIGITS} {
|
||||
phpdbg_init_param(yylval, NUMERIC_PARAM);
|
||||
yylval->num = atoi(yytext);
|
||||
return T_DIGITS;
|
||||
}
|
||||
{ADDR} {
|
||||
phpdbg_init_param(yylval, ADDR_PARAM);
|
||||
yylval->addr = strtoul(yytext, 0, 16);
|
||||
return T_ADDR;
|
||||
}
|
||||
{OPCODE} {
|
||||
phpdbg_init_param(yylval, OP_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
return T_OPCODE;
|
||||
}
|
||||
{ID} {
|
||||
phpdbg_init_param(yylval, STR_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
return T_ID;
|
||||
}
|
||||
<NORMAL>{T_IF} {
|
||||
YYSETCONDITION(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_IF;
|
||||
}
|
||||
|
||||
<RAW>{INPUT} {
|
||||
<NORMAL>{ID}[:]{1}[//]{2} {
|
||||
phpdbg_init_param(yylval, STR_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
return T_PROTO;
|
||||
}
|
||||
<NORMAL>[#]{1} {
|
||||
return T_POUND;
|
||||
}
|
||||
<NORMAL>[:]{2} {
|
||||
return T_DCOLON;
|
||||
}
|
||||
<NORMAL>[:]{1} {
|
||||
return T_COLON;
|
||||
}
|
||||
|
||||
<NORMAL>{T_YES}|{T_ON}|{T_ENABLED}|{T_TRUE} {
|
||||
phpdbg_init_param(yylval, NUMERIC_PARAM);
|
||||
yylval->num = 1;
|
||||
return T_TRUTHY;
|
||||
}
|
||||
|
||||
<NORMAL>{T_NO}|{T_OFF}|{T_DISABLED}|{T_FALSE} {
|
||||
phpdbg_init_param(yylval, NUMERIC_PARAM);
|
||||
yylval->num = 0;
|
||||
return T_FALSY;
|
||||
}
|
||||
|
||||
<NORMAL>{DIGITS} {
|
||||
phpdbg_init_param(yylval, NUMERIC_PARAM);
|
||||
yylval->num = atoi(yytext);
|
||||
return T_DIGITS;
|
||||
}
|
||||
|
||||
<NORMAL>{ADDR} {
|
||||
phpdbg_init_param(yylval, ADDR_PARAM);
|
||||
yylval->addr = strtoul(yytext, 0, 16);
|
||||
return T_ADDR;
|
||||
}
|
||||
|
||||
<NORMAL>{OPCODE} {
|
||||
phpdbg_init_param(yylval, OP_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
return T_OPCODE;
|
||||
}
|
||||
|
||||
<NORMAL>{ID} {
|
||||
phpdbg_init_param(yylval, STR_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
return T_ID;
|
||||
}
|
||||
|
||||
<RAW>{INPUT} {
|
||||
phpdbg_init_param(yylval, STR_PARAM);
|
||||
yylval->str = zend_strndup(yytext, yyleng);
|
||||
yylval->len = yyleng;
|
||||
BEGIN(INITIAL);
|
||||
return T_INPUT;
|
||||
}
|
||||
|
||||
{WS} { /* ignore whitespace */ }
|
||||
%%
|
||||
<*>{WS} {
|
||||
/* ignore whitespace */
|
||||
|
||||
goto restart;
|
||||
}
|
||||
|
||||
<INITIAL>{T_EVAL} {
|
||||
YYSETCONDITION(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_EVAL;
|
||||
}
|
||||
<INITIAL>{T_SHELL} {
|
||||
YYSETCONDITION(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_SHELL;
|
||||
}
|
||||
<INITIAL>{T_RUN}|{T_RUN_SHORT} {
|
||||
YYSETCONDITION(RAW);
|
||||
phpdbg_init_param(yylval, EMPTY_PARAM);
|
||||
return T_RUN;
|
||||
}
|
||||
|
||||
<INITIAL>. {
|
||||
YYSETCONDITION(NORMAL);
|
||||
|
||||
YYCURSOR = LEX(text);
|
||||
goto restart;
|
||||
}
|
||||
|
||||
*/
|
||||
}
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1,4 +1,4 @@
|
||||
/* A Bison parser, made by GNU Bison 2.7. */
|
||||
/* A Bison parser, made by GNU Bison 2.6.2. */
|
||||
|
||||
/* Bison interface for Yacc-like parsers in C
|
||||
|
||||
@ -30,18 +30,18 @@
|
||||
This special exception was added by the Free Software Foundation in
|
||||
version 2.2 of Bison. */
|
||||
|
||||
#ifndef YY_YY_SAPI_PHPDBG_PHPDBG_PARSER_H_INCLUDED
|
||||
# define YY_YY_SAPI_PHPDBG_PHPDBG_PARSER_H_INCLUDED
|
||||
#ifndef PHPDBG_SAPI_PHPDBG_PHPDBG_PARSER_H
|
||||
# define PHPDBG_SAPI_PHPDBG_PHPDBG_PARSER_H
|
||||
/* Enabling traces. */
|
||||
#ifndef YYDEBUG
|
||||
# define YYDEBUG 0
|
||||
#endif
|
||||
#if YYDEBUG
|
||||
extern int yydebug;
|
||||
extern int phpdbg_debug;
|
||||
#endif
|
||||
/* "%code requires" blocks. */
|
||||
/* Line 2058 of yacc.c */
|
||||
#line 40 "/usr/src/php-src/sapi/phpdbg/phpdbg_parser.y"
|
||||
/* Line 2055 of yacc.c */
|
||||
#line 31 "/var/root/php-src/sapi/phpdbg/phpdbg_parser.y"
|
||||
|
||||
#include "phpdbg.h"
|
||||
#ifndef YY_TYPEDEF_YY_SCANNER_T
|
||||
@ -50,7 +50,7 @@ typedef void* yyscan_t;
|
||||
#endif
|
||||
|
||||
|
||||
/* Line 2058 of yacc.c */
|
||||
/* Line 2055 of yacc.c */
|
||||
#line 55 "sapi/phpdbg/phpdbg_parser.h"
|
||||
|
||||
/* Tokens. */
|
||||
@ -111,16 +111,16 @@ typedef int YYSTYPE;
|
||||
|
||||
#ifdef YYPARSE_PARAM
|
||||
#if defined __STDC__ || defined __cplusplus
|
||||
int yyparse (void *YYPARSE_PARAM);
|
||||
int phpdbg_parse (void *YYPARSE_PARAM);
|
||||
#else
|
||||
int yyparse ();
|
||||
int phpdbg_parse ();
|
||||
#endif
|
||||
#else /* ! YYPARSE_PARAM */
|
||||
#if defined __STDC__ || defined __cplusplus
|
||||
int yyparse (phpdbg_param_t *stack, yyscan_t scanner);
|
||||
int phpdbg_parse (void *tsrm_ls);
|
||||
#else
|
||||
int yyparse ();
|
||||
int phpdbg_parse ();
|
||||
#endif
|
||||
#endif /* ! YYPARSE_PARAM */
|
||||
|
||||
#endif /* !YY_YY_SAPI_PHPDBG_PHPDBG_PARSER_H_INCLUDED */
|
||||
#endif /* !PHPDBG_SAPI_PHPDBG_PHPDBG_PARSER_H */
|
||||
|
@ -1,4 +1,3 @@
|
||||
%error-verbose
|
||||
%{
|
||||
|
||||
/*
|
||||
@ -19,23 +18,15 @@
|
||||
#include "phpdbg_parser.h"
|
||||
#include "phpdbg_lexer.h"
|
||||
|
||||
#undef yyerror
|
||||
static int yyerror(void ***tsrm_ls, const char *msg);
|
||||
|
||||
ZEND_EXTERN_MODULE_GLOBALS(phpdbg);
|
||||
|
||||
int yyerror(phpdbg_param_t *stack, yyscan_t scanner, const char *msg) {
|
||||
TSRMLS_FETCH();
|
||||
phpdbg_error("Parse Error: %s", msg);
|
||||
{
|
||||
const phpdbg_param_t *top = stack;
|
||||
|
||||
while (top) {
|
||||
phpdbg_param_debug(
|
||||
top, "--> ");
|
||||
top = top->next;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
%}
|
||||
|
||||
%pure-parser
|
||||
%error-verbose
|
||||
|
||||
%code requires {
|
||||
#include "phpdbg.h"
|
||||
@ -44,59 +35,58 @@ int yyerror(phpdbg_param_t *stack, yyscan_t scanner, const char *msg) {
|
||||
typedef void* yyscan_t;
|
||||
#endif
|
||||
}
|
||||
|
||||
%parse-param { void *tsrm_ls }
|
||||
|
||||
%output "sapi/phpdbg/phpdbg_parser.c"
|
||||
%defines "sapi/phpdbg/phpdbg_parser.h"
|
||||
|
||||
%define api.pure
|
||||
%lex-param { yyscan_t scanner }
|
||||
%parse-param { phpdbg_param_t *stack }
|
||||
%parse-param { yyscan_t scanner }
|
||||
|
||||
%token T_EVAL "eval"
|
||||
%token T_RUN "run"
|
||||
%token T_SHELL "shell"
|
||||
%token T_IF "if (condition)"
|
||||
%token T_TRUTHY "truthy (true, on, yes or enabled)"
|
||||
%token T_FALSY "falsy (false, off, no or disabled)"
|
||||
%token T_STRING "string (some input, perhaps)"
|
||||
%token T_COLON ": (colon)"
|
||||
%token T_DCOLON ":: (double colon)"
|
||||
%token T_POUND "# (pound sign)"
|
||||
%token T_PROTO "protocol (file://)"
|
||||
%token T_DIGITS "digits (numbers)"
|
||||
%token T_LITERAL "literal (string)"
|
||||
%token T_ADDR "address"
|
||||
%token T_OPCODE "opcode"
|
||||
%token T_ID "identifier (command or function name)"
|
||||
%token T_INPUT "input (input string or data)"
|
||||
%token T_UNEXPECTED "input"
|
||||
%%
|
||||
%token T_EVAL "eval"
|
||||
%token T_RUN "run"
|
||||
%token T_SHELL "shell"
|
||||
%token T_IF "if (condition)"
|
||||
%token T_TRUTHY "truthy (true, on, yes or enabled)"
|
||||
%token T_FALSY "falsy (false, off, no or disabled)"
|
||||
%token T_STRING "string (some input, perhaps)"
|
||||
%token T_COLON ": (colon)"
|
||||
%token T_DCOLON ":: (double colon)"
|
||||
%token T_POUND "# (pound sign)"
|
||||
%token T_PROTO "protocol (file://)"
|
||||
%token T_DIGITS "digits (numbers)"
|
||||
%token T_LITERAL "literal (string)"
|
||||
%token T_ADDR "address"
|
||||
%token T_OPCODE "opcode"
|
||||
%token T_ID "identifier (command or function name)"
|
||||
%token T_INPUT "input (input string or data)"
|
||||
%token T_UNEXPECTED "input"
|
||||
|
||||
%% /* Rules */
|
||||
|
||||
input
|
||||
: parameters
|
||||
| /* nothing */
|
||||
;
|
||||
: parameters
|
||||
| full_expression { phpdbg_stack_push(PHPDBG_G(parser_stack), &$1); }
|
||||
| /* nothing */
|
||||
;
|
||||
|
||||
parameters
|
||||
: parameter { phpdbg_stack_push(stack, &$1); }
|
||||
| parameters parameter { phpdbg_stack_push(stack, &$2); }
|
||||
: parameter { phpdbg_stack_push(PHPDBG_G(parser_stack), &$1); }
|
||||
| parameters parameter { phpdbg_stack_push(PHPDBG_G(parser_stack), &$2); }
|
||||
;
|
||||
|
||||
parameter
|
||||
: T_ID T_COLON T_DIGITS {
|
||||
: T_ID T_COLON T_DIGITS {
|
||||
$$.type = FILE_PARAM;
|
||||
$$.file.name = $2.str;
|
||||
$$.file.line = $3.num;
|
||||
}
|
||||
| T_ID T_COLON T_POUND T_DIGITS {
|
||||
| T_ID T_COLON T_POUND T_DIGITS {
|
||||
$$.type = NUMERIC_FILE_PARAM;
|
||||
$$.file.name = $1.str;
|
||||
$$.file.line = $4.num;
|
||||
}
|
||||
| T_PROTO T_ID T_COLON T_DIGITS {
|
||||
| T_PROTO T_ID T_COLON T_DIGITS {
|
||||
$$.type = FILE_PARAM;
|
||||
$$.file.name = malloc($1.len +
|
||||
$2.len + 1);
|
||||
$$.file.name = malloc($1.len + $2.len + 1);
|
||||
if ($$.file.name) {
|
||||
memcpy(&$$.file.name[0], $1.str, $1.len);
|
||||
memcpy(&$$.file.name[$1.len], $2.str, $2.len);
|
||||
@ -104,10 +94,9 @@ parameter
|
||||
}
|
||||
$$.file.line = $4.num;
|
||||
}
|
||||
| T_PROTO T_ID T_COLON T_POUND T_DIGITS {
|
||||
| T_PROTO T_ID T_COLON T_POUND T_DIGITS {
|
||||
$$.type = NUMERIC_FILE_PARAM;
|
||||
$$.file.name = malloc($1.len +
|
||||
$2.len + 1);
|
||||
$$.file.name = malloc($1.len + $2.len + 1);
|
||||
if ($$.file.name) {
|
||||
memcpy(&$$.file.name[0], $1.str, $1.len);
|
||||
memcpy(&$$.file.name[$1.len], $2.str, $2.len);
|
||||
@ -115,54 +104,81 @@ parameter
|
||||
}
|
||||
$$.file.line = $5.num;
|
||||
}
|
||||
| T_ID T_DCOLON T_ID {
|
||||
| T_ID T_DCOLON T_ID {
|
||||
$$.type = METHOD_PARAM;
|
||||
$$.method.class = $1.str;
|
||||
$$.method.name = $3.str;
|
||||
}
|
||||
| T_ID T_DCOLON T_ID T_POUND T_DIGITS {
|
||||
| T_ID T_DCOLON T_ID T_POUND T_DIGITS {
|
||||
$$.type = NUMERIC_METHOD_PARAM;
|
||||
$$.method.class = $1.str;
|
||||
$$.method.name = $3.str;
|
||||
$$.num = $5.num;
|
||||
}
|
||||
| T_ID T_POUND T_DIGITS {
|
||||
| T_ID T_POUND T_DIGITS {
|
||||
$$.type = NUMERIC_FUNCTION_PARAM;
|
||||
$$.str = $1.str;
|
||||
$$.len = $1.len;
|
||||
$$.num = $3.num;
|
||||
}
|
||||
| T_IF T_INPUT {
|
||||
| T_OPCODE { $$ = $1; }
|
||||
| T_ADDR { $$ = $1; }
|
||||
| T_LITERAL { $$ = $1; }
|
||||
| T_TRUTHY { $$ = $1; }
|
||||
| T_FALSY { $$ = $1; }
|
||||
| T_DIGITS { $$ = $1; }
|
||||
| T_ID { $$ = $1; }
|
||||
;
|
||||
|
||||
full_expression
|
||||
: T_IF T_INPUT {
|
||||
$$.type = COND_PARAM;
|
||||
$$.str = $2.str;
|
||||
$$.len = $2.len;
|
||||
}
|
||||
| T_EVAL T_INPUT {
|
||||
| T_EVAL T_INPUT {
|
||||
$$.type = EVAL_PARAM;
|
||||
$$.str = $2.str;
|
||||
$$.len = $2.len;
|
||||
}
|
||||
| T_SHELL T_INPUT {
|
||||
| T_SHELL T_INPUT {
|
||||
$$.type = SHELL_PARAM;
|
||||
$$.str = $2.str;
|
||||
$$.len = $2.len;
|
||||
}
|
||||
| T_RUN {
|
||||
| T_RUN {
|
||||
$$.type = RUN_PARAM;
|
||||
$$.len = 0;
|
||||
}
|
||||
| T_RUN T_INPUT {
|
||||
| T_RUN T_INPUT {
|
||||
$$.type = RUN_PARAM;
|
||||
$$.str = $2.str;
|
||||
$$.len = $2.len;
|
||||
}
|
||||
| T_OPCODE { $$ = $1; }
|
||||
| T_ADDR { $$ = $1; }
|
||||
| T_LITERAL { $$ = $1; }
|
||||
| T_TRUTHY { $$ = $1; }
|
||||
| T_FALSY { $$ = $1; }
|
||||
| T_DIGITS { $$ = $1; }
|
||||
| T_ID { $$ = $1; }
|
||||
;
|
||||
|
||||
%%
|
||||
|
||||
static int yyerror(void ***tsrm_ls, const char *msg) {
|
||||
phpdbg_error("Parse Error: %s", msg);
|
||||
|
||||
{
|
||||
const phpdbg_param_t *top = PHPDBG_G(parser_stack);
|
||||
|
||||
while (top) {
|
||||
phpdbg_param_debug(top, "--> ");
|
||||
top = top->next;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int phpdbg_do_parse(phpdbg_param_t *stack, char *input TSRMLS_DC) {
|
||||
phpdbg_init_lexer(stack, input TSRMLS_CC);
|
||||
|
||||
#ifdef ZTS
|
||||
return yyparse(TSRMLS_C);
|
||||
#else
|
||||
return yyparse(NULL);
|
||||
#endif
|
||||
}
|
||||
|
@ -38,8 +38,6 @@
|
||||
#include "phpdbg_lexer.h"
|
||||
#include "phpdbg_parser.h"
|
||||
|
||||
int yyparse(phpdbg_param_t *stack, yyscan_t scanner);
|
||||
|
||||
/* {{{ command declarations */
|
||||
const phpdbg_command_t phpdbg_prompt_commands[] = {
|
||||
PHPDBG_COMMAND_D(exec, "set execution context", 'e', NULL, "s"),
|
||||
@ -248,20 +246,10 @@ void phpdbg_try_file_init(char *init_file, size_t init_file_len, zend_bool free_
|
||||
char *why = NULL;
|
||||
char *input = phpdbg_read_input(cmd TSRMLS_CC);
|
||||
phpdbg_param_t stack;
|
||||
yyscan_t scanner;
|
||||
YY_BUFFER_STATE state;
|
||||
|
||||
phpdbg_init_param(&stack, STACK_PARAM);
|
||||
|
||||
if (yylex_init(&scanner)) {
|
||||
phpdbg_error(
|
||||
"could not initialize scanner");
|
||||
break;
|
||||
}
|
||||
|
||||
state = yy_scan_string(input, scanner);
|
||||
|
||||
if (yyparse(&stack, scanner) <= 0) {
|
||||
if (phpdbg_do_parse(&stack, input TSRMLS_CC) <= 0) {
|
||||
switch (phpdbg_stack_execute(&stack, &why TSRMLS_CC)) {
|
||||
case FAILURE:
|
||||
// if (!(PHPDBG_G(flags) & PHPDBG_IS_QUITTING)) {
|
||||
@ -274,15 +262,12 @@ void phpdbg_try_file_init(char *init_file, size_t init_file_len, zend_bool free_
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (why) {
|
||||
free(why);
|
||||
why = NULL;
|
||||
}
|
||||
|
||||
yy_delete_buffer(state, scanner);
|
||||
yylex_destroy(scanner);
|
||||
|
||||
|
||||
phpdbg_stack_free(&stack);
|
||||
phpdbg_destroy_input(&input TSRMLS_CC);
|
||||
}
|
||||
@ -1014,20 +999,9 @@ int phpdbg_interactive(TSRMLS_D) /* {{{ */
|
||||
|
||||
if (input) {
|
||||
do {
|
||||
yyscan_t scanner;
|
||||
YY_BUFFER_STATE state;
|
||||
|
||||
phpdbg_init_param(&stack, STACK_PARAM);
|
||||
|
||||
if (yylex_init(&scanner)) {
|
||||
phpdbg_error(
|
||||
"could not initialize scanner");
|
||||
return FAILURE;
|
||||
}
|
||||
|
||||
state = yy_scan_string(input, scanner);
|
||||
|
||||
if (yyparse(&stack, scanner) <= 0) {
|
||||
if (phpdbg_do_parse(&stack, input TSRMLS_CC) <= 0) {
|
||||
switch (ret = phpdbg_stack_execute(&stack, &why TSRMLS_CC)) {
|
||||
case FAILURE:
|
||||
if (!(PHPDBG_G(flags) & PHPDBG_IS_QUITTING)) {
|
||||
@ -1061,9 +1035,6 @@ int phpdbg_interactive(TSRMLS_D) /* {{{ */
|
||||
why = NULL;
|
||||
}
|
||||
|
||||
yy_delete_buffer(state, scanner);
|
||||
yylex_destroy(scanner);
|
||||
|
||||
phpdbg_stack_free(&stack);
|
||||
phpdbg_destroy_input(&input TSRMLS_CC);
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
#!/usr/bin/env sh
|
||||
git clone https://github.com/php/php-src
|
||||
cd php-src/sapi
|
||||
rm -rf phpdbg
|
||||
git clone https://github.com/krakjoe/phpdbg.git
|
||||
cd ../
|
||||
./buildconf --force
|
||||
|
Loading…
Reference in New Issue
Block a user