Compare commits
1 Commits
cc6f527371
...
272be51bb0
Author | SHA1 | Date | |
---|---|---|---|
272be51bb0
|
@ -33,7 +33,7 @@ class PySide6DependencyAnalyzer:
|
|||||||
"""Находит все Python файлы в директории"""
|
"""Находит все Python файлы в директории"""
|
||||||
python_files = []
|
python_files = []
|
||||||
for root, dirs, files in os.walk(directory):
|
for root, dirs, files in os.walk(directory):
|
||||||
dirs[:] = [d for d in dirs if d not in {'.venv', '__pycache__', '.git', 'node_modules'}]
|
dirs[:] = [d for d in dirs if d not in {'.venv', '__pycache__', '.git'}]
|
||||||
|
|
||||||
for file in files:
|
for file in files:
|
||||||
if file.endswith('.py'):
|
if file.endswith('.py'):
|
||||||
@ -44,27 +44,11 @@ class PySide6DependencyAnalyzer:
|
|||||||
"""Находит все PySide6 библиотеки (.so файлы)"""
|
"""Находит все PySide6 библиотеки (.so файлы)"""
|
||||||
libs = {}
|
libs = {}
|
||||||
|
|
||||||
# Поиск в разных возможных локациях
|
# Поиск в единственной локации
|
||||||
search_paths = [
|
search_path = Path("../.venv/lib/python3.10/site-packages/PySide6")
|
||||||
base_path / "usr/local/lib/python3.10/dist-packages/PySide6",
|
|
||||||
base_path / "usr/local/lib/python3.11/dist-packages/PySide6",
|
|
||||||
base_path / "usr/lib/python3/dist-packages/PySide6",
|
|
||||||
base_path / ".venv/lib/python3.10/site-packages/PySide6",
|
|
||||||
base_path / ".venv/lib/python3.11/site-packages/PySide6",
|
|
||||||
]
|
|
||||||
|
|
||||||
# Также добавляем путь, если PySide6 установлен системно
|
|
||||||
try:
|
|
||||||
import PySide6
|
|
||||||
system_path = Path(PySide6.__file__).parent
|
|
||||||
search_paths.append(system_path)
|
|
||||||
except ImportError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
for search_path in search_paths:
|
|
||||||
if search_path.exists():
|
|
||||||
print(f"Поиск PySide6 библиотек в: {search_path}")
|
print(f"Поиск PySide6 библиотек в: {search_path}")
|
||||||
|
|
||||||
|
if search_path.exists():
|
||||||
# Ищем .so файлы модулей
|
# Ищем .so файлы модулей
|
||||||
for so_file in search_path.glob("Qt*.*.so"):
|
for so_file in search_path.glob("Qt*.*.so"):
|
||||||
module_name = so_file.stem.split('.')[0] # QtCore.abi3.so -> QtCore
|
module_name = so_file.stem.split('.')[0] # QtCore.abi3.so -> QtCore
|
||||||
@ -79,9 +63,6 @@ class PySide6DependencyAnalyzer:
|
|||||||
libs[subdir.name] = so_file
|
libs[subdir.name] = so_file
|
||||||
break
|
break
|
||||||
|
|
||||||
if libs:
|
|
||||||
break
|
|
||||||
|
|
||||||
return libs
|
return libs
|
||||||
|
|
||||||
def analyze_ldd_dependencies(self, lib_path: Path) -> Set[str]:
|
def analyze_ldd_dependencies(self, lib_path: Path) -> Set[str]:
|
||||||
@ -366,13 +347,13 @@ def main():
|
|||||||
print(f"\nПотенциальная экономия места: {results['analysis_summary']['space_saving_potential']}")
|
print(f"\nПотенциальная экономия места: {results['analysis_summary']['space_saving_potential']}")
|
||||||
|
|
||||||
if args.verbose and results['real_dependencies']:
|
if args.verbose and results['real_dependencies']:
|
||||||
print(f"\nРеальные зависимости (ldd):")
|
Devlin(f"\nРеальные зависимости (ldd):")
|
||||||
for module, deps in results['real_dependencies'].items():
|
for module, deps in results['real_dependencies'].items():
|
||||||
if deps:
|
if deps:
|
||||||
print(f" {module} → {', '.join(deps)}")
|
print(f" {module} → {', '.join(deps)}")
|
||||||
|
|
||||||
# Обновляем AppImage рецепт
|
# Обновляем AppImage рецепт
|
||||||
recipe_path = project_path / "../build-aux/AppImageBuilder.yml"
|
recipe_path = Path("../build-aux/AppImageBuilder.yml")
|
||||||
if recipe_path.exists():
|
if recipe_path.exists():
|
||||||
updated_recipe = analyzer.generate_appimage_recipe(results['removable'], recipe_path)
|
updated_recipe = analyzer.generate_appimage_recipe(results['removable'], recipe_path)
|
||||||
if updated_recipe:
|
if updated_recipe:
|
||||||
|
Reference in New Issue
Block a user