mirror of
https://github.com/asherkin/accelerator.git
synced 2025-12-06 18:08:30 +00:00
* overhaul the repository add protobuf change repo url try to restore github python syntax highlighter move breakpad into third_party, update packagescript * AMBuildifying remove unnecessary files Move the git patching into ambuild move lss to a patch Add windows compilation support remove breakpad.bat move postlink libs * Overhaul CI (#4) * Dockerbuild (#5) * make cwd_cmd spew stdout and stderr * add proper docker build support * Overhaul ci (#6) * Setup CI * fix checkout * fix yaml syntax * no fail fast * setup CI cache * Fix pip install * remove pip git * update actions, ditch node 16 * small syntax cleanups * more CI changes * github doc lied --------- Co-authored-by: Kenzzer <kenzzer@users.noreply.github.com> * final push for perfect dockerbuilds in every scenario that i have been able to find * rename cicd->dockerbuild --------- Co-authored-by: Kenzzer <kenzzer@users.noreply.github.com> * Add readme, remode duplicate -fPIC update names of dockerbuild folder in sh files * cleanup dockerfile (#7) * Update 0002-Write-FUNC-records-instead-of-PUBLIC-for-ELF-symbols.patch * Statically link libz, libgcc & libstdc++ * fix submodule path * Review change + comment patch --------- Co-authored-by: Kenzzer <kenzzer@users.noreply.github.com> Co-authored-by: Benoist <14257866+Kenzzer@users.noreply.github.com>
217 lines
6.2 KiB
Python
217 lines
6.2 KiB
Python
# vim: set ts=2 sw=2 tw=99 noet ft=python:
|
|
import os, sys, shutil
|
|
|
|
def ResolveEnvPath(env, folder=None):
|
|
if env in os.environ:
|
|
path = os.environ[env]
|
|
if os.path.isdir(path):
|
|
return path
|
|
return None
|
|
|
|
if folder:
|
|
head = os.getcwd()
|
|
oldhead = None
|
|
while head != None and head != oldhead:
|
|
path = os.path.join(head, folder)
|
|
if os.path.isdir(path):
|
|
return path
|
|
oldhead = head
|
|
head, tail = os.path.split(head)
|
|
|
|
return None
|
|
|
|
def Normalize(path):
|
|
return os.path.abspath(os.path.normpath(path))
|
|
|
|
class AcceleratorConfig(object):
|
|
def __init__(self):
|
|
self.mms_root = None
|
|
self.sm_root = None
|
|
self.extension = None
|
|
self.libz = None
|
|
self.libbreakpad_client = None
|
|
self.libbreakpad = None
|
|
self.libdisasm = None
|
|
self.breakpad_patch = None
|
|
self.targets = []
|
|
self.target_archs = set()
|
|
self.breakpad_config = dict()
|
|
self.breakpad_patch = None
|
|
|
|
if builder.options.targets:
|
|
target_archs = builder.options.targets.split(',')
|
|
else:
|
|
target_archs = ['x86', 'x86_64']
|
|
|
|
for arch in target_archs:
|
|
try:
|
|
cxx = builder.DetectCxx(target_arch = arch)
|
|
self.target_archs.add(cxx.target.arch)
|
|
except Exception as e:
|
|
if builder.options.targets:
|
|
raise
|
|
print('Skipping target {}: {}'.format(arch, e))
|
|
continue
|
|
self.targets.append(cxx)
|
|
|
|
if not self.targets:
|
|
raise Exception('No suitable C/C++ compiler was found.')
|
|
|
|
@property
|
|
def tag(self):
|
|
if builder.options.debug == '1':
|
|
return 'Debug'
|
|
return 'Release'
|
|
|
|
def retrieve_sm(self):
|
|
if builder.options.sm_path:
|
|
self.sm_root = builder.options.sm_path
|
|
else:
|
|
self.sm_root = ResolveEnvPath('SOURCEMOD', 'sourcemod')
|
|
|
|
if not self.sm_root or not os.path.isdir(self.sm_root):
|
|
raise Exception('Could not find a source copy of SourceMod')
|
|
self.sm_root = Normalize(self.sm_root)
|
|
|
|
def use_auto_versioning(self):
|
|
return not builder.options.disable_auto_versioning
|
|
|
|
def configure_cxx(self, cxx):
|
|
if cxx.like('gcc'):
|
|
self.configure_gcc(cxx)
|
|
elif cxx.family == 'msvc':
|
|
self.configure_msvc(cxx)
|
|
|
|
# Optimization
|
|
if builder.options.opt == '1':
|
|
cxx.defines += ['NDEBUG']
|
|
|
|
# Debugging
|
|
if builder.options.debug == '1':
|
|
cxx.defines += ['DEBUG', '_DEBUG']
|
|
|
|
# Platform-specifics
|
|
if cxx.target.platform == 'linux':
|
|
self.configure_linux(cxx)
|
|
elif cxx.target.platform == 'windows':
|
|
self.configure_windows(cxx)
|
|
|
|
if self.use_auto_versioning():
|
|
cxx.defines += ['GIT_ACTION_BUILD']
|
|
|
|
def configure_gcc(self, cxx):
|
|
cxx.cflags += [
|
|
'-fPIC',
|
|
'-pipe',
|
|
'-fno-strict-aliasing',
|
|
'-fvisibility=hidden',
|
|
'-fvisibility-inlines-hidden',
|
|
'-Wall',
|
|
'-Werror',
|
|
'-msse'
|
|
]
|
|
|
|
cxx.cxxflags += [
|
|
'-std=c++17',
|
|
'-fno-threadsafe-statics',
|
|
'-Wno-non-virtual-dtor',
|
|
'-Wno-overloaded-virtual',
|
|
'-Wno-implicit-exception-spec-mismatch'
|
|
]
|
|
|
|
cxx.postlink += ['-pthread', '-static-libstdc++', '-static-libgcc']
|
|
|
|
if builder.options.opt == '1':
|
|
cxx.cflags += ['-O3']
|
|
return
|
|
|
|
def configure_msvc(self, cxx):
|
|
|
|
cxx.cxxflags += [
|
|
'/EHsc',
|
|
'/std:c++17'
|
|
]
|
|
|
|
return
|
|
|
|
def configure_linux(self, cxx):
|
|
cxx.defines += ['_LINUX', 'POSIX', '_GLIBCXX_USE_CXX11_ABI=0']
|
|
return
|
|
|
|
def configure_windows(self, cxx):
|
|
cxx.defines += ['_WINDOWS']
|
|
if cxx.target.arch == 'x86':
|
|
cxx.defines += ['WIN32']
|
|
elif cxx.target.arch == 'x86_64':
|
|
cxx.defines += ['WIN64']
|
|
return
|
|
|
|
def configure(self):
|
|
self.retrieve_sm()
|
|
|
|
for cxx in self.targets:
|
|
self.configure_cxx(cxx)
|
|
|
|
def configure_extension(self, compiler, context):
|
|
compiler.cxxincludes += [
|
|
os.path.join(context.currentSourcePath),
|
|
os.path.join(self.sm_root, 'public'),
|
|
os.path.join(self.sm_root, 'public', 'extensions'),
|
|
os.path.join(self.sm_root, 'public', 'amtl', 'amtl'),
|
|
os.path.join(self.sm_root, 'public', 'amtl'),
|
|
os.path.join(self.sm_root, 'sourcepawn', 'include')
|
|
]
|
|
|
|
def link_libz(self, compiler, context):
|
|
for task in self.libz:
|
|
if task.target.arch == compiler.target.arch:
|
|
compiler.postlink += [os.path.join(context.buildPath, task.binary.path)]
|
|
compiler.linkdeps += [task.binary]
|
|
return
|
|
raise Exception('No suitable build of libz was found.')
|
|
|
|
def link_libbreakpad_client(self, compiler, context):
|
|
for task in self.libbreakpad_client:
|
|
if task.target.arch == compiler.target.arch:
|
|
compiler.postlink += [os.path.join(context.buildPath, task.binary.path)]
|
|
compiler.linkdeps += [task.binary]
|
|
return
|
|
raise Exception('No suitable build of libbreakpad_client was found.')
|
|
|
|
def link_libbreakpad(self, compiler, context):
|
|
for task in self.libbreakpad:
|
|
if task.target.arch == compiler.target.arch:
|
|
compiler.postlink += [os.path.join(context.buildPath, task.binary.path)]
|
|
compiler.linkdeps += [task.binary]
|
|
return
|
|
raise Exception('No suitable build of libbreakpad was found.')
|
|
|
|
def link_libdisasm(self, compiler, context):
|
|
for task in self.libdisasm:
|
|
if task.target.arch == compiler.target.arch:
|
|
compiler.postlink += [os.path.join(context.buildPath, task.binary.path)]
|
|
compiler.linkdeps += [task.binary]
|
|
return
|
|
raise Exception('No suitable build of libdisasm was found.')
|
|
|
|
def ConfigureLibrary(self, project, compiler, context):
|
|
binary = project.Configure(compiler, project.name, '{0} - {1}'.format(self.tag, compiler.target.arch))
|
|
binary.compiler.cxxincludes += [
|
|
os.path.join(context.currentSourcePath)
|
|
]
|
|
return binary
|
|
|
|
def ConfigureExtension(self, project, compiler, context):
|
|
binary = self.ConfigureLibrary(project, compiler, context)
|
|
self.configure_extension(binary.compiler, context)
|
|
return binary
|
|
|
|
Accelerator = AcceleratorConfig()
|
|
Accelerator.configure()
|
|
|
|
builder.Build(['third_party/Patch', 'third_party/Configure', 'third_party/AMBuilder'], { 'Accelerator': Accelerator })
|
|
|
|
BuildScripts = ['extension/AMBuilder', 'buildbot/PackageScript']
|
|
builder.Build(BuildScripts, { 'Accelerator': Accelerator })
|
|
|