diff options
author | Damian Perticone <mjolnirdam@gmail.com> | 2022-04-26 05:06:35 +0100 |
---|---|---|
committer | Willy Sudiarto Raharjo <willysr@slackbuilds.org> | 2022-04-30 13:51:52 +0700 |
commit | bdcc683d4e9822cfe91f86fd7632810a2c0abf4e (patch) | |
tree | 82c98f5a801520cf02d72dd2411afe3920b60d7f | |
parent | 1a90621cd7d7b252ee58a0970381d7a6d3ce8998 (diff) |
libraries/date: Added (date and time library)
Signed-off-by: Dave Woodfall <dave@slackbuilds.org>
Signed-off-by: Willy Sudiarto Raharjo <willysr@slackbuilds.org>
-rw-r--r-- | libraries/date/052eebaf0086e6bbc5ead01c3f1a8f02496aa701.patch | 29 | ||||
-rw-r--r-- | libraries/date/538-output-date-pc-for-pkg-config.patch | 60 | ||||
-rw-r--r-- | libraries/date/README | 26 | ||||
-rw-r--r-- | libraries/date/b49a7575ebbe127e8bd344900a52c14b5d69dd7b.patch | 24 | ||||
-rw-r--r-- | libraries/date/date.SlackBuild | 122 | ||||
-rw-r--r-- | libraries/date/date.info | 10 | ||||
-rw-r--r-- | libraries/date/disable_buggy_libstdc++_tests.patch | 30 | ||||
-rw-r--r-- | libraries/date/slack-desc | 19 |
8 files changed, 320 insertions, 0 deletions
diff --git a/libraries/date/052eebaf0086e6bbc5ead01c3f1a8f02496aa701.patch b/libraries/date/052eebaf0086e6bbc5ead01c3f1a8f02496aa701.patch new file mode 100644 index 0000000000000..d7edfa0a4b5f4 --- /dev/null +++ b/libraries/date/052eebaf0086e6bbc5ead01c3f1a8f02496aa701.patch @@ -0,0 +1,29 @@ +From 052eebaf0086e6bbc5ead01c3f1a8f02496aa701 Mon Sep 17 00:00:00 2001 +From: Howard Hinnant <howard.hinnant@gmail.com> +Date: Tue, 18 May 2021 16:17:37 -0400 +Subject: [PATCH] When comparing sys_info in test... only compare whether the + saves are equal to 0 and not their actual values. + +This allows one to compare against the binary database +which does not contain actual values of save. +--- + test/posix/ptz.pass.cpp | 3 ++- + 1 file changed, 2 insertions(+), 1 deletion(-) + +diff --git a/test/posix/ptz.pass.cpp b/test/posix/ptz.pass.cpp +index 5601c21d..9e15e3a9 100644 +--- a/test/posix/ptz.pass.cpp ++++ b/test/posix/ptz.pass.cpp +@@ -29,10 +29,11 @@ + bool + is_equal(date::sys_info const& x, date::sys_info const& y) + { ++ using namespace std::chrono; + return x.begin == y.begin && + x.end == y.end && + x.offset == y.offset && +- x.save == y.save && ++ (x.save == minutes{0}) == (y.save == minutes{0}) && + x.abbrev == y.abbrev; + } + diff --git a/libraries/date/538-output-date-pc-for-pkg-config.patch b/libraries/date/538-output-date-pc-for-pkg-config.patch new file mode 100644 index 0000000000000..d20af66b16dca --- /dev/null +++ b/libraries/date/538-output-date-pc-for-pkg-config.patch @@ -0,0 +1,60 @@ +From e56b2dce7e89a92e1b9b35caa13b3e938c4cedea Mon Sep 17 00:00:00 2001 +From: Cole Mickens <cole.mickens@gmail.com> +Date: Sun, 26 Jan 2020 01:27:08 -0800 +Subject: [PATCH] CMakeLists.txt: output date.pc for pkg-config + +--- + CMakeLists.txt | 15 +++++++++++++++ + date.pc.in | 10 ++++++++++ + 2 files changed, 25 insertions(+) + create mode 100644 date.pc.in + +diff --git a/CMakeLists.txt b/CMakeLists.txt +index f30c473..fe778e8 100644 +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -128,6 +128,15 @@ if( BUILD_TZ_LIB ) + endif( ) + endif( ) + ++if ( BUILD_TZ_LIB ) ++ # Cflags: -I${includedir} @TZ_COMPILE_DEFINITIONS@ ++ set( TZ_COMPILE_DEFINITIONS "$<IF:$<TARGET_EXISTS:date-tz>,-D$<JOIN:$<TARGET_PROPERTY:date-tz,INTERFACE_COMPILE_DEFINITIONS>, -D>,>" ) ++ configure_file(date.pc.in date.pc.cf @ONLY) ++ file( GENERATE OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/date.pc" ++ INPUT "${CMAKE_CURRENT_BINARY_DIR}/date.pc.cf" ) ++ ++endif( ) ++ + #[===================================================================[ + installation + #]===================================================================] +@@ -171,6 +180,12 @@ install ( + FILES cmake/dateConfig.cmake "${version_config}" + DESTINATION ${CONFIG_LOC}) + ++if ( BUILD_TZ_LIB ) ++ install( ++ FILES ${CMAKE_BINARY_DIR}/date.pc ++ DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig) ++endif( ) ++ + #[===================================================================[ + testing + #]===================================================================] +diff --git a/date.pc.in b/date.pc.in +new file mode 100644 +index 0000000..b9c4623 +--- /dev/null ++++ b/date.pc.in +@@ -0,0 +1,10 @@ ++prefix=@CMAKE_INSTALL_PREFIX@ ++exec_prefix=@CMAKE_INSTALL_BINDIR@ ++libdir=@CMAKE_INSTALL_LIB@ ++includedir=@CMAKE_INSTALL_INCLUDE@ ++ ++Name: date ++Description: A date and time library based on the C++11/14/17 <chrono> header ++Version: @PACKAGE_VERSION@ ++Libs: -L${libdir} -ldate-tz ++Cflags: -I${includedir} @TZ_COMPILE_DEFINITIONS@ diff --git a/libraries/date/README b/libraries/date/README new file mode 100644 index 0000000000000..6ab91e8d4a8c0 --- /dev/null +++ b/libraries/date/README @@ -0,0 +1,26 @@ +This is actually several separate C++11/C++14/C++17 libraries: + +"date.h" is a header-only library which builds upon <chrono>. It adds +some new duration types, and new time_point types. It also adds +"field" types such as year_month_day which is a struct +{year, month, day}. And it provides convenient means to convert between +the "field" types and the time_point types. + +"tz.h" / "tz.cpp" are a timezone library built on top of the "date.h" +library. +This timezone library is a complete parser of the IANA timezone +database. It provides for an easy way to access all of the data in this +database, using the types from "date.h" and <chrono>. The IANA database + also includes data on leap seconds, and this library provides utilities +to compute with that information as well. + +"iso_week.h" is a header-only library built on top of the "date.h" +library which implements the ISO week date calendar. + +"julian.h" is a header-only library built on top of the "date.h" library +which implements a proleptic Julian calendar which is fully +interoperable with everything above. + +"islamic.h" is a header-only library built on top of the "date.h" +library which implements a proleptic Islamic calendar which is fully +interoperable with everything above. diff --git a/libraries/date/b49a7575ebbe127e8bd344900a52c14b5d69dd7b.patch b/libraries/date/b49a7575ebbe127e8bd344900a52c14b5d69dd7b.patch new file mode 100644 index 0000000000000..5ce6f15f6d266 --- /dev/null +++ b/libraries/date/b49a7575ebbe127e8bd344900a52c14b5d69dd7b.patch @@ -0,0 +1,24 @@ +From b49a7575ebbe127e8bd344900a52c14b5d69dd7b Mon Sep 17 00:00:00 2001 +From: Howard Hinnant <howard.hinnant@gmail.com> +Date: Tue, 18 May 2021 16:15:31 -0400 +Subject: [PATCH] Zero initialize local_info in get_info + +* Even when the result is unique, the second sys_info + should be zero initialized. +--- + src/tz.cpp | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/src/tz.cpp b/src/tz.cpp +index 26babbd9..1592bc8f 100644 +--- a/src/tz.cpp ++++ b/src/tz.cpp +@@ -2164,7 +2164,7 @@ time_zone::get_info_impl(local_seconds tp) const + { + using namespace std::chrono; + init(); +- local_info i; ++ local_info i{}; + i.result = local_info::unique; + auto tr = upper_bound(transitions_.begin(), transitions_.end(), tp, + [](const local_seconds& x, const transition& t) diff --git a/libraries/date/date.SlackBuild b/libraries/date/date.SlackBuild new file mode 100644 index 0000000000000..f26c3536db247 --- /dev/null +++ b/libraries/date/date.SlackBuild @@ -0,0 +1,122 @@ +#!/bin/bash + +# Slackware build script for date + +# Copyright 2022 Damian Perticone Berisso, Argentina +# All rights reserved. +# thanks for the cmake hint OXBG! + +# Redistribution and use of this script, with or without modification, is +# permitted provided that the following conditions are met: +# +# 1. Redistributions of this script must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED +# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO +# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; +# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR +# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF +# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +cd $(dirname $0) ; CWD=$(pwd) + +PRGNAM=date +VERSION=${VERSION:-3.0.1} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} +PKGTYPE=${PKGTYPE:-tgz} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i586 ;; + arm*) ARCH=arm ;; + + *) ARCH=$( uname -m ) ;; + esac +fi + +if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then + echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE" + exit 0 +fi + +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +if [ "$ARCH" = "i586" ]; then + SLKCFLAGS="-O2 -march=i586 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $PRGNAM-$VERSION +tar xvf $CWD/$PRGNAM-$VERSION.tar.gz +cd $PRGNAM-$VERSION +chown -R root:root . +find -L . \ + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + +# fix failing test +patch -p1 < $CWD/052eebaf0086e6bbc5ead01c3f1a8f02496aa701.patch +patch -p1 < $CWD/b49a7575ebbe127e8bd344900a52c14b5d69dd7b.patch +# Modified to link against date-tz as newer releases of date changed the library. +patch -p1 < $CWD/538-output-date-pc-for-pkg-config.patch +# fix one particular test suite will fail; according to the date author, +# GCC's std::time_get is buggy and bugs should be raised to that project. +patch -p1 < $CWD/disable_buggy_libstdc++_tests.patch + +mkdir -p build +cd build + cmake \ + -DCMAKE_C_FLAGS:STRING="$SLKCFLAGS" \ + -DCMAKE_CXX_FLAGS:STRING="$SLKCFLAGS" \ + -DCMAKE_INSTALL_PREFIX=/usr \ + -DCMAKE_INSTALL_LIBDIR=/usr/lib${LIBDIRSUFFIX} \ + -DCMAKE_INSTALL_MANDIR=/usr/man \ + -DCMAKE_BUILD_TYPE=Release \ + -DENABLE_DATE_TESTING=ON \ + -DBUILD_TZ_LIB=ON \ + -DUSE_SYSTEM_TZ_DB=ON \ + -DBUILD_SHARED_LIBS=ON .. + make + make install/strip DESTDIR=$PKG +cd .. + +rm -f $PKG/{,usr/}lib${LIBDIRSUFFIX}/*.la + +find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ + | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + +find $PKG -name perllocal.pod -o -name ".packlist" -o -name "*.bs" | xargs rm -f || true + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -a LICENSE.txt README.md $PKG/usr/doc/$PRGNAM-$VERSION +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE diff --git a/libraries/date/date.info b/libraries/date/date.info new file mode 100644 index 0000000000000..5ffb5a0375ec7 --- /dev/null +++ b/libraries/date/date.info @@ -0,0 +1,10 @@ +PRGNAM="date" +VERSION="3.0.1" +HOMEPAGE="https://github.com/HowardHinnant/date" +DOWNLOAD="https://github.com/HowardHinnant/date/archive/v3.0.1/date-3.0.1.tar.gz" +MD5SUM="78902f47f7931a3ae8a320e0dea1f20a" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="" +MAINTAINER="Damian Perticone" +EMAIL="mjolnirdam@gmail.com" diff --git a/libraries/date/disable_buggy_libstdc++_tests.patch b/libraries/date/disable_buggy_libstdc++_tests.patch new file mode 100644 index 0000000000000..d6257c4c3016e --- /dev/null +++ b/libraries/date/disable_buggy_libstdc++_tests.patch @@ -0,0 +1,30 @@ +--- a/test/date_test/parse.pass.cpp 2020-06-02 18:08:57.000000000 -0700 ++++ b/test/date_test/parse.pass.cpp 2020-07-11 19:35:35.349377734 -0700 +@@ -874,27 +874,20 @@ + int + main() + { +- test_a(); +- test_b(); +- test_c(); + test_C(); + test_d(); + test_D(); + test_F(); + test_H(); +- test_Ip(); + test_j(); + test_m(); + test_M(); +- test_p(); +- test_r(); + test_R(); + test_S(); + test_T(); + test_U(); + test_W(); + test_GV(); +- test_x(); + test_X(); + test_z(); + test_Z(); diff --git a/libraries/date/slack-desc b/libraries/date/slack-desc new file mode 100644 index 0000000000000..a1413b99e93ab --- /dev/null +++ b/libraries/date/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. +# Line up the first '|' above the ':' following the base package name, and +# the '|' on the right side marks the last column you can put a character in. +# You must make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +date: date (date and time library) +date: +date: Date is a date and time library +date: based on the C++11/14/17 <chrono> header +date: +date: +date: Home: https://github.com/HowardHinnant/date +date: +date: +date: +date: |