forked from rpms/glibc
glibc-2.23.90-3
- Enhance support for upgrading from a non-language-pack system.
This commit is contained in:
parent
9edc2b688b
commit
f2d40207ea
86
glibc.spec
86
glibc.spec
@ -1,6 +1,6 @@
|
|||||||
%define glibcsrcdir glibc-2.23-40-gde51ff8
|
%define glibcsrcdir glibc-2.23-40-gde51ff8
|
||||||
%define glibcversion 2.23.90
|
%define glibcversion 2.23.90
|
||||||
%define glibcrelease 2%{?dist}
|
%define glibcrelease 3%{?dist}
|
||||||
# Pre-release tarballs are pulled in from git using a command that is
|
# Pre-release tarballs are pulled in from git using a command that is
|
||||||
# effectively:
|
# effectively:
|
||||||
#
|
#
|
||||||
@ -436,6 +436,18 @@ BuildRequires: glibc-static
|
|||||||
# the package and should not be examined by any other tool.
|
# the package and should not be examined by any other tool.
|
||||||
%global __filter_GLIBC_PRIVATE 1
|
%global __filter_GLIBC_PRIVATE 1
|
||||||
|
|
||||||
|
# For language packs we have glibc require a virtual dependency
|
||||||
|
# "glibc-langpack" wich gives us at least one installed langpack.
|
||||||
|
# If no langpack providing 'glibc-langpack' was installed you'd
|
||||||
|
# get all of them, and that would make the transition from a
|
||||||
|
# system without langpacks smoother (you'd get all the locales
|
||||||
|
# installed). You would then trim that list, and the trimmed list
|
||||||
|
# is preserved. One problem is you can't have "no" locales installed,
|
||||||
|
# in that case we offer a "glibc-minimal-langpack" sub-pakcage for
|
||||||
|
# this purpose.
|
||||||
|
Requires: glibc-langpack = %{version}-%{release}
|
||||||
|
Suggests: glibc-all-langpacks = %{version}-%{release}
|
||||||
|
|
||||||
%description
|
%description
|
||||||
The glibc package contains standard libraries which are used by
|
The glibc package contains standard libraries which are used by
|
||||||
multiple programs on the system. In order to save disk space and
|
multiple programs on the system. In order to save disk space and
|
||||||
@ -559,9 +571,9 @@ these sources as the basis for your new locale.
|
|||||||
%define lang_package()\
|
%define lang_package()\
|
||||||
%package langpack-%{1}\
|
%package langpack-%{1}\
|
||||||
Summary: Locale data for %{1}\
|
Summary: Locale data for %{1}\
|
||||||
|
Provides: glibc-langpack = %{version}-%{release}\
|
||||||
Requires: %{name} = %{version}-%{release}\
|
Requires: %{name} = %{version}-%{release}\
|
||||||
Requires: %{name}-common = %{version}-%{release}\
|
Requires: %{name}-common = %{version}-%{release}\
|
||||||
Requires: tzdata >= 2003a\
|
|
||||||
%define supplements_list %(cat %{SOURCE11} | grep ^%{1}_ | cut -d / -f 1 | cut -d @ -f 1 | cut -d . -f 1 | sort -u | tr "\\\\n" " " | sed 's/ $//' | sed 's/ / or langpacks-/g' | sed 's/^/ or langpacks-/')\
|
%define supplements_list %(cat %{SOURCE11} | grep ^%{1}_ | cut -d / -f 1 | cut -d @ -f 1 | cut -d . -f 1 | sort -u | tr "\\\\n" " " | sed 's/ $//' | sed 's/ / or langpacks-/g' | sed 's/^/ or langpacks-/')\
|
||||||
Supplements: (glibc = %{version}-%{release} and (langpacks-%{1}%{supplements_list}))\
|
Supplements: (glibc = %{version}-%{release} and (langpacks-%{1}%{supplements_list}))\
|
||||||
Group: System Environment/Base\
|
Group: System Environment/Base\
|
||||||
@ -598,14 +610,36 @@ string.gsub(languages, "(%a+)",\
|
|||||||
function(i) print(rpm.expand("Requires: %{name}-langpack-"..i.." = %{version}-%{release}\\n")) end)}\
|
function(i) print(rpm.expand("Requires: %{name}-langpack-"..i.." = %{version}-%{release}\\n")) end)}\
|
||||||
%{nil}
|
%{nil}
|
||||||
|
|
||||||
|
# The glibc-all-langpacks provides the virtual glibc-langpack,
|
||||||
|
# and thus satisfies glibc's requirement for installed locales.
|
||||||
|
# Users can add one more other langauge packs and then eventually
|
||||||
|
# uninstall all-langpacks to save space.
|
||||||
%package all-langpacks
|
%package all-langpacks
|
||||||
Summary: Meta package to require all langpacks
|
Summary: All language packs for %{name}.
|
||||||
Group: System Environment/Base
|
Group: System Environment/Base
|
||||||
%require_langpacks %language_list
|
Requires: %{name} = %{version}-%{release}
|
||||||
|
Requires: %{name}-common = %{version}-%{release}
|
||||||
|
Provides: %{name}-langpack = %{version}-%{release}
|
||||||
%description all-langpacks
|
%description all-langpacks
|
||||||
Meta package that requires all language packs.
|
|
||||||
|
# No %files, this is an empty pacakge. The C/POSIX and
|
||||||
|
# C.UTF-8 files are already installed by glibc. We create
|
||||||
|
# minimal-langpack because the virtual provide of
|
||||||
|
# glibc-langpack needs at least one package installed
|
||||||
|
# to satisfy it. Given that no-locales installed is a valid
|
||||||
|
# use case we support it here with this package.
|
||||||
|
%package minimal-langpack
|
||||||
|
Summary: Minimal language packs for %{name}.
|
||||||
|
Group: System Environment/Base
|
||||||
|
Provides: glibc-langpack = %{version}-%{release}
|
||||||
|
Requires: %{name} = %{version}-%{release}
|
||||||
|
Requires: %{name}-common = %{version}-%{release}
|
||||||
|
%description minimal-langpack
|
||||||
|
This is a Meta package that is used to install minimal language packs.
|
||||||
|
This package ensures you can use C, POSIX, or C.UTF-8 locales, but
|
||||||
|
nothing else. It is designed for assembling a minimal system.
|
||||||
%ifnarch %{auxarches}
|
%ifnarch %{auxarches}
|
||||||
%files all-langpacks
|
%files minimal-langpack
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
@ -1171,6 +1205,15 @@ rm -f $RPM_BUILD_ROOT%{_infodir}/libc.info*
|
|||||||
olddir=`pwd`
|
olddir=`pwd`
|
||||||
pushd ${RPM_BUILD_ROOT}%{_prefix}/lib/locale
|
pushd ${RPM_BUILD_ROOT}%{_prefix}/lib/locale
|
||||||
rm -f locale-archive
|
rm -f locale-archive
|
||||||
|
# Intentionally we do not pass --alias-file=, aliases will be added
|
||||||
|
# by build-locale-archive.
|
||||||
|
$olddir/build-%{target}/elf/ld.so \
|
||||||
|
--library-path $olddir/build-%{target}/ \
|
||||||
|
$olddir/build-%{target}/locale/localedef \
|
||||||
|
--prefix ${RPM_BUILD_ROOT} --add-to-archive \
|
||||||
|
*_*
|
||||||
|
# Setup the locale-archive template for use by glibc-all-langpacks.
|
||||||
|
mv locale-archive{,.tmpl}
|
||||||
# Create the file lists for the language specific sub-packages:
|
# Create the file lists for the language specific sub-packages:
|
||||||
for i in *_*
|
for i in *_*
|
||||||
do
|
do
|
||||||
@ -1697,6 +1740,10 @@ touch $RPM_BUILD_ROOT/var/run/nscd/{socket,nscd.pid}
|
|||||||
|
|
||||||
%endif # %{auxarches}
|
%endif # %{auxarches}
|
||||||
|
|
||||||
|
%ifnarch %{auxarches}
|
||||||
|
truncate -s 0 $RPM_BUILD_ROOT/%{_prefix}/lib/locale/locale-archive
|
||||||
|
%endif
|
||||||
|
|
||||||
mkdir -p $RPM_BUILD_ROOT/var/cache/ldconfig
|
mkdir -p $RPM_BUILD_ROOT/var/cache/ldconfig
|
||||||
truncate -s 0 $RPM_BUILD_ROOT/var/cache/ldconfig/aux-cache
|
truncate -s 0 $RPM_BUILD_ROOT/var/cache/ldconfig/aux-cache
|
||||||
|
|
||||||
@ -1854,7 +1901,25 @@ end
|
|||||||
|
|
||||||
%postun -p /sbin/ldconfig
|
%postun -p /sbin/ldconfig
|
||||||
|
|
||||||
%post common -p <lua>
|
%posttrans all-langpacks -p <lua>
|
||||||
|
-- If at the end of the transaction we are still installed
|
||||||
|
-- (have a template of non-zero size), then we rebuild the
|
||||||
|
-- locale cache (locale-archive) from the pre-populated
|
||||||
|
-- locale cache (locale-archive.tmpl) i.e. template.
|
||||||
|
if posix.stat("%{_prefix}/lib/locale/locale-archive.tmpl", "size") > 0 then
|
||||||
|
pid = posix.fork()
|
||||||
|
if pid == 0 then
|
||||||
|
posix.exec("%{_prefix}/sbin/build-locale-archive", "--install-langs", rpm.expand("%%{_install_langs}"))
|
||||||
|
elseif pid > 0 then
|
||||||
|
posix.wait(pid)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
%postun all-langpacks -p <lua>
|
||||||
|
-- In the postun we always remove the locale cache.
|
||||||
|
-- We are being uninstalled and if this is an upgrade
|
||||||
|
-- then the new packages template will be used to
|
||||||
|
-- recreate a new copy of the cache.
|
||||||
os.remove("%{_prefix}/lib/locale/locale-archive")
|
os.remove("%{_prefix}/lib/locale/locale-archive")
|
||||||
|
|
||||||
%if %{with docs}
|
%if %{with docs}
|
||||||
@ -1962,6 +2027,10 @@ rm -f *.filelist*
|
|||||||
%verify(not md5 size mtime) %config(noreplace) /etc/default/nss
|
%verify(not md5 size mtime) %config(noreplace) /etc/default/nss
|
||||||
%doc documentation/*
|
%doc documentation/*
|
||||||
|
|
||||||
|
%files all-langpacks
|
||||||
|
%attr(0644,root,root) %verify(not md5 size mtime) %{_prefix}/lib/locale/locale-archive.tmpl
|
||||||
|
%attr(0644,root,root) %verify(not md5 size mtime mode) %ghost %config(missingok,noreplace) %{_prefix}/lib/locale/locale-archive
|
||||||
|
|
||||||
%files locale-source
|
%files locale-source
|
||||||
%defattr(-,root,root)
|
%defattr(-,root,root)
|
||||||
%dir %{_prefix}/share/i18n/locales
|
%dir %{_prefix}/share/i18n/locales
|
||||||
@ -2019,6 +2088,9 @@ rm -f *.filelist*
|
|||||||
%endif
|
%endif
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Feb 29 2016 Carlos O'Donell <carlos@redhat.com> - 2.23.90-3
|
||||||
|
- Enhance support for upgrading from a non-language-pack system.
|
||||||
|
|
||||||
* Fri Feb 26 2016 Mike FABIAN <mfabian@redhat.com> - 2.23.90-2
|
* Fri Feb 26 2016 Mike FABIAN <mfabian@redhat.com> - 2.23.90-2
|
||||||
- Create new language packages for all supported languages.
|
- Create new language packages for all supported languages.
|
||||||
Locales, translations, and locale sources are split into
|
Locales, translations, and locale sources are split into
|
||||||
|
Loading…
Reference in New Issue
Block a user