File stp.spec of Package stp

#
# spec file for package stp
#
# Copyright (c) 2025 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/
#


%define sover 2_3
Name:           stp
Version:        2.3.4+20240918
Release:        0
Summary:        Constraint Solver
License:        MIT
URL:            https://github.com/stp/stp/wiki
Source0:        %{name}-%{version}.tar.xz
Patch0:         py3.patch
Patch1:         CMakeLists-use-absolute-libdir-in-rpath-handling.patch
BuildRequires:  bison
BuildRequires:  cmake
BuildRequires:  flex
BuildRequires:  gcc-c++
BuildRequires:  gmp-devel
BuildRequires:  libboost_program_options-devel
BuildRequires:  minisat-devel
BuildRequires:  ninja
BuildRequires:  python3-base
BuildRequires:  python3-setuptools
BuildRequires:  xz

%description
STP is an efficient decision procedure for the validity (or satisfiability) of
formulas from a quantifier-free many-sorted theory of fixed-width bitvectors
and (non-extensional) one-dimensional arrays. The functions in STP's input
language include concatenation, extraction, left/right shift, sign-extension,
unary minus, addition, multiplication, (signed) modulo/division, bitwise
Boolean operations, if-then-else terms, and array reads and writes. The
predicates in the language include equality and (signed) comparators between
bitvector terms.

%package -n libstp%{sover}
Summary:        Constraint Solver

%description -n libstp%{sover}
STP is an efficient decision procedure for the validity (or satisfiability) of
formulas from a quantifier-free many-sorted theory of fixed-width bitvectors
and (non-extensional) one-dimensional arrays. The functions in STP's input
language include concatenation, extraction, left/right shift, sign-extension,
unary minus, addition, multiplication, (signed) modulo/division, bitwise
Boolean operations, if-then-else terms, and array reads and writes. The
predicates in the language include equality and (signed) comparators between
bitvector terms.

%package devel
Summary:        Devel files for stp
Requires:       %{name} = %{version}
Requires:       libstp%{sover} = %{version}
Requires:       minisat-devel
%if 0%{?suse_version} > 1320
Requires:       libboost_program_options-devel
%else
Requires:       boost-devel
%endif

%description devel
Developmnet files for stp library.

%package -n python3-stp
Summary:        Python bindings for stp
Requires:       libstp%{sover} = %{version}
BuildArch:      noarch

%description -n python3-stp
Python bindings for stp library.

%prep
%autosetup -p1

%build
%define __builder ninja
%cmake \
	-DPython_ADDITIONAL_VERSIONS=3 \
	-DALSO_BUILD_STATIC_LIB:BOOL="off" \
	-DSTP_TIMESTAMPS:BOOL="off"
%cmake_build

%install
%cmake_install

install -d %{buildroot}/%{_docdir}/%{name}/example
install -m 644 -t %{buildroot}/%{_docdir}/%{name}/example examples/simple/*

%post -n libstp%{sover} -p /sbin/ldconfig
%postun -n libstp%{sover} -p /sbin/ldconfig

%files
%doc AUTHORS README.markdown
%license LICENSE
%{_bindir}/stp*
%exclude %{_docdir}/%{name}/example/

%files -n libstp%{sover}
%{_libdir}/libstp.so.*

%files devel
%dir %{_includedir}/stp/
%{_includedir}/stp/*.h
%dir %{_libdir}/cmake/
%{_libdir}/libstp.so
%{_libdir}/cmake/STP/
%{_docdir}/%{name}/example/

%files -n python3-stp
%{python3_sitelib}/*

%changelog
openSUSE Build Service is sponsored by