Commit 36ec20b2 authored by Jason R. Coombs's avatar Jason R. Coombs

Move imports to the top and normalize usage.

parent 21480cfc
import os
import distutils.errors
try: try:
import distutils.msvc9compiler import distutils.msvc9compiler
except ImportError: except ImportError:
...@@ -40,8 +43,7 @@ def find_vcvarsall(version): ...@@ -40,8 +43,7 @@ def find_vcvarsall(version):
productdir = None productdir = None
if productdir: if productdir:
import os vcvarsall = os.path.os.path.join(productdir, "vcvarsall.bat")
vcvarsall = os.path.join(productdir, "vcvarsall.bat")
if os.path.isfile(vcvarsall): if os.path.isfile(vcvarsall):
return vcvarsall return vcvarsall
...@@ -89,20 +91,16 @@ def _query_vcvarsall(version, arch): ...@@ -89,20 +91,16 @@ def _query_vcvarsall(version, arch):
Return environment variables for specified Microsoft Visual C++ version Return environment variables for specified Microsoft Visual C++ version
and platform. and platform.
""" """
from os.path import join, isdir
from os import environ
from distutils.errors import DistutilsPlatformError
# Find current and target architecture # Find current and target architecture
CurrentCpu = environ['processor_architecture'].lower() CurrentCpu = os.environ['processor_architecture'].lower()
TargetCpu = arch[arch.find('_') + 1:] TargetCpu = arch[arch.find('_') + 1:]
Tar_not_x86 = TargetCpu != 'x86' Tar_not_x86 = TargetCpu != 'x86'
Cur_not_x86 = CurrentCpu != 'x86' Cur_not_x86 = CurrentCpu != 'x86'
# Find "Windows" and "Program Files" system directories # Find "Windows" and "Program Files" system directories
WinDir = environ['WinDir'] WinDir = os.environ['WinDir']
ProgramFiles = environ['ProgramFiles'] ProgramFiles = os.environ['ProgramFiles']
ProgramFilesX86 = environ.get('ProgramFiles(x86)', ProgramFiles) ProgramFilesX86 = os.environ.get('ProgramFiles(x86)', ProgramFiles)
# Set registry base paths # Set registry base paths
reg_value = distutils.msvc9compiler.Reg.get_value reg_value = distutils.msvc9compiler.Reg.get_value
...@@ -139,7 +137,7 @@ def _query_vcvarsall(version, arch): ...@@ -139,7 +137,7 @@ def _query_vcvarsall(version, arch):
VsInstallDir = reg_value(VsReg, '%0.1f' % version) VsInstallDir = reg_value(VsReg, '%0.1f' % version)
except KeyError: except KeyError:
# If fail, use default path # If fail, use default path
VsInstallDir = join(ProgramFilesX86, VsInstallDir = os.path.join(ProgramFilesX86,
'Microsoft Visual Studio %0.1f' % version) 'Microsoft Visual Studio %0.1f' % version)
# Find Microsoft Visual C++ directory # Find Microsoft Visual C++ directory
...@@ -149,13 +147,13 @@ def _query_vcvarsall(version, arch): ...@@ -149,13 +147,13 @@ def _query_vcvarsall(version, arch):
except KeyError: except KeyError:
try: try:
# Try to get "VC++ for Python" version from registry # Try to get "VC++ for Python" version from registry
VcInstallDir = join(reg_value(VcForPythonReg, 'installdir'), 'VC') VcInstallDir = os.path.join(reg_value(VcForPythonReg, 'installdir'), 'VC')
except KeyError: except KeyError:
# If fail, use default path # If fail, use default path
VcInstallDir = join(ProgramFilesX86, VcInstallDir = os.path.join(ProgramFilesX86,
r'Microsoft Visual Studio %0.1f\VC' % version) r'Microsoft Visual Studio %0.1f\VC' % version)
if not isdir(VcInstallDir): if not os.path.isdir(VcInstallDir):
raise DistutilsPlatformError('vcvarsall.bat and Visual C++ ' raise distutils.errors.DistutilsPlatformError('vcvarsall.bat and Visual C++ '
'directory not found') 'directory not found')
# Find Microsoft Windows SDK directory # Find Microsoft Windows SDK directory
...@@ -169,27 +167,27 @@ def _query_vcvarsall(version, arch): ...@@ -169,27 +167,27 @@ def _query_vcvarsall(version, arch):
for ver in WindowsSdkVer: for ver in WindowsSdkVer:
# Try to get it from registry # Try to get it from registry
try: try:
WindowsSdkDir = reg_value(join(WindowsSdkReg, 'v%s' % ver), WindowsSdkDir = reg_value(os.path.join(WindowsSdkReg, 'v%s' % ver),
'installationfolder') 'installationfolder')
break break
except KeyError: except KeyError:
pass pass
if not WindowsSdkDir or not isdir(WindowsSdkDir): if not WindowsSdkDir or not os.path.isdir(WindowsSdkDir):
# Try to get "VC++ for Python" version from registry # Try to get "VC++ for Python" version from registry
try: try:
WindowsSdkDir = join(reg_value(VcForPythonReg, 'installdir'), WindowsSdkDir = os.path.join(reg_value(VcForPythonReg, 'installdir'),
'WinSDK') 'WinSDK')
except: except:
pass pass
if not WindowsSdkDir or not isdir(WindowsSdkDir): if not WindowsSdkDir or not os.path.isdir(WindowsSdkDir):
# If fail, use default path # If fail, use default path
for ver in WindowsSdkVer: for ver in WindowsSdkVer:
d = join(ProgramFiles, r'Microsoft SDKs\Windows\v%s' % ver) d = os.path.join(ProgramFiles, r'Microsoft SDKs\Windows\v%s' % ver)
if isdir(d): if os.path.isdir(d):
WindowsSdkDir = d WindowsSdkDir = d
if not WindowsSdkDir: if not WindowsSdkDir:
# If fail, use Platform SDK # If fail, use Platform SDK
WindowsSdkDir = join(VcInstallDir, 'PlatformSDK') WindowsSdkDir = os.path.join(VcInstallDir, 'PlatformSDK')
# Find Microsoft .NET Framework 32bit directory # Find Microsoft .NET Framework 32bit directory
try: try:
...@@ -197,7 +195,7 @@ def _query_vcvarsall(version, arch): ...@@ -197,7 +195,7 @@ def _query_vcvarsall(version, arch):
FrameworkDir32 = reg_value(VcReg, 'frameworkdir32') FrameworkDir32 = reg_value(VcReg, 'frameworkdir32')
except KeyError: except KeyError:
# If fail, use default path # If fail, use default path
FrameworkDir32 = join(WinDir, r'Microsoft.NET\Framework') FrameworkDir32 = os.path.join(WinDir, r'Microsoft.NET\Framework')
# Find Microsoft .NET Framework 64bit directory # Find Microsoft .NET Framework 64bit directory
try: try:
...@@ -205,7 +203,7 @@ def _query_vcvarsall(version, arch): ...@@ -205,7 +203,7 @@ def _query_vcvarsall(version, arch):
FrameworkDir64 = reg_value(VcReg, 'frameworkdir64') FrameworkDir64 = reg_value(VcReg, 'frameworkdir64')
except KeyError: except KeyError:
# If fail, use default path # If fail, use default path
FrameworkDir64 = join(WinDir, r'Microsoft.NET\Framework64') FrameworkDir64 = os.path.join(WinDir, r'Microsoft.NET\Framework64')
# Find Microsoft .NET Framework Versions # Find Microsoft .NET Framework Versions
if version == 10.0: if version == 10.0:
...@@ -224,48 +222,48 @@ def _query_vcvarsall(version, arch): ...@@ -224,48 +222,48 @@ def _query_vcvarsall(version, arch):
FrameworkVer = ('v3.0', 'v2.0.50727') FrameworkVer = ('v3.0', 'v2.0.50727')
# Set Microsoft Visual Studio Tools # Set Microsoft Visual Studio Tools
VSTools = [join(VsInstallDir, r'Common7\IDE'), VSTools = [os.path.join(VsInstallDir, r'Common7\IDE'),
join(VsInstallDir, r'Common7\Tools')] os.path.join(VsInstallDir, r'Common7\Tools')]
# Set Microsoft Visual C++ Includes # Set Microsoft Visual C++ Includes
VCIncludes = [join(VcInstallDir, 'Include')] VCIncludes = [os.path.join(VcInstallDir, 'Include')]
# Set Microsoft Visual C++ & Microsoft Foundation Class Libraries # Set Microsoft Visual C++ & Microsoft Foundation Class Libraries
VCLibraries = [join(VcInstallDir, 'Lib' + plt_subd_lib), VCLibraries = [os.path.join(VcInstallDir, 'Lib' + plt_subd_lib),
join(VcInstallDir, r'ATLMFC\LIB' + plt_subd_lib)] os.path.join(VcInstallDir, r'ATLMFC\LIB' + plt_subd_lib)]
# Set Microsoft Visual C++ Tools # Set Microsoft Visual C++ Tools
VCTools = [join(VcInstallDir, 'VCPackages'), VCTools = [os.path.join(VcInstallDir, 'VCPackages'),
join(VcInstallDir, 'Bin' + plt_subd_tools)] os.path.join(VcInstallDir, 'Bin' + plt_subd_tools)]
if plt_subd_tools: if plt_subd_tools:
VCTools.append(join(VcInstallDir, 'Bin')) VCTools.append(os.path.join(VcInstallDir, 'Bin'))
# Set Microsoft Windows SDK Include # Set Microsoft Windows SDK Include
OSLibraries = [join(WindowsSdkDir, 'Lib' + plt_subd_sdk)] OSLibraries = [os.path.join(WindowsSdkDir, 'Lib' + plt_subd_sdk)]
# Set Microsoft Windows SDK Libraries # Set Microsoft Windows SDK Libraries
OSIncludes = [join(WindowsSdkDir, 'Include'), OSIncludes = [os.path.join(WindowsSdkDir, 'Include'),
join(WindowsSdkDir, r'Include\gl')] os.path.join(WindowsSdkDir, r'Include\gl')]
# Set Microsoft Windows SDK Tools # Set Microsoft Windows SDK Tools
SdkTools = [join(WindowsSdkDir, 'Bin')] SdkTools = [os.path.join(WindowsSdkDir, 'Bin')]
if Tar_not_x86: if Tar_not_x86:
SdkTools.append(join(WindowsSdkDir, 'Bin' + plt_subd_sdk)) SdkTools.append(os.path.join(WindowsSdkDir, 'Bin' + plt_subd_sdk))
if version == 10.0: if version == 10.0:
SdkTools.append(join(WindowsSdkDir, SdkTools.append(os.path.join(WindowsSdkDir,
r'Bin\NETFX 4.0 Tools' + plt_subd_sdk)) r'Bin\NETFX 4.0 Tools' + plt_subd_sdk))
# Set Microsoft Windows SDK Setup # Set Microsoft Windows SDK Setup
SdkSetup = [join(WindowsSdkDir, 'Setup')] SdkSetup = [os.path.join(WindowsSdkDir, 'Setup')]
# Set Microsoft .NET Framework Tools # Set Microsoft .NET Framework Tools
FxTools = [join(FrameworkDir32, ver) for ver in FrameworkVer] FxTools = [os.path.join(FrameworkDir32, ver) for ver in FrameworkVer]
if Tar_not_x86 and Cur_not_x86: if Tar_not_x86 and Cur_not_x86:
for ver in FrameworkVer: for ver in FrameworkVer:
FxTools.append(join(FrameworkDir64, ver)) FxTools.append(os.path.join(FrameworkDir64, ver))
# Set Microsoft Visual Studio Team System Database # Set Microsoft Visual Studio Team System Database
VsTDb = [join(VsInstallDir, r'VSTSDB\Deploy')] VsTDb = [os.path.join(VsInstallDir, r'VSTSDB\Deploy')]
# Return Environment Variables # Return Environment Variables
env = {} env = {}
...@@ -276,7 +274,7 @@ def _query_vcvarsall(version, arch): ...@@ -276,7 +274,7 @@ def _query_vcvarsall(version, arch):
def checkpath(path, varlist): def checkpath(path, varlist):
# Function that add valid paths in list in not already present # Function that add valid paths in list in not already present
if isdir(path) and path not in varlist: if os.path.isdir(path) and path not in varlist:
varlist.append(path) varlist.append(path)
for key in env.keys(): for key in env.keys():
...@@ -288,15 +286,15 @@ def _query_vcvarsall(version, arch): ...@@ -288,15 +286,15 @@ def _query_vcvarsall(version, arch):
# Add values from actual environment # Add values from actual environment
try: try:
for val in environ[key].split(';'): for val in os.environ[key].split(';'):
checkpath(val, var) checkpath(val, var)
except KeyError: except KeyError:
pass pass
# Format paths to Environment Variable string # Format paths to Environment Variable string
if var: if var:
env[key] = ';'.join(var) env[key] = ';'.os.path.join(var)
else: else:
raise DistutilsPlatformError("%s environment variable is empty" % raise distutils.errors.DistutilsPlatformError("%s environment variable is empty" %
key.upper()) key.upper())
return env return env
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment