Show HN: acmsg (automated commit message generator)

(github.com)

8 points | by qeden 7 hours ago ago

17 comments

  • InsideOutSanta 6 hours ago ago

    I don't understand the reasoning for persisting LLM output that can be generated at any point. If I want to use an LLM to understand someone else's commits, I can use the LLM best suited for that task at the time I need the information, which will likely be more accurate than what was available at the time of the commit and will have access to more context.

    I also believe that commit messages should focus on information the code doesn't already convey. Whatever the LLM can generate from looking at your code is likely not the info I'll seek when I read your commit message.

    • bee_rider 5 hours ago ago

      It looks like it just is based on the git diff and status, at least as far as I can tell in a quick skim…

      Hypothetically, a tool like this could ingest the bug report you were fixing, some emails, etc etc. It could also read the whole project (to get more context than just the diff). In principle there’s no reason it couldn’t relay more info than just the diff, in some extreme form…

      Also, it could be seen as producing a starting point. When a person picks which AI generated text to keep, that is enough to add a bit of human spark into the system, right?

  • pvdebbe 6 hours ago ago

    Maybe I am a bit old-fashioned but I think the commit message should convey intent and not content of the diffs. Perhaps the real utility of this is to describe existing commits in a repository.

    • owebmaster 6 hours ago ago

      I'm also old-fashioned but I always thought it made much more sense to give a content diff, it makes it easier to find changes.

      • JimDabell 5 hours ago ago

        The commit itself is the content diff. Repeating that in the log message is redundant.

        • owebmaster 4 hours ago ago

          no, it is not redundant, a summary makes it easier to search and find the correct commit to read the full diff.

          • hiatus an hour ago ago

            Isn't that solved with blame?

  • nickcw 5 hours ago ago

    When you are looking through commit messages, "Why?", Is the question you want answered. The diff contains "What?" and "How?".

    Assuming that the commits in this repo were generated by this tool it is missing the "Why?".

    • flysand7 5 hours ago ago

      You are talking about the commit message body, right, not just the header? Because for me it's something similar, but:

      Header: Contains "What" and the scope of the changes, as short as possible Body: Contains "Why" and the full explanation of the change

    • myrmidon 5 hours ago ago

      Fully agree. Also, using LLMs for things like this can have bad side-effects, too, simply because it raises the noise-floor:

      By spelling out things that are not noteworthy enough for a human, you make it more difficult to find comments that are (and were). Injecting a lot of irrelevant information can hamper understanding even if it is technically completely correct.

    • trallnag 4 hours ago ago

      So what kind of commit subject do you expect for fixing a single typo? Or bumping the patch version of a random dependency?

  • theknarf 4 hours ago ago

    This is worse than useless.

    The commit message is supposed to contain the details that you can't just glance from the code. Why a certain decision was made, or the pro's and con's of a decision, a link to a relevant Github / Jira issue, etc.

    • jasonjmcghee 3 hours ago ago

      > a link to a relevant Github / Jira issue, etc.

      So important!

      Makes all devs lives so much easier.

      Though you know someone is going to tweak the lint rules at some point and have the top commit on nearly every line at a certain point in time.

      Is there a "non-functional change commit" dictionary for git blame to ignore these? I would use that feature...

  • alzamixer 5 hours ago ago

    I use the following script to allow copilot vim plugin to help me.

    ```plaintext name=../../bin/assisted-commit

    #!/bin/bash

    # Run git commit with --verbose --dry-run and save the output git commit --verbose --dry-run > ./commit.message

    # Prepend # to every line and add "conventional commit message:" at the end sed -i 's/^/# /' ./commit.message echo "# uncommented conventional commit message using feat, fix or doc flags. !beakingchange iff change breaks backward compatibility:" >> ./commit.message echo "" >> ./commit.message

    # Open the file in vim for editing, with cursor on a new line at the end and in insert mode vim +':normal Go' +startinsert ./commit.message

    # Filter out commented lines and save to a temporary file grep -v '^#' ./commit.message > ./commit.message.filtered

    # Commit using the filtered file git commit -F ./commit.message.filtered

    # Delete the files rm ./commit.message ./commit.message.filtered

    ```

  • esafak 5 hours ago ago

    Don't forget to include committed code in the context when amending.

  • infocollector 6 hours ago ago

    Looks like openrouter api can be self-hosted, which means you should be able to run this locally. If anyone is able to run this with ollama, please do post how you did that? :)

    • theblazehen 5 hours ago ago

      The openrouter api is the same as the openai api, so you should be able to use the openai api compatibility built into ollama after updating the url in /src/acmsg/constants.py