mirror of
https://github.com/boostorg/python.git
synced 2026-01-20 04:42:28 +00:00
Compare commits
10 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b85bc984e2 | ||
|
|
aeb1c4b659 | ||
|
|
11aaebf26f | ||
|
|
c5e545ba28 | ||
|
|
7704f6bbe7 | ||
|
|
2b6f667e98 | ||
|
|
aa458d2ca9 | ||
|
|
16627261f1 | ||
|
|
303299e677 | ||
|
|
cb95b611bb |
10
.github/workflows/test-ubuntu.yml
vendored
10
.github/workflows/test-ubuntu.yml
vendored
@@ -11,16 +11,16 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
python: [python, python3]
|
python: [python, python3]
|
||||||
cxx: [g++, clang++]
|
cxx: [g++, clang++]
|
||||||
std: [c++98, c++11, c++14, c++17]
|
std: [c++11, c++14, c++17]
|
||||||
include:
|
include:
|
||||||
# Add the appropriate docker image for each compiler.
|
# Add the appropriate docker image for each compiler.
|
||||||
# The images from teeks99/boost-python-test already have boost::python
|
# The images from teeks99/boost-python-test already have boost::python
|
||||||
# pre-reqs installed, see:
|
# pre-reqs installed, see:
|
||||||
# https://github.com/teeks99/boost-python-test-docker
|
# https://github.com/teeks99/boost-python-test-docker
|
||||||
- cxx: clang++
|
- cxx: clang++
|
||||||
docker-img: teeks99/boost-python-test:clang-12_1.76.0
|
docker-img: teeks99/boost-python-test:clang-21_1.89.0
|
||||||
- cxx: g++
|
- cxx: g++
|
||||||
docker-img: teeks99/boost-python-test:gcc-10_1.76.0
|
docker-img: teeks99/boost-python-test:gcc-15_1.89.0
|
||||||
|
|
||||||
container:
|
container:
|
||||||
image: ${{ matrix.docker-img }}
|
image: ${{ matrix.docker-img }}
|
||||||
@@ -28,6 +28,10 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v5
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
|
- name: setup prerequisites
|
||||||
|
run: |
|
||||||
|
# Warning: this is not necessarily the same Python version as the one configured above !
|
||||||
|
python3 -m pip install -U faber --break-system-packages
|
||||||
- name: build
|
- name: build
|
||||||
run: |
|
run: |
|
||||||
${{ matrix.python }} --version
|
${{ matrix.python }} --version
|
||||||
|
|||||||
4
.github/workflows/test-windows.yml
vendored
4
.github/workflows/test-windows.yml
vendored
@@ -17,7 +17,7 @@ jobs:
|
|||||||
python-version: ${{ matrix.python-version }}
|
python-version: ${{ matrix.python-version }}
|
||||||
- uses: microsoft/setup-msbuild@v2
|
- uses: microsoft/setup-msbuild@v2
|
||||||
- name: setup boost prerequisites
|
- name: setup boost prerequisites
|
||||||
uses: lukka/run-vcpkg@v11
|
uses: lukka/run-vcpkg@v6
|
||||||
with:
|
with:
|
||||||
vcpkgGitCommitId: '88b1071e39f13b632644d9d953738d345a4ac055'
|
vcpkgGitCommitId: '88b1071e39f13b632644d9d953738d345a4ac055'
|
||||||
vcpkgDirectory: '${{ runner.workspace }}/vcpkg'
|
vcpkgDirectory: '${{ runner.workspace }}/vcpkg'
|
||||||
@@ -42,7 +42,7 @@ 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: |
|
||||||
|
|||||||
@@ -90,7 +90,7 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td valign="top" width="300">
|
<td valign="top" width="300">
|
||||||
<h3><a href="{{ pathto('index') }}"><img
|
<h3><a href="{{ pathto('index') }}"><img
|
||||||
alt="C++ Boost" src="{{ pathto('_static/' + logo, 1) }}" border="0"></a></h3>
|
alt="C++ Boost" src="{{ pathto('_static/bpl.png', 1) }}" border="0"></a></h3>
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td >
|
<td >
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ from faber.config.try_run import try_run
|
|||||||
|
|
||||||
features += include('include')
|
features += include('include')
|
||||||
features += define('BOOST_ALL_NO_LIB') # disable auto-linking
|
features += define('BOOST_ALL_NO_LIB') # disable auto-linking
|
||||||
|
features += define('BOOST_NO_AUTO_PTR')
|
||||||
boost_include = options.get_with('boost-include')
|
boost_include = options.get_with('boost-include')
|
||||||
if boost_include:
|
if boost_include:
|
||||||
features += include(boost_include)
|
features += include(boost_include)
|
||||||
|
|||||||
@@ -8,6 +8,8 @@
|
|||||||
# ifndef BOOST_NO_AUTO_PTR
|
# ifndef BOOST_NO_AUTO_PTR
|
||||||
# include <boost/python/detail/is_xxx.hpp>
|
# include <boost/python/detail/is_xxx.hpp>
|
||||||
# include <memory>
|
# include <memory>
|
||||||
|
# else
|
||||||
|
# include <boost/mpl/bool.hpp>
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
namespace boost { namespace python { namespace detail {
|
namespace boost { namespace python { namespace detail {
|
||||||
|
|||||||
@@ -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)));
|
||||||
|
|
||||||
|
|||||||
@@ -99,7 +99,7 @@ BOOST_PYTHON_MODULE(back_reference_ext)
|
|||||||
.def("set", &Y::set)
|
.def("set", &Y::set)
|
||||||
;
|
;
|
||||||
|
|
||||||
class_<Z,std::auto_ptr<Z> >("Z", init<int>())
|
class_<Z,std::shared_ptr<Z> >("Z", init<int>())
|
||||||
.def("value", &Z::value)
|
.def("value", &Z::value)
|
||||||
.def("set", &Z::set)
|
.def("set", &Z::set)
|
||||||
;
|
;
|
||||||
|
|||||||
@@ -9,14 +9,13 @@
|
|||||||
|
|
||||||
struct foo
|
struct foo
|
||||||
{
|
{
|
||||||
operator std::auto_ptr<int>&() const;
|
operator std::shared_ptr<int>&() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
using namespace boost::python::detail;
|
using namespace boost::python::detail;
|
||||||
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<int>::value);
|
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<int>::value);
|
||||||
BOOST_STATIC_ASSERT(copy_ctor_mutates_rhs<std::auto_ptr<int> >::value);
|
|
||||||
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<std::string>::value);
|
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<std::string>::value);
|
||||||
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<foo>::value);
|
BOOST_STATIC_ASSERT(!copy_ctor_mutates_rhs<foo>::value);
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -118,10 +118,10 @@ for t in [('injected',),
|
|||||||
|
|
||||||
tests.append(extension_test('shared_ptr',
|
tests.append(extension_test('shared_ptr',
|
||||||
condition=set.define.contains('HAS_CXX11')))
|
condition=set.define.contains('HAS_CXX11')))
|
||||||
tests.append(extension_test('polymorphism2_auto_ptr',
|
#tests.append(extension_test('polymorphism2_auto_ptr',
|
||||||
condition=set.define.contains('HAS_CXX11').not_()))
|
# condition=set.define.contains('HAS_CXX11').not_()))
|
||||||
tests.append(extension_test('auto_ptr',
|
#tests.append(extension_test('auto_ptr',
|
||||||
condition=set.define.contains('HAS_CXX11')))
|
# condition=set.define.contains('HAS_CXX11')))
|
||||||
|
|
||||||
import_ = binary('import_', ['import_.cpp', src.bpl], features=features|python_libs)
|
import_ = binary('import_', ['import_.cpp', src.bpl], features=features|python_libs)
|
||||||
if platform.os == 'Windows':
|
if platform.os == 'Windows':
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ typedef test_class<> X;
|
|||||||
|
|
||||||
X* empty() { return new X(1000); }
|
X* empty() { return new X(1000); }
|
||||||
|
|
||||||
std::auto_ptr<X> sum(int a, int b) { return std::auto_ptr<X>(new X(a+b)); }
|
std::shared_ptr<X> sum(int a, int b) { return std::shared_ptr<X>(new X(a+b)); }
|
||||||
|
|
||||||
boost::shared_ptr<X> product(int a, int b, int c)
|
boost::shared_ptr<X> product(int a, int b, int c)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ BOOST_PYTHON_MODULE( operators_wrapper_ext )
|
|||||||
;
|
;
|
||||||
|
|
||||||
scope().attr("v") = vector();
|
scope().attr("v") = vector();
|
||||||
std::auto_ptr<vector> dp(new dvector);
|
std::shared_ptr<vector> dp(new dvector);
|
||||||
register_ptr_to_python< std::auto_ptr<vector> >();
|
register_ptr_to_python< std::shared_ptr<vector> >();
|
||||||
scope().attr("d") = dp;
|
scope().attr("d") = dp;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -62,14 +62,14 @@ int test_main(int, char * [])
|
|||||||
assert_holder<Base,Derived
|
assert_holder<Base,Derived
|
||||||
,value_holder_back_reference<Base,Derived> >();
|
,value_holder_back_reference<Base,Derived> >();
|
||||||
|
|
||||||
assert_holder<Base,std::auto_ptr<Base>
|
assert_holder<Base,std::unique_ptr<Base>
|
||||||
,pointer_holder<std::auto_ptr<Base>,Base> >();
|
,pointer_holder<std::unique_ptr<Base>,Base> >();
|
||||||
|
|
||||||
assert_holder<Base,std::auto_ptr<Derived>
|
assert_holder<Base,std::unique_ptr<Derived>
|
||||||
,pointer_holder_back_reference<std::auto_ptr<Derived>,Base> >();
|
,pointer_holder_back_reference<std::unique_ptr<Derived>,Base> >();
|
||||||
|
|
||||||
assert_holder<BR,std::auto_ptr<BR>
|
assert_holder<BR,std::unique_ptr<BR>
|
||||||
,pointer_holder_back_reference<std::auto_ptr<BR>,BR> > ();
|
,pointer_holder_back_reference<std::unique_ptr<BR>,BR> > ();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ int main()
|
|||||||
{
|
{
|
||||||
PyTypeObject o;
|
PyTypeObject o;
|
||||||
Y y;
|
Y y;
|
||||||
BOOST_TEST(&Py_REFCNT(boost::python::upcast<PyObject>(&o)) == &Py_REFCNT(&o));
|
BOOST_TEST(boost::python::upcast<PyObject>(&o) == reinterpret_cast<PyObject*>(&o));
|
||||||
BOOST_TEST(&Py_REFCNT(boost::python::upcast<PyObject>(&y)) == &Py_REFCNT(&y));
|
BOOST_TEST(boost::python::upcast<PyObject>(&y) == &y);
|
||||||
return boost::report_errors();
|
return boost::report_errors();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,12 +20,12 @@ struct data
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
std::auto_ptr<data> create_data()
|
std::shared_ptr<data> create_data()
|
||||||
{
|
{
|
||||||
return std::auto_ptr<data>( new data );
|
return std::shared_ptr<data>( new data );
|
||||||
}
|
}
|
||||||
|
|
||||||
void do_nothing( std::auto_ptr<data>& ){}
|
void do_nothing( std::shared_ptr<data>& ){}
|
||||||
|
|
||||||
|
|
||||||
namespace bp = boost::python;
|
namespace bp = boost::python;
|
||||||
@@ -59,7 +59,7 @@ struct data_wrapper : data, bp::wrapper< data >
|
|||||||
|
|
||||||
BOOST_PYTHON_MODULE(wrapper_held_type_ext)
|
BOOST_PYTHON_MODULE(wrapper_held_type_ext)
|
||||||
{
|
{
|
||||||
bp::class_< data_wrapper, std::auto_ptr< data > >( "data" )
|
bp::class_< data_wrapper, std::shared_ptr< data > >( "data" )
|
||||||
.def( "id", &data::id, &::data_wrapper::default_id );
|
.def( "id", &data::id, &::data_wrapper::default_id );
|
||||||
|
|
||||||
bp::def( "do_nothing", &do_nothing );
|
bp::def( "do_nothing", &do_nothing );
|
||||||
|
|||||||
Reference in New Issue
Block a user