3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-10-09 01:11:58 +00:00
yosys/docs/source/yosys_internals
Mohamed Gaber 88be728353
pyosys: rewrite using pybind11
- Rewrite all Python features to use the pybind11 library instead of boost::python.
  Unlike boost::python, pybind11 is a header-only library that is just included by Pyosys code, saving a lot of compile time on wheels.
- Factor out as much "translation" code from the generator into proper C++ files
- Fix running the embedded interpreter not supporting "from pyosys import libyosys as ys" like wheels
- Move Python-related elements to `pyosys` directory at the root of the repo
- Slight shift in bridging semantics:
  - Containers are declared as "opaque types" and are passed by reference to Python - many methods have been implemented to make them feel right at home without the overhead/ambiguity of copying to Python and then copying back after mutation
  - Monitor/Pass use "trampoline" pattern to support virual methods overridable in Python: virtual methods no longer require `py_` prefix
- Create really short test set for pyosys that just exercises basic functionality
2025-10-03 11:54:44 +03:00
..
extending_yosys .github: typos 2025-09-30 11:03:19 +02:00
flow docs: fix verilog frontend internals 2025-08-11 13:34:10 +02:00
formats Docs: Move rtlil_text (back) to appendix 2024-10-15 07:34:52 +13:00
hashing.rst pyosys: rewrite using pybind11 2025-10-03 11:54:44 +03:00
index.rst Docs: Move verilog.rst to using_yosys 2025-08-05 09:53:58 +12:00
techmap.rst Docs: Reflow line length 2024-10-15 07:23:45 +13:00