Footle is a debugger front-end for the Xdebug PHP debugger. It offers a browser-based user interface for Xdebug. The goal is to make interactive debugging easy for PHP newcomers.
Footle is heavily under construction. It works, but user experience is not good enough yet. It cannot cope with multiple simultaneous debugging sessions. It also lacks user authentication.
- Open Footle's release page
- Download the appropriate archive file for your platform. e.g. footle-linux-64.tar.gz for 64-bit GNU/Linux environment.
- Uncompress the archive file. e.g.
tar xfz footle-linux-64.tar.gz
,unzip footle-win-64.zip
, etc. - If you are using Xdebug 2.6 or prior, try an older version of Footle.
For Footle to work, you first need to properly install and configure Xdebug. Setting up Xdebug is out of scope of this document. Instead we point you to the Xdebug configuration wizard.
To keep things simple, here is a sample xdebug.ini file that works for simple PHP projects:
zend_extension=xdebug.so
xdebug.remote_enable = 1
xdebug.remote_autostart = 1
Many of us use the xdebug.remote_connect_back
or xdebug.remote_host
settings to instruct Xdebug to talk to Xdebug clients in a different machine. This setting is usually not needed for Footle as it is easier to run Footle in the same machine as Xdebug.
If you suspect that Xdebug is not talking to Footle, launch Footle with the -vvv option. This should dump into screen all traffic to and from Xdebug. Total silence would mean Xdebug is not talking to Footle. In which case review the xdebug settings present in the output of the phpinfo() function.
$ cd /var/www/html/
$ ~/footle-linux-64/footle
This makes two assumptions:
- Your PHP code is inside the /var/www/html/ directory.
- Footle is running in the same machine as Xdebug.
Press Ctrl-C to quit.
- Open http://localhost:1234/ in a browser. This brings up the Footle user interface. When Footle is running in a different machine from the browser, use that machine's hostname rather than localhost.
- You should be presented with Footle's file picker. The file picker is always the first tab within Footle's interface. This should list all files and directories from your PHP codebase.
- Click one or more PHP files from the file picker. Selected files will open in their own tabs. Note that these tabs are not browser tabs. These tabs are part of the webpage drawn by Footle.
- Set breakpoints by clicking line numbers. Line numbers appear at the left edge of each file.
- Now in another browser tab or window, open a webpage that will execute the PHP files where you have just set breakpoints.
- Once execution reaches the breakpoint, the line with the breakpoint is highlighted by a light-green background.
- To inspect local and global variables, use the two buttons labelled Locals and Globals
Footle is cross-platform. We prepare distributions for FreeBSD, GNU/Linux, MacOS, and Windows. Minimum web browser requirement is Firefox 60 ESR or Chromium 69. Recent browsers of other flavours may work although none are tested as yet.
Footle is not fully responsive yet, so at least a tablet display is recommended.
Have a question about Footle? Found a bug? Please file an issue.
Simplified BSD licence. It effectively means you can do whatever you want with Footle.