How can you determine all the files that changed in a given changeset?
I'm not looking for a diff in this case, just a list of add/remove/modifications.
hg log -vprX
does a list of diffs but I just want the files.
How can you determine all the files that changed in a given changeset?
I'm not looking for a diff in this case, just a list of add/remove/modifications.
hg log -vprX
does a list of diffs but I just want the files.
If you want to list only files that have changed then you should be using "status command" The following will list the changes to files in revision REV
hg status --change REV
-n
/ --no-status
flag too. –
Mealymouthed hg status --no-status --change REV
–
Kreiner hg status --rev REV~1:REV
which I used to do. –
Lagerkvist hg status --change .
–
Gay hg status --change .
.
is shorthand for the current rev, just like @HEAD
in Git
hg status
hg status --change REV_ID
Just remove p
from your hg log -vpr
will show the list of files. -p
means show patch. You can also use a template to format the output to your taste.
hg status --change .
worked better and gave a file action prefix (A\M\D etc) and better relative path –
Gay I know the question is for a single changeset, but if you'd like to get all the files modified for a range of changesets, you can do
hg status --rev 1 --rev 10 -m
hg log -r BEGIN:END --template "{files}\n"
as @geoffrey-zheng and @ton wrote two years ago!!! –
Activism hg status --rev BEGIN --rev END
is: 1. much easier to remember than hg log -r BEGIN:END --template "{files}\n"
; 2. it prints the files in separate lines without using sed
(@Eric Lawler) or join()
(@Foxichu); 3. without the -m
flag, it displays not only modified, but also added and removed files (the nice standard coloring applies here too); 4. there are -a
and -r
flags which allow different filtering; 5. if one doesn't want the status prefix, there's -n
option, which suppresses it. –
Royalty Found this question through Googling for a similar concept. To show all files that changed through a range of changesets, it's as easy as:
hg log -r [start rev]:[end rev] --template "{file_mods}{file_adds}\n" | sed -e 's/ /\n/g' | sort -d | uniq
hg log -r [start rev]:[end rev] --template "{file_mods}{file_adds}\n"
will show you a list of each file changed or added in each changeset, from [start rev] to [end rev], with each changeset's files on a new line. Swap {file_mods}{file_adds}
with {files}
to show all files modified, added, or removed.sed -e 's/ /\n/g'
will split all the files to show on separate lines andsort
will, er, sort the list for you so we can filter the list with uniquniq
will filter the list to remove duplicates—files that changed in more than one revision.--template
-based solution without these shortcomings could be constructed using join()
as suggested by @Foxichu. –
Royalty I know this question is an old question and I'm surprised nobody just offered modified code form OP. I got a list of modified/added/removed files (not labeled which is which though) by just running hg log -v
. Or what I actually needed hg log -v -l5
to see files that have been modified/added/removed in the last 5 commits (including the ones that I didn't push yet to the repo).
If you're like most shops, you use a ticketing system to track changes. If you know the ticket number and want to find all the commits associated with that ticket (assuming you include the ticket number in the commit message), you can use:
hg log -k TICKET_NUMBER
This does display the all the revisions associated with the ticket. However, it does not list the files. You could do use one of the answers above to then get the list of files associated with the revisions.
To make it simpler though, combining the info from the previous answers, you could do the following to search for commits, including files changed:
hg log -vk TICKET_NUMBER
© 2022 - 2024 — McMap. All rights reserved.