Download the PHP package raveren/kint without Composer
On this page you can find all versions of the php package raveren/kint. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Package kint
Short Description ☯ Insightful PHP debugging assistant.
License MIT
Homepage https://github.com/phpsage/sage
Informations about the package kint
Sage - Insightful PHP debugging assistant ☯
At first glance Sage is just a drop-in replacement for var_dump() and debug_backtrace().
However, it's much, much more.
Sage is designed to exceed expectations, it intelligently handles everything that you throw at it and displays in the best possible way.
If you can think of how it can be better, please create an issue!
For an overview of Sage's outstanding features jump to the F.A.Q.
Installation
Or if you prefer, download the phar and simply
Or if your PHP version does not support either, download the latest source code and include Sage.php
Usage
Function | Shorthand | |
---|---|---|
sage |
s |
Dump (same as \Sage::dump() ) |
saged |
sd |
Dump & die |
ssage |
ss |
Simple dump |
ssaged |
ssd |
Simple dump & die |
sagetrace |
s(1) |
Debug backtrace (same as \Sage::trace() ) |
Simple dump:
Debug backtrace:
Guarantees ✅
-
Sage just works and it displays ALL available information (or in cases when something is truncated - that is clear too).
-
Each release is vigorously tested. Or - use the bleeding edge
dev-main
version at your own risk. -
Semver versioning ensures there's no compatibility breaks if you use it in your production (eg. reporting).
- Sage has gotten lots of love and improvements in the last >10 years. It is used by a lot of real people in a lot of real-world scenarios, it is battle tested and has a lot of advanced features no other tool has.
More cool stuff
Sage displays the passed variable name and supports prefixes to the dump function call. Use it for some common on-the-fly adjustments to the dump output.
Sage tokenizes & introspects the calling code to get all this information. All that can be done with prefixes can also be achieved with standard, verbose syntax:
See Advanced section below if you want more tips & tricks.
Verbose versions
If you want to use Sage as part of permanent code (e.g. part of a test helper/logger/exception reporter etc), you can use the verbose way to invoke Sage:
Customization
The main goal of Sage is to be zero-setup. There are also several customization options for advanced uses.
Where to store the configuration?
-
Add this entry to the
autoload.files
configuration incomposer.json
: -
Put settings inside of
php.ini
: - Include the desired settings in your bootstrap process anywhere™.
All available options
Currently available themes are:
Sage::THEME_ORIGINAL
Sage::THEME_LIGHT
Sage::THEME_SOLARIZED
Sage::THEME_SOLARIZED_DARK
Make visible source file paths clickable to open your editor. Available options are:
'phpstorm-remote'
- default (requires IDE Remote Control plugin),'sublime'
,'textmate'
,'emacs'
,'macvim'
,'phpstorm'
,'idea'
,'vscode'
,'vscode-insiders'
,'vscode-remote'
,'vscode-insiders-remote'
,'vscodium'
,'atom'
,'nova'
,'netbeans'
,'xdebug'
Or pass a custom string where %file should be replaced with full file path, %line with line number to create a custom link. Set to null to disable linking.
Whether to display where Sage was called from
Max array/object levels to go deep, set to zero/false to disable
Draw rich output already expanded without having to click
Enable detection when running in command line and adjust output format accordingly.
In addition to above setting, enable detection when Sage is run in UNIX command line. Attempts to add coloring, but if opened as plain text, the color information is visible as gibberish.
Possible alternative char encodings in order of probability.
Sage returns output instead of printing it.
Add new custom Sage wrapper names. Optional, but needed for backtraces, variable name detection and modifiers to work
properly. Accepts array or comma separated string. Use notation Class::method
for methods.
🧙 Advanced Tips & Tricks
this section is under construction :)
- Sage supports keyboard shortcuts! Just press d when viewing output and the rest is self-explanatory, try it
out! (p.s.
vim-style
hjkl
works as well); - Call
Sage::enabled(Sage::MODE_PLAIN);
to switch to a simpler, js-free output. - Call
Sage::enabled(Sage::MODE_TEXT_ONLY);
for pure-plain text output which you can save or pass around by first settingSage::$returnOutput = true;
-
Sage can provide a plain-text version of its output and does so automatically when invoked via PHP running in command line mode.
- Double clicking the
[+]
sign in the output will expand/collapse ALL nodes; triple clicking a big block of text will select it all. - Clicking the tiny arrow on the right of the output will open it in a separate window where you can keep it for comparison.
-
Sage supports themes:
For customization instructions read the section below.
- If a variable is an object, its classname can be clicked to open the class in your IDE.
-
There are several real-time prefix modifiers you can use (combinations possible):
Prefix Example print Puts output into current DIR as sage.html print sage() ! Dump ignoring depth limits for large objects ! sage() ~ Simplifies sage output (rich->html->plain) ~ sage() - Clean up any output before dumping - sage() + Expand all nodes (in rich view) + sage() @ Return output instead of displaying it @ sage() - Sage also includes a naïve profiler you may find handy. It's for determining relatively which code blocks take longer than others:
- Sage runs perfectly fine on PHP 5.1 (couldn't find a way to test it on 5.0).
F.A.Q.
💬 How is it different or better than symfony/var-dumper?
- Visible Variable name
- Keyboard shortcuts. Type d and the rest is just self-explanatory (use arrows, space, tab, enter, you'll get it!).
- Debug backtraces with full insight of arguments, callee objects and more.
- Custom display for a lot of recognized types:
- Has text-only, plain and rich views, has several visual themes - created by a professional designer.
- A huge number of usability enhancements - like the (clickable) call trace in the footer of each output.
- Supports convenience modifiers, for example
@sage($var);
will return instead of outputting,-sage($var);
willob_clean
all output to be the only thing on page (see advanced section above for more). - Compatibility! Fully works on PHP 5.1 - 8.1+!
- Code is way less complex - to read and contribute to.
- Sage came first - developed since pre-2012. It inspired the now ubiquitous dd shorthand, pioneered a lot of the concepts in the tool niche.
💬 What are the other dumpers out there
- Symfony/var-dumper
- yii\helpers\VarDumper
- Tracy
- PHP Debug Bar
- Kint - sage supersedes Kint.
💬 Why does Sage look so much like Kint? A.K.A. Why does this repo have so few stars?
Because it is Kint, and I am its author, however the project was forcibly taken over by a malicious contributor!
Instead of fighting windmills I chose to fork and rename the last good version and continue under a new name!
You can use Sage as a drop-in replacement for Kint. Simple.
💬 How is var_dump
- style debugging still relevant when we have Xdebug?
- In practice, Xdebug is quite often very difficult and time-consuming to install and configure.
- There's many use-cases where dump&die is just faster to bring up.
- There is no way you can visualise a timeline of changed data with XDebug. For example, all values dumped from within a loop.
- And there's more subtle use-cases, eg. if you stepped over something there's no way to go back, but with var-dumping the values are still there...
I use xdebug almost daily, by the way. Side by side with Sage.
Known issues
- Since PHP 8.2 variable name detection for multiline Sage calls is broken. Simple matter of Backtrace format changing the reported line, fix is comming.
Contributing
🎲 Prerequisites
- Install Docker Compose.
- If you're on Windows 10+ you need to use WSL2:
- Setup:
wsl --install
- Set Ubuntu as your default wsl shell:
wsl --set-version Ubuntu 2
. - All commands listed below must be run from inside wsl shell:
wsl
- Setup:
Do your changes but before committing run
To compile resources and build the phar file.
Author
Rokas Šleinius (Raveren)
Contributors: https://github.com/php-sage/sage/graphs/contributors
License
Licensed under the MIT License
Hope you'll love using Sage as much as I love creating it!