Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
setuptools
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Jérome Perrin
setuptools
Commits
36ec20b2
Commit
36ec20b2
authored
Feb 23, 2016
by
Jason R. Coombs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move imports to the top and normalize usage.
parent
21480cfc
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
46 deletions
+44
-46
setuptools/msvc9_support.py
setuptools/msvc9_support.py
+44
-46
No files found.
setuptools/msvc9_support.py
View file @
36ec20b2
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
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment