git stage 暂存_Git:如何在预提交挂钩中重新暂存已暂存的文件

I'm writting a git pre-commit hook.

The script could reformat some code, so it could modify the staged files.

How can I re-stage all files that are already staged ?

解决方案

Without the pre-commit hook context, you can get a list of the staged files with the following command:

git diff --name-only --cached

So if you want to re-index the staged files, you can use:

git diff --name-only --cached | xargs -l git add

In the pre-commit hook context, you should follow the advices of David Winterbottom and stash unstaged changes before anything else.

This technique allows you not to be worry about indexing, or alterate, a change that was not staged.

So you don't have to stage all the staged files, but all the updated files:

# Stash unstaged changes

git stash -q --keep-index

# Edit your project files here

...

# Stage updated files

git add -u

# Re-apply original unstaged changes

git stash pop -q

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值