From a37388e008caf07c0c43aad5dda4e86b0abd940b Mon Sep 17 00:00:00 2001 From: CentOS Sources Date: Tue, 9 Nov 2021 05:02:01 -0500 Subject: [PATCH] import apr-1.6.3-12.el8 --- .apr.metadata | 1 + .gitignore | 1 + SOURCES/apr-1.2.2-libdir.patch | 18 + SOURCES/apr-1.2.2-locktimeout.patch | 11 + SOURCES/apr-1.2.7-pkgconf.patch | 56 +++ SOURCES/apr-1.4.8-deepbind.patch | 60 +++ SOURCES/apr-1.6.3-r1834495.patch | 171 ++++++++ SOURCES/apr-rh1539844.patch | 20 + SOURCES/apr-wrapper.h | 22 + SPECS/apr.spec | 619 ++++++++++++++++++++++++++++ 10 files changed, 979 insertions(+) create mode 100644 .apr.metadata create mode 100644 .gitignore create mode 100644 SOURCES/apr-1.2.2-libdir.patch create mode 100644 SOURCES/apr-1.2.2-locktimeout.patch create mode 100644 SOURCES/apr-1.2.7-pkgconf.patch create mode 100644 SOURCES/apr-1.4.8-deepbind.patch create mode 100644 SOURCES/apr-1.6.3-r1834495.patch create mode 100644 SOURCES/apr-rh1539844.patch create mode 100644 SOURCES/apr-wrapper.h create mode 100644 SPECS/apr.spec diff --git a/.apr.metadata b/.apr.metadata new file mode 100644 index 0000000..c943625 --- /dev/null +++ b/.apr.metadata @@ -0,0 +1 @@ +4f3aa8d8204a2674868b9d485c11349e1848987d SOURCES/apr-1.6.3.tar.bz2 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..87437ea --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +SOURCES/apr-1.6.3.tar.bz2 diff --git a/SOURCES/apr-1.2.2-libdir.patch b/SOURCES/apr-1.2.2-libdir.patch new file mode 100644 index 0000000..aeb7ee1 --- /dev/null +++ b/SOURCES/apr-1.2.2-libdir.patch @@ -0,0 +1,18 @@ + +- avoid adding %{_libdir} to --link-ld output + +--- apr-1.2.2/apr-config.in.libdir ++++ apr-1.2.2/apr-config.in +@@ -181,8 +181,10 @@ + ;; + --link-ld) + if test "$location" = "installed"; then +- ### avoid using -L if libdir is a "standard" location like /usr/lib +- flags="$flags -L$libdir -l${APR_LIBNAME}" ++ if test "$prefix" != "/usr"; then ++ flags="$flags -L$libdir" ++ fi ++ flags="$flags -l${APR_LIBNAME}" + else + ### this surely can't work since the library is in .libs? + flags="$flags -L$APR_BUILD_DIR -l${APR_LIBNAME}" diff --git a/SOURCES/apr-1.2.2-locktimeout.patch b/SOURCES/apr-1.2.2-locktimeout.patch new file mode 100644 index 0000000..73f3994 --- /dev/null +++ b/SOURCES/apr-1.2.2-locktimeout.patch @@ -0,0 +1,11 @@ +--- apr-1.2.2/test/testlock.c.locktimeout ++++ apr-1.2.2/test/testlock.c +@@ -295,7 +295,7 @@ + continue; + } + ABTS_INT_EQUAL(tc, 1, APR_STATUS_IS_TIMEUP(s)); +- ABTS_ASSERT(tc, "Timer returned too late", end - begin - timeout < 100000); ++ ABTS_ASSERT(tc, "Timer returned too late", end - begin - timeout < 500000); + break; + } + ABTS_ASSERT(tc, "Too many retries", i < MAX_RETRY); diff --git a/SOURCES/apr-1.2.7-pkgconf.patch b/SOURCES/apr-1.2.7-pkgconf.patch new file mode 100644 index 0000000..bd6d65c --- /dev/null +++ b/SOURCES/apr-1.2.7-pkgconf.patch @@ -0,0 +1,56 @@ + +This is a fugly hack to make apr-1-config libdir-agnostic, by using +pkg-config to determine the libdir setting. pkg-config will +magically determine the appropriate libdir setting. + +This allows apr-devel.i386 and apr-devel.x86_64 to be +installed in parallel. + +--- apr-1.2.7/Makefile.in.pkgconf ++++ apr-1.2.7/Makefile.in +@@ -60,7 +60,7 @@ + + # Create apr-config script suitable for the install tree + apr-config.out: $(APR_CONFIG) +- sed 's,^\(location=\).*$$,\1installed,' < $(APR_CONFIG) > $@ ++ sed 's,^\(location=\).*$$,\1installed,;s,^\(APR_.*_DIR\)=.*,\1="$${libdir}/build",' < $(APR_CONFIG) > $@ + + # Create apr_rules.mk suitable for the install tree + build/apr_rules.out: build/apr_rules.mk +--- apr-1.2.7/apr.pc.in.pkgconf ++++ apr-1.2.7/apr.pc.in +@@ -3,9 +3,10 @@ + libdir=@libdir@ + APR_MAJOR_VERSION=@APR_MAJOR_VERSION@ + includedir=@includedir@ ++CPPFLAGS=@EXTRA_CPPFLAGS@ + + Name: APR + Description: The Apache Portable Runtime library + Version: @APR_DOTTED_VERSION@ + Libs: -L${libdir} -l@APR_LIBNAME@ @EXTRA_LIBS@ +-Cflags: @EXTRA_CPPFLAGS@ @EXTRA_CFLAGS@ -I${includedir} ++Cflags: ${CPPFLAGS} @EXTRA_CFLAGS@ -I${includedir} +--- apr-1.2.7/apr-config.in.pkgconf ++++ apr-1.2.7/apr-config.in +@@ -24,16 +24,17 @@ + prefix="@prefix@" + exec_prefix="@exec_prefix@" + bindir="@bindir@" +-libdir="@libdir@" + datarootdir="@datadir@" + datadir="@datadir@" +-installbuilddir="@installbuilddir@" + includedir="@includedir@" + ++libdir=`pkg-config --variable=libdir apr-@APR_MAJOR_VERSION@` ++installbuilddir="${libdir}/apr-@APR_MAJOR_VERSION@/build" ++ + CC="@CC@" + CPP="@CPP@" + SHELL="@SHELL@" +-CPPFLAGS="@EXTRA_CPPFLAGS@" ++CPPFLAGS=`pkg-config --variable=CPPFLAGS apr-@APR_MAJOR_VERSION@` + CFLAGS="@EXTRA_CFLAGS@" + LDFLAGS="@EXTRA_LDFLAGS@" + LIBS="@EXTRA_LIBS@" diff --git a/SOURCES/apr-1.4.8-deepbind.patch b/SOURCES/apr-1.4.8-deepbind.patch new file mode 100644 index 0000000..bcc782c --- /dev/null +++ b/SOURCES/apr-1.4.8-deepbind.patch @@ -0,0 +1,60 @@ + +Add $APR_DEEPBIND to enable use of RTLD_DEEPBIND in apr_dso_open(). + +--- apr-1.4.8/dso/unix/dso.c.deepbind ++++ apr-1.4.8/dso/unix/dso.c +@@ -38,6 +38,8 @@ + #define DYLD_LIBRARY_HANDLE (void *)-1 + #endif + ++static int use_deepbind; /* 0 = unset, 1 = use DEEPBIND, -1, don't use DEEPBIND */ ++ + APR_DECLARE(apr_status_t) apr_os_dso_handle_put(apr_dso_handle_t **aprdso, + apr_os_dso_handle_t osdso, + apr_pool_t *pool) +@@ -125,6 +127,12 @@ + #else + int flags = RTLD_NOW | RTLD_GLOBAL; + void *os_handle; ++ ++ if (use_deepbind == 0) ++ use_deepbind = getenv("APR_DEEPBIND") != NULL ? 1 : -1; ++ if (use_deepbind == 1) ++ flags |= RTLD_DEEPBIND; ++ + #ifdef _AIX + if (strchr(path + 1, '(') && path[strlen(path) - 1] == ')') + { +--- apr-1.7.0/README.deepbind.deepbind ++++ apr-1.7.0/README.deepbind +@@ -0,0 +1,30 @@ ++This distribution of APR contains a modification of the behaviour of ++the apr_dso_open() function which allows users enable the ++"RTLD_DEEPBIND" flag when dlopen() is called. ++ ++If the "APR_DEEPBIND" environment variable is set at runtime, the ++RTLD_DEEPBIND flag is always added to the flags passed to dlopen(). ++ ++With normal use of dlopen(), dynamically loaded objects will use ++global symbols in preference to any symbols defined within the object. ++Using RTLD_DEEPBIND reverses this binding order. See the dlopen(3) ++man page for more information. ++ ++This can be useful with Apache httpd, where two different modules are ++loaded like: ++ ++1. mod_foo.so uses library "libfoo.so" ++ libfoo.so defines a function "SomeSym" ++2. mod_bar.so uses library "libbar.so" ++ libbar.so defines a different "SomeSym" function ++ ++By default, mod_bar or mod_foo would use the "SomeSym" definition from ++the "wrong" library depending on the load order. If RTLD_DEEPBIND is ++used, the "SomeSym" definition will always be mapped to the definition ++from the corresponding dependent library. This can avoid symbol ++conflicts. ++ ++There are some risks with using RTLD_DEEPBIND, in particular potential ++issues with modules written in C++. It is not recommended to enable ++$APR_DEEPBIND unless it solves a specific problem and after thorough ++testing of the configuration. diff --git a/SOURCES/apr-1.6.3-r1834495.patch b/SOURCES/apr-1.6.3-r1834495.patch new file mode 100644 index 0000000..015f15b --- /dev/null +++ b/SOURCES/apr-1.6.3-r1834495.patch @@ -0,0 +1,171 @@ +# ./pullrev.sh 1834495 +http://svn.apache.org/viewvc?view=revision&revision=1834495 + +--- apr-1.6.3/buildconf ++++ apr-1.6.3/buildconf +@@ -112,8 +112,10 @@ + # Remove autoconf 2.5x's cache directory + rm -rf autom4te*.cache + ++PYTHON=${PYTHON-`build/PrintPath python3 python2 python`} ++ + echo "buildconf: generating 'make' outputs ..." +-build/gen-build.py $verbose make ++${PYTHON} build/gen-build.py $verbose make + + # Create RPM Spec file + if [ -f `which cut` ]; then +--- apr-1.6.3/build/gen-build.py ++++ apr-1.6.3/build/gen-build.py +@@ -10,7 +10,10 @@ + + + import os +-import ConfigParser ++try: ++ import configparser ++except ImportError: ++ import ConfigParser as configparser + import getopt + import string + import glob +@@ -36,7 +39,7 @@ + + + def main(): +- parser = ConfigParser.ConfigParser() ++ parser = configparser.ConfigParser() + parser.read('build.conf') + + if parser.has_option('options', 'dsp'): +@@ -62,7 +65,7 @@ + # write out the platform-independent files + files = get_files(parser.get('options', 'paths')) + objects, dirs = write_objects(f, legal_deps, h_deps, files) +- f.write('\nOBJECTS_all = %s\n\n' % string.join(objects)) ++ f.write('\nOBJECTS_all = %s\n\n' % " ".join(objects)) + + # for each platform and each subdirectory holding platform-specific files, + # write out their compilation rules, and an OBJECT__ symbol. +@@ -86,11 +89,11 @@ + inherit_files[-1] = inherit_files[-1][:-2] + '.lo' + # replace the \\'s with /'s + inherit_line = '/'.join(inherit_files) +- if not inherit_parent.has_key(inherit_files[0]): ++ if inherit_files[0] not in inherit_parent: + inherit_parent[inherit_files[0]] = [] + inherit_parent[inherit_files[0]].append(inherit_line) + +- for subdir in string.split(parser.get('options', 'platform_dirs')): ++ for subdir in parser.get('options', 'platform_dirs').split(): + path = '%s/%s' % (subdir, platform) + if not os.path.exists(path): + # this subdir doesn't have a subdir for this platform, so we'll +@@ -106,7 +109,7 @@ + files = get_files(path + '/*.c') + objects, _unused = write_objects(f, legal_deps, h_deps, files) + +- if inherit_parent.has_key(subdir): ++ if subdir in inherit_parent: + objects = objects + inherit_parent[subdir] + + symname = 'OBJECTS_%s_%s' % (subdir, platform) +@@ -114,7 +117,7 @@ + objects.sort() + + # and write the symbol for the whole group +- f.write('\n%s = %s\n\n' % (symname, string.join(objects))) ++ f.write('\n%s = %s\n\n' % (symname, " ".join(objects))) + + # and include that symbol in the group + group.append('$(%s)' % symname) +@@ -122,18 +125,18 @@ + group.sort() + + # write out a symbol which contains the necessary files +- f.write('OBJECTS_%s = %s\n\n' % (platform, string.join(group))) ++ f.write('OBJECTS_%s = %s\n\n' % (platform, " ".join(group))) + +- f.write('HEADERS = $(top_srcdir)/%s\n\n' % string.join(headers, ' $(top_srcdir)/')) +- f.write('SOURCE_DIRS = %s $(EXTRA_SOURCE_DIRS)\n\n' % string.join(dirs.keys())) ++ f.write('HEADERS = $(top_srcdir)/%s\n\n' % ' $(top_srcdir)/'.join(headers)) ++ f.write('SOURCE_DIRS = %s $(EXTRA_SOURCE_DIRS)\n\n' % " ".join(dirs.keys())) + + if parser.has_option('options', 'modules'): + modules = parser.get('options', 'modules') + +- for mod in string.split(modules): ++ for mod in modules.split(): + files = get_files(parser.get(mod, 'paths')) + objects, _unused = write_objects(f, legal_deps, h_deps, files) +- flat_objects = string.join(objects) ++ flat_objects = " ".join(objects) + f.write('OBJECTS_%s = %s\n' % (mod, flat_objects)) + + if parser.has_option(mod, 'target'): +@@ -153,9 +156,9 @@ + d = os.path.dirname(d) + + # Sort so 'foo' is before 'foo/bar' +- keys = alldirs.keys() ++ keys = list(alldirs.keys()) + keys.sort() +- f.write('BUILD_DIRS = %s\n\n' % string.join(keys)) ++ f.write('BUILD_DIRS = %s\n\n' % " ".join(keys)) + + f.write('.make.dirs: $(srcdir)/build-outputs.mk\n' \ + '\t@for d in $(BUILD_DIRS); do test -d $$d || mkdir $$d; done\n' \ +@@ -177,12 +180,12 @@ + + # what headers does this file include, along with the implied headers + deps = extract_deps(file, legal_deps) +- for hdr in deps.keys(): ++ for hdr in list(deps.keys()): + deps.update(h_deps.get(hdr, {})) + +- vals = deps.values() ++ vals = list(deps.values()) + vals.sort() +- f.write('%s: %s .make.dirs %s\n' % (obj, file, string.join(vals))) ++ f.write('%s: %s .make.dirs %s\n' % (obj, file, " ".join(vals))) + + objects.sort() + +@@ -210,7 +213,7 @@ + for hdr, deps in header_deps.items(): + # print hdr, deps + start = len(deps) +- for dep in deps.keys(): ++ for dep in list(deps.keys()): + deps.update(header_deps.get(dep, {})) + if len(deps) != start: + altered = 1 +@@ -220,7 +223,7 @@ + + def get_files(patterns): + files = [ ] +- for pat in string.split(patterns): ++ for pat in patterns.split(): + files.extend(map(clean_path, glob.glob(pat))) + files.sort() + return files +--- apr-1.6.3/build/buildcheck.sh ++++ apr-1.6.3/build/buildcheck.sh +@@ -4,7 +4,7 @@ + res=0 + + # any python +-python=`build/PrintPath python` ++python=${PYTHON-`build/PrintPath python3 python2 python`} + if test -z "$python"; then + echo "buildconf: python not found." + echo " You need python installed" +@@ -11,7 +11,7 @@ + echo " to build APR from SVN." + res=1 + else +- py_version=`python -c 'import sys; print sys.version' 2>&1|sed 's/ .*//;q'` ++ py_version=`$python -c 'import sys; print(sys.version)' 2>&1|sed 's/ .*//;q'` + echo "buildconf: python version $py_version (ok)" + fi + diff --git a/SOURCES/apr-rh1539844.patch b/SOURCES/apr-rh1539844.patch new file mode 100644 index 0000000..15178af --- /dev/null +++ b/SOURCES/apr-rh1539844.patch @@ -0,0 +1,20 @@ +diff -ur apr-1.6.3.orig/test/teststr.c apr-1.6.3/test/teststr.c +--- apr-1.6.3.orig/test/teststr.c 2016-03-03 17:11:16.000000000 +0100 ++++ apr-1.6.3/test/teststr.c 2018-01-29 18:54:44.748931098 +0100 +@@ -307,10 +307,15 @@ + for (; off < 999999999; off += 999) { + apr_strfsize(off, buf); + } +- for (off = 1; off < LONG_MAX && off > 0; off *= 2) { ++ ++ off = 1; ++ while (1) { + apr_strfsize(off, buf); + apr_strfsize(off + 1, buf); + apr_strfsize(off - 1, buf); ++ if (off > LONG_MAX / 2) ++ break; ++ off *= 2; + } + + ABTS_ASSERT(tc, "strfsize overflowed", buf[5] == '$'); diff --git a/SOURCES/apr-wrapper.h b/SOURCES/apr-wrapper.h new file mode 100644 index 0000000..2641f76 --- /dev/null +++ b/SOURCES/apr-wrapper.h @@ -0,0 +1,22 @@ +/* This file is here to prevent a file conflict on multiarch systems. A + * conflict will occur because apr.h has arch-specific definitions. + * + * DO NOT INCLUDE THE NEW FILE DIRECTLY -- ALWAYS INCLUDE THIS ONE INSTEAD. */ + +#if defined(__i386__) +#include "apr-i386.h" +#elif defined(__ia64__) +#include "apr-ia64.h" +#elif defined(__powerpc64__) +#include "apr-ppc64.h" +#elif defined(__powerpc__) +#include "apr-ppc.h" +#elif defined(__s390x__) +#include "apr-s390x.h" +#elif defined(__s390__) +#include "apr-s390.h" +#elif defined(__x86_64__) +#include "apr-x86_64.h" +#else +#error "This apr-devel package does not work your architecture?" +#endif diff --git a/SPECS/apr.spec b/SPECS/apr.spec new file mode 100644 index 0000000..8456a3b --- /dev/null +++ b/SPECS/apr.spec @@ -0,0 +1,619 @@ +%define aprver 1 + +# Arches on which the multilib apr.h hack is needed: +%define multilib_arches %{ix86} ia64 ppc ppc64 s390 s390x x86_64 + +Summary: Apache Portable Runtime library +Name: apr +Version: 1.6.3 +Release: 12%{?dist} +# ASL 2.0: everything +# ISC: network_io/apr-1.4.6/network_io/unix/inet_?to?.c +# BSD with advertising: strings/apr_snprintf.c, strings/apr_fnmatch.c, +# include/apr_fnmatch.h, misc/unix/getopt.c, +# file_io/unix/mktemp.c, strings/apr_strings.c +# BSD (3-clause): strings/apr_strnatcmp.c, include/apr_strings.h +License: ASL 2.0 and BSD with advertising and ISC and BSD +Group: System Environment/Libraries +URL: http://apr.apache.org/ +Source0: http://www.apache.org/dist/apr/%{name}-%{version}.tar.bz2 +Source1: apr-wrapper.h +Patch1: apr-1.6.3-r1834495.patch +Patch2: apr-1.2.2-locktimeout.patch +Patch3: apr-1.2.2-libdir.patch +Patch4: apr-1.2.7-pkgconf.patch +Patch5: apr-rh1539844.patch +Patch6: apr-1.4.8-deepbind.patch +BuildRequires: gcc, autoconf, libtool, libuuid-devel, python3-devel +# To enable SCTP support +BuildRequires: lksctp-tools-devel + +%description +The mission of the Apache Portable Runtime (APR) is to provide a +free library of C data structures and routines, forming a system +portability layer to as many operating systems as possible, +including Unices, MS Win32, BeOS and OS/2. + +%package devel +Group: Development/Libraries +Summary: APR library development kit +Conflicts: subversion-devel < 0.20.1-2 +Requires: apr = %{version}-%{release}, pkgconfig + +%description devel +This package provides the support files which can be used to +build applications using the APR library. The mission of the +Apache Portable Runtime (APR) is to provide a free library of +C data structures and routines. + +%prep +%setup -q +%patch1 -p1 -b .r1834495 +%patch2 -p1 -b .locktimeout +%patch3 -p1 -b .libdir +%patch4 -p1 -b .pkgconf +%patch5 -p1 -b .rh1539844 +%patch6 -p1 -b .deepbind + +%build +# regenerate configure script etc. +./buildconf + +# Forcibly prevent detection of shm_open (which then picks up but +# does not use -lrt). +export ac_cv_search_shm_open=no + +%configure \ + --includedir=%{_includedir}/apr-%{aprver} \ + --with-installbuilddir=%{_libdir}/apr-%{aprver}/build \ + --with-devrandom=/dev/urandom +make %{?_smp_mflags} + +%install +rm -rf $RPM_BUILD_ROOT +make install DESTDIR=$RPM_BUILD_ROOT + +mkdir -p $RPM_BUILD_ROOT/%{_datadir}/aclocal +install -m 644 build/find_apr.m4 $RPM_BUILD_ROOT/%{_datadir}/aclocal + +# Trim exported dependecies +sed -ri '/^dependency_libs/{s,-l(uuid|crypt) ,,g}' \ + $RPM_BUILD_ROOT%{_libdir}/libapr*.la +sed -ri '/^LIBS=/{s,-l(uuid|crypt) ,,g;s/ */ /g}' \ + $RPM_BUILD_ROOT%{_bindir}/apr-%{aprver}-config +sed -ri '/^Libs/{s,-l(uuid|crypt) ,,g}' \ + $RPM_BUILD_ROOT%{_libdir}/pkgconfig/apr-%{aprver}.pc + +%ifarch %{multilib_arches} +# Ugly hack to allow parallel installation of 32-bit and 64-bit apr-devel +# packages: +mv $RPM_BUILD_ROOT%{_includedir}/apr-%{aprver}/apr.h \ + $RPM_BUILD_ROOT%{_includedir}/apr-%{aprver}/apr-%{_arch}.h +install -c -m644 %{SOURCE1} $RPM_BUILD_ROOT%{_includedir}/apr-%{aprver}/apr.h +%endif + +# Unpackaged files: +rm -f $RPM_BUILD_ROOT%{_libdir}/apr.exp \ + $RPM_BUILD_ROOT%{_libdir}/libapr-*.a + +# Additionally packaged (see https://bugzilla.redhat.com/1669589) -- +sed -i '1s,/.*,/usr/bin/python3,' build/gen-build.py +for f in build/gen-build.py build/install.sh build/config.*; do + install -c -m755 $f $RPM_BUILD_ROOT%{_libdir}/apr-%{aprver}/build +done + +%check +# Fail if LFS support isn't present in a 32-bit build, since this +# breaks ABI and the soname doesn't change: see #254241 +if grep 'define SIZEOF_VOIDP 4' include/apr.h \ + && ! grep off64_t include/apr.h; then + cat config.log + : LFS support not present in 32-bit build + exit 1 +fi +pushd test + make %{?_smp_mflags} + ./testall -v -q +popd + +%post -p /sbin/ldconfig + +%postun -p /sbin/ldconfig + +%files +%defattr(-,root,root,-) +%doc CHANGES LICENSE NOTICE README* +%{_libdir}/libapr-%{aprver}.so.* + +%files devel +%defattr(-,root,root,-) +%doc docs/APRDesign.html docs/canonical_filenames.html +%doc docs/incomplete_types docs/non_apr_programs +%{_bindir}/apr-%{aprver}-config +%{_libdir}/libapr-%{aprver}.*a +%{_libdir}/libapr-%{aprver}.so +%{_libdir}/pkgconfig/*.pc +%dir %{_libdir}/apr-%{aprver} +%dir %{_libdir}/apr-%{aprver}/build +%{_libdir}/apr-%{aprver}/build/* +%dir %{_includedir}/apr-%{aprver} +%{_includedir}/apr-%{aprver}/*.h +%{_datadir}/aclocal/*.m4 + +%changelog +* Wed Jun 23 2021 Joe Orton - 1.6.3-12 +- document $APR_DEEPBIND env var (#1886222) + +* Thu Jun 11 2020 Joe Orton - 1.6.3-11 +- only enable RTLD_DEEPBIND if $APR_DEEPBIND is set in env (#1845912) + +* Thu May 28 2020 Joe Orton - 1.6.3-10 +- use RTLD_DEEPBIND in apr_dso_open() (#1819607) + +* Fri Feb 1 2019 Joe Orton - 1.6.3-9 +- package install.sh, gen-build.py and config.* in -devel (#1669589) + +* Wed Jun 27 2018 Joe Orton - 1.6.3-8 +- update to use Python 3 at build time + +* Wed Mar 14 2018 Iryna Shcherbina - 1.6.3-7 +- Update Python 2 dependency declarations to new packaging standards + (See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3) + +* Wed Feb 21 2018 Joe Orton - 1.6.3-6 +- BuildRequires: gcc + +* Wed Feb 07 2018 Fedora Release Engineering - 1.6.3-5 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild + +* Mon Jan 29 2018 Florian Weimer - 1.6.3-4 +- Fix FTBFS in test/teststr.c with GCC 8 (#1539844) + +* Mon Jan 29 2018 Florian Weimer - 1.6.3-3 +- Rebuild with new redhat-rpm-config build flags + +* Sat Jan 20 2018 Björn Esser - 1.6.3-2 +- Rebuilt for switch to libxcrypt + +* Wed Oct 25 2017 Luboš Uhliarik - 1.6.3-1 +- new version 1.6.3 + +* Tue Sep 19 2017 Joe Orton - 1.6.2-4 +- re-enable test suite + +* Wed Aug 02 2017 Fedora Release Engineering - 1.6.2-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild + +* Sat Jul 29 2017 Florian Weimer - 1.6.2-2 +- Rebuild with binutils fix for ppc64le (#1475636) + +* Wed Jul 26 2017 Joe Orton - 1.6.2-1 +- update to 1.6.2 (#1460830) + +* Wed Jul 26 2017 Fedora Release Engineering - 1.5.2-6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild + +* Fri Feb 10 2017 Fedora Release Engineering - 1.5.2-5 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild + +* Fri Apr 15 2016 David Tardon - 1.5.2-4 +- rebuild for ICU 57.1 + +* Wed Feb 03 2016 Fedora Release Engineering - 1.5.2-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild + +* Wed Jun 17 2015 Fedora Release Engineering - 1.5.2-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild + +* Wed Apr 29 2015 Jan Kaluza - 1.5.2-1 +- update to 1.5.2 (#1217012) + +* Fri Aug 15 2014 Fedora Release Engineering - 1.5.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_22_Mass_Rebuild + +* Sat Jun 07 2014 Fedora Release Engineering - 1.5.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild + +* Wed Apr 23 2014 Jan Kaluza - 1.5.1-1 +- update to 1.5.1 (#1089917) + +* Tue Nov 26 2013 Joe Orton - 1.5.0-2 +- update to 1.5.0 + +* Sat Aug 03 2013 Fedora Release Engineering - 1.4.8-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_20_Mass_Rebuild + +* Mon Jun 24 2013 Joe Orton - 1.4.8-1 +- update to 1.4.8 (#976972) + +* Wed May 29 2013 Joe Orton - 1.4.6-7 +- update config.* for aarch64 (#925009) + +* Wed Feb 13 2013 Fedora Release Engineering - 1.4.6-6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild + +* Wed Dec 12 2012 Jan Kaluza - 1.4.6-5 +- fix strict-aliasing gcc warning +- remove unused SHA384 and SHA512 code + +* Thu Nov 22 2012 Joe Orton - 1.4.6-4 +- update license + +* Wed Jul 18 2012 Fedora Release Engineering - 1.4.6-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild + +* Fri Jul 6 2012 Joe Orton - 1.4.6-2 +- pull fix for apr_mcast_hops from upstream + +* Tue Feb 14 2012 Bojan Smojver - 1.4.6-1 +- bump up to 1.4.6 + +* Thu Jan 12 2012 Fedora Release Engineering - 1.4.5-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_17_Mass_Rebuild + +* Thu Oct 13 2011 Joe Orton - 1.4.5-2 +- remove deepbind patch, should no longer be necessary + +* Fri May 20 2011 Bojan Smojver - 1.4.5-1 +- bump up to 1.4.5 + +* Tue May 10 2011 Bojan Smojver - 1.4.4-2 +- fix top_builddir in apr_rules.mk + +* Mon May 9 2011 Bojan Smojver - 1.4.4-1 +- bump up to 1.4.4 +- CVE-2011-0419 + +* Wed Mar 2 2011 Joe Orton - 1.4.2-3 +- work around alising issue in ring macros (upstream PR 50190) +- fix buildconf with newer libtool (#670621) + +* Mon Feb 07 2011 Fedora Release Engineering - 1.4.2-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild + +* Sat Dec 4 2010 Joe Orton - 1.4.2-1 +- update to 1.4.2 +- always enable SCTP support (#659815) + +* Sun Oct 25 2009 Bojan Smojver - 1.3.9-3 +- remove uuid/crypt libs from pkg-config file (#511522) + +* Mon Sep 28 2009 Bojan Smojver - 1.3.9-2 +- revert use of accept4(), dup3() and epoll_create1() + +* Fri Sep 25 2009 Bojan Smojver - 1.3.9-1 +- bump up to 1.3.9 + +* Thu Aug 6 2009 Bojan Smojver - 1.3.8-1 +- bump up to 1.3.8 +- CVE-2009-2412 +- allocator alignment fixes + +* Sun Jul 26 2009 Bojan Smojver - 1.3.7-2 +- include apr_cv_sock_cloexec too + +* Sun Jul 26 2009 Bojan Smojver - 1.3.7-1 +- bump up to 1.3.7 + +* Fri Jul 24 2009 Fedora Release Engineering - 1.3.6-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_12_Mass_Rebuild + +* Wed Jul 15 2009 Bojan Smojver - 1.3.6-1 +- bump up to 1.3.6 + +* Tue Jun 30 2009 Joe Orton 1.3.5-5 +- BR libuuid-devel instead of e2fsprogs-devel + +* Mon Jun 8 2009 Bojan Smojver - 1.3.5-4 +- bump up to 1.3.5 + +* Mon Feb 23 2009 Fedora Release Engineering - 1.3.3-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_11_Mass_Rebuild + +* Wed Feb 4 2009 Joe Orton 1.3.3 +- fix build with libtool 2.2 + +* Fri Jan 2 2009 Joe Orton 1.3.3 +- rebuild + +* Sat Aug 16 2008 Bojan Smojver - 1.3.3-1 +- bump up to 1.3.3 + +* Wed Jul 16 2008 Bojan Smojver - 1.3.2-2 +- ship find_apr.m4, fix bug #455189 + +* Thu Jun 19 2008 Bojan Smojver - 1.3.2-1 +- bump up to 1.3.2 + +* Sun Jun 1 2008 Bojan Smojver - 1.3.0-1 +- bump up to 1.3.0 + +* Tue Feb 19 2008 Fedora Release Engineering - 1.2.12-2 +- Autorebuild for GCC 4.3 + +* Mon Nov 26 2007 Bojan Smojver 1.2.12-1 +- bump up to 1.2.12 +- add dist +- remove a comment from apr-1.2.7-psprintfpi.patch (applied upstream) + +* Tue Sep 18 2007 Joe Orton 1.2.11-2 +- fix %%check for non-multilib 64-bit platforms + +* Sun Sep 9 2007 Bojan Smojver 1.2.11-1 +- bump up to 1.2.11 +- drop openlfs patch (fixed upstream) + +* Sun Sep 2 2007 Joe Orton 1.2.9-4 +- fix API/ABI of 32-bit builds (#254241) + +* Tue Aug 21 2007 Joe Orton 1.2.9-2 +- fix License + +* Mon Jun 25 2007 Bojan Smojver 1.2.9-1 +- bump up to 1.2.9 + +* Mon Jun 4 2007 Joe Orton 1.2.8-7 +- drop %%check section entirely; inappropriate to run in build env. + +* Fri Mar 30 2007 Joe Orton 1.2.8-6 +- merge review (#225253): drop .a archive; drop use of CC/CXX, + use BuildRequires; drop old Conflicts; URL reference for Source + +* Thu Mar 22 2007 Joe Orton 1.2.8-5 +- drop the doxygen documentation (which causes multilib conflicts) + +* Thu Feb 15 2007 Joe Orton 1.2.8-4 +- add BR for python + +* Thu Feb 15 2007 Joe Orton 1.2.8-3 +- update to pick up new libtool, drop specific gcc requirement + +* Mon Dec 4 2006 Joe Orton 1.2.8-2 +- update to 1.2.8 + +* Wed Jul 19 2006 Joe Orton 1.2.7-10 +- fix buildconf with autoconf 2.60 (#199067) + +* Wed Jul 12 2006 Jesse Keating 1.2.7-9.1 +- rebuild + +* Mon Jun 19 2006 Joe Orton 1.2.7-9 +- add fix for use of %%pI with psprintf + +* Fri May 26 2006 Jakub Jelinek 1.2.7-8 +- rebuilt with GCC 4.1.0 + +* Tue May 23 2006 Joe Orton 1.2.7-7 +- fix another multilib conflict (#192659) + +* Tue May 16 2006 Joe Orton 1.2.7-6 +- BR e2fsprogs-devel for libuuid + +* Mon May 8 2006 Joe Orton 1.2.7-4 +- use multilib parallel-installation wrapper hack for apr.h + +* Tue May 2 2006 Joe Orton 1.2.7-3 +- fix installbuilddir in apr-1-config + +* Tue May 2 2006 Joe Orton 1.2.7-2 +- update to 1.2.7 +- use pkg-config in apr-1-config to make it libdir-agnostic + +* Thu Apr 6 2006 Joe Orton 1.2.6-2 +- update to 1.2.6 + +* Fri Feb 10 2006 Jesse Keating - 1.2.2-7.2 +- bump again for double-long bug on ppc(64) + +* Tue Feb 07 2006 Jesse Keating - 1.2.2-7.1 +- rebuilt for new gcc4.1 snapshot and glibc changes + +* Wed Jan 4 2006 Joe Orton 1.2.2-7 +- fix namespace pollution (r354824, r355464) + +* Wed Jan 4 2006 Joe Orton 1.2.2-6 +- fix build with recent glibc (#176911) + +* Tue Jan 3 2006 Jesse Keating 1.2.2-5.2 +- rebuilt again + +* Fri Dec 09 2005 Jesse Keating +- rebuilt + +* Fri Dec 9 2005 Joe Orton 1.2.2-5 +- rebuild for new gcc + +* Thu Dec 8 2005 Joe Orton 1.2.2-4 +- add apr_file_seek() fixes from upstream (r326593, r326597) + +* Wed Dec 7 2005 Joe Orton 1.2.2-3 +- apr-1-config: strip more exports (#175124) + +* Tue Dec 6 2005 Joe Orton 1.2.2-2 +- avoid linking against -lrt +- don't print -L${libdir} in --libs output +- don't export -lcrypt/-luuid in .la file + +* Fri Dec 2 2005 Joe Orton 1.2.2-1 +- update to 1.2.2 + +* Thu Nov 24 2005 Joe Orton 0.9.7-3 +- use RTLD_DEEPBIND in apr_dso_open by default + +* Thu Oct 20 2005 Joe Orton 0.9.7-2 +- update to 0.9.7 + +* Fri Sep 30 2005 Florian La Roche +- rebuild for new gcc + +* Thu Sep 15 2005 Joe Orton 0.9.6-6 +- don't override CFLAGS at build time +- allow setting TCP_NODELAY and TCP_CORK concurrently +- use _exit() not exit() in child if exec*() fails (upstream #30913) + +* Fri Sep 9 2005 Joe Orton 0.9.6-5 +- add from 0.9.x branch: + * fix for apr_{uid,gid}_* error handling (r239592) + * fix for apr_file_ write flushing (r267192) +- add backport for use of readdir64_r (r265032, r265681, r265684) + +* Mon Jul 11 2005 Florian La Roche +- rebuild + +* Tue May 17 2005 Joe Orton 0.9.6-3 +- fix apr_procattr_child_*_set error handling + +* Tue Mar 1 2005 Joe Orton 0.9.6-2 +- have apr-devel depend on specific version of gcc +- add NOTICE to docdir + +* Wed Feb 9 2005 Joe Orton 0.9.6-1 +- update to 0.9.6 + +* Wed Feb 2 2005 Joe Orton 0.9.5-4 +- don't disable sendfile on s390 (IBM LTC, #146891) + +* Mon Nov 22 2004 Joe Orton 0.9.5-3 +- really fix apr-config --srcdir + +* Mon Nov 22 2004 Joe Orton 0.9.5-2 +- fix apr-config --srcdir again + +* Sun Nov 21 2004 Joe Orton 0.9.5-1 +- update to 0.9.5 + +* Mon Sep 27 2004 Joe Orton 0.9.4-24 +- rebuild + +* Wed Sep 1 2004 Joe Orton 0.9.4-23 +- have -devel require apr of same V-R + +* Tue Aug 31 2004 Joe Orton 0.9.4-22 +- backport fixes from HEAD: + * correct implementation of nested mutexes + * support for POSIX semaphores on LP64 platforms + +* Thu Jul 15 2004 Joe Orton 0.9.4-21 +- rebuild for another attempt at using sem_open + +* Tue Jul 13 2004 Joe Orton 0.9.4-20 +- move sticky/suid bits outside APR_OS_DEFAULT bitmask (Greg Hudson) + +* Thu Jul 1 2004 Joe Orton 0.9.4-19 +- rebuild + +* Wed Jun 30 2004 Joe Orton 0.9.4-18 +- rebuild now /dev/shm is mounted + +* Thu Jun 17 2004 Joe Orton 0.9.4-17 +- add fix for cleanup structure reuse (part of upstream #23567) + +* Tue Jun 15 2004 Elliot Lee +- rebuilt + +* Thu Jun 10 2004 Joe Orton 0.9.4-15 +- add support for setuid/setgid/sticky bits (André Malo) +- add apr_threadattr_{guardsize,stacksize}_set() (latter by Jeff Trawick) + +* Mon Jun 7 2004 Joe Orton 0.9.4-14 +- enable posixsem and process-shared pthread mutex support, but + ensure that sysvsem remains the default mechanism + +* Mon May 24 2004 Joe Orton 0.9.4-13 +- entirely remove 2Gb file size limit from apr_file_copy(); + fixes "svnadmin hotcopy" on repos with >2Gb strings table +- work around getnameinfo bugs with v4-mapped addresses +- fix apr_time_exp_get() for dates in 2038 (Philip Martin) + +* Thu May 13 2004 Joe Orton 0.9.4-12 +- use APR_LARGEFILE in apr_file_{copy,append} + +* Wed Mar 24 2004 Joe Orton 0.9.4-11 +- add APR_LARGEFILE flag + +* Mon Mar 15 2004 Joe Orton 0.9.4-10 +- fix configure check for mmap of /dev/zero +- just put -D_GNU_SOURCE in CPPFLAGS not _{BSD,SVID,XOPEN}_SOURCE + +* Tue Mar 02 2004 Elliot Lee 0.9.4-9.1 +- rebuilt + +* Thu Feb 19 2004 Joe Orton 0.9.4-9 +- undocument apr_dir_read() ordering constraint and fix tests + +* Sun Feb 15 2004 Joe Orton 0.9.4-8 +- rebuilt without -Wall -Werror + +* Fri Feb 13 2004 Elliot Lee 0.9.4-7 +- rebuilt + +* Tue Feb 3 2004 Joe Orton 0.9.4-6 +- define apr_off_t as int/long/... to prevent it changing + with _FILE_OFFSET_BITS on 32-bit platforms + +* Mon Jan 12 2004 Joe Orton 0.9.4-5 +- add apr_temp_dir_get fixes from HEAD + +* Thu Jan 8 2004 Joe Orton 0.9.4-4 +- ensure that libapr is linked against libpthread +- don't link libapr against -lnsl + +* Thu Nov 13 2003 Joe Orton 0.9.4-3 +- -devel package no longer requires libtool + +* Fri Oct 3 2003 Joe Orton 0.9.4-2 +- disable tests on x86_64 (#97611) + +* Fri Oct 3 2003 Joe Orton 0.9.4-1 +- update to 0.9.4, enable tests +- ensure that libresolv is not used + +* Sun Sep 7 2003 Joe Orton 0.9.3-14 +- use /dev/urandom (#103049) + +* Thu Jul 24 2003 Joe Orton 0.9.3-13 +- add back CC=gcc, CXX=g++ + +* Tue Jul 22 2003 Nalin Dahyabhai 0.9.3-12 +- rebuild + +* Mon Jul 14 2003 Joe Orton 0.9.3-11 +- work round useless autoconf 2.57 AC_DECL_SYS_SIGLIST + +* Thu Jul 10 2003 Joe Orton 0.9.3-10 +- support --cc and --cpp arguments in apr-config + +* Thu Jul 3 2003 Joe Orton 0.9.3-9 +- force libtool to use CC=gcc, CXX=g++ + +* Thu Jul 3 2003 Joe Orton 0.9.3-8 +- fix libtool location in apr_rules.mk + +* Mon Jun 30 2003 Joe Orton 0.9.3-7 +- use AI_ADDRCONFIG in getaddrinfo() support (#73350) +- include a working libtool script rather than relying on + /usr/bin/libtool (#97695) + +* Wed Jun 18 2003 Joe Orton 0.9.3-6 +- don't use /usr/bin/libtool + +* Wed Jun 04 2003 Elliot Lee +- rebuilt + +* Tue May 20 2003 Joe Orton 0.9.3-5 +- add fix for psprintf memory corruption (CAN-2003-0245) +- remove executable bit from apr_poll.h + +* Thu May 1 2003 Joe Orton 0.9.3-4 +- link libapr against libpthread +- make apr-devel conflict with old subversion-devel +- fix License + +* Tue Apr 29 2003 Joe Orton 0.9.3-3 +- run ldconfig in post/postun + +* Tue Apr 29 2003 Joe Orton 0.9.3-2 +- patch test suite to not care if IPv6 is disabled + +* Mon Apr 28 2003 Joe Orton 0.9.3-1 +- initial build