Churchyard (talk | contribs) mNo edit summary |
(Redirect Package Maintainer wiki links to docs.fp.o) |
||
(3 intermediate revisions by 2 users not shown) | |||
Line 2: | Line 2: | ||
<div style="float: right; margin-left: 0.5em" class="toclimit-2">__TOC__</div> | <div style="float: right; margin-left: 0.5em" class="toclimit-2">__TOC__</div> | ||
Sometimes a package is intended to be [ | Sometimes a package is intended to be [https://docs.fedoraproject.org/en-US/package-maintainers/Package_Retirement_Process/ removed from Fedora], however it is kept in Fedora for some more (often undefined) time, mostly for backwards compatibility. In order to prevent new packages to depend on such package, packagers can mark it as '''deprecated'''. | ||
== Marking a package deprecated == | == Marking a package deprecated == | ||
Line 12: | Line 12: | ||
In order to mark a package deprecated, a special virtual provides is added: | In order to mark a package deprecated, a special virtual provides is added: | ||
Provides: deprecated( | Provides: deprecated() | ||
If the package has subpackages and the packager intends to deprecate the package as a whole, packager MUST mark all subpackages as deprecated as well. | If the package has subpackages and the packager intends to deprecate the package as a whole, packager MUST mark all subpackages as deprecated as well. | ||
Line 18: | Line 18: | ||
Name: mainpackage | Name: mainpackage | ||
... | ... | ||
Provides: deprecated( | Provides: deprecated() | ||
... | ... | ||
Line 24: | Line 24: | ||
%package subpackage | %package subpackage | ||
... | ... | ||
Provides: deprecated( | Provides: deprecated() | ||
Alternatively, a packager MAY decide to only deprecate some subpackages. | Alternatively, a packager MAY decide to only deprecate some subpackages. | ||
Line 34: | Line 34: | ||
# however lot of sysadmins still expect ifconfig to be there, so we keep it | # however lot of sysadmins still expect ifconfig to be there, so we keep it | ||
# around as a deprecated package. | # around as a deprecated package. | ||
Provides: deprecated() | |||
Provides: deprecated( | |||
If a date for the deprecation is known, it MAY be included as follows: | |||
Provides: deprecated() == YYYYMMDD | |||
== Consequences of a package being deprecated == | == Consequences of a package being deprecated == | ||
Technically, nothing is changed, a deprecated package works and behaves as before. However, other packages in Fedora MUST NOT add a dependency on a deprecated package (that includes Requires, BuildRequires, Recommends, Suggests, etc.). This applies both for updates of existing packages and new packages added to Fedora. Package Reviewer MUST check if required packages are not deprecated. | Technically, nothing is changed, a deprecated package works and behaves as before. However, other packages in Fedora MUST NOT add a dependency on a deprecated package (that includes Requires, BuildRequires, Recommends, Suggests, etc.). This applies both for updates of existing packages and new packages added to Fedora. Package Reviewer MUST check if required packages are not deprecated. There are possible exceptions for this rule, for example when the review is done as a rename of another existing package. | ||
[[Category:Packaging guidelines]] | [[Category:Packaging guidelines drafts]] |
Latest revision as of 11:08, 9 October 2021
Sometimes a package is intended to be removed from Fedora, however it is kept in Fedora for some more (often undefined) time, mostly for backwards compatibility. In order to prevent new packages to depend on such package, packagers can mark it as deprecated.
Marking a package deprecated
A package maintainer may decide to make their package deprecated only if nothing in Fedora requires it. Alternatively a packager may decide to deprecate a set of packages that are only required from within the set. Deprecating packages that are still required requires a FESCo approved Fedora change. A packager SHOULD communicate package deprecation to other packages, preferably trough the Fedora devel mailing list.
In order to mark a package deprecated, a special virtual provides is added:
Provides: deprecated()
If the package has subpackages and the packager intends to deprecate the package as a whole, packager MUST mark all subpackages as deprecated as well.
Name: mainpackage ... Provides: deprecated() ... %package subpackage ... Provides: deprecated()
Alternatively, a packager MAY decide to only deprecate some subpackages.
A packager SHOULD add a comment in the spec explaining why a package is being deprecated. For example:
# net-tools (ifconfig etc.) have been obsoleted for ~20 years upstream. # We want to get rid of it from Fedora in favor of the iproute package, # however lot of sysadmins still expect ifconfig to be there, so we keep it # around as a deprecated package. Provides: deprecated()
If a date for the deprecation is known, it MAY be included as follows:
Provides: deprecated() == YYYYMMDD
Consequences of a package being deprecated
Technically, nothing is changed, a deprecated package works and behaves as before. However, other packages in Fedora MUST NOT add a dependency on a deprecated package (that includes Requires, BuildRequires, Recommends, Suggests, etc.). This applies both for updates of existing packages and new packages added to Fedora. Package Reviewer MUST check if required packages are not deprecated. There are possible exceptions for this rule, for example when the review is done as a rename of another existing package.