Alexander-Miller/treemacs@96a808f067 -> Alexander-Miller/treemacs@820b09db10 FStarLang/fstar-mode.el@36ffb46259 -> FStarLang/fstar-mode.el@3bbfe93abd JuliaEditorSupport/julia-emacs@0f4d74f904 -> JuliaEditorSupport/julia-emacs@5c940c4ba3 ProofGeneral/PG@85cde55a86 -> ProofGeneral/PG@af2e7b9a4e Silex/docker.el@3bea08f1d2 -> Silex/docker.el@464105ed8b Wilfred/helpful@6a4d5e0760 -> Wilfred/helpful@03756fa6ad abo-abo/swiper@e33b028ed4 -> abo-abo/swiper@2529a23f9f agda/agda@49a12eab7f -> agda/agda@900bdaa335 alexluigit/dirvish@ecb7c42e20 -> alexluigit/dirvish@e8ec5765da ardumont/markdown-toc@d2fb4cbd95 -> ardumont/markdown-toc@1b0c5ae7f3 bastibe/org-journal@cf72173233 -> bastibe/org-journal@e581bf5530 clojure-emacs/cider@fdfa7c2200 -> clojure-emacs/cider@12f10a6f4b clojure-emacs/clojure-mode@eabe29b076 -> clojure-emacs/clojure-mode@b766094aea company-mode/company-mode@8d599ebc8a -> company-mode/company-mode@41f07c7d40 creichert/ido-vertical-mode.el@b1659e967d -> creichert/ido-vertical-mode.el@35c521789b dgutov/diff-hl@7da881a957 -> dgutov/diff-hl@aa667ac58a dimitri/switch-window@61e425e703 -> dimitri/switch-window@8f771b571a doomelpa/code-review@eeffdd9e20 -> doomelpa/code-review@fba8fe3343 editorconfig/editorconfig-emacs@1a9942746c -> editorconfig/editorconfig-emacs@d2beb3ec2e ema2159/centaur-tabs@7704f2017c -> ema2159/centaur-tabs@a790dc8fb6 emacs-circe/circe@d0e531bd2a -> emacs-circe/circe@e5e64d549f emacs-citar/citar-org-roam@ff38add0aa -> emacs-citar/citar-org-roam@9750cfbbf3 emacs-ess/ESS@56f355acbd -> emacs-ess/ESS@d19efaae12 emacs-helm/helm-org@22d60952f8 -> emacs-helm/helm-org@4744ca7f8b emacs-helm/helm@f948dc4464 -> emacs-helm/helm@5a222a8a6b emacs-lsp/dap-mode@56e92dd86b -> emacs-lsp/dap-mode@b977566657 emacs-lsp/emacs-ccls@28c7930c89 -> emacs-lsp/emacs-ccls@5636ee6c50 emacs-lsp/helm-lsp@cf4ea6fb42 -> emacs-lsp/helm-lsp@54926afd10 emacs-lsp/lsp-dart@2170823139 -> emacs-lsp/lsp-dart@34e2a1191f emacs-lsp/lsp-haskell@cd0f5d251c -> emacs-lsp/lsp-haskell@081d5115ce emacs-lsp/lsp-ivy@bdc730a209 -> emacs-lsp/lsp-ivy@3ee14a24bb emacs-lsp/lsp-java@6cfff8761e -> emacs-lsp/lsp-java@21c89243ad emacs-lsp/lsp-metals@345b4fa80e -> emacs-lsp/lsp-metals@e1d9d04f3b emacs-lsp/lsp-mode@7c0df125c1 -> emacs-lsp/lsp-mode@54251da4ff emacs-lsp/lsp-pyright@b4cee81af4 -> emacs-lsp/lsp-pyright@73377169be emacs-lsp/lsp-sourcekit@3bd9750e7e -> emacs-lsp/lsp-sourcekit@1fb230109e emacs-lsp/lsp-treemacs@312dee2b3a -> emacs-lsp/lsp-treemacs@3e5550f278 emacs-lsp/lsp-ui@09d4080642 -> emacs-lsp/lsp-ui@a0dde8b52b emacs-php/composer.el@6c7e19256f -> emacs-php/composer.el@eba6b953a4 emacs-php/php-mode@5b6cc1c068 -> emacs-php/php-mode@462b62248f emacs-php/psysh.el@ae15a36301 -> emacs-php/psysh.el@223bf55975 emacs-rustic/rustic@22a5ef8bfd -> emacs-rustic/rustic@29f912c750 emacs-straight/auctex@6fb366064c -> emacs-straight/auctex@f58a2b972b emacs-straight/dape@c7a1f1abdb -> emacs-straight/dape@588a907c87 emacs-straight/eglot@6a9e0c76b9 -> emacs-straight/eglot@928c216af5 emacs-straight/org-mode@74dde3abae -> emacs-straight/org-mode@79781bac69 emacs-straight/project@369ac661c8 -> emacs-straight/project@27c6b04914 emacs-straight/sml-mode@021233f60a -> emacs-straight/sml-mode@c33659fd9b emacs-straight/use-package@d79bac4574 -> emacs-straight/use-package@bbfe01bdf1 emacs-straight/vundo@c32481ab48 -> emacs-straight/vundo@5a666b34e4 emacs-tree-sitter/elisp-tree-sitter@8516c9977e -> emacs-tree-sitter/elisp-tree-sitter@12f92ef399 emacs-tree-sitter/tree-sitter-langs@2ff446b4b8 -> emacs-tree-sitter/tree-sitter-langs@4eb4989d1a emacsmirror/org-contrib@8d14a600a2 -> emacsmirror/org-contrib@f1f6b6ec81 emacsorphanage/dart-mode@6229941ec5 -> emacsorphanage/dart-mode@f82ff05230 emacsorphanage/ox-pandoc@34e6ea97b5 -> emacsorphanage/ox-pandoc@5766c70b6d emacsorphanage/quickrun@4b6df453f8 -> emacsorphanage/quickrun@a5c9a5e8c6 ericdallo/hover.el@4ca0638a14 -> ericdallo/hover.el@1b380fa395 erlang/otp@740af6bae5 -> erlang/otp@b9d3ec017d flycheck/flycheck@b9db1379dc -> flycheck/flycheck@16b536b031 fsharp/emacs-fsharp-mode@bf7a11e1ba -> fsharp/emacs-fsharp-mode@8d08f05788 godotengine/emacs-gdscript-mode@3f3739dd88 -> godotengine/emacs-gdscript-mode@5136be407a greghendershott/racket-mode@88d82e249e -> greghendershott/racket-mode@c4cc7c160b hakimel/reveal.js@dfc5690c6d -> hakimel/reveal.js@eb95b14531 haskell/haskell-mode@be2639592f -> haskell/haskell-mode@e9c3567393 https://git.notmuchmail.org/git/notmuch@dfc800c26e7b -> https://git.notmuchmail.org/git/notmuch@d8ebc9cf80b6 https://git.savannah.gnu.org/git/emms.git@8713a0ee985c -> https://git.savannah.gnu.org/git/emms.git@abb4f614dae6 idris-hackers/idris-mode@09de86a8f0 -> idris-hackers/idris-mode@ccf32ed0b5 jcollard/elm-mode@699841865e -> jcollard/elm-mode@90b72cd2c9 jdtsmith/indent-bars@fa293f98ab -> jdtsmith/indent-bars@ea74161b46 jdtsmith/ultra-scroll@b72c507f67 -> jdtsmith/ultra-scroll@f2e4fba601 jimhourihan/glsl-mode@c5f2c2e7ed -> jimhourihan/glsl-mode@86e6bb6cf2 joaotavora/sly@c48defcf58 -> joaotavora/sly@ce17a568ef jrblevin/markdown-mode@d2d960bec1 -> jrblevin/markdown-mode@90ad4af79a jschaf/powershell.el@38727f1cda -> jschaf/powershell.el@9efa1b4d0a magit/magit@bf58615a03 -> magit/magit@531e7ca619 minad/cape@f72ebcaeff -> minad/cape@5546a2db8e minad/consult-flycheck@3bc2141daf -> minad/consult-flycheck@77d3e790a3 minad/consult@f94d557807 -> minad/consult@ee64a2a299 minad/corfu@061d926d0f -> minad/corfu@2e05fe8244 minad/goggles@d71e85ff8d -> minad/goggles@6141d31c51 minad/marginalia@c51fd9e4d4 -> minad/marginalia@2ff4d690f7 minad/org-modern@3cc432dc99 -> minad/org-modern@6158d3d007 minad/vertico@e0bb699ebf -> minad/vertico@304be874be mohkale/consult-yasnippet@834d39acfe -> mohkale/consult-yasnippet@a3482dfbdc msnoigrs/ox-rst@b4ba5c7e95 -> msnoigrs/ox-rst@b73eff187e oantolin/embark@d5df0eff18 -> oantolin/embark@923d0ec52e ocaml/dune@a46193e167 -> ocaml/dune@422986440e ocaml/merlin@2eeb63d002 -> ocaml/merlin@e4c66857ad oer/org-re-reveal@53e9be7d89 -> oer/org-re-reveal@89ed240450 polymode/poly-R@8024e852cf -> polymode/poly-R@fee0b6e999 purcell/package-lint@43012b41ac -> purcell/package-lint@2dc48e5fb9 purescript-emacs/purescript-mode@a3d6ca4ba5 -> purescript-emacs/purescript-mode@8c4736759a pythonic-emacs/pyenv-mode@7faed57eb7 -> pythonic-emacs/pyenv-mode@ba1a8c7bd7 rust-lang/rust-mode@efd830806c -> rust-lang/rust-mode@25d91cff28 seagle0128/doom-modeline@1708db2d35 -> seagle0128/doom-modeline@a85cb28da8 seagle0128/grip-mode@e90e3b47d8 -> seagle0128/grip-mode@96a927dce6 seagle0128/nerd-icons-ivy-rich@5006f91b49 -> seagle0128/nerd-icons-ivy-rich@83c7b60595 sebasmonia/sharper@496e90e337 -> sebasmonia/sharper@5049795848 swift-emacs/swift-mode@2c0b2b72dc -> swift-emacs/swift-mode@e30b9d46e0 szermatt/emacs-bash-completion@a4c8fbc902 -> szermatt/emacs-bash-completion@d0637428fd technomancy/fennel-mode@811f39de12 -> technomancy/fennel-mode@df8e83d6e2 wanderlust/wanderlust@6a0605415d -> wanderlust/wanderlust@d6dcbad228 weijiangan/flycheck-golangci-lint@424ba1b3a1 -> weijiangan/flycheck-golangci-lint@14bf143ea7 ziglang/zig-mode@4ad4edf759 -> ziglang/zig-mode@c46d024733
:lang php
Description unfold
This module adds support for PHP 5.3+ (including PHP8) to Doom Emacs.
- ctags-based code completion (
company-php
andphpctags
) - eldoc support (
ac-php
andphp-extras
) - REPL (
psysh
) - Code refactoring commands (
php-refactor-mode
) - Unit-test commands (
phpunit
) - Support for
laravel
andcomposer
projects (with project-specific snippets) - LSP support (via the doom-module:+lsp flag)
- File templates
- Snippets
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.
Maintainers
Module flags
- +hack
- Add support for the Hack dialect of PHP by Facebook.
- +lsp
-
Enable LSP support for
php-mode
. Requires doom-module::tools lsp and a langserver (supports phpactor, intelephense, serenata, php-language-server). - +tree-sitter
- Leverages tree-sitter for better syntax highlighting and structural text editing. Requires doom-module::tools tree-sitter.
Packages
Hacks
No hacks documented for this module.
TODO Changelog
This module does not have a changelog yet.
Installation
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
andnpm
.
PHP
MacOS
PHP 5.5 comes prepackaged with newer versions of MacOS. These instructions are provided for reference:
brew tap homebrew/homebrew-php
brew install php@8.0 # or php53, php54, php55
brew install composer
# If you use intelephense:
brew install node
brew install npm
Arch Linux
sudo pacman --needed --noconfirm -S php composer # or php53, php54, php55
# If you use intelephense:
sudo pacman -S nodejs npm
openSUSE
sudo zypper install php-composer
# If you use intelephense:
sudo zypper install nodejs npm
Debian
sudo apt-get install php php-common
# If you use intelephense:
sudo apt-get install nodejs npm
LSP Support
There are a number of currently supported LSP servers:
- Intelephense (Recommended)
- phpactor
- Serenata
- felixbecker (Considered unsupported)
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 M-x.
The others have to be installed manually and added to your $PATH
.
Dependencies
pysh
(REPL)phpctags
(better code completion)phpunit
(unit test commands)phpcbf
, provided bysquizlabs/php_codesniffer
(for code formatting)phpactor
(for LSP if intelephense isn't desired)
composer global require \
psy/psysh \
phpunit/phpunit \
techlivezheng/phpctags \
squizlabs/php_codesniffer \
phpactor/phpactor
You must ensure that $HOME/.composer/vendor/bin
is in $PATH
, so these
executables are visible to Emacs:
# place this in your profile file, like ~/.bash_profile or ~/.zshenv
export PATH="~/.composer/vendor/bin:$PATH"
You may also need to regenerate your envvar file by running $ doom env
on the
command line.
NOTE phpactor doesn't have to be installed via composer
, just has to exist in
your $PATH
.
NOTE Phpactor cannot be installed, globally at least, with PHP ^8.
TODO Usage
This module's usage documentation is incomplete. Complete it?
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 projectphpunit-current-class
Launch all tests for the current class/fixturephpunit-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
(setq phpunit-configuration-file "phpunit.xml")
Composer
This module provides several convenience methods for triggering composer commands:
Binding | Function |
---|---|
<localleader> m c c | composer |
<localleader> m c i | composer-install |
<localleader> m c r | composer-require |
<localleader> m c u | composer-update |
<localleader> m c d | composer-dump-autoload |
<localleader> m c s | composer-run-scripts |
<localleader> m c v | composer-run-vendor-bin-command |
<localleader> m c o | composer-find-json-file |
<localleader> m c l | composer-view-lock-file |
These are all run via M-x too.
TODO Configuration
This module's configuration documentation is incomplete. Complete it?
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.
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)
((php-mode . ((+php-default-docker-container . "php-octane"))))
Troubleshooting
"I'm missing functionality on lsp-mode"
Unfortunately, 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:
(setq lsp-intelephense-licence-key "<key>")
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
your auth-sources
has the correct values) called ~/.authinfo
:
machine * login intelephense password <key>
And add the following to your config:
(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-licence-key (my-fetch-password :user intelephense))
Frequently asked questions
This module has no FAQs yet. Ask one?
TODO Appendix
This module has no appendix yet. Write one?