1. 13 Feb, 2024 1 commit
  2. 06 Feb, 2024 1 commit
  3. 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
  4. 17 Jan, 2024 1 commit
  5. 13 Jan, 2024 2 commits
  6. 08 Jan, 2024 1 commit
  7. 02 Jan, 2024 2 commits
  8. 30 Dec, 2023 1 commit
  9. 15 Dec, 2023 3 commits
  10. 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
  11. 07 Dec, 2023 1 commit
  12. 05 Dec, 2023 1 commit
  13. 29 Nov, 2023 1 commit
  14. 27 Nov, 2023 1 commit
  15. 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
  16. 15 Nov, 2023 1 commit
  17. 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
  18. 05 Nov, 2023 1 commit
  19. 04 Nov, 2023 1 commit
  20. 01 Nov, 2023 1 commit
  21. 27 Oct, 2023 3 commits
  22. 24 Oct, 2023 1 commit
  23. 23 Oct, 2023 1 commit
  24. 21 Oct, 2023 1 commit
    • Workaround NVCC parse failure in `cast_op` (#4893) · 3414c56b
      * Workaround NVCC parse failure in `cast_op`
      
      There is a bug in some CUDA versions (observed in CUDA 12.1 and 11.7 w/ GCC 12.2),
      that makes `cast_op` fail to compile:
        `cast.h:45:120: error: expected template-name before ‘<’ token`
      
      Defining the nested type as an alias and using it allows this to work
      without any change in semantics.
      
      Fixes #4606
      
      * style: pre-commit fixes
      
      * Add comments to result_t referencing PR
      
      ---------
      
      Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
      Alexander Grund committed
  25. 20 Oct, 2023 1 commit
  26. 17 Oct, 2023 1 commit
  27. 16 Oct, 2023 1 commit
    • Update pytest to version 7.2.0 (which removes their dependency on py) (#4880) · 0cbd92ba
      * Update pytest (which removes their dependency on py)
      
      The py library through 1.11.0 for Python allows remote attackers to conduct a ReDoS (Regular expression Denial of Service) attack via a Subversion repository with crafted info data, because the InfoSvnCommand argument is mishandled.
      
      The particular codepath in question is the regular expression at py._path.svnurl.InfoSvnCommand.lspattern and is only relevant when dealing with subversion (svn) projects. Notably the codepath is not used in the popular pytest project. The developers of the pytest package have released version 7.2.0 which removes their dependency on py. Users of pytest seeing alerts relating to this advisory may update to version 7.2.0 of pytest to resolve this issue. See https://github.com/pytest-dev/py/issues/287#issuecomment-1290407715 for additional context.
      
      * Added conditions so that we keep using 7.0.0 on python 3.6
      Pablo Speciale committed