Cleanup: use type hints for the QtCreator project generator

Also resolve some warnings for project_info.py.
This commit is contained in:
Campbell Barton
2025-01-02 17:06:56 +11:00
parent bb0fd51b3c
commit 0b0fddb614
3 changed files with 32 additions and 23 deletions

View File

@@ -43,8 +43,6 @@ PATHS_EXCLUDE = set(
os.path.join(SOURCE_DIR, p.replace("/", os.sep)) os.path.join(SOURCE_DIR, p.replace("/", os.sep))
for p in for p in
( (
"tools/check_source/clang_array_check.py",
"tools/utils_ide/cmake_qtcreator_project.py",
"release/datafiles/blender_icons_geom.py", # Uses `bpy` too much. "release/datafiles/blender_icons_geom.py", # Uses `bpy` too much.
"tests/utils/bl_run_operators.py", # Uses `bpy` too much. "tests/utils/bl_run_operators.py", # Uses `bpy` too much.
"tests/utils/bl_run_operators_event_simulate.py", # Uses `bpy` too much. "tests/utils/bl_run_operators_event_simulate.py", # Uses `bpy` too much.
@@ -58,6 +56,7 @@ PATHS_EXCLUDE = set(
"tools/check_blender_release/scripts/requests_basic_access.py", "tools/check_blender_release/scripts/requests_basic_access.py",
"tools/check_blender_release/scripts/requests_import.py", "tools/check_blender_release/scripts/requests_import.py",
"tools/check_source/check_descriptions.py", "tools/check_source/check_descriptions.py",
"tools/check_source/clang_array_check.py",
"tools/utils/blend2json.py", "tools/utils/blend2json.py",
"tools/utils/blender_keyconfig_export_permutations.py", "tools/utils/blender_keyconfig_export_permutations.py",
"tools/utils/blender_merge_format_changes.py", "tools/utils/blender_merge_format_changes.py",

View File

@@ -11,18 +11,25 @@ Example Win32 usage:
c:\Python32\python.exe c:\blender_dev\blender\build_files\cmake\cmake_qtcreator_project.py --build-dir c:\blender_dev\cmake_build c:\Python32\python.exe c:\blender_dev\blender\build_files\cmake\cmake_qtcreator_project.py --build-dir c:\blender_dev\cmake_build
""" """
__all__ = (
"main",
)
import argparse
import os import os
import sys
project_name_default = "Unknown"
def quote_define(define): def quote_define(define: str) -> str:
if " " in define.strip(): if " " in define.strip():
return '"%s"' % define return '"%s"' % define
else: else:
return define return define
def create_qtc_project_main(name): def create_qtc_project_main(name: str) -> None:
from project_info import ( from project_info import (
SIMPLE_PROJECTFILE, SIMPLE_PROJECTFILE,
SOURCE_DIR, SOURCE_DIR,
@@ -43,7 +50,7 @@ def create_qtc_project_main(name):
# --- qtcreator specific, simple format # --- qtcreator specific, simple format
if SIMPLE_PROJECTFILE: if SIMPLE_PROJECTFILE:
# --- qtcreator specific, simple format # --- qtcreator specific, simple format
PROJECT_NAME = name or "Blender" PROJECT_NAME = name or project_name_default
FILE_NAME = PROJECT_NAME.lower() FILE_NAME = PROJECT_NAME.lower()
with open(os.path.join(PROJECT_DIR, "%s.files" % FILE_NAME), 'w') as f: with open(os.path.join(PROJECT_DIR, "%s.files" % FILE_NAME), 'w') as f:
f.write("\n".join(files_rel)) f.write("\n".join(files_rel))
@@ -61,18 +68,21 @@ def create_qtc_project_main(name):
with open(qtc_cfg, 'w') as f: with open(qtc_cfg, 'w') as f:
f.write("// ADD PREDEFINED MACROS HERE!\n") f.write("// ADD PREDEFINED MACROS HERE!\n")
else: else:
includes, defines = cmake_advanced_info() if (includes_and_defines := cmake_advanced_info()) is None:
if (includes, defines) == (None, None):
return return
includes, defines = includes_and_defines
# for some reason it doesn't give all internal includes # for some reason it doesn't give all internal includes
includes = list(set(includes) | set(os.path.dirname(f) includes = list(
for f in files_rel if is_c_header(f))) set(includes) | {
os.path.dirname(f)
for f in files_rel if is_c_header(f)
}
)
includes.sort() includes.sort()
# be tricky, get the project name from CMake if we can! # be tricky, get the project name from CMake if we can!
PROJECT_NAME = name or project_name_get() PROJECT_NAME = name or project_name_get() or project_name_default
FILE_NAME = PROJECT_NAME.lower() FILE_NAME = PROJECT_NAME.lower()
with open(os.path.join(PROJECT_DIR, "%s.files" % FILE_NAME), 'w') as f: with open(os.path.join(PROJECT_DIR, "%s.files" % FILE_NAME), 'w') as f:
@@ -97,14 +107,14 @@ def create_qtc_project_main(name):
defines_final = [("#define %s %s" % (item[0], quote_define(item[1]))) for item in defines] defines_final = [("#define %s %s" % (item[0], quote_define(item[1]))) for item in defines]
if os.name != "nt": if os.name != "nt":
defines_final += cmake_compiler_defines() defines_final.extend(cmake_compiler_defines() or [])
f.write("\n".join(defines_final)) f.write("\n".join(defines_final))
print("Blender project file written to: %r" % qtc_prj) print("Blender project file written to: %r" % qtc_prj)
# --- end # --- end
def create_qtc_project_python(name): def create_qtc_project_python(name: str) -> None:
from project_info import ( from project_info import (
SOURCE_DIR, SOURCE_DIR,
# CMAKE_DIR, # CMAKE_DIR,
@@ -120,7 +130,7 @@ def create_qtc_project_python(name):
# --- qtcreator specific, simple format # --- qtcreator specific, simple format
# be tricky, get the project name from git if we can! # be tricky, get the project name from git if we can!
PROJECT_NAME = (name or project_name_get()) + "_Python" PROJECT_NAME = (name or project_name_get() or project_name_default) + "_Python"
FILE_NAME = PROJECT_NAME.lower() FILE_NAME = PROJECT_NAME.lower()
with open(os.path.join(PROJECT_DIR, "%s.files" % FILE_NAME), 'w') as f: with open(os.path.join(PROJECT_DIR, "%s.files" % FILE_NAME), 'w') as f:
@@ -138,8 +148,7 @@ def create_qtc_project_python(name):
print("Python project file written to: %r" % qtc_prj) print("Python project file written to: %r" % qtc_prj)
def argparse_create(): def argparse_create() -> argparse.ArgumentParser:
import argparse
parser = argparse.ArgumentParser( parser = argparse.ArgumentParser(
description="This script generates Qt Creator project files for Blender", description="This script generates Qt Creator project files for Blender",
@@ -164,18 +173,20 @@ def argparse_create():
return parser return parser
def main(): def main() -> int:
parser = argparse_create() parser = argparse_create()
args = parser.parse_args() args = parser.parse_args()
name = args.name name = args.name
import project_info import project_info
if not project_info.init(args.build_dir): if not project_info.init(args.build_dir):
return return 1
create_qtc_project_main(name) create_qtc_project_main(name)
create_qtc_project_python(name) create_qtc_project_python(name)
return 0
if __name__ == "__main__": if __name__ == "__main__":
main() sys.exit(main())

View File

@@ -129,8 +129,7 @@ def is_project_file(filename: str) -> bool:
def cmake_advanced_info() -> ( def cmake_advanced_info() -> (
tuple[list[str], list[tuple[str, str]]] | tuple[list[str], list[tuple[str, str]]] | None
tuple[None, None]
): ):
""" Extract includes and defines from cmake. """ Extract includes and defines from cmake.
""" """
@@ -138,7 +137,7 @@ def cmake_advanced_info() -> (
make_exe = cmake_cache_var("CMAKE_MAKE_PROGRAM") make_exe = cmake_cache_var("CMAKE_MAKE_PROGRAM")
if make_exe is None: if make_exe is None:
print("Make command not found: CMAKE_MAKE_PROGRAM") print("Make command not found: CMAKE_MAKE_PROGRAM")
return None, None return None
make_exe_basename = os.path.basename(make_exe) make_exe_basename = os.path.basename(make_exe)
@@ -164,7 +163,7 @@ def cmake_advanced_info() -> (
if not exists(project_path): if not exists(project_path):
print("Generating Eclipse Project File Failed: %r not found" % project_path) print("Generating Eclipse Project File Failed: %r not found" % project_path)
return None, None return None
from xml.dom.minidom import parse from xml.dom.minidom import parse
tree = parse(project_path) tree = parse(project_path)