name: Changed Files description: Get all Added, Copied, Modified, Deleted, Renamed, Type changed, Unmerged, Unknown files. author: tj-actions inputs: separator: description: "Split character for output strings" required: false default: " " include_all_old_new_renamed_files: description: "Include `all_old_new_renamed_files` output. Note this can generate a large output See: [#501](https://github.com/tj-actions/changed-files/issues/501)." required: false default: "false" old_new_separator: description: "Split character for old and new filename pairs." required: false default: "," old_new_files_separator: description: "Split character for old and new renamed filename pairs." required: false default: " " files_from_source_file: description: "Source file(s) used to populate the `files` input." required: false default: "" files: description: "File and directory patterns to detect changes using only these list of file(s) (Defaults to the entire repo) **NOTE:** Multiline file/directory patterns should not include quotes." required: false default: "" files_separator: description: "Separator used to split the `files` input" default: "\n" required: false files_ignore: description: "Ignore changes to these file(s) **NOTE:** Multiline file/directory patterns should not include quotes." required: false default: "" files_ignore_separator: description: "Separator used to split the `files_ignore` input" default: "\n" required: false files_ignore_from_source_file: description: "Source file(s) used to populate the `files_ignore` input" required: false default: "" sha: description: "Specify a different commit SHA used for comparing changes" required: false base_sha: description: "Specify a different base commit SHA used for comparing changes" required: false since: description: "Get changed files for commits whose timestamp is older than the given time." required: false default: "" until: description: "Get changed files for commits whose timestamp is earlier than the given time." required: false default: "" path: description: "Specify a relative path under `$GITHUB_WORKSPACE` to locate the repository." required: false default: "." quotepath: description: "Use non ascii characters to match files and output the filenames completely verbatim by setting this to `false`" default: "true" required: false diff_relative: description: "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 `path` input." required: false dir_names: default: "false" description: "Output unique changed directories instead of filenames. **NOTE:** This returns `.` for changed files located in the root of the project." required: false dir_names_max_depth: description: "Maximum depth of directories to output. e.g `test/test1/test2` with max depth of `2` returns `test/test1`." required: false dir_names_exclude_root: description: "Exclude the root directory represented by `.` from the output when `dir_names`is set to `true`." required: false default: "false" json: description: "Output list of changed files in a JSON formatted string which can be used for matrix jobs." required: false default: "false" json_raw_format: description: "Output list of changed files in [jq](https://devdocs.io/jq/) raw output format which means that the output will not be surrounded by quotes and special characters will not be escaped." required: false default: "false" fetch_depth: description: "Depth of additional branch history fetched. **NOTE**: This can be adjusted to resolve errors with insufficient history." required: false default: "50" since_last_remote_commit: description: "Use the last commit on the remote branch as the `base_sha`. Defaults to the last non merge commit on the target branch for pull request events and the previous remote commit of the current branch for push events." required: false default: "false" write_output_files: description: "Write outputs to files in the `.github/outputs` folder by default." required: false default: "false" output_dir: description: "Directory to store output files." required: false default: ".github/outputs" match_directories: description: "Indicates whether to include match directories" default: "true" required: false outputs: added_files: description: "Returns only files that are Added (A)." value: ${{ steps.changed-files.outputs.added_files }} copied_files: description: "Returns only files that are Copied (C)." value: ${{ steps.changed-files.outputs.copied_files }} deleted_files: description: "Returns only files that are Deleted (D)." value: ${{ steps.changed-files.outputs.deleted_files }} modified_files: description: "Returns only files that are Modified (M)." value: ${{ steps.changed-files.outputs.modified_files }} renamed_files: description: "Returns only files that are Renamed (R)." value: ${{ steps.changed-files.outputs.renamed_files }} all_old_new_renamed_files: description: "Returns only files that are Renamed and list their old and new names. **NOTE:** This requires setting `include_all_old_new_renamed_files` to `true` (R)" value: ${{ steps.changed-files.outputs.all_old_new_renamed_files }} type_changed_files: description: "Returns only files that have their file type changed (T)." value: ${{ steps.changed-files.outputs.type_changed_files }} unmerged_files: description: "Returns only files that are Unmerged (U)." value: ${{ steps.changed-files.outputs.unmerged_files }} unknown_files: description: "Returns only files that are Unknown (X)." value: ${{ steps.changed-files.outputs.unknown_files }} all_changed_and_modified_files: description: "Returns all changed and modified files i.e. *a combination of (ACMRDTUX)*" value: ${{ steps.changed-files.outputs.all_changed_and_modified_files }} all_changed_files: description: "Returns all changed files i.e. *a combination of all added, copied, modified and renamed files (ACMR)*" value: ${{ steps.changed-files.outputs.all_changed_files }} any_changed: description: "Returns `true` when any of the filenames provided using the `files` input has changed. If no `files` have been specified,an empty string `''` is returned. i.e. *using a combination of all added, copied, modified and renamed files (ACMR)*." value: ${{ steps.changed-files.outputs.any_changed }} only_changed: description: "Returns `true` when only files provided using the `files` input has changed. If no `files` have been specified,an empty string `''` is returned. i.e. *using a combination of all added, copied, modified and renamed files (ACMR)*." value: ${{ steps.changed-files.outputs.only_changed }} other_changed_files: description: "Returns all other changed files not listed in the files input i.e. *using a combination of all added, copied, modified and renamed files (ACMR)*." value: ${{ steps.changed-files.outputs.other_changed_files }} all_modified_files: description: "Returns all changed files i.e. *a combination of all added, copied, modified, renamed and deleted files (ACMRD)*." value: ${{ steps.changed-files.outputs.all_modified_files }} any_modified: description: "Returns `true` when any of the filenames provided using the `files` input has been modified. If no `files` have been specified,an empty string `''` is returned. i.e. *using a combination of all added, copied, modified, renamed, and deleted files (ACMRD)*." value: ${{ steps.changed-files.outputs.any_modified }} only_modified: description: "Returns `true` when only files provided using the `files` input has been modified. If no `files` have been specified,an empty string `''` is returned.(ACMRD)." value: ${{ steps.changed-files.outputs.only_modified }} other_modified_files: description: "Returns all other modified files not listed in the files input i.e. *a combination of all added, copied, modified, and deleted files (ACMRD)*" value: ${{ steps.changed-files.outputs.other_modified_files }} any_deleted: description: "Returns `true` when any of the filenames provided using the `files` input has been deleted. If no `files` have been specified,an empty string `''` is returned. (D)" value: ${{ steps.changed-files.outputs.any_deleted }} only_deleted: description: "Returns `true` when only files provided using the `files` input has been deleted. If no `files` have been specified,an empty string `''` is returned. (D)" value: ${{ steps.changed-files.outputs.only_deleted }} other_deleted_files: description: "Returns all other deleted files not listed in the files input i.e. *a combination of all deleted files (D)*" value: ${{ steps.changed-files.outputs.other_deleted_files }} runs: using: "composite" steps: - run: | # "Calculating the previous and current SHA..." bash $GITHUB_ACTION_PATH/diff-sha.sh id: changed-files-diff-sha shell: bash env: GITHUB_SERVER_URL: ${{ github.server_url }} GITHUB_REPOSITORY: ${{ github.repository }} GITHUB_REF: ${{ github.ref }} GITHUB_SHA: ${{ github.sha }} GITHUB_WORKSPACE: ${{ github.workspace }} GITHUB_EVENT_BASE_REF: ${{ github.event.base_ref }} GITHUB_EVENT_HEAD_REPO_FORK: ${{ github.event.pull_request.head.repo.fork }} GITHUB_EVENT_PULL_REQUEST_NUMBER: ${{ github.event.pull_request.number }} GITHUB_EVENT_PULL_REQUEST_BASE_REF: ${{ github.event.pull_request.base.ref }} GITHUB_EVENT_PULL_REQUEST_HEAD_REF: ${{ github.event.pull_request.head.ref }} GITHUB_EVENT_PULL_REQUEST_BASE_SHA: ${{ github.event.pull_request.base.sha }} GITHUB_EVENT_PULL_REQUEST_HEAD_SHA: ${{ github.event.pull_request.head.sha }} GITHUB_EVENT_PULL_REQUEST_COMMITS: ${{ github.event.pull_request.commits }} GITHUB_EVENT_BEFORE: ${{ github.event.before }} GITHUB_EVENT_FORCED: ${{ github.event.forced }} GITHUB_REFNAME: ${{ github.ref_name }} # INPUT_ is not available in Composite run steps # https://docs.github.com/en/actions/creating-actions/metadata-syntax-for-github-actions#example-specifying-inputs INPUT_SHA: ${{ inputs.sha }} INPUT_BASE_SHA: ${{ inputs.base_sha }} INPUT_SINCE: ${{ inputs.since }} INPUT_UNTIL: ${{ inputs.until }} INPUT_PATH: ${{ inputs.path }} INPUT_FETCH_DEPTH: ${{ inputs.fetch_depth }} INPUT_SINCE_LAST_REMOTE_COMMIT: ${{ inputs.since_last_remote_commit }} - name: Glob match uses: tj-actions/glob@v16.14 id: glob with: files: ${{ inputs.files }} files-separator: ${{ inputs.files_separator }} excluded-files: ${{ inputs.files_ignore }} excluded-files-separator: ${{ inputs.files_ignore_separator }} files-from-source-file: ${{ inputs.files_from_source_file }} excluded-files-from-source-file: ${{ inputs.files_ignore_from_source_file}} escape-paths: true working-directory: ${{ inputs.path }} base-sha: ${{ steps.changed-files-diff-sha.outputs.previous_sha }} sha: ${{ steps.changed-files-diff-sha.outputs.current_sha }} diff: ${{ steps.changed-files-diff-sha.outputs.diff }} match-directories: ${{ inputs.match_directories }} include-deleted-files: true separator: "|" - run: | bash $GITHUB_ACTION_PATH/get-changed-paths.sh id: changed-files shell: bash env: GITHUB_WORKSPACE: ${{ github.workspace }} GITHUB_EVENT_PULL_REQUEST_BASE_REF: ${{ github.event.pull_request.base.ref }} GITHUB_EVENT_PULL_REQUEST_HEAD_REPO_FORK: ${{ github.event.pull_request.head.repo.fork }} # INPUT_ is not available in Composite run steps # https://docs.github.com/en/actions/creating-actions/metadata-syntax-for-github-actions#example-specifying-inputs INPUT_FILES_PATTERN_FILE: ${{ steps.glob.outputs.paths-output-file }} INPUT_SEPARATOR: ${{ inputs.separator }} INPUT_PATH: ${{ inputs.path }} INPUT_PREVIOUS_SHA: ${{ steps.changed-files-diff-sha.outputs.previous_sha }} INPUT_CURRENT_SHA: ${{ steps.changed-files-diff-sha.outputs.current_sha }} INPUT_TARGET_BRANCH: ${{ steps.changed-files-diff-sha.outputs.target_branch }} INPUT_CURRENT_BRANCH: ${{ steps.changed-files-diff-sha.outputs.current_branch }} INPUT_DIFF: ${{ steps.changed-files-diff-sha.outputs.diff }} INPUT_QUOTEPATH: ${{ inputs.quotepath }} INPUT_INCLUDE_ALL_OLD_NEW_RENAMED_FILES: ${{ inputs.include_all_old_new_renamed_files }} INPUT_OLD_NEW_SEPARATOR: ${{ inputs.old_new_separator }} INPUT_OLD_NEW_FILES_SEPARATOR: ${{ inputs.old_new_files_separator }} INPUT_DIFF_RELATIVE: ${{ inputs.diff_relative }} INPUT_DIR_NAMES: ${{ inputs.dir_names }} INPUT_DIR_NAMES_MAX_DEPTH: ${{ inputs.dir_names_max_depth }} INPUT_DIR_NAMES_EXCLUDE_ROOT: ${{ inputs.dir_names_exclude_root }} INPUT_JSON: ${{ inputs.json }} INPUT_HAS_CUSTOM_PATTERNS: ${{ steps.glob.outputs.has-custom-patterns }} INPUT_JSON_RAW_FORMAT: ${{ inputs.json_raw_format }} - name: Generate output files uses: tj-actions/json2file@v1.4.0 if: inputs.write_output_files == 'true' with: outputs: ${{ toJSON(steps.changed-files.outputs) }} directory: ${{ inputs.output_dir }} skip_missing_keys: true keys: | added_files copied_files deleted_files modified_files renamed_files all_old_new_renamed_files type_changed_files unmerged_files unknown_files all_changed_and_modified_files all_changed_files any_changed only_changed other_changed_files all_modified_files any_modified only_modified other_modified_files any_deleted only_deleted other_deleted_files extension: ${{ steps.changed-files.outputs.outputs_extension }} branding: icon: file-text color: white