This repository has been archived by the owner on Jul 11, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #184 from craftcms/feature/xdebug-setup-edits
Spiff up Xdebug PhpStorm setup instructions.
- Loading branch information
Showing
1 changed file
with
23 additions
and
27 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,46 +1,42 @@ | ||
# Using Xdebug with Nitro and PhpStorm | ||
|
||
Once you have a machine created, you can run `nitro xdebug on` and `nitro xdebug configure` to enable Xdebug and set it up for automatic remote connections from your host machine. These make the | ||
Once you’ve created a machine, you can run `nitro xdebug on` and `nitro xdebug configure` to enable [Xdebug](https://xdebug.org/) and set it up for automatic connections from your host machine. | ||
|
||
## Debugging web requests | ||
You can use `nitro xdebug off` to disable Xdebug without having to restart the machine. | ||
|
||
Install the Xdebug browser helper in your favorite browser. | ||
## Configuring PhpStorm | ||
|
||
- [Chrome](https://chrome.google.com/extensions/detail/eadndfjplgieldjbigjakmdgkmoaaaoc) | ||
- [Firefox](https://addons.mozilla.org/en-US/firefox/addon/xdebug-helper-for-firefox/) | ||
- [Internet Explorer](https://www.jetbrains.com/phpstorm/marklets/) | ||
- [Safari](https://github.com/benmatselby/xdebug-toggler) | ||
- [Opera](https://addons.opera.com/addons/extensions/details/xdebug-launcher/) | ||
|
||
Go to the Xdebug browser helper options, choose "PhpStorm" and save. | ||
|
||
data:image/s3,"s3://crabby-images/cf5ac/cf5ac3a7d39998ef7fd9519c5ad05b0930e140df" alt="Xdebug Browser Helper Chrome" | ||
|
||
Create a new server in PhpStorm using your machine's domain name. | ||
First, you’ll need to configure PhpStorm to listen for requests from the browser or console. | ||
|
||
1. Create a new server in PhpStorm using your machine’s domain name. (“Preferences” → “Languages & Frameworks” → “PHP” → “Servers”.) | ||
data:image/s3,"s3://crabby-images/2e1d3/2e1d348c4079692ed7c36eb658124d5de9be3818" alt="PhpStorm Server Settings" | ||
|
||
Setup path mappings to that `/app/sites/example.test` in your Nitro machine is | ||
mapped to your project's root on your host machine. | ||
2. Enable “Use path mappings” and set your existing project root to the absolute path on the server. The absolute path will look like `/home/ubuntu/sites/my-site`, where `my-site` reflects your actual project’s folder name in the Nitro machine. (Use `nitro context` if you need to check the path, and keep in mind this is the project root and not necessarily the web root.) | ||
|
||
Create a new "PHP Remote Debug" configuration and select the server you just created. | ||
3. Choose “Run” → “Edit Configurations...” and create a new “PHP Remote Debug” configuration, selecting the server you just created. Check “Filter debug connection by IDE key” and enter `PHPSTORM`. | ||
data:image/s3,"s3://crabby-images/57fe6/57fe6e10b57b75dfeaeb65aaecb675f9e92212bb" alt="PhpStorm Remote Debug Settings" | ||
|
||
Check "Filter debug connection by IDE key" and enter "PHPSTORM" for the IDE key. | ||
4. Choose “Run” → “Start Listening for PHP Debug Connections”. | ||
data:image/s3,"s3://crabby-images/bf12b/bf12be15d3648fa7cb83528147aacbc49da3a5ae" alt="PhpStorm Remote Debug Settings" | ||
|
||
data:image/s3,"s3://crabby-images/57fe6/57fe6e10b57b75dfeaeb65aaecb675f9e92212bb" alt="PhpStorm Remote Debug Settings" | ||
## Debugging Web Requests | ||
|
||
Click the "Start Listening for PHP Debug Connections" button in PhpStorm. | ||
1. Install the Xdebug helper in your favorite browser. | ||
|
||
data:image/s3,"s3://crabby-images/bf12b/bf12be15d3648fa7cb83528147aacbc49da3a5ae" alt="PhpStorm Remote Debug Settings" | ||
- [Chrome](https://chrome.google.com/extensions/detail/eadndfjplgieldjbigjakmdgkmoaaaoc) | ||
- [Firefox](https://addons.mozilla.org/en-US/firefox/addon/xdebug-helper-for-firefox/) | ||
- [Internet Explorer](https://www.jetbrains.com/phpstorm/marklets/) | ||
- [Safari](https://github.com/benmatselby/xdebug-toggler) | ||
- [Opera](https://addons.opera.com/addons/extensions/details/xdebug-launcher/) | ||
|
||
Click the "Debug" button on your browser's Xdebug helper. | ||
2. In the browser helper’s options, choose “PhpStorm” and save. | ||
data:image/s3,"s3://crabby-images/cf5ac/cf5ac3a7d39998ef7fd9519c5ad05b0930e140df" alt="Xdebug Browser Helper Chrome" | ||
|
||
3. Choose “Debug” on your browser’s Xdebug helper. | ||
data:image/s3,"s3://crabby-images/09f5e/09f5e61465c1d8574bda4dd4025a9a578df6d0e5" alt="PhpStorm Remote Debug Settings" | ||
|
||
Then load the site in your browser and whatever breakpoints you've set will be hit. | ||
4. Load the site in your browser and whatever breakpoints you’ve set will be hit. | ||
|
||
## Debugging PHP console requests | ||
## Debugging Console Requests | ||
|
||
Do everything above except Xdebug browser helper. SSH into your Nitro machine using | ||
`nitro ssh`, then run your PHP script from the console and any breakpoints you've | ||
set will be hit. | ||
SSH into your Nitro machine using `nitro ssh`, then run your PHP script from the console and any breakpoints you’ve set will be hit. |