mirror of
https://github.com/boostorg/python.git
synced 2026-01-19 16:32:16 +00:00
Compare commits
15 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3e4c518f4d | ||
|
|
2b6f667e98 | ||
|
|
aa458d2ca9 | ||
|
|
16627261f1 | ||
|
|
303299e677 | ||
|
|
cb95b611bb | ||
|
|
b4fb28e99a | ||
|
|
867f0dddfe | ||
|
|
a40bb656ee | ||
|
|
f604eb8d0f | ||
|
|
d30c1bb7a8 | ||
|
|
3e7be69e1e | ||
|
|
cbdf1ce2a1 | ||
|
|
4fe3403584 | ||
|
|
b1b43f1e1a |
10
.github/workflows/deploy-documentation.yml
vendored
10
.github/workflows/deploy-documentation.yml
vendored
@@ -4,20 +4,20 @@ 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 \
|
||||||
xsltproc \
|
xsltproc \
|
||||||
docbook-xsl
|
docbook-xsl
|
||||||
sudo python3 -m pip install --upgrade pip
|
#sudo python3 -m pip install --upgrade pip
|
||||||
sudo python3 -m pip install faber
|
sudo python3 -m pip install faber
|
||||||
- name: build
|
- name: build
|
||||||
run: |
|
run: |
|
||||||
@@ -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
|
||||||
|
|||||||
10
.github/workflows/test-osx.yml
vendored
10
.github/workflows/test-osx.yml
vendored
@@ -14,9 +14,9 @@ jobs:
|
|||||||
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
|
||||||
@@ -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
|
||||||
|
|||||||
4
.github/workflows/test-ubuntu.yml
vendored
4
.github/workflows/test-ubuntu.yml
vendored
@@ -26,7 +26,7 @@ jobs:
|
|||||||
image: ${{ matrix.docker-img }}
|
image: ${{ matrix.docker-img }}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: build
|
- name: build
|
||||||
run: |
|
run: |
|
||||||
@@ -39,6 +39,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 +48,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
|
||||||
|
|||||||
10
.github/workflows/test-windows.yml
vendored
10
.github/workflows/test-windows.yml
vendored
@@ -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
|
||||||
|
|||||||
@@ -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)
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -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))
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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");
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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)));
|
||||||
|
|
||||||
|
|||||||
@@ -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):
|
||||||
|
|||||||
@@ -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.
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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.
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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...")
|
||||||
|
|||||||
@@ -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...")
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user