mirror of
https://github.com/boostorg/python.git
synced 2026-01-19 16:32:16 +00:00
Compare commits
43 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3e4c518f4d | ||
|
|
2b6f667e98 | ||
|
|
aa458d2ca9 | ||
|
|
16627261f1 | ||
|
|
303299e677 | ||
|
|
cb95b611bb | ||
|
|
b4fb28e99a | ||
|
|
867f0dddfe | ||
|
|
a40bb656ee | ||
|
|
f604eb8d0f | ||
|
|
d30c1bb7a8 | ||
|
|
3e7be69e1e | ||
|
|
cbdf1ce2a1 | ||
|
|
4fe3403584 | ||
|
|
b1b43f1e1a | ||
|
|
7b1960446b | ||
|
|
2dc5a92727 | ||
|
|
4fc3afa3ac | ||
|
|
ff0ae9b29d | ||
|
|
b988d70207 | ||
|
|
b3a28d7033 | ||
|
|
3ea0cb8501 | ||
|
|
95e53011d8 | ||
|
|
301256cf1e | ||
|
|
c76d67ef3f | ||
|
|
0102b31945 | ||
|
|
4c6f40fb82 | ||
|
|
d1910f3d65 | ||
|
|
c4e3b13dc2 | ||
|
|
a498e2458c | ||
|
|
7a3cc07042 | ||
|
|
58b1a010bb | ||
|
|
8ca8724ad9 | ||
|
|
5a8d096135 | ||
|
|
30bdbf3ae2 | ||
|
|
5a07cdb96b | ||
|
|
06fa956fe8 | ||
|
|
9ab1742c46 | ||
|
|
071b0bc964 | ||
|
|
d8d9861036 | ||
|
|
f6d20e1099 | ||
|
|
99a5352b5c | ||
|
|
1fed0824ad |
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
|
||||||
|
|||||||
13
.github/workflows/test-osx.yml
vendored
13
.github/workflows/test-osx.yml
vendored
@@ -9,14 +9,14 @@ jobs:
|
|||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
python-version: [3.6]
|
python-version: [3.8.10]
|
||||||
cxx: [clang++]
|
cxx: [clang++]
|
||||||
std: [c++98, c++11, c++14] # TODO: c++17 is failing !
|
std: [c++11, c++14] # TODO: c++17 is failing !
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v5
|
||||||
- name: setup python
|
- name: setup python
|
||||||
uses: actions/setup-python@v2
|
uses: actions/setup-python@v6
|
||||||
with:
|
with:
|
||||||
python-version: ${{ matrix.python-version }}
|
python-version: ${{ matrix.python-version }}
|
||||||
- name: setup prerequisites
|
- name: setup prerequisites
|
||||||
@@ -28,18 +28,23 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
python --version
|
python --version
|
||||||
${{ matrix.cxx }} --version
|
${{ matrix.cxx }} --version
|
||||||
|
brew info boost
|
||||||
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=$(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=$(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@v2
|
- 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@v2
|
- uses: actions/checkout@v5
|
||||||
- uses: actions/setup-python@v2
|
- 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
|
||||||
|
|||||||
41
build.jam
Normal file
41
build.jam
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
# Copyright René Ferdinand Rivera Morell 2024
|
||||||
|
# Distributed under the Boost Software License, Version 1.0.
|
||||||
|
# (See accompanying file LICENSE_1_0.txt or copy at
|
||||||
|
# http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
|
||||||
|
require-b2 5.2 ;
|
||||||
|
|
||||||
|
constant boost_dependencies :
|
||||||
|
/boost/align//boost_align
|
||||||
|
/boost/bind//boost_bind
|
||||||
|
/boost/config//boost_config
|
||||||
|
/boost/conversion//boost_conversion
|
||||||
|
/boost/core//boost_core
|
||||||
|
/boost/detail//boost_detail
|
||||||
|
/boost/foreach//boost_foreach
|
||||||
|
/boost/function//boost_function
|
||||||
|
/boost/iterator//boost_iterator
|
||||||
|
/boost/lexical_cast//boost_lexical_cast
|
||||||
|
/boost/mpl//boost_mpl
|
||||||
|
/boost/numeric_conversion//boost_numeric_conversion
|
||||||
|
/boost/preprocessor//boost_preprocessor
|
||||||
|
/boost/static_assert//boost_static_assert
|
||||||
|
/boost/tuple//boost_tuple
|
||||||
|
/boost/type_traits//boost_type_traits
|
||||||
|
/boost/utility//boost_utility ;
|
||||||
|
|
||||||
|
project /boost/python
|
||||||
|
: common-requirements
|
||||||
|
<include>include
|
||||||
|
;
|
||||||
|
|
||||||
|
explicit
|
||||||
|
[ alias boost_python : build//boost_python ]
|
||||||
|
[ alias boost_numpy : build//boost_numpy ]
|
||||||
|
[ alias all : boost_python boost_numpy test ]
|
||||||
|
;
|
||||||
|
|
||||||
|
call-if : boost-library python
|
||||||
|
: install boost_python boost_numpy
|
||||||
|
;
|
||||||
|
|
||||||
@@ -30,14 +30,34 @@ else
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
project boost/python
|
constant boost_dependencies_private :
|
||||||
|
/boost/graph//boost_graph
|
||||||
|
/boost/integer//boost_integer
|
||||||
|
/boost/property_map//boost_property_map
|
||||||
|
/boost/smart_ptr//boost_smart_ptr
|
||||||
|
;
|
||||||
|
|
||||||
|
project
|
||||||
: source-location ../src
|
: source-location ../src
|
||||||
|
: common-requirements <library>$(boost_dependencies)
|
||||||
|
: requirements <library>$(boost_dependencies_private)
|
||||||
;
|
;
|
||||||
|
|
||||||
rule cond ( test ? : yes * : no * ) { if $(test) { return $(yes) ; } else { return $(no) ; } }
|
rule cond ( test ? : yes * : no * ) { if $(test) { return $(yes) ; } else { return $(no) ; } }
|
||||||
rule unless ( test ? : yes * : no * ) { if ! $(test) { return $(yes) ; } else { return $(no) ; } }
|
rule unless ( test ? : yes * : no * ) { if ! $(test) { return $(yes) ; } else { return $(no) ; } }
|
||||||
local rule eq ( a : b ) { if $(a) = $(b) { return 1 ; } }
|
local rule eq ( a : b ) { if $(a) = $(b) { return 1 ; } }
|
||||||
|
|
||||||
|
rule tag ( name : type ? : property-set )
|
||||||
|
{
|
||||||
|
if python-tag in [ RULENAMES $(__name__) ]
|
||||||
|
{
|
||||||
|
return [ $(__name__).python-tag $(name) : $(type) : $(property-set) ] ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ python.configured ]
|
||||||
|
{
|
||||||
|
|
||||||
lib boost_python
|
lib boost_python
|
||||||
: # sources
|
: # sources
|
||||||
list.cpp
|
list.cpp
|
||||||
@@ -92,8 +112,9 @@ lib boost_python
|
|||||||
[ unless [ python.configured ] : <build>no ]
|
[ unless [ python.configured ] : <build>no ]
|
||||||
<dependency>config-warning
|
<dependency>config-warning
|
||||||
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
||||||
|
-<tag>@%boostcpp.tag
|
||||||
-<tag>@$(BOOST_JAMROOT_MODULE)%$(BOOST_JAMROOT_MODULE).tag
|
-<tag>@$(BOOST_JAMROOT_MODULE)%$(BOOST_JAMROOT_MODULE).tag
|
||||||
<tag>@python-tag
|
<tag>@tag
|
||||||
<conditional>@python.require-py
|
<conditional>@python.require-py
|
||||||
|
|
||||||
: # default build
|
: # default build
|
||||||
@@ -101,8 +122,20 @@ lib boost_python
|
|||||||
: # usage requirements
|
: # usage requirements
|
||||||
<link>static:<define>BOOST_PYTHON_STATIC_LIB
|
<link>static:<define>BOOST_PYTHON_STATIC_LIB
|
||||||
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
||||||
|
<define>BOOST_PYTHON_NO_LIB
|
||||||
;
|
;
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
|
||||||
|
alias boost_python : config-warning ;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ python.configured ] && [ python.numpy ]
|
||||||
|
{
|
||||||
|
|
||||||
numpy-include = [ python.numpy-include ] ;
|
numpy-include = [ python.numpy-include ] ;
|
||||||
lib boost_numpy
|
lib boost_numpy
|
||||||
: # sources
|
: # sources
|
||||||
@@ -120,8 +153,9 @@ lib boost_numpy
|
|||||||
<library>/python//numpy
|
<library>/python//numpy
|
||||||
<library>boost_python
|
<library>boost_python
|
||||||
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
||||||
|
-<tag>@%boostcpp.tag
|
||||||
-<tag>@$(BOOST_JAMROOT_MODULE)%$(BOOST_JAMROOT_MODULE).tag
|
-<tag>@$(BOOST_JAMROOT_MODULE)%$(BOOST_JAMROOT_MODULE).tag
|
||||||
<tag>@python-tag
|
<tag>@tag
|
||||||
<conditional>@python.require-py
|
<conditional>@python.require-py
|
||||||
|
|
||||||
: # default build
|
: # default build
|
||||||
@@ -129,39 +163,13 @@ lib boost_numpy
|
|||||||
: # usage requirements
|
: # usage requirements
|
||||||
<link>static:<define>BOOST_NUMPY_STATIC_LIB
|
<link>static:<define>BOOST_NUMPY_STATIC_LIB
|
||||||
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
<python-debugging>on:<define>BOOST_DEBUG_PYTHON
|
||||||
|
<define>BOOST_NUMPY_NO_LIB
|
||||||
;
|
;
|
||||||
|
|
||||||
# boost-install creates `stage` and `install` targets
|
|
||||||
#
|
|
||||||
# `stage` stages (builds and copies into `stage/lib`) the given libraries
|
|
||||||
# `boost_python` and `boost_numpy` and their dependencies and is similar
|
|
||||||
# to issuing `b2 --with-python stage` from top level
|
|
||||||
#
|
|
||||||
# `install` installs the two libraries and their dependencies and is similar
|
|
||||||
# to issuing `b2 --with-python install` from top level
|
|
||||||
|
|
||||||
if [ python.configured ]
|
|
||||||
{
|
|
||||||
if [ python.numpy ]
|
|
||||||
{
|
|
||||||
boost-install boost_python boost_numpy ;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
boost-install boost_python ;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
# When Python isn't configured, the above `boost-install` is not executed,
|
alias boost_numpy : config-warning ;
|
||||||
# so we create empty `stage` and `install` targets that do nothing but issue
|
|
||||||
# a warning message unless `--without-python` is given
|
|
||||||
|
|
||||||
alias stage : config-warning ;
|
|
||||||
explicit stage ;
|
|
||||||
|
|
||||||
alias install : config-warning ;
|
|
||||||
explicit install ;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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 %}"
|
||||||
|
|||||||
@@ -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)
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -48,7 +48,7 @@ Next, create a list, and add this tuple to the list. Then use the list to create
|
|||||||
list_for_dtype.append(for_custom_dtype) ;
|
list_for_dtype.append(for_custom_dtype) ;
|
||||||
np::dtype custom_dtype = np::dtype(list_for_dtype) ;
|
np::dtype custom_dtype = np::dtype(list_for_dtype) ;
|
||||||
|
|
||||||
We are now ready to create an ndarray with dimensions specified by \*shape\* and of custom dtpye ::
|
We are now ready to create an ndarray with dimensions specified by \*shape\* and of custom dtype ::
|
||||||
|
|
||||||
np::ndarray new_array = np::zeros(shape,custom_dtype);
|
np::ndarray new_array = np::zeros(shape,custom_dtype);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@
|
|||||||
# Examples
|
# Examples
|
||||||
|
|
||||||
This directory contains various examples using Boost.Python.
|
This directory contains various examples using Boost.Python.
|
||||||
You may compile these using the `bjam` command either in this directory
|
You may compile these using the `b2` command either in this directory
|
||||||
or in any of the subdirectories.
|
or in any of the subdirectories.
|
||||||
You may need to adjust the paths in the Jamroot file if Boost.Python
|
You may need to adjust the paths in the Jamroot file if Boost.Python
|
||||||
is not installed in a default location.
|
is not installed in a default location.
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -372,10 +372,11 @@ class class_ : public objects::class_base
|
|||||||
{
|
{
|
||||||
typedef typename api::is_object_operators<F>::type is_obj_or_proxy;
|
typedef typename api::is_object_operators<F>::type is_obj_or_proxy;
|
||||||
|
|
||||||
return this->make_fn_impl(
|
return objects::add_doc(
|
||||||
|
this->make_fn_impl(
|
||||||
detail::unwrap_wrapper((W*)0)
|
detail::unwrap_wrapper((W*)0)
|
||||||
, f, is_obj_or_proxy(), (char*)0, detail::is_data_member_pointer<F>()
|
, f, is_obj_or_proxy(), (char*)0, detail::is_data_member_pointer<F>()
|
||||||
);
|
), NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class F>
|
template <class F>
|
||||||
@@ -383,10 +384,11 @@ class class_ : public objects::class_base
|
|||||||
{
|
{
|
||||||
typedef typename api::is_object_operators<F>::type is_obj_or_proxy;
|
typedef typename api::is_object_operators<F>::type is_obj_or_proxy;
|
||||||
|
|
||||||
return this->make_fn_impl(
|
return objects::add_doc(
|
||||||
|
this->make_fn_impl(
|
||||||
detail::unwrap_wrapper((W*)0)
|
detail::unwrap_wrapper((W*)0)
|
||||||
, f, is_obj_or_proxy(), (int*)0, detail::is_data_member_pointer<F>()
|
, f, is_obj_or_proxy(), (int*)0, detail::is_data_member_pointer<F>()
|
||||||
);
|
), NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T, class F>
|
template <class T, class F>
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
# include <boost/python/converter/registered.hpp>
|
# include <boost/python/converter/registered.hpp>
|
||||||
# include <boost/python/detail/unwind_type.hpp>
|
# include <boost/python/detail/unwind_type.hpp>
|
||||||
# include <boost/python/detail/type_traits.hpp>
|
# include <boost/python/detail/type_traits.hpp>
|
||||||
|
# include <boost/python/back_reference.hpp>
|
||||||
|
|
||||||
namespace boost { namespace python {
|
namespace boost { namespace python {
|
||||||
|
|
||||||
@@ -46,6 +46,12 @@ inline python::type_info unwind_type_id_(boost::type<T>* = 0, mpl::false_ * =0)
|
|||||||
return boost::python::detail::unwind_type<unwind_type_id_helper, T> ();
|
return boost::python::detail::unwind_type<unwind_type_id_helper, T> ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
inline python::type_info unwind_type_id_(boost::type<back_reference<T> >* = 0, mpl::false_ * =0)
|
||||||
|
{
|
||||||
|
return boost::python::detail::unwind_type<unwind_type_id_helper, T> ();
|
||||||
|
}
|
||||||
|
|
||||||
inline python::type_info unwind_type_id_(boost::type<void>* = 0, mpl::true_* =0)
|
inline python::type_info unwind_type_id_(boost::type<void>* = 0, mpl::true_* =0)
|
||||||
{
|
{
|
||||||
return type_id<void>();
|
return type_id<void>();
|
||||||
|
|||||||
@@ -61,7 +61,8 @@ namespace detail
|
|||||||
typedef objects::pointer_holder<Ptr,value_type> holder;
|
typedef objects::pointer_holder<Ptr,value_type> holder;
|
||||||
typedef objects::instance<holder> instance_t;
|
typedef objects::instance<holder> instance_t;
|
||||||
|
|
||||||
void* memory = holder::allocate(this->m_self, offsetof(instance_t, storage), sizeof(holder));
|
void* memory = holder::allocate(this->m_self, offsetof(instance_t, storage), sizeof(holder),
|
||||||
|
boost::python::detail::alignment_of<holder>::value);
|
||||||
try {
|
try {
|
||||||
#if defined(BOOST_NO_CXX11_SMART_PTR)
|
#if defined(BOOST_NO_CXX11_SMART_PTR)
|
||||||
(new (memory) holder(x))->install(this->m_self);
|
(new (memory) holder(x))->install(this->m_self);
|
||||||
|
|||||||
@@ -18,6 +18,8 @@ BOOST_PYTHON_DECL void add_to_namespace(
|
|||||||
BOOST_PYTHON_DECL void add_to_namespace(
|
BOOST_PYTHON_DECL void add_to_namespace(
|
||||||
object const& name_space, char const* name, object const& attribute, char const* doc);
|
object const& name_space, char const* name, object const& attribute, char const* doc);
|
||||||
|
|
||||||
|
BOOST_PYTHON_DECL object const& add_doc(object const& attribute, char const* doc);
|
||||||
|
|
||||||
}}} // namespace boost::python::objects
|
}}} // namespace boost::python::objects
|
||||||
|
|
||||||
#endif // ADD_TO_NAMESPACE_DWA200286_HPP
|
#endif // ADD_TO_NAMESPACE_DWA200286_HPP
|
||||||
|
|||||||
@@ -35,6 +35,8 @@ struct BOOST_PYTHON_DECL function : PyObject
|
|||||||
static void add_to_namespace(
|
static void add_to_namespace(
|
||||||
object const& name_space, char const* name, object const& attribute, char const* doc);
|
object const& name_space, char const* name, object const& attribute, char const* doc);
|
||||||
|
|
||||||
|
static object const& add_doc(object const& attribute, char const* doc);
|
||||||
|
|
||||||
object const& doc() const;
|
object const& doc() const;
|
||||||
void doc(object const& x);
|
void doc(object const& x);
|
||||||
|
|
||||||
@@ -42,6 +44,8 @@ struct BOOST_PYTHON_DECL function : PyObject
|
|||||||
|
|
||||||
object const& get_namespace() const { return m_namespace; }
|
object const& get_namespace() const { return m_namespace; }
|
||||||
|
|
||||||
|
object const& get_module() const { return m_module; }
|
||||||
|
|
||||||
private: // helper functions
|
private: // helper functions
|
||||||
object signature(bool show_return_type=false) const;
|
object signature(bool show_return_type=false) const;
|
||||||
object signatures(bool show_return_type=false) const;
|
object signatures(bool show_return_type=false) const;
|
||||||
@@ -53,6 +57,7 @@ struct BOOST_PYTHON_DECL function : PyObject
|
|||||||
handle<function> m_overloads;
|
handle<function> m_overloads;
|
||||||
object m_name;
|
object m_name;
|
||||||
object m_namespace;
|
object m_namespace;
|
||||||
|
object m_module;
|
||||||
object m_doc;
|
object m_doc;
|
||||||
object m_arg_names;
|
object m_arg_names;
|
||||||
unsigned m_nkeyword_values;
|
unsigned m_nkeyword_values;
|
||||||
|
|||||||
@@ -18,13 +18,13 @@
|
|||||||
namespace boost { namespace python { namespace objects {
|
namespace boost { namespace python { namespace objects {
|
||||||
|
|
||||||
class function_doc_signature_generator{
|
class function_doc_signature_generator{
|
||||||
static const char * py_type_str(const python::detail::signature_element &s);
|
static str py_type_str(const python::detail::signature_element &s, const object& current_module_name);
|
||||||
static bool arity_cmp( function const *f1, function const *f2 );
|
static bool arity_cmp( function const *f1, function const *f2 );
|
||||||
static bool are_seq_overloads( function const *f1, function const *f2 , bool check_docs);
|
static bool are_seq_overloads( function const *f1, function const *f2 , bool check_docs);
|
||||||
static std::vector<function const*> flatten(function const *f);
|
static std::vector<function const*> flatten(function const *f);
|
||||||
static std::vector<function const*> split_seq_overloads( const std::vector<function const *> &funcs, bool split_on_doc_change);
|
static std::vector<function const*> split_seq_overloads( const std::vector<function const *> &funcs, bool split_on_doc_change);
|
||||||
static str raw_function_pretty_signature(function const *f, size_t n_overloads, bool cpp_types = false);
|
static str raw_function_pretty_signature(function const *f, size_t n_overloads, bool cpp_types = false);
|
||||||
static str parameter_string(py_function const &f, size_t n, object arg_names, bool cpp_types);
|
static str parameter_string(py_function const &f, size_t n, object arg_names, const object& module_name, bool cpp_types);
|
||||||
static str pretty_signature(function const *f, size_t n_overloads, bool cpp_types = false);
|
static str pretty_signature(function const *f, size_t n_overloads, bool cpp_types = false);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -96,6 +96,7 @@ namespace detail
|
|||||||
, make_function(
|
, make_function(
|
||||||
detail::nullary_function_adaptor<void(*)()>(pure_virtual_called)
|
detail::nullary_function_adaptor<void(*)()>(pure_virtual_called)
|
||||||
, default_call_policies()
|
, default_call_policies()
|
||||||
|
, options.keywords()
|
||||||
, detail::error_signature<held_type>(detail::get_signature(m_pmf))
|
, detail::error_signature<held_type>(detail::get_signature(m_pmf))
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -107,32 +107,7 @@ int dtype::get_itemsize() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool equivalent(dtype const & a, dtype const & b) {
|
bool equivalent(dtype const & a, dtype const & b) {
|
||||||
// On Windows x64, the behaviour described on
|
return a == b;
|
||||||
// http://docs.scipy.org/doc/numpy/reference/c-api.array.html for
|
|
||||||
// PyArray_EquivTypes unfortunately does not extend as expected:
|
|
||||||
// "For example, on 32-bit platforms, NPY_LONG and NPY_INT are equivalent".
|
|
||||||
// This should also hold for 64-bit platforms (and does on Linux), but not
|
|
||||||
// on Windows. Implement an alternative:
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
if (sizeof(long) == sizeof(int) &&
|
|
||||||
// Manually take care of the type equivalence.
|
|
||||||
((a == dtype::get_builtin<long>() || a == dtype::get_builtin<int>()) &&
|
|
||||||
(b == dtype::get_builtin<long>() || b == dtype::get_builtin<int>()) ||
|
|
||||||
(a == dtype::get_builtin<unsigned int>() || a == dtype::get_builtin<unsigned long>()) &&
|
|
||||||
(b == dtype::get_builtin<unsigned int>() || b == dtype::get_builtin<unsigned long>()))) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return PyArray_EquivTypes(
|
|
||||||
reinterpret_cast<PyArray_Descr*>(a.ptr()),
|
|
||||||
reinterpret_cast<PyArray_Descr*>(b.ptr())
|
|
||||||
);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
return PyArray_EquivTypes(
|
|
||||||
reinterpret_cast<PyArray_Descr*>(a.ptr()),
|
|
||||||
reinterpret_cast<PyArray_Descr*>(b.ptr())
|
|
||||||
);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
|
|||||||
@@ -333,8 +333,9 @@ namespace objects
|
|||||||
for (instance_holder* p = kill_me->objects, *next; p != 0; p = next)
|
for (instance_holder* p = kill_me->objects, *next; p != 0; p = next)
|
||||||
{
|
{
|
||||||
next = p->next();
|
next = p->next();
|
||||||
|
void* q = dynamic_cast<void*>(p);
|
||||||
p->~instance_holder();
|
p->~instance_holder();
|
||||||
instance_holder::deallocate(inst, dynamic_cast<void*>(p));
|
instance_holder::deallocate(inst, q);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Python 2.2.1 won't add weak references automatically when
|
// Python 2.2.1 won't add weak references automatically when
|
||||||
@@ -502,6 +503,16 @@ namespace objects
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
object qualname(const char *name)
|
||||||
|
{
|
||||||
|
#if PY_VERSION_HEX >= 0x03030000
|
||||||
|
if (PyObject_HasAttrString(scope().ptr(), "__qualname__")) {
|
||||||
|
return str("%s.%s" % make_tuple(scope().attr("__qualname__"), name));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return str(name);
|
||||||
|
}
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
// Find a registered class object corresponding to id. Return a
|
// Find a registered class object corresponding to id. Return a
|
||||||
@@ -564,6 +575,9 @@ namespace objects
|
|||||||
|
|
||||||
object m = module_prefix();
|
object m = module_prefix();
|
||||||
if (m) d["__module__"] = m;
|
if (m) d["__module__"] = m;
|
||||||
|
#if PY_VERSION_HEX >= 0x03030000
|
||||||
|
d["__qualname__"] = qualname(name);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (doc != 0)
|
if (doc != 0)
|
||||||
d["__doc__"] = doc;
|
d["__doc__"] = doc;
|
||||||
@@ -753,10 +767,9 @@ void* instance_holder::allocate(PyObject* self_, std::size_t holder_offset, std:
|
|||||||
throw std::bad_alloc();
|
throw std::bad_alloc();
|
||||||
|
|
||||||
const uintptr_t x = reinterpret_cast<uintptr_t>(base_storage) + sizeof(alignment_marker_t);
|
const uintptr_t x = reinterpret_cast<uintptr_t>(base_storage) + sizeof(alignment_marker_t);
|
||||||
//this has problems for x -> max(void *)
|
// Padding required to align the start of a data structure is: (alignment - (x % alignment)) % alignment
|
||||||
//const size_t padding = alignment - ((x + sizeof(alignment_marker_t)) % alignment);
|
// Since the alignment is a power of two, the formula can be simplified with bitwise AND operator as follow:
|
||||||
//only works for alignments with alignments of powers of 2, but no edge conditions
|
const uintptr_t padding = (alignment - (x & (alignment - 1))) & (alignment - 1);
|
||||||
const uintptr_t padding = alignment == 1 ? 0 : ( alignment - (x & (alignment - 1)) );
|
|
||||||
const size_t aligned_offset = sizeof(alignment_marker_t) + padding;
|
const size_t aligned_offset = sizeof(alignment_marker_t) + padding;
|
||||||
void* const aligned_storage = (char *)base_storage + aligned_offset;
|
void* const aligned_storage = (char *)base_storage + aligned_offset;
|
||||||
BOOST_ASSERT((char *) aligned_storage + holder_size <= (char *)base_storage + base_allocation);
|
BOOST_ASSERT((char *) aligned_storage + holder_size <= (char *)base_storage + base_allocation);
|
||||||
|
|||||||
@@ -49,7 +49,9 @@ extern "C"
|
|||||||
if (!self->name)
|
if (!self->name)
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
#if PY_VERSION_HEX >= 0x03000000
|
#if PY_VERSION_HEX >= 0x03030000
|
||||||
|
PyUnicode_FromFormat("%S.%S(%ld)", mod, ((PyHeapTypeObject*)(self_->ob_type))->ht_qualname, PyLong_AsLong(self_));
|
||||||
|
#elif PY_VERSION_HEX >= 0x03000000
|
||||||
PyUnicode_FromFormat("%S.%s(%ld)", mod, self_->ob_type->tp_name, PyLong_AsLong(self_));
|
PyUnicode_FromFormat("%S.%s(%ld)", mod, self_->ob_type->tp_name, PyLong_AsLong(self_));
|
||||||
#else
|
#else
|
||||||
PyString_FromFormat("%s.%s(%ld)", PyString_AsString(mod), self_->ob_type->tp_name, PyInt_AS_LONG(self_));
|
PyString_FromFormat("%s.%s(%ld)", PyString_AsString(mod), self_->ob_type->tp_name, PyInt_AS_LONG(self_));
|
||||||
@@ -62,7 +64,9 @@ extern "C"
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return
|
return
|
||||||
#if PY_VERSION_HEX >= 0x03000000
|
#if PY_VERSION_HEX >= 0x03030000
|
||||||
|
PyUnicode_FromFormat("%S.%S.%S", mod, ((PyHeapTypeObject*)(self_->ob_type))->ht_qualname, name);
|
||||||
|
#elif PY_VERSION_HEX >= 0x03000000
|
||||||
PyUnicode_FromFormat("%S.%s.%S", mod, self_->ob_type->tp_name, name);
|
PyUnicode_FromFormat("%S.%s.%S", mod, self_->ob_type->tp_name, name);
|
||||||
#else
|
#else
|
||||||
PyString_FromFormat("%s.%s.%s",
|
PyString_FromFormat("%s.%s.%s",
|
||||||
@@ -145,6 +149,7 @@ static PyTypeObject enum_type_object = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
object module_prefix();
|
object module_prefix();
|
||||||
|
object qualname(const char *name);
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
@@ -175,6 +180,11 @@ namespace
|
|||||||
object module_name = module_prefix();
|
object module_name = module_prefix();
|
||||||
if (module_name)
|
if (module_name)
|
||||||
d["__module__"] = module_name;
|
d["__module__"] = module_name;
|
||||||
|
#if PY_VERSION_HEX >= 0x03030000
|
||||||
|
object q = qualname(name);
|
||||||
|
if (q)
|
||||||
|
d["__qualname__"] = q;
|
||||||
|
#endif
|
||||||
if (doc)
|
if (doc)
|
||||||
d["__doc__"] = doc;
|
d["__doc__"] = doc;
|
||||||
|
|
||||||
|
|||||||
@@ -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)));
|
||||||
|
|
||||||
@@ -419,6 +418,30 @@ namespace detail
|
|||||||
extern char cpp_signature_tag[];
|
extern char cpp_signature_tag[];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
object const& function::add_doc(object const& attribute, char const* doc)
|
||||||
|
{
|
||||||
|
str _doc;
|
||||||
|
|
||||||
|
if (docstring_options::show_py_signatures_)
|
||||||
|
{
|
||||||
|
_doc += str(const_cast<const char*>(detail::py_signature_tag));
|
||||||
|
}
|
||||||
|
if (doc != 0 && docstring_options::show_user_defined_)
|
||||||
|
_doc += doc;
|
||||||
|
|
||||||
|
if (docstring_options::show_cpp_signatures_)
|
||||||
|
{
|
||||||
|
_doc += str(const_cast<const char*>(detail::cpp_signature_tag));
|
||||||
|
}
|
||||||
|
if(_doc)
|
||||||
|
{
|
||||||
|
object mutable_attribute(attribute);
|
||||||
|
mutable_attribute.attr("__doc__")= _doc;
|
||||||
|
}
|
||||||
|
|
||||||
|
return attribute;
|
||||||
|
}
|
||||||
|
|
||||||
void function::add_to_namespace(
|
void function::add_to_namespace(
|
||||||
object const& name_space, char const* name_, object const& attribute, char const* doc)
|
object const& name_space, char const* name_, object const& attribute, char const* doc)
|
||||||
{
|
{
|
||||||
@@ -489,11 +512,24 @@ void function::add_to_namespace(
|
|||||||
|
|
||||||
assert(!PyErr_Occurred());
|
assert(!PyErr_Occurred());
|
||||||
handle<> name_space_name(
|
handle<> name_space_name(
|
||||||
allow_null(::PyObject_GetAttrString(name_space.ptr(), const_cast<char*>("__name__"))));
|
allow_null(::PyObject_GetAttrString(name_space.ptr(), const_cast<char*>(
|
||||||
|
#if PY_VERSION_HEX < 0x03030000
|
||||||
|
"__name__"
|
||||||
|
#else
|
||||||
|
"__qualname__"
|
||||||
|
#endif
|
||||||
|
))));
|
||||||
PyErr_Clear();
|
PyErr_Clear();
|
||||||
|
|
||||||
if (name_space_name)
|
if (name_space_name)
|
||||||
new_func->m_namespace = object(name_space_name);
|
new_func->m_namespace = object(name_space_name);
|
||||||
|
|
||||||
|
object module_name(
|
||||||
|
PyObject_IsInstance(name_space.ptr(), upcast<PyObject>(&PyModule_Type))
|
||||||
|
? object(name_space.attr("__name__"))
|
||||||
|
: api::getattr(name_space, "__module__", str())
|
||||||
|
);
|
||||||
|
new_func->m_module = module_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (PyObject_SetAttr(ns, name.ptr(), attribute.ptr()) < 0)
|
if (PyObject_SetAttr(ns, name.ptr(), attribute.ptr()) < 0)
|
||||||
@@ -532,24 +568,7 @@ void function::add_to_namespace(
|
|||||||
"C++ signature:", f->signature(true)));
|
"C++ signature:", f->signature(true)));
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
str _doc;
|
add_doc(attribute, doc);
|
||||||
|
|
||||||
if (docstring_options::show_py_signatures_)
|
|
||||||
{
|
|
||||||
_doc += str(const_cast<const char*>(detail::py_signature_tag));
|
|
||||||
}
|
|
||||||
if (doc != 0 && docstring_options::show_user_defined_)
|
|
||||||
_doc += doc;
|
|
||||||
|
|
||||||
if (docstring_options::show_cpp_signatures_)
|
|
||||||
{
|
|
||||||
_doc += str(const_cast<const char*>(detail::cpp_signature_tag));
|
|
||||||
}
|
|
||||||
if(_doc)
|
|
||||||
{
|
|
||||||
object mutable_attribute(attribute);
|
|
||||||
mutable_attribute.attr("__doc__")= _doc;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_PYTHON_DECL void add_to_namespace(
|
BOOST_PYTHON_DECL void add_to_namespace(
|
||||||
@@ -564,6 +583,18 @@ BOOST_PYTHON_DECL void add_to_namespace(
|
|||||||
function::add_to_namespace(name_space, name, attribute, doc);
|
function::add_to_namespace(name_space, name, attribute, doc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_PYTHON_DECL object const& add_doc(object const& attribute, char const* doc)
|
||||||
|
{
|
||||||
|
#if PY_VERSION_HEX >= 0x03000000
|
||||||
|
if (PyInstanceMethod_Check(attribute.ptr())) {
|
||||||
|
#else
|
||||||
|
if (PyMethod_Check(attribute.ptr())) {
|
||||||
|
#endif
|
||||||
|
return attribute;
|
||||||
|
}
|
||||||
|
return function::add_doc(attribute, doc);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
@@ -670,7 +701,7 @@ extern "C"
|
|||||||
static PyObject* function_get_module(PyObject* op, void*)
|
static PyObject* function_get_module(PyObject* op, void*)
|
||||||
{
|
{
|
||||||
function* f = downcast<function>(op);
|
function* f = downcast<function>(op);
|
||||||
object const& ns = f->get_namespace();
|
object const& ns = f->get_module();
|
||||||
if (!ns.is_none()) {
|
if (!ns.is_none()) {
|
||||||
return python::incref(ns.ptr());
|
return python::incref(ns.ptr());
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -114,23 +114,47 @@ namespace boost { namespace python { namespace objects {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char * function_doc_signature_generator::py_type_str(const python::detail::signature_element &s)
|
static str get_qualname(const PyTypeObject *py_type)
|
||||||
|
{
|
||||||
|
# if PY_VERSION_HEX >= 0x03030000
|
||||||
|
if ( py_type->tp_flags & Py_TPFLAGS_HEAPTYPE )
|
||||||
|
return str(handle<>(borrowed(((PyHeapTypeObject*)(py_type))->ht_qualname)));
|
||||||
|
# endif
|
||||||
|
return str(py_type->tp_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
str function_doc_signature_generator::py_type_str(const python::detail::signature_element &s, const object ¤t_module_name)
|
||||||
{
|
{
|
||||||
if (s.basename==std::string("void")){
|
if (s.basename==std::string("void")){
|
||||||
static const char * none = "None";
|
static const char * none = "None";
|
||||||
return none;
|
return str(none);
|
||||||
}
|
}
|
||||||
|
|
||||||
PyTypeObject const * py_type = s.pytype_f?s.pytype_f():0;
|
PyTypeObject const * py_type = s.pytype_f?s.pytype_f():0;
|
||||||
if ( py_type )
|
if ( py_type ) {
|
||||||
return py_type->tp_name;
|
str name(get_qualname(py_type));
|
||||||
else{
|
if ( py_type->tp_flags & Py_TPFLAGS_HEAPTYPE ) {
|
||||||
|
// Qualify the type name if it is defined in a different module.
|
||||||
|
PyObject *type_module_name = PyDict_GetItemString(py_type->tp_dict, "__module__");
|
||||||
|
if (
|
||||||
|
type_module_name
|
||||||
|
&& PyObject_RichCompareBool(
|
||||||
|
type_module_name,
|
||||||
|
current_module_name.ptr(),
|
||||||
|
Py_NE
|
||||||
|
) != 0
|
||||||
|
) {
|
||||||
|
return str("%s.%s" % make_tuple(handle<>(borrowed(type_module_name)), name));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return name;
|
||||||
|
} else {
|
||||||
static const char * object = "object";
|
static const char * object = "object";
|
||||||
return object;
|
return str(object);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
str function_doc_signature_generator::parameter_string(py_function const &f, size_t n, object arg_names, bool cpp_types)
|
str function_doc_signature_generator::parameter_string(py_function const &f, size_t n, object arg_names, const object& current_module_name, bool cpp_types)
|
||||||
{
|
{
|
||||||
str param;
|
str param;
|
||||||
|
|
||||||
@@ -156,12 +180,12 @@ namespace boost { namespace python { namespace objects {
|
|||||||
{
|
{
|
||||||
object kv;
|
object kv;
|
||||||
if ( arg_names && (kv = arg_names[n-1]) )
|
if ( arg_names && (kv = arg_names[n-1]) )
|
||||||
param = str( " (%s)%s" % make_tuple(py_type_str(s[n]),kv[0]) );
|
param = str( " (%s)%s" % make_tuple(py_type_str(s[n], current_module_name),kv[0]) );
|
||||||
else
|
else
|
||||||
param = str(" (%s)%s%d" % make_tuple(py_type_str(s[n]),"arg", n) );
|
param = str(" (%s)%s%d" % make_tuple(py_type_str(s[n], current_module_name),"arg", n) );
|
||||||
}
|
}
|
||||||
else //we are processing the return type
|
else //we are processing the return type
|
||||||
param = py_type_str(f.get_return_type());
|
param = py_type_str(f.get_return_type(), current_module_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
//an argument - check for default value and append it
|
//an argument - check for default value and append it
|
||||||
@@ -199,7 +223,7 @@ namespace boost { namespace python { namespace objects {
|
|||||||
str param;
|
str param;
|
||||||
|
|
||||||
formal_params.append(
|
formal_params.append(
|
||||||
parameter_string(impl, n, f->m_arg_names, cpp_types)
|
parameter_string(impl, n, f->m_arg_names, f->get_module(), cpp_types)
|
||||||
);
|
);
|
||||||
|
|
||||||
// find all the arguments with default values preceeding the arity-n_overloads
|
// find all the arguments with default values preceeding the arity-n_overloads
|
||||||
|
|||||||
@@ -34,4 +34,14 @@ slice_base::step() const
|
|||||||
((PySliceObject*)this->ptr())->step));
|
((PySliceObject*)this->ptr())->step));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static struct register_slice_pytype_ptr
|
||||||
|
{
|
||||||
|
register_slice_pytype_ptr()
|
||||||
|
{
|
||||||
|
const_cast<converter::registration &>(
|
||||||
|
converter::registry::lookup(boost::python::type_id<boost::python::slice>())
|
||||||
|
).m_class_object = &PySlice_Type;
|
||||||
|
}
|
||||||
|
}register_slice_pytype_ptr_;
|
||||||
|
|
||||||
} } } // !namespace boost::python::detail
|
} } } // !namespace boost::python::detail
|
||||||
|
|||||||
53
test/Jamfile
53
test/Jamfile
@@ -2,14 +2,16 @@
|
|||||||
# 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)
|
||||||
|
|
||||||
|
require-b2 5.0.1 ;
|
||||||
|
import-search /boost/config/checks ;
|
||||||
|
|
||||||
import python ;
|
import python ;
|
||||||
import os ;
|
import os ;
|
||||||
import ../../config/checks/config : requires ;
|
import config : requires ;
|
||||||
|
|
||||||
lib socket ;
|
lib socket ;
|
||||||
|
|
||||||
use-project /boost/python : ../build ;
|
project
|
||||||
project /boost/python/test
|
|
||||||
: requirements
|
: requirements
|
||||||
<toolset>gcc:<cxxflags>-Wextra
|
<toolset>gcc:<cxxflags>-Wextra
|
||||||
<target-os>qnxnto:<library>socket
|
<target-os>qnxnto:<library>socket
|
||||||
@@ -28,7 +30,7 @@ rule py-run ( sources * : input-file ? )
|
|||||||
: $(input-file)
|
: $(input-file)
|
||||||
: #requirements
|
: #requirements
|
||||||
<define>BOOST_PYTHON_SUPPRESS_REGISTRY_INITIALIZATION
|
<define>BOOST_PYTHON_SUPPRESS_REGISTRY_INITIALIZATION
|
||||||
|
|
||||||
] ;
|
] ;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -52,6 +54,18 @@ rule require-windows ( properties * )
|
|||||||
|
|
||||||
if [ python.configured ]
|
if [ python.configured ]
|
||||||
{
|
{
|
||||||
|
alias base_deps : usage-requirements
|
||||||
|
<library>/boost/align//boost_align
|
||||||
|
<library>/boost/assert//boost_assert
|
||||||
|
<library>/boost/config//boost_config
|
||||||
|
<library>/boost/core//boost_core
|
||||||
|
<library>/boost/detail//boost_detail
|
||||||
|
<library>/boost/function//boost_function
|
||||||
|
<library>/boost/mpl//boost_mpl
|
||||||
|
<library>/boost/preprocessor//boost_preprocessor
|
||||||
|
<library>/boost/static_assert//boost_static_assert
|
||||||
|
<library>/boost/type_traits//boost_type_traits
|
||||||
|
;
|
||||||
test-suite python
|
test-suite python
|
||||||
:
|
:
|
||||||
|
|
||||||
@@ -97,8 +111,8 @@ bpl-test crossmod_exception
|
|||||||
[ bpl-test andreas_beyer ]
|
[ bpl-test andreas_beyer ]
|
||||||
[ bpl-test wrapper_held_type ]
|
[ bpl-test wrapper_held_type ]
|
||||||
|
|
||||||
[ bpl-test polymorphism2_auto_ptr
|
[ bpl-test polymorphism2_auto_ptr
|
||||||
: polymorphism2_auto_ptr.py polymorphism2.py polymorphism2_auto_ptr.cpp
|
: polymorphism2_auto_ptr.py polymorphism2.py polymorphism2_auto_ptr.cpp
|
||||||
: [ requires auto_ptr ]
|
: [ requires auto_ptr ]
|
||||||
]
|
]
|
||||||
|
|
||||||
@@ -119,7 +133,7 @@ bpl-test crossmod_exception
|
|||||||
[ bpl-test try : newtest.py m1.cpp m2.cpp ]
|
[ bpl-test try : newtest.py m1.cpp m2.cpp ]
|
||||||
[ bpl-test const_argument ]
|
[ bpl-test const_argument ]
|
||||||
[ bpl-test keywords : keywords.cpp keywords_test.py ]
|
[ bpl-test keywords : keywords.cpp keywords_test.py ]
|
||||||
|
|
||||||
|
|
||||||
[ python-extension builtin_converters_ext : builtin_converters.cpp /boost/python//boost_python ]
|
[ python-extension builtin_converters_ext : builtin_converters.cpp /boost/python//boost_python ]
|
||||||
[ bpl-test builtin_converters : test_builtin_converters.py builtin_converters_ext ]
|
[ bpl-test builtin_converters : test_builtin_converters.py builtin_converters_ext ]
|
||||||
@@ -192,13 +206,13 @@ bpl-test crossmod_opaque
|
|||||||
# Whenever the cause for the failure of the polymorphism test is found
|
# Whenever the cause for the failure of the polymorphism test is found
|
||||||
# and fixed, this should be retested.
|
# and fixed, this should be retested.
|
||||||
<toolset>hp_cxx:<build>no ]
|
<toolset>hp_cxx:<build>no ]
|
||||||
|
|
||||||
[ python-extension map_indexing_suite_ext
|
[ python-extension map_indexing_suite_ext
|
||||||
: map_indexing_suite.cpp int_map_indexing_suite.cpp a_map_indexing_suite.cpp
|
: map_indexing_suite.cpp int_map_indexing_suite.cpp a_map_indexing_suite.cpp
|
||||||
/boost/python//boost_python ]
|
/boost/python//boost_python ]
|
||||||
[ bpl-test
|
[ bpl-test
|
||||||
map_indexing_suite : map_indexing_suite.py map_indexing_suite_ext ]
|
map_indexing_suite : map_indexing_suite.py map_indexing_suite_ext ]
|
||||||
|
|
||||||
[ run import_.cpp /boost/python//boost_python $(PY) : : import_.py ]
|
[ run import_.cpp /boost/python//boost_python $(PY) : : import_.py ]
|
||||||
|
|
||||||
# if $(TEST_BIENSTMAN_NON_BUGS)
|
# if $(TEST_BIENSTMAN_NON_BUGS)
|
||||||
@@ -212,28 +226,29 @@ bpl-test crossmod_opaque
|
|||||||
|
|
||||||
# --- unit tests of library components ---
|
# --- unit tests of library components ---
|
||||||
|
|
||||||
[ compile indirect_traits_test.cpp ]
|
[ compile indirect_traits_test.cpp : <use>base_deps ]
|
||||||
[ run destroy_test.cpp ]
|
[ run destroy_test.cpp : : : <use>base_deps ]
|
||||||
[ py-run pointer_type_id_test.cpp ]
|
[ py-run pointer_type_id_test.cpp ]
|
||||||
[ py-run bases.cpp ]
|
[ py-run bases.cpp ]
|
||||||
[ run if_else.cpp ]
|
[ run if_else.cpp : : : <use>base_deps ]
|
||||||
[ py-run pointee.cpp ]
|
[ py-run pointee.cpp ]
|
||||||
[ run result.cpp ]
|
[ run result.cpp : : : <use>base_deps ]
|
||||||
|
|
||||||
[ compile string_literal.cpp ]
|
[ compile string_literal.cpp : <use>base_deps ]
|
||||||
[ py-compile borrowed.cpp ]
|
[ py-compile borrowed.cpp ]
|
||||||
[ py-compile object_manager.cpp ]
|
[ py-compile object_manager.cpp ]
|
||||||
[ py-compile copy_ctor_mutates_rhs.cpp ]
|
[ py-compile copy_ctor_mutates_rhs.cpp ]
|
||||||
|
|
||||||
[ py-run upcast.cpp ]
|
[ py-run upcast.cpp ]
|
||||||
|
|
||||||
[ py-compile select_holder.cpp ]
|
[ py-compile select_holder.cpp ]
|
||||||
|
|
||||||
[ run select_from_python_test.cpp ../src/converter/type_id.cpp
|
[ run select_from_python_test.cpp ../src/converter/type_id.cpp
|
||||||
:
|
:
|
||||||
:
|
:
|
||||||
: <define>BOOST_PYTHON_STATIC_LIB
|
: <define>BOOST_PYTHON_STATIC_LIB
|
||||||
<use>$(PY)
|
<use>$(PY)
|
||||||
|
<use>base_deps
|
||||||
|
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|||||||
@@ -214,6 +214,13 @@ joel kimpo
|
|||||||
... i.data()
|
... i.data()
|
||||||
4
|
4
|
||||||
|
|
||||||
|
#####################################################################
|
||||||
|
# Test signature...
|
||||||
|
#####################################################################
|
||||||
|
|
||||||
|
>>> AMap.__iter__.__doc__.strip().split("\\n")[0]
|
||||||
|
'__iter__( (AMap)arg1) -> __main__.iterator :'
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# END....
|
# END....
|
||||||
#####################################################################
|
#####################################################################
|
||||||
|
|||||||
@@ -4,6 +4,8 @@
|
|||||||
// http://www.boost.org/LICENSE_1_0.txt)
|
// http://www.boost.org/LICENSE_1_0.txt)
|
||||||
#include <boost/python/module.hpp>
|
#include <boost/python/module.hpp>
|
||||||
#include <boost/python/class.hpp>
|
#include <boost/python/class.hpp>
|
||||||
|
#include <boost/python/def.hpp>
|
||||||
|
#include <boost/python/enum.hpp>
|
||||||
#include <boost/python/operators.hpp>
|
#include <boost/python/operators.hpp>
|
||||||
#include <boost/python/scope.hpp>
|
#include <boost/python/scope.hpp>
|
||||||
#include "test_class.hpp"
|
#include "test_class.hpp"
|
||||||
@@ -16,6 +18,8 @@
|
|||||||
typedef test_class<> X;
|
typedef test_class<> X;
|
||||||
typedef test_class<1> Y;
|
typedef test_class<1> Y;
|
||||||
|
|
||||||
|
enum color { red = 0, blue = 1, green = 2 };
|
||||||
|
|
||||||
std::ostream& operator<<(std::ostream& s, X const& x)
|
std::ostream& operator<<(std::ostream& s, X const& x)
|
||||||
{
|
{
|
||||||
return s << x.value();
|
return s << x.value();
|
||||||
@@ -26,11 +30,13 @@ std::ostream& operator<<(std::ostream& s, Y const& x)
|
|||||||
return s << x.value();
|
return s << x.value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void test_function(const X& x, const Y& y) {}
|
||||||
|
|
||||||
BOOST_PYTHON_MODULE(nested_ext)
|
BOOST_PYTHON_MODULE(nested_ext)
|
||||||
{
|
{
|
||||||
using namespace boost::python;
|
using namespace boost::python;
|
||||||
|
|
||||||
|
{
|
||||||
// Establish X as the current scope.
|
// Establish X as the current scope.
|
||||||
scope x_class
|
scope x_class
|
||||||
= class_<X>("X", init<int>())
|
= class_<X>("X", init<int>())
|
||||||
@@ -42,6 +48,17 @@ BOOST_PYTHON_MODULE(nested_ext)
|
|||||||
class_<Y>("Y", init<int>())
|
class_<Y>("Y", init<int>())
|
||||||
.def(str(self))
|
.def(str(self))
|
||||||
;
|
;
|
||||||
|
|
||||||
|
// so will the enum `color`
|
||||||
|
enum_<color>("color")
|
||||||
|
.value("red", red)
|
||||||
|
.value("green", green)
|
||||||
|
.value("blue", blue)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The generated docstring will use the fully-qualified name of Y
|
||||||
|
def("test_function", &test_function);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -13,14 +13,35 @@
|
|||||||
>>> X.__name__
|
>>> X.__name__
|
||||||
'X'
|
'X'
|
||||||
|
|
||||||
>>> X.Y
|
>>> X.Y # doctest: +py2
|
||||||
<class 'nested_ext.Y'>
|
<class 'nested_ext.Y'>
|
||||||
|
|
||||||
|
>>> X.Y # doctest: +py3
|
||||||
|
<class 'nested_ext.X.Y'>
|
||||||
|
|
||||||
>>> X.Y.__module__
|
>>> X.Y.__module__
|
||||||
'nested_ext'
|
'nested_ext'
|
||||||
|
|
||||||
>>> X.Y.__name__
|
>>> X.Y.__name__
|
||||||
'Y'
|
'Y'
|
||||||
|
|
||||||
|
>>> getattr(X.color, "__qualname__", None) # doctest: +py3
|
||||||
|
'X.color'
|
||||||
|
|
||||||
|
>>> repr(X.color.red) # doctest: +py2
|
||||||
|
'nested_ext.color.red'
|
||||||
|
|
||||||
|
>>> repr(X.color.red) # doctest: +py3
|
||||||
|
'nested_ext.X.color.red'
|
||||||
|
|
||||||
|
>>> repr(X.color(1)) # doctest: +py2
|
||||||
|
'nested_ext.color(1)'
|
||||||
|
|
||||||
|
>>> repr(X.color(1)) # doctest: +py3
|
||||||
|
'nested_ext.X.color(1)'
|
||||||
|
|
||||||
|
>>> test_function.__doc__.strip().split('\\n')[0] # doctest: +py3
|
||||||
|
'test_function( (X)arg1, (X.Y)arg2) -> None :'
|
||||||
|
|
||||||
'''
|
'''
|
||||||
|
|
||||||
@@ -30,7 +51,23 @@ 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__))
|
|
||||||
|
py2 = doctest.register_optionflag("py2")
|
||||||
|
py3 = doctest.register_optionflag("py3")
|
||||||
|
|
||||||
|
class ConditionalChecker(doctest.OutputChecker):
|
||||||
|
def check_output(self, want, got, optionflags):
|
||||||
|
if (optionflags & py3) and (sys.version_info[0] < 3):
|
||||||
|
return True
|
||||||
|
if (optionflags & py2) and (sys.version_info[0] >= 3):
|
||||||
|
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...")
|
||||||
|
|||||||
@@ -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...")
|
||||||
|
|||||||
@@ -64,6 +64,7 @@ BOOST_PYTHON_MODULE(properties_ext)
|
|||||||
class_<X>("X", init<int>() )
|
class_<X>("X", init<int>() )
|
||||||
//defining read only property
|
//defining read only property
|
||||||
.add_property( "value_r", &X::get_value )
|
.add_property( "value_r", &X::get_value )
|
||||||
|
.add_property( "value_r_f", make_function(&X::get_value) )
|
||||||
.add_property( "value_r_ds", &X::get_value, "value_r_ds is read-only")
|
.add_property( "value_r_ds", &X::get_value, "value_r_ds is read-only")
|
||||||
//defining read \ write property
|
//defining read \ write property
|
||||||
.add_property( "value_rw", &X::get_value, &X::set_value )
|
.add_property( "value_rw", &X::get_value, &X::set_value )
|
||||||
|
|||||||
@@ -20,6 +20,9 @@ value read only
|
|||||||
>>> x1.value_r
|
>>> x1.value_r
|
||||||
1
|
1
|
||||||
|
|
||||||
|
>>> x1.value_r_f
|
||||||
|
1
|
||||||
|
|
||||||
value read - write
|
value read - write
|
||||||
>>> x1.value_rw
|
>>> x1.value_rw
|
||||||
1
|
1
|
||||||
@@ -53,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
|
||||||
@@ -84,8 +86,27 @@ after creating second intstance of X instances count is 2
|
|||||||
|
|
||||||
>>> assert properties.X.value_rw_ds.__doc__ == "value_rw_ds is read-write"
|
>>> assert properties.X.value_rw_ds.__doc__ == "value_rw_ds is read-write"
|
||||||
|
|
||||||
|
>>> properties.X.value_r_f.fget.__doc__.strip().split("\\n")[0]
|
||||||
|
'None( (properties_ext.X)arg1) -> int :'
|
||||||
|
|
||||||
|
>>> properties.X.value_rw_ds.fget.__doc__.strip().split("\\n")[0]
|
||||||
|
'None( (properties_ext.X)arg1) -> int :'
|
||||||
|
|
||||||
|
>>> properties.X.value_rw_ds.fset.__doc__.strip().split("\\n")[0]
|
||||||
|
'None( (properties_ext.X)arg1, (int)arg2) -> None :'
|
||||||
|
|
||||||
|
>>> properties.X.value_rw_ds.fget.__doc__.strip().split("\\n")[0]
|
||||||
|
'None( (properties_ext.X)arg1) -> int :'
|
||||||
|
|
||||||
|
>>> properties.X.value_direct.fset.__doc__.strip().split("\\n")[0]
|
||||||
|
'None( (properties_ext.X)arg1, (int)arg2) -> None :'
|
||||||
|
|
||||||
|
>>> properties.X.value_direct.fget.__doc__.strip().split("\\n")[0]
|
||||||
|
'None( (properties_ext.X)arg1) -> int :'
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
# FIXME: cases to cover: pointer-to-member, preconstructed function
|
||||||
|
|
||||||
#import sys; sys.path.append(r'P:\Actimize4.0\smart_const\py_smart_const___Win32_Debug')
|
#import sys; sys.path.append(r'P:\Actimize4.0\smart_const\py_smart_const___Win32_Debug')
|
||||||
import properties_ext as properties
|
import properties_ext as properties
|
||||||
|
|
||||||
|
|||||||
@@ -33,6 +33,8 @@ test passed
|
|||||||
0
|
0
|
||||||
>>> check_slice_get_indices( slice( -2, -5, -2))
|
>>> check_slice_get_indices( slice( -2, -5, -2))
|
||||||
6
|
6
|
||||||
|
>>> check_slice_get_indices.__doc__.strip().split('\\n')[0]
|
||||||
|
'check_slice_get_indices( (slice)arg1) -> int :'
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# Performs an affirmative and negative argument resolution check.
|
# Performs an affirmative and negative argument resolution check.
|
||||||
|
|||||||
@@ -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