Xdebug  
  XDEBUG EXTENSION FOR PHP | INSTALLATION
home | updates | installation | documentation | screenshots | license | support

PRECOMPILED MODULES

There are a few precompiled modules for Windows, they are all for the non-debug version of PHP. See the links on the right side.

Installing the precompiled modules is easy. Just place them in a directory, and add the following line to php.ini: (don't forget to change the path and filename to the correct one)

zend_extension_ts="c:/php/modules/xdebug-4.3-1.3.1.dll"

PECL INSTALLATION

As of Xdebug 0.9.0 you can install Xdebug through PEAR/PECL. This only works with the latest CVS version of PHP (with PEAR version 0.9.1-dev or higher installed) and some UNIX.

Installing with PEAR/PECL is as easy as:

# pear install xdebug

but you still need to add the correct line to your php.ini: (don't forget to change the path and filename to the correct one)

zend_extension="/usr/local/php/modules/xdebug.so"
INSTALLATION FROM SOURCE

You can download the source of the latest stable release here. Alternatively you can obtain Xdebug from CVS:

cvs -d :pserver:srmread@cvs.xdebug.org:/repository login
CVS password: srmread
cvs -d :pserver:srmread@cvs.xdebug.org:/repository co xdebug

This will checkout the latest development version which is currently 2.0dev. In case you want to retrieve the latest stable version from CVS, use the following checkout line:

cvs -d :pserver:srmread@cvs.xdebug.org:/repository co -r xdebug_1_3 xdebug
COMPILING

You compile Xdebug separately from the rest of PHP. Note, however, that you need access to the scripts "phpize" and "php-config". If your system does not have "phpize" and "php-config", you will need to compile and install PHP from a source tarball first, as these script are by-products of the PHP compilation and installation processes. (Debian users can install the required tools with apt-get install php4-dev). It is important that the source version matches the installed version as there are slight, but important, differences between PHP versions. For a detailed installation on Mac OSX see Jason Perkins' installation instructions. Once you have access to "phpize" and "php-config", do the following:

  1. Unpack the tarball: tar -xzf xdebug-1.x.x.tgz. Note that you do not need to unpack the tarball inside the PHP source code tree. Xdebug is compiled separately, all by itself, as stated above.
  2. cd xdebug-1.x.x
  3. Run phpize: phpize (or /path/to/phpize if phpize is not in your path). See in the table below which version numbers it should show for different PHP versions.
  4. ./configure --enable-xdebug (or: ./configure --enable-xdebug --with-php-config=/path/to/php-config if php-config is not in your path).

    If this fails with something like:
    ../configure: line 1960: syntax error near unexpected token
    `PHP_NEW_EXTENSION(xdebug,'
    ../configure: line 1960: `  PHP_NEW_EXTENSION(xdebug, xdebug.c
    xdebug_code_coverage.c xdebug_com.c xdebug_handler_gdb.c
    xdebug_handler_php3.c xdebug_handlers.c xdebug_llist.c xdebug_hash.c
    xdebug_profiler.c xdebug_superglobals.c xdebug_var.c usefulstuff.c,
    $ext_shared)'
    then it means that you do not meet the PHP 4.3.x version requirement for Xdebug.

    Another problem that might occur is:
    configure: line 1145: PHP_INIT_BUILD_SYSTEM: command not found
    configure: line 1151: syntax error near unexpected token `config.nice'
    configure: line 1151: `PHP_CONFIG_NICE(config.nice)'
    You will need to upgrade your autotools (autoconf, automake and libtool) or install the known working versions: autoconf-2.13, automake-1.5 and libtool-1.4.3.

  5. make
  6. cp modules/xdebug.so /to/wherever/you/want/it
  7. add the following line to php.ini: zend_extension="/wherever/you/put/it/xdebug.so" (for non-threaded use of PHP, for example the CLI, CGI or Apache 1.3 module) or: zend_extension_ts="/wherever/you/put/it/xdebug.so" (for threaded usage of PHP, for example the Apache 2 work MPM or the the ISAPI module)
  8. Restart your webserver.
  9. Write a PHP page that calls "phpinfo()" Load it in a browser and look for the info on the Xdebug module. If you see it next to the Zend logo, you have been successful! You can also use "php -m" if you have a command line version of PHP, it lists all loaded modules. Xdebug should appear twice there (once under "PHP Modules" and once under "Zend Modules").

COMPATIBILITY

Xdebug does not work together with the Zend Optimizer or any other Zend extension (DBG, APC, APD etc). This is due to compatibility problems with those modules. We will be working on figuring out what the problems are, and of course try to fix those.

PHPIZE OUTPUT TABLE

PHP Version: PHP Api Version: Zend Module Api No: Zend Extension Api No: Recommended version:
4.2.3 20010901 20020429 20020429 1.0.0rc1
4.3.0pre2 20020307 20020429 20021010 1.1.0pre2
4.3.0rc1 20020918 20020429 20021010 1.1.0
4.3.0 20020918 20020429 20021010 1.2.0
4.3.1-4.3.5 20020918 20020429 20021010 1.3.1
4.3.7-4.3.8 20020918 20020429 20021010 1.3.2 / 2.0.0-cvs
5.0.0rc3 20031224 20040412 220040412 1.3.2 / 2.0.0-cvs

DEBUGCLIENT INSTALLATION

Unpack the Xdebug source tarball and issue the following commands:

$ cd debugclient
$ ./configure --with-libedit
$ make
# make install

This will install the debugclient binary in /usr/local/bin unless you don't have libedit installed on your system. You can either install it, or leave out the "--with-libedit" option to configure. Debian 'unstable' users can install the library with apt-get install libedit-dev libedit2.



 
RELEASES
[29-11-2004]
Source:
Debug client 0.8.0 (binary):
[15-09-2004]
Windows modules:
[30-06-2004]
Source:
Modules for 4.3.x (binary):
Debug client 0.7.0 (binary):

DEVELOPMENT VERSION (2.0dev)
Instructions to get Xdebug 2.0dev from CVS can be found here. This version compiles on PHP 4.3.0 and higher.

BINARY SNAPSHOTS (2.0dev)
Modules for 4.3.x-dev:
Modules for 5.0.x-dev:
Modules for 5.1.x-dev:

OLDER RELEASES
Source:

 
 
This site and all of its contents are Copyright © 2002, 2003, 2004 by Derick Rethans.
All rights reserved.