A GitHub action for syntax checking fish shell files.
Here's an example from the test workflow for Pond:
This action requires fish shell. You can install it using the fish-shop/install-fish-shell action.
Add a uses
step to your GitHub workflow as shown below:
- name: Syntax check
uses: fish-shop/syntax-check@v2
By default, all files under $GITHUB_WORKSPACE
with a .fish
file extension are checked. To override the default behaviour, provide one or more space-separated pattern values to the patterns
input. For example, to check all .fish
files starting in the src
directory and descending into subdirectories:
- name: Syntax check
uses: fish-shop/syntax-check@v2
with:
patterns: src/**.fish
Each pattern value may include wildcards and/or brace expansion:
- name: Syntax check
uses: fish-shop/syntax-check@v2
with:
patterns: init.fish functions/**.fish {conf.d,completions}/**.fish tests/???-*.fish
Important
The ?
wildcard character is deprecated and can be disabled via the fish
feature flag qmark-noglob
. Support for the ?
wildcard may therefore be dependent upon the version of fish
shell in use and/or the configuration of its feature flags.
Configure the action using the following inputs:
Name | Description | Default |
---|---|---|
annotations |
The string value 'true' or 'false' indicating whether to enable annotations or not |
true |
patterns |
A space-separated list of file patterns to match against when running syntax checks; each pattern may include wildcards and/or brace expansions | **.fish |
title |
The title to display in the job summary; can be used to distinguish multiple summaries generated from a single workflow | Syntax check results |
The following outputs are made available to subsequent steps in a workflow:
Name | Description |
---|---|
total |
The total number of files syntax checked |
passed |
The number of files that passed syntax checks |
failed |
The number of files that failed syntax checks |
Syntax issues identified by this action are displayed as annotations on the workflow summary page:
Annotations are also displayed directly alongside the code in the 'Files changed' tab of pull requests:
This behaviour can be disabled by setting the annotations
input to false
.
This action generates a job summary at run-time which can be viewed from the workflow run summary page:
Use one of the following patterns when specifying the version reference for this action in your workflow (i.e. the {ref}
value in uses: fish-shop/syntax-check@{ref}
):
Pattern | Example | Description |
---|---|---|
vX |
v1 |
the latest v1.* release including non-breaking changes and bug fixes |
vX.Y |
v1.1 |
the latest v1.1.* release including bug fixes |
vX.Y.Z |
v1.1.0 |
the v1.1.0 release only |
Tip
The recommended pattern is vX
(e.g. v1
). This will ensure that the version of the action used in your workflow includes the latest non-breaking changes and bug fixes, and guarantees compatibility with previous versions of that major release number.
Using a main
branch reference in your workflow is not recommended as this branch may include breaking changes intended for the next major release.
A number of related composite actions are also available from the fish-shop 🐟. Check them out:
- fish-shop/indent-check - A GitHub action for checking indentation in fish shell files
- fish-shop/install-fish-shell - A GitHub action for installing fish shell
- fish-shop/install-plugin - A GitHub action for installing fish shell plugins
- fish-shop/install-plugin-manager - A GitHub action for installing a fish shell plugin manager
- fish-shop/run-fishtape-tests - A GitHub action for running Fishtape tests
- This project was inspired by fish-actions/syntax-check
- Fish market icon made by Freepik from www.flaticon.com
fish-shop/syntax-check
is provided under the terms of the MIT License.
Email me at marc.ransome@fidgetbox.co.uk or create an issue.
Resources
fish-shop/syntax-check is not certified by GitHub. It is provided by a third-party and is governed by separate terms of service, privacy policy, and support documentation.