def IsExecutingOnWindows(): import sys, os if sys.platform.startswith('win') or os.name == 'nt': return True return False def GetWindowsStdSysEnvVarList(path=False, temp=True, user=True, os=True, shell=True, cpu=True): ret = [] if os: ret += 'OS WINDIR SYSTEMDRIVE SYSTEMROOT ALLUSERSPROFILE Public ProgramData CommonProgramFiles CommonProgramFiles(x86) CommonProgramW6432 ProgramFiles ProgramFiles(x86) ProgramW6432'.split() if cpu: ret += 'NUMBER_OF_PROCESSORS PROCESSOR_ARCHITECTURE PROCESSOR_ARCHITEW6432 PROCESSOR_IDENTIFIER PROCESSOR_LEVEL PROCESSOR_REVISION'.split() if user: ret += 'COMPUTERNAME USERNAME USERPROFILE APPDATA LOCALAPPDATA HOMEDRIVE HOMESHARE HOMEPATH LOGONSERVER USERDNSDOMAIN USERDOMAIN USERDOMAIN_ROAMINGPROFILE ClientName SessionName'.split() if shell: ret += 'COMSPEC PATHEXT PSModulePath'.split() # PROMPT if temp: ret += 'TEMP TMP'.split() if path: ret += 'PATH'.split() return ret def GetPosixStdSysEnvVarList(path=False, temp=True, user=True, os=True, shell=True, cpu=True): ret = [] if os: ret += 'HOSTALIASES'.split() if user: ret += 'HOME USER LOGNAME DATEMSK UID'.split() # XDG_* TZ LANGUAGE LANG LC_* NLSPATH if shell: ret += 'SHELL TERM TERMCAP'.split() if temp: ret += 'TMPDIR'.split() if path: ret += 'PATH MANPATH'.split() return ret def GetStdSysEnvVarList(path=False, temp=True, user=True, os=True, shell=True, cpu=True): func = GetPosixStdSysEnvVarList if IsExecutingOnWindows(): func = GetWindowsStdSysEnvVarList return func(path=path, temp=temp, user=user, os=os, shell=shell, cpu=cpu) def AddAvailableLibs(env, libs): """ Scans through a list of libraries and adds available libraries to the environment. """ conf = env.Configure() for lib in libs: conf.CheckLib(lib) conf.Finish() def AddZLib(env, platform, alias='install-utils'): """ Checks for platform specific zlib and adds the appropriate compiler and linker options to the environment """ zlib = 'z' if platform == 'win32': if 'ZLIB_W32' in env: # Add include and library path of zlib for Win32 env.Append(CPPPATH = env['ZLIB_W32_INC']) env.Append(LIBPATH = env['ZLIB_W32_LIB']) zlib = ['zdll', 'z'] if 'ZLIB_W32_DLL' in env and env['ZLIB_W32_DLL']: env.DistributeW32Bin(env['ZLIB_W32_DLL'], alias=alias) if 'ZLIB_W32_NEW_DLL' in env and env['ZLIB_W32_NEW_DLL']: env.DistributeW32Bin(env['ZLIB_W32_NEW_DLL'], alias=alias) else: print('Please specify folder of zlib for Win32 via ZLIB_W32') Exit(1) # Avoid unnecessary configuring when cleaning targets # and a clash when scons is run in parallel operation. if not env.GetOption('clean'): conf = env.Configure() if not conf.CheckLibWithHeader(zlib, 'zlib.h', 'c'): print('zlib (%s) is missing!' % (platform)) Exit(1) env = conf.Finish() def GetAvailableLibs(env, libs): """ Scans through a list list of libraries and adds available libraries to the environment. """ conf = env.Configure() avail_libs = [] for lib in libs: if conf.CheckLib(lib): avail_libs.append(lib) conf.Finish() return avail_libs def check_compile_flag(ctx, flag): """ Checks if a compiler flag is valid. """ ctx.Message('Checking for compiler flag %s... ' % flag) old_flags = ctx.env['CCFLAGS'] ctx.env.Append(CCFLAGS = [flag]) test = """ int main() { return 0; } """ result = ctx.TryCompile(test, '.c') ctx.Result(result) if not result: ctx.env.Replace(CCFLAGS = [old_flags]) return result def check_link_flag(ctx, flag, run = 0, extension = '.c', code = None): """ Checks if a linker flag is valid. """ ctx.Message('Checking for linker flag %s... ' % flag) old_flags = ctx.env['LINKFLAGS'] ctx.env.Append(LINKFLAGS = [flag]) if code: test = code else: test = """ int main() { return 0; } """ result = ctx.TryLink(test, extension) if run: result = result and ctx.TryRun(test, extension)[0] ctx.Result(result) if not result: ctx.env.Replace(LINKFLAGS = [old_flags]) return result def FlagsConfigure(env): """ Wrapper for env.Configure which adds two new tests: CheckCompileFlag - checks for a compiler flag CheckLinkFlag - checks for a linker flag """ return env.Configure(custom_tests = { 'CheckCompileFlag' : check_compile_flag, 'CheckLinkFlag': check_link_flag }) def GetOptionOrEnv(name, defval = None): """ Get option set on scons command line or in os.environ """ import os #if optenv and name in optenv: # return optenv[name] if name in ARGUMENTS: return ARGUMENTS[name] if name in os.environ: return os.environ[name] return defval import struct def FileUnpackRead(pack, size, f, fpos=None, defval=None): r = defval try: if not fpos is None: f.seek(fpos) r = struct.unpack(pack, f.read(size))[0] finally: return r def ReadU16LE(f, fpos=None, defval=None): return FileUnpackRead("