Get all changed/modified files in a pull request (pull_request
or pull_request_target
) or push's commits.
You can choose to get all changed files, only added files, only modified files, only removed files, only renamed files, or all added and modified files.
These outputs are available via the steps
output context.
The steps
output context exposes the output names all
, added
, modified
, removed
, renamed
, and added_modified
.
Renamed files that are also modified are included in renamed
, modified
and added_modified
.
This project is a fork of https://github.com/jitterbit/get-changed-files, which supports pull_request_target
, allow to filter files using regular expressions, removes the ahead check and considers renamed modified files as modified.
See action.yml
- uses: Ana06/get-changed-files@v2.1.0
with:
# Format of the steps output context.
# Can be 'space-delimited', 'csv', or 'json'.
# Default: 'space-delimited'
format: ''
# Filter files using a glob filter
filter: '*'
You can filter files using regular expressions with the filter
option.
This option receives a list of patterns using GitHub Actions syntax.
You can use !
at the start of a pattern to negate previous positive patterns.
See the Get all changed *.yml
files but exclude .github/*/*.yml
files example.
If there are any files with spaces in them, then this method won't work and the step will fail. Consider using one of the other formats if that's the case.
- id: files
uses: Ana06/get-changed-files@v2.1.0
- run: |
for changed_file in ${{ steps.files.outputs.all }}; do
echo "Do something with this ${changed_file}."
done
If there are any files with spaces in them, then this method won't work and the step will fail. Consider using one of the other formats if that's the case.
- id: files
uses: Ana06/get-changed-files@v2.1.0
with:
filter: '*.php'
- run: |
for changed_file in ${{ steps.files.outputs.all }}; do
echo "Do something with this ${changed_file}."
done
Be careful that the order of the glob has an importance.
Therefore, including all YML files first and excluding the YML files of your .github/*/
directories is the way to go to exclude them.
If those two globs were inverted, you would include all the YML files, with the ones in your .github/*/
directories.
- uses: Ana06/get-changed-files@v2.1.0
with:
filter: |
*.yml
!.github/*/*.yml
- id: files
uses: Ana06/get-changed-files@v2.1.0
with:
format: 'csv'
filter: '*'
- run: |
mapfile -d ',' -t added_modified_files < <(printf '%s,' '${{ steps.files.outputs.added_modified }}')
for added_modified_file in "${added_modified_files[@]}"; do
echo "Do something with this ${added_modified_file}."
done
- id: files
uses: Ana06/get-changed-files@v2.1.0
with:
format: 'json'
filter: '*'
- run: |
readarray -t removed_files <<<"$(jq -r '.[]' <<<'${{ steps.files.outputs.removed }}')"
for removed_file in ${removed_files[@]}; do
echo "Do something with this ${removed_file}."
done
Make sure to do the following before checking in any code changes.
yarn
yarn all
The scripts and documentation in this project are released under the MIT License