1. 24 Jun, 2017 1 commit
  2. 23 Jun, 2017 2 commits
  3. 20 Jun, 2017 1 commit
    • Switch debian docker images to stretch · e067c584
      Debian stretch was just released, so `debian:testing` and
      `debian:stetch` are starting to diverge; this commit keeps the travis-ci
      docker image on stretch for gcc6 and clang3.9.
      
      Debian has also moved gcc 7 from experimental to unstable, so this
      switches the gcc7 build to `sid`.  Once it migrates to `testing` I'll
      switch the gcc 7 build docker image to `testing` and take it out of
      failure-allowed.
      Jason Rhinelander committed
  4. 15 Jun, 2017 2 commits
  5. 14 Jun, 2017 2 commits
    • Make check-style.sh work on stock macOS · d080f833
      ./tools/check-style.sh fails on stock OS X currently; this fixes it:
      
      - use pipes directly rather than exec redirection (macOS's ancient
        version of bash fails with the latter)
      - macOS's ancient bash doesn't support '\e' escapes in `echo -e`;
        replace with \033 instead
      - BSD grep doesn't support GREP_COLORS, but does allow GREP_COLOR.
        Adding both doesn't hurt GNU grep: GREP_COLOR is deprecated, and won't
        be used when GREP_COLORS is set.
      - BSD grep doesn't collapse multiple /'s in the listed filename, so
        failures under `include/` would should up as
        `include//pybind11/whatever.h`.  This removes the / from the include
        directory argument.
      
      Minor other changes:
      - The CRLF detection runs with -l, so GREP_COLORS wasn't doing
        anything; removed it.
      - The trailing whitespace test would trigger on CRLFs, but the CR would
        result in messed up output.  Changed the test to just match trailing
        spaces and tabs, rather than all whitespace.
      Jason Rhinelander committed
    • travis-ci: clang 4.0: install and use ldd-4.0 · 404bcf25
      The clang 4.0/cpp17 build wasn't enabling -flto because the system
      linker didn't like the output generated by clang for some reason.  This
      switches the build to use llvm's lld instead, which lets -flto work
      again (and links considerably faster, too).
      Jason Rhinelander committed
  6. 12 Jun, 2017 2 commits
    • Upgrade pypy to 5.8, use pre-built numpy/scipy wheels · 2cc1916e
      numpy 1.13.0 fails with pypy 5.7.1, so this upgrades to 5.8.0.  I've
      also uploaded pre-built .whl files to imaginary.ca (checked every 4
      hours and rebuilt if needed), and list that as an extra pypi location
      under the pypy pip install to avoid the long travis pypy build times for
      a new release or branch.
      Jason Rhinelander committed
    • Support multiple inheritance from python · e45c2114
      This commit allows multiple inheritance of pybind11 classes from
      Python, e.g.
      
          class MyType(Base1, Base2):
              def __init__(self):
                  Base1.__init__(self)
                  Base2.__init__(self)
      
      where Base1 and Base2 are pybind11-exported classes.
      
      This requires collapsing the various builtin base objects
      (pybind11_object_56, ...) introduced in 2.1 into a single
      pybind11_object of a fixed size; this fixed size object allocates enough
      space to contain either a simple object (one base class & small* holder
      instance), or a pointer to a new allocation that can contain an
      arbitrary number of base classes and holders, with holder size
      unrestricted.
      
      * "small" here means having a sizeof() of at most 2 pointers, which is
      enough to fit unique_ptr (sizeof is 1 ptr) and shared_ptr (sizeof is 2
      ptrs).
      
      To minimize the performance impact, this repurposes
      `internals::registered_types_py` to store a vector of pybind-registered
      base types.  For direct-use pybind types (e.g. the `PyA` for a C++ `A`)
      this is simply storing the same thing as before, but now in a vector;
      for Python-side inherited types, the map lets us avoid having to do a
      base class traversal as long as we've seen the class before.  The
      change to vector is needed for multiple inheritance: Python types
      inheriting from multiple registered bases have one entry per base.
      Jason Rhinelander committed
  7. 10 Jun, 2017 3 commits
  8. 08 Jun, 2017 4 commits
  9. 07 Jun, 2017 2 commits
  10. 06 Jun, 2017 1 commit
    • Explicitly define copy/move constructors for accessor · 91bbe2f2
      `accessor` currently relies on an implicit default copy constructor, but that is deprecated in C++11 when a copy assignment operator is present and can, in some cases, raise deprecation warnings (see #888).  This commit explicitly specifies the default copy constructor and also adds a default move constructor.
      eirrgang committed
  11. 31 May, 2017 1 commit
  12. 30 May, 2017 3 commits
    • std::reference_wrapper: non-generic types; no None · acedd6c7
      This reimplements the std::reference_wrapper<T> caster to be a shell
      around the underlying T caster (rather than assuming T is a generic
      type), which lets it work for things like `std::reference_wrapper<int>`
      or anything else custom type caster with a lvalue cast operator.
      
      This also makes it properly fail when None is provided, just as an
      ordinary lvalue reference argument would similarly fail.
      
      This also adds a static assert to test that T has an appropriate type
      caster.  It triggers for casters like `std::pair`, which have
      return-by-value cast operators.  (In theory this could be supported by
      storing a local temporary for such types, but that's beyond the scope
      of this PR).
      
      This also replaces `automatic` or `take_ownership` return value policies
      with `automatic_reference` as taking ownership of a reference inside a
      reference_wrapper is not valid.
      Jason Rhinelander committed
    • Move reference_wrapper test from test_issues to test_python_types · 7cdf9f1a
      test_issues is deprecated, and the following commit adds other, related
      reference_wrapper tests.
      Jason Rhinelander committed
    • Filter warnings on pytest >= v3.1 · 005fde6a
      The new version of pytest now reports Python warnings by default. This
      commit filters out some third-party extension warnings which are not
      useful for pybind11 tests.
      Dean Moldovan committed
  13. 29 May, 2017 3 commits
    • Replace PYBIND11_PLUGIN with PYBIND11_MODULE · 443ab594
      This commit also adds `doc()` to `object_api` as a shortcut for the
      `attr("__doc__")` accessor.
      
      The module macro changes from:
      ```c++
      PYBIND11_PLUGIN(example) {
          pybind11::module m("example", "pybind11 example plugin");
          m.def("add", [](int a, int b) { return a + b; });
          return m.ptr();
      }
      ```
      
      to:
      
      ```c++
      PYBIND11_MODULE(example, m) {
          m.doc() = "pybind11 example plugin";
          m.def("add", [](int a, int b) { return a + b; });
      }
      ```
      
      Using the old macro results in a deprecation warning. The warning
      actually points to the `pybind11_init` function (since attributes
      don't bind to macros), but the message should be quite clear:
      "PYBIND11_PLUGIN is deprecated, use PYBIND11_MODULE".
      Dean Moldovan committed
    • Convenience constructor templates for buffer_info (#860) · b700c5d6
      * Added template constructors to buffer_info that can deduce the item size, format string, and number of dimensions from the pointer type and the shape container
      
      * Implemented actual buffer_info constructor as private delegate constructor taking rvalue reference as a workaround for the evaluation order move problem on GCC 4.8
      Yannick Jadoul committed
    • Fix buffer protocol inheritance · 427e4afc
      Fixes #878.
      Dean Moldovan committed
  14. 28 May, 2017 5 commits
  15. 27 May, 2017 3 commits
  16. 25 May, 2017 5 commits
    • Fix invalid memory access in vector insert method · eee4f4fc
      The stl_bind.h wrapper for `Vector.insert` neglected to do a bounds
      check.
      Bruce Merry committed
    • Fix quadratic-time behaviour of vector extend · 6a0f6c40
      The "extend" method for vectors defined in stl_bind.h used `reserve` to
      allocate space for the extra growth. While this can sometimes make a
      constant-factor improvement in performance, it can also cause
      construction of a vector by repeated extension to take quadratic rather
      than linear time, as memory is reallocated in small increments rather
      than on an exponential schedule. For example, this Python code would
      take time proportional to the square of the trip count:
      
      ```python
      a = VectorInt([1, 2, 3])
      b = VectorInt()
      for i in range(100000):
          b.extend(a)
      ```
      
      This commit removes the `reserve` call. The alternative would be to try
      to add some smarter heuristics, but the standard library may well have
      its own heuristics (the iterators are random access iterators, so it can
      easily determine the number of items being added) and trying to add more
      heuristics on top of that seems like a bad idea.
      Bruce Merry committed
    • Force MSVC to compile in utf-8 mode · 8dc63ba9
      MSVC by default uses the local codepage, which fails when it sees the
      utf-8 in test_python_types.cpp.  This adds the /utf-8 flag to the test
      suite compilation to force it to interpret source code as utf-8.
      
      Fixes #869
      Jason Rhinelander committed
    • vectorize: pass-through of non-vectorizable args · f3ce00ea
      This extends py::vectorize to automatically pass through
      non-vectorizable arguments.  This removes the need for the documented
      "explicitly exclude an argument" workaround.
      
      Vectorization now applies to arithmetic, std::complex, and POD types,
      passed as plain value or by const lvalue reference (previously only
      pass-by-value types were supported).  Non-const lvalue references and
      any other types are passed through as-is.
      
      Functions with rvalue reference arguments (whether vectorizable or not)
      are explicitly prohibited: an rvalue reference is inherently not
      something that can be passed multiple times and is thus unsuitable to
      being in a vectorized function.
      
      The vectorize returned value is also now more sensitive to inputs:
      previously it would return by value when all inputs are of size 1; this
      is now amended to having all inputs of size 1 *and* 0 dimensions.  Thus
      if you pass in, for example, [[1]], you get back a 1x1, 2D array, while
      previously you got back just the resulting single value.
      
      Vectorization of member function specializations is now also supported
      via `py::vectorize(&Class::method)`; this required passthrough support
      for the initial object pointer on the wrapping function pointer.
      Jason Rhinelander committed
    • array_t: make c_style/f_style work for array creation · 41f8da4a
      Currently if you construct an `array_t<T, array::f_style>` with a shape
      but not strides you get a C-style array; the only way to get F-style
      strides was to calculate the strides manually.  This commit fixes that
      by adding logic to use f_style strides when the flag is set.
      
      This also simplifies the existing c_style stride logic.
      Jason Rhinelander committed