rawdreeg / phpswitcher
A simple CLI tool to manage multiple PHP versions on macOS using Homebrew. Linux and Windows support planned.
Package info
github.com/rawdreeg/phpswitcher
Language:Shell
Type:project
pkg:composer/rawdreeg/phpswitcher
Requires
- php: ^8.1
- symfony/console: ^6.0|^7.0
- symfony/process: ^6.0|^7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.75
This package is auto-updated.
Last update: 2026-03-25 14:37:05 UTC
README
PHP Switcher
A simple CLI tool to manage multiple PHP versions on macOS and Linux.
Features
- Install specific PHP versions (via Homebrew for macOS, or APT for Linux).
- Uninstall PHP versions you no longer need.
- Switch the active PHP version.
- List all installed PHP versions.
- Auto-detect required version from
.php-version,composer.json, or global default. - Global default version — set a fallback PHP version used when no project-level config is found.
- Automatic version switching when you change directories (supports
.php-version,composer.json, and global default). - Status command — see active PHP version, detection source, and path info at a glance.
- Extensions management — list or install PHP extensions for any version.
- Tab completion for Bash, Zsh, and Fish.
Prerequisites
- macOS: Requires Homebrew for installing and managing PHP versions.
- Linux (Debian/Ubuntu): Requires
aptand thesoftware-properties-commonpackage.sudois required for installing and switching versions.
Installation
Run the following command in your terminal to download and execute the installation script:
# Ensure you have curl installed bash -c "$(curl -fsSL https://raw.githubusercontent.com/rawdreeg/phpswitcher/main/install.sh)"
This will install phpswitcher to $HOME/.phpswitcher and add it to your shell's profile file (e.g., .zshrc, .bashrc).
After installation, open a new terminal session or run source ~/.zshrc (or the equivalent for your shell) and verify with:
phpswitcher help
Usage
List installed PHP versions:
Shows all available PHP versions and highlights the one that is currently active.
phpswitcher list # Example Output: # # Installed PHP Versions (via Homebrew): # 7.4 # * 8.1 (active)
Install a PHP version:
If you are in a directory containing a composer.json file with a PHP requirement, you can omit the <version> argument to automatically detect and install the required X.Y version.
phpswitcher install [<version>] # Examples: phpswitcher install 8.1 phpswitcher install 7.4 # Auto-detect from composer.json in current directory: cd my-project-using-php8.0/ phpswitcher install
Uninstall a PHP version:
Remove a PHP version that is no longer needed. The currently active version cannot be uninstalled — switch to a different version first.
phpswitcher uninstall <version> # Example: phpswitcher uninstall 7.4
Switch active PHP version:
If you are in a directory containing a composer.json file with a PHP requirement (require.php or config.platform.php), you can omit the <version> argument, and phpswitcher will attempt to detect and use the appropriate X.Y version.
phpswitcher use [<version>] # Examples: phpswitcher use 8.1 # Auto-detect from composer.json in current directory: cd my-project-using-php7.4/ phpswitcher use
Set a global default PHP version:
Set a fallback version that's used when no .php-version file or composer.json is found in the directory tree:
phpswitcher default 8.2 # Show the current default: phpswitcher default # Remove the default: phpswitcher default --unset
Show status:
Display the current active PHP version, how it was detected, and path information:
phpswitcher status # Example Output: # # PHP Switcher Status # =================== # # Active PHP version: 8.1 # PHP reports version: 8.1 # PHP binary path: /usr/bin/php8.1 # Loaded php.ini: /etc/php/8.1/cli/php.ini # # Version detection for current directory: # Detected version: 8.1 # Source: .php-version (/home/user/project/.php-version) # # Global default: 8.2
Manage PHP extensions:
List installed extensions for a PHP version, or install new ones:
# List extensions for the active PHP version: phpswitcher extensions # List extensions for a specific version: phpswitcher extensions 8.1 # Install an extension (uses active version): phpswitcher extensions install xdebug # Install an extension for a specific version: phpswitcher extensions install redis 8.1
On Linux, extensions are installed via apt (e.g., php8.1-xdebug). On macOS, PECL is used.
Show Version:
phpswitcher version
Self-Update:
phpswitcher self-update
This will fetch and install the latest version of phpswitcher from GitHub.
Check active PHP version (after switching):
php --version
Automatic Version Switching
phpswitcher supports automatic version switching when you change directories. This is achieved by hooking into your shell's prompt.
How it Works
- When you
cdinto a new directory,phpswitcherlooks for a.php-versionfile in the current directory or any parent directory. - If no
.php-versionfile is found, it checks for acomposer.jsonin the current directory and reads the PHP version constraint. - If neither is found, it falls back to the global default version (if set via
phpswitcher default). - If a required version is detected and it differs from the currently active version,
phpswitcherautomatically switches to it.
Usage
To use this feature, simply create a file named .php-version in the root of your project and put the desired PHP version number in it.
# In your project's root directory echo "8.1" > .php-version
Now, whenever you cd into this directory (or any subdirectory), phpswitcher will ensure that PHP 8.1 is activated automatically.
This feature is enabled by default during the installation process, which adds a sourcing line to your shell's profile file (.bashrc, .zshrc, or Fish config).
Fish Shell Support
Fish shell is fully supported. The installer automatically detects Fish and creates a config file at ~/.config/fish/conf.d/phpswitcher.fish. Auto-switching works via Fish's --on-variable PWD event.
Tab Completion
Tab completion for commands and PHP versions is enabled automatically during installation for Bash, Zsh, and Fish. Type phpswitcher followed by Tab to see available commands, or phpswitcher use followed by Tab to see installed PHP versions.
Development
- Clone the repository:
git clone https://github.com/rawdreeg/phpswitcher.git - Navigate into the project directory:
cd phpswitcher. - The main script is
bin/phpswitcher. You can run it directly for testing:./bin/phpswitcher install 8.2
- To create a release artifact, run the build script:
./build.sh
This will create aphpswitcher.tar.gzin the root directory.
Contributing
Contributions are welcome! Please feel free to open issues or submit pull requests.
License
MIT License