Update to new recipe system (S++ 2.0).
This commit is contained in:
@@ -1,12 +1,44 @@
|
||||
|
||||
import os
|
||||
import re
|
||||
from SCons.Script import *
|
||||
|
||||
def cook(env: Environment, remote: str = 'github', git_ref: str = 'main') -> dict:
|
||||
if remote == 'mewin':
|
||||
repo = env.GitBranch(repo_name = 'VulkanHeaders_mewin', remote_url = 'https://git.mewin.de/mewin/vulkan-headers.git', git_ref = git_ref)
|
||||
_REPO_NAMES = {
|
||||
'default': 'VulkanHeaders',
|
||||
'mewin': 'VulkanHeaders_mewin'
|
||||
}
|
||||
_REPO_URLS = {
|
||||
'default': 'https://github.com/KhronosGroup/Vulkan-Headers.git',
|
||||
'mewin': 'https://git.mewin.de/mewin/vulkan-headers.git'
|
||||
}
|
||||
_TAG_PATTERN = re.compile(r'^v([0-9]+)\.([0-9]+)\.([0-9]+)$')
|
||||
|
||||
|
||||
def _get_repo_name(env: Environment) -> str:
|
||||
return _REPO_NAMES[env.get('VULKANHEADERS_REMOTE', 'default')]
|
||||
|
||||
def _get_repo_url(env: Environment) -> str:
|
||||
return _REPO_URLS[env.get('VULKANHEADERS_REMOTE', 'default')]
|
||||
|
||||
def versions(env: Environment, update: bool = False):
|
||||
if env.get('VULKANHEADERS_REMOTE') == 'mewin':
|
||||
return [(0, 0, 0)]
|
||||
tags = env.GitTags(repo_name = _get_repo_name(env), remote_url = _get_repo_url(env), force_fetch=update)
|
||||
result = []
|
||||
for tag in tags:
|
||||
match = _TAG_PATTERN.match(tag)
|
||||
if match:
|
||||
result.append((int(match.groups()[0]), int(match.groups()[1]), int(match.groups()[2])))
|
||||
return result
|
||||
|
||||
def dependencies(env: Environment, version) -> 'dict':
|
||||
return {}
|
||||
|
||||
def cook(env: Environment, version) -> dict:
|
||||
if env.get('VULKANHEADERS_REMOTE') == 'mewin':
|
||||
git_ref = 'main'
|
||||
else:
|
||||
repo = env.GitBranch(repo_name = 'VulkanHeaders', remote_url = 'https://github.com/KhronosGroup/Vulkan-Headers.git', git_ref = git_ref)
|
||||
git_ref = f'refs/tags/v{version[0]}.{version[1]}.{version[2]}'
|
||||
repo = env.GitBranch(repo_name = _get_repo_name(env), remote_url = _get_repo_url(env), git_ref = git_ref)
|
||||
checkout_root = repo['checkout_root']
|
||||
return {
|
||||
'CPPPATH': [os.path.join(checkout_root, 'include')]
|
||||
|
||||
Reference in New Issue
Block a user