diff options
Diffstat (limited to 'build_files/utils/make_utils.py')
-rwxr-xr-x | build_files/utils/make_utils.py | 84 |
1 files changed, 70 insertions, 14 deletions
diff --git a/build_files/utils/make_utils.py b/build_files/utils/make_utils.py index e4c676474b5..564930617ff 100755 --- a/build_files/utils/make_utils.py +++ b/build_files/utils/make_utils.py @@ -9,9 +9,15 @@ import re import shutil import subprocess import sys +from pathlib import Path +from typing import ( + Sequence, + Optional, +) -def call(cmd, exit_on_error=True, silent=False): + +def call(cmd: Sequence[str], exit_on_error: bool = True, silent: bool = False) -> int: if not silent: print(" ".join(cmd)) @@ -29,7 +35,7 @@ def call(cmd, exit_on_error=True, silent=False): return retcode -def check_output(cmd, exit_on_error=True): +def check_output(cmd: Sequence[str], exit_on_error: bool = True) -> str: # Flush to ensure correct order output on Windows. sys.stdout.flush() sys.stderr.flush() @@ -46,14 +52,14 @@ def check_output(cmd, exit_on_error=True): return output.strip() -def git_branch_exists(git_command, branch): +def git_branch_exists(git_command: str, branch: str) -> bool: return ( call([git_command, "rev-parse", "--verify", branch], exit_on_error=False, silent=True) == 0 or call([git_command, "rev-parse", "--verify", "remotes/origin/" + branch], exit_on_error=False, silent=True) == 0 ) -def git_branch(git_command): +def git_branch(git_command: str) -> str: # Get current branch name. try: branch = subprocess.check_output([git_command, "rev-parse", "--abbrev-ref", "HEAD"]) @@ -64,7 +70,7 @@ def git_branch(git_command): return branch.strip().decode('utf8') -def git_tag(git_command): +def git_tag(git_command: str) -> Optional[str]: # Get current tag name. try: tag = subprocess.check_output([git_command, "describe", "--exact-match"], stderr=subprocess.STDOUT) @@ -74,18 +80,19 @@ def git_tag(git_command): return tag.strip().decode('utf8') -def git_branch_release_version(branch, tag): - release_version = re.search("^blender-v(.*)-release$", branch) - if release_version: - release_version = release_version.group(1) +def git_branch_release_version(branch: str, tag: str) -> Optional[str]: + re_match = re.search("^blender-v(.*)-release$", branch) + release_version = None + if re_match: + release_version = re_match.group(1) elif tag: - release_version = re.search(r"^v([0-9]*\.[0-9]*).*", tag) - if release_version: - release_version = release_version.group(1) + re_match = re.search(r"^v([0-9]*\.[0-9]*).*", tag) + if re_match: + release_version = re_match.group(1) return release_version -def svn_libraries_base_url(release_version, branch=None): +def svn_libraries_base_url(release_version: Optional[str], branch: Optional[str] = None) -> str: if release_version: svn_branch = "tags/blender-" + release_version + "-release" elif branch: @@ -95,9 +102,58 @@ def svn_libraries_base_url(release_version, branch=None): return "https://svn.blender.org/svnroot/bf-blender/" + svn_branch + "/lib/" -def command_missing(command): +def command_missing(command: str) -> bool: # Support running with Python 2 for macOS if sys.version_info >= (3, 0): return shutil.which(command) is None else: return False + + +class BlenderVersion: + def __init__(self, version: int, patch: int, cycle: str): + # 293 for 2.93.1 + self.version = version + # 1 for 2.93.1 + self.patch = patch + # 'alpha', 'beta', 'release', maybe others. + self.cycle = cycle + + def is_release(self) -> bool: + return self.cycle == "release" + + def __str__(self) -> str: + """Convert to version string. + + >>> str(BlenderVersion(293, 1, "alpha")) + '2.93.1-alpha' + >>> str(BlenderVersion(327, 0, "release")) + '3.27.0' + """ + version_major = self.version // 100 + version_minor = self.version % 100 + as_string = f"{version_major}.{version_minor}.{self.patch}" + if self.is_release(): + return as_string + return f"{as_string}-{self.cycle}" + + +def parse_blender_version() -> BlenderVersion: + blender_srcdir = Path(__file__).absolute().parent.parent.parent + version_path = blender_srcdir / "source/blender/blenkernel/BKE_blender_version.h" + + version_info = {} + line_re = re.compile(r"^#define (BLENDER_VERSION[A-Z_]*)\s+([0-9a-z]+)$") + + with version_path.open(encoding="utf-8") as version_file: + for line in version_file: + match = line_re.match(line.strip()) + if not match: + continue + version_info[match.group(1)] = match.group(2) + + return BlenderVersion( + int(version_info["BLENDER_VERSION"]), + int(version_info["BLENDER_VERSION_PATCH"]), + version_info["BLENDER_VERSION_CYCLE"], + ) |