mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-31 11:42:30 +00:00 
			
		
		
		
	* `misc/__init__.py`: * checks if there's a `yosys-abc` in the same directory - if yes, sets the variable `sys._pyosys_abc` * checks if there's a `share` in the same directory - if yes, sets the variable `sys._pyosys_share_dirname` * `yosys.cc::init_share_dirname`: check for `sys._pyosys_share_dirname`, use it at the highest priority if Python is enabled * `yosys.cc::init_abc_executable_name`: check for `sys._pyosys_abc`, use it at at the highest priority if Python is enabled * `Makefile`: add new target, `share`, to only create the extra targets * `setup.py`: compile libyosys.so, yosys-abc and share, and copy them all as part of the pyosys build * `test/arch/ecp5/add_sub.py`: ported `add_sub.ys` to Python to act as a test for the share directory and abc with Python wheels, used in CI
		
			
				
	
	
		
			19 lines
		
	
	
	
		
			522 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			19 lines
		
	
	
	
		
			522 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| import os
 | |
| import sys
 | |
| 
 | |
| sys.setdlopenflags(os.RTLD_NOW | os.RTLD_GLOBAL)
 | |
| 
 | |
| __dir__ = os.path.abspath(os.path.dirname(__file__))
 | |
| sys._pyosys_dir = os.path.abspath(__dir__)
 | |
| 
 | |
| bin_ext = ".exe" if os.name == "nt" else ""
 | |
| 
 | |
| _share_candidate = os.path.join(__dir__, "share")
 | |
| if os.path.isdir(_share_candidate):
 | |
|     sys._pyosys_share_dirname = _share_candidate + os.path.sep
 | |
| 
 | |
| _abc_candidate = os.path.join(__dir__, f"yosys-abc{bin_ext}")
 | |
| if os.path.isfile(_abc_candidate):
 | |
|     sys._pyosys_abc = _abc_candidate
 | |
| 
 | |
| __all__ = ["libyosys"]
 |