Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Git] Add support for git patch-id #851

Open
jgbarah opened this issue Nov 1, 2024 · 1 comment
Open

[Git] Add support for git patch-id #851

jgbarah opened this issue Nov 1, 2024 · 1 comment

Comments

@jgbarah
Copy link
Contributor

jgbarah commented Nov 1, 2024

git patch-id provides a sort-of unique ids for the information in a commit. It is basically "a sum of SHA-1 of the file diffs associated with a patch, with line numbers ignored". This means that the same commit, when for example cherry-picked to a different repository or to a different branch, or rebased, etc., keeps the same "patch-id". This is very useful to track the same commit when it travels to different repos (for example, all repos in the Linux kernel hierarchy), or to keep track of the commit when it is rebased o cherry-picked in any way.

I'm not sure which way to compute it would be better. Likely, using git itself could be the easiest one. But it can also be computed directly from the diff, which maybe is more aligned with the way in which Perceval works.

Another option could be to add some option to the backend to collect the diff, and then compute the patch-id in a separate step, by some other tool, after Perceval finishes its work. But that could cause a lot of information (all the diff data) to be produced by Perceval, which if you are only interested in the patch-id would just cause Perceval to produce much more data than needed, and maybe make it impractical for large repos.

@sduenas
Copy link
Member

sduenas commented Nov 7, 2024

We should run some tests and check the performance of this. We can get the diff of every commit with the option -p. So, something like git log --raw -p --full-diff should do the work. With the diff we can calculate the patch-id. However, this can work for the first time the commits are fetched. For newest commits we use git show that apparently, can be combined with git patch-id.

@sduenas sduenas added the git label Dec 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants