| Index: scons-2.0.1/engine/SCons/Tool/MSCommon/sdk.py
|
| ===================================================================
|
| --- scons-2.0.1/engine/SCons/Tool/MSCommon/sdk.py (revision 0)
|
| +++ scons-2.0.1/engine/SCons/Tool/MSCommon/sdk.py (revision 0)
|
| @@ -0,0 +1,391 @@
|
| +#
|
| +# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 The SCons Foundation
|
| +#
|
| +# Permission is hereby granted, free of charge, to any person obtaining
|
| +# a copy of this software and associated documentation files (the
|
| +# "Software"), to deal in the Software without restriction, including
|
| +# without limitation the rights to use, copy, modify, merge, publish,
|
| +# distribute, sublicense, and/or sell copies of the Software, and to
|
| +# permit persons to whom the Software is furnished to do so, subject to
|
| +# the following conditions:
|
| +#
|
| +# The above copyright notice and this permission notice shall be included
|
| +# in all copies or substantial portions of the Software.
|
| +#
|
| +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
| +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
| +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
| +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
| +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
| +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
| +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
| +#
|
| +
|
| +__revision__ = "src/engine/SCons/Tool/MSCommon/sdk.py 5134 2010/08/16 23:02:40 bdeegan"
|
| +
|
| +__doc__ = """Module to detect the Platform/Windows SDK
|
| +
|
| +PSDK 2003 R1 is the earliest version detected.
|
| +"""
|
| +
|
| +import os
|
| +
|
| +import SCons.Errors
|
| +import SCons.Util
|
| +
|
| +import common
|
| +
|
| +debug = common.debug
|
| +
|
| +# SDK Checks. This is of course a mess as everything else on MS platforms. Here
|
| +# is what we do to detect the SDK:
|
| +#
|
| +# For Windows SDK >= 6.0: just look into the registry entries:
|
| +# HKLM\Software\Microsoft\Microsoft SDKs\Windows
|
| +# All the keys in there are the available versions.
|
| +#
|
| +# For Platform SDK before 6.0 (2003 server R1 and R2, etc...), there does not
|
| +# seem to be any sane registry key, so the precise location is hardcoded.
|
| +#
|
| +# For versions below 2003R1, it seems the PSDK is included with Visual Studio?
|
| +#
|
| +# Also, per the following:
|
| +# http://benjamin.smedbergs.us/blog/tag/atl/
|
| +# VC++ Professional comes with the SDK, VC++ Express does not.
|
| +
|
| +# Location of the SDK (checked for 6.1 only)
|
| +_CURINSTALLED_SDK_HKEY_ROOT = \
|
| + r"Software\Microsoft\Microsoft SDKs\Windows\CurrentInstallFolder"
|
| +
|
| +
|
| +class SDKDefinition(object):
|
| + """
|
| + An abstract base class for trying to find installed SDK directories.
|
| + """
|
| + def __init__(self, version, **kw):
|
| + self.version = version
|
| + self.__dict__.update(kw)
|
| +
|
| + def find_sdk_dir(self):
|
| + """Try to find the MS SDK from the registry.
|
| +
|
| + Return None if failed or the directory does not exist.
|
| + """
|
| + if not SCons.Util.can_read_reg:
|
| + debug('find_sdk_dir(): can not read registry')
|
| + return None
|
| +
|
| + hkey = self.HKEY_FMT % self.hkey_data
|
| + debug('find_sdk_dir(): checking registry:%s'%hkey)
|
| +
|
| + try:
|
| + sdk_dir = common.read_reg(hkey)
|
| + except WindowsError, e:
|
| + debug('find_sdk_dir(): no SDK registry key %s' % repr(hkey))
|
| + return None
|
| +
|
| + debug('find_sdk_dir(): Trying SDK Dir: %s'%sdk_dir)
|
| +
|
| + if not os.path.exists(sdk_dir):
|
| + debug('find_sdk_dir(): %s not on file system' % sdk_dir)
|
| + return None
|
| +
|
| + ftc = os.path.join(sdk_dir, self.sanity_check_file)
|
| + if not os.path.exists(ftc):
|
| + debug("find_sdk_dir(): sanity check %s not found" % ftc)
|
| + return None
|
| +
|
| + return sdk_dir
|
| +
|
| + def get_sdk_dir(self):
|
| + """Return the MSSSDK given the version string."""
|
| + try:
|
| + return self._sdk_dir
|
| + except AttributeError:
|
| + sdk_dir = self.find_sdk_dir()
|
| + self._sdk_dir = sdk_dir
|
| + return sdk_dir
|
| +
|
| + def get_sdk_vc_script(self,host_arch, target_arch):
|
| + """ Return the script to initialize the VC compiler installed by SDK
|
| + """
|
| +
|
| + if (host_arch == 'amd64' and target_arch == 'x86'):
|
| + # No cross tools needed compiling 32 bits on 64 bit machine
|
| + host_arch=target_arch
|
| +
|
| + arch_string=target_arch
|
| + if (host_arch != target_arch):
|
| + arch_string='%s_%s'%(host_arch,target_arch)
|
| +
|
| + debug("sdk.py: get_sdk_vc_script():arch_string:%s host_arch:%s target_arch:%s"%(arch_string,
|
| + host_arch,
|
| + target_arch))
|
| + file=self.vc_setup_scripts.get(arch_string,None)
|
| + debug("sdk.py: get_sdk_vc_script():file:%s"%file)
|
| + return file
|
| +
|
| +class WindowsSDK(SDKDefinition):
|
| + """
|
| + A subclass for trying to find installed Windows SDK directories.
|
| + """
|
| + HKEY_FMT = r'Software\Microsoft\Microsoft SDKs\Windows\v%s\InstallationFolder'
|
| + def __init__(self, *args, **kw):
|
| + SDKDefinition.__init__(self, *args, **kw)
|
| + self.hkey_data = self.version
|
| +
|
| +class PlatformSDK(SDKDefinition):
|
| + """
|
| + A subclass for trying to find installed Platform SDK directories.
|
| + """
|
| + HKEY_FMT = r'Software\Microsoft\MicrosoftSDK\InstalledSDKS\%s\Install Dir'
|
| + def __init__(self, *args, **kw):
|
| + SDKDefinition.__init__(self, *args, **kw)
|
| + self.hkey_data = self.uuid
|
| +
|
| +#
|
| +# The list of VC initialization scripts installed by the SDK
|
| +# These should be tried if the vcvarsall.bat TARGET_ARCH fails
|
| +preSDK61VCSetupScripts = { 'x86' : r'bin\vcvars32.bat',
|
| + 'amd64' : r'bin\vcvarsamd64.bat',
|
| + 'x86_amd64': r'bin\vcvarsx86_amd64.bat',
|
| + 'x86_ia64' : r'bin\vcvarsx86_ia64.bat',
|
| + 'ia64' : r'bin\vcvarsia64.bat'}
|
| +
|
| +SDK61VCSetupScripts = {'x86' : r'bin\vcvars32.bat',
|
| + 'amd64' : r'bin\amd64\vcvarsamd64.bat',
|
| + 'x86_amd64': r'bin\x86_amd64\vcvarsx86_amd64.bat',
|
| + 'x86_ia64' : r'bin\x86_ia64\vcvarsx86_ia64.bat',
|
| + 'ia64' : r'bin\ia64\vcvarsia64.bat'}
|
| +
|
| +SDK70VCSetupScripts = { 'x86' : r'bin\vcvars32.bat',
|
| + 'amd64' : r'bin\vcvars64.bat',
|
| + 'x86_amd64': r'bin\vcvarsx86_amd64.bat',
|
| + 'x86_ia64' : r'bin\vcvarsx86_ia64.bat',
|
| + 'ia64' : r'bin\vcvarsia64.bat'}
|
| +
|
| +# The list of support SDKs which we know how to detect.
|
| +#
|
| +# The first SDK found in the list is the one used by default if there
|
| +# are multiple SDKs installed. Barring good reasons to the contrary,
|
| +# this means we should list SDKs with from most recent to oldest.
|
| +#
|
| +# If you update this list, update the documentation in Tool/mssdk.xml.
|
| +SupportedSDKList = [
|
| + WindowsSDK('7.0',
|
| + sanity_check_file=r'bin\SetEnv.Cmd',
|
| + include_subdir='include',
|
| + lib_subdir={
|
| + 'x86' : ['lib'],
|
| + 'x86_64' : [r'lib\x64'],
|
| + 'ia64' : [r'lib\ia64'],
|
| + },
|
| + vc_setup_scripts = SDK70VCSetupScripts,
|
| + ),
|
| + WindowsSDK('6.1',
|
| + sanity_check_file=r'bin\SetEnv.Cmd',
|
| + include_subdir='include',
|
| + lib_subdir={
|
| + 'x86' : ['lib'],
|
| + 'x86_64' : [r'lib\x64'],
|
| + 'ia64' : [r'lib\ia64'],
|
| + },
|
| + vc_setup_scripts = SDK61VCSetupScripts,
|
| + ),
|
| +
|
| + WindowsSDK('6.0A',
|
| + sanity_check_file=r'include\windows.h',
|
| + include_subdir='include',
|
| + lib_subdir={
|
| + 'x86' : ['lib'],
|
| + 'x86_64' : [r'lib\x64'],
|
| + 'ia64' : [r'lib\ia64'],
|
| + },
|
| + vc_setup_scripts = preSDK61VCSetupScripts,
|
| + ),
|
| +
|
| + WindowsSDK('6.0',
|
| + sanity_check_file=r'bin\gacutil.exe',
|
| + include_subdir='include',
|
| + lib_subdir='lib',
|
| + vc_setup_scripts = preSDK61VCSetupScripts,
|
| + ),
|
| +
|
| + PlatformSDK('2003R2',
|
| + sanity_check_file=r'SetEnv.Cmd',
|
| + uuid="D2FF9F89-8AA2-4373-8A31-C838BF4DBBE1",
|
| + vc_setup_scripts = preSDK61VCSetupScripts,
|
| + ),
|
| +
|
| + PlatformSDK('2003R1',
|
| + sanity_check_file=r'SetEnv.Cmd',
|
| + uuid="8F9E5EF3-A9A5-491B-A889-C58EFFECE8B3",
|
| + vc_setup_scripts = preSDK61VCSetupScripts,
|
| + ),
|
| +]
|
| +
|
| +SupportedSDKMap = {}
|
| +for sdk in SupportedSDKList:
|
| + SupportedSDKMap[sdk.version] = sdk
|
| +
|
| +
|
| +# Finding installed SDKs isn't cheap, because it goes not only to the
|
| +# registry but also to the disk to sanity-check that there is, in fact,
|
| +# an SDK installed there and that the registry entry isn't just stale.
|
| +# Find this information once, when requested, and cache it.
|
| +
|
| +InstalledSDKList = None
|
| +InstalledSDKMap = None
|
| +
|
| +def get_installed_sdks():
|
| + global InstalledSDKList
|
| + global InstalledSDKMap
|
| + debug('sdk.py:get_installed_sdks()')
|
| + if InstalledSDKList is None:
|
| + InstalledSDKList = []
|
| + InstalledSDKMap = {}
|
| + for sdk in SupportedSDKList:
|
| + debug('MSCommon/sdk.py: trying to find SDK %s' % sdk.version)
|
| + if sdk.get_sdk_dir():
|
| + debug('MSCommon/sdk.py:found SDK %s' % sdk.version)
|
| + InstalledSDKList.append(sdk)
|
| + InstalledSDKMap[sdk.version] = sdk
|
| + return InstalledSDKList
|
| +
|
| +
|
| +# We may be asked to update multiple construction environments with
|
| +# SDK information. When doing this, we check on-disk for whether
|
| +# the SDK has 'mfc' and 'atl' subdirectories. Since going to disk
|
| +# is expensive, cache results by directory.
|
| +
|
| +SDKEnvironmentUpdates = {}
|
| +
|
| +def set_sdk_by_directory(env, sdk_dir):
|
| + global SDKEnvironmentUpdates
|
| + debug('set_sdk_by_directory: Using dir:%s'%sdk_dir)
|
| + try:
|
| + env_tuple_list = SDKEnvironmentUpdates[sdk_dir]
|
| + except KeyError:
|
| + env_tuple_list = []
|
| + SDKEnvironmentUpdates[sdk_dir] = env_tuple_list
|
| +
|
| + include_path = os.path.join(sdk_dir, 'include')
|
| + mfc_path = os.path.join(include_path, 'mfc')
|
| + atl_path = os.path.join(include_path, 'atl')
|
| +
|
| + if os.path.exists(mfc_path):
|
| + env_tuple_list.append(('INCLUDE', mfc_path))
|
| + if os.path.exists(atl_path):
|
| + env_tuple_list.append(('INCLUDE', atl_path))
|
| + env_tuple_list.append(('INCLUDE', include_path))
|
| +
|
| + env_tuple_list.append(('LIB', os.path.join(sdk_dir, 'lib')))
|
| + env_tuple_list.append(('LIBPATH', os.path.join(sdk_dir, 'lib')))
|
| + env_tuple_list.append(('PATH', os.path.join(sdk_dir, 'bin')))
|
| +
|
| + for variable, directory in env_tuple_list:
|
| + env.PrependENVPath(variable, directory)
|
| +
|
| +
|
| +# TODO(sgk): currently unused; remove?
|
| +def get_cur_sdk_dir_from_reg():
|
| + """Try to find the platform sdk directory from the registry.
|
| +
|
| + Return None if failed or the directory does not exist"""
|
| + if not SCons.Util.can_read_reg:
|
| + debug('SCons cannot read registry')
|
| + return None
|
| +
|
| + try:
|
| + val = common.read_reg(_CURINSTALLED_SDK_HKEY_ROOT)
|
| + debug("Found current sdk dir in registry: %s" % val)
|
| + except WindowsError, e:
|
| + debug("Did not find current sdk in registry")
|
| + return None
|
| +
|
| + if not os.path.exists(val):
|
| + debug("Current sdk dir %s not on fs" % val)
|
| + return None
|
| +
|
| + return val
|
| +
|
| +def get_sdk_by_version(mssdk):
|
| + if mssdk not in SupportedSDKMap:
|
| + msg = "SDK version %s is not supported" % repr(mssdk)
|
| + raise SCons.Errors.UserError(msg)
|
| + get_installed_sdks()
|
| + return InstalledSDKMap.get(mssdk)
|
| +
|
| +def get_default_sdk():
|
| + """Set up the default Platform/Windows SDK."""
|
| + get_installed_sdks()
|
| + if not InstalledSDKList:
|
| + return None
|
| + return InstalledSDKList[0]
|
| +
|
| +
|
| +
|
| +
|
| +def mssdk_setup_env(env):
|
| + debug('sdk.py:mssdk_setup_env()')
|
| + if 'MSSDK_DIR' in env:
|
| + sdk_dir = env['MSSDK_DIR']
|
| + if sdk_dir is None:
|
| + return
|
| + sdk_dir = env.subst(sdk_dir)
|
| + debug('sdk.py:mssdk_setup_env: Using MSSDK_DIR:%s'%sdk_dir)
|
| + elif 'MSSDK_VERSION' in env:
|
| + sdk_version = env['MSSDK_VERSION']
|
| + if sdk_version is None:
|
| + msg = "SDK version %s is not installed" % repr(mssdk)
|
| + raise SCons.Errors.UserError(msg)
|
| + sdk_version = env.subst(sdk_version)
|
| + mssdk = get_sdk_by_version(sdk_version)
|
| + sdk_dir = mssdk.get_sdk_dir()
|
| + debug('sdk.py:mssdk_setup_env: Using MSSDK_VERSION:%s'%sdk_dir)
|
| + elif 'MSVS_VERSION' in env:
|
| + msvs_version = env['MSVS_VERSION']
|
| + debug('sdk.py:mssdk_setup_env:Getting MSVS_VERSION from env:%s'%msvs_version)
|
| + if msvs_version is None:
|
| + debug('sdk.py:mssdk_setup_env thinks msvs_version is None')
|
| + return
|
| + msvs_version = env.subst(msvs_version)
|
| + import vs
|
| + msvs = vs.get_vs_by_version(msvs_version)
|
| + debug('sdk.py:mssdk_setup_env:msvs is :%s'%msvs)
|
| + if not msvs:
|
| + debug('sdk.py:mssdk_setup_env: no VS version detected, bailingout:%s'%msvs)
|
| + return
|
| + sdk_version = msvs.sdk_version
|
| + debug('sdk.py:msvs.sdk_version is %s'%sdk_version)
|
| + if not sdk_version:
|
| + return
|
| + mssdk = get_sdk_by_version(sdk_version)
|
| + if not mssdk:
|
| + mssdk = get_default_sdk()
|
| + if not mssdk:
|
| + return
|
| + sdk_dir = mssdk.get_sdk_dir()
|
| + debug('sdk.py:mssdk_setup_env: Using MSVS_VERSION:%s'%sdk_dir)
|
| + else:
|
| + mssdk = get_default_sdk()
|
| + if not mssdk:
|
| + return
|
| + sdk_dir = mssdk.get_sdk_dir()
|
| + debug('sdk.py:mssdk_setup_env: not using any env values. sdk_dir:%s'%sdk_dir)
|
| +
|
| + set_sdk_by_directory(env, sdk_dir)
|
| +
|
| + #print "No MSVS_VERSION: this is likely to be a bug"
|
| +
|
| +def mssdk_exists(version=None):
|
| + sdks = get_installed_sdks()
|
| + if version is None:
|
| + return len(sdks) > 0
|
| + return version in sdks
|
| +
|
| +# Local Variables:
|
| +# tab-width:4
|
| +# indent-tabs-mode:nil
|
| +# End:
|
| +# vim: set expandtab tabstop=4 shiftwidth=4:
|
|
|
| Property changes on: scons-2.0.1/engine/SCons/Tool/MSCommon/sdk.py
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|