 Tonye Jack
		
	
	
		a351a301d2
			Tonye Jack
		
	
	
		a351a301d2
		
			changed-files
Effortlessly track all changed files and directories relative to a target branch, preceding commit or the last remote commit returning relative paths from the project root using this GitHub action.
Table of contents
- Features 🚀
- Usage 💻
- Useful Acronyms 🧮
- Outputs 📤
- Inputs ⚙️
- Versioning 🏷️
- Examples 📄
- Real-world usage 🌐
- Known Limitation ⚠️
- Migration guide 🔄
- Credits 👏
- Report Bugs 🐛
- Contributors ✨
Features 🚀
- Fast execution, averaging 0-10 seconds.
- Leverages either Github's REST API or Git's native diff to determine changed files.
- Facilitates easy debugging.
- Scales to handle large repositories.
- Supports Git submodules.
- Supports merge queues for pull requests.
- Generates escaped JSON output for running matrix jobs based on changed files.
- Lists changed directories.
- Limits matching changed directories to a specified maximum depth.
- Optionally excludes the current directory.
 
- Writes outputs to a designated .txtor.jsonfile for further processing.
- Restores deleted files to their previous location or a newly specified location.
- Supports Monorepos by fetching a fixed number of commits.
- Compatible with all platforms (Linux, MacOS, Windows).
- Supports GitHub-hosted runners.
- Supports GitHub Enterprise Server.
- Supports self-hosted runners.
- Lists all files and directories that have changed:
- Between the current pull request branch and the last commit on the target branch.
- Between the last commit and the current pushed change.
- Between the last remote branch commit and the current HEAD.
 
- Restricts change detection to a subset of files and directories:
- Provides boolean output indicating changes in specific files.
- Uses Glob pattern matching.
- Supports Globstar.
- Supports brace expansion.
- Supports negation.
 
- Uses YAML syntax for specifying patterns.
- Supports YAML anchors & aliases.
- Supports YAML multi-line strings.
 
 
And many more...
Usage 💻
Warning
- For
pushevents: When configuringactions/checkout, make sure to setfetch-depthto either0or2, depending on your use case.- For mono repositories where pulling all branch history might not be desired, you can still use the default
fetch-depth, which is set to1forpull_requestevents.- Avoid using single or double quotes for multiline inputs, as the value is already a string separated by a newline character. See Examples for more information.
- If
fetch-depthisn't set to0, ensure thatpersist-credentialsis set totruewhen configuringactions/checkout.- For repositories that have PRs generated from forks, when configuring
actions/checkout, set therepositoryto${{ github.event.pull_request.head.repo.full_name }}. See Example.
Visit the discussions for more information or create a new discussion for usage-related questions.
On pull_request 🔀
Detect changes to all files in a Pull request relative to the target branch or since the last pushed commit.
Using local .git history 📁
name: CI
on:
  pull_request:
    branches:
      - main
