diff options
Diffstat (limited to 'engine/SCons/Tool/clangxx.py')
| -rw-r--r-- | engine/SCons/Tool/clangxx.py | 20 | 
1 files changed, 16 insertions, 4 deletions
diff --git a/engine/SCons/Tool/clangxx.py b/engine/SCons/Tool/clangxx.py index 63a9dec..8afda08 100644 --- a/engine/SCons/Tool/clangxx.py +++ b/engine/SCons/Tool/clangxx.py @@ -11,7 +11,7 @@ selection method.  """  # -# Copyright (c) 2001 - 2017 The SCons Foundation +# Copyright (c) 2001 - 2019 The SCons Foundation  #  # Permission is hereby granted, free of charge, to any person obtaining  # a copy of this software and associated documentation files (the @@ -33,7 +33,7 @@ selection method.  # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.  # -# __revision__ = "src/engine/SCons/Tool/clangxx.py 74b2c53bc42290e911b334a6b44f187da698a668 2017/11/14 13:16:53 bdbaddog" +# __revision__ = "src/engine/SCons/Tool/clangxx.py 72ae09dc35ac2626f8ff711d8c4b30b6138e08e3 2019-08-08 14:50:06 bdeegan"  # Based on SCons/Tool/g++.py by Paweł Tomulik 2014 as a separate tool.  # Brought into the SCons mainline by Russel Winder 2017. @@ -46,6 +46,8 @@ import sys  import SCons.Tool  import SCons.Util  import SCons.Tool.cxx +from SCons.Tool.clangCommon import get_clang_install_dirs +  compilers = ['clang++'] @@ -66,15 +68,25 @@ def generate(env):          env['SHOBJSUFFIX'] = '.pic.o'      elif env['PLATFORM'] == 'sunos':          env['SHOBJSUFFIX'] = '.pic.o' +    elif env['PLATFORM'] == 'win32': +        # Ensure that we have a proper path for clang++ +        clangxx = SCons.Tool.find_program_path(env, compilers[0], default_paths=get_clang_install_dirs(env['PLATFORM'])) +        if clangxx: +            clangxx_bin_dir = os.path.dirname(clangxx) +            env.AppendENVPath('PATH', clangxx_bin_dir) +      # determine compiler version      if env['CXX']:          pipe = SCons.Action._subproc(env, [env['CXX'], '--version'],                                       stdin='devnull',                                       stderr='devnull',                                       stdout=subprocess.PIPE) -        if pipe.wait() != 0: return +        if pipe.wait() != 0:  +            return +                  # clang -dumpversion is of no use -        line = pipe.stdout.readline() +        with pipe.stdout: +            line = pipe.stdout.readline()          if sys.version_info[0] > 2:              line = line.decode()          match = re.search(r'clang +version +([0-9]+(?:\.[0-9]+)+)', line)  | 
