engine: wscript: refactor, use sdl2.py to get configure SDL2, use shared get_subproject_name

This commit is contained in:
Alibek Omarov 2018-12-13 08:03:26 +03:00
parent ec50c4571c
commit 62995b0769

View File

@ -4,10 +4,12 @@
from waflib import Logs from waflib import Logs
import os import os
from fwgslib import get_subproject_name
top = '.' top = '.'
def options(opt): def options(opt):
opt.load('sdl2')
opt.add_option( opt.add_option(
'--enable-bsp2', action = 'store_true', dest = 'SUPPORT_BSP2_FORMAT', default = False, '--enable-bsp2', action = 'store_true', dest = 'SUPPORT_BSP2_FORMAT', default = False,
help = 'build engine with BSP2 map support(recommended for Quake, breaks compability!)') help = 'build engine with BSP2 map support(recommended for Quake, breaks compability!)')
@ -20,47 +22,17 @@ def configure(conf):
conf.env.append_unique('DEFINES', 'SINGLE_BINARY') conf.env.append_unique('DEFINES', 'SINGLE_BINARY')
conf.env.append_unique('DEFINES', 'XASH_DEDICATED') conf.env.append_unique('DEFINES', 'XASH_DEDICATED')
else: else:
# TODO: add way to specify SDL2 path, move to separate function conf.load('sdl2')
try: if not conf.env.HAVE_SDL2:
conf.check_cfg(
path='sdl2-config',
args='--cflags --libs',
package='',
msg='Checking for SDL2',
uselib_store='SDL2')
except conf.errors.ConfigurationError:
if(conf.options.SDL2_PATH):
conf.start_msg('Configuring SDL2 by provided path')
conf.env.HAVE_SDL2 = 1
conf.env.INCLUDES_SDL2 = [
os.path.abspath(os.path.join(conf.options.SDL2_PATH, 'include')),
os.path.abspath(os.path.join(conf.options.SDL2_PATH, 'include/SDL2'))
]
libpath = 'lib'
if(conf.env.COMPILER_CC == 'msvc'):
libpath = 'lib/x86'
conf.env.LIBPATH_SDL2 = [os.path.abspath(os.path.join(conf.options.SDL2_PATH, libpath))]
conf.env.LIB_SDL2 = ['SDL2']
conf.end_msg('yes: {0}, {1}, {2}'.format(conf.env.LIB_SDL2, conf.env.LIBPATH_SDL2, conf.env.INCLUDES_SDL2))
else:
conf.fatal('SDL2 not availiable! If you want to build dedicated server, specify --dedicated') conf.fatal('SDL2 not availiable! If you want to build dedicated server, specify --dedicated')
conf.env.append_unique('DEFINES', 'XASH_SDL') conf.env.append_unique('DEFINES', 'XASH_SDL')
if(conf.options.SUPPORT_BSP2_FORMAT): if conf.options.SUPPORT_BSP2_FORMAT:
conf.env.append_unique('DEFINES', 'SUPPORT_BSP2_FORMAT') conf.env.append_unique('DEFINES', 'SUPPORT_BSP2_FORMAT')
if conf.env.DEST_OS == 'win32': if conf.env.DEST_OS == 'win32':
conf.check( lib='user32' )
conf.check( lib='shell32' )
conf.check( lib='gdi32' )
conf.check( lib='advapi32' )
conf.check( lib='dbghelp' )
conf.check( lib='psapi' )
conf.env.append_unique('DEFINES', 'DBGHELP') conf.env.append_unique('DEFINES', 'DBGHELP')
def get_subproject_name(ctx):
return os.path.basename(os.path.realpath(str(ctx.path)))
def build(bld): def build(bld):
bld.load_envs() bld.load_envs()
bld.env = bld.all_envs[get_subproject_name(bld)] bld.env = bld.all_envs[get_subproject_name(bld)]
@ -98,7 +70,7 @@ def build(bld):
includes = ['common', 'server', 'client', 'client/vgui', '.', '../common', '../pm_shared' ] includes = ['common', 'server', 'client', 'client/vgui', '.', '../common', '../pm_shared' ]
if(bld.env.SINGLE_BINARY): if bld.env.SINGLE_BINARY:
bld( bld(
source = source, source = source,
target = 'xash', target = 'xash',