2021-11-04 16:27:37 +01:00
|
|
|
← [[doom-module-index:][Back to module index]] ! [[doom-module-issues:::lang php][Issues]] ↖ [[doom-source:modules/lang/php/][Github]] ± [[doom-suggest-edit:][Suggest edits]] ? [[doom-help-modules:][Help]]
|
2021-10-16 01:28:32 +02:00
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
#+TITLE: :lang php
|
|
|
|
#+SUBTITLE: Perl's insecure younger brother
|
|
|
|
#+CREATED: January 16, 2017
|
|
|
|
#+SINCE: 1.3
|
|
|
|
|
|
|
|
* Description :unfold:
|
|
|
|
This module adds support for PHP 5.3+ (including PHP7) to Doom Emacs.
|
|
|
|
|
|
|
|
- ctags-based code completion (~company-php~ and ~phpctags~)
|
|
|
|
- eldoc support (~ac-php~ and ~php-extras~)
|
|
|
|
- REPL (~php-boris~)
|
|
|
|
- Code refactoring commands (~php-refactor-mode~)
|
|
|
|
- Unit-test commands (~phpunit~)
|
|
|
|
- Support for ~laravel~ and ~composer~ projects (with project-specific snippets)
|
|
|
|
- [[../../editor/file-templates/templates/php-mode][File templates]]
|
|
|
|
- [[https://github.com/hlissner/doom-snippets/tree/master/php-mode][Snippets]]
|
2017-05-25 20:08:50 +02:00
|
|
|
|
|
|
|
#+begin_quote
|
2021-10-16 01:28:32 +02:00
|
|
|
💡 PHP was the first programming language I got paid to code in, back in the
|
|
|
|
Cretaceous period (2003). My sincerest apologies go out to all the
|
|
|
|
programmers who inherited my earliest PHP work. I know you're out there,
|
|
|
|
writhing in your straitjackets.
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
Save a programmer today. Stop a friend from choosing PHP as their first
|
|
|
|
language.
|
2017-05-25 20:08:50 +02:00
|
|
|
#+end_quote
|
|
|
|
|
2020-03-27 18:06:51 -04:00
|
|
|
** Maintainers
|
2021-10-16 01:28:32 +02:00
|
|
|
*This module needs a maintainer.* [[doom-contrib-maintainer:][Become a maintainer?]]
|
|
|
|
|
|
|
|
** Module flags
|
|
|
|
- +hack ::
|
|
|
|
Add support for the [[https://hacklang.org/][Hack dialect of PHP]] by Facebook.
|
|
|
|
- +lsp ::
|
|
|
|
Enable LSP support for ~php-mode~. Requires [[doom-module:][:tools lsp]] and a langserver
|
|
|
|
(supports [[https://phpactor.readthedocs.io/en/develop/usage/standalone.html][phpactor]] and intelephense).
|
|
|
|
|
|
|
|
** Packages
|
|
|
|
- [[doom-package:][async]]
|
|
|
|
- [[doom-package:][hack-mode]] if [[doom-module:][+hack]]
|
|
|
|
- [[doom-package:][php-boris]]
|
|
|
|
- [[doom-package:][php-cs-fixer]] if [[doom-package:][:editor format]]
|
|
|
|
- [[doom-package:][php-extras]]
|
|
|
|
- [[doom-package:][php-mode]]
|
|
|
|
- [[doom-package:][php-refactor-mode]]
|
|
|
|
- [[doom-package:][phpunit]]
|
|
|
|
- if [[doom-module:][+lsp]]
|
|
|
|
- [[doom-package:][phpactor]]
|
|
|
|
- [[doom-package:][company-phpactor]]
|
|
|
|
|
|
|
|
** Hacks
|
|
|
|
/No hacks documented for this module./
|
|
|
|
|
|
|
|
** TODO Changelog
|
|
|
|
# This section will be machine generated. Don't edit it by hand.
|
|
|
|
/This module does not have a changelog yet./
|
|
|
|
|
|
|
|
* Installation
|
|
|
|
[[id:01cffea4-3329-45e2-a892-95a384ab2338][Enable this module in your ~doom!~ block.]]
|
|
|
|
|
|
|
|
This module requires ~php~ (5.3+) and ~composer~.
|
|
|
|
|
|
|
|
If [[doom-module:][+lsp]] is enabled, you'll also need one of these LSP servers:
|
|
|
|
- Phpactor requires ~php~ 7.3+.
|
|
|
|
- Intelephense requires ~node~ and ~npm~.
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
** PHP
|
2017-05-25 20:08:50 +02:00
|
|
|
*** MacOS
|
2021-09-15 20:22:52 +01:00
|
|
|
PHP 5.5 comes prepackaged with newer versions of MacOS. These instructions are
|
|
|
|
provided for reference:
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
#+begin_src sh
|
2017-05-25 20:08:50 +02:00
|
|
|
brew tap homebrew/homebrew-php
|
|
|
|
brew install php71 # or php53, php54, php55
|
|
|
|
brew install composer
|
2020-10-22 18:28:19 +08:00
|
|
|
|
|
|
|
# If you use intelephense:
|
|
|
|
brew install node
|
|
|
|
brew install npm
|
2021-09-15 20:10:42 +01:00
|
|
|
#+end_src
|
2017-05-25 20:08:50 +02:00
|
|
|
|
|
|
|
*** Arch Linux
|
2021-10-16 01:28:32 +02:00
|
|
|
#+begin_src sh
|
2017-05-25 20:08:50 +02:00
|
|
|
sudo pacman --needed --noconfirm -S php composer # or php53, php54, php55
|
2020-10-22 18:28:19 +08:00
|
|
|
|
|
|
|
# If you use intelephense:
|
|
|
|
sudo pacman -S nodejs npm
|
2021-09-15 20:10:42 +01:00
|
|
|
#+end_src
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2019-08-27 10:50:37 +02:00
|
|
|
*** openSUSE
|
2021-10-16 01:28:32 +02:00
|
|
|
#+begin_src sh
|
2019-08-27 10:50:37 +02:00
|
|
|
sudo zypper install php-composer
|
2020-10-22 18:28:19 +08:00
|
|
|
|
|
|
|
# If you use intelephense:
|
|
|
|
sudo zypper install nodejs npm
|
2021-09-15 20:10:42 +01:00
|
|
|
#+end_src
|
2019-08-27 10:50:37 +02:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
** LSP Support
|
|
|
|
There are a number of currently supported LSP servers:
|
|
|
|
|
|
|
|
- [[https://emacs-lsp.github.io/lsp-mode/page/lsp-intelephense/][Intelephense]] (_Recommended_)
|
|
|
|
- [[https://emacs-lsp.github.io/lsp-mode/page/lsp-phpactor/][phpactor]]
|
|
|
|
- [[https://emacs-lsp.github.io/lsp-mode/page/lsp-serenata/][Serenata]]
|
|
|
|
- [[https://emacs-lsp.github.io/lsp-mode/page/lsp-php/][felixbecker]] (Considered unsupported)
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
Intelephense is currently the only server that supports automatic installation,
|
|
|
|
which will trigger either when you open a PHP project or manually invoke
|
|
|
|
~lsp-install-server~ through [[kbd:][M-x]].
|
|
|
|
|
|
|
|
The others have to be installed manually and added to your =$PATH=.
|
|
|
|
|
|
|
|
** Dependencies
|
|
|
|
- ~boris~ (REPL)
|
|
|
|
- ~phpctags~ (better code completion)
|
|
|
|
- ~phpunit~ (unit test commands)
|
|
|
|
- ~php-cs-fixer~ and ~@prettier/plugin-php~ (for code formatting)
|
2021-09-15 20:22:52 +01:00
|
|
|
+ ~phpactor~ (for LSP if intelephense isn't desired)
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2021-09-15 20:10:42 +01:00
|
|
|
#+begin_src sh
|
2017-05-25 20:08:50 +02:00
|
|
|
composer global require \
|
|
|
|
d11wtq/boris \
|
|
|
|
phpunit/phpunit \
|
2021-01-31 05:42:13 -05:00
|
|
|
techlivezheng/phpctags \
|
2021-09-15 20:22:52 +01:00
|
|
|
friendsofphp/php-cs-fixer \
|
|
|
|
phpactor/phpactor
|
2021-01-31 05:42:13 -05:00
|
|
|
|
|
|
|
# Needed by php-cs-fixer, otherwise you'll get "Couldn't resolve parser
|
|
|
|
# 'php'" errors
|
|
|
|
npm install -g @prettier/plugin-php
|
2021-09-15 20:10:42 +01:00
|
|
|
#+end_src
|
2017-05-25 20:08:50 +02:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
You must ensure that =$HOME/.composer/vendor/bin= is in =$PATH=, so these
|
|
|
|
executables are visible to Emacs:
|
2021-09-15 20:10:42 +01:00
|
|
|
#+begin_src sh
|
2017-05-25 20:08:50 +02:00
|
|
|
# place this in your profile file, like ~/.bash_profile or ~/.zshenv
|
|
|
|
export PATH="~/.composer/vendor/bin:$PATH"
|
2021-09-15 20:10:42 +01:00
|
|
|
#+end_src
|
2020-03-27 18:06:51 -04:00
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
You may also need to regenerate your envvar file by running ~$ doom env~ on the
|
2021-01-31 05:42:13 -05:00
|
|
|
command line.
|
|
|
|
|
2021-09-15 20:22:52 +01:00
|
|
|
*NOTE* phpactor doesn't have to be installed via =composer=, just has to exist in
|
|
|
|
your =$PATH=.
|
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
* TODO Usage
|
|
|
|
#+begin_quote
|
|
|
|
🔨 /This module's usage documentation is incomplete./ [[doom-contrib-module:][Complete it?]]
|
|
|
|
#+end_quote
|
2021-09-15 20:22:52 +01:00
|
|
|
|
|
|
|
** PHPUnit
|
|
|
|
This module provides an interface to PHPUnit through a number of commands as
|
|
|
|
detailed below. By default, it loads configuration from the root ~phpunit.xml~.
|
|
|
|
|
|
|
|
+ ~phpunit-current-project~ Launch all tests for the project
|
|
|
|
+ ~phpunit-current-class~ Launch all tests for the current class/fixture
|
|
|
|
+ ~phpunit-current-test~ Launch the current test at point
|
|
|
|
|
|
|
|
If for some reason, the default ~phpunit.xml~ is in a different location (or you
|
|
|
|
use the ~phpunit.xml.dist~ convention) , the path can be changed via
|
|
|
|
=phpunit-configuration-file=
|
|
|
|
|
|
|
|
#+begin_src emacs-lisp
|
|
|
|
(setq phpunit-configuration-file "phpunit.xml")
|
|
|
|
#+end_src
|
|
|
|
|
|
|
|
** Composer
|
|
|
|
This module provides several convenience methods for triggering composer
|
|
|
|
commands:
|
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
| Binding | Function |
|
|
|
|
|---------------------+-----------------------------------|
|
|
|
|
| [[kbd:][<localleader> m c c]] | ~composer~ |
|
|
|
|
| [[kbd:][<localleader> m c i]] | ~composer-install~ |
|
|
|
|
| [[kbd:][<localleader> m c r]] | ~composer-require~ |
|
|
|
|
| [[kbd:][<localleader> m c u]] | ~composer-update~ |
|
|
|
|
| [[kbd:][<localleader> m c d]] | ~composer-dump-autoload~ |
|
|
|
|
| [[kbd:][<localleader> m c s]] | ~composer-run-scripts~ |
|
|
|
|
| [[kbd:][<localleader> m c v]] | ~composer-run-vendor-bin-command~ |
|
|
|
|
| [[kbd:][<localleader> m c o]] | ~composer-find-json-file~ |
|
|
|
|
| [[kbd:][<localleader> m c l]] | ~composer-view-lock-file~ |
|
|
|
|
|
|
|
|
These are all invokable via [[kbd:][M-x]] too.
|
|
|
|
|
|
|
|
* TODO Configuration
|
|
|
|
#+begin_quote
|
|
|
|
🔨 /This module's configuration documentation is incomplete./ [[doom-contrib-module:][Complete it?]]
|
|
|
|
#+end_quote
|
|
|
|
|
2021-09-15 20:22:52 +01:00
|
|
|
** Docker Compose
|
|
|
|
A lot of projects rely on running inside docker compose (ie Laravel), and as
|
|
|
|
such a minor mode has been configured to attempt to run tests inside the =php-fpm=
|
|
|
|
(by default) container.
|
|
|
|
|
2021-10-18 00:37:32 +01:00
|
|
|
This mode is disabled by default, to opt-in set =+php-run-tests-in-docker= to =t= in
|
|
|
|
your config. If this is done during Emacs running, you will also have to reload
|
|
|
|
=php-mode= (i.e. through =M-x php-mode=)
|
|
|
|
|
|
|
|
If you wish to specify a different container, modify the
|
|
|
|
~+php-default-docker-container~ variable (ideally inside a ~.dir-locals.el~ file)
|
2021-09-15 20:22:52 +01:00
|
|
|
|
|
|
|
#+begin_src emacs-lisp
|
2021-10-18 00:37:32 +01:00
|
|
|
((php-mode . ((+php-default-docker-container . "php-octane"))))
|
2021-09-15 20:22:52 +01:00
|
|
|
#+end_src
|
|
|
|
|
|
|
|
* Troubleshooting
|
2021-10-16 01:28:32 +02:00
|
|
|
[[doom-report:][Report an issue?]]
|
|
|
|
|
2021-09-15 20:22:52 +01:00
|
|
|
** "I'm missing functionality on lsp-mode"
|
|
|
|
Unfortunately, [[https://intelephense.com/][intelephense]] currently operates under a "freemium" model, and as
|
|
|
|
such requires a license for extended features. Once purchased, this can be
|
|
|
|
(insecurely) added directly to your config:
|
|
|
|
#+begin_src emacs-lisp
|
|
|
|
(setq lsp-intelephense-licence-key "<key>")
|
|
|
|
#+end_src
|
|
|
|
|
|
|
|
A more recommended approach would be to utilise Emacs' own ~auth-sources~ for
|
|
|
|
storing authentication info, which can also be encrypted.
|
|
|
|
|
|
|
|
Create a file in your home directory (which can optionally be encrypted, verify
|
2021-10-16 01:28:32 +02:00
|
|
|
your ~auth-sources~ has the correct values) called ~~/.authinfo~:
|
2021-09-15 20:22:52 +01:00
|
|
|
#+begin_src
|
|
|
|
machine * login intelephense password <key>
|
|
|
|
#+end_src
|
|
|
|
|
2021-10-16 01:28:32 +02:00
|
|
|
And add the following to your config:
|
2021-09-15 20:10:42 +01:00
|
|
|
#+begin_src emacs-lisp
|
2021-09-15 20:22:52 +01:00
|
|
|
(defun my-fetch-password (&rest params)
|
|
|
|
(require 'auth-source)
|
|
|
|
(let ((match (car (apply #'auth-source-search params))))
|
|
|
|
(if match
|
|
|
|
(let ((secret (plist-get match :secret)))
|
|
|
|
(if (functionp secret)
|
|
|
|
(funcall secret)
|
|
|
|
secret))
|
|
|
|
(error "Password not found for %S" params))))
|
|
|
|
|
|
|
|
(setq lsp-intelephense-license-key (my-fetch-password :user intelephense))
|
2021-09-15 20:10:42 +01:00
|
|
|
#+end_src
|
2021-10-16 01:28:32 +02:00
|
|
|
|
|
|
|
* Frequently asked questions
|
|
|
|
/This module has no FAQs yet./ [[doom-suggest-faq:][Ask one?]]
|
|
|
|
|
|
|
|
* TODO Appendix
|
|
|
|
#+begin_quote
|
|
|
|
🔨 This module has no appendix yet. [[doom-contrib-module:][Write one?]]
|
|
|
|
#+end_quote
|