1. 27 Mar, 2024 4 commits
  2. 26 Mar, 2024 2 commits
    • feat: make `numpy.h` compatible with both NumPy 1.x and 2.x (#5050) · 705efcce
      * API: Make `numpy.h` compatible with both NumPy 1.x and 2.x
      
      * TST: Update numpy dtype flags test to not covert flags to char
      
      * API: Add `numpy2.h` instead and make `numpy.h` safe
      
      This means that users of `numpy.h` cannot be broken, but need to
      update to `numpy2.h` if they want to compile for NumPy 2.
      
      Using Macros simply and didn't bother to try to remove unnecessary
      code paths.
      
      * API: Rather than `numpy2.h` use a define for the user.
      
      * Thread `PYBIND11_NUMPY2_SUPPORT` through things and try to adept test matrix
      
      * Small fixups (shouldn't matter)?
      
      * Fixup.  Does upgrading scipy help?  (it shouldn't?)
      
      (Some other small fixup)
      
      * Use NumPy 2 nightlies for ubuntu-latest job also
      
      * BUG: Fix numpy.bool check
      
      * TST: Fix complexwarning
      
      * BUG: Fix the fact that only the 50 slot is filled with the copy alias
      
      (There were 3 functions all doing the same, only this slot survived 2.x)
      
      * TST: One more test tweak
      
      * TST: Use "long" name for long, since it changed on windows
      
      * TST: Apparently we didn't always have ulong, so just use `L`
      
      * TST: Enforce dtype='l' for test as default isn't long anymore on windows
      
      * Rename macro and invert logic to PYBIND11_NUMPY_1_ONLY
      
      * PYBIND11_INTERNAL_NUMPY_1_ONLY_DETECTED
      
      * Test and code comment expansion
      
      * CI: Use pre-releases of numpy/scipy from pip via explicit version
      
      * CI: NumPy 2 only available on almalinux (as it is Python >=3.9)
      
      * MAINT: Match name more exactly and adopt error phrasing
      
      * MAINT: Pushed early, move helper to be private member
      
      * fix error message compilation when using NumPy 1.x-only backcompat
      
      * silence name shadowing warning
      
      * chore: minor optimization
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      ---------
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Co-authored-by: Ralf W. Grosse-Kunstleve <rwgk@google.com>
      Co-authored-by: Henry Schreiner <henryschreineriii@gmail.com>
      Sebastian Berg committed
    • tests: hide warning on clang (#5069) · e0f2c715
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Henry Schreiner committed
  3. 21 Mar, 2024 3 commits
  4. 14 Feb, 2024 1 commit
  5. 13 Feb, 2024 2 commits
  6. 06 Feb, 2024 1 commit
  7. 28 Jan, 2024 1 commit
    • doc: add litgen to the automatic generators list (compiling.rst) (#5012) · 768cebe1
      * doc: add litgen to the automatic generators list (compiling.rst)
      
      Added this:
      
      [litgen]_ is an automatic python bindings generator with a focus on generating
      documented and discoverable bindings: bindings will nicely reproduce the documentation
      found in headers. It is is based on srcML (srcml.org), a highly scalable, multi-language
      parsing tool with a developer centric approach. The API that you want to expose to python
      must be C++14 compatible (but your implementation can use more modern constructs).
      
      .. [litgen] https://pthom.github.io/litgen
      
      * style: pre-commit fixes
      
      ---------
      
      Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
      Pascal Thomet committed
  8. 17 Jan, 2024 1 commit
  9. 13 Jan, 2024 2 commits
  10. 08 Jan, 2024 1 commit
  11. 02 Jan, 2024 2 commits
  12. 30 Dec, 2023 1 commit
  13. 15 Dec, 2023 3 commits
  14. 14 Dec, 2023 2 commits
    • fix(cmake): upgrade maximum supported CMake version to 3.27 (#4786) · daea1130
      * Upgrade maximum supported CMake version to 3.27 to fix warning with CMP0148 policy (#4785)
      
      * Update `macos_brew_install_llvm` pipeline to use expected Python installation
      
      * Fix `Python_EXECUTABLE` Cmake variable typo
      
      * Apply suggestions from code review
      
      * fix: use FindPython for CMake 3.18+ by default for pybind11's tests
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * tests: fix issues with finding Python
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * tests: also set executable on subdir tests
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * fix(cmake): correct logic for FindPython
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * Update ci.yml
      
      * Revert "Update ci.yml"
      
      This reverts commit 33798adf3f3892ac4b78da8d3d91d3b27611bbe5.
      
      ---------
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Co-authored-by: Henry Schreiner <HenrySchreinerIII@gmail.com>
      Pol Mesalles committed
    • fix: make_static_property_type() (#4971) · 7d538a42
      Update make_static_property_type() to make it compatible with Python
      3.13: set Py_TPFLAGS_MANAGED_DICT flag before calling PyType_Ready().
      Victor Stinner committed
  15. 07 Dec, 2023 1 commit
  16. 05 Dec, 2023 1 commit
  17. 29 Nov, 2023 1 commit
  18. 27 Nov, 2023 1 commit
  19. 16 Nov, 2023 4 commits
    • pybind11.pc: use pcfiledir for relative destinations (#4830) · dc9b3959
      * pybind11.pc: use pcfiledir for relative destinations
      
      If the datarootdir is absolute, just use the absolute path directly.
      However, if it is relative, we can compute the prefix from the location
      of the `.pc` file itself. This allows the install to be relocatable.
      
      * chore: use 3.20's cmake_path if available
      
      * style: pre-commit fixes
      
      * Update CMakeLists.txt
      
      ---------
      
      Co-authored-by: Henry Schreiner <HenrySchreinerIII@gmail.com>
      Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
      Ben Boeckel committed
    • fix(cmake): findpython issues and 3.12 support for pybind11_find_import (#4941) · 9591cfb0
      * fix(cmake): findpython issues and 3.12 support for pybind11_find_import
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * Update pybind11NewTools.cmake
      
      ---------
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Henry Schreiner committed
    • ci: add more versions of numpy/scipy/pypy (#4714) · 6831666f
      * ci: add more versions of numpy/scipy/pypy
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * Apply suggestions from code review
      
      * style: pre-commit fixes
      
      * Update requirements.txt
      
      * Update requirements.txt
      
      * Apply suggestions from code review
      
      ---------
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
      Henry Schreiner committed
    • fix(cmake): avoid really slow compile on emscripten (#4642) · 6cf90e72
      * fix: avoid really slow compile on emscripten
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      
      * Update tools/pybind11Common.cmake
      
      ---------
      
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Henry Schreiner committed
  20. 15 Nov, 2023 1 commit
  21. 08 Nov, 2023 4 commits
    • Fix a long-standing bug in the handling of Python multiple inheritance (#4762) · e250155a
      * Equivalent of https://github.com/google/clif/commit/5718e4d0807fd3b6a8187dde140069120b81ecef
      
      * Resolve clang-tidy errors.
      
      * Moving test_PPCCInit() first changes the behavior!
      
      * Resolve new Clang dev C++11 errors:
      
      ```
      The CXX compiler identification is Clang 17.0.0
      ```
      
      ```
      pytypes.h:1615:23: error: identifier '_s' preceded by whitespace in a literal operator declaration is deprecated [-Werror,-Wdeprecated-literal-operator]
      ```
      
      ```
      cast.h:1380:26: error: identifier '_a' preceded by whitespace in a literal operator declaration is deprecated [-Werror,-Wdeprecated-literal-operator]
      ```
      
      * Resolve gcc 4.8.5 error:
      
      ```
      pytypes.h:1615:12: error: missing space between '""' and suffix identifier
      ```
      
      * Specifically exclude `__clang__`
      
      * Snapshot of debugging code (does NOT pass pre-commit checks).
      
      * Revert "Snapshot of debugging code (does NOT pass pre-commit checks)."
      
      This reverts commit 1d4f9ff2632b32ddcb0dc7ecd0ab7a4ce4c15a4e.
      
      * [ci skip] Order Dependence Demo
      
      * Revert "[ci skip] Order Dependence Demo"
      
      This reverts commit d37b5409d4e5b835620ccbb321a4e1ba89af315c.
      
      * One way to deal with the order dependency issue. This is not the best way, more like a proof of concept.
      
      * Move test_PC() first again.
      
      * Add `all_type_info_add_base_most_derived_first()`, use in `all_type_info_populate()`
      
      * Revert "One way to deal with the order dependency issue. This is not the best way, more like a proof of concept."
      
      This reverts commit eb09c6c1b978208ceee40f05bbe75491b6ff8ad6.
      
      * clang-tidy fixes (automatic)
      
      * Add `is_redundant_value_and_holder()` and use to avoid forcing `__init__` overrides when they are not needed.
      
      * Streamline implementation and avoid unsafe `reinterpret_cast<instance *>()` introduced with PR #2152
      
      The `reinterpret_cast<instance *>(self)` is unsafe if `__new__` is mocked,
      which was actually found in the wild: the mock returned `None` for `self`.
      This was inconsequential because `inst` is currently cast straight back to
      `PyObject *` to compute `all_type_info()`, which is empty if `self` is not
      a pybind11 `instance`, and then `inst` is never dereferenced. However, the
      unsafe detour through `instance *` is easily avoided and the updated
      implementation is less prone to accidents while debugging or refactoring.
      
      * Fix actual undefined behavior exposed by previous changes.
      
      It turns out the previous commit message is incorrect, the `inst` pointer is actually dereferenced, in the `value_and_holder` ctor here:
      
      https://github.com/pybind/pybind11/blob/f3e0602802c7840992c97f4960515777cad6a5c7/include/pybind11/detail/type_caster_base.h#L262-L263
      
      ```
      259     // Main constructor for a found value/holder:
      260     value_and_holder(instance *i, const detail::type_info *type, size_t vpos, size_t index)
      261         : inst{i}, index{index}, type{type},
      262           vh{inst->simple_layout ? inst->simple_value_holder
      263                                  : &inst->nonsimple.values_and_holders[vpos]} {}
      ```
      
      * Add test_mock_new()
      
      * Experiment: specify indirect bases
      
      * Revert "Experiment: specify indirect bases"
      
      This reverts commit 4f90d85f9fc15290d6be54d5ae9417bd131b84d9.
      
      * Add `all_type_info_check_for_divergence()` and some tests.
      
      * Call `all_type_info_check_for_divergence()` also from `type_caster_generic::load_impl<>`
      
      * Resolve clang-tidy error:
      
      ```
      include/pybind11/detail/type_caster_base.h:795:21: error: the 'empty' method should be used to check for emptiness instead of 'size' [readability-container-size-empty,-warnings-as-errors]
                      if (matching_bases.size() != 0) {
                          ^~~~~~~~~~~~~~~~~~~~~~~~~~
                          !matching_bases.empty()
      ```
      
      * Revert "Resolve clang-tidy error:"
      
      This reverts commit df27188dc6d6cf333145755543f56b2f6657aa5e.
      
      * Revert "Call `all_type_info_check_for_divergence()` also from `type_caster_generic::load_impl<>`"
      
      This reverts commit 5f5fd6a68e3cff1726628f6dea8e1c0754636a23.
      
      * Revert "Add `all_type_info_check_for_divergence()` and some tests."
      
      This reverts commit 0a9599f775bfd3ca196c5e23a3fcf2890cbf6e82.
      Ralf W. Grosse-Kunstleve committed
    • chore: move to ruff-format (#4912) · c758b81f
      Signed-off-by: Henry Schreiner <henryschreineriii@gmail.com>
      Co-authored-by: Ralf W. Grosse-Kunstleve <rwgk@google.com>
      Henry Schreiner committed
    • chore(deps): update pre-commit hooks (#4923) · 0a974fed
      updates:
      - [github.com/pre-commit/mirrors-clang-format: v17.0.3 → v17.0.4](https://github.com/pre-commit/mirrors-clang-format/compare/v17.0.3...v17.0.4)
      - [github.com/astral-sh/ruff-pre-commit: v0.1.2 → v0.1.4](https://github.com/astral-sh/ruff-pre-commit/compare/v0.1.2...v0.1.4)
      
      Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
      pre-commit-ci[bot] committed
  22. 05 Nov, 2023 1 commit