Creating a patch
This page amends the Devmanual's patches article and describes how to create a patch for source code.
Creating a patch
Using git
A source code patch for an existing package can easily be created using git diff.
Unpack the package to be patched using the ebuild command:
user $
ebuild $(portageq get_repo_path / gentoo)/sys-fs/lvm2/lvm2-2.02.145-r2.ebuild clean unpack
... >>> Unpacking source... >>> Unpacking LVM2.2.02.145.tgz to /var/tmp/portage/sys-fs/lvm2-2.02.145-r2/work >>> Source unpacked in /var/tmp/portage/sys-fs/lvm2-2.02.145-r2/work
Step into the ${S} directory as defined in the ebuild:
user $
cd /var/tmp/portage/sys-fs/lvm2-2.02.145-r2/work/LVM2.2.02.145/
Initialize a git repository
If the unpacked directory is a git repository, skip the following initialization of the git repository.
Initialize the unpacked package sources as a git repository:
user $
git init
Initialized empty Git repository in /var/tmp/portage/sys-fs/lvm2-2.02.145-r2/work/LVM2.2.02.145/.git/
Add all the existing files to git and do a commit. Remember to write a commit message!
user $
git add .
user $
git commit -m "Initial commit"
Make changes
Now make the necessary changes to the unpacked source code, one or more files may be changed. Of course, the required changes should probably be known in advance.
Here is an example of a command making changes to the source code:
user $
sed -e 's/MAKEDEV:-"debian"/MAKEDEV:-"gentoo"/' -i scripts/lvm2create_initrd/lvm2create_initrd
Create diff using git
When changes are done, have git output the diff, and tee it into the patch file:
user $
git diff | tee /tmp/foobar.patch
diff --git a/scripts/lvm2create_initrd/lvm2create_initrd b/scripts/lvm2create_initrd/lvm2create_initrd index 6e70c55..1e46b5e 100644 --- a/scripts/lvm2create_initrd/lvm2create_initrd +++ b/scripts/lvm2create_initrd/lvm2create_initrd @@ -57,7 +57,7 @@ DEVRAM=/tmp/initrd.$$ BINFILES=${BINFILES:-"`which lvm` `which bash` `which busybox` `which pivot_root`"} BASICDEVICES=${BASICDEVICES:-"std consoleonly fd"} BLOCKDEVICES=${BLOCKDEVICES:-"md hda hdb hdc hdd sda sdb sdc sdd"} -MAKEDEV=${MAKEDEV:-"debian"} +MAKEDEV=${MAKEDEV:-"gentoo"} # Uncomment this if you want to disable automatic size detection #INITRDSIZE=4096
Cleanup
If the patch isn't in a standard format already (like git format-patch), it's a good idea to clean it up a bit before using it in an ebuild. The devmanual has a guide, and the scrub-patch command from app-portage/iwdevtools may used to automate some changes.
Adjusting a malformed patch from TortoiseGit or Git for Windows
Patches generated by Tortoise Git and Git for Windows are padded with additional information that patch
does not understand.
From HASH Day Mon DD hh:mm:ss YYYY
From: AUTHOR <AUTHOR@E-MAIL.TLD>
Date: Day, DD MMM YYYY hh:mm:ss +hhmm
Subject: [PATCH] COMMIT MESSAGE
---
PATH/TO/FILE.EXT 1 +
1 file changed, 1 insertion(+)
diff --git a/PATH/TO/FILE.EXT b/PATH/TO/FILE.EXT
index HA..SH CODE
--- a/PATH/TO/FILE.EXT
+++ b/PATH/TO/FILE.EXT
@@ -56,6 +56,7 @@
+ some new code
- some old code
--
VERSION.windows.REVISION
The individual generating the patch has to strip these additional lines to make a viable patch file.
--- a/PATH/TO/FILE.EXT
+++ b/PATH/TO/FILE.EXT
@@ -56,6 +56,7 @@
+ some new code
- some old code
See also
- /etc/portage/patches — provide a way to apply patches to package source code when sources are extracted before installation
- User:Veremit/Patch_format
- GLEP 25 - Technical information about the formal inclusion and usage of patches within portage.
External resources
- How to write clean patches when not using git-format-patch.
- Patching with eapply - Describes how ebuilds should use PATCHES=( "${FILESDIR}/mypatch.patch" "${FILESDIR}/patches_folder/" )