Project:Package Manager Specification

In the past, the ebuild environment has been defined by what Portage has supported. With the advent of alternative package managers, such a moving standard is no longer sufficient. The Package Manager Specification (PMS) aims to solve this by defining, independent of any package manager, what is and is not allowed in the tree, and what ebuilds may assume about their environment.

It is also required to document what each value of the EAPI ebuild variable actually means. At present PMS aims to document all Council-approved EAPIs.

A git repository with the document's sources can be found at:
 * Gitweb: https://gitweb.gentoo.org/proj/pms.git/
 * Git via HTTPS (read-only): https://anongit.gentoo.org/git/proj/pms.git
 * Git via SSH (read/write): git+ssh://git@git.gentoo.org/proj/pms.git

A convenient way to be up to date with the current document is the live ebuild found in the Gentoo repository, called (TeX Live needs to be installed). Additionally, the latest approved version is available as ebuild of that package. Alternatively, will install pre-built PDF and HTML files.

Generated versions of the document
Here are links to generated PDF versions of the document to make it easier for some people to read it. Approved versions of the document will be here along with those considered of interest by the PMS editors.


 * Versions approved by the Gentoo Council
 * eapi-5-approved-2012-09-20 (PDF, HTML, Cheat Sheet)
 * eapi-6-approved-2017-04-29 (PDF, HTML, Cheat Sheet)
 * eapi-7-approved-2018-04-30 (PDF, HTML, Cheat Sheet)
 * eapi-8-approved-2021-06-13 (PDF, HTML, Cheat Sheet)


 * Current HEAD (might not be completely up to date)
 * master (PDF, HTML, Cheat Sheet)

Glossary

 * Deprecated EAPI
 * A deprecated EAPI is no longer required for the upgrade path of users' systems. Its use is discouraged, and tools like pkgcheck will warn about this.


 * Banned EAPI
 * A banned EAPI must no longer be used, neither for new ebuilds, nor for updating of existing ebuilds.