10 years of Xdebug and Xdebug 2.2.0 released
Today it has been ten years since the first release of Xdebug: version 0.7.0. I would like to celebrate this tenth anniversary with a new release: Xdebug 2.2.0. Xdebug 2.2 adds support for PHP 5.4 and provides some new features:
Colours on the command line
First of all there is now var_dump() overloading and colours on the command line. I've already written about that before, but here are the screenshots again:
Linux/Mac:
Windows:
You can find an article about this here.
Better support for closures in stack and function traces
Closures are functions that don't have a function name associated with them. Therefore, Xdebug creates a pseudo function in its stack traces. The stack trace for this example:
<?php
function test1()
{
$f = function($a, $b) {
$Q = strlen($a * $b);
trigger_error('foo');
};
$f(5, 25);
}
test1();
?>
Looks like:
Notice: foo in /tmp/closure-stack-trace.php on line 21
Call Stack:
0.0009 268464 1. {main}() /tmp/closure-stack-trace.php:0
0.0026 269288 2. test1() /tmp/closure-stack-trace.php:27
0.0032 270024 3. {closure:/tmp/closure-stack-trace.php:19-22}($a = 5, $b = 25) /tmp/closure-stack-trace.php:24
0.0038 270496 4. trigger_error('foo') /tmp/closure-stack-trace.php:21
In the 3rd line in the call stack you see {closure:/tmp/closure-stack-trace.php:19-22}($a = 5, $b = 25) where /tmp/closure-stack-trace.php:19-22 contains the filename and line numbers on which the closure is defined at.
The size of arrays is now shown with the overloaded variable output
After this change, each array in the HTML version of the overloaded var_dump() function now looks like:
<b>array</b> <i>(size=5)</li>
Before the change, this was only:
<b>array</b>
Added the method call type to xdebug_get_function_stack
This changes adds another array element to xdebug_get_function_stack() to show whether it was a static or dynamic function call. For example, for:
new Error_Entry(false, $errno);
It now adds the ["type"]=> string(7) "dynamic" element to each stack element:
array(6) {
["function"]=>
string(11) "__construct"
["type"]=>
string(7) "dynamic"
["class"]=>
string(11) "Error_Entry"
["file"]=>
string(%d) "%sbug00241.php"
["line"]=>
int(11)
Extra information to error printouts to tell that the error suppression operator has been ignored due to xdebug.scream
When you have the xdebug.scream option activated, Xdebug will now tell you when it had any effect on the error reporting with a big "SCREAM: Error suppression ignored for" warning prepended to the actual error message.
Changelog
You can find the full changelog for Xdebug 2.2.0 at the Xdebug website where you can also download the latest version. If you are using Windows, and don't know which binary to download, please refer to the wizard.
Support
If you find Xdebug valuable for your PHP development, perhaps you want to support its development by acquiring a "support" contract. See the buying "support" page if you feel generous.
What's next?
Now Xdebug 2.2 is out of the door, I am looking for new features to add to Xdebug. What would you like to see added to Xdebug? Please leave a comment here, or add your feature requests at http://bugs.xdebug.org.
Comments
I am still hoping that we will find the time to implement what we outlined in http://sebastian-bergmann.de/archives/913-Towards-Better-Code-Coverage-Metrics-in-the-PHP-World.html ;-)
Congratulations on ten years of Xdebug!
Congrats on the 10 years! This is a heckuva tool you developed and I use it every day to debug my code.
Still shipping with .cvsignore ;-) Thank you for the hard work and h'ppy birthday Xdebug.
Life Line
I walked 6.8km in 1h15m36s
Updated an estate_agent office
I walked 4.1km in 55m33s
I walked 1.1km in 10m05s
My First Lapwing!
I went to the London Wetland Centre yesterday, for a day out in nature.
While hiding in a hide, this chap and a friend showed up starting to forage for grubs.
#BirdPhotography #BirdsOfMastodon #Photography #Birds #London #Nature
Created a waste_basket; Updated a cafe and a restaurant; Confirmed an estate_agent office
I walked 6.6km in 1h8m53s
@bennuttall Are you at the Crucible this year again?
I walked 9.7km in 5h29m12s
Updated a gate
Staring Contest with a Squirrel
On my walk on the weekend, I sat down on a tree branch of a tree that had fallen over some time ago. Just listening to the birds.
Then after hearing rustling in the foliage above me, I looked up, and saw this chap staring at me.
I walked 3.0km in 41m38s
I walked 1.1km in 12m20s
Bluebell Carpet
I had a lovely walk on Hampstead Heath yesterday, finding all the nooks and crannies away from the busy paths.
This field of bluebells under the colourful tree was a stand-out quiet spot.
I walked 2.3km in 21m51s
Fix paths
Created a memorial
Created a bench
@Edent Seems like my Android stopped sending coordinates to @openbenches as well, which is surprising as I haven't updated anything as far as I'm aware. Could it be a problem with the reader in your side after the latest changes and the addition of the warning?
I walked 5.8km in 2h15m45s
I walked 1.7km in 17m46s
I walked 4.8km in 1h39m40s
Add the new Queen Elizabeth II garden.
Updated a bench and a crossing; Deleted 2 kerbs
Created 3 gates and a waste_basket




Shortlink
This article has a short URL available: https://drck.me/xdebug-10-9eo