Library folders
A library is a third-party file or set of files used in a project as is.
PHP libraries are most commonly managed in projects by Composer, which declares them as dependencies and installs to folders in the vendor directory. To distinguish libraries from the project files but still include their classes and methods to the IDE's internal knowledge, PhpStorm marks library folders as library roots. For more information, refer to PHP library roots.
JavaScript libraries can be configured at the global (IDE) or project level, which defines reusability of the library within the IDE. For more information, refer to Configuring Javascript libraries.
In PhpStorm, a library root is a folder with library files that is marked as Excluded and at the same time is added as a PHP include path in Settings | PHP | Include Path. PhpStorm treats this root type in the following way:
Despite being excluded, libraries are still indexed, which means that the classes and methods from libraries are available in auto-completion, search, reference resolution, and so on, but on a second-class citizen principle. You can exclude libraries from indexing completely.
Libraries are excluded from error checks.
All library files open in the Reader mode and are protected with a Non-Project Files Protection pop-up on modification attempts, such as direct intentional editing or update result from refactoring.
In the Project tool window Alt01, library roots are marked with a colored background only:
data:image/s3,"s3://crabby-images/c84b9/c84b9f0e762f268aa90606336f877dee8a71a408" alt="Library roots in Project tool window Library roots in Project tool window"
By default, all folders under the vendor directory are considered to be library roots by PhpStorm. Such folders are added to Settings | PHP | Include Path automatically.
tip
You can remove library roots from the autogenerated list in Settings | PHP | Include Path manually, but note that, when you close and re-open the project, the list is regenerated by PhpStorm from the vendor folder anew.
The External Libraries node in the Project tool window Alt01 contains library roots added as PHP include paths manually.
If the project contains only Composer-managed libraries, double-clicking External Libraries opens the list of library roots in Settings | PHP | Include Path.
You can exclude specific folders in the vendor directory from indexing. To do so, select the folder in the Settings | PHP | Include Path list and click Exclude on the tools panel.
By doing so, you exclude the selected folder or file from include paths, changing its root type from Library () to Excluded (
).
data:image/s3,"s3://crabby-images/50d13/50d131144a2046ed03f2ba491c7fc5736386043b" alt="PHP exclude files from indexing PHP exclude files from indexing"
Besides Composer, you can use a third-party tool or framework as a library in your project in the following ways:
Store the tool under the project content root.
Add the tool under the PHP home directory and specify a relative path to it manually.
Store the tool elsewhere and configure it as a custom command line tool.
In either case, you can use exploded and archived tool sources. PhpStorm recognizes most popular zip and TAR.GZ formats as well as the PHP native PHAR format.
Thanks for your feedback!