260

If I've a git repository with tags representing the versions of the releases.

How can I get the list of the commits between two tags (with a pretty format if is possible) ?

ROMANIA_engineer
  • 51,252
  • 26
  • 196
  • 186
telemaco
  • 2,853
  • 2
  • 15
  • 8

7 Answers7

307

git log --pretty=oneline tagA...tagB (i.e. three dots)

If you just wanted commits reachable from tagB but not tagA:

git log --pretty=oneline tagA..tagB (i.e. two dots)

or

git log --pretty=oneline ^tagA tagB

dumbledad
  • 14,688
  • 20
  • 108
  • 248
manojlds
  • 275,671
  • 58
  • 453
  • 409
34

To compare between latest commit of current branch and a tag:

git log --pretty=oneline HEAD...tag
szaman
  • 6,576
  • 13
  • 50
  • 81
hidro
  • 12,005
  • 6
  • 50
  • 53
31

git log takes a range of commits as an argument:

git log --pretty=[your_choice] tag1..tag2

See the man page for git rev-parse for more info.

Garrett Hyde
  • 5,108
  • 7
  • 51
  • 53
Ben Stiglitz
  • 3,964
  • 26
  • 24
22

To style the output to your preferred pretty format, see the man page for git-log.

Example:

git log --pretty=format:"%h; author: %cn; date: %ci; subject:%s" tagA...tagB
lual
  • 386
  • 2
  • 6
4

FYI:

git log tagA...tagB

provides standard log output in a range.

starsinmypockets
  • 2,244
  • 4
  • 33
  • 45
3

Consider also this:

git range-diff tagA...tagB

Source: https://git-scm.com/docs/git-range-diff

1

If your team uses descriptive commit messages (eg. "Ticket #12345 - Update dependencies") on this project, then generating changelog since the latest tag can de done like this:

git log --no-merges --pretty=format:"%s" 'old-tag^'...new-tag > /path/to/changelog.md
  • --no-merges omits the merge commits from the list
  • old-tag^ refers to the previous commit earlier than the tagged one. Useful if you want to see the tagged commit at the bottom of the list by any reason. (Single quotes needed only for iTerm on mac OS).
Balu Ertl
  • 151
  • 3
  • 5