On Fri, Apr 08, 2022 at 07:32:03PM -0400, rsbecker@xxxxxxxxxxxxx wrote: > On April 8, 2022 6:30 PM, brian m. carlson wrote: > >On 2022-04-08 at 03:35:04, jurgen_gjoncari@xxxxxxxxxx wrote: > >> I think that often commit messages are unnecessary. I propose that by > >> default a user should be able to commit without a message. > > > >This topic comes up from time to time and you can see the previous discussion in > >the archives. The reasons we haven't done this are roughly as follows. > > > >First, writing commit messages is a way of communicating to others about your > >changes, as well as to future you. In my experience, it is substantially more > >important in software engineering to communicate clearly and effectively than it is > >to write code. The computer will accept anything that runs, but when you write > >code others must read it and change it, and they must have the appropriate > >context behind those changes to evaluate your changes and to make their own in > >the future. > >We want to encourage good software engineering practices. > > > >Tools like git log use the commit message, and empty commit messages mean that > >viewing the list of commits is completely useless without viewing a diff. This > >means that functionality such as `git log --graph` is just completely broken. Writing > >even one line in the commit summary makes a massive difference in the usability > >of these tools. > > > >Users who want this behaviour can use --allow-empty-message or create an alias > >with that option. The functionality already exists. I use aliases extensively in my > >development and I know others do as well, so this shouldn't be an impediment if > >you're working on projects where this is acceptable. > > > >> I don't think this would be a problem from the UX point of view, > >> because a user could get a lot of information about a change, from the > >> history of the GitHub repository, such as from the time of change, and > >> seeing the diff. > > > >I certainly hope when you are writing code that you explain your changes > >somewhere. I know some people who use pull requests prefer to do so in the pull > >request rather than the commit message, but I for one would never accept a > >change that doesn't contain some sort of explanation about why it's valuable or > >relevant somewhere. I am, unfortunately, not omniscient, so I need people to > >communicate their intentions and decisions to me, and the best way to do that is > >with words. > > > >I should also point out that the GitHub UI is specifically designed to show the > >commit summary in the history view, so GitHub intends for you to write at least > >one line of helpful text (the summary) in this context. > > > >Overall, I don't believe your proposal is likely to gain traction here for the reasons I > >mentioned above, and I personally don't support it. > > The commit message is an essential part of why a change was made, in particular for forensics when something goes wrong, or when you are trying to figure out why you did something. Without a commit message, you are saying, "yeah, ok, something happened." It's up there with reporting a bug saying, "It doesn't work", with no additional details - I have customers who do that, and it is not helpful. To be harsh about it, if someone commits something with no or a useless message, I will reject the change with impunity. Not explaining yourself is not helpful to those who come after. It's up there with "Why did you not document your code, when you used single letter variables and strung the whole program on one line because C (or APL) allows it," with an answer along the lines of "Any decent developer should be able to figure out the code." Sorry, but I feel very strongly on the subject that this is not a good idea. If you want to put junk in your commit, that is your business, but expect a > significant segment of the population looking at your repo on GitHub to judge harshly. This sounds more like "I don't want to use a version control system, but I have to for some reason, like HR metrics." I know I am being harsh on this, and I apologize in advance for it if I offended anyone, but I would want a way to disable (potentially at build time) this if it ever went forward. There is nothing stopping you using '.' as the commit message which is as informative as when it is empty. Hence this enforcement of non-empty commit message does not serve the stated purpose. Sure, if you are merging someone's pull request you can enforce that the changes are intelliginle by human review but that's not something git can do automatically. Also I have an auto-generated git repository of web pages in which every single commit message is the same. It is not empty because I was too lazy to figure out how to do that but the effective information value is the same. And it's in git because the publication system uses git as backend so there it goes. Thanks Michal