blob: b4eecab587e9a3b0ed8cdb60dbbfa8430229bba5 [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
12* TBD
13
Dean Moldovan7939f4b2017-09-04 13:49:19 +020014v2.2.1 (Not yet released)
15-----------------------------------------------------
16
17* Fixed a regression where the ``py::keep_alive`` policy could not be applied
18 to constructors. `#1065 <https://github.com/pybind/pybind11/pull/1065>`_.
19
Dean Moldovan00b8f362017-09-04 23:46:11 +020020* Relax overly strict ``py::picke()`` check for matching get and set types.
21 `#1064 <https://github.com/pybind/pybind11/pull/1064>`_.
22
Wenzel Jakob2a5a5ec2017-08-31 13:58:24 +020023v2.2.0 (August 31, 2017)
Wenzel Jakobd405b1b2017-03-22 22:20:07 +010024-----------------------------------------------------
25
Dean Moldovandb46a892017-08-13 22:25:15 +020026* Support for embedding the Python interpreter. See the
27 :doc:`documentation page </advanced/embedding>` for a
28 full overview of the new features.
29 `#774 <https://github.com/pybind/pybind11/pull/774>`_,
30 `#889 <https://github.com/pybind/pybind11/pull/889>`_,
31 `#892 <https://github.com/pybind/pybind11/pull/892>`_,
32 `#920 <https://github.com/pybind/pybind11/pull/920>`_.
33
34 .. code-block:: cpp
35
36 #include <pybind11/embed.h>
37 namespace py = pybind11;
38
39 int main() {
40 py::scoped_interpreter guard{}; // start the interpreter and keep it alive
41
42 py::print("Hello, World!"); // use the Python API
43 }
44
45* Support for inheriting from multiple C++ bases in Python.
46 `#693 <https://github.com/pybind/pybind11/pull/693>`_.
47
48 .. code-block:: python
49
50 from cpp_module import CppBase1, CppBase2
51
52 class PyDerived(CppBase1, CppBase2):
53 def __init__(self):
54 CppBase1.__init__(self) # C++ bases must be initialized explicitly
55 CppBase2.__init__(self)
56
57* ``PYBIND11_MODULE`` is now the preferred way to create module entry points.
58 ``PYBIND11_PLUGIN`` is deprecated. See :ref:`macros` for details.
59 `#879 <https://github.com/pybind/pybind11/pull/879>`_.
60
61 .. code-block:: cpp
62
63 // new
64 PYBIND11_MODULE(example, m) {
65 m.def("add", [](int a, int b) { return a + b; });
66 }
67
68 // old
69 PYBIND11_PLUGIN(example) {
70 py::module m("example");
71 m.def("add", [](int a, int b) { return a + b; });
72 return m.ptr();
73 }
74
75* pybind11's headers and build system now more strictly enforce hidden symbol
76 visibility for extension modules. This should be seamless for most users,
Dean Moldovan1fb9df62017-08-18 19:26:49 +020077 but see the :doc:`upgrade` if you use a custom build system.
78 `#995 <https://github.com/pybind/pybind11/pull/995>`_.
Dean Moldovandb46a892017-08-13 22:25:15 +020079
80* Support for ``py::module_local`` types which allow multiple modules to
81 export the same C++ types without conflicts. This is useful for opaque
82 types like ``std::vector<int>``. ``py::bind_vector`` and ``py::bind_map``
83 now default to ``py::module_local`` if their elements are builtins or
84 local types. See :ref:`module_local` for details.
85 `#949 <https://github.com/pybind/pybind11/pull/949>`_,
86 `#981 <https://github.com/pybind/pybind11/pull/981>`_,
87 `#995 <https://github.com/pybind/pybind11/pull/995>`_,
88 `#997 <https://github.com/pybind/pybind11/pull/997>`_.
89
90* Custom constructors can now be added very easily using lambdas or factory
91 functions which return a class instance by value, pointer or holder. This
92 supersedes the old placement-new ``__init__`` technique.
93 See :ref:`custom_constructors` for details.
Dean Moldovan4c540442017-08-30 21:53:08 +020094 `#805 <https://github.com/pybind/pybind11/pull/805>`_,
95 `#1014 <https://github.com/pybind/pybind11/pull/1014>`_.
Dean Moldovandb46a892017-08-13 22:25:15 +020096
97 .. code-block:: cpp
98
99 struct Example {
100 Example(std::string);
101 };
102
103 py::class_<Example>(m, "Example")
104 .def(py::init<std::string>()) // existing constructor
105 .def(py::init([](int n) { // custom constructor
106 return std::make_unique<Example>(std::to_string(n));
107 }));
108
Dean Moldovan1e5a7da2017-08-24 01:53:15 +0200109* Similarly to custom constructors, pickling support functions are now bound
110 using the ``py::pickle()`` adaptor which improves type safety. See the
111 :doc:`upgrade` and :ref:`pickling` for details.
112 `#1038 <https://github.com/pybind/pybind11/pull/1038>`_.
113
Dean Moldovandb46a892017-08-13 22:25:15 +0200114* Builtin support for converting C++17 standard library types and general
115 conversion improvements:
116
117 1. C++17 ``std::variant`` is supported right out of the box. C++11/14
118 equivalents (e.g. ``boost::variant``) can also be added with a simple
119 user-defined specialization. See :ref:`cpp17_container_casters` for details.
120 `#811 <https://github.com/pybind/pybind11/pull/811>`_,
121 `#845 <https://github.com/pybind/pybind11/pull/845>`_,
122 `#989 <https://github.com/pybind/pybind11/pull/989>`_.
123
124 2. Out-of-the-box support for C++17 ``std::string_view``.
125 `#906 <https://github.com/pybind/pybind11/pull/906>`_.
126
127 3. Improved compatibility of the builtin ``optional`` converter.
128 `#874 <https://github.com/pybind/pybind11/pull/874>`_.
129
130 4. The ``bool`` converter now accepts ``numpy.bool_`` and types which
131 define ``__bool__`` (Python 3.x) or ``__nonzero__`` (Python 2.7).
132 `#925 <https://github.com/pybind/pybind11/pull/925>`_.
133
134 5. C++-to-Python casters are now more efficient and move elements out
135 of rvalue containers whenever possible.
136 `#851 <https://github.com/pybind/pybind11/pull/851>`_,
137 `#936 <https://github.com/pybind/pybind11/pull/936>`_,
138 `#938 <https://github.com/pybind/pybind11/pull/938>`_.
139
140 6. Fixed ``bytes`` to ``std::string/char*`` conversion on Python 3.
141 `#817 <https://github.com/pybind/pybind11/pull/817>`_.
142
143 7. Fixed lifetime of temporary C++ objects created in Python-to-C++ conversions.
144 `#924 <https://github.com/pybind/pybind11/pull/924>`_.
145
Henry Schreiner8b405052017-08-24 17:12:43 -0700146* Scope guard call policy for RAII types, e.g. ``py::call_guard<py::gil_scoped_release>()``,
147 ``py::call_guard<py::scoped_ostream_redirect>()``. See :ref:`call_policies` for details.
Dean Moldovandb46a892017-08-13 22:25:15 +0200148 `#740 <https://github.com/pybind/pybind11/pull/740>`_.
149
Henry Schreiner8b405052017-08-24 17:12:43 -0700150* Utility for redirecting C++ streams to Python (e.g. ``std::cout`` ->
151 ``sys.stdout``). Scope guard ``py::scoped_ostream_redirect`` in C++ and
152 a context manager in Python. See :ref:`ostream_redirect`.
153 `#1009 <https://github.com/pybind/pybind11/pull/1009>`_.
154
Dean Moldovandb46a892017-08-13 22:25:15 +0200155* Improved handling of types and exceptions across module boundaries.
156 `#915 <https://github.com/pybind/pybind11/pull/915>`_,
157 `#951 <https://github.com/pybind/pybind11/pull/951>`_,
158 `#995 <https://github.com/pybind/pybind11/pull/995>`_.
159
160* Fixed destruction order of ``py::keep_alive`` nurse/patient objects
161 in reference cycles.
162 `#856 <https://github.com/pybind/pybind11/pull/856>`_.
163
164* Numpy and buffer protocol related improvements:
165
166 1. Support for negative strides in Python buffer objects/numpy arrays. This
167 required changing integers from unsigned to signed for the related C++ APIs.
168 Note: If you have compiler warnings enabled, you may notice some new conversion
169 warnings after upgrading. These can be resolved with ``static_cast``.
170 `#782 <https://github.com/pybind/pybind11/pull/782>`_.
171
172 2. Support ``std::complex`` and arrays inside ``PYBIND11_NUMPY_DTYPE``.
173 `#831 <https://github.com/pybind/pybind11/pull/831>`_,
174 `#832 <https://github.com/pybind/pybind11/pull/832>`_.
175
176 3. Support for constructing ``py::buffer_info`` and ``py::arrays`` using
177 arbitrary containers or iterators instead of requiring a ``std::vector``.
178 `#788 <https://github.com/pybind/pybind11/pull/788>`_,
179 `#822 <https://github.com/pybind/pybind11/pull/822>`_,
180 `#860 <https://github.com/pybind/pybind11/pull/860>`_.
181
182 4. Explicitly check numpy version and require >= 1.7.0.
183 `#819 <https://github.com/pybind/pybind11/pull/819>`_.
184
185* Support for allowing/prohibiting ``None`` for specific arguments and improved
186 ``None`` overload resolution order. See :ref:`none_arguments` for details.
187 `#843 <https://github.com/pybind/pybind11/pull/843>`_.
188 `#859 <https://github.com/pybind/pybind11/pull/859>`_.
189
190* Added ``py::exec()`` as a shortcut for ``py::eval<py::eval_statements>()``
191 and support for C++11 raw string literals as input. See :ref:`eval`.
192 `#766 <https://github.com/pybind/pybind11/pull/766>`_,
193 `#827 <https://github.com/pybind/pybind11/pull/827>`_.
194
195* ``py::vectorize()`` ignores non-vectorizable arguments and supports
196 member functions.
197 `#762 <https://github.com/pybind/pybind11/pull/762>`_.
198
199* Support for bound methods as callbacks (``pybind11/functional.h``).
200 `#815 <https://github.com/pybind/pybind11/pull/815>`_.
201
202* Allow aliasing pybind11 methods: ``cls.attr("foo") = cls.attr("bar")``.
203 `#802 <https://github.com/pybind/pybind11/pull/802>`_.
204
205* Don't allow mixed static/non-static overloads.
206 `#804 <https://github.com/pybind/pybind11/pull/804>`_.
207
208* Fixed overriding static properties in derived classes.
209 `#784 <https://github.com/pybind/pybind11/pull/784>`_.
210
Dean Moldovan4c540442017-08-30 21:53:08 +0200211* Improved deduction of member functions of a derived class when its bases
212 aren't registered with pybind11.
Dean Moldovandb46a892017-08-13 22:25:15 +0200213 `#855 <https://github.com/pybind/pybind11/pull/855>`_.
214
215 .. code-block:: cpp
216
217 struct Base {
218 int foo() { return 42; }
219 }
220
221 struct Derived : Base {}
222
223 // Now works, but previously required also binding `Base`
224 py::class_<Derived>(m, "Derived")
225 .def("foo", &Derived::foo); // function is actually from `Base`
226
Wenzel Jakobb12a9d62017-08-23 16:30:56 +0200227* The implementation of ``py::init<>`` now uses C++11 brace initialization
228 syntax to construct instances, which permits binding implicit constructors of
229 aggregate types. `#1015 <https://github.com/pybind/pybind11/pull/1015>`_.
230
231 .. code-block:: cpp
232
233 struct Aggregate {
234 int a;
235 std::string b;
236 };
237
238 py::class_<Aggregate>(m, "Aggregate")
239 .def(py::init<int, const std::string &>());
240
Dean Moldovandb46a892017-08-13 22:25:15 +0200241* Fixed issues with multiple inheritance with offset base/derived pointers.
242 `#812 <https://github.com/pybind/pybind11/pull/812>`_,
243 `#866 <https://github.com/pybind/pybind11/pull/866>`_,
244 `#960 <https://github.com/pybind/pybind11/pull/960>`_.
245
Dean Moldovan4c540442017-08-30 21:53:08 +0200246* Fixed reference leak of type objects.
247 `#1030 <https://github.com/pybind/pybind11/pull/1030>`_.
248
Dean Moldovandb46a892017-08-13 22:25:15 +0200249* Improved support for the ``/std:c++14`` and ``/std:c++latest`` modes
250 on MSVC 2017.
251 `#841 <https://github.com/pybind/pybind11/pull/841>`_,
252 `#999 <https://github.com/pybind/pybind11/pull/999>`_.
253
254* Fixed detection of private operator new on MSVC.
255 `#893 <https://github.com/pybind/pybind11/pull/893>`_,
256 `#918 <https://github.com/pybind/pybind11/pull/918>`_.
257
258* Intel C++ compiler compatibility fixes.
259 `#937 <https://github.com/pybind/pybind11/pull/937>`_.
260
261* Fixed implicit conversion of `py::enum_` to integer types on Python 2.7.
262 `#821 <https://github.com/pybind/pybind11/pull/821>`_.
263
Bruce Merry37de2da2017-08-30 14:22:00 +0200264* Added ``py::hash`` to fetch the hash value of Python objects, and
265 ``.def(hash(py::self))`` to provide the C++ ``std::hash`` as the Python
266 ``__hash__`` method.
267 `#1034 <https://github.com/pybind/pybind11/pull/1034>`_.
268
Dean Moldovandb46a892017-08-13 22:25:15 +0200269* Fixed ``__truediv__`` on Python 2 and ``__itruediv__`` on Python 3.
270 `#867 <https://github.com/pybind/pybind11/pull/867>`_.
271
272* ``py::capsule`` objects now support the ``name`` attribute. This is useful
273 for interfacing with ``scipy.LowLevelCallable``.
274 `#902 <https://github.com/pybind/pybind11/pull/902>`_.
275
276* Fixed ``py::make_iterator``'s ``__next__()`` for past-the-end calls.
277 `#897 <https://github.com/pybind/pybind11/pull/897>`_.
278
279* Added ``error_already_set::matches()`` for checking Python exceptions.
280 `#772 <https://github.com/pybind/pybind11/pull/772>`_.
281
282* Deprecated ``py::error_already_set::clear()``. It's no longer needed
283 following a simplification of the ``py::error_already_set`` class.
284 `#954 <https://github.com/pybind/pybind11/pull/954>`_.
285
286* Deprecated ``py::handle::operator==()`` in favor of ``py::handle::is()``
287 `#825 <https://github.com/pybind/pybind11/pull/825>`_.
288
289* Deprecated ``py::object::borrowed``/``py::object::stolen``.
290 Use ``py::object::borrowed_t{}``/``py::object::stolen_t{}`` instead.
291 `#771 <https://github.com/pybind/pybind11/pull/771>`_.
292
Dean Moldovan4c540442017-08-30 21:53:08 +0200293* Changed internal data structure versioning to avoid conflicts between
294 modules compiled with different revisions of pybind11.
295 `#1012 <https://github.com/pybind/pybind11/pull/1012>`_.
296
Dean Moldovandb46a892017-08-13 22:25:15 +0200297* Additional compile-time and run-time error checking and more informative messages.
298 `#786 <https://github.com/pybind/pybind11/pull/786>`_,
299 `#794 <https://github.com/pybind/pybind11/pull/794>`_,
300 `#803 <https://github.com/pybind/pybind11/pull/803>`_.
301
302* Various minor improvements and fixes.
303 `#764 <https://github.com/pybind/pybind11/pull/764>`_,
304 `#791 <https://github.com/pybind/pybind11/pull/791>`_,
305 `#795 <https://github.com/pybind/pybind11/pull/795>`_,
306 `#840 <https://github.com/pybind/pybind11/pull/840>`_,
307 `#844 <https://github.com/pybind/pybind11/pull/844>`_,
308 `#846 <https://github.com/pybind/pybind11/pull/846>`_,
309 `#849 <https://github.com/pybind/pybind11/pull/849>`_,
310 `#858 <https://github.com/pybind/pybind11/pull/858>`_,
311 `#862 <https://github.com/pybind/pybind11/pull/862>`_,
312 `#871 <https://github.com/pybind/pybind11/pull/871>`_,
313 `#872 <https://github.com/pybind/pybind11/pull/872>`_,
314 `#881 <https://github.com/pybind/pybind11/pull/881>`_,
315 `#888 <https://github.com/pybind/pybind11/pull/888>`_,
316 `#899 <https://github.com/pybind/pybind11/pull/899>`_,
317 `#928 <https://github.com/pybind/pybind11/pull/928>`_,
318 `#931 <https://github.com/pybind/pybind11/pull/931>`_,
319 `#944 <https://github.com/pybind/pybind11/pull/944>`_,
320 `#950 <https://github.com/pybind/pybind11/pull/950>`_,
321 `#952 <https://github.com/pybind/pybind11/pull/952>`_,
322 `#962 <https://github.com/pybind/pybind11/pull/962>`_,
323 `#965 <https://github.com/pybind/pybind11/pull/965>`_,
324 `#970 <https://github.com/pybind/pybind11/pull/970>`_,
Dean Moldovandb46a892017-08-13 22:25:15 +0200325 `#978 <https://github.com/pybind/pybind11/pull/978>`_,
Dean Moldovan4c540442017-08-30 21:53:08 +0200326 `#979 <https://github.com/pybind/pybind11/pull/979>`_,
Wenzel Jakoba1041192017-08-28 16:35:32 +0200327 `#986 <https://github.com/pybind/pybind11/pull/986>`_,
Dean Moldovan4c540442017-08-30 21:53:08 +0200328 `#1020 <https://github.com/pybind/pybind11/pull/1020>`_,
329 `#1027 <https://github.com/pybind/pybind11/pull/1027>`_,
Wenzel Jakoba1041192017-08-28 16:35:32 +0200330 `#1037 <https://github.com/pybind/pybind11/pull/1037>`_.
Dean Moldovandb46a892017-08-13 22:25:15 +0200331
332* Testing improvements.
333 `#798 <https://github.com/pybind/pybind11/pull/798>`_,
334 `#882 <https://github.com/pybind/pybind11/pull/882>`_,
335 `#898 <https://github.com/pybind/pybind11/pull/898>`_,
336 `#900 <https://github.com/pybind/pybind11/pull/900>`_,
337 `#921 <https://github.com/pybind/pybind11/pull/921>`_,
338 `#923 <https://github.com/pybind/pybind11/pull/923>`_,
339 `#963 <https://github.com/pybind/pybind11/pull/963>`_.
340
Wenzel Jakobdb200952017-04-07 02:03:46 +0200341v2.1.1 (April 7, 2017)
342-----------------------------------------------------
343
344* Fixed minimum version requirement for MSVC 2015u3
345 `#773 <https://github.com/pybind/pybind11/pull/773>`_.
346
Wenzel Jakobd405b1b2017-03-22 22:20:07 +0100347v2.1.0 (March 22, 2017)
Wenzel Jakoba9730be2017-01-06 14:18:44 +0100348-----------------------------------------------------
349
Wenzel Jakob62e5fef2017-03-22 22:07:45 +0100350* pybind11 now performs function overload resolution in two phases. The first
351 phase only considers exact type matches, while the second allows for implicit
352 conversions to take place. A special ``noconvert()`` syntax can be used to
353 completely disable implicit conversions for specific arguments.
354 `#643 <https://github.com/pybind/pybind11/pull/643>`_,
355 `#634 <https://github.com/pybind/pybind11/pull/634>`_,
356 `#650 <https://github.com/pybind/pybind11/pull/650>`_.
357
358* Fixed a regression where static properties no longer worked with classes
359 using multiple inheritance. The ``py::metaclass`` attribute is no longer
360 necessary (and deprecated as of this release) when binding classes with
361 static properties.
362 `#679 <https://github.com/pybind/pybind11/pull/679>`_,
363
364* Classes bound using ``pybind11`` can now use custom metaclasses.
365 `#679 <https://github.com/pybind/pybind11/pull/679>`_,
366
367* ``py::args`` and ``py::kwargs`` can now be mixed with other positional
368 arguments when binding functions using pybind11.
369 `#611 <https://github.com/pybind/pybind11/pull/611>`_.
370
371* Improved support for C++11 unicode string and character types; added
372 extensive documentation regarding pybind11's string conversion behavior.
373 `#624 <https://github.com/pybind/pybind11/pull/624>`_,
374 `#636 <https://github.com/pybind/pybind11/pull/636>`_,
375 `#715 <https://github.com/pybind/pybind11/pull/715>`_.
376
377* pybind11 can now avoid expensive copies when converting Eigen arrays to NumPy
378 arrays (and vice versa). `#610 <https://github.com/pybind/pybind11/pull/610>`_.
379
380* The "fast path" in ``py::vectorize`` now works for any full-size group of C or
381 F-contiguous arrays. The non-fast path is also faster since it no longer performs
382 copies of the input arguments (except when type conversions are necessary).
383 `#610 <https://github.com/pybind/pybind11/pull/610>`_.
384
385* Added fast, unchecked access to NumPy arrays via a proxy object.
386 `#746 <https://github.com/pybind/pybind11/pull/746>`_.
387
Wenzel Jakob0d929382017-03-22 22:52:29 +0100388* Transparent support for class-specific ``operator new`` and
Wenzel Jakob62e5fef2017-03-22 22:07:45 +0100389 ``operator delete`` implementations.
390 `#755 <https://github.com/pybind/pybind11/pull/755>`_.
391
392* Slimmer and more efficient STL-compatible iterator interface for sequence types.
393 `#662 <https://github.com/pybind/pybind11/pull/662>`_.
394
395* Improved custom holder type support.
396 `#607 <https://github.com/pybind/pybind11/pull/607>`_.
397
398* ``nullptr`` to ``None`` conversion fixed in various builtin type casters.
399 `#732 <https://github.com/pybind/pybind11/pull/732>`_.
400
401* ``enum_`` now exposes its members via a special ``__members__`` attribute.
402 `#666 <https://github.com/pybind/pybind11/pull/666>`_.
403
404* ``std::vector`` bindings created using ``stl_bind.h`` can now optionally
405 implement the buffer protocol. `#488 <https://github.com/pybind/pybind11/pull/488>`_.
406
407* Automated C++ reference documentation using doxygen and breathe.
408 `#598 <https://github.com/pybind/pybind11/pull/598>`_.
409
410* Added minimum compiler version assertions.
411 `#727 <https://github.com/pybind/pybind11/pull/727>`_.
412
413* Improved compatibility with C++1z.
414 `#677 <https://github.com/pybind/pybind11/pull/677>`_.
415
416* Improved ``py::capsule`` API. Can be used to implement cleanup
417 callbacks that are involved at module destruction time.
418 `#752 <https://github.com/pybind/pybind11/pull/752>`_.
419
420* Various minor improvements and fixes.
421 `#595 <https://github.com/pybind/pybind11/pull/595>`_,
422 `#588 <https://github.com/pybind/pybind11/pull/588>`_,
423 `#589 <https://github.com/pybind/pybind11/pull/589>`_,
424 `#603 <https://github.com/pybind/pybind11/pull/603>`_,
425 `#619 <https://github.com/pybind/pybind11/pull/619>`_,
426 `#648 <https://github.com/pybind/pybind11/pull/648>`_,
427 `#695 <https://github.com/pybind/pybind11/pull/695>`_,
428 `#720 <https://github.com/pybind/pybind11/pull/720>`_,
429 `#723 <https://github.com/pybind/pybind11/pull/723>`_,
430 `#729 <https://github.com/pybind/pybind11/pull/729>`_,
431 `#724 <https://github.com/pybind/pybind11/pull/724>`_,
432 `#742 <https://github.com/pybind/pybind11/pull/742>`_,
433 `#753 <https://github.com/pybind/pybind11/pull/753>`_.
Wenzel Jakoba9730be2017-01-06 14:18:44 +0100434
Wenzel Jakobf8dafe92017-01-04 15:09:49 +0100435v2.0.1 (Jan 4, 2017)
436-----------------------------------------------------
437
438* Fix pointer to reference error in type_caster on MSVC
439 `#583 <https://github.com/pybind/pybind11/pull/583>`_.
440
441* Fixed a segmentation in the test suite due to a typo
442 `cd7eac <https://github.com/pybind/pybind11/commit/cd7eac>`_.
443
Wenzel Jakobe33ef9c2017-01-01 13:55:06 +0100444v2.0.0 (Jan 1, 2017)
Wenzel Jakobed52f462016-12-26 13:18:26 +0100445-----------------------------------------------------
446
447* Fixed a reference counting regression affecting types with custom metaclasses
448 (introduced in v2.0.0-rc1).
449 `#571 <https://github.com/pybind/pybind11/pull/571>`_.
450
451* Quenched a CMake policy warning.
452 `#570 <https://github.com/pybind/pybind11/pull/570>`_.
453
Wenzel Jakobe33ef9c2017-01-01 13:55:06 +0100454v2.0.0-rc1 (Dec 23, 2016)
Wenzel Jakobf88af0c2016-06-22 13:52:31 +0200455-----------------------------------------------------
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200456
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100457The pybind11 developers are excited to issue a release candidate of pybind11
458with a subsequent v2.0.0 release planned in early January next year.
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200459
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100460An incredible amount of effort by went into pybind11 over the last ~5 months,
461leading to a release that is jam-packed with exciting new features and numerous
Wenzel Jakobf8dafe92017-01-04 15:09:49 +0100462usability improvements. The following list links PRs or individual commits
Wenzel Jakobed52f462016-12-26 13:18:26 +0100463whenever applicable.
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100464
465Happy Christmas!
466
467* Support for binding C++ class hierarchies that make use of multiple
468 inheritance. `#410 <https://github.com/pybind/pybind11/pull/410>`_.
469
470* PyPy support: pybind11 now supports nightly builds of PyPy and will
471 interoperate with the future 5.7 release. No code changes are necessary,
472 everything "just" works as usual. Note that we only target the Python 2.7
473 branch for now; support for 3.x will be added once its ``cpyext`` extension
Wenzel Jakobed52f462016-12-26 13:18:26 +0100474 support catches up. A few minor features remain unsupported for the time
475 being (notably dynamic attributes in custom types).
476 `#527 <https://github.com/pybind/pybind11/pull/527>`_.
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100477
478* Significant work on the documentation -- in particular, the monolitic
479 ``advanced.rst`` file was restructured into a easier to read hierarchical
480 organization. `#448 <https://github.com/pybind/pybind11/pull/448>`_.
481
482* Many NumPy-related improvements:
483
484 1. Object-oriented API to access and modify NumPy ``ndarray`` instances,
485 replicating much of the corresponding NumPy C API functionality.
486 `#402 <https://github.com/pybind/pybind11/pull/402>`_.
487
488 2. NumPy array ``dtype`` array descriptors are now first-class citizens and
489 are exposed via a new class ``py::dtype``.
490
491 3. Structured dtypes can be registered using the ``PYBIND11_NUMPY_DTYPE()``
492 macro. Special ``array`` constructors accepting dtype objects were also
493 added.
494
495 One potential caveat involving this change: format descriptor strings
496 should now be accessed via ``format_descriptor::format()`` (however, for
497 compatibility purposes, the old syntax ``format_descriptor::value`` will
498 still work for non-structured data types). `#308
499 <https://github.com/pybind/pybind11/pull/308>`_.
500
501 4. Further improvements to support structured dtypes throughout the system.
502 `#472 <https://github.com/pybind/pybind11/pull/472>`_,
503 `#474 <https://github.com/pybind/pybind11/pull/474>`_,
504 `#459 <https://github.com/pybind/pybind11/pull/459>`_,
505 `#453 <https://github.com/pybind/pybind11/pull/453>`_,
506 `#452 <https://github.com/pybind/pybind11/pull/452>`_, and
507 `#505 <https://github.com/pybind/pybind11/pull/505>`_.
508
509 5. Fast access operators. `#497 <https://github.com/pybind/pybind11/pull/497>`_.
510
511 6. Constructors for arrays whose storage is owned by another object.
512 `#440 <https://github.com/pybind/pybind11/pull/440>`_.
513
514 7. Added constructors for ``array`` and ``array_t`` explicitly accepting shape
515 and strides; if strides are not provided, they are deduced assuming
516 C-contiguity. Also added simplified constructors for 1-dimensional case.
517
518 8. Added buffer/NumPy support for ``char[N]`` and ``std::array<char, N>`` types.
519
520 9. Added ``memoryview`` wrapper type which is constructible from ``buffer_info``.
521
522* Eigen: many additional conversions and support for non-contiguous
523 arrays/slices.
524 `#427 <https://github.com/pybind/pybind11/pull/427>`_,
525 `#315 <https://github.com/pybind/pybind11/pull/315>`_,
526 `#316 <https://github.com/pybind/pybind11/pull/316>`_,
527 `#312 <https://github.com/pybind/pybind11/pull/312>`_, and
528 `#267 <https://github.com/pybind/pybind11/pull/267>`_
529
530* Incompatible changes in ``class_<...>::class_()``:
531
532 1. Declarations of types that provide access via the buffer protocol must
533 now include the ``py::buffer_protocol()`` annotation as an argument to
534 the ``class_`` constructor.
535
536 2. Declarations of types that require a custom metaclass (i.e. all classes
537 which include static properties via commands such as
538 ``def_readwrite_static()``) must now include the ``py::metaclass()``
539 annotation as an argument to the ``class_`` constructor.
540
541 These two changes were necessary to make type definitions in pybind11
542 future-proof, and to support PyPy via its cpyext mechanism. `#527
543 <https://github.com/pybind/pybind11/pull/527>`_.
544
545
546 3. This version of pybind11 uses a redesigned mechnism for instantiating
547 trempoline classes that are used to override virtual methods from within
548 Python. This led to the following user-visible syntax change: instead of
549
550 .. code-block:: cpp
551
552 py::class_<TrampolineClass>("MyClass")
553 .alias<MyClass>()
554 ....
555
556 write
557
558 .. code-block:: cpp
559
560 py::class_<MyClass, TrampolineClass>("MyClass")
561 ....
562
563 Importantly, both the original and the trampoline class are now
564 specified as an arguments (in arbitrary order) to the ``py::class_``
565 template, and the ``alias<..>()`` call is gone. The new scheme has zero
566 overhead in cases when Python doesn't override any functions of the
567 underlying C++ class. `rev. 86d825
568 <https://github.com/pybind/pybind11/commit/86d825>`_.
569
Wenzel Jakobe6b2f752016-07-10 10:54:46 +0200570* Added ``eval`` and ``eval_file`` functions for evaluating expressions and
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100571 statements from a string or file. `rev. 0d3fc3
572 <https://github.com/pybind/pybind11/commit/0d3fc3>`_.
573
574* pybind11 can now create types with a modifiable dictionary.
575 `#437 <https://github.com/pybind/pybind11/pull/437>`_ and
576 `#444 <https://github.com/pybind/pybind11/pull/444>`_.
577
578* Support for translation of arbitrary C++ exceptions to Python counterparts.
579 `#296 <https://github.com/pybind/pybind11/pull/296>`_ and
580 `#273 <https://github.com/pybind/pybind11/pull/273>`_.
581
582* Report full backtraces through mixed C++/Python code, better reporting for
583 import errors, fixed GIL management in exception processing.
584 `#537 <https://github.com/pybind/pybind11/pull/537>`_,
585 `#494 <https://github.com/pybind/pybind11/pull/494>`_,
586 `rev. e72d95 <https://github.com/pybind/pybind11/commit/e72d95>`_, and
587 `rev. 099d6e <https://github.com/pybind/pybind11/commit/099d6e>`_.
588
589* Support for bit-level operations, comparisons, and serialization of C++
590 enumerations. `#503 <https://github.com/pybind/pybind11/pull/503>`_,
591 `#508 <https://github.com/pybind/pybind11/pull/508>`_,
592 `#380 <https://github.com/pybind/pybind11/pull/380>`_,
593 `#309 <https://github.com/pybind/pybind11/pull/309>`_.
594 `#311 <https://github.com/pybind/pybind11/pull/311>`_.
595
596* The ``class_`` constructor now accepts its template arguments in any order.
597 `#385 <https://github.com/pybind/pybind11/pull/385>`_.
598
599* Attribute and item accessors now have a more complete interface which makes
600 it possible to chain attributes as in
601 ``obj.attr("a")[key].attr("b").attr("method")(1, 2, 3)``. `#425
602 <https://github.com/pybind/pybind11/pull/425>`_.
603
604* Major redesign of the default and conversion constructors in ``pytypes.h``.
605 `#464 <https://github.com/pybind/pybind11/pull/464>`_.
606
607* Added built-in support for ``std::shared_ptr`` holder type. It is no longer
608 necessary to to include a declaration of the form
609 ``PYBIND11_DECLARE_HOLDER_TYPE(T, std::shared_ptr<T>)`` (though continuing to
610 do so won't cause an error).
611 `#454 <https://github.com/pybind/pybind11/pull/454>`_.
612
613* New ``py::overload_cast`` casting operator to select among multiple possible
614 overloads of a function. An example:
615
616 .. code-block:: cpp
617
618 py::class_<Pet>(m, "Pet")
619 .def("set", py::overload_cast<int>(&Pet::set), "Set the pet's age")
620 .def("set", py::overload_cast<const std::string &>(&Pet::set), "Set the pet's name");
621
622 This feature only works on C++14-capable compilers.
623 `#541 <https://github.com/pybind/pybind11/pull/541>`_.
624
625* C++ types are automatically cast to Python types, e.g. when assigning
626 them as an attribute. For instance, the following is now legal:
627
628 .. code-block:: cpp
629
630 py::module m = /* ... */
631 m.attr("constant") = 123;
632
633 (Previously, a ``py::cast`` call was necessary to avoid a compilation error.)
634 `#551 <https://github.com/pybind/pybind11/pull/551>`_.
635
636* Redesigned ``pytest``-based test suite. `#321 <https://github.com/pybind/pybind11/pull/321>`_.
637
638* Instance tracking to detect reference leaks in test suite. `#324 <https://github.com/pybind/pybind11/pull/324>`_
639
640* pybind11 can now distinguish between multiple different instances that are
641 located at the same memory address, but which have different types.
642 `#329 <https://github.com/pybind/pybind11/pull/329>`_.
643
644* Improved logic in ``move`` return value policy.
645 `#510 <https://github.com/pybind/pybind11/pull/510>`_,
646 `#297 <https://github.com/pybind/pybind11/pull/297>`_.
647
648* Generalized unpacking API to permit calling Python functions from C++ using
649 notation such as ``foo(a1, a2, *args, "ka"_a=1, "kb"_a=2, **kwargs)``. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
650
651* ``py::print()`` function whose behavior matches that of the native Python
652 ``print()`` function. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
653
654* Added ``py::dict`` keyword constructor:``auto d = dict("number"_a=42,
655 "name"_a="World");``. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
656
657* Added ``py::str::format()`` method and ``_s`` literal: ``py::str s = "1 + 2
658 = {}"_s.format(3);``. `#372 <https://github.com/pybind/pybind11/pull/372>`_.
659
660* Added ``py::repr()`` function which is equivalent to Python's builtin
661 ``repr()``. `#333 <https://github.com/pybind/pybind11/pull/333>`_.
662
663* Improved construction and destruction logic for holder types. It is now
664 possible to reference instances with smart pointer holder types without
665 constructing the holder if desired. The ``PYBIND11_DECLARE_HOLDER_TYPE``
666 macro now accepts an optional second parameter to indicate whether the holder
667 type uses intrusive reference counting.
668 `#533 <https://github.com/pybind/pybind11/pull/533>`_ and
669 `#561 <https://github.com/pybind/pybind11/pull/561>`_.
670
671* Mapping a stateless C++ function to Python and back is now "for free" (i.e.
672 no extra indirections or argument conversion overheads). `rev. 954b79
673 <https://github.com/pybind/pybind11/commit/954b79>`_.
674
675* Bindings for ``std::valarray<T>``.
676 `#545 <https://github.com/pybind/pybind11/pull/545>`_.
677
678* Improved support for C++17 capable compilers.
679 `#562 <https://github.com/pybind/pybind11/pull/562>`_.
680
681* Bindings for ``std::optional<t>``.
682 `#475 <https://github.com/pybind/pybind11/pull/475>`_,
683 `#476 <https://github.com/pybind/pybind11/pull/476>`_,
684 `#479 <https://github.com/pybind/pybind11/pull/479>`_,
685 `#499 <https://github.com/pybind/pybind11/pull/499>`_, and
686 `#501 <https://github.com/pybind/pybind11/pull/501>`_.
687
688* ``stl_bind.h``: general improvements and support for ``std::map`` and
689 ``std::unordered_map``.
690 `#490 <https://github.com/pybind/pybind11/pull/490>`_,
691 `#282 <https://github.com/pybind/pybind11/pull/282>`_,
692 `#235 <https://github.com/pybind/pybind11/pull/235>`_.
693
694* The ``std::tuple``, ``std::pair``, ``std::list``, and ``std::vector`` type
695 casters now accept any Python sequence type as input. `rev. 107285
696 <https://github.com/pybind/pybind11/commit/107285>`_.
697
698* Improved CMake Python detection on multi-architecture Linux.
699 `#532 <https://github.com/pybind/pybind11/pull/532>`_.
700
701* Infrastructure to selectively disable or enable parts of the automatically
702 generated docstrings. `#486 <https://github.com/pybind/pybind11/pull/486>`_.
703
704* ``reference`` and ``reference_internal`` are now the default return value
705 properties for static and non-static properties, respectively. `#473
706 <https://github.com/pybind/pybind11/pull/473>`_. (the previous defaults
707 were ``automatic``). `#473 <https://github.com/pybind/pybind11/pull/473>`_.
708
709* Support for ``std::unique_ptr`` with non-default deleters or no deleter at
710 all (``py::nodelete``). `#384 <https://github.com/pybind/pybind11/pull/384>`_.
711
Wenzel Jakob3c796712016-12-23 16:19:36 +0100712* Deprecated ``handle::call()`` method. The new syntax to call Python
713 functions is simply ``handle()``. It can also be invoked explicitly via
Wenzel Jakobd3549d62016-12-23 16:01:04 +0100714 ``handle::operator<X>()``, where ``X`` is an optional return value policy.
715
716* Print more informative error messages when ``make_tuple()`` or ``cast()``
717 fail. `#262 <https://github.com/pybind/pybind11/pull/262>`_.
718
719* Creation of holder types for classes deriving from
720 ``std::enable_shared_from_this<>`` now also works for ``const`` values.
721 `#260 <https://github.com/pybind/pybind11/pull/260>`_.
722
723* ``make_iterator()`` improvements for better compatibility with various
724 types (now uses prefix increment operator); it now also accepts iterators
725 with different begin/end types as long as they are equality comparable.
726 `#247 <https://github.com/pybind/pybind11/pull/247>`_.
727
728* ``arg()`` now accepts a wider range of argument types for default values.
729 `#244 <https://github.com/pybind/pybind11/pull/244>`_.
730
731* Support ``keep_alive`` where the nurse object may be ``None``. `#341
732 <https://github.com/pybind/pybind11/pull/341>`_.
733
734* Added constructors for ``str`` and ``bytes`` from zero-terminated char
735 pointers, and from char pointers and length. Added constructors for ``str``
736 from ``bytes`` and for ``bytes`` from ``str``, which will perform UTF-8
737 decoding/encoding as required.
738
739* Many other improvements of library internals without user-visible changes
740
Wenzel Jakoba720a602016-07-12 18:02:13 +0200741
7421.8.1 (July 12, 2016)
743----------------------
Wenzel Jakobc47d4982016-07-11 23:40:28 +0200744* Fixed a rare but potentially very severe issue when the garbage collector ran
745 during pybind11 type creation.
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200746
Wenzel Jakobf9502152016-06-14 15:00:46 +02007471.8.0 (June 14, 2016)
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200748----------------------
749* Redesigned CMake build system which exports a convenient
750 ``pybind11_add_module`` function to parent projects.
751* ``std::vector<>`` type bindings analogous to Boost.Python's ``indexing_suite``
752* Transparent conversion of sparse and dense Eigen matrices and vectors (``eigen.h``)
753* Added an ``ExtraFlags`` template argument to the NumPy ``array_t<>`` wrapper
754 to disable an enforced cast that may lose precision, e.g. to create overloads
755 for different precisions and complex vs real-valued matrices.
Wenzel Jakob3f200fa2016-05-17 15:35:29 +0200756* Prevent implicit conversion of floating point values to integral types in
757 function arguments
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200758* Fixed incorrect default return value policy for functions returning a shared
759 pointer
Wenzel Jakob38d8b8c2016-05-31 09:53:28 +0200760* Don't allow registering a type via ``class_`` twice
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200761* Don't allow casting a ``None`` value into a C++ lvalue reference
762* Fixed a crash in ``enum_::operator==`` that was triggered by the ``help()`` command
763* Improved detection of whether or not custom C++ types can be copy/move-constructed
764* Extended ``str`` type to also work with ``bytes`` instances
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200765* Added a ``"name"_a`` user defined string literal that is equivalent to ``py::arg("name")``.
766* When specifying function arguments via ``py::arg``, the test that verifies
767 the number of arguments now runs at compile time.
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200768* Added ``[[noreturn]]`` attribute to ``pybind11_fail()`` to quench some
769 compiler warnings
Wenzel Jakob86d825f2016-05-26 13:19:27 +0200770* List function arguments in exception text when the dispatch code cannot find
771 a matching overload
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200772* Added ``PYBIND11_OVERLOAD_NAME`` and ``PYBIND11_OVERLOAD_PURE_NAME`` macros which
Wenzel Jakobf9502152016-06-14 15:00:46 +0200773 can be used to override virtual methods whose name differs in C++ and Python
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200774 (e.g. ``__call__`` and ``operator()``)
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200775* Various minor ``iterator`` and ``make_iterator()`` improvements
Wenzel Jakob86d825f2016-05-26 13:19:27 +0200776* Transparently support ``__bool__`` on Python 2.x and Python 3.x
777* Fixed issue with destructor of unpickled object not being called
Wenzel Jakob163ac2e2016-05-03 14:16:18 +0200778* Minor CMake build system improvements on Windows
Wenzel Jakob86d825f2016-05-26 13:19:27 +0200779* New ``pybind11::args`` and ``pybind11::kwargs`` types to create functions which
780 take an arbitrary number of arguments and keyword arguments
781* New syntax to call a Python function from C++ using ``*args`` and ``*kwargs``
Wenzel Jakob1cbe7ef2016-06-14 14:55:10 +0200782* The functions ``def_property_*`` now correctly process docstring arguments (these
783 formerly caused a segmentation fault)
784* Many ``mkdoc.py`` improvements (enumerations, template arguments, ``DOC()``
785 macro accepts more arguments)
786* Cygwin support
787* Documentation improvements (pickling support, ``keep_alive``, macro usage)
Wenzel Jakobc4d7ccd2016-04-30 22:00:44 +0200788
Wenzel Jakobe70b2ab2016-04-30 19:58:33 +02007891.7 (April 30, 2016)
Wenzel Jakobbb79d7b2016-04-21 12:23:20 +0200790----------------------
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200791* Added a new ``move`` return value policy that triggers C++11 move semantics.
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200792 The automatic return value policy falls back to this case whenever a rvalue
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200793 reference is encountered
Wenzel Jakobe84f5572016-04-26 23:19:19 +0200794* Significantly more general GIL state routines that are used instead of
795 Python's troublesome ``PyGILState_Ensure`` and ``PyGILState_Release`` API
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200796* Redesign of opaque types that drastically simplifies their usage
Wenzel Jakobe70b2ab2016-04-30 19:58:33 +0200797* Extended ability to pass values of type ``[const] void *``
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200798* ``keep_alive`` fix: don't fail when there is no patient
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200799* ``functional.h``: acquire the GIL before calling a Python function
Wenzel Jakob1ac22e32016-04-25 23:25:40 +0200800* Added Python RAII type wrappers ``none`` and ``iterable``
801* Added ``*args`` and ``*kwargs`` pass-through parameters to
802 ``pybind11.get_include()`` function
Wenzel Jakobdd7ec342016-04-29 10:06:24 +0200803* Iterator improvements and fixes
804* Documentation on return value policies and opaque types improved
Wenzel Jakobbb79d7b2016-04-21 12:23:20 +0200805
Wenzel Jakobe70b2ab2016-04-30 19:58:33 +02008061.6 (April 30, 2016)
807----------------------
808* Skipped due to upload to PyPI gone wrong and inability to recover
809 (https://github.com/pypa/packaging-problems/issues/74)
810
Wenzel Jakobbb79d7b2016-04-21 12:23:20 +02008111.5 (April 21, 2016)
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200812----------------------
Wenzel Jakobc79dbe42016-04-17 21:54:31 +0200813* For polymorphic types, use RTTI to try to return the closest type registered with pybind11
Wenzel Jakobd7efa4f2016-04-13 13:45:09 +0200814* Pickling support for serializing and unserializing C++ instances to a byte stream in Python
Wenzel Jakobb2825952016-04-13 23:33:00 +0200815* Added a convenience routine ``make_iterator()`` which turns a range indicated
816 by a pair of C++ iterators into a iterable Python object
817* Added ``len()`` and a variadic ``make_tuple()`` function
Wenzel Jakobb2b44a92016-04-15 17:50:40 +0200818* Addressed a rare issue that could confuse the current virtual function
819 dispatcher and another that could lead to crashes in multi-threaded
820 applications
Wenzel Jakobb2825952016-04-13 23:33:00 +0200821* Added a ``get_include()`` function to the Python module that returns the path
822 of the directory containing the installed pybind11 header files
Wenzel Jakob1c329aa2016-04-13 02:37:36 +0200823* Documentation improvements: import issues, symbol visibility, pickling, limitations
Wenzel Jakobdbe43ff2016-04-21 12:21:14 +0200824* Added casting support for ``std::reference_wrapper<>``
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200825
Wenzel Jakob33c2a042016-04-07 09:06:49 +02008261.4 (April 7, 2016)
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100827--------------------------
Wenzel Jakob81dfd2c2016-03-08 19:40:32 +0100828* Transparent type conversion for ``std::wstring`` and ``wchar_t``
Wenzel Jakob0e6ca592016-04-07 08:49:37 +0200829* Allow passing ``nullptr``-valued strings
Wenzel Jakob34116732016-04-06 17:55:41 +0200830* Transparent passing of ``void *`` pointers using capsules
Wenzel Jakob0e6ca592016-04-07 08:49:37 +0200831* Transparent support for returning values wrapped in ``std::unique_ptr<>``
Wenzel Jakob4e455dd2016-03-09 16:38:28 +0100832* Improved docstring generation for compatibility with Sphinx
Wenzel Jakob34116732016-04-06 17:55:41 +0200833* Nicer debug error message when default parameter construction fails
834* Support for "opaque" types that bypass the transparent conversion layer for STL containers
835* Redesigned type casting interface to avoid ambiguities that could occasionally cause compiler errors
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200836* Redesigned property implementation; fixes crashes due to an unfortunate default return value policy
Wenzel Jakob4e455dd2016-03-09 16:38:28 +0100837* Anaconda package generation support
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100838
8391.3 (March 8, 2016)
Wenzel Jakob8ed28082016-02-07 17:32:37 +0100840--------------------------
Wenzel Jakobcf2b87a2016-02-22 17:32:44 +0100841
842* Added support for the Intel C++ compiler (v15+)
843* Added support for the STL unordered set/map data structures
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100844* Added support for the STL linked list data structure
Wenzel Jakobcf2b87a2016-02-22 17:32:44 +0100845* NumPy-style broadcasting support in ``pybind11::vectorize``
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200846* pybind11 now displays more verbose error messages when ``arg::operator=()`` fails
Wenzel Jakobd2385e82016-03-08 18:04:43 +0100847* pybind11 internal data structures now live in a version-dependent namespace to avoid ABI issues
848* Many, many bugfixes involving corner cases and advanced usage
Wenzel Jakob8ed28082016-02-07 17:32:37 +0100849
8501.2 (February 7, 2016)
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100851--------------------------
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100852
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100853* Optional: efficient generation of function signatures at compile time using C++14
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100854* Switched to a simpler and more general way of dealing with function default
855 arguments. Unused keyword arguments in function calls are now detected and
856 cause errors as expected
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100857* New ``keep_alive`` call policy analogous to Boost.Python's ``with_custodian_and_ward``
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100858* New ``pybind11::base<>`` attribute to indicate a subclass relationship
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100859* Improved interface for RAII type wrappers in ``pytypes.h``
860* Use RAII type wrappers consistently within pybind11 itself. This
861 fixes various potential refcount leaks when exceptions occur
Wenzel Jakob2c5d5602016-04-11 18:46:11 +0200862* Added new ``bytes`` RAII type wrapper (maps to ``string`` in Python 2.7)
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100863* Made handle and related RAII classes const correct, using them more
864 consistently everywhere now
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100865* Got rid of the ugly ``__pybind11__`` attributes on the Python side---they are
866 now stored in a C++ hash table that is not visible in Python
867* Fixed refcount leaks involving NumPy arrays and bound functions
868* Vastly improved handling of shared/smart pointers
869* Removed an unnecessary copy operation in ``pybind11::vectorize``
870* Fixed naming clashes when both pybind11 and NumPy headers are included
871* Added conversions for additional exception types
Wenzel Jakob48548ea2016-01-17 22:36:44 +0100872* Documentation improvements (using multiple extension modules, smart pointers,
873 other minor clarifications)
Wenzel Jakob61587162016-01-18 22:38:52 +0100874* unified infrastructure for parsing variadic arguments in ``class_`` and cpp_function
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100875* Fixed license text (was: ZLIB, should have been: 3-clause BSD)
876* Python 3.2 compatibility
Wenzel Jakobcd4e6ae2016-01-29 11:48:40 +0100877* Fixed remaining issues when accessing types in another plugin module
878* Added enum comparison and casting methods
879* Improved SFINAE-based detection of whether types are copy-constructible
880* Eliminated many warnings about unused variables and the use of ``offsetof()``
Wenzel Jakob8ed28082016-02-07 17:32:37 +0100881* Support for ``std::array<>`` conversions
Wenzel Jakob1ae77fe2016-01-17 22:36:43 +0100882
8831.1 (December 7, 2015)
884--------------------------
885
886* Documentation improvements (GIL, wrapping functions, casting, fixed many typos)
887* Generalized conversion of integer types
888* Improved support for casting function objects
889* Improved support for ``std::shared_ptr<>`` conversions
890* Initial support for ``std::set<>`` conversions
891* Fixed type resolution issue for types defined in a separate plugin module
892* Cmake build system improvements
893* Factored out generic functionality to non-templated code (smaller code size)
894* Added a code size / compile time benchmark vs Boost.Python
895* Added an appveyor CI script
896
8971.0 (October 15, 2015)
898------------------------
899* Initial release