Maho Intelligence LSP integration for Visual Studio Code.
Provides code completion, hover information, go-to-definition, and diagnostics for Maho's class alias system across PHP and XML files.
- Maho 26.5 or later
- PHP available on your PATH (or configured via settings)
- Install the extension:
- VSCodium: Install from Open VSX Registry
- VS Code: Marketplace listing is work in progress
- Manual install: Download the
.vsixfile from the latest release, then runcode --install-extension maho-*.vsix(orcodium --install-extension maho-*.vsixfor VSCodium)
- Open a Maho project — the extension activates automatically when it detects a
mahofile in the workspace root
By default, the extension uses php from your PATH and the maho CLI in the workspace root. You can override the PHP command in VS Code settings via maho.phpCommand:
{
"maho.phpCommand": "/usr/local/bin/php8.3"
}{
"maho.phpCommand": "docker exec mycontainer php"
}All features work across both PHP and XML files.
Suggests aliases and paths as you type (triggered by ' and " characters).
PHP contexts:
| Call | Example |
|---|---|
| Model aliases | Mage::getModel('catalog/product') |
| Model aliases | Mage::getSingleton('catalog/product') |
| Resource model aliases | Mage::getResourceModel('catalog/product') |
| Resource model aliases | Mage::getResourceSingleton('catalog/product') |
| Helper aliases | Mage::helper('catalog') |
| Block aliases | $layout->createBlock('catalog/product_list') |
| Block aliases | $layout->getBlockSingleton('catalog/product_list') |
| Config paths | Mage::getStoreConfig('web/secure/base_url') |
| Config paths | Mage::getStoreConfigFlag('web/secure/use_in_frontend') |
| Event names | Mage::dispatchEvent('catalog_product_save_after') |
XML contexts:
Completion is context-aware based on XML tag and ancestry:
<class>tags — model alias or FQCN depending on parent path (observers, rewrites, class prefixes, etc.)<source_model>,<backend_model>— model aliases<frontend_model>,<render>,<renderer>— block aliases<block type="...">attribute — block aliases<template>tag andtemplateattribute — template paths<model>inside cron jobs — model alias with method callback (e.g.catalog/product_action::run)ifconfigattribute — config pathshandleattribute — layout handles
Shows context-sensitive documentation at cursor position.
- Class aliases (model, helper, block, resource model) — resolved PHP class name, file path, and rewrite info if applicable
- Event names — all registered observers grouped by area (frontend, admin), with class, method, and observer name
- Config paths — field label, section/group hierarchy, type, and default value
- Fully qualified class names in XML — class name and file location
- XML methods — method name, parent class, and method signature extracted from source
- Cron callbacks — model alias, method, class details, and method signature
- Template paths — resolved file location in theme directories
- Layout handles — handle name, defining file, and block count
Jumps to the source file for:
- Class aliases (model, helper, block, resource model) → class file
- Fully qualified class names in XML → class file
- XML methods → method line in the class file
- Cron callbacks → class file or method line
- Template paths → template file in the design directory
Reports unresolved aliases as warnings (source: maho-intelligence). Diagnostics run automatically with a 0.3s debounce on document changes.
PHP — detects unresolved aliases in all Mage::getModel(), Mage::getSingleton(), Mage::helper(), Mage::getResourceModel(), Mage::getResourceSingleton(), ->createBlock(), and ->getBlockSingleton() calls.
XML — detects unresolved aliases in <class>, <source_model>, <backend_model>, <frontend_model>, <render>, <renderer>, <block type="...">, and <model> (cron callback) contexts.
MIT