forked from pool/python-berkeleydb
Compare commits
4 Commits
Author | SHA256 | Date | |
---|---|---|---|
|
df4f2c221e | ||
16e78b99be | |||
|
30ccdd9c99 | ||
b255ab15e2 |
3
berkeleydb-18.1.11.tar.gz
Normal file
3
berkeleydb-18.1.11.tar.gz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:7454f560d2d1a0e5d0d5630a437f19926b68bc794eb161edea2cdc4b267cf574
|
||||||
|
size 174774
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:e1831a790bfd855740e5c12f952f19f646c269806cfc362775afd9878cf32557
|
|
||||||
size 294803
|
|
@ -1,3 +1,124 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Nov 19 12:52:51 UTC 2024 - Dirk Müller <dmueller@suse.com>
|
||||||
|
|
||||||
|
- update to 18.1.11:
|
||||||
|
* WARNING - BREAKING CHANGE: Drop support for Python 3.8. This
|
||||||
|
breaking change should usually require a major and/or minor
|
||||||
|
number update. Since berkeleydb traditional numbering is
|
||||||
|
related to the higher Oracle Berkeley DB supported, I would
|
||||||
|
usually wait until Oracle releases a new version to upgrade
|
||||||
|
my own version and deprecate old Python support at the same
|
||||||
|
time. Given that Oracle has not released a new Oracle
|
||||||
|
Berkeley DB in almost five years, I must break this practice
|
||||||
|
for now. I am sorry if this update breaks your Python 3.8
|
||||||
|
environment. In that case, please pin your berkeleydb
|
||||||
|
installation to
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Oct 9 06:33:55 UTC 2024 - Dirk Müller <dmueller@suse.com>
|
||||||
|
|
||||||
|
- update to 18.1.10:
|
||||||
|
* Since MS Windows is unsupported without community help, I
|
||||||
|
deleted some legacy code. It could be restored if there is
|
||||||
|
demand and some help to improve MS Windows support.
|
||||||
|
* New URL for :Oracle:`Oracle documentation <index.html>`.
|
||||||
|
* Now we also use Python Stable ABI under Python 3.8 and 3.9.
|
||||||
|
Under Python 3.10 and up we can define types that users can
|
||||||
|
not instantiate as Py_TPFLAGS_DISALLOW_INSTANTIATION, but
|
||||||
|
that flag is not available under previous Python versions. In
|
||||||
|
Python 3.8 and 3.9 we used to do type->tp_new = NULL; for
|
||||||
|
that, but this approach is not available under Python Stable
|
||||||
|
ABI. That is the reason this module could use Python Stable
|
||||||
|
ABI only when compiled under Python 3.10 and superior. In
|
||||||
|
this release we define the slot Py_tp_new as NULL in Python
|
||||||
|
3.8 and 3.9 to achieve the same effect, and that is available
|
||||||
|
under Python Stable ABI.
|
||||||
|
* Since this module can now use Python Stable ABI under all
|
||||||
|
supported Python releases, that is exactly what we do. From
|
||||||
|
now on this module always uses Python Stable ABI.
|
||||||
|
* WARNING - BREAKING CHANGE: Change return value of
|
||||||
|
berkeleydb.py_limited_api(). This function was introduced in
|
||||||
|
18.1.9 and it is used to indicate if the module was using the
|
||||||
|
Python Stable ABI or not, and the version Python Stable ABI
|
||||||
|
used. Now that the module has been improved to use Python
|
||||||
|
Stable ABI always, the function returns a tuple of integers.
|
||||||
|
First tuple element tells us what Python Stable ABI version
|
||||||
|
are we supporting. Second element tells us what Python
|
||||||
|
release was this module compiled under, although it should
|
||||||
|
work in any more recent Python release. Since this function
|
||||||
|
was introduced in release 18.1.9, we consider this breaking
|
||||||
|
change a minor infraction affecting most probably nobody.
|
||||||
|
* Delete some unneeded ancient Python 2.x code.
|
||||||
|
* Delete more unneeded code to check threading support since
|
||||||
|
Python 3.7 and up always guarantee threads.
|
||||||
|
* pkg_resources is deprecated, so migrate to packaging. This is
|
||||||
|
already provided by modern setuptools. This change only
|
||||||
|
affects you if you run the test suite.
|
||||||
|
* If compiled under Python 3.10 or higher, we use the Python
|
||||||
|
Stable ABI, as defined in PEP 384 and related PEPs. That is,
|
||||||
|
you can use the same compiled module with any Python release
|
||||||
|
if Python version >= 3.10. In order to achieve this, we have
|
||||||
|
made these changes: Some fast Python API (not error
|
||||||
|
checking) have been replaced by somewhat slower functions
|
||||||
|
(functions that do error checking), because the former are
|
||||||
|
not available in the Stable ABI: PyBytes_GET_SIZE(),
|
||||||
|
PyBytes_AS_STRING(), PyTuple_SET_ITEM(). We replaced
|
||||||
|
PyErr_Warn() by PyErr_WarnEx() because it is not available in
|
||||||
|
the Stable ABI. When an exception is raised because an
|
||||||
|
incompatible type, we need to write complicated code because
|
||||||
|
Py_TYPE(keyobj)->tp_name is not available in the Stable ABI.
|
||||||
|
Code generated for Python < 3.11 is "ugly", we will clean it
|
||||||
|
up when the minimum supported Python version is 3.11.
|
||||||
|
TYPE->tp_alloc is not available under the Stable ABI. We
|
||||||
|
replace it with PyType_GenericNew(). Internal types that
|
||||||
|
should NOT be instanciated by the user has type->tp_new =
|
||||||
|
NULL. This can not be done under the Stable ABI, so we use
|
||||||
|
Py_TPFLAGS_DISALLOW_INSTANTIATION flag. This is the reason we
|
||||||
|
only create Stable ABI modules under Python >= 3.10, because
|
||||||
|
that flag is defined in that Python release. The new function
|
||||||
|
berkeleydb.py_limited_api() returns an integer describing the
|
||||||
|
minimum supported Stable ABI or None. If None, the module is
|
||||||
|
not compiled with Stable ABI and can not be used with a
|
||||||
|
different Python version. When not None, the value of
|
||||||
|
berkeleydb.py_limited_api() can be easily interpreted using
|
||||||
|
something like hex(berkeleydb.py_limited_api()).
|
||||||
|
* Some fast Python API (not error checking) have been replaced
|
||||||
|
by somewhat slower functions (functions that do error
|
||||||
|
checking), because the former are not available in the Stable
|
||||||
|
ABI: PyBytes_GET_SIZE(), PyBytes_AS_STRING(),
|
||||||
|
PyTuple_SET_ITEM().
|
||||||
|
* We replaced PyErr_Warn() by PyErr_WarnEx() because it is not
|
||||||
|
available in the Stable ABI.
|
||||||
|
* When an exception is raised because an incompatible type, we
|
||||||
|
need to write complicated code because
|
||||||
|
Py_TYPE(keyobj)->tp_name is not available in the Stable ABI.
|
||||||
|
Code generated for Python < 3.11 is "ugly", we will clean it
|
||||||
|
up when the minimum supported Python version is 3.11.
|
||||||
|
* TYPE->tp_alloc is not available under the Stable ABI. We
|
||||||
|
replace it with PyType_GenericNew().
|
||||||
|
* Internal types that should NOT be instanciated by the user
|
||||||
|
has type->tp_new = NULL. This can not be done under the
|
||||||
|
Stable ABI, so we use Py_TPFLAGS_DISALLOW_INSTANTIATION flag.
|
||||||
|
This is the reason we only create Stable ABI modules under
|
||||||
|
Python >= 3.10, because that flag is defined in that Python
|
||||||
|
release.
|
||||||
|
* The new function berkeleydb.py_limited_api() returns an
|
||||||
|
integer describing the minimum supported Stable ABI or None.
|
||||||
|
If None, the module is not compiled with Stable ABI and can
|
||||||
|
not be used with a different Python version. When not None,
|
||||||
|
the value of berkeleydb.py_limited_api() can be easily
|
||||||
|
interpreted using something like
|
||||||
|
hex(berkeleydb.py_limited_api()).
|
||||||
|
* Python 3.13 added to the full test matrix.
|
||||||
|
* Experimental Python 3.13 support. Tested under 3.13.0b2.
|
||||||
|
* This code can be compiled under MS Windows, but I am unable
|
||||||
|
to provide support for it and it is far from trivial. Because
|
||||||
|
of this and some complains about it, I change the
|
||||||
|
"Classifiers" for this project from 'Operating System :: OS
|
||||||
|
Independent' to 'Operating System :: Unix' I would restore
|
||||||
|
MS Windows support if there is some kind of community support
|
||||||
|
for it. I can not do it by myself alone. Sorry about that.
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Mon Feb 5 03:28:49 UTC 2024 - Steve Kowalik <steven.kowalik@suse.com>
|
Mon Feb 5 03:28:49 UTC 2024 - Steve Kowalik <steven.kowalik@suse.com>
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
|
|
||||||
Name: python-berkeleydb
|
Name: python-berkeleydb
|
||||||
Version: 18.1.8
|
Version: 18.1.11
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: Python bindings for Oracle Berkeley DB
|
Summary: Python bindings for Oracle Berkeley DB
|
||||||
License: BSD-3-Clause
|
License: BSD-3-Clause
|
||||||
|
Loading…
Reference in New Issue
Block a user