commit:     8780fff0f2a923ea747f4fb180263562d32f7580
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Mar 24 04:14:59 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Mar 24 04:14:59 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=8780fff0

sys-libs/timezone-data: add 2023b

Signed-off-by: Sam James <sam <AT> gentoo.org>

 sys-libs/timezone-data/Manifest                   |   2 +
 sys-libs/timezone-data/timezone-data-2023b.ebuild | 197 ++++++++++++++++++++++
 2 files changed, 199 insertions(+)

diff --git a/sys-libs/timezone-data/Manifest b/sys-libs/timezone-data/Manifest
index 7400a616e1ec..ac23c2e4cc91 100644
--- a/sys-libs/timezone-data/Manifest
+++ b/sys-libs/timezone-data/Manifest
@@ -1,4 +1,6 @@
 DIST tzcode2022g.tar.gz 287901 BLAKE2B 
b67bb2020913c57cc6bc68d231c53ba645b95305256065e2645bce3b0d71adfaea865ed9bf40f1ec3b4a73aad7e6c48f5ecd0895de6e2d69bed6113d6b579e26
 SHA512 
5188edd8d05238a88da734cf78fadfb57640d4db3e7a0a9dddd70e3071e16b6eebc2e2ab17109b7dafafae68abfbc857df481cfdc3ffe63f7eb1569ea0b5997a
 DIST tzcode2023a.tar.gz 292438 BLAKE2B 
090d80ddaf580e5638175cb511f8da0644886b6eb8c38dc1b2b3c854be30e9caec980ae0dcc2034471bef7b15abee6ce83901977bf3b8697651f6711573e1575
 SHA512 
d45fc677a0a32ae807bf421faceff675565ee15e3ff42d3a4121df10e1f7855ac16b27fbc28bd365f93c57f40c5bdf19cde88546f7090cfab7676cac0a5516a4
+DIST tzcode2023b.tar.gz 292492 BLAKE2B 
a6b8f7706114257d1ed28651f59b099a4f1f830c55f53de270a2438639b5ca61145f8561eb487d4a745833f7782e61b0478cb81517a00e42539638337bae3120
 SHA512 
94058ceabfdaa62eeff9be804a030f0eb95b4099b62fbb7e55557e8b934c8d883f488a3a6996331e24aebd147d66c19a73fb925a3dd929c630a9e11b51003b7f
 DIST tzdata2022g.tar.gz 439731 BLAKE2B 
582b79cc2317d27f3883042cbca25801397d9e2808ad8d3a340017d635372ef20316ce646a25a43b0ea5d4024841b54925ecc4510613295c39c28647989645cb
 SHA512 
7f79394295e00e3a24ebdbf9af3bc454a65f432a93b517e7e96c7f9db9949f6f5fdae9892a9d3789ff44ae0eb1bfe4744d36976b4624659af951d26414f94e65
 DIST tzdata2023a.tar.gz 442875 BLAKE2B 
33dd386d37a6349c9f9e60694c43323e97c9ba2cc6ca8f7f3a27c96734c1f6281e08748f1676e9fb4162d75202c9d38910caa28475bcb7414283b5991053d096
 SHA512 
10aadd6eba50f63f427399281065ba34cb474f6a854f8dc7a6f4f1343b1474a05f22b69b1e113ea67bb5f3f479253610a16b89d9dfa157bf0fde4c69aa3d6493
+DIST tzdata2023b.tar.gz 443019 BLAKE2B 
2738f4248882c771b85de7001ce350136df904ff978e2b5b77c28b4b2a9034b3b5a4fcfa87cc472299f701209922ecc21219e5d1bdeb1c87124988979d2f9672
 SHA512 
0f697b872ef02109d2098db12d0effc834b2ac5438921e0867f2c70987f305a47dc3eac720c344bb3757c902a7653109621e943564bdfbf00937077c311aa29b

