blob: c6ef76b59bd40a1e6443b1aca437fd2d36c8c2c3 [file] [log] [blame]
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +01001.. _changelog:
2
3Changelog
4#########
5
Wenzel Jakobed52f462016-12-26 13:18:26 +01006Starting with version 1.8.0, pybind11 releases use a `semantic versioning
Wenzel Jakobd3549d62016-12-23 16:01:04 +01007<http://semver.org>`_ policy.
Wenzel Jakobf9502152016-06-14 15:00:46 +02008
Wenzel Jakob8cf091a2017-08-31 14:01:08 +02009v2.3.0 (Not yet released)
10-----------------------------------------------------
11
Dean Moldovan56613942017-07-02 12:52:00 +020012* Significantly reduced module binary size (10-20%) when compiled in C++11 mode
13 with GCC/Clang, or in any mode with MSVC. Function signatures are now always
14 precomputed at compile time (this was previously only available in C++14 mode
15 for non-MSVC compilers).
16 `#934 <https://github.com/pybind/pybind11/pull/934>`_.
Wenzel Jakob8cf091a2017-08-31 14:01:08 +020017
Ted Drain0a0758c2017-11-07 08:35:27 -080018* Added support for write only properties.
19 `#1144 <https://github.com/pybind/pybind11/pull/1144>`_.
20
Wenzel Jakob6d190362017-11-16 22:24:36 +010021* The ``value()`` method of ``py::enum_`` now accepts an optional docstring
22 that will be shown in the documentation of the associated enumeration.
23
Wenzel Jakobf5f66182018-04-29 15:47:03 +020024v2.2.3 (April 29, 2018)
25-----------------------------------------------------
26
27* The pybind11 header location detection was replaced by a new implementation
28 that no longer depends on ``pip`` internals (the recently released ``pip``
29 10 has restricted access to this API).
30 `#1190 <https://github.com/pybind/pybind11/pull/1190>`_.
31
32* Small adjustment to an implementation detail to work around a compiler segmentation fault in Clang 3.3/3.4.
33 `#1350 <https://github.com/pybind/pybind11/pull/1350>`_.
34
35* The minimal supported version of the Intel compiler was >= 17.0 since
36 pybind11 v2.1. This check is now explicit, and a compile-time error is raised
37 if the compiler meet the requirement.
38 `#1363 <https://github.com/pybind/pybind11/pull/1363>`_.
39
40* Fixed an endianness-related fault in the test suite.
41 `#1287 <https://github.com/pybind/pybind11/pull/1287>`_.
Lori A. Burnsbdbe8d02018-04-29 07:48:25 -040042
Wenzel Jakob2d0507d2018-02-07 11:05:41 +010043v2.2.2 (February 7, 2018)
44-----------------------------------------------------
45
46* Fixed a segfault when combining embedded interpreter
47 shutdown/reinitialization with external loaded pybind11 modules.
48 `#1092 <https://github.com/pybind/pybind11/pull/1092>`_.
49
50* Eigen support: fixed a bug where Nx1/1xN numpy inputs couldn't be passed as
51 arguments to Eigen vectors (which for Eigen are simply compile-time fixed
52 Nx1/1xN matrices).
53 `#1106 <https://github.com/pybind/pybind11/pull/1106>`_.
54
55* Clarified to license by moving the licensing of contributions from
56 ``LICENSE`` into ``CONTRIBUTING.md``: the licensing of contributions is not
57 actually part of the software license as distributed. This isn't meant to be
58 a substantial change in the licensing of the project, but addresses concerns
59 that the clause made the license non-standard.
60 `#1109 <https://github.com/pybind/pybind11/issues/1109>`_.
61
62* Fixed a regression introduced in 2.1 that broke binding functions with lvalue
63 character literal arguments.
64 `#1128 <https://github.com/pybind/pybind11/pull/1128>`_.
65
66* MSVC: fix for compilation failures under /permissive-, and added the flag to
67 the appveyor test suite.
68 `#1155 <https://github.com/pybind/pybind11/pull/1155>`_.
69
70* Fixed ``__qualname__`` generation, and in turn, fixes how class names
71 (especially nested class names) are shown in generated docstrings.
72 `#1171 <https://github.com/pybind/pybind11/pull/1171>`_.
73
74* Updated the FAQ with a suggested project citation reference.
75 `#1189 <https://github.com/pybind/pybind11/pull/1189>`_.
76
77* Added fixes for deprecation warnings when compiled under C++17 with
78 ``-Wdeprecated`` turned on, and add ``-Wdeprecated`` to the test suite
79 compilation flags.
80 `#1191 <https://github.com/pybind/pybind11/pull/1191>`_.
81
82* Fixed outdated PyPI URLs in ``setup.py``.
83 `#1213 <https://github.com/pybind/pybind11/pull/1213>`_.
84
85* Fixed a refcount leak for arguments that end up in a ``py::args`` argument
86 for functions with both fixed positional and ``py::args`` arguments.
87 `#1216 <https://github.com/pybind/pybind11/pull/1216>`_.
88
89* Fixed a potential segfault resulting from possible premature destruction of
90 ``py::args``/``py::kwargs`` arguments with overloaded functions.
91 `#1223 <https://github.com/pybind/pybind11/pull/1223>`_.
92
93* Fixed ``del map[item]`` for a ``stl_bind.h`` bound stl map.
94 `#1229 <https://github.com/pybind/pybind11/pull/1229>`_.
95
96* Fixed a regression from v2.1.x where the aggregate initialization could
97 unintentionally end up at a constructor taking a templated
98 ``std::initializer_list<T>`` argument.
99 `#1249 <https://github.com/pybind/pybind11/pull/1249>`_.
100
101* Fixed an issue where calling a function with a keep_alive policy on the same
102 nurse/patient pair would cause the internal patient storage to needlessly
103 grow (unboundedly, if the nurse is long-lived).
104 `#1251 <https://github.com/pybind/pybind11/issues/1251>`_.
105
106* Various other minor fixes.
107
Wenzel Jakobf94d7592017-09-14 08:49:47 +0200108v2.2.1 (September 14, 2017)
Dean Moldovan7939f4b2017-09-04 13:49:19 +0200109-----------------------------------------------------
110
Dean Moldovan27680302017-09-13 19:04:25 +0200111* Added ``py::module::reload()`` member function for reloading a module.
112 `#1040 <https://github.com/pybind/pybind11/pull/1040>`_.
Dean Moldovanb0a0e4a2017-09-04 21:16:09 +0200113
Dean Moldovan953d2422017-09-10 16:53:02 +0200114* Fixed a reference leak in the number converter.
115 `#1078 <https://github.com/pybind/pybind11/pull/1078>`_.
116
Dean Moldovan27680302017-09-13 19:04:25 +0200117* Fixed compilation with Clang on host GCC < 5 (old libstdc++ which isn't fully
118 C++11 compliant). `#1062 <https://github.com/pybind/pybind11/pull/1062>`_.
119
Dean Moldovan3c4933c2017-09-01 21:42:20 +0200120* Fixed a regression where the automatic ``std::vector<bool>`` caster would
121 fail to compile. The same fix also applies to any container which returns
122 element proxies instead of references.
123 `#1053 <https://github.com/pybind/pybind11/pull/1053>`_.
124
Dean Moldovan7939f4b2017-09-04 13:49:19 +0200125* Fixed a regression where the ``py::keep_alive`` policy could not be applied
126 to constructors. `#1065 <https://github.com/pybind/pybind11/pull/1065>`_.
127
Dean Moldovan7b1de1e2017-09-03 01:31:47 +0200128* Fixed a nullptr dereference when loading a ``py::module_local`` type
129 that's only registered in an external module.
130 `#1058 <https://github.com/pybind/pybind11/pull/1058>`_.
131
Dean Moldovan27680302017-09-13 19:04:25 +0200132* Fixed implicit conversion of accessors to types derived from ``py::object``.
133 `#1076 <https://github.com/pybind/pybind11/pull/1076>`_.
134
135* The ``name`` in ``PYBIND11_MODULE(name, variable)`` can now be a macro.
136 `#1082 <https://github.com/pybind/pybind11/pull/1082>`_.
137
138* Relaxed overly strict ``py::pickle()`` check for matching get and set types.
139 `#1064 <https://github.com/pybind/pybind11/pull/1064>`_.
140
Dean Moldovan2b4477e2017-09-09 20:21:34 +0200141* Conversion errors now try to be more informative when it's likely that
142 a missing header is the cause (e.g. forgetting ``<pybind11/stl.h>``).
143 `#1077 <https://github.com/pybind/pybind11/pull/1077>`_.
144
Wenzel Jakob2a5a5ec2017-08-31 13:58:24 +0200145v2.2.0 (August 31, 2017)
Wenzel Jakobd405b1b2017-03-22 22:20:07 +0100146-----------------------------------------------------
147
Dean Moldovandb46a892017-08-13 22:25:15 +0200148* Support for embedding the Python interpreter. See the
149 :doc:`documentation page </advanced/embedding>` for a
150 full overview of the new features.
151 `#774 <https://github.com/pybind/pybind11/pull/774>`_,
152 `#889 <https://github.com/pybind/pybind11/pull/889>`_,
153 `#892 <https://github.com/pybind/pybind11/pull/892>`_,
154 `#920 <https://github.com/pybind/pybind11/pull/920>`_.
155
156 .. code-block:: cpp
157
158 #include <pybind11/embed.h>
159 namespace py = pybind11;
160
161 int main() {
162 py::scoped_interpreter guard{}; // start the interpreter and keep it alive
163
164 py::print("Hello, World!"); // use the Python API
165 }
166
167* Support for inheriting from multiple C++ bases in Python.
168 `#693 <https://github.com/pybind/pybind11/pull/693>`_.
169
170 .. code-block:: python
171
172 from cpp_module import CppBase1, CppBase2
173
174 class PyDerived(CppBase1, CppBase2):
175 def __init__(self):
176 CppBase1.__init__(self) # C++ bases must be initialized explicitly
177 CppBase2.__init__(self)
178
179* ``PYBIND11_MODULE`` is now the preferred way to create module entry points.
180 ``PYBIND11_PLUGIN`` is deprecated. See :ref:`macros` for details.
181 `#879 <https://github.com/pybind/pybind11/pull/879>`_.
182
183 .. code-block:: cpp
184
185 // new
186 PYBIND11_MODULE(example, m) {
187 m.def("add", [](int a, int b) { return a + b; });
188 }
189
190 // old
191 PYBIND11_PLUGIN(example) {
192 py::module m("example");
193 m.def("add", [](int a, int b) { return a + b; });
194 return m.ptr();
195 }
196
197* pybind11's headers and build system now more strictly enforce hidden symbol
198 visibility for extension modules. This should be seamless for most users,
Dean Moldovan1fb9df62017-08-18 19:26:49 +0200199 but see the :doc:`upgrade` if you use a custom build system.
200 `#995 <https://github.com/pybind/pybind11/pull/995>`_.
Dean Moldovandb46a892017-08-13 22:25:15 +0200201
202* Support for ``py::module_local`` types which allow multiple modules to
203 export the same C++ types without conflicts. This is useful for opaque
204 types like ``std::vector<int>``. ``py::bind_vector`` and ``py::bind_map``
205 now default to ``py::module_local`` if their elements are builtins or
206 local types. See :ref:`module_local` for details.
207 `#949 <https://github.com/pybind/pybind11/pull/949>`_,
208 `#981 <https://github.com/pybind/pybind11/pull/981>`_,
209 `#995 <https://github.com/pybind/pybind11/pull/995>`_,
210 `#997 <https://github.com/pybind/pybind11/pull/997>`_.
211
212* Custom constructors can now be added very easily using lambdas or factory
213 functions which return a class instance by value, pointer or holder. This
214 supersedes the old placement-new ``__init__`` technique.
215 See :ref:`custom_constructors` for details.
Dean Moldovan4c540442017-08-30 21:53:08 +0200216 `#805 <https://github.com/pybind/pybind11/pull/805>`_,
217 `#1014 <https://github.com/pybind/pybind11/pull/1014>`_.
Dean Moldovandb46a892017-08-13 22:25:15 +0200218
219 .. code-block:: cpp
220
221 struct Example {
222 Example(std::string);
223 };
224
225 py::class_<Example>(m, "Example")
226 .def(py::init<std::string>()) // existing constructor
227 .def(py::init([](int n) { // custom constructor
228 return std::make_unique<Example>(std::to_string(n));
229 }));
230
Dean Moldovan1e5a7da2017-08-24 01:53:15 +0200231* Similarly to custom constructors, pickling support functions are now bound
232 using the ``py::pickle()`` adaptor which improves type safety. See the
233 :doc:`upgrade` and :ref:`pickling` for details.
234 `#1038 <https://github.com/pybind/pybind11/pull/1038>`_.
235
Dean Moldovandb46a892017-08-13 22:25:15 +0200236* Builtin support for converting C++17 standard library types and general
237 conversion improvements:
238
239 1. C++17 ``std::variant`` is supported right out of the box. C++11/14
240 equivalents (e.g. ``boost::variant``) can also be added with a simple
241 user-defined specialization. See :ref:`cpp17_container_casters` for details.
242 `#811 <https://github.com/pybind/pybind11/pull/811>`_,
243 `#845 <https://github.com/pybind/pybind11/pull/845>`_,
244 `#989 <https://github.com/pybind/pybind11/pull/989>`_.
245
246 2. Out-of-the-box support for C++17 ``std::string_view``.
247 `#906 <https://github.com/pybind/pybind11/pull/906>`_.
248
249 3. Improved compatibility of the builtin ``optional`` converter.
250 `#874 <https://github.com/pybind/pybind11/pull/874>`_.
251
252 4. The ``bool`` converter now accepts ``numpy.bool_`` and types which
253 define ``__bool__`` (Python 3.x) or ``__nonzero__`` (Python 2.7).
254 `#925 <https://github.com/pybind/pybind11/pull/925>`_.
255
256 5. C++-to-Python casters are now more efficient and move elements out
257 of rvalue containers whenever possible.
258 `#851 <https://github.com/pybind/pybind11/pull/851>`_,
259 `#936 <https://github.com/pybind/pybind11/pull/936>`_,
260 `#938 <https://github.com/pybind/pybind11/pull/938>`_.
261
262 6. Fixed ``bytes`` to ``std::string/char*`` conversion on Python 3.
263 `#817 <https://github.com/pybind/pybind11/pull/817>`_.
264
265 7. Fixed lifetime of temporary C++ objects created in Python-to-C++ conversions.
266 `#924 <https://github.com/pybind/pybind11/pull/924>`_.
267
Henry Schreiner8b405052017-08-24 17:12:43 -0700268* Scope guard call policy for RAII types, e.g. ``py::call_guard<py::gil_scoped_release>()``,
269 ``py::call_guard<py::scoped_ostream_redirect>()``. See :ref:`call_policies` for details.
Dean Moldovandb46a892017-08-13 22:25:15 +0200270 `#740 <https://github.com/pybind/pybind11/pull/740>`_.
271
Henry Schreiner8b405052017-08-24 17:12:43 -0700272* Utility for redirecting C++ streams to Python (e.g. ``std::cout`` ->
273 ``sys.stdout``). Scope guard ``py::scoped_ostream_redirect`` in C++ and
274 a context manager in Python. See :ref:`ostream_redirect`.
275 `#1009 <https://github.com/pybind/pybind11/pull/1009>`_.
276
Dean Moldovandb46a892017-08-13 22:25:15 +0200277* Improved handling of types and exceptions across module boundaries.
278 `#915 <https://github.com/pybind/pybind11/pull/915>`_,
279 `#951 <https://github.com/pybind/pybind11/pull/951>`_,
280 `#995 <https://github.com/pybind/pybind11/pull/995>`_.
281
282* Fixed destruction order of ``py::keep_alive`` nurse/patient objects
283 in reference cycles.
284 `#856 <https://github.com/pybind/pybind11/pull/856>`_.
285
286* Numpy and buffer protocol related improvements:
287
288 1. Support for negative strides in Python buffer objects/numpy arrays. This
289 required changing integers from unsigned to signed for the related C++ APIs.
290 Note: If you have compiler warnings enabled, you may notice some new conversion
291 warnings after upgrading. These can be resolved with ``static_cast``.
292 `#782 <https://github.com/pybind/pybind11/pull/782>`_.
293
294 2. Support ``std::complex`` and arrays inside ``PYBIND11_NUMPY_DTYPE``.
295 `#831 <https://github.com/pybind/pybind11/pull/831>`_,
296 `#832 <https://github.com/pybind/pybind11/pull/832>`_.
297
298 3. Support for constructing ``py::buffer_info`` and ``py::arrays`` using
299 arbitrary containers or iterators instead of requiring a ``std::vector``.
300 `#788 <https://github.com/pybind/pybind11/pull/788>`_,
301 `#822 <https://github.com/pybind/pybind11/pull/822>`_,
302 `#860 <https://github.com/pybind/pybind11/pull/860>`_.
303
304 4. Explicitly check numpy version and require >= 1.7.0.
305 `#819 <https://github.com/pybind/pybind11/pull/819>`_.
306
307* Support for allowing/prohibiting ``None`` for specific arguments and improved
308 ``None`` overload resolution order. See :ref:`none_arguments` for details.
309 `#843 <https://github.com/pybind/pybind11/pull/843>`_.
310 `#859 <https://github.com/pybind/pybind11/pull/859>`_.
311
312* Added ``py::exec()`` as a shortcut for ``py::eval<py::eval_statements>()``
313 and support for C++11 raw string literals as input. See :ref:`eval`.
314 `#766 <https://github.com/pybind/pybind11/pull/766>`_,
315 `#827 <https://github.com/pybind/pybind11/pull/827>`_.
316
317* ``py::vectorize()`` ignores non-vectorizable arguments and supports
318 member functions.
319 `#762 <https://github.com/pybind/pybind11/pull/762>`_.
320
321* Support for bound methods as callbacks (``pybind11/functional.h``).
322 `#815 <https://github.com/pybind/pybind11/pull/815>`_.
323
324* Allow aliasing pybind11 methods: ``cls.attr("foo") = cls.attr("bar")``.
325 `#802 <https://github.com/pybind/pybind11/pull/802>`_.
326
327* Don't allow mixed static/non-static overloads.
328 `#804 <https://github.com/pybind/pybind11/pull/804>`_.
329
330* Fixed overriding static properties in derived classes.
331 `#784 <https://github.com/pybind/pybind11/pull/784>`_.
332
Dean Moldovan4c540442017-08-30 21:53:08 +0200333* Improved deduction of member functions of a derived class when its bases
334 aren't registered with pybind11.
Dean Moldovandb46a892017-08-13 22:25:15 +0200335 `#855 <https://github.com/pybind/pybind11/pull/855>`_.
336
337 .. code-block:: cpp
338
339 struct Base {
340 int foo() { return 42; }
341 }
342
343 struct Derived : Base {}
344
345 // Now works, but previously required also binding `Base`
346 py::class_<Derived>(m, "Derived")
347 .def("foo", &Derived::foo); // function is actually from `Base`
348
Wenzel Jakobb12a9d62017-08-23 16:30:56 +0200349* The implementation of ``py::init<>`` now uses C++11 brace initialization
350 syntax to construct instances, which permits binding implicit constructors of
351 aggregate types. `#1015 <https://github.com/pybind/pybind11/pull/1015>`_.
352
353 .. code-block:: cpp
354
355 struct Aggregate {
356 int a;
357 std::string b;
358 };
359
360 py::class_<Aggregate>(m, "Aggregate")
361 .def(py::init<int, const std::string &>());
362
Dean Moldovandb46a892017-08-13 22:25:15 +0200363* Fixed issues with multiple inheritance with offset base/derived pointers.
364 `#812 <https://github.com/pybind/pybind11/pull/812>`_,
365 `#866 <https://github.com/pybind/pybind11/pull/866>`_,
366 `#960 <https://github.com/pybind/pybind11/pull/960>`_.
367
Dean Moldovan4c540442017-08-30 21:53:08 +0200368* Fixed reference leak of type objects.
369 `#1030 <https://github.com/pybind/pybind11/pull/1030>`_.
370
Dean Moldovandb46a892017-08-13 22:25:15 +0200371* Improved support for the ``/std:c++14`` and ``/std:c++latest`` modes
372 on MSVC 2017.
373 `#841 <https://github.com/pybind/pybind11/pull/841>`_,
374 `#999 <https://github.com/pybind/pybind11/pull/999>`_.
375
376* Fixed detection of private operator new on MSVC.
377 `#893 <https://github.com/pybind/pybind11/pull/893>`_,
378 `#918 <https://github.com/pybind/pybind11/pull/918>`_.
379
380* Intel C++ compiler compatibility fixes.
381 `#937 <https://github.com/pybind/pybind11/pull/937>`_.
382
383* Fixed implicit conversion of `py::enum_` to integer types on Python 2.7.
384 `#821 <https://github.com/pybind/pybind11/pull/821>`_.
385
Bruce Merry37de2da2017-08-30 14:22:00 +0200386* Added ``py::hash`` to fetch the hash value of Python objects, and
387 ``.def(hash(py::self))`` to provide the C++ ``std::hash`` as the Python
388 ``__hash__`` method.
389 `#1034 <https://github.com/pybind/pybind11/pull/1034>`_.
390
Dean Moldovandb46a892017-08-13 22:25:15 +0200391* Fixed ``__truediv__`` on Python 2 and ``__itruediv__`` on Python 3.
392 `#867 <https://github.com/pybind/pybind11/pull/867>`_.
393
394* ``py::capsule`` objects now support the ``name`` attribute. This is useful
395 for interfacing with ``scipy.LowLevelCallable``.
396 `#902 <https://github.com/pybind/pybind11/pull/902>`_.
397
398* Fixed ``py::make_iterator``'s ``__next__()`` for past-the-end calls.
399 `#897 <https://github.com/pybind/pybind11/pull/897>`_.
400
401* Added ``error_already_set::matches()`` for checking Python exceptions.
402 `#772 <https://github.com/pybind/pybind11/pull/772>`_.
403
404* Deprecated ``py::error_already_set::clear()``. It's no longer needed
405 following a simplification of the ``py::error_already_set`` class.
406 `#954 <https://github.com/pybind/pybind11/pull/954>`_.
407
408* Deprecated ``py::handle::operator==()`` in favor of ``py::handle::is()``
409 `#825 <https://github.com/pybind/pybind11/pull/825>`_.
410
411* Deprecated ``py::object::borrowed``/``py::object::stolen``.
412 Use ``py::object::borrowed_t{}``/``py::object::stolen_t{}`` instead.
413 `#771 <https://github.com/pybind/pybind11/pull/771>`_.
414
Dean Moldovan4c540442017-08-30 21:53:08 +0200415* Changed internal data structure versioning to avoid conflicts between
416 modules compiled with different revisions of pybind11.
417 `#1012 <https://github.com/pybind/pybind11/pull/1012>`_.
418
Dean Moldovandb46a892017-08-13 22:25:15 +0200419* Additional compile-time and run-time error checking and more informative messages.
420 `#786 <https://github.com/pybind/pybind11/pull/786>`_,
421 `#794 <https://github.com/pybind/pybind11/pull/794>`_,
422 `#803 <https://github.com/pybind/pybind11/pull/803>`_.
423
424* Various minor improvements and fixes.
425 `#764 <https://github.com/pybind/pybind11/pull/764>`_,
426 `#791 <https://github.com/pybind/pybind11/pull/791>`_,
427 `#795 <https://github.com/pybind/pybind11/pull/795>`_,
428 `#840 <https://github.com/pybind/pybind11/pull/840>`_,
429 `#844 <https://github.com/pybind/pybind11/pull/844>`_,
430 `#846 <https://github.com/pybind/pybind11/pull/846>`_,
431 `#849 <https://github.com/pybind/pybind11/pull/849>`_,
432 `#858 <https://github.com/pybind/pybind11/pull/858>`_,
433 `#862 <https://github.com/pybind/pybind11/pull/862>`_,
434 `#871 <https://github.com/pybind/pybind11/pull/871>`_,
435 `#872 <https://github.com/pybind/pybind11/pull/872>`_,
436 `#881 <https://github.com/pybind/pybind11/pull/881>`_,
437 `#888 <https://github.com/pybind/pybind11/pull/888>`_,
438 `#899 <https://github.com/pybind/pybind11/pull/899>`_,
439 `#928 <https://github.com/pybind/pybind11/pull/928>`_,
440 `#931 <https://github.com/pybind/pybind11/pull/931>`_,
441 `#944 <https://github.com/pybind/pybind11/pull/944>`_,
442 `#950 <https://github.com/pybind/pybind11/pull/950>`_,
443 `#952 <https://github.com/pybind/pybind11/pull/952>`_,
444 `#962 <https://github.com/pybind/pybind11/pull/962>`_,
445 `#965 <https://github.com/pybind/pybind11/pull/965>`_,
446 `#970 <https://github.com/pybind/pybind11/pull/970>`_,
Dean Moldovandb46a892017-08-13 22:25:15 +0200447 `#978 <https://github.com/pybind/pybind11/pull/978>`_,
Dean Moldovan4c540442017-08-30 21:53:08 +0200448 `#979 <https://github.com/pybind/pybind11/pull/979>`_,
Wenzel Jakoba1041192017-08-28 16:35:32 +0200449 `#986 <https://github.com/pybind/pybind11/pull/986>`_,
Dean Moldovan4c540442017-08-30 21:53:08 +0200450 `#1020 <https://github.com/pybind/pybind11/pull/1020>`_,
451 `#1027 <https://github.com/pybind/pybind11/pull/1027>`_,
Wenzel Jakoba1041192017-08-28 16:35:32 +0200452 `#1037 <https://github.com/pybind/pybind11/pull/1037>`_.
Dean Moldovandb46a892017-08-13 22:25:15 +0200453
454* Testing improvements.
455 `#798 <https://github.com/pybind/pybind11/pull/798>`_,
456 `#882 <https://github.com/pybind/pybind11/pull/882>`_,
457 `#898 <https://github.com/pybind/pybind11/pull/898>`_,
458 `#900 <https://github.com/pybind/pybind11/pull/900>`_,
459 `#921 <https://github.com/pybind/pybind11/pull/921>`_,
460 `#923 <https://github.com/pybind/pybind11/pull/923>`_,
461 `#963 <https://github.com/pybind/pybind11/pull/963>`_.
462
Wenzel Jakobdb200952017-04-07 02:03:46 +0200463v2.1.1 (April 7, 2017)
464-----------------------------------------------------
465
466* Fixed minimum version requirement for MSVC 2015u3
467 `#773 <https://github.com/pybind/pybind11/pull/773>`_.
468
Wenzel Jakobd405b1b2017-03-22 22:20:07 +0100469v2.1.0 (March 22, 2017)
Wenzel Jakoba9730be2017-01-06 14:18:44 +0100470-----------------------------------------------------
471
Wenzel Jakob62e5fef2017-03-22 22:07:45 +0100472* pybind11 now performs function overload resolution in two phases. The first
473 phase only considers exact type matches, while the second allows for implicit
474 conversions to take place. A special ``noconvert()`` syntax can be used to
475 completely disable implicit conversions for specific arguments.
476 `#643 <https://github.com/pybind/pybind11/pull/643>`_,
477 `#634 <https://github.com/pybind/pybind11/pull/634>`_,
478 `#650 <https://github.com/pybind/pybind11/pull/650>`_.
479
480* Fixed a regression where static properties no longer worked with classes
481 using multiple inheritance. The ``py::metaclass`` attribute is no longer
482 necessary (and deprecated as of this release) when binding classes with
483 static properties.
484 `#679 <https://github.com/pybind/pybind11/pull/679>`_,
485
486* Classes bound using ``pybind11`` can now use custom metaclasses.
487 `#679 <https://github.com/pybind/pybind11/pull/679>`_,
488
489* ``py::args`` and ``py::kwargs`` can now be mixed with other positional
490 arguments when binding functions using pybind11.
491 `#611 <https://github.com/pybind/pybind11/pull/611>`_.
492
493* Improved support for C++11 unicode string and character types; added
494 extensive documentation regarding pybind11's string conversion behavior.
495 `#624 <https://github.com/pybind/pybind11/pull/624>`_,
496 `#636 <https://github.com/pybind/pybind11/pull/636>`_,
497 `#715 <https://github.com/pybind/pybind11/pull/715>`_.
498
499* pybind11 can now avoid expensive copies when converting Eigen arrays to NumPy
500 arrays (and vice versa). `#610 <https://github.com/pybind/pybind11/pull/610>`_.
501
502* The "fast path" in ``py::vectorize`` now works for any full-size group of C or
503 F-contiguous arrays. The non-fast path is also faster since it no longer performs
504 copies of the input arguments (except when type conversions are necessary).
505 `#610 <https://github.com/pybind/pybind11/pull/610>`_.
506
507* Added fast, unchecked access to NumPy arrays via a proxy object.
508 `#746 <https://github.com/pybind/pybind11/pull/746>`_.
509
Wenzel Jakob0d929382017-03-22 22:52:29 +0100510* Transparent support for class-specific ``operator new`` and
Wenzel Jakob62e5fef2017-03-22 22:07:45 +0100511 ``operator delete`` implementations.
512 `#755 <https://github.com/pybind/pybind11/pull/755>`_.
513
514* Slimmer and more efficient STL-compatible iterator interface for sequence types.
515 `#662 <https://github.com/pybind/pybind11/pull/662>`_.
516
517* Improved custom holder type support.
518 `#607 <https://github.com/pybind/pybind11/pull/607>`_.
519
520* ``nullptr`` to ``None`` conversion fixed in various builtin type casters.
521 `#732 <https://github.com/pybind/pybind11/pull/732>`_.
522
523* ``enum_`` now exposes its members via a special ``__members__`` attribute.
524 `#666 <https://github.com/pybind/pybind11/pull/666>`_.
525
526* ``std::vector`` bindings created using ``stl_bind.h`` can now optionally
527 implement the buffer protocol. `#488 <https://github.com/pybind/pybind11/pull/488>`_.
528
529* Automated C++ reference documentation using doxygen and breathe.
530 `#598 <https://github.com/pybind/pybind11/pull/598>`_.
531
532* Added minimum compiler version assertions.
533 `#727 <https://github.com/pybind/pybind11/pull/727>`_.
534
535* Improved compatibility with C++1z.
536 `#677 <https://github.com/pybind/pybind11/pull/677>`_.
537
538* Improved ``py::capsule`` API. Can be used to implement cleanup
539 callbacks that are involved at module destruction time.
540 `#752 <https://github.com/pybind/pybind11/pull/752>`_.
541
542* Various minor improvements and fixes.
543 `#595 <https://github.com/pybind/pybind11/pull/595>`_,
544 `#588 <https://github.com/pybind/pybind11/pull/588>`_,
545 `#589 <https://github.com/pybind/pybind11/pull/589>`_,
546 `#603 <https://github.com/pybind/pybind11/pull/603>`_,
547 `#619 <https://github.com/pybind/pybind11/pull/619>`_,
548 `#648 <https://github.com/pybind/pybind11/pull/648>`_,
549 `#695 <https://github.com/pybind/pybind11/pull/695>`_,
550 `#720 <https://github.com/pybind/pybind11/pull/720>`_,
551 `#723 <https://github.com/pybind/pybind11/pull/723>`_,
552 `#729 <https://github.com/pybind/pybind11/pull/729>`_,
553 `#724 <https://github.com/pybind/pybind11/pull/724>`_,
554 `#742 <https://github.com/pybind/pybind11/pull/742>`_,
555 `#753 <https://github.com/pybind/pybind11/pull/753>`_.
Wenzel Jakoba9730be2017-01-06 14:18:44 +0100556
Wenzel Jakobf8dafe92017-01-04 15:09:49 +0100557v2.0.1 (Jan 4, 2017)
558-----------------------------------------------------
559
560* Fix pointer to reference error in type_caster on MSVC
561 `#583 <https://github.com/pybind/pybind11/pull/583>`_.
562
563* Fixed a segmentation in the test suite due to a typo
564 `cd7eac <https://github.com/pybind/pybind11/commit/cd7eac>`_.
565
Wenzel Jakobe33ef9c2017-01-01 13:55:06 +0100566v2.0.0 (Jan 1, 2017)
Wenzel Jakobed52f462016-12-26 13:18:26 +0100567-----------------------------------------------------
568
569* Fixed a reference counting regression affecting types with custom metaclasses
570 (introduced in v2.0.0-rc1).
571 `#571 <https://github.com/pybind/pybind11/pull/571>`_.
572
573* Quenched a CMake policy warning.
574 `#570 <https://github.com/pybind/pybind11/pull/570>`_.
575
Wenzel Jakobe33ef9c2017-01-01 13:55:06 +0100576v2.0.0-rc1 (Dec 23, 2016)
Wenzel Jakobf88af0c2016-06-22 13:52:31 +0200577-----------------------------------------------------
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200578
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100579The pybind11 developers are excited to issue a release candidate of pybind11
580with a subsequent v2.0.0 release planned in early January next year.
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200581
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100582An incredible amount of effort by went into pybind11 over the last ~5 months,
583leading to a release that is jam-packed with exciting new features and numerous
Wenzel Jakobf8dafe92017-01-04 15:09:49 +0100584usability improvements. The following list links PRs or individual commits
Wenzel Jakobed52f462016-12-26 13:18:26 +0100585whenever applicable.
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100586
587Happy Christmas!
588
589* Support for binding C++ class hierarchies that make use of multiple
590 inheritance. `#410 <https://github.com/pybind/pybind11/pull/410>`_.
591
592* PyPy support: pybind11 now supports nightly builds of PyPy and will
593 interoperate with the future 5.7 release. No code changes are necessary,
594 everything "just" works as usual. Note that we only target the Python 2.7
595 branch for now; support for 3.x will be added once its ``cpyext`` extension
Wenzel Jakobed52f462016-12-26 13:18:26 +0100596 support catches up. A few minor features remain unsupported for the time
597 being (notably dynamic attributes in custom types).
598 `#527 <https://github.com/pybind/pybind11/pull/527>`_.
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100599
luzpaz4b874612018-05-06 13:54:10 +0000600* Significant work on the documentation -- in particular, the monolithic
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100601 ``advanced.rst`` file was restructured into a easier to read hierarchical
602 organization. `#448 <https://github.com/pybind/pybind11/pull/448>`_.
603
604* Many NumPy-related improvements:
605
606 1. Object-oriented API to access and modify NumPy ``ndarray`` instances,
607 replicating much of the corresponding NumPy C API functionality.
608 `#402 <https://github.com/pybind/pybind11/pull/402>`_.
609
610 2. NumPy array ``dtype`` array descriptors are now first-class citizens and
611 are exposed via a new class ``py::dtype``.
612
613 3. Structured dtypes can be registered using the ``PYBIND11_NUMPY_DTYPE()``
614 macro. Special ``array`` constructors accepting dtype objects were also
615 added.
616
617 One potential caveat involving this change: format descriptor strings
618 should now be accessed via ``format_descriptor::format()`` (however, for
619 compatibility purposes, the old syntax ``format_descriptor::value`` will
620 still work for non-structured data types). `#308
621 <https://github.com/pybind/pybind11/pull/308>`_.
622
623 4. Further improvements to support structured dtypes throughout the system.
624 `#472 <https://github.com/pybind/pybind11/pull/472>`_,
625 `#474 <https://github.com/pybind/pybind11/pull/474>`_,
626 `#459 <https://github.com/pybind/pybind11/pull/459>`_,
627 `#453 <https://github.com/pybind/pybind11/pull/453>`_,
628 `#452 <https://github.com/pybind/pybind11/pull/452>`_, and
629 `#505 <https://github.com/pybind/pybind11/pull/505>`_.
630
631 5. Fast access operators. `#497 <https://github.com/pybind/pybind11/pull/497>`_.
632
633 6. Constructors for arrays whose storage is owned by another object.
634 `#440 <https://github.com/pybind/pybind11/pull/440>`_.
635
636 7. Added constructors for ``array`` and ``array_t`` explicitly accepting shape
637 and strides; if strides are not provided, they are deduced assuming
638 C-contiguity. Also added simplified constructors for 1-dimensional case.
639
640 8. Added buffer/NumPy support for ``char[N]`` and ``std::array<char, N>`` types.
641
642 9. Added ``memoryview`` wrapper type which is constructible from ``buffer_info``.
643
644* Eigen: many additional conversions and support for non-contiguous
645 arrays/slices.
646 `#427 <https://github.com/pybind/pybind11/pull/427>`_,
647 `#315 <https://github.com/pybind/pybind11/pull/315>`_,
648 `#316 <https://github.com/pybind/pybind11/pull/316>`_,
649 `#312 <https://github.com/pybind/pybind11/pull/312>`_, and
650 `#267 <https://github.com/pybind/pybind11/pull/267>`_
651
652* Incompatible changes in ``class_<...>::class_()``:
653
654 1. Declarations of types that provide access via the buffer protocol must
655 now include the ``py::buffer_protocol()`` annotation as an argument to
656 the ``class_`` constructor.
657
658 2. Declarations of types that require a custom metaclass (i.e. all classes
659 which include static properties via commands such as
660 ``def_readwrite_static()``) must now include the ``py::metaclass()``
661 annotation as an argument to the ``class_`` constructor.
662
663 These two changes were necessary to make type definitions in pybind11
664 future-proof, and to support PyPy via its cpyext mechanism. `#527
665 <https://github.com/pybind/pybind11/pull/527>`_.
666
667
luzpaz4b874612018-05-06 13:54:10 +0000668 3. This version of pybind11 uses a redesigned mechanism for instantiating
669 trampoline classes that are used to override virtual methods from within
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100670 Python. This led to the following user-visible syntax change: instead of
671
672 .. code-block:: cpp
673
674 py::class_<TrampolineClass>("MyClass")
675 .alias<MyClass>()
676 ....
677
678 write
679
680 .. code-block:: cpp
681
682 py::class_<MyClass, TrampolineClass>("MyClass")
683 ....
684
685 Importantly, both the original and the trampoline class are now
686 specified as an arguments (in arbitrary order) to the ``py::class_``
687 template, and the ``alias<..>()`` call is gone. The new scheme has zero
688 overhead in cases when Python doesn't override any functions of the
689 underlying C++ class. `rev. 86d825
690 <https://github.com/pybind/pybind11/commit/86d825>`_.
691
Wenzel Jakobe6b2f752016-07-10 10:54:46 +0200692* Added ``eval`` and ``eval_file`` functions for evaluating expressions and
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100693 statements from a string or file. `rev. 0d3fc3
694 <https://github.com/pybind/pybind11/commit/0d3fc3>`_.
695
696* pybind11 can now create types with a modifiable dictionary.
697 `#437 <https://github.com/pybind/pybind11/pull/437>`_ and
698 `#444 <https://github.com/pybind/pybind11/pull/444>`_.
699
700* Support for translation of arbitrary C++ exceptions to Python counterparts.
701 `#296 <https://github.com/pybind/pybind11/pull/296>`_ and
702 `#273 <https://github.com/pybind/pybind11/pull/273>`_.
703
704* Report full backtraces through mixed C++/Python code, better reporting for
705 import errors, fixed GIL management in exception processing.
706 `#537 <https://github.com/pybind/pybind11/pull/537>`_,
707 `#494 <https://github.com/pybind/pybind11/pull/494>`_,
708 `rev. e72d95 <https://github.com/pybind/pybind11/commit/e72d95>`_, and
709 `rev. 099d6e <https://github.com/pybind/pybind11/commit/099d6e>`_.
710
711* Support for bit-level operations, comparisons, and serialization of C++
712 enumerations. `#503 <https://github.com/pybind/pybind11/pull/503>`_,
713 `#508 <https://github.com/pybind/pybind11/pull/508>`_,
714 `#380 <https://github.com/pybind/pybind11/pull/380>`_,
715 `#309 <https://github.com/pybind/pybind11/pull/309>`_.
716 `#311 <https://github.com/pybind/pybind11/pull/311>`_.
717
718* The ``class_`` constructor now accepts its template arguments in any order.
719 `#385 <https://github.com/pybind/pybind11/pull/385>`_.
720
721* Attribute and item accessors now have a more complete interface which makes
722 it possible to chain attributes as in
723 ``obj.attr("a")[key].attr("b").attr("method")(1, 2, 3)``. `#425
724 <https://github.com/pybind/pybind11/pull/425>`_.
725
726* Major redesign of the default and conversion constructors in ``pytypes.h``.
727 `#464 <https://github.com/pybind/pybind11/pull/464>`_.
728
729* Added built-in support for ``std::shared_ptr`` holder type. It is no longer
730 necessary to to include a declaration of the form
731 ``PYBIND11_DECLARE_HOLDER_TYPE(T, std::shared_ptr<T>)`` (though continuing to
732 do so won't cause an error).
733 `#454 <https://github.com/pybind/pybind11/pull/454>`_.
734
735* New ``py::overload_cast`` casting operator to select among multiple possible
736 overloads of a function. An example:
737
738 .. code-block:: cpp
739
740 py::class_<Pet>(m, "Pet")
741 .def("set", py::overload_cast<int>(&Pet::set), "Set the pet's age")
742 .def("set", py::overload_cast<const std::string &>(&Pet::set), "Set the pet's name");
743
744 This feature only works on C++14-capable compilers.
745 `#541 <https://github.com/pybind/pybind11/pull/541>`_.
746
747* C++ types are automatically cast to Python types, e.g. when assigning
748 them as an attribute. For instance, the following is now legal:
749
750 .. code-block:: cpp
751
752 py::module m = /* ... */
753 m.attr("constant") = 123;
754
755 (Previously, a ``py::cast`` call was necessary to avoid a compilation error.)
756 `#551 <https://github.com/pybind/pybind11/pull/551>`_.
757
758* Redesigned ``pytest``-based test suite. `#321 <https://github.com/pybind/pybind11/pull/321>`_.
759
760* Instance tracking to detect reference leaks in test suite. `#324 <https://github.com/pybind/pybind11/pull/324>`_
761
762* pybind11 can now distinguish between multiple different instances that are
763 located at the same memory address, but which have different types.
764 `#329 <https://github.com/pybind/pybind11/pull/329>`_.
765
766* Improved logic in ``move`` return value policy.
767 `#510 <https://github.com/pybind/pybind11/pull/510>`_,
768 `#297 <https://github.com/pybind/pybind11/pull/297>`_.
769
770* Generalized unpacking API to permit calling Python functions from C++ using
771 notation such as ``foo(a1, a2, *args, "ka"_a=1, "kb"_a=2, **kwargs)``. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
772
773* ``py::print()`` function whose behavior matches that of the native Python
774 ``print()`` function. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
775
776* Added ``py::dict`` keyword constructor:``auto d = dict("number"_a=42,
777 "name"_a="World");``. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
778
779* Added ``py::str::format()`` method and ``_s`` literal: ``py::str s = "1 + 2
780 = {}"_s.format(3);``. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
781
782* Added ``py::repr()`` function which is equivalent to Python's builtin
783 ``repr()``. `#333 <https://github.com/pybind/pybind11/pull/333>`_.
784
785* Improved construction and destruction logic for holder types. It is now
786 possible to reference instances with smart pointer holder types without
787 constructing the holder if desired. The ``PYBIND11_DECLARE_HOLDER_TYPE``
788 macro now accepts an optional second parameter to indicate whether the holder
789 type uses intrusive reference counting.
790 `#533 <https://github.com/pybind/pybind11/pull/533>`_ and
791 `#561 <https://github.com/pybind/pybind11/pull/561>`_.
792
793* Mapping a stateless C++ function to Python and back is now "for free" (i.e.
794 no extra indirections or argument conversion overheads). `rev. 954b79
795 <https://github.com/pybind/pybind11/commit/954b79>`_.
796
797* Bindings for ``std::valarray<T>``.
798 `#545 <https://github.com/pybind/pybind11/pull/545>`_.
799
800* Improved support for C++17 capable compilers.
801 `#562 <https://github.com/pybind/pybind11/pull/562>`_.
802
803* Bindings for ``std::optional<t>``.
804 `#475 <https://github.com/pybind/pybind11/pull/475>`_,
805 `#476 <https://github.com/pybind/pybind11/pull/476>`_,
806 `#479 <https://github.com/pybind/pybind11/pull/479>`_,
807 `#499 <https://github.com/pybind/pybind11/pull/499>`_, and
808 `#501 <https://github.com/pybind/pybind11/pull/501>`_.
809
810* ``stl_bind.h``: general improvements and support for ``std::map`` and
811 ``std::unordered_map``.
812 `#490 <https://github.com/pybind/pybind11/pull/490>`_,
813 `#282 <https://github.com/pybind/pybind11/pull/282>`_,
814 `#235 <https://github.com/pybind/pybind11/pull/235>`_.
815
816* The ``std::tuple``, ``std::pair``, ``std::list``, and ``std::vector`` type
817 casters now accept any Python sequence type as input. `rev. 107285
818 <https://github.com/pybind/pybind11/commit/107285>`_.
819
820* Improved CMake Python detection on multi-architecture Linux.
821 `#532 <https://github.com/pybind/pybind11/pull/532>`_.
822
823* Infrastructure to selectively disable or enable parts of the automatically
824 generated docstrings. `#486 <https://github.com/pybind/pybind11/pull/486>`_.
825
826* ``reference`` and ``reference_internal`` are now the default return value
827 properties for static and non-static properties, respectively. `#473
828 <https://github.com/pybind/pybind11/pull/473>`_. (the previous defaults
829 were ``automatic``). `#473 <https://github.com/pybind/pybind11/pull/473>`_.
830
831* Support for ``std::unique_ptr`` with non-default deleters or no deleter at
832 all (``py::nodelete``). `#384 <https://github.com/pybind/pybind11/pull/384>`_.
833
Wenzel Jakob3c796712016-12-23 16:19:36 +0100834* Deprecated ``handle::call()`` method. The new syntax to call Python
835 functions is simply ``handle()``. It can also be invoked explicitly via
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100836 ``handle::operator<X>()``, where ``X`` is an optional return value policy.
837
838* Print more informative error messages when ``make_tuple()`` or ``cast()``
839 fail. `#262 <https://github.com/pybind/pybind11/pull/262>`_.
840
841* Creation of holder types for classes deriving from
842 ``std::enable_shared_from_this<>`` now also works for ``const`` values.
843 `#260 <https://github.com/pybind/pybind11/pull/260>`_.
844
845* ``make_iterator()`` improvements for better compatibility with various
846 types (now uses prefix increment operator); it now also accepts iterators
847 with different begin/end types as long as they are equality comparable.
848 `#247 <https://github.com/pybind/pybind11/pull/247>`_.
849
850* ``arg()`` now accepts a wider range of argument types for default values.
851 `#244 <https://github.com/pybind/pybind11/pull/244>`_.
852
853* Support ``keep_alive`` where the nurse object may be ``None``. `#341
854 <https://github.com/pybind/pybind11/pull/341>`_.
855
856* Added constructors for ``str`` and ``bytes`` from zero-terminated char
857 pointers, and from char pointers and length. Added constructors for ``str``
858 from ``bytes`` and for ``bytes`` from ``str``, which will perform UTF-8
859 decoding/encoding as required.
860
861* Many other improvements of library internals without user-visible changes
862
Wenzel Jakoba720a602016-07-12 18:02:13 +0200863
8641.8.1 (July 12, 2016)
865----------------------
Wenzel Jakobc47d4982016-07-11 23:40:28 +0200866* Fixed a rare but potentially very severe issue when the garbage collector ran
867 during pybind11 type creation.
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200868
Wenzel Jakobf9502152016-06-14 15:00:46 +02008691.8.0 (June 14, 2016)
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200870----------------------
871* Redesigned CMake build system which exports a convenient
872 ``pybind11_add_module`` function to parent projects.
873* ``std::vector<>`` type bindings analogous to Boost.Python's ``indexing_suite``
874* Transparent conversion of sparse and dense Eigen matrices and vectors (``eigen.h``)
875* Added an ``ExtraFlags`` template argument to the NumPy ``array_t<>`` wrapper
876 to disable an enforced cast that may lose precision, e.g. to create overloads
877 for different precisions and complex vs real-valued matrices.
Wenzel Jakob3f200fa2016-05-17 15:35:29 +0200878* Prevent implicit conversion of floating point values to integral types in
879 function arguments
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200880* Fixed incorrect default return value policy for functions returning a shared
881 pointer
Wenzel Jakob38d8b8c2016-05-31 09:53:28 +0200882* Don't allow registering a type via ``class_`` twice
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200883* Don't allow casting a ``None`` value into a C++ lvalue reference
884* Fixed a crash in ``enum_::operator==`` that was triggered by the ``help()`` command
885* Improved detection of whether or not custom C++ types can be copy/move-constructed
886* Extended ``str`` type to also work with ``bytes`` instances
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200887* Added a ``"name"_a`` user defined string literal that is equivalent to ``py::arg("name")``.
888* When specifying function arguments via ``py::arg``, the test that verifies
889 the number of arguments now runs at compile time.
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200890* Added ``[[noreturn]]`` attribute to ``pybind11_fail()`` to quench some
891 compiler warnings
Wenzel Jakob86d825f2016-05-26 13:19:27 +0200892* List function arguments in exception text when the dispatch code cannot find
893 a matching overload
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200894* Added ``PYBIND11_OVERLOAD_NAME`` and ``PYBIND11_OVERLOAD_PURE_NAME`` macros which
Wenzel Jakobf9502152016-06-14 15:00:46 +0200895 can be used to override virtual methods whose name differs in C++ and Python
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200896 (e.g. ``__call__`` and ``operator()``)
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200897* Various minor ``iterator`` and ``make_iterator()`` improvements
Wenzel Jakob86d825f2016-05-26 13:19:27 +0200898* Transparently support ``__bool__`` on Python 2.x and Python 3.x
899* Fixed issue with destructor of unpickled object not being called
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200900* Minor CMake build system improvements on Windows
Wenzel Jakob86d825f2016-05-26 13:19:27 +0200901* New ``pybind11::args`` and ``pybind11::kwargs`` types to create functions which
902 take an arbitrary number of arguments and keyword arguments
903* New syntax to call a Python function from C++ using ``*args`` and ``*kwargs``
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200904* The functions ``def_property_*`` now correctly process docstring arguments (these
905 formerly caused a segmentation fault)
906* Many ``mkdoc.py`` improvements (enumerations, template arguments, ``DOC()``
907 macro accepts more arguments)
908* Cygwin support
909* Documentation improvements (pickling support, ``keep_alive``, macro usage)
Wenzel Jakobc4d7ccd2016-04-30 22:00:44 +0200910
Wenzel Jakobe70b2ab2016-04-30 19:58:33 +02009111.7 (April 30, 2016)
Wenzel Jakobbb79d7b2016-04-21 12:23:20 +0200912----------------------
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200913* Added a new ``move`` return value policy that triggers C++11 move semantics.
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200914 The automatic return value policy falls back to this case whenever a rvalue
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200915 reference is encountered
Wenzel Jakobe84f5572016-04-26 23:19:19 +0200916* Significantly more general GIL state routines that are used instead of
917 Python's troublesome ``PyGILState_Ensure`` and ``PyGILState_Release`` API
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200918* Redesign of opaque types that drastically simplifies their usage
Wenzel Jakobe70b2ab2016-04-30 19:58:33 +0200919* Extended ability to pass values of type ``[const] void *``
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200920* ``keep_alive`` fix: don't fail when there is no patient
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200921* ``functional.h``: acquire the GIL before calling a Python function
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200922* Added Python RAII type wrappers ``none`` and ``iterable``
923* Added ``*args`` and ``*kwargs`` pass-through parameters to
924 ``pybind11.get_include()`` function
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200925* Iterator improvements and fixes
926* Documentation on return value policies and opaque types improved
Wenzel Jakobbb79d7b2016-04-21 12:23:20 +0200927
Wenzel Jakobe70b2ab2016-04-30 19:58:33 +02009281.6 (April 30, 2016)
929----------------------
930* Skipped due to upload to PyPI gone wrong and inability to recover
931 (https://github.com/pypa/packaging-problems/issues/74)
932
Wenzel Jakobbb79d7b2016-04-21 12:23:20 +02009331.5 (April 21, 2016)
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200934----------------------
Wenzel Jakobc79dbe42016-04-17 21:54:31 +0200935* For polymorphic types, use RTTI to try to return the closest type registered with pybind11
Wenzel Jakobd7efa4f2016-04-13 13:45:09 +0200936* Pickling support for serializing and unserializing C++ instances to a byte stream in Python
Wenzel Jakobb2825952016-04-13 23:33:00 +0200937* Added a convenience routine ``make_iterator()`` which turns a range indicated
938 by a pair of C++ iterators into a iterable Python object
939* Added ``len()`` and a variadic ``make_tuple()`` function
Wenzel Jakobb2b44a92016-04-15 17:50:40 +0200940* Addressed a rare issue that could confuse the current virtual function
941 dispatcher and another that could lead to crashes in multi-threaded
942 applications
Wenzel Jakobb2825952016-04-13 23:33:00 +0200943* Added a ``get_include()`` function to the Python module that returns the path
944 of the directory containing the installed pybind11 header files
Wenzel Jakob1c329aa2016-04-13 02:37:36 +0200945* Documentation improvements: import issues, symbol visibility, pickling, limitations
Wenzel Jakobdbe43ff2016-04-21 12:21:14 +0200946* Added casting support for ``std::reference_wrapper<>``
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200947
Wenzel Jakob33c2a042016-04-07 09:06:49 +02009481.4 (April 7, 2016)
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100949--------------------------
Wenzel Jakob81dfd2c2016-03-08 19:40:32 +0100950* Transparent type conversion for ``std::wstring`` and ``wchar_t``
Wenzel Jakob0e6ca592016-04-07 08:49:37 +0200951* Allow passing ``nullptr``-valued strings
Wenzel Jakob34116732016-04-06 17:55:41 +0200952* Transparent passing of ``void *`` pointers using capsules
Wenzel Jakob0e6ca592016-04-07 08:49:37 +0200953* Transparent support for returning values wrapped in ``std::unique_ptr<>``
Wenzel Jakob4e455dd2016-03-09 16:38:28 +0100954* Improved docstring generation for compatibility with Sphinx
Wenzel Jakob34116732016-04-06 17:55:41 +0200955* Nicer debug error message when default parameter construction fails
956* Support for "opaque" types that bypass the transparent conversion layer for STL containers
957* Redesigned type casting interface to avoid ambiguities that could occasionally cause compiler errors
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200958* Redesigned property implementation; fixes crashes due to an unfortunate default return value policy
Wenzel Jakob4e455dd2016-03-09 16:38:28 +0100959* Anaconda package generation support
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100960
9611.3 (March 8, 2016)
Wenzel Jakob8ed28082016-02-07 17:32:37 +0100962--------------------------
Wenzel Jakobcf2b87a2016-02-22 17:32:44 +0100963
964* Added support for the Intel C++ compiler (v15+)
965* Added support for the STL unordered set/map data structures
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100966* Added support for the STL linked list data structure
Wenzel Jakobcf2b87a2016-02-22 17:32:44 +0100967* NumPy-style broadcasting support in ``pybind11::vectorize``
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200968* pybind11 now displays more verbose error messages when ``arg::operator=()`` fails
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100969* pybind11 internal data structures now live in a version-dependent namespace to avoid ABI issues
970* Many, many bugfixes involving corner cases and advanced usage
Wenzel Jakob8ed28082016-02-07 17:32:37 +0100971
9721.2 (February 7, 2016)
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100973--------------------------
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100974
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100975* Optional: efficient generation of function signatures at compile time using C++14
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100976* Switched to a simpler and more general way of dealing with function default
977 arguments. Unused keyword arguments in function calls are now detected and
978 cause errors as expected
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100979* New ``keep_alive`` call policy analogous to Boost.Python's ``with_custodian_and_ward``
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100980* New ``pybind11::base<>`` attribute to indicate a subclass relationship
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100981* Improved interface for RAII type wrappers in ``pytypes.h``
982* Use RAII type wrappers consistently within pybind11 itself. This
983 fixes various potential refcount leaks when exceptions occur
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200984* Added new ``bytes`` RAII type wrapper (maps to ``string`` in Python 2.7)
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100985* Made handle and related RAII classes const correct, using them more
986 consistently everywhere now
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100987* Got rid of the ugly ``__pybind11__`` attributes on the Python side---they are
988 now stored in a C++ hash table that is not visible in Python
989* Fixed refcount leaks involving NumPy arrays and bound functions
990* Vastly improved handling of shared/smart pointers
991* Removed an unnecessary copy operation in ``pybind11::vectorize``
992* Fixed naming clashes when both pybind11 and NumPy headers are included
993* Added conversions for additional exception types
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100994* Documentation improvements (using multiple extension modules, smart pointers,
995 other minor clarifications)
Wenzel Jakob61587162016-01-18 22:38:52 +0100996* unified infrastructure for parsing variadic arguments in ``class_`` and cpp_function
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100997* Fixed license text (was: ZLIB, should have been: 3-clause BSD)
998* Python 3.2 compatibility
Wenzel Jakobcd4e6ae2016-01-29 11:48:40 +0100999* Fixed remaining issues when accessing types in another plugin module
1000* Added enum comparison and casting methods
1001* Improved SFINAE-based detection of whether types are copy-constructible
1002* Eliminated many warnings about unused variables and the use of ``offsetof()``
Wenzel Jakob8ed28082016-02-07 17:32:37 +01001003* Support for ``std::array<>`` conversions
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +01001004
10051.1 (December 7, 2015)
1006--------------------------
1007
1008* Documentation improvements (GIL, wrapping functions, casting, fixed many typos)
1009* Generalized conversion of integer types
1010* Improved support for casting function objects
1011* Improved support for ``std::shared_ptr<>`` conversions
1012* Initial support for ``std::set<>`` conversions
1013* Fixed type resolution issue for types defined in a separate plugin module
1014* Cmake build system improvements
1015* Factored out generic functionality to non-templated code (smaller code size)
1016* Added a code size / compile time benchmark vs Boost.Python
1017* Added an appveyor CI script
1018
10191.0 (October 15, 2015)
1020------------------------
1021* Initial release