jobs:
  # ------------------------------------------------------------------------------------------------------------------------------------------------
  # Event `pull_request`: Compare the last commit of the main branch or last remote commit of the PR branch -> to the current commit of a PR branch.
  # ------------------------------------------------------------------------------------------------------------------------------------------------
  changed_files:
    runs-on: ubuntu-latest  # windows-latest || macos-latest
    name: Test changed-files
    steps:
      - uses: actions/checkout@v4
        with:
          fetch-depth: 0  # OR "2" -> To retrieve the preceding commit.
      # Example 1
      - name: Get all test, doc and src files that have changed
        id: changed-files-yaml
        uses: tj-actions/changed-files@v39
        with:
          files_yaml: |
            doc:
              - '**/*.md'
              - docs/**
              - README.md
            test:
              - test/**
              - '!test/**.md'
            src:
              - src/**
          # Optionally set `files_yaml_from_source_file` to read the YAML from a file. e.g `files_yaml_from_source_file: .github/changed-files.yml`
      - name: Run step if test file(s) change
        # NOTE: Ensure all outputs are prefixed by the same key used above e.g. `test_(...)` | `doc_(...)` | `src_(...)` when trying to access the `any_changed` output.
        if: steps.changed-files-yaml.outputs.test_any_changed == 'true'  
        run: |
          echo "One or more test file(s) has changed."
          echo "List all the files that have changed: ${{ steps.changed-files-yaml.outputs.test_all_changed_files }}"
      
      - name: Run step if doc file(s) change
        if: steps.changed-files-yaml.outputs.doc_any_changed == 'true'
        run: |
          echo "One or more doc file(s) has changed."
          echo "List all the files that have changed: ${{ steps.changed-files-yaml.outputs.doc_all_changed_files }}"
      # Example 2
      - name: Get changed files
        id: changed-files
        uses: tj-actions/changed-files@v39
        
        # To compare changes between the current commit and the last pushed remote commit set `since_last_remote_commit: true`. e.g
        # with:
        #   since_last_remote_commit: true 
      - name: List all changed files
        run: |
          for file in ${{ steps.changed-files.outputs.all_changed_files }}; do
            echo "$file was changed"
          done
      # Example 3
      - name: Get changed files in the docs folder
        id: changed-files-specific
        uses: tj-actions/changed-files@v39
        with:
          files: docs/*.{js,html}  # Alternatively using: `docs/**` or `docs`
          files_ignore: docs/static.js
      - name: Run step if any file(s) in the docs folder change
        if: steps.changed-files-specific.outputs.any_changed == 'true'
        run: |
          echo "One or more files in the docs folder has changed."
          echo "List all the files that have changed: ${{ steps.changed-files-specific.outputs.all_changed_files }}"
Using Github's API :octocat:
name: CI
on:
  pull_request:
    branches:
      - main
jobs:
  # -------------------------------------------------------------
  # Event `pull_request`: Returns all changed pull request files.
  # --------------------------------------------------------------
  changed_files:
    # NOTE:
    # - This is limited to pull_request* events and would raise an error for other events.
    # - A maximum of 3000 files can be returned.
    # - For more flexibility and no limitations see "Using local .git history" above.
    runs-on: ubuntu-latest  # windows-latest || macos-latest
    name: Test changed-files
    permissions:
      pull-requests: read
    steps:
      - name: Get changed files
        id: changed-files
        uses: tj-actions/changed-files@v39
      - name: List all changed files
        run: |
          for file in ${{ steps.changed-files.outputs.all_changed_files }}; do
            echo "$file was changed"
          done
On push ⬆️
Detect changes to files made since the last pushed commit.
name: CI
on:
  push:
    branches:
      - main
# -------------------------------
#  Optionally run on other events
# -------------------------------
#  schedule:
#     - cron: '0 0 * * *'
#
#  release:
#    types: [...]
#
#  workflow_dispatch:
#
#  push:
#    tags:
#      - '**'
#
#  merge_group:
#
# ...and many more
jobs:
  # -------------------------------------------------------------
  # Using GitHub's API is not supported for push events
  # -------------------------------------------------------------
  # 
  # ----------------------------------------------------------------------------------------------
  # Using local .git history
  # ----------------------------------------------------------------------------------------------
  # Event `push`: Compare the preceding remote commit -> to the current commit of the main branch 
  # ----------------------------------------------------------------------------------------------
  changed_files:
    runs-on: ubuntu-latest  # windows-latest || macos-latest
    name: Test changed-files
    steps:
      - uses: actions/checkout@v4
        with:
          fetch-depth: 0  # OR "2" -> To retrieve the preceding commit.
      - name: Get changed files
        id: changed-files
        uses: tj-actions/changed-files@v39
      # NOTE: `since_last_remote_commit: true` is implied by default and falls back to the previous local commit.
      - name: List all changed files
        run: |
          for file in ${{ steps.changed-files.outputs.all_changed_files }}; do
            echo "$file was changed"
          done
      ...
To access more examples, navigate to the Examples section.
If you feel generous and want to show some extra appreciation:
Support this project with a ⭐
Useful Acronyms 🧮
| Acronym | Meaning | 
|---|---|
| A | Added | 
| C | Copied | 
| M | Modified | 
| D | Deleted | 
| R | Renamed | 
| T | Type changed | 
| U | Unmerged | 
| X | Unknown | 
Warning
- When using
files_yaml*inputs ensure all outputs are prefixed by the keytest_{...}e.g.test_added_files,test_any_changed- All keys must start with a letter or _ and contain only alphanumeric characters, -, or _.
Outputs 📤
| OUTPUT | TYPE | DESCRIPTION | 
|---|---|---|
| added_files | string | Returns only files that are Added (A). | 
| added_files_count | string | Returns the number of added_files | 
| all_changed_and_modified_files | string | Returns all changed and modified files i.e. a combination of (ACMRDTUX) | 
| all_changed_and_modified_files_count | string | Returns the number of all_changed_and_modified_files | 
| all_changed_files | string | Returns all changed files i.e. a combination of all added, copied, modified and renamed files (ACMR) | 
| all_changed_files_count | string | Returns the number of all_changed_files | 
| all_modified_files | string | Returns all changed files i.e. a combination of all added, copied, modified, renamed and deleted files (ACMRD). | 
| all_modified_files_count | string | Returns the number of all_modified_files | 
| all_old_new_renamed_files | string | Returns only files that are Renamed and lists their old and new names. NOTE: This requires setting include_all_old_new_renamed_filestotrue.Also, keep in mind that this output is global and wouldn't be nested in outputs generated when the *_yaml_*inputis used. (R) | 
| all_old_new_renamed_files_count | string | Returns the number of all_old_new_renamed_files | 
| any_changed | string | Returns truewhen any ofthe filenames provided using the files*orfiles_ignore*inputs has changed. i.e.includes a combination of all added, copied, modified and renamed files (ACMR). | 
| any_deleted | string | Returns truewhen any ofthe filenames provided using the files*orfiles_ignore*inputs has been deleted.(D) | 
| any_modified | string | Returns truewhen any ofthe filenames provided using the files*orfiles_ignore*inputs has been modified.i.e. includes a combination of all added, copied, modified, renamed, and deleted files (ACMRD). | 
| changed_keys | string | Returns all changed YAML keys when the files_yamlinput isused. i.e. key that contains any path that has either been added, copied, modified, and renamed (ACMR) | 
| copied_files | string | Returns only files that are Copied (C). | 
| copied_files_count | string | Returns the number of copied_files | 
| deleted_files | string | Returns only files that are Deleted (D). | 
| deleted_files_count | string | Returns the number of deleted_files | 
| modified_files | string | Returns only files that are Modified (M). | 
| modified_files_count | string | Returns the number of modified_files | 
| modified_keys | string | Returns all modified YAML keys when the files_yamlinput isused. i.e. key that contains any path that has either been added, copied, modified, and deleted (ACMRD) | 
| only_changed | string | Returns truewhen only filesprovided using the files*orfiles_ignore*inputshas changed. i.e. includes a combination of all added, copied, modified and renamed files (ACMR). | 
| only_deleted | string | Returns truewhen only filesprovided using the files*orfiles_ignore*inputshas been deleted. (D) | 
| only_modified | string | Returns truewhen only filesprovided using the files*orfiles_ignore*inputshas been modified. (ACMRD). | 
| other_changed_files | string | Returns all other changed files not listed in the files input i.e. includes a combination of all added, copied, modified and renamed files (ACMR). | 
| other_changed_files_count | string | Returns the number of other_changed_files | 
| other_deleted_files | string | Returns all other deleted files not listed in the files input i.e. a combination of all deleted files (D) | 
| other_deleted_files_count | string | Returns the number of other_deleted_files | 
| other_modified_files | string | Returns all other modified files not listed in the files input i.e. a combination of all added, copied, modified, and deleted files (ACMRD) | 
| other_modified_files_count | string | Returns the number of other_modified_files | 
| renamed_files | string | Returns only files that are Renamed (R). | 
| renamed_files_count | string | Returns the number of renamed_files | 
| type_changed_files | string | Returns only files that have their file type changed (T). | 
| type_changed_files_count | string | Returns the number of type_changed_files | 
| unknown_files | string | Returns only files that are Unknown (X). | 
| unknown_files_count | string | Returns the number of unknown_files | 
| unmerged_files | string | Returns only files that are Unmerged (U). | 
| unmerged_files_count | string | Returns the number of unmerged_files | 
Inputs ⚙️
| INPUT | TYPE | REQUIRED | DEFAULT | DESCRIPTION | 
|---|---|---|---|---|
| api_url | string | false | "${{ github.api_url }}" | Github API URL. | 
| base_sha | string | false | Specify a different base commit SHA used for comparing changes | |
| diff_relative | string | false | "true" | Exclude changes outside the current directory and show path names relative to it. NOTE: This requires you to specify the top level directory via the pathinput. | 
| dir_names | string | false | "false" | Output unique changed directories instead of filenames. NOTE: This returns .for changed files locatedin the current working directory which defaults to $GITHUB_WORKSPACE. | 
| dir_names_exclude_current_dir | string | false | "false" | Exclude the current directory represented by .from the outputwhen dir_namesis set totrue. | 
| dir_names_include_files | string | false | Include files in the output when dir_namesis set totrue. NOTE: This returns onlythe matching files and also the directory names. | |
| dir_names_include_files_separator | string | false | "\n" | Separator used to split the dir_names_include_filesinput | 
| dir_names_max_depth | string | false | Limit the directory output to a maximum depth e.g test/test1/test2with max depth of 2returns test/test1. | |
| escape_json | string | false | "true" | Escape JSON output. | 
| fail_on_initial_diff_error | string | false | "false" | Fail when the initial diff fails. | 
| fail_on_submodule_diff_error | string | false | "false" | Fail when the submodule diff fails. | 
| fetch_additional_submodule_history | string | false | "false" | Fetch additional history for submodules. | 
| fetch_depth | string | false | "50" | Depth of additional branch history fetched. NOTE: This can be adjusted to resolve errors with insufficient history. | 
| files | string | false | File and directory patterns used to detect changes (Defaults to the entire repo if unset) NOTE: Multiline file/directory patterns should not include quotes. | |
| files_from_source_file | string | false | Source file(s) used to populate the filesinput. | |
| files_from_source_file_separator | string | false | "\n" | Separator used to split the files_from_source_fileinput | 
| files_ignore | string | false | Ignore changes to these file(s) NOTE: Multiline file/directory patterns should not include quotes. | |
| files_ignore_from_source_file | string | false | Source file(s) used to populate the files_ignoreinput | |
| files_ignore_from_source_file_separator | string | false | "\n" | Separator used to split the files_ignore_from_source_fileinput | 
| files_ignore_separator | string | false | "\n" | Separator used to split the files_ignoreinput | 
| files_ignore_yaml | string | false | YAML used to define a set of file patterns to ignore changes | |
| files_ignore_yaml_from_source_file | string | false | Source file(s) used to populate the files_ignore_yamlinput. Example | |
| files_ignore_yaml_from_source_file_separator | string | false | "\n" | Separator used to split the files_ignore_yaml_from_source_fileinput | 
| files_separator | string | false | "\n" | Separator used to split the filesinput | 
| files_yaml | string | false | YAML used to define a set of file patterns to detect changes | |
| files_yaml_from_source_file | string | false | Source file(s) used to populate the files_yamlinput. Example | |
| files_yaml_from_source_file_separator | string | false | "\n" | Separator used to split the files_yaml_from_source_fileinput | 
| include_all_old_new_renamed_files | string | false | "false" | Include all_old_new_renamed_filesoutput. Note thiscan generate a large output See: #501. | 
| json | string | false | "false" | Output list of changed files in a JSON formatted string which can be used for matrix jobs. Example | 
| old_new_files_separator | string | false | " " | Split character for old and new renamed filename pairs. | 
| old_new_separator | string | false | "," | Split character for old and new filename pairs. | 
| output_dir | string | false | ".github/outputs" | Directory to store output files. | 
| output_renamed_files_as_deleted_and_added | string | false | "false" | Output renamed files as deleted and added files. | 
| path | string | false | "." | Specify a relative path under $GITHUB_WORKSPACEto locate the repository. | 
| quotepath | string | false | "true" | Use non-ascii characters to match files and output the filenames completely verbatim by setting this to false | 
| recover_deleted_files | string | false | "false" | Recover deleted files. | 
| recover_deleted_files_to_destination | string | false | Recover deleted files to a new destination directory, defaults to the original location. | |
| recover_files | string | false | File and directory patterns used to recover deleted files, defaults to the patterns provided via the files,files_from_source_file,files_ignoreandfiles_ignore_from_source_fileinputs or all deletedfiles if no patterns are provided. | |
| recover_files_ignore | string | false | File and directory patterns to ignore when recovering deleted files. | |
| recover_files_ignore_separator | string | false | "\n" | Separator used to split the recover_files_ignoreinput | 
| recover_files_separator | string | false | "\n" | Separator used to split the recover_filesinput | 
| separator | string | false | " " | Split character for output strings | 
| sha | string | false | Specify a different commit SHA used for comparing changes | |
| since | string | false | Get changed files for commits whose timestamp is older than the given time. | |
| since_last_remote_commit | string | false | "false" | Use the last commit on the remote branch as the base_sha. Defaults to the lastnon-merge commit on the target branch for pull request events and the previous remote commit of the current branch for push events. | 
| skip_initial_fetch | string | false | "false" | Skip the initial fetch to improve performance for shallow repositories. NOTE: This could lead to errors with missing history and the intended use is limited to when you've fetched the history necessary to perform the diff. | 
| token | string | false | "${{ github.token }}" | Github token used to fetch changed files from Github's API. | 
| until | string | false | Get changed files for commits whose timestamp is earlier than the given time. | |
| write_output_files | string | false | "false" | Write outputs to the output_dirdefaults to .github/outputsfolder. NOTE:This creates a .txtfileby default and a .jsonfile if jsonis setto true. | 
Versioning 🏷️
This GitHub Action follows the principles of Semantic Versioning for versioning releases.
The format of the version string is as follows:
- 
major: indicates significant changes or new features that may not be backward compatible. 
- 
minor: indicates minor changes or new features that are backward compatible. 
- 
patch: indicates bug fixes or other small changes that are backward compatible. 
Examples 📄
Get all changed files in the current branch
...
    - name: Get changed files
      id: changed-files
      uses: tj-actions/changed-files@v39
...
Get all changed files and use a comma separator
...
    - name: Get all changed files and use a comma separator in the output
      id: changed-files
      uses: tj-actions/changed-files@v39
      with:
        separator: ","
...
See inputs for more information.
Get all changed files and list all added files
...
    - name: Get changed files
      id: changed-files
      uses: tj-actions/changed-files@v39
    - name: List all added files
      run: |
        for file in ${{ steps.changed-files.outputs.added_files }}; do
          echo "$file was added"
        done
...
See outputs for a list of all available outputs.
Get all changed files and optionally run a step if a file was modified
...
    - name: Get changed files
      id: changed-files
      uses: tj-actions/changed-files@v39
    - name: Run a step if my-file.txt was modified
      if: contains(steps.changed-files.outputs.modified_files, 'my-file.txt')
      run: |
        echo "my-file.txt file has been modified."
...
See outputs for a list of all available outputs.
Get all changed files and write the outputs to a txt file
...
   - name: Get changed files and write the outputs to a Txt file
     id: changed-files-write-output-files-txt
     uses: ./
     with:
       write_output_files: true
   - name: Verify the contents of the .github/outputs/added_files.txt file
     run: |
       cat .github/outputs/added_files.txt
...
Get all changed files and write the outputs to a json file
...
   - name: Get changed files and write the outputs to a JSON file
     id: changed-files-write-output-files-json
     uses: ./
     with:
       json: true
       write_output_files: true
   - name: Verify the contents of the .github/outputs/added_files.json file
     run: |
       cat .github/outputs/added_files.json
...
Get all changed files using a list of files
...
    - name: Get changed files
      id: changed-files
      uses: tj-actions/changed-files@v39
      with:
        files: |
          my-file.txt
          *.sh
          *.png
          !*.md
          test_directory
          **/*.sql
...
See inputs for more information.
Get all changed files using a list of files and take action based on the changes
...
    - name: Get changed files
      id: changed-files-specific
      uses: tj-actions/changed-files@v39
      with:
        files: |
          my-file.txt
          *.sh
          *.png
          !*.md
          test_directory
          **/*.sql
    - name: Run step if any of the listed files above change
      if: steps.changed-files-specific.outputs.any_changed == 'true'
      run: |
        echo "One or more files listed above has changed."
    - name: Run step if only the files listed above change
      if: steps.changed-files-specific.outputs.only_changed == 'true'
      run: |
        echo "Only files listed above have changed."
    - name: Run step if any of the listed files above is deleted
      if: steps.changed-files-specific.outputs.any_deleted == 'true'
      run: |
        for file in ${{ steps.changed-files-specific.outputs.deleted_files }}; do
          echo "$file was deleted"
        done
    - name: Run step if all listed files above have been deleted
      if: steps.changed-files-specific.outputs.only_deleted == 'true'
      run: |
        for file in ${{ steps.changed-files-specific.outputs.deleted_files }}; do
          echo "$file was deleted"
        done
...
See outputs for a list of all available outputs.
Get all changed files using a source file or list of file(s) to populate to files input
...
    - name: Get changed files using a source file or list of file(s) to populate to files input.
      id: changed-files-specific-source-file
      uses: tj-actions/changed-files@v39
      with:
        files_from_source_file: test/changed-files-list.txt
...
See inputs for more information.
Get changed files using a source file or list of file(s) to populate to files input and optionally specify more files
...
    - name: Get changed files using a source file or list of file(s) to populate to files input and optionally specify more files.
      id: changed-files-specific-source-file-and-specify-files
      uses: tj-actions/changed-files@v39
      with:
        files_from_source_file: |
          test/changed-files-list.txt
        files: |
          test.txt
...
See inputs for more information.
Get all changed files using a different SHA
...
    - name: Get changed files using a different SHA
      id: changed-files
      uses: tj-actions/changed-files@v39
      with:
        sha: ${{ github.event.pull_request.head.sha }}
...
See inputs for more information.
Get all changed files using a different base SHA
...
    - name: Get changed files using a different base SHA
      id: changed-files
      uses: tj-actions/changed-files@v39
      with:
        base_sha: ${{ github.event.pull_request.base.sha }}
...
See inputs for more information.
Get all changed files between the previous tag and the current tag
...
on:
  push:
    tags:
      - 'v*'
jobs:
  release:
    name: Release
    runs-on: ubuntu-latest
    steps:
      - name: Checkout
        uses: actions/checkout@v4
        with:
          fetch-depth: 0
      - name: Get changed files
        id: changed-files
        uses: tj-actions/changed-files@v39
      - name: Get changed files in the .github folder
        id: changed-files-specific
        uses: tj-actions/changed-files@v39
        with:
          base_sha: ${{ steps.get-base-sha.outputs.base_sha }}
          files: .github/**
      - name: Run step if any file(s) in the .github folder change
        if: steps.changed-files-specific.outputs.any_changed == 'true'
        run: |
          echo "One or more files in the .github folder has changed."
          echo "List all the files that have changed: ${{ steps.changed-files-specific.outputs.all_changed_files }}"
...
See inputs for more information.
Get all changed files for a repository located in a different path
...
    - name: Checkout into dir1
      uses: actions/checkout@v4
      with:
        fetch-depth: 0
        path: dir1
    - name: Run changed-files with defaults in dir1
      id: changed-files-for-dir1
      uses: tj-actions/changed-files@v39
      with:
        path: dir1
    - name: List all added files in dir1
      run: |
        for file in ${{ steps.changed-files-for-dir1.outputs.added_files }}; do
          echo "$file was added"
        done
...
See inputs for more information.
Get all changed files with non-äšćįí characters i.e (Filename in other languages)
...
    - name: Run changed-files with quotepath disabled
      id: changed-files-quotepath
      uses: tj-actions/changed-files@v39
      with:
        quotepath: "false"
    - name: Run changed-files with quotepath disabled for a specified list of file(s)
      id: changed-files-quotepath-specific
      uses: ./
      with:
        files: test/test-è.txt
        quotepath: "false"
...
See inputs for more information.
Get all changed files using the last successful commit of the base branch
- 
        Push event... - name: Get branch name id: branch-name uses: tj-actions/branch-names@v6 - uses: nrwl/nx-set-shas@v3 id: last_successful_commit_push with: main-branch-name: ${{ steps.branch-name.outputs.current_branch }} # Get the last successful commit for the current branch. workflow-id: 'test.yml' - name: Run changed-files with the commit of the last successful test workflow run id: changed-files-base-sha-push uses: tj-actions/changed-files@v39 with: base_sha: ${{ steps.last_successful_commit_push.outputs.base }} ...
- 
Pull request events... - name: Get branch name id: branch-name uses: tj-actions/branch-names@v5 - uses: nrwl/nx-set-shas@v3 id: last_successful_commit_pull_request with: main-branch-name: ${{ steps.branch-name.outputs.base_ref_branch }} # Get the last successful commit on the master or main branch workflow_id: 'test.yml' - name: Run changed-files with the commit of the last successful test workflow run on the main branch id: changed-files-base-sha-pull-request uses: tj-actions/changed-files@v39 with: base_sha: ${{ steps.last_successful_commit_pull_request.outputs.base }} ...
Warning
This setting overrides the commit sha used by setting
since_last_remote_committo true. It is recommended to use either solution that works for your use case.
See inputs for more information.
Get all changed files but only return the directory names
...
    - name: Run changed-files with dir_names
      id: changed-files-dir-names
      uses: tj-actions/changed-files@v39
      with:
        dir_names: "true"
...
See inputs for more information.
Get all changed files and return JSON formatted outputs
...
    - name: Run changed-files with JSON output
      id: changed-files-json
      uses: tj-actions/changed-files@v39
      with:
        json: "true"
...
See inputs for more information.
Get all changed files by commits pushed in the past
...
    - name: Get changed-files since 2022-08-19
      id: changed-files-since
      uses: tj-actions/changed-files@v39
      with:
        since: "2022-08-19"
    - name: Get changed-files until 2022-08-20
      id: changed-files-until
      uses: tj-actions/changed-files@v39
      with:
        until: "2022-08-20"
...
See inputs for more information.
Real-world usage 🌐
Open source projects 📦
- 
vitejs/vite: uses tj-actions/changed-files to automate testing 
- 
qgis/QGIS: uses tj-actions/changed-files to automate spell checking 
- 
tldr-pages/tldr: uses tj-actions/changed-files to automate detecting spelling errors 
- 
nodejs/docker-node: uses tj-actions/changed-files to generate matrix jobs based on changes detected 
- 
refined-github: uses tj-actions/changed-files to automate test URL validation in added/edited files 
- 
aws-doc-sdk-examples: uses tj-actions/changed-files to automate testing 
- 
nhost: uses tj-actions/changed-files to automate testing based on changes detected 
And many more...
Scalability Example 📈
Known Limitation ⚠️
Warning
Spaces in file names can introduce bugs when using bash loops. See: #216 However, this action will handle spaces in file names, with a recommendation of using a separator to prevent any hidden issues.
Migration guide 🔄
With the switch from using grep's Extended regex to match files to the natively supported workflow glob pattern matching syntax introduced in v13 you'll need to modify patterns used to match files.
...
      - name: Get specific changed files
        id: changed-files-specific
        uses: tj-actions/changed-files@v24
        with:
          files: |
-            \.sh$
-            .(sql|py)$
-            ^(dir1|dir2)
+            **/*.{sh,sql,py}
+            {dir1,dir2}/**
- Free software: MIT license
Credits 👏
This package was created with cookiecutter-action.
- tj-actions/auto-doc
- tj-actions/verify-changed-files
- tj-actions/demo
- tj-actions/demo2
- tj-actions/demo3
- tj-actions/release-tagger
Report Bugs 🐛
Report bugs at https://github.com/tj-actions/changed-files/issues.
If you are reporting a bug, please include:
- Your operating system name and version.
- Any details about your workflow that might be helpful in troubleshooting. (NOTE: Ensure that you include full log outputs with debugging enabled)
- Detailed steps to reproduce the bug.
Contributors ✨
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!

