What did you do before the bug happened? (Steps to reproduce your issue) 1. Create a brand new file, e.g. 'touch a.py' 2. Add it to worktree with 'git add a.py' 3. stash the file with 'git stash' 4. pop the stashed change with 'git stash pop', WITHOUT the --index option What did you expect to happen? (Expected behavior) I expect the file 'a.py' to be in unstaged area since I did not pass the '--index' option to 'git stash pop' What happened instead? (Actual behavior) The file is found in staged are are after 'git stash pop', potentially causing merge-conflict in certain scenarios What's different between what you expected and what actually happened? I want the file to be found in unstaged area. The 'git stash push'/'git stash pop' combo works as expected if the file is already added to worktree prior to this maneuver. I think the behavior should be consistent for brand new files as well. Anything else you want to add: Please review the rest of the bug report below. You can delete any lines you don't wish to share. [System Info] git version: git version 2.31.0 cpu: x86_64 no commit associated with this build sizeof-long: 8 sizeof-size_t: 8 shell-path: /bin/sh uname: Darwin 21.3.0 Darwin Kernel Version 21.3.0: Wed Jan 5 21:37:58 PST 2022; root:xnu-8019.80.24~20/RELEASE_X86_64 x86_64 compiler info: clang: 12.0.0 (clang-1200.0.32.29) libc info: no libc information available $SHELL (typically, interactive shell): /bin/zsh [Enabled Hooks]