Подтвердить что ты не робот

Как изменить время фиксации (еще не нажато)?

Как я могу изменить время, которое я совершил в своем локальном репозитории?

Предположим, что я сделал несколько коммитов и заметил, что дата на моем компьютере неверна. Предположим также, что эти коммиты еще не были нажаты.

4b9b3361

Ответ 1

Вы можете сделать это легко с помощью MQ (Mercurial Queues):

Настройте неудачную дату репо

+ hg init
+ echo line
+ hg commit -A -d 12/1 -m first
adding file
+ echo line
+ hg commit -A -d 12/2 -m second
+ echo line
+ hg commit -A -d 12/3 -m third
+ hg log
changeset:   2:81c88de729a8
tag:         tip
user:        Ry4an Brase <[email protected]>
date:        Thu Dec 03 00:00:00 2009 -0600
summary:     third

changeset:   1:c1fe70008824
user:        Ry4an Brase <[email protected]>
date:        Wed Dec 02 00:00:00 2009 -0600
summary:     second

changeset:   0:abb97adaa541
user:        Ry4an Brase <[email protected]>
date:        Tue Dec 01 00:00:00 2009 -0600
summary:     first

Поверните изменения в патчи в очереди

+ hg qimport -r 2
+ hg qimport -r 1
+ hg qimport -r 0

Сделайте каждый патч Qtip по очереди и исправьте дату

+ hg qrefresh -D
+ hg qpop
Now at: 1.diff
+ hg qrefresh -D
+ hg qpop
Now at: 0.diff
+ hg qrefresh -D

Повторите патчи

+ hg qpush
applying 1.diff
Now at: 1.diff
+ hg qpush
applying 2.diff
Now at: 2.diff

Поверните каждый патч обратно в реальные изменения.

+ hg qdel -r 0
+ hg qdel -r 1
+ hg qdel -r 2

Все лучше:

+ hg log
changeset:   2:6b51e14aadfc
tag:         tip
user:        Ry4an Brase <[email protected]>
date:        Wed Feb 25 22:29:01 2009 -0600
summary:     third

changeset:   1:5cbb9fc51bcc
user:        Ry4an Brase <[email protected]>
date:        Wed Feb 25 22:29:02 2009 -0600
summary:     second

changeset:   0:ec58d1f24278
user:        Ry4an Brase <[email protected]>
date:        Wed Feb 25 22:29:02 2009 -0600
summary:     first

Ответ 2

Там --date флаг для hg commit, вот как вы перезаписываете время фиксации. Вопрос в том, как повторять предыдущие изменения без особых усилий.

Предположим, вы получили следующую историю локальных коммитов:

dir1> hg commit # r100, OK
dir1> hg commit # r101, need to fix time
dir1> hg commit # r102, need to fix time

Здесь мое решение:

hg diff -r100:101 > 101.diff
hg diff -r101:102 > 102.diff
cd ..
hg clone -r100 dir1 dir2 # create a copy just before changesets than needs to be fixed
cd dir2
patch -i ../dir1/101.diff
hg commit -m "Same commit message" --date="required date"
patch -i ../dir1/102.diff
hg commit -m "Same commit message" --date="required date"
cd ..
rm -rf dir1 &&  mv dir2 dir1 # replace working copy

Вы можете автоматизировать применение патчей с помощью hg patch, который я еще не использовал в своей практике.

Ответ 3

Если это всего лишь одно коммит, и это фиксация является самой последней (в любой ветки, в которой вы находитесь), быстрый однострочный для этого:

hg commit --amend -d now