2024-09-11 13:36:58 +02:00
|
|
|
#
|
|
|
|
# spec file for package expat
|
|
|
|
#
|
|
|
|
# Copyright (c) 2022 SUSE LLC
|
|
|
|
#
|
|
|
|
# All modifications and additions to the file contributed by third parties
|
|
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
|
|
# upon. The license for this file, and modifications and additions to the
|
|
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
|
|
# license for the pristine package is not an Open Source License, in which
|
|
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
|
|
# published by the Open Source Initiative.
|
|
|
|
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
%global unversion 2_5_0
|
|
|
|
Name: expat
|
|
|
|
Version: 2.5.0
|
|
|
|
Release: 0
|
|
|
|
Summary: XML Parser Toolkit
|
|
|
|
License: MIT
|
|
|
|
Group: Development/Libraries/C and C++
|
|
|
|
URL: https://libexpat.github.io
|
|
|
|
Source0: https://github.com/libexpat/libexpat/releases/download/R_%{unversion}/expat-%{version}.tar.xz
|
|
|
|
Source1: https://github.com/libexpat/libexpat/releases/download/R_%{unversion}/expat-%{version}.tar.xz.asc
|
|
|
|
Source2: baselibs.conf
|
|
|
|
Source3: %{name}faq.html
|
|
|
|
# https://www.gentoo.org/inside-gentoo/developers/index.html#sping
|
|
|
|
# https://keys.gentoo.org/pks/lookup?op=get&search=0x1F9B0E909AF37285#/%{name}.keyring
|
|
|
|
Source4: %{name}.keyring
|
|
|
|
# PATCH FIX-UPSTREAM: bsc#1221289 (CVE-2024-28757)
|
|
|
|
# https://github.com/libexpat/libexpat/pull/842
|
|
|
|
Patch0: expat-CVE-2024-28757.patch
|
|
|
|
Patch1: expat-fix-minicheck.patch
|
|
|
|
|
|
|
|
# detect integer overflow in function nextScaffoldPart
|
|
|
|
# UPSTREAM-FIX: (CVE-2024-45492, bsc#1229932) https://github.com/libexpat/libexpat/pull/892
|
|
|
|
Patch2: expat-CVE-2024-45492.patch
|
|
|
|
|
|
|
|
# detect integer overflow in dtdCopy
|
|
|
|
# UPSTREAM-FIX: (bsc#1229931, CVE-2024-45491) https://github.com/libexpat/libexpat/pull/891
|
|
|
|
Patch3: expat-CVE-2024-45491.patch
|
|
|
|
|
|
|
|
# reject negative len for XML_ParseBuffer
|
|
|
|
# UPSTREAM-FIX: (bsc#1229930, CVE-2024-45490) https://github.com/libexpat/libexpat/pull/890
|
|
|
|
Patch4: expat-CVE-2024-45490.patch
|
2024-12-06 13:34:34 +01:00
|
|
|
# CVE-2024-50602 [bsc#1232579], DoS via XML_ResumeParser
|
|
|
|
Patch5: expat-CVE-2024-50602.patch
|
2024-09-11 13:36:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
BuildRequires: gcc-c++
|
|
|
|
BuildRequires: libtool
|
|
|
|
BuildRequires: pkgconfig
|
|
|
|
|
|
|
|
%description
|
|
|
|
Expat is an XML parser library written in C. It is a stream-oriented
|
|
|
|
parser in which an application registers handlers for things the
|
|
|
|
parser might find in the XML document (like start tags).
|
|
|
|
|
|
|
|
%package -n libexpat1
|
|
|
|
Summary: XML Parser Toolkit
|
|
|
|
Group: System/Libraries
|
|
|
|
|
|
|
|
%description -n libexpat1
|
|
|
|
Expat is an XML parser library written in C. It is a stream-oriented
|
|
|
|
parser in which an application registers handlers for things the
|
|
|
|
parser might find in the XML document (like start tags).
|
|
|
|
|
|
|
|
%package -n libexpat-devel
|
|
|
|
Summary: Development files for expat, an XML parser toolkit
|
|
|
|
Group: Development/Libraries/C and C++
|
|
|
|
Requires: glibc-devel
|
|
|
|
Requires: libexpat1 = %{version}
|
|
|
|
|
|
|
|
%description -n libexpat-devel
|
|
|
|
Expat is an XML parser library written in C. It is a stream-oriented
|
|
|
|
parser in which an application registers handlers for things the
|
|
|
|
parser might find in the XML document (like start tags).
|
|
|
|
|
|
|
|
This package contains the development headers for the library found
|
|
|
|
in libexpat.
|
|
|
|
|
|
|
|
%prep
|
|
|
|
%autosetup -p1
|
|
|
|
|
|
|
|
cp %{SOURCE3} .
|
|
|
|
rm -f examples/*.dsp
|
|
|
|
|
|
|
|
%build
|
|
|
|
%configure \
|
|
|
|
--disable-silent-rules \
|
|
|
|
--docdir="%{_docdir}/%{name}" \
|
|
|
|
--disable-static
|
|
|
|
%if 0%{?do_profiling}
|
|
|
|
%make_build CFLAGS="%{optflags} %{cflags_profile_generate}"
|
|
|
|
%make_build CFLAGS="%{optflags} %{cflags_profile_generate}" LDFLAGS="%{optflags} %{cflags_profile_generate}" check
|
|
|
|
%make_build clean
|
|
|
|
%make_build CFLAGS="%{optflags} %{cflags_profile_feedback}"
|
|
|
|
%else
|
|
|
|
%make_build CFLAGS="%{optflags}"
|
|
|
|
%endif
|
|
|
|
|
|
|
|
%install
|
|
|
|
%make_install
|
|
|
|
find %{buildroot} -type f -name "*.la" -delete -print
|
|
|
|
# Fix permissions error: spurious-executable-perm
|
|
|
|
chmod 0644 examples/elements.c
|
|
|
|
|
|
|
|
%check
|
|
|
|
%make_build check
|
|
|
|
|
|
|
|
%post -n libexpat1 -p /sbin/ldconfig
|
|
|
|
%postun -n libexpat1 -p /sbin/ldconfig
|
|
|
|
|
|
|
|
%files
|
|
|
|
%license COPYING
|
|
|
|
%doc AUTHORS README.md expatfaq.html
|
|
|
|
%doc doc/reference.html doc/style.css
|
|
|
|
%doc examples/elements.c examples/outline.c examples/Makefile.am examples/Makefile.in
|
|
|
|
%doc changelog
|
|
|
|
%{_bindir}/xmlwf
|
|
|
|
|
|
|
|
%files -n libexpat1
|
|
|
|
%{_libdir}/libexpat.so.*
|
|
|
|
|
|
|
|
%files -n libexpat-devel
|
|
|
|
%{_includedir}/*
|
|
|
|
%{_libdir}/libexpat.so
|
|
|
|
%{_libdir}/pkgconfig/expat.pc
|
|
|
|
%dir %{_libdir}/cmake
|
|
|
|
%{_libdir}/cmake/expat-%{version}
|
|
|
|
|
|
|
|
%changelog
|