kicad-developers team mailing list archive
  
  - 
     kicad-developers team kicad-developers team
- 
    Mailing list archive
  
- 
    Message #35661
  
 A reminder on Git commit comments
  
I'd like to make an observation on some of the Git commit comments I'm 
reading. Some of these commit log entries are really unhelpful.
When I was at University many, many years ago, students were taught to 
place comments in their code. Many misunderstood the purpose of 
comments, though, and would write code like this:
   x = x + 1;       /* Add 1 to x */
While the comment is totally correct, it's also totally useless. I can 
/see/ that this line adds 1 to /x/; I don't need a comment to tell me 
that. As a programmer coming along later, what I need to know is /why/ 1 
is being added to /x/.
I'm seeing commit comments of the form "add one to x" in the KiCad 
repos. These comments are useless. For an example, look at this commit 
in the kicad-symbols repo:
   commit 4ada78e26774c841ce8ec33e8b221d04fed1f4c7
   Author: Rene Pöschl <r.poeschl@xxxxxxxxxxxxxxxxx>
   Date:   Fri Apr 20 11:14:47 2018 +0200
        Remove Connector_Specialized files.
Great. I can /see/ that these files are being removed. That's obvious 
from looking at the content of the commit. But there is no explanation 
of why these files were deleted. Don't tell me that there was discussion 
about this in email; even if that happened it's irrelevant. No one 
should have to go chasing through an email archive hoping to understand 
why a change was made. That's what the commit log entry is for.
I went back further in the Git logs for commits touching these files 
hoping to find a more illuminating commit comment, but found nothing 
helpful. In fact, I came across an earlier series of commits that are 
even /less/ helpful:
   commit 467170586b106d00c4df185dc1683046e259b74c
   Author: evanshultz <evanshultz@xxxxxxxxxxxxxxxxxxxxxxxx>
   Date:   Thu Apr 19 09:42:52 2018 -0700
        Just checking... still no dice
   commit 966a1a40aa36732d9c2404b044a4ef63bd0bb417
   Author: evanshultz <evanshultz@xxxxxxxxxxxxxxxxxxxxxxxx>
   Date:   Thu Apr 19 09:36:28 2018 -0700
        Delete Connector_Specialized.lib
   commit aeb4270213da8a063f24163d6fa31e8521f08a83
   Author: evanshultz <evanshultz@xxxxxxxxxxxxxxxxxxxxxxxx>
   Date:   Thu Apr 19 09:36:03 2018 -0700
        Delete Connector_Specialized.dcm
The top (latest) commit actually reverts the actions of the previous two 
commits. So now I have the idea that there's some sort of disagreement 
whether these files should be part of the repo or not. But I still have 
no idea why.
In a previous job I was the poor sod (or arrogant bastard, take your 
pick) who had to review commits before they were merged into the master 
branch. I would have rejected commits like these immediately. With Open 
Source development there's often less control over what gets merged and 
what doesn't. But that just means it's all the more important for 
everyone to make an effort to write good commit comments.
From the KiCad source file 
Documentation/development/commit-message-format.md:
   Commit messages should begin with a subject line; try to limit this
   to no more
   than 50-72 characters. The body of the message should be separated
   from the
   subject by a blank line and wrapped at 72 characters. The body of a
   commit
   message should explain what the commit does and why, but do not
   explain *how*
   as the code itself should do that.
Follow ups