π perl Package to Install Core Modules
π Summary
dnf install perl
will install all core Perl modules that come with Perl upstream sources.
π Owner
- Name: Petr PΓsaΕ
- Email: <ppisar@redhat.com>
- Release notes owner:
π Current status
π Completed items
- Provide perl-interpreter symbol in F27
- Provide perl-interpreter symbol in F25
π Items in progress
- Provide perl-interpreter symbol in F26
- Provide perl-interpreter symbol in F24
π Items to be done
- Replace perl to perl-interpreter build-time dependency in all F27 spec files
- Replace perl to perl-interpreter run-time dependency in all F27 spec files and rebuild them
- Rename perl to perl-interpreter and perl-core to perl in perl.spec
π Detailed Description
Upstream releases Perl interpreter together with many Perl modules. This set of modules is called core modules. Fedora splits the modules into subpackages so that installing perl package results in a stripped-down set of modules. Fedora documents this as a feature and provides perl-core metapackage that allows installing all the core modules as is intended by upstream.
Unfortunately this seems to be confusing to Perl users because Fedora is the only distribution doing so.
To align Fedora's behavior to upstream and other distributions this change will rename perl package to perl-interpreter and perl-core package to perl. This will allow installing all core Perl modules with dnf install perl
while still retain the possibility to install only a minimal perl interpreter (/usr/bin/perl) with dnf install perl-interpreter
.
This change will also update Fedora Packaging Guidelines for Perl and all spec files that require perl to use perl-interpreter instead. There is only 81 binary packages affected. They will rebuilt. Otherwise no mass rebuild won't be necessary.
To ease sharing spec files with older Fedoras, perl-interpreter provide will add to perl package there.
π Benefit to Fedora
Fedora's Perl becomes more similar to other distributions. Installing perl package will be enough to get full user experience intended by Perl upstream.
π Scope
- Proposal owners:
- Submit Fedora Packaging Guidelines for Perl update to Fedora Packaging Committee.
- Update and rebuild perl source package.
- Add Provides: perl-interpreter to perl package in older Fedoras.
- Replace BuildRequires and Requires for perl with perl-interpreter in all spec files.
- Rebuild packages with replaced Requires to propagate the change to repositories.
- Replace perl-core with perl in compose groups definition.
- Other developers: Get familiar with new Fedora Packaging Guidelines for Perl.
- Release engineering: No action needed. Request to check of an impact with Release Engeneering.
- List of deliverables: Anything what contains perl package
- Policies and guidelines: Fedora Packaging Guidelines for Perl update request to use perl and perl-interpreter instead of perl-core and perl.
- Trademark approval: N/A (not needed for this Change)
π Upgrade/compatibility impact
Users that explicitly installed perl package will get installed additional packages as if they had installed perl-core package. This can be fixed by uninstalling perl package manually.
π How To Test
Install perl package. This makes available all Perl modules as listed in corelist -v 5.26.0
output (without modules specific for other operating systems).
π User Experience
dnf install perl
will install all core Perl modules.
π Dependencies
This change will affect 2302 source packages and 81 binary packages. Their spec files will be updated. The 81 binary packages will be rebuilt. There is no dependency on other Fedora changes.
π Contingency Plan
- Contingency mechanism: The change will be reverted.
- Contingency deadline: Any time.
- Blocks release? No.
- Blocks product? No.
π Documentation
- Build Dependencies section of Fedora Packaging Guidelines for Perl
- Build Dependencies section of propsed Fedora Packaging Guidelines for Perl
- FPC request to update Fedora Packaging Guidelines for Perl
- Releng request to check of the impact
- perl-devel mailing list discussion
- devel mailing list discussion