1. 26 Apr, 2016 1 commit
  2. 25 Apr, 2016 1 commit
  3. 22 Apr, 2016 1 commit
  4. 14 Apr, 2016 1 commit
  5. 13 Apr, 2016 5 commits
  6. 11 Apr, 2016 1 commit
  7. 07 Apr, 2016 1 commit
  8. 06 Apr, 2016 1 commit
  9. 15 Mar, 2016 1 commit
  10. 06 Mar, 2016 1 commit
  11. 03 Mar, 2016 1 commit
  12. 02 Feb, 2016 1 commit
  13. 18 Jan, 2016 1 commit
  14. 17 Jan, 2016 6 commits
    • Wenzel Jakob's avatar
      general cleanup of the codebase · 48548ea4
      Wenzel Jakob authored
      - new pybind11::base<> attribute to indicate a subclass relationship
      - unified infrastructure for parsing variadic arguments in class_ and cpp_function
      - use 'handle' and 'object' more consistently everywhere
      48548ea4
    • Wenzel Jakob's avatar
      improved handling of shared/smart pointers · b2c2c792
      Wenzel Jakob authored
      Previously, pybind11 required classes using std::shared_ptr<> to derive
      from std::enable_shared_from_this<> (or compilation failures would ensue).
      
      Everything now also works for classes that don't do this, assuming that
      some basic rules are followed (e.g. never passing "raw" pointers of
      instances manged by shared pointers). The safer
      std::enable_shared_from_this<> approach continues to be supported.
      b2c2c792
    • Wenzel Jakob's avatar
    • Wenzel Jakob's avatar
    • Wenzel Jakob's avatar
      2dfbadee
    • Wenzel Jakob's avatar
      moved processing of cpp_function arguments out of dispatch code · 2ac5044a
      Wenzel Jakob authored
      The cpp_function class accepts a variadic argument, which was formerly
      processed twice -- once at registration time, and once in the dispatch
      lambda function. This is not only unnecessarily slow but also leads to
      code bloat since it adds to the object code generated for every bound
      function. This change removes the second pass at dispatch time.
      
      One noteworthy change of this commit is that default arguments are now
      constructed (and converted to Python objects) right at declaration time.
      Consider the following example:
      
      py::class_<MyClass>("MyClass")
          .def("myFunction", py::arg("arg") = SomeType(123));
      
      In this case, the change means that pybind11 must already be set up to
      deal with values of the type 'SomeType', or an exception will be thrown.
      Another change is that the "preview" of the default argument in the
      function signature is generated using the __repr__ special method. If
      it is not available in this type, the signature may not be very helpful,
      i.e.:
      
      |  myFunction(...)
      |      Signature : (MyClass, arg : SomeType = <SomeType object at 0x101b7b080>) -> None
      
      One workaround (other than defining SomeType.__repr__) is to specify the
      human-readable preview of the default argument manually using the more
      cumbersome arg_t notation:
      
      py::class_<MyClass>("MyClass")
          .def("myFunction", py::arg_t<SomeType>("arg", SomeType(123), "SomeType(123)"));
      2ac5044a
  15. 15 Dec, 2015 2 commits
  16. 14 Dec, 2015 3 commits
  17. 07 Dec, 2015 1 commit
  18. 24 Nov, 2015 1 commit
  19. 17 Nov, 2015 1 commit
  20. 19 Oct, 2015 1 commit
  21. 18 Oct, 2015 2 commits
  22. 15 Oct, 2015 2 commits
  23. 13 Oct, 2015 2 commits