diff --git a/sys-libs/timezone-data/timezone-data-2023b.ebuild 
b/sys-libs/timezone-data/timezone-data-2023b.ebuild
new file mode 100644
index 000000000000..0c77ada9e0ad
--- /dev/null
+++ b/sys-libs/timezone-data/timezone-data-2023b.ebuild
@@ -0,0 +1,197 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit toolchain-funcs flag-o-matic
+
+MY_CODE_VER=${PV}
+MY_DATA_VER=${PV}
+DESCRIPTION="Timezone data (/usr/share/zoneinfo) and utilities 
(tzselect/zic/zdump)"
+HOMEPAGE="https://www.iana.org/time-zones";
+SRC_URI="https://www.iana.org/time-zones/repository/releases/tzdata${MY_DATA_VER}.tar.gz
+       
https://www.iana.org/time-zones/repository/releases/tzcode${MY_CODE_VER}.tar.gz";
+
+LICENSE="BSD public-domain"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~m68k ~mips ~ppc ~ppc64 
~riscv ~s390 ~sparc ~x86 ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos 
~x64-macos ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
+IUSE="nls leaps-timezone zic-slim"
+
+DEPEND="nls? ( virtual/libintl )"
+RDEPEND="
+       ${DEPEND}
+       !sys-libs/glibc[vanilla(+)]
+"
+
+src_unpack() {
+       mkdir "${S}" && cd "${S}" || die
+       default
+}
+
+src_prepare() {
+       default
+
+       # check_web contacts validator.w3.org
+       sed -i -e 's/check_tables check_web/check_tables/g' \
+               Makefile || die "Failed to disable check_web"
+
+       if tc-is-cross-compiler ; then
+               cp -pR "${S}" "${S}"-native || die
+       fi
+}
+
+src_configure() {
+       tc-export CC
+
+       # bug #471102
+       append-lfs-flags
+
+       if use elibc_Darwin ; then
+               # bug #138251
+               append-cppflags -DSTD_INSPIRED
+       fi
+
+       append-cppflags -DHAVE_GETTEXT=$(usex nls 1 0) -DTZ_DOMAIN='\"libc\"'
+
+       # Upstream default is 'slim', but it breaks quite a few programs
+       # that parse /etc/localtime directly: bug #747538.
+       append-cppflags -DZIC_BLOAT_DEFAULT='\"'$(usex zic-slim slim fat)'\"'
+
+       LDLIBS=""
+       if use nls ; then
+               # See if an external libintl is available. bug #154181, bug 
#578424
+               local c="${T}/test"
+               echo 'main(){}' > "${c}.c" || die
+               if $(tc-getCC) ${CPPFLAGS} ${CFLAGS} ${LDFLAGS} "${c}.c" -o 
"${c}" -lintl 2>/dev/null ; then
+                       LDLIBS+=" -lintl"
+               fi
+       fi
+}
+
+_emake() {
+       emake \
+               REDO=$(usex leaps-timezone posix_right posix_only) \
+               TOPDIR="${EPREFIX}" \
+               ZICDIR='$(TOPDIR)/usr/bin' \
+               "$@"
+}
+
+src_compile() {
+       _emake \
+               AR="$(tc-getAR)" \
+               cc="$(tc-getCC)" \
+               RANLIB="$(tc-getRANLIB)" \
+               CFLAGS="${CFLAGS} -std=gnu99 ${CPPFLAGS}" \
+               LDFLAGS="${LDFLAGS}" \
+               LDLIBS="${LDLIBS}"
+
+       if tc-is-cross-compiler ; then
+               _emake -C "${S}"-native \
+                       AR="$(tc-getBUILD_AR)" \
+                       cc="$(tc-getBUILD_CC)" \
+                       RANLIB="$(tc-getBUILD_RANLIB)" \
+                       CFLAGS="${BUILD_CFLAGS} ${BUILD_CPPFLAGS}" \
+                       LDFLAGS="${BUILD_LDFLAGS}" \
+                       LDLIBS="${LDLIBS}" \
+                       zic
+       fi
+}
+
+src_test() {
+       # VALIDATE_ENV is used for extended/web based tests. Punt on them.
+       emake check VALIDATE_ENV=true
+}
+
+src_install() {
+       local zic=""
+       tc-is-cross-compiler && zic="zic=${S}-native/zic"
+       _emake install ${zic} DESTDIR="${D}" LIBDIR="/nukeit"
+       rm -rf "${D}/nukeit" "${ED}/etc" || die
+
+       insinto /usr/share/zoneinfo
+       doins "${S}"/leap-seconds.list
+
+       # Delete man pages installed by man-pages package.
+       rm "${ED}"/usr/share/man/man5/tzfile.5* 
"${ED}"/usr/share/man/man8/{tzselect,zdump,zic}.8 || die
+       dodoc CONTRIBUTING README NEWS *.html
+}
+
+get_TIMEZONE() {
+       local tz src="${EROOT}/etc/timezone"
+       if [[ -e ${src} ]] ; then
+               tz=$(sed -e 's:#.*::' -e 's:[[:space:]]*::g' -e '/^$/d' 
"${src}")
+       else
+               tz="FOOKABLOIE"
+       fi
+
+       [[ -z ${tz} ]] && return 1 || echo "${tz}"
+}
+
+pkg_preinst() {
+       local tz=$(get_TIMEZONE)
+       if [[ ${tz} == right/* || ${tz} == posix/* ]] ; then
+               eerror "The right & posix subdirs are no longer installed as 
subdirs -- they have been"
+               eerror "relocated to match upstream paths as sibling paths.  
Further, posix/xxx is the"
+               eerror "same as xxx, so you should simply drop the posix/ 
prefix.  You also should not"
+               eerror "be using right/xxx for the system timezone as it breaks 
programs."
+               die "Please fix your timezone setting"
+       fi
+
+       # Trim the symlink by hand to avoid portage's automatic protection 
checks.
+       rm -f "${EROOT}"/usr/share/zoneinfo/posix
+}
+
+configure_tz_data() {
+       # Make sure the /etc/localtime file does not get stale, bug #127899
+       local tz src="${EROOT}/etc/timezone" etc_lt="${EROOT}/etc/localtime"
+
+       # If it's a symlink, assume the user knows what they're doing and
+       # they're managing it themselves, bug #511474
+       if [[ -L "${etc_lt}" ]] ; then
+               einfo "Assuming your ${etc_lt} symlink is what you want; 
skipping update."
+               return 0
+       fi
+
+       if ! tz=$(get_TIMEZONE) ; then
+               einfo "Assuming your empty ${src} file is what you want; 
skipping update."
+               return 0
+       fi
+
+       if [[ "${tz}" == "FOOKABLOIE" ]] ; then
+               einfo "You do not have a timezone set in ${src}; skipping 
update."
+               return 0
+       fi
+
+       local tzpath="${EROOT}/usr/share/zoneinfo/${tz}"
+
+       if [[ ! -e ${tzpath} ]]; then
+               ewarn "The timezone specified in ${src} is not valid!"
+               return 1
+       fi
+
+       if [[ -f ${etc_lt} ]]; then
+               # If a regular file already exists, copy over it.
+               ewarn "Found a regular file at ${etc_lt}."
+               ewarn "Some software may expect a symlink instead."
+               ewarn "You may convert it to a symlink by removing the file and 
running:"
+               ewarn "  emerge --config sys-libs/timezone-data"
+               einfo "Copying ${tzpath} to ${etc_lt}."
+               cp -f "${tzpath}" "${etc_lt}"
+       else
+               # Otherwise, create a symlink and remove the timezone file.
+               tzpath="../usr/share/zoneinfo/${tz}"
+               einfo "Linking ${tzpath} at ${etc_lt}."
+               if ln -snf "${tzpath}" "${etc_lt}"; then
+                       einfo "Removing ${src}."
+                       rm -f "${src}"
+               fi
+       fi
+}
+
+pkg_config() {
+       configure_tz_data
+}
+
+pkg_postinst() {
+       configure_tz_data
+}

Reply via email to