2
0
mirror of https://github.com/boostorg/python.git synced 2026-01-20 16:52:15 +00:00

Compare commits

..

18 Commits

Author SHA1 Message Date
Abhay Kumar
97402f7925 🐛 Fix broken link to Jamroot in example docs 2025-11-03 10:14:34 -05:00
Anton Gladky
668bc7c106 Include missing header boost/type_traits/is_unsigned.hpp
During the Debian Packaging of new version it was found that
this header is missing during the rebuild with GCC-15.
2025-11-03 10:13:40 -05:00
Eisuke Kawashima
5f5f38fa8a fix: fix quotation 2025-11-03 09:30:32 -05:00
Stefan Seefeld
cc873d9682 Fix documentation build error. 2025-11-03 08:40:38 -05:00
Stefan Seefeld
20de46cd0c Update faber 2025-11-03 08:40:38 -05:00
Stefan Seefeld
5d7b9a0648 Stop testing c++98 support 2025-11-03 08:40:38 -05:00
Tom Kent
608ec27c4d Updated to recent compilers/boost 2025-11-03 08:40:38 -05:00
Stefan Seefeld
7fd39323ac Don't rely on Py_REFCNT to test upcast. 2025-11-03 08:40:38 -05:00
Eisuke Kawashima
2b6f667e98 chore: remove meaningless comparison 2025-10-25 15:23:44 -04:00
Eisuke Kawashima
aa458d2ca9 fix(test.properties): use doctest.ELLIPSIS for traceback
Since python 3.11 (PEP 657) traceback info is changed
fix #460
2025-10-25 15:22:21 -04:00
Eisuke Kawashima
16627261f1 fix(test.pickle): fix for change in the return value of object.__reduce__()
https://docs.python.org/3.11/library/pickle.html#object.__reduce__

fix #461
2025-10-25 14:14:07 -04:00
Stefan Seefeld
303299e677 log commands 2025-10-25 13:25:52 -04:00
Stefan Seefeld
cb95b611bb Downgrade run-vcpkg dependency to avoid regression. 2025-10-25 13:25:52 -04:00
Eisuke Kawashima
b4fb28e99a ci: update GitHub Actions 2025-10-23 22:14:55 -04:00
Stefan Seefeld
867f0dddfe Fix windows header path. 2025-10-23 22:08:00 -04:00
Aditya Pillai
a40bb656ee Use Py_REFCNT instead of ob_refcnt on Python 3.9 and above 2025-10-23 19:38:05 -04:00
Eisuke Kawashima
f604eb8d0f fix(test.numpy/ufunc): fix import error and value comparison 2025-04-02 08:21:09 -04:00
Eisuke Kawashima
d30c1bb7a8 refactor: switch to python 3 2025-03-31 21:58:42 -04:00
35 changed files with 143 additions and 84 deletions

View File

@@ -4,14 +4,14 @@ on: [push]
jobs: jobs:
deploy: deploy:
runs-on: ubuntu-20.04 runs-on: ubuntu-24.04
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v5
- name: setup - name: setup
run: | run: |
sudo apt-get update sudo apt-get update
sudo apt-get install \ sudo apt-get install \
libboost1.71-tools-dev \ libboost-tools-dev \
python3 \ python3 \
python3-numpy \ python3-numpy \
python3-sphinx \ python3-sphinx \
@@ -29,7 +29,7 @@ jobs:
echo "destination_dir=doc/develop/html" >> $GITHUB_ENV echo "destination_dir=doc/develop/html" >> $GITHUB_ENV
fi fi
- name: deploy - name: deploy
uses: peaceiris/actions-gh-pages@v3 uses: peaceiris/actions-gh-pages@v4
with: with:
github_token: ${{ secrets.GITHUB_TOKEN }} github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: build/doc/html publish_dir: build/doc/html

View File

@@ -9,14 +9,14 @@ jobs:
strategy: strategy:
fail-fast: false fail-fast: false
matrix: matrix:
python-version: ['3.8.10', '3.12'] python-version: [3.8.10]
cxx: [clang++] cxx: [clang++]
std: [c++11, c++14] # TODO: c++17 is failing ! std: [c++11, c++14] # TODO: c++17 is failing !
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v5
- name: setup python - name: setup python
uses: actions/setup-python@v5 uses: actions/setup-python@v6
with: with:
python-version: ${{ matrix.python-version }} python-version: ${{ matrix.python-version }}
- name: setup prerequisites - name: setup prerequisites

