8053 beefd0184a 2022-08-08 ct_chen 2 years ago
..
tests beefd0184a 2022-08-08 ct_chen 2 years ago
travis beefd0184a 2022-08-08 ct_chen 2 years ago
.gdbinit beefd0184a 2022-08-08 ct_chen 2 years ago
.gitignore beefd0184a 2022-08-08 ct_chen 2 years ago
.phpdbginit beefd0184a 2022-08-08 ct_chen 2 years ago
.travis.yml beefd0184a 2022-08-08 ct_chen 2 years ago
CREDITS beefd0184a 2022-08-08 ct_chen 2 years ago
Changelog.md beefd0184a 2022-08-08 ct_chen 2 years ago
Makefile.frag beefd0184a 2022-08-08 ct_chen 2 years ago
README.md beefd0184a 2022-08-08 ct_chen 2 years ago
config.m4 beefd0184a 2022-08-08 ct_chen 2 years ago
config.w32 beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg.1 beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg.init.d beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_bp.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_bp.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_break.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_break.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_btree.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_btree.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_cmd.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_cmd.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_frame.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_frame.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_help.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_help.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_info.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_info.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_lexer.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_lexer.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_lexer.l beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_list.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_list.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_opcode.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_opcode.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_parser.y beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_print.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_print.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_prompt.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_prompt.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_set.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_set.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_utils.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_utils.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_watch.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_watch.h beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_win.c beefd0184a 2022-08-08 ct_chen 2 years ago
phpdbg_win.h beefd0184a 2022-08-08 ct_chen 2 years ago
test.php beefd0184a 2022-08-08 ct_chen 2 years ago
web-bootstrap.php beefd0184a 2022-08-08 ct_chen 2 years ago

README.md

The interactive PHP debugger

Implemented as a SAPI module, phpdbg can excert complete control over the environment without impacting the functionality or performance of your code.

phpdbg aims to be a lightweight, powerful, easy to use debugging platform for PHP 5.4+

phpdbg on travis-ci

Features

  • Stepthrough Debugging
  • Flexible Breakpoints (Class Method, Function, File:Line, Address, Opcode)
  • Easy Access to PHP with built-in eval()
  • Easy Access to Currently Executing Code
  • Userland API
  • SAPI Agnostic - Easily Integrated
  • PHP Configuration File Support
  • JIT Super Globals - Set Your Own!!
  • Optional readline Support - Comfortable Terminal Operation
  • Remote Debugging Support - Bundled Java GUI
  • Easy Operation - See Help :)

Planned

  • Improve Everything :)

Installation

To install phpdbg, you must compile the source against your PHP installation sources, and enable the SAPI with the configure command.

cd /usr/src/php-src/sapi
git clone https://github.com/krakjoe/phpdbg
cd ../
./buildconf --force
./configure --enable-phpdbg
make -j8
make install-phpdbg

Where the source directory has been used previously to build PHP, there exists a file named config.nice which can be used to invoke configure with the same parameters as were used by the last execution of configure.

Note: PHP must be configured with the switch --with-readline for phpdbg to support history, autocompletion, tab-listing etc.

Command Line Options

The following switches are implemented (just like cli SAPI):

  • -n ignore php ini
  • -c search for php ini in path
  • -z load zend extension
  • -d define php ini entry

The following switches change the default behaviour of phpdbg:

  • -v disables quietness
  • -s enabled stepping
  • -e sets execution context
  • -b boring - disables use of colour on the console
  • -I ignore .phpdbginit (default init file)
  • -i override .phpgdbinit location (implies -I)
  • -O set oplog output file
  • -q do not print banner on startup
  • -r jump straight to run
  • -E enable step through eval()
  • -l listen ports for remote mode
  • -a listen address for remote mode
  • -S override SAPI name

Note: Passing -rr will cause phpdbg to quit after execution, rather than returning to the console.

Getting Started

See the website for tutorials/documentation

http://phpdbg.com