2
0
mirror of https://github.com/boostorg/python.git synced 2026-01-20 04:42:28 +00:00

Compare commits

...

9 Commits

Author SHA1 Message Date
Stefan Seefeld
76799ffa6d Test with multiple python versions. 2025-03-31 23:50:50 -04:00
Eisuke Kawashima
d30c1bb7a8 refactor: switch to python 3 2025-03-31 21:58:42 -04:00
Aditya Pillai
3e7be69e1e Conditionally use Py_REFCNT 2025-03-10 15:10:12 -04:00
Aditya Pillai
cbdf1ce2a1 Use Py_REFCNT instead of ->ob_refcnt
Py_REFCNT was stabilized in 3.9, uses this official API instead of the
`ob_refcnt` field that doesn't exist in the free-threaded build of 3.13.
2025-03-10 15:10:12 -04:00
Stefan Seefeld
4fe3403584 Make sure to pass C++ version to preprocessor as well. 2025-02-01 22:55:02 -05:00
Stefan Seefeld
b1b43f1e1a Fix homebrew include path. 2025-02-01 22:55:02 -05:00
Peter Dimov
7b1960446b Merge pull request #470 from boostorg/pr/fix-iterator-detail
Replace use of boost/iterator/detail/enable_if.hpp
2025-02-01 19:35:16 +02:00
Peter Dimov
2dc5a92727 Replace use of boost/iterator/detail/enable_if.hpp 2025-01-28 02:27:49 +02:00
sdarwin
4fc3afa3ac Support newer version of Sphinx 2024-10-10 09:28:59 -04:00
18 changed files with 74 additions and 37 deletions

View File

@@ -32,17 +32,19 @@ jobs:
faber -v faber -v
sed -e "s/\$PYTHON/python/g" .ci/faber > ~/.faber sed -e "s/\$PYTHON/python/g" .ci/faber > ~/.faber
faber \ faber \
--with-boost-include=/opt/homebrew/Cellar/boost/1.86.0/include \ --with-boost-include=$(brew --prefix boost)/include \
--builddir=build \ --builddir=build \
cxx.name=${{ matrix.cxx }} \ cxx.name=${{ matrix.cxx }} \
cxxflags=-std=${{ matrix.std }} \ cxxflags=-std=${{ matrix.std }} \
cppflags=-std=${{ matrix.std }} \
-j`sysctl -n hw.ncpu` -j`sysctl -n hw.ncpu`
- name: test - name: test
run: | run: |
faber \ faber \
--with-boost-include=/opt/homebrew/Cellar/boost/1.86.0/include \ --with-boost-include=$(brew --prefix boost)/include \
--builddir=build\ --builddir=build\
cxx.name=${{ matrix.cxx }} \ cxx.name=${{ matrix.cxx }} \
cxxflags=-std=${{ matrix.std }} \ cxxflags=-std=${{ matrix.std }} \
cppflags=-std=${{ matrix.std }} \
-j`sysctl -n hw.ncpu` \ -j`sysctl -n hw.ncpu` \
test.report test.report

View File

@@ -9,7 +9,7 @@ jobs:
strategy: strategy:
fail-fast: false fail-fast: false
matrix: matrix:
python: [python, python3] python-version: ['3.8.18', '3.9.21', '3.10.15', '3.11.11', '3.12.9', '3.13.2']
cxx: [g++, clang++] cxx: [g++, clang++]
std: [c++98, c++11, c++14, c++17] std: [c++98, c++11, c++14, c++17]
include: include:
@@ -27,10 +27,13 @@ jobs:
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: build - name: build
run: | run: |
${{ matrix.python }} --version python --version
${{ matrix.cxx }} --version ${{ matrix.cxx }} --version
faber -v faber -v
sed -e "s/\$PYTHON/${{ matrix.python }}/g" .ci/faber > ~/.faber sed -e "s/\$PYTHON/${{ matrix.python }}/g" .ci/faber > ~/.faber
@@ -39,6 +42,7 @@ jobs:
--builddir=build \ --builddir=build \
cxx.name=${{ matrix.cxx }} \ cxx.name=${{ matrix.cxx }} \
cxxflags=-std=${{ matrix.std }} \ cxxflags=-std=${{ matrix.std }} \
cppflags=-std=${{ matrix.std }} \
-j`nproc` -j`nproc`
- name: test - name: test
run: | run: |
@@ -47,5 +51,6 @@ jobs:
--builddir=build \ --builddir=build \
cxx.name=${{ matrix.cxx }} \ cxx.name=${{ matrix.cxx }} \
cxxflags=-std=${{ matrix.std }} \ cxxflags=-std=${{ matrix.std }} \
cppflags=-std=${{ matrix.std }} \
-j`nproc` \ -j`nproc` \
test.report test.report

View File

@@ -714,3 +714,23 @@ span.purple { color: purple; }
span.gold { color: gold; } span.gold { color: gold; }
span.silver { color: silver; } /* lighter gray */ span.silver { color: silver; } /* lighter gray */
span.gray { color: #808080; } /* light gray */ span.gray { color: #808080; } /* light gray */
/* 2022 fix */
ol.simple ol p,
ol.simple ul p,
ul.simple ol p,
ul.simple ul p {
margin-top: 0;
}
ol.simple > li:not(:first-child) > p,
ul.simple > li:not(:first-child) > p {
margin-top: 0;
}
ol.simple p,
ul.simple p {
margin-bottom: 0;
}

View File

@@ -49,6 +49,9 @@
{%- for scriptfile in script_files %} {%- for scriptfile in script_files %}
<script type="text/javascript" src="{{ pathto(scriptfile, 1) }}"></script> <script type="text/javascript" src="{{ pathto(scriptfile, 1) }}"></script>
{%- endfor %} {%- endfor %}
<script data-url_root="{{ pathto('', 1) }}" id="documentation_options" src="{{ pathto('', 1) }}_static/documentation_options.js"></script>
<script src="{{ pathto('', 1) }}_static/searchtools.js"></script>
<script src="{{ pathto('', 1) }}_static/language_data.js"></script>
{%- if use_opensearch %} {%- if use_opensearch %}
<link rel="search" type="application/opensearchdescription+xml" <link rel="search" type="application/opensearchdescription+xml"
title="{% trans docstitle=docstitle|e %}Search within {{ docstitle }}{% endtrans %}" title="{% trans docstitle=docstitle|e %}Search within {{ docstitle }}{% endtrans %}"

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

@@ -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

@@ -9,7 +9,7 @@
# include <boost/python/object_core.hpp> # include <boost/python/object_core.hpp>
# include <boost/python/call.hpp> # include <boost/python/call.hpp>
# include <boost/iterator/detail/enable_if.hpp> # include <boost/type_traits/enable_if.hpp>
# include <boost/mpl/bool.hpp> # include <boost/mpl/bool.hpp>
# include <boost/iterator/detail/config_def.hpp> # include <boost/iterator/detail/config_def.hpp>
@@ -40,7 +40,7 @@ struct is_object_operators
# if !defined(BOOST_NO_SFINAE) && !defined(BOOST_NO_IS_CONVERTIBLE) # if !defined(BOOST_NO_SFINAE) && !defined(BOOST_NO_IS_CONVERTIBLE)
template <class L, class R, class T> template <class L, class R, class T>
struct enable_binary struct enable_binary
: boost::iterators::enable_if<is_object_operators<L,R>, T> : boost::enable_if_<is_object_operators<L,R>::value, T>
{}; {};
# define BOOST_PYTHON_BINARY_RETURN(T) typename enable_binary<L,R,T>::type # define BOOST_PYTHON_BINARY_RETURN(T) typename enable_binary<L,R,T>::type
# else # else

View File

@@ -222,7 +222,13 @@ namespace
, char const* ref_type) , char const* ref_type)
{ {
handle<> holder(source); handle<> holder(source);
if (source->ob_refcnt <= 1) if (
#if PY_VERSION_HEX < 0x03090000
source->ob_refcnt
#else
Py_REFCNT(source)
#endif
<= 1)
{ {
handle<> msg( handle<> msg(
#if PY_VERSION_HEX >= 0x3000000 #if PY_VERSION_HEX >= 0x3000000

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.
@@ -24,7 +24,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 is d)
assert_array_almost_equal(d, a*2.0) assert_array_almost_equal(d, a*2.0)
def testList(self): def testList(self):
@@ -47,7 +47,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 is d)
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

@@ -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