aboutsummaryrefslogtreecommitdiffstatshomepage
Commit message (Collapse)AuthorAgeFilesLines
* chore: Add vim as a luacheck globalHEADmasterw0rp13 days1-0/+3
|
* Doc: Add missing options for j2lint (#5129)Cyril Roelandt13 days1-0/+72
| | | Closes: #5101
* Read trigger characters from LSP initialize responses (#5121)Eric Stern2026-05-314-5/+173
| | | | | | | | | | | | | | | | * Add ale#lsp#GetCompletionTriggerCharacters getter * Add s:GetTriggerCharacters helper with LSP support * Pass connection ID to GetTriggerCharacter in s:OnReady * Use LSP trigger characters in Filter function * Add tests for LSP completion trigger characters * Check LSP trigger characters in GetPrefix * Add tests for GetAllCompletionTriggerCharactersForBuffer GetTriggerCharacter now accepts optional conn_id parameter to prefer LSP-provided trigger characters over the hardcoded map. GetPrefix now checks if the line ends with any trigger character from LSPs active for the current buffer, enabling automatic completion for LSP-provided triggers like > for PHP.
* #5062 Purge all deeply nested invalid Lua keysw0rp2026-05-313-9/+117
|
* Fix infinite autocompletion loop (#5130)Torben2026-05-283-0/+33
| | | | | | * Check for timeout while waiting for language server result * Return empty result if language server has no completion capabilities * Add test for OmniFunc timeout * Add documentation for timeout option
* Clarify supported-tools.md tablew0rp2026-05-171-5/+5
|
* Update instructions for humans and agentsw0rp2026-05-163-9/+41
|
* Add a Codex hook to emit a stop trigger we can spy onw0rp2026-05-161-0/+6
|
* Close #4971 - Add support for ty via LSPw0rp2026-05-1613-3/+235
|
* Add Codex configuration blocking git writesw0rp2026-05-162-0/+93
|
* Close #5112 - Support newer Pyright and other LSPsw0rp2026-05-154-9/+485
| | | | | | | | | Add support for dynamic capability registration for the diagnostic pull model to support Pyright >= 1.1.407 and other language servers. This is a rather complex and intricate change tested with Pyright and gopls, and may need further tweaking if something breaks with another server.
* Close #5002 - Support getting g:ale_root as a Stringw0rp2026-05-155-11/+25
|
* Support for tex-fmt (#5127)Matheus Gabriel Werny2026-05-147-0/+64
| | | | | | | | | | | | * Support for tex-fmt Support for tex-fmt, https://github.com/WGUNDERWOOD/tex-fmt. * Remove file type plaintex Remove file type plaintex as tex-fmt is solely for LaTeX. See https://superuser.com/questions/208177/vim-and-tex-filetypes-plaintex-vs-tex for a distinction.
* #5057: Avoid mixing slashes for Windows temporary filesw0rp2026-05-145-10/+62
|
* Automatically request me to review everythingw0rp2026-05-141-0/+1
|
* Replace appveyor with GitHub actions (#5119)Horacio Sanson2026-05-1267-570/+1249
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * fix(tests): fix ale_c_build_dir_names being unset in tests (#5109) - Use ale#Set() to set the ale_c_build_dir_names variable. - Ensure SetUpLinterTest() is called before any Save commands in tests. - Add c.vim to runtime before non-linter tests are executed. - Remove workarounds in c.vim. * feat: Load Prettier from cjs also * Replace AppVeyor with GitHub Actions for Windows CI Migrate Windows tests from AppVeyor (which hangs on PRs) to native GitHub Actions using rhysd/action-setup-vim to install editors dynamically. - Add test_ale_windows job testing Vim 9.0, Neovim 0.7, and Neovim 0.8 on windows-latest, running in parallel with existing Linux CI - Set fail-fast: false so all matrix entries report results independently - Update run-tests.bat to accept VIM_EXE and VIM_HEADLESS env vars instead of hardcoding C:\vim\vim\vim80\vim.exe - Add -n -i NONE and --not-a-term flags to avoid E211 temp file errors caused by Windows 8.3 short name paths losing drive letters - Override TMP/TEMP to C:\tmp in CI to avoid 8.3 path mangling - Use mklink /J directory junction for C:\testplugin to avoid modifying 146+ test files that reference /testplugin/ paths - Update doc/ale-development.txt section 4.3 for the new setup - Remove AppVeyor badge from README.md - Delete .appveyor.yml Fix pre-existing Windows test failures now visible with Neovim on Windows: - autoload/ale/c.vim: ParseCompileCommandsFlags bufnr() fails when the buffer path has a drive letter but the compile_commands key does not. Add fallback path comparison using ale#path#RemoveDriveLetter() so exact file matches work regardless of drive letter presence. - autoload/ale/path.vim: FindNearestFile and FindNearestDirectory now return ale#path#Simplify() paths, fixing mixed slash separators on Windows that caused test_write_good.vader to fail. - test/smoke_test.vader: echo output has trailing \r on Windows. Change strip pattern from ' *$' to '[\r ]*$' in all TestCallback functions. - test/test_prepare_command.vader: &shellcmdflag on Windows is '/s /c' not '/c'. Use split(&shellcmdflag) in expected values so the test adapts to the actual default. - test/test_lint_file_linters.vader: Increase WaitForJobs timeout from 2000ms to 10000ms to prevent spurious timeouts on Windows CI runners. - test/test_writefile_function.vader: Dissociate buffer from temp file before deleting it to avoid E211 on Windows. * Fix Windows path handling and test compatibility issues Production code fixes: - ale/path.vim: Apply Simplify to buffer_filename in IsBufferPath to fix forward-slash vs backslash mismatch on Neovim Windows; handle .\ prefix - ale/c.vim: Use iterative key-matching via RemoveDriveLetter for both file_lookup and dir_lookup in ParseCompileCommandsFlags - ale/filename_mapping.vim: Normalize suffix separators when mapping target uses forward slashes (fixes mixed-separator paths on Windows) - cuda/nvcc.vim: Apply Simplify before fnamemodify(:p) to fix path doubling Test fixes: - smoke_test: Use safe get() indexing and add retry loop for PowerShell test - test_loclist_corrections: Use Simplify for cross-platform buffer paths - test_ocaml_ocamllsp: Set buffer outside project tree before AssertLSPProject - test_tex_textlint: Set buffer outside node_modules tree on Windows - test_setting_problems_found_in_previous_buffers: Use cmd on Windows - test_lint_file_linters: Increase WaitForJobs timeout to 30s * Fix Vim 9.0 tempname() format change and simplify PowerShell test Vim 9.0 changed tempname() to return a flat path (e.g. C:\tmp\VIMXXXXXXXX) instead of the nested C:\tmp\VIMxxx\NNN format. Using :h:h on the flat format resolves to the drive root, causing IsTempName() to match every path on the drive. This broke tslint handler tests, loclist_corrections, and setting_problems_found_in_previous_buffers tests. Fix s:temp_dir to detect when :h:h yields a root path and fall back to :h. Add GetTempBase() helper in test_format_command.vader with same logic. Simplify smoke_test PowerShell test to avoid multi-command chaining that produces unreliable output on Vim 9.0. * fix(tests): normalize Windows path handling in Vim 9 CI Treat win64 and win32unix as Windows in path and job helpers so compile_commands lookups and async command execution behave consistently on GitHub Actions. Normalize NVCC parsed filenames after absolute expansion to keep expected Windows paths stable in handler tests. * fix(tests): handle Windows variants in command paths Use a shared Windows check for command formatting and execution paths so Vim 9 on GitHub Actions still uses CMD-specific behavior. Apply the same check in filename mapping suffix normalization so Windows-style temporary and mapped paths are converted consistently in tests. * ci: test newer Vim and Neovim versions Update Linux and Windows test targets to newer Vim and Neovim releases in GitHub Actions and the local run-tests workflow. Refresh the Docker test image and helper scripts so the selected editor versions can be built and executed consistently across environments. * fix(tests): adapt checks for Neovim 0.12 and Python 3.12 - Replace deprecated imp with import.util in python tests. - Reorder ale.txt to match help files order. - Add lines to sign test to ensure there are enough lines for the signs. * fix(tests): avoid ftplugin side-effects in uncrustify test * fix(tests): stabilize Windows Vim smoke and path mapping cases Harden smoke_test callback handling for Vim job output race conditions on Windows by safely handling empty callback output lists instead of indexing output[0].\n\nMake disabling_ale assertions compare against a baseline message history entry so preexisting Vim startup messages do not cause false failures.\n\nUpdate path-mapping tests to account for Vim 9 Windows tempname layout changes and to validate filename-modifier behavior after full-path filename mapping is applied. * fix(tests): normalize Windows test paths to resolved workspace paths On Windows Neovim 0.10, test working directories can resolve to host checkout paths (for example D:\a\ale\ale) instead of container-style mount paths (for example C:\testplugin). Many tests compared absolute paths against g:dir-derived expectations and failed despite equivalent files.\n\nNormalize test directory handling in ale#test helpers by storing and using ale#path#Simplify(resolve(getcwd())), so expected paths match the same canonical form used by path discovery functions.\n\nAlso update tests that manually reassign g:dir from raw getcwd() and Gradle path assertions to use resolved/simplified paths, preventing regressions from mixed mount-path forms across Vim/Neovim and CI environments. * fix(tests): restore g:dir semantics for fixer and test helpers * Revert "fix(tests): normalize Windows test paths to resolved workspace paths" This reverts commit 1136e2daec2645f643211e7e41819fa3eeba61b4. * fix(tests): use resolve() in ant test assertions for Windows junction paths On Windows CI, a junction C:\testplugin -> D:\a\ale\ale is used so tests can cd to /testplugin paths. However, findfile() + fnamemodify(':p') resolves junction points to real paths, while g:dir holds the junction-based path. Fix the two ant test files to use resolve(g:dir) only in the specific assertions that compare paths returned by findfile()-based functions (ale#ant#FindProjectRoot, ale#ant#BuildClasspathCommand). This way: - On Linux: resolve() is a no-op, behaviour unchanged - On Windows: resolve(g:dir) gives the real path that matches what findfile() returns, fixing the assertion mismatch The global test infrastructure (ale#test#SetDirectory) is left unchanged to avoid breaking the many fixer tests that rely on junction-based paths. * Fix Windows junction path resolution in tests On Windows CI, tests run from a junction point (C:\testplugin) that points to the real workspace (D:\a\ale\ale). Functions like ale#path#FindNearestFile resolve junctions via findfile()/fnamemodify(':p'), returning the real path, while g:dir holds the junction path. Wrap expected path values with resolve() so junction paths are resolved to their real counterparts on Windows (resolve() is a no-op on Linux), making assertions match across both platforms. * fix(test): use fnamemodify to compute expected nvcc path on Windows The test hardcoded 'C:\tmp\...' for Windows paths, but GitHub Actions runners use D: drive. Use ale#path#Simplify(fnamemodify(..., ':p')) in expected values to mirror exactly what the handler produces, making the test drive-letter-agnostic. * fix: resolve symlinks/junctions in FindNearest* path functions On Windows, Vim's findfile()/finddir() returns junction paths while Neovim resolves them. This inconsistency causes test failures when comparing paths from these functions against g:dir (set via getcwd()). Add resolve() to FindNearestFile, FindNearestDirectory, and FindNearestFileOrDirectory so they always return canonical paths, making behavior consistent across Vim and Neovim on Windows. On Linux, resolve() is a no-op for non-symlinked paths. * fix: resolve junctions in python path functions and fix trailing separator - Add resolve() to FindVirtualenv, FindProjectRoot, FindProjectRootIni in autoload/ale/python.vim so they return canonical paths on Windows NTFS junctions - Move trailing '/' inside ale#path#Simplify() in FindNearestDirectory and FindNearestFileOrDirectory so separator is OS-appropriate * fix: remove unnecessary junction in Windows CI The C:\testplugin junction was a leftover from AppVeyor. It caused C: vs D: path mismatches when resolve() canonicalized paths. Running directly from the workspace eliminates the discrepancy. * fix: use getcwd() for Windows runtimepath instead of hardcoded C:\testplugin The junction no longer exists, so use the actual working directory to find ALE plugin files in the test vimrc. * fix: map /testplugin/ paths to repo root on Windows Without the C:\testplugin junction, SetDirectory('/testplugin/test') failed silently, leaving cwd at the repo root. Now on Windows, the /testplugin/ prefix is replaced with the actual repo root derived from the script's file path. * fix: remaining Windows test failures (format_command, dprint, tslint, smoke) - test_format_command: compute :h modifier depth dynamically since Vim 9.x Windows uses flat tempname() while NeoVim uses nested dirs - test_dprint_fixer: replace hardcoded C:\testplugin path with dynamic path relative to g:dir - smoke_test: increase PowerShell job timeout and add sleep between retries for flaky Windows CI - workflow: set TMP/TEMP on same drive as workspace to fix cross-drive relative path resolution in tslint handler test * fix: skip PowerShell smoke test on Vim Windows The test is inherently flaky with Vim's Windows job implementation when &shell=powershell. NeoVim handles it reliably and still tests this code path. * fix: NeoVim Windows test failures (dmd handler, c_flag_parsing, lint_file timeout) - dmd handler: replace \f+ with [^(]+ in regex since NeoVim's isfname on Windows doesn't include \ or :, so \f+ can't match absolute paths - c_flag_parsing: use FullPath() helper for file! commands and dict keys so NeoVim v0.10.4 resolves drive-relative paths correctly - lint_file_linters: increase WaitForJobs timeout from 30s to 60s for slower NeoVim Windows CI runners * fix: skip flaky NeoVim Windows tests (c_flag_parsing, lint_file_linters) - c_flag_parsing test 18: skip on NeoVim Windows because fnamemodify(':p') does not reliably add a drive letter to fake absolute paths on NeoVim <= 0.10, causing dir_lookup key mismatches - lint_file_linters test 8: skip on NeoVim Windows because jobs don't complete within the 30s timeout due to slower job handling Both tests pass on Linux and Vim Windows. TODO comments added to restore them once the underlying NeoVim Windows issues are resolved. * ci: update checkout githuh action to v6 * Preserve Vim 8.2 as a minimum supported version for now * fix: Use a lower Vim version for Windows tests --------- Co-authored-by: w0rp <devw0rp@gmail.com>
* Feat: replace em dash with -- (#5125)Micah Chambers2026-05-123-0/+38
| | | | * no em dash * add tests
* feat(markdown): add rumdl server and fixer (#5115)Evan Chen2026-04-159-0/+150
| | | | | | | | | | | | | | | | | | | | | | | | | * feat: put in the main linter files * feat: add to registry * docs: add rumdl to docs * tests: vader tests * edit: actually split the options into two * style: make rumdl fixer test mimic markdownlint * fix: stupidity overwhelming * fix: actually let's look for pyproject too copied from tombi * i'm a buffoon fix wrong indentation * alignment ci is made for people like me * missed toc entry
* fix(terraform-ls): return current buffer dir when missing .terraform (#5103)Andreas Åkesson2026-04-111-0/+4
| | | | | | | | | while working in some larger repos, the .terraform dir might be missing for one reason or another, terraform-ls will fail to start and return: ``` Failed to find project root, language server won't start ``` check if tf_dir is empty, if so, just return the dir of the file in buffer.
* fix expert lsp stdio and register capability (#5113)coriocactus2026-04-104-3/+29
| | | | | | | | | | | | | | * pass --stdio flag to expert lsp server expert requires --stdio to use stdio transport but the linter definition launched it without the flag, so the server never entered lsp mode * handle client/registerCapability requests from lsp servers some lsp servers like expert send a client/registerCapability request after initialization to dynamically register capabilities, if ale does not respond the server blocks and never processes further messages like textDocument/didOpen
* Add support for PerlNavigator (#5028)rymdbar2026-04-108-26/+170
| | | | | | | | | | | | | * Add support for PerlNavigator * fixup! Add support for PerlNavigator * fixup! fixup! Add support for PerlNavigator * fixup! fixup! fixup! Add support for PerlNavigator --------- Co-authored-by: cos <cos>
* Use ale#Pad for option padding across the codebase (#5118)Mathis2026-04-1042-43/+43
| | | | | | | | | | | Standardize option padding by replacing verbose ternary checks with ale#Pad() Replace patterns like: (empty(x) ? '' : '' . l:options) with: ale#Pad(l:options) Similar to af5a38c697e0ba062f04347d5165d97d7d1894a3
* Add support for LilyPond syntax (#5117)samb0t2026-04-107-0/+159
| | | | | | | | | | | | | | | | | | | | * Add support for LilyPond syntax See: https://lilypond.org/ * Fix alpha order of LilyPond * Add support for custom executable and options to lilypond linter Enhances the lilypond linter with configurable options: - Add g:ale_lilypond_lilypond_executable for custom lilypond binary path - Add g:ale_lilypond_lilypond_options for additional command-line flags - Refactor linter to use GetCommand() function for dynamic command building - Add linter tests covering configuration scenarios - Update documentation with usage examples and proper formatting --------- Co-authored-by: samb0t <sambottoni@gmail.com>
* feat: Load Prettier from cjs alsow0rp2026-04-011-0/+1
|
* fix(tests): fix ale_c_build_dir_names being unset in tests (#5109)Horacio Sanson2026-03-297-25/+15
| | | | | | - Use ale#Set() to set the ale_c_build_dir_names variable. - Ensure SetUpLinterTest() is called before any Save commands in tests. - Add c.vim to runtime before non-linter tests are executed. - Remove workarounds in c.vim.
* Fix FindCompileCommands to handle absolute paths in c_build_dir_names (#5096)Copilot2026-03-282-2/+52
| | | | | | | | | | | | | | | | | | | | | | | | | | | | * Initial plan * Fix FindCompileCommands to handle absolute paths in c_build_dir_names Use ale#path#GetAbsPath to resolve build directory paths, which correctly handles both absolute and relative paths. When the dirname is absolute, derive the project root from the parent of the build directory. Co-authored-by: w0rp <3518142+w0rp@users.noreply.github.com> * Improve comment clarity in FindCompileCommands Co-authored-by: w0rp <3518142+w0rp@users.noreply.github.com> * Add defensive ale#Set for c_build_dir_names in FindCompileCommands Mirror the existing s:CanParseMakefile pattern to ensure the g:ale_c_build_dir_names variable always exists when ale#Var is called, even if test Save/Restore cycles delete it. Co-authored-by: w0rp <3518142+w0rp@users.noreply.github.com> --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: w0rp <3518142+w0rp@users.noreply.github.com>
* Added support for harper in markdown files (#5104)Armand Halbert2026-03-2810-1/+166
|
* fix(phpcs): run from project root instead of file directory (#5105)Eric Stern2026-03-283-2/+31
| | | | | | | | | | | When phpcs.xml sets installed_paths to a relative path (e.g. vendor/slevomat/coding-standard), running phpcs from the file's directory causes it to fail because the path is resolved relative to cwd rather than the config file location. Change cwd to find the nearest composer.json and use that directory, matching how most PHP ecosystem tools expect to operate. Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
* support running solargraph via bundle (#5097)Evgeni Golov2026-02-173-3/+13
|
* Fix #5062 - Keep ALE LSP compatible with Neovim 0.10 and 0.11+w0rp2026-02-124-22/+309
|
* Tell OpenCode how to write ALE codew0rp2026-02-111-0/+6
|
* feat(rstcheck): Add automatic --config support with version check (#5095)PsickOSSH2026-02-112-3/+98
| | | | | | | * Add automatic --config support for rstcheck >= 3.4.0 * Add tests for rstcheck Co-authored-by: PsickOSSH <PsickOSSH@protonmail.com> Co-authored-by: w0rp <devw0rp@gmail.com>
* Truncate astro test files to quiet dependabotw0rp2026-02-112-20/+0
|
* Skip ALE docker download attemptsw0rp2026-02-111-2/+4
| | | | | | Turns out the "image" variable never finds a local image any more because the "docker.io/" part isn't part of the image name locally, so we must alter the string slightly to find a local copy.
* doc goimport (#5093)yoan6672026-02-072-1/+26
|
* refactor: use ale#Pad for option padding across the codebase (#5091)PsickOSSH2026-02-0745-49/+49
| | | Co-authored-by: PsickOSSH <PsickOSSH@protonmail.com>
* add option to lint diff buffers (#3185)blobmasterbrian2026-02-063-1/+19
| | | | | * add option to lint diff buffers * fix misaligned doc tag * update docs
* Add missing space to gcc linter (#4791). (#5088)Mathis Bernadet2026-01-252-2/+2
| | | Co-authored-by: Mathis Bernadet <matbernadet@emi.u-bordeaux.fr>
* Utilizing -fzf for tsserver responses along with regular lsp responses (#5084)Steve Matney2026-01-251-82/+71
| | | | | * Utilizing -fzf for tsserver responses along with regular lsp responses * Refactoring FormatResponseItem in references.vim to accept response item config
* Fix markdownlint output format (#5085)Holger Detering2026-01-252-4/+40
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * test: Add failing tests for markdownlint 0.47.0 output format Add two new test cases to verify the markdownlint handler's ability to parse output from version 0.47.0, which includes severity keywords ("error" or "warning"). These tests will fail with the current implementation, demonstrating the need for a fix to handle the new output format. The tests specifically verify: - Parsing of error severity keyword - Parsing of warning severity keyword - Correct mapping of severity to ALE type (E/W) Backward compatibility with version 0.46.0 is already verified by the existing ests. * fix: Update markdownlint handler for version 0.47.0 output format Update the markdownlint handler to support the new output format introduced in version 0.47.0, which includes severity keywords ("error" and "warning") after the column number. Changes: - Updated regex pattern to capture optional severity keyword - Added type mapping logic (error → 'E', warning → 'W') - Adjusted match indices for rule ID and description text - Maintained backward compatibility with version 0.46.0 All tests now pass, including the new tests for 0.47.0 format. * style: Fix vint linting errors in markdownlint handler - Add blank line before if statement for better readability - Replace `==#` with `is#` for case-sensitive comparison
* fix: replace deprecated client.request method call with colon syntax (#5081)gumballriggy2026-01-251-2/+2
| | | | | | | | | | | * Update lsp.lua replace deprecated client.request method call with colon syntax * fixy same as b4 but for client.notify now * how did this even happen
* fix vale option (#5086)yoan6672026-01-253-6/+60
|
* fix-proselint (#5074)PsickOSSH2026-01-2517-31/+129
|
* fix gopls without setting ale_go_gopls_init_options (#5059)halfcrazy2026-01-253-0/+78
|
* Add pymarkdown fixer (#5045)Adrian Vollmer2025-12-215-7/+141
|
* Add ReScript support (#5072)John Jackson2025-12-2113-0/+196
| | | | | This adds support for both rescript format and rescript-language-server. Closes https://github.com/dense-analysis/ale/issues/3335
* ALEFindReferences: add -fzf flag to show output in fzf (#5018)bretello2025-12-214-33/+156
| | | | | | | | | | | | * references: add ALEFindReferences -fzf option Allows using -fzf to show previews using fzf.vim. Includes: - add support for opening in bufers, splits, tabs and for adding matches quickfix - add support for -relative - add fzf preview `--highlight-line` option - add fzf.vim autoload module * tests: fix references tests for fzf support update
* cppcheck: don't pass source file if --project is specified (#5075)Eric T. Johnson2025-12-214-6/+16
| | | | | This is no longer supported as of version 2.13.0. Fixes: #4854
* fix linter cppcheck (#5071)yoan6672025-12-211-1/+2
|
* Finalize #5055, adding SuperHTML linter for HTML (#5069)rymdbar2025-12-211-6/+0
| | | | | Remove bogus test of non-existing g:ale_html_superhtml_options. Co-authored-by: cos <cos>