View File

@@ -11,23 +11,27 @@ jobs:
matrix: matrix:
python: [python, python3] python: [python, python3]
cxx: [g++, clang++] cxx: [g++, clang++]
std: [c++98, c++11, c++14, c++17] std: [c++11, c++14, c++17]
include: include:
# Add the appropriate docker image for each compiler. # Add the appropriate docker image for each compiler.
# The images from teeks99/boost-python-test already have boost::python # The images from teeks99/boost-python-test already have boost::python
# pre-reqs installed, see: # pre-reqs installed, see:
# https://github.com/teeks99/boost-python-test-docker # https://github.com/teeks99/boost-python-test-docker
- cxx: clang++ - cxx: clang++
docker-img: teeks99/boost-python-test:clang-12_1.76.0 docker-img: teeks99/boost-python-test:clang-21_1.89.0
- cxx: g++ - cxx: g++
docker-img: teeks99/boost-python-test:gcc-10_1.76.0 docker-img: teeks99/boost-python-test:gcc-15_1.89.0
container: container:
image: ${{ matrix.docker-img }} image: ${{ matrix.docker-img }}
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v5
- name: setup prerequisites
run: |
# Warning: this is not necessarily the same Python version as the one configured above !
python3 -m pip install -U faber --break-system-packages
- name: build - name: build
run: | run: |
${{ matrix.python }} --version ${{ matrix.python }} --version

View File

@@ -11,11 +11,11 @@ jobs:
python-version: [3.7] python-version: [3.7]
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v5
- uses: actions/setup-python@v5 - uses: actions/setup-python@v6
with: with:
python-version: ${{ matrix.python-version }} python-version: ${{ matrix.python-version }}
- uses: microsoft/setup-msbuild@v1.1 - uses: microsoft/setup-msbuild@v2
- name: setup boost prerequisites - name: setup boost prerequisites
uses: lukka/run-vcpkg@v6 uses: lukka/run-vcpkg@v6
with: with:
@@ -42,8 +42,8 @@ jobs:
- name: build - name: build
shell: cmd shell: cmd
run: | run: |
faber --builddir=build cxx.name=msvc --with-boost-include=${{ runner.workspace }}/vcpkg/installed/x64-windows/include -j4 faber --builddir=build cxx.name=msvc --log=commands --log=output --with-boost-include=${{ runner.workspace }}\vcpkg\installed\x64-windows\include -j4
- name: test - name: test
shell: cmd shell: cmd
run: | run: |
faber --builddir=build cxx.name=msvc --with-boost-include=${{ runner.workspace }}/vcpkg/installed/x64-windows/include -j4 test.report faber --builddir=build cxx.name=msvc --with-boost-include=${{ runner.workspace }}\vcpkg\installed\x64-windows\include -j4 test.report

View File

@@ -90,7 +90,7 @@
<tr> <tr>
<td valign="top" width="300"> <td valign="top" width="300">
<h3><a href="{{ pathto('index') }}"><img <h3><a href="{{ pathto('index') }}"><img
alt="C++ Boost" src="{{ pathto('_static/' + logo, 1) }}" border="0"></a></h3> alt="C++ Boost" src="{{ pathto('_static/bpl.png', 1) }}" border="0"></a></h3>
</td> </td>
<td > <td >

View File

@@ -40,8 +40,8 @@ source_suffix = '.rst'
master_doc = 'index' master_doc = 'index'
# General information about the project. # General information about the project.
project = u'Boost.Python NumPy extension' project = 'Boost.Python NumPy extension'
copyright = u'2011, Stefan Seefeld' copyright = '2011, Stefan Seefeld'
# The version info for the project you're documenting, acts as replacement for # The version info for the project you're documenting, acts as replacement for
# |version| and |release|, also used in various other places throughout the # |version| and |release|, also used in various other places throughout the
@@ -181,8 +181,8 @@ html_add_permalinks = False
# Grouping the document tree into LaTeX files. List of tuples # Grouping the document tree into LaTeX files. List of tuples
# (source start file, target name, title, author, documentclass [howto/manual]). # (source start file, target name, title, author, documentclass [howto/manual]).
latex_documents = [ latex_documents = [
('index', 'BoostPythonNumPy.tex', u'Boost.Python NumPy Documentation', ('index', 'BoostPythonNumPy.tex', 'Boost.Python NumPy Documentation',
u'Stefan Seefeld', 'manual'), 'Stefan Seefeld', 'manual'),
] ]
# The name of an image file (relative to this directory) to place at the top of # The name of an image file (relative to this directory) to place at the top of
@@ -214,6 +214,6 @@ latex_documents = [
# One entry per manual page. List of tuples # One entry per manual page. List of tuples
# (source start file, name, description, authors, manual section). # (source start file, name, description, authors, manual section).
man_pages = [ man_pages = [
('index', 'boostnumpy', u'Boost.Python NumPy Documentation', ('index', 'boostnumpy', 'Boost.Python NumPy Documentation',
[u'Stefan Seefeld'], 1) ['Stefan Seefeld'], 1)
] ]

View File

@@ -117,7 +117,7 @@ platforms. The complete list of Bjam executables can be found
[h2 Let's Jam!] [h2 Let's Jam!]
__jam__ __jam__
[@../../../../example/tutorial/Jamroot Here] is our minimalist Jamroot [@../example/Jamroot Here] is our minimalist Jamroot
file. Simply copy the file and tweak [^use-project boost] to where your file. Simply copy the file and tweak [^use-project boost] to where your
boost root directory is and you're OK. boost root directory is and you're OK.

View File

@@ -3,6 +3,7 @@
# (See accompanying file LICENSE_1_0.txt or copy at # (See accompanying file LICENSE_1_0.txt or copy at
# http://www.boost.org/LICENSE_1_0.txt) # http://www.boost.org/LICENSE_1_0.txt)
from __future__ import print_function
import numpy import numpy
import gaussian import gaussian
@@ -19,19 +20,19 @@ x, y = numpy.meshgrid(r, r)
z = g(x, y) z = g(x, y)
s = z.sum() * (r[1] - r[0])**2 s = z.sum() * (r[1] - r[0])**2
print "sum (should be ~ 1):", s print("sum (should be ~ 1):", s)
xc = (z * x).sum() / z.sum() xc = (z * x).sum() / z.sum()
print "x centroid (should be ~ %f): %f" % (mu[0], xc) print("x centroid (should be ~ %f): %f" % (mu[0], xc))
yc = (z * y).sum() / z.sum() yc = (z * y).sum() / z.sum()
print "y centroid (should be ~ %f): %f" % (mu[1], yc) print("y centroid (should be ~ %f): %f" % (mu[1], yc))
xx = (z * (x - xc)**2).sum() / z.sum() xx = (z * (x - xc)**2).sum() / z.sum()
print "xx moment (should be ~ %f): %f" % (sigma[0,0], xx) print("xx moment (should be ~ %f): %f" % (sigma[0,0], xx))
yy = (z * (y - yc)**2).sum() / z.sum() yy = (z * (y - yc)**2).sum() / z.sum()
print "yy moment (should be ~ %f): %f" % (sigma[1,1], yy) print("yy moment (should be ~ %f): %f" % (sigma[1,1], yy))
xy = 0.5 * (z * (x - xc) * (y - yc)).sum() / z.sum() xy = 0.5 * (z * (x - xc) * (y - yc)).sum() / z.sum()
print "xy moment (should be ~ %f): %f" % (sigma[0,1], xy) print("xy moment (should be ~ %f): %f" % (sigma[0,1], xy))

View File

@@ -1,4 +1,4 @@
#! /usr/bin/env python #!/usr/bin/env python3
# Copyright Stefan Seefeld 2006. Distributed under the Boost # Copyright Stefan Seefeld 2006. Distributed under the Boost
# Software License, Version 1.0. (See accompanying # Software License, Version 1.0. (See accompanying
# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) # file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

View File

@@ -1,4 +1,4 @@
#! /usr/bin/env python #!/usr/bin/env python3
# Copyright Ralf W. Grosse-Kunstleve 2006. Distributed under the Boost # Copyright Ralf W. Grosse-Kunstleve 2006. Distributed under the Boost
# Software License, Version 1.0. (See accompanying # Software License, Version 1.0. (See accompanying
# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) # file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

View File

@@ -1,4 +1,4 @@
#! /usr/bin/env python #!/usr/bin/env python3
# Copyright Joel de Guzman 2002-2007. Distributed under the Boost # Copyright Joel de Guzman 2002-2007. Distributed under the Boost
# Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt # Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt
# or copy at http://www.boost.org/LICENSE_1_0.txt) # or copy at http://www.boost.org/LICENSE_1_0.txt)

View File

@@ -16,6 +16,7 @@ from faber.config.try_run import try_run
features += include('include') features += include('include')
features += define('BOOST_ALL_NO_LIB') # disable auto-linking features += define('BOOST_ALL_NO_LIB') # disable auto-linking
features += define('BOOST_NO_AUTO_PTR')
boost_include = options.get_with('boost-include') boost_include = options.get_with('boost-include')
if boost_include: if boost_include:
features += include(boost_include) features += include(boost_include)

View File

@@ -8,6 +8,8 @@
# ifndef BOOST_NO_AUTO_PTR # ifndef BOOST_NO_AUTO_PTR
# include <boost/python/detail/is_xxx.hpp> # include <boost/python/detail/is_xxx.hpp>
# include <memory> # include <memory>
# else
# include <boost/mpl/bool.hpp>
# endif # endif
namespace boost { namespace python { namespace detail { namespace boost { namespace python { namespace detail {

View File

@@ -17,6 +17,7 @@
#include <boost/python/numpy/numpy_object_mgr_traits.hpp> #include <boost/python/numpy/numpy_object_mgr_traits.hpp>
#include <boost/mpl/for_each.hpp> #include <boost/mpl/for_each.hpp>
#include <boost/python/detail/type_traits.hpp> #include <boost/python/detail/type_traits.hpp>
#include <boost/type_traits/is_unsigned.hpp>
namespace boost { namespace python { namespace numpy { namespace boost { namespace python { namespace numpy {

View File

@@ -216,7 +216,13 @@ namespace boost { namespace python { namespace detail {
{ {
for (const_iterator i = proxies.begin(); i != proxies.end(); ++i) for (const_iterator i = proxies.begin(); i != proxies.end(); ++i)
{ {
if ((*i)->ob_refcnt <= 0) if (
#if PY_VERSION_HEX < 0x03090000
(*i)->ob_refcnt
#else
Py_REFCNT(*i)
#endif
<= 0)
{ {
PyErr_SetString(PyExc_RuntimeError, PyErr_SetString(PyExc_RuntimeError,
"Invariant: Proxy vector in an inconsistent state"); "Invariant: Proxy vector in an inconsistent state");

View File

@@ -161,7 +161,6 @@ PyObject* function::call(PyObject* args, PyObject* keywords) const
else else
{ {
// build a new arg tuple, will adjust its size later // build a new arg tuple, will adjust its size later
assert(max_arity <= static_cast<std::size_t>(ssize_t_max));
inner_args = handle<>( inner_args = handle<>(
PyTuple_New(static_cast<ssize_t>(max_arity))); PyTuple_New(static_cast<ssize_t>(max_arity)));

View File

@@ -99,7 +99,7 @@ BOOST_PYTHON_MODULE(back_reference_ext)
.def("set", &Y::set) .def("set", &Y::set)
; ;
class_<Z,std::auto_ptr<Z> >("Z", init<int>()) class_<Z,std::shared_ptr<Z> >("Z", init<int>())
.def("value", &Z::value) .def("value", &Z::value)
.def("set", &Z::set) .def("set", &Z::set)
; ;

View File

@@ -9,14 +9,13 @@
struct foo struct foo
{ {
operator std::auto_ptr<int>&() const; operator std::shared_ptr<int>&() const;
}; };
int main() int main()
{ {
using namespace boost::python::detail; using namespace boost::python::detail;
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<int>::value); BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<int>::value);
BOOST_STATIC_ASSERT(copy_ctor_mutates_rhs<std::auto_ptr<int> >::value);
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<std::string>::value); BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<std::string>::value);
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<foo>::value); BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<foo>::value);
return 0; return 0;

View File

@@ -118,10 +118,10 @@ for t in [('injected',),
tests.append(extension_test('shared_ptr', tests.append(extension_test('shared_ptr',
condition=set.define.contains('HAS_CXX11'))) condition=set.define.contains('HAS_CXX11')))
tests.append(extension_test('polymorphism2_auto_ptr', #tests.append(extension_test('polymorphism2_auto_ptr',
condition=set.define.contains('HAS_CXX11').not_())) # condition=set.define.contains('HAS_CXX11').not_()))
tests.append(extension_test('auto_ptr', #tests.append(extension_test('auto_ptr',
condition=set.define.contains('HAS_CXX11'))) # condition=set.define.contains('HAS_CXX11')))
import_ = binary('import_', ['import_.cpp', src.bpl], features=features|python_libs) import_ = binary('import_', ['import_.cpp', src.bpl], features=features|python_libs)
if platform.os == 'Windows': if platform.os == 'Windows':

View File

@@ -17,7 +17,7 @@ typedef test_class<> X;
X* empty() { return new X(1000); } X* empty() { return new X(1000); }
std::auto_ptr<X> sum(int a, int b) { return std::auto_ptr<X>(new X(a+b)); } std::shared_ptr<X> sum(int a, int b) { return std::shared_ptr<X>(new X(a+b)); }
boost::shared_ptr<X> product(int a, int b, int c) boost::shared_ptr<X> product(int a, int b, int c)
{ {

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env python #!/usr/bin/env python3
# Copyright Jim Bosch & Ankit Daftery 2010-2012. # Copyright Jim Bosch & Ankit Daftery 2010-2012.
# Distributed under the Boost Software License, Version 1.0. # Distributed under the Boost Software License, Version 1.0.
@@ -15,7 +15,7 @@ if (sys.version_info.major >= 3):
class DtypeTestCase(unittest.TestCase): class DtypeTestCase(unittest.TestCase):
def assertEquivalent(self, a, b): def assertEquivalent(self, a, b):
return self.assert_(dtype_ext.equivalent(a, b), "%r is not equivalent to %r") return self.assertTrue(dtype_ext.equivalent(a, b), "%r is not equivalent to %r")
def testIntegers(self): def testIntegers(self):
for bits in (8, 16, 32, 64): for bits in (8, 16, 32, 64):

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env python #!/usr/bin/env python3
# Copyright Jim Bosch & Ankit Daftery 2010-2012. # Copyright Jim Bosch & Ankit Daftery 2010-2012.
# Distributed under the Boost Software License, Version 1.0. # Distributed under the Boost Software License, Version 1.0.

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env python #!/usr/bin/env python3
# Copyright Jim Bosch & Ankit Daftery 2010-2012. # Copyright Jim Bosch & Ankit Daftery 2010-2012.
# Distributed under the Boost Software License, Version 1.0. # Distributed under the Boost Software License, Version 1.0.
@@ -19,7 +19,7 @@ class TestNdarray(unittest.TestCase):
a1 = ndarray_ext.zeros(shape,dt) a1 = ndarray_ext.zeros(shape,dt)
a2 = v.reshape(a1.shape) a2 = v.reshape(a1.shape)
self.assertEqual(shape,a1.shape) self.assertEqual(shape,a1.shape)
self.assert_((a1 == a2).all()) self.assertTrue((a1 == a2).all())
def testNdzeros_matrix(self): def testNdzeros_matrix(self):
for dtp in (numpy.int16, numpy.int32, numpy.float32, numpy.complex128): for dtp in (numpy.int16, numpy.int32, numpy.float32, numpy.complex128):
@@ -28,7 +28,7 @@ class TestNdarray(unittest.TestCase):
a1 = ndarray_ext.zeros_matrix(shape, dt) a1 = ndarray_ext.zeros_matrix(shape, dt)
a2 = numpy.matrix(numpy.zeros(shape, dtype=dtp)) a2 = numpy.matrix(numpy.zeros(shape, dtype=dtp))
self.assertEqual(shape,a1.shape) self.assertEqual(shape,a1.shape)
self.assert_((a1 == a2).all()) self.assertTrue((a1 == a2).all())
self.assertEqual(type(a1), type(a2)) self.assertEqual(type(a1), type(a2))
def testNdarray(self): def testNdarray(self):
@@ -38,8 +38,8 @@ class TestNdarray(unittest.TestCase):
dt = numpy.dtype(dtp) dt = numpy.dtype(dtp)
a1 = ndarray_ext.array(a) a1 = ndarray_ext.array(a)
a2 = ndarray_ext.array(a,dt) a2 = ndarray_ext.array(a,dt)
self.assert_((a1 == v).all()) self.assertTrue((a1 == v).all())
self.assert_((a2 == v).all()) self.assertTrue((a2 == v).all())
for shape in ((60,),(6,10),(4,3,5),(2,2,3,5)): for shape in ((60,),(6,10),(4,3,5),(2,2,3,5)):
a1 = a1.reshape(shape) a1 = a1.reshape(shape)
self.assertEqual(shape,a1.shape) self.assertEqual(shape,a1.shape)

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env python #!/usr/bin/env python3
# Copyright Jim Bosch & Ankit Daftery 2010-2012. # Copyright Jim Bosch & Ankit Daftery 2010-2012.
# Distributed under the Boost Software License, Version 1.0. # Distributed under the Boost Software License, Version 1.0.

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env python #!/usr/bin/env python3
# Copyright Jim Bosch & Ankit Daftery 2010-2012. # Copyright Jim Bosch & Ankit Daftery 2010-2012.
# Distributed under the Boost Software License, Version 1.0. # Distributed under the Boost Software License, Version 1.0.
@@ -18,7 +18,7 @@ class TestTemplates(unittest.TestCase):
a1 = numpy.zeros(shape, dtype=dtype) a1 = numpy.zeros(shape, dtype=dtype)
a2 = v.reshape(a1.shape) a2 = v.reshape(a1.shape)
templates_ext.fill(a1) templates_ext.fill(a1)
self.assert_((a1 == a2).all()) self.assertTrue((a1 == a2).all())
a1 = numpy.zeros((12,), dtype=numpy.float64) a1 = numpy.zeros((12,), dtype=numpy.float64)
self.assertRaises(TypeError, templates_ext.fill, a1) self.assertRaises(TypeError, templates_ext.fill, a1)
a1 = numpy.zeros((12,2,3), dtype=numpy.float32) a1 = numpy.zeros((12,2,3), dtype=numpy.float32)

View File

@@ -1,4 +1,4 @@
#!/usr/bin/env python #!/usr/bin/env python3
# Copyright Jim Bosch & Ankit Daftery 2010-2012. # Copyright Jim Bosch & Ankit Daftery 2010-2012.
# Distributed under the Boost Software License, Version 1.0. # Distributed under the Boost Software License, Version 1.0.
@@ -8,7 +8,10 @@
import ufunc_ext import ufunc_ext
import unittest import unittest
import numpy import numpy
from numpy.testing.utils import assert_array_almost_equal try:
from numpy.testing import assert_array_almost_equal
except ImportError:
from numpy.testing.utils import assert_array_almost_equal
class TestUnary(unittest.TestCase): class TestUnary(unittest.TestCase):
@@ -24,7 +27,7 @@ class TestUnary(unittest.TestCase):
assert_array_almost_equal(b, a*2.0) assert_array_almost_equal(b, a*2.0)
c = numpy.zeros(5, dtype=float) c = numpy.zeros(5, dtype=float)
d = f(a,output=c) d = f(a,output=c)
self.assert_(c is d) self.assertTrue((c == d).all())
assert_array_almost_equal(d, a*2.0) assert_array_almost_equal(d, a*2.0)
def testList(self): def testList(self):
@@ -47,7 +50,7 @@ class TestBinary(unittest.TestCase):
assert_array_almost_equal(f(a,b), (a*2+b*3)) assert_array_almost_equal(f(a,b), (a*2+b*3))
c = numpy.zeros(5, dtype=float) c = numpy.zeros(5, dtype=float)
d = f(a,b,output=c) d = f(a,b,output=c)
self.assert_(c is d) self.assertTrue((c == d).all())
assert_array_almost_equal(d, a*2 + b*3) assert_array_almost_equal(d, a*2 + b*3)
assert_array_almost_equal(f(a, 2.0), a*2 + 6.0) assert_array_almost_equal(f(a, 2.0), a*2 + 6.0)
assert_array_almost_equal(f(1.0, b), 2.0 + b*3) assert_array_almost_equal(f(1.0, b), 2.0 + b*3)

View File

@@ -36,7 +36,7 @@ BOOST_PYTHON_MODULE( operators_wrapper_ext )
; ;
scope().attr("v") = vector(); scope().attr("v") = vector();
std::auto_ptr<vector> dp(new dvector); std::shared_ptr<vector> dp(new dvector);
register_ptr_to_python< std::auto_ptr<vector> >(); register_ptr_to_python< std::shared_ptr<vector> >();
scope().attr("d") = dp; scope().attr("d") = dp;
} }

View File

@@ -9,8 +9,10 @@ r'''>>> import pickle1_ext
1 1
>>> pickle1_ext.world.__name__ >>> pickle1_ext.world.__name__
'world' 'world'
>>> pickle1_ext.world('Hello').__reduce__() >>> pickle1_ext.world('Hello').__reduce__() # doctest: +PY310
(<class 'pickle1_ext.world'>, ('Hello',)) (<class 'pickle1_ext.world'>, ('Hello',))
>>> pickle1_ext.world('Hello').__reduce__() # doctest: +PY311
(<class 'pickle1_ext.world'>, ('Hello',), None)
>>> wd = pickle1_ext.world('California') >>> wd = pickle1_ext.world('California')
>>> pstr = pickle.dumps(wd) >>> pstr = pickle.dumps(wd)
>>> wl = pickle.loads(pstr) >>> wl = pickle.loads(pstr)
@@ -31,7 +33,27 @@ def run(args = None):
if args is not None: if args is not None:
sys.argv = args sys.argv = args
return doctest.testmod(sys.modules.get(__name__))
# > https://docs.python.org/3.11/library/pickle.html#object.__reduce__
# object.__reduce__() returns
# - python 3.10 or prior: a 2-element tuple
# - python 3.11 or later: a 3-element tuple (object's state added)
PY310 = doctest.register_optionflag("PY310")
PY311 = doctest.register_optionflag("PY311")
class ConditionalChecker(doctest.OutputChecker):
def check_output(self, want, got, optionflags):
if (optionflags & PY311) and (sys.version_info[:2] < (3, 11)):
return True
if (optionflags & PY310) and (sys.version_info[:2] >= (3, 11)):
return True
return doctest.OutputChecker.check_output(self, want, got, optionflags)
runner = doctest.DocTestRunner(ConditionalChecker())
for test in doctest.DocTestFinder().find(sys.modules.get(__name__)):
runner.run(test)
return doctest.TestResults(runner.failures, runner.tries)
if __name__ == '__main__': if __name__ == '__main__':
print("running...") print("running...")

View File

@@ -12,8 +12,10 @@ r'''>>> import pickle4_ext
1 1
>>> pickle4_ext.world.__name__ >>> pickle4_ext.world.__name__
'world' 'world'
>>> pickle4_ext.world('Hello').__reduce__() >>> pickle4_ext.world('Hello').__reduce__() # doctest: +PY310
(<class 'pickle4_ext.world'>, ('Hello',)) (<class 'pickle4_ext.world'>, ('Hello',))
>>> pickle4_ext.world('Hello').__reduce__() # doctest: +PY311
(<class 'pickle4_ext.world'>, ('Hello',), None)
>>> wd = pickle4_ext.world('California') >>> wd = pickle4_ext.world('California')
>>> pstr = pickle.dumps(wd) >>> pstr = pickle.dumps(wd)
>>> wl = pickle.loads(pstr) >>> wl = pickle.loads(pstr)
@@ -29,7 +31,27 @@ def run(args = None):
if args is not None: if args is not None:
sys.argv = args sys.argv = args
return doctest.testmod(sys.modules.get(__name__))
# > https://docs.python.org/3.11/library/pickle.html#object.__reduce__
# object.__reduce__() returns
# - python 3.10 or prior: a 2-element tuple
# - python 3.11 or later: a 3-element tuple (object's state added)
PY310 = doctest.register_optionflag("PY310")
PY311 = doctest.register_optionflag("PY311")
class ConditionalChecker(doctest.OutputChecker):
def check_output(self, want, got, optionflags):
if (optionflags & PY311) and (sys.version_info[:2] < (3, 11)):
return True
if (optionflags & PY310) and (sys.version_info[:2] >= (3, 11)):
return True
return doctest.OutputChecker.check_output(self, want, got, optionflags)
runner = doctest.DocTestRunner(ConditionalChecker())
for test in doctest.DocTestFinder().find(sys.modules.get(__name__)):
runner.run(test)
return doctest.TestResults(runner.failures, runner.tries)
if __name__ == '__main__': if __name__ == '__main__':
print("running...") print("running...")

View File

@@ -56,11 +56,10 @@ class instance count from object:
1 1
as expected you can't assign new value to read only property as expected you can't assign new value to read only property
>>> x1.value_r = 2 >>> x1.value_r = 2 # doctest: +ELLIPSIS
Traceback (most recent call last): Traceback (most recent call last):
File "properties.py", line 49, in ? ...
x1.value_r = 2 AttributeError: ...
AttributeError: can't set attribute
setting value_rw to 2. value_direct: setting value_rw to 2. value_direct:
>>> x1.value_rw = 2 >>> x1.value_rw = 2

View File

@@ -62,14 +62,14 @@ int test_main(int, char * [])
assert_holder<Base,Derived assert_holder<Base,Derived
,value_holder_back_reference<Base,Derived> >(); ,value_holder_back_reference<Base,Derived> >();
assert_holder<Base,std::auto_ptr<Base> assert_holder<Base,std::unique_ptr<Base>
,pointer_holder<std::auto_ptr<Base>,Base> >(); ,pointer_holder<std::unique_ptr<Base>,Base> >();
assert_holder<Base,std::auto_ptr<Derived> assert_holder<Base,std::unique_ptr<Derived>
,pointer_holder_back_reference<std::auto_ptr<Derived>,Base> >(); ,pointer_holder_back_reference<std::unique_ptr<Derived>,Base> >();
assert_holder<BR,std::auto_ptr<BR> assert_holder<BR,std::unique_ptr<BR>
,pointer_holder_back_reference<std::auto_ptr<BR>,BR> > (); ,pointer_holder_back_reference<std::unique_ptr<BR>,BR> > ();
return 0; return 0;
} }

View File

@@ -38,7 +38,7 @@
12 12
>>> try: modify(p) >>> try: modify(p)
... except TypeError: pass ... except TypeError: pass
... else: 'print(expected a TypeError)' ... else: print('expected a TypeError')
>>> look(None) >>> look(None)
-1 -1
>>> store(p) >>> store(p)
@@ -61,7 +61,7 @@ bye
13 13
>>> try: modify(z) >>> try: modify(z)
... except TypeError: pass ... except TypeError: pass
... else: 'print(expected a TypeError)' ... else: print('expected a TypeError')
>>> Z.get() # should be None >>> Z.get() # should be None
>>> store(z) >>> store(z)
@@ -84,7 +84,7 @@ bye
17 17
>>> try: modify(x) >>> try: modify(x)
... except TypeError: pass ... except TypeError: pass
... else: 'print(expected a TypeError)' ... else: print('expected a TypeError')
>>> look(None) >>> look(None)
-1 -1
>>> store(x) >>> store(x)

View File

@@ -1,7 +1,7 @@
# Copyright David Abrahams 2004. Distributed under the Boost # Copyright David Abrahams 2004. Distributed under the Boost
# Software License, Version 1.0. (See accompanying # Software License, Version 1.0. (See accompanying
# file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) # file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
#!/usr/bin/env python #!/usr/bin/env python3
from cltree import basic,symbol,constant,variable from cltree import basic,symbol,constant,variable

View File

@@ -13,7 +13,7 @@ int main()
{ {
PyTypeObject o; PyTypeObject o;
Y y; Y y;
BOOST_TEST(&Py_REFCNT(boost::python::upcast<PyObject>(&o)) == &Py_REFCNT(&o)); BOOST_TEST(boost::python::upcast<PyObject>(&o) == reinterpret_cast<PyObject*>(&o));
BOOST_TEST(&Py_REFCNT(boost::python::upcast<PyObject>(&y)) == &Py_REFCNT(&y)); BOOST_TEST(boost::python::upcast<PyObject>(&y) == &y);
return boost::report_errors(); return boost::report_errors();
} }

View File

@@ -20,12 +20,12 @@ struct data
} }
}; };
std::auto_ptr<data> create_data() std::shared_ptr<data> create_data()
{ {
return std::auto_ptr<data>( new data ); return std::shared_ptr<data>( new data );
} }
void do_nothing( std::auto_ptr<data>& ){} void do_nothing( std::shared_ptr<data>& ){}
namespace bp = boost::python; namespace bp = boost::python;
@@ -59,7 +59,7 @@ struct data_wrapper : data, bp::wrapper< data >
BOOST_PYTHON_MODULE(wrapper_held_type_ext) BOOST_PYTHON_MODULE(wrapper_held_type_ext)
{ {
bp::class_< data_wrapper, std::auto_ptr< data > >( "data" ) bp::class_< data_wrapper, std::shared_ptr< data > >( "data" )
.def( "id", &data::id, &::data_wrapper::default_id ); .def( "id", &data::id, &::data_wrapper::default_id );
bp::def( "do_nothing", &do_nothing ); bp::def( "do_nothing", &do_nothing );