Hi, you can put any patches to a dir pointed by epatch (EPATCH_SOURCE) and portage doesn't check for digest in Manifest. Example: archer ~ # touch /usr/portage/app-doc/doxygen/files/1.4.7/02_all_hack.patch ; emerge doxygen Calculating dependencies... done! >>> Emerging (1 of 1) app-doc/doxygen-1.4.7 to / * doxygen-1.4.7.src.tar.gz MD5 ;-) ... [ ok ] * doxygen-1.4.7.src.tar.gz RMD160 ;-) ... [ ok ] * doxygen-1.4.7.src.tar.gz SHA1 ;-) ... [ ok ] * doxygen-1.4.7.src.tar.gz SHA256 ;-) ... [ ok ] * doxygen-1.4.7.src.tar.gz size ;-) ... [ ok ] * checking ebuild checksums ;-) ... [ ok ] * checking auxfile checksums ;-) ... [ ok ] * checking miscfile checksums ;-) ... [ ok ] * checking doxygen-1.4.7.src.tar.gz ;-) ... [ ok ] >>> Unpacking source... >>> Unpacking doxygen-1.4.7.src.tar.gz to /var/tmp/portage/doxygen-1.4.7/work * Applying various patches (bugfixes/updates) ... * 01_all_cp1251.patch ... [ ok ] * 02_all_hack.patch ... [ ok ] * 05_all_system-libpng.patch ... [ ok ] * 06_all_qtools.patch ... [ ok ] * Done with patching >>> Source unpacked. >>> Compiling source in /var/tmp/portage/doxygen-1.4.7/work/doxygen-1.4.7 ... <cut> You can put any patches here, not only blank file
1/ epatch doesn't check any digests, it's an eutils.eclass wrapper around patch and it's none of its business to do anything about digests. 2/ PORTDIR is only writeable by root, at which point you are already doomed if someone else gained root privs, fail to see your point here???
The file would be listed in the Manifest and checked if it had been official. Our official ebuilds won't go looking for files that aren't listed in the Manifest.
I didn't realize that epatch would just grab all the files in a directory like that. Anyway, only privileged users should have write permission in $FILESDIR, normally. That leaves you open to attack from a compromised mirror, but you can't protect yourself from that unless we implement checking of gpg signatures on signed manifests.
(In reply to comment #3) Yes sorry it's my fault, i need to be more clear the next time (thanks exg)
This is fixed in svn r4655.
This has been released in 2.1.2_pre2-r9.