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
de9e0e83
Commit
de9e0e83
authored
May 02, 2016
by
Jason R. Coombs
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #565 from JGoutin/feature/msvc-discovery
Feature/msvc discovery
parents
4b411f54
d4486dc6
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
10 deletions
+28
-10
setuptools/msvc9_support.py
setuptools/msvc9_support.py
+28
-10
No files found.
setuptools/msvc9_support.py
View file @
de9e0e83
...
@@ -235,7 +235,7 @@ class PlatformInfo:
...
@@ -235,7 +235,7 @@ class PlatformInfo:
current_cpu
=
os
.
environ
[
'processor_architecture'
].
lower
()
current_cpu
=
os
.
environ
[
'processor_architecture'
].
lower
()
def
__init__
(
self
,
arch
):
def
__init__
(
self
,
arch
):
self
.
arch
=
arch
.
lower
()
self
.
arch
=
arch
.
lower
()
.
replace
(
'x64'
,
'amd64'
)
@
property
@
property
def
target_cpu
(
self
):
def
target_cpu
(
self
):
...
@@ -829,7 +829,7 @@ class EnvironmentInfo:
...
@@ -829,7 +829,7 @@ class EnvironmentInfo:
"""
"""
if self.vcver <= 10.0:
if self.vcver <= 10.0:
arch_subdir = self.pi.target_dir(hidex86=True, x64=True)
arch_subdir = self.pi.target_dir(hidex86=True, x64=True)
return [os.path.join(self.si.WindowsSdkDir, '
Bin
%
s
' % arch_subdir)]
return [os.path.join(self.si.WindowsSdkDir, '
Lib
%
s
' % arch_subdir)]
else:
else:
arch_subdir = self.pi.target_dir(x64=True)
arch_subdir = self.pi.target_dir(x64=True)
...
@@ -862,7 +862,13 @@ class EnvironmentInfo:
...
@@ -862,7 +862,13 @@ class EnvironmentInfo:
Microsoft Windows SDK Libraries Paths
Microsoft Windows SDK Libraries Paths
"""
"""
ref = os.path.join(self.si.WindowsSdkDir, '
References
')
ref = os.path.join(self.si.WindowsSdkDir, '
References
')
libpath = [os.path.join(ref, r'
CommonConfiguration
\
Neutral
')]
libpath = []
if self.vcver <= 9.0:
libpath += self.OSLibraries
if self.vcver >= 11.0:
libpath += [os.path.join(ref, r'
CommonConfiguration
\
Neutral
')]
if self.vcver >= 14.0:
if self.vcver >= 14.0:
libpath += [ref,
libpath += [ref,
...
@@ -910,6 +916,9 @@ class EnvironmentInfo:
...
@@ -910,6 +916,9 @@ class EnvironmentInfo:
"""
"""
Microsoft Windows SDK Setup
Microsoft Windows SDK Setup
"""
"""
if self.vcver > 9.0:
return []
return [os.path.join(self.si.WindowsSdkDir, '
Setup
')]
return [os.path.join(self.si.WindowsSdkDir, '
Setup
')]
@property
@property
...
@@ -1033,27 +1042,35 @@ class EnvironmentInfo:
...
@@ -1033,27 +1042,35 @@ class EnvironmentInfo:
vcruntime = vcruntime % (arch_subdir, self.vcver, self.vcver)
vcruntime = vcruntime % (arch_subdir, self.vcver, self.vcver)
return os.path.join(self.si.VCInstallDir, vcruntime)
return os.path.join(self.si.VCInstallDir, vcruntime)
def return_env(self):
def return_env(self
, exists=True
):
"""
"""
Return environment dict.
Return environment dict.
Parameters
----------
exists: bool
It True, only return existing paths.
"""
"""
env = dict(
env = dict(
include=self._build_paths('
include
',
include=self._build_paths('
include
',
[self.VCIncludes,
[self.VCIncludes,
self.OSIncludes,
self.OSIncludes,
self.UCRTIncludes,
self.UCRTIncludes,
self.NetFxSDKIncludes]),
self.NetFxSDKIncludes],
exists),
lib=self._build_paths('
lib
',
lib=self._build_paths('
lib
',
[self.VCLibraries,
[self.VCLibraries,
self.OSLibraries,
self.OSLibraries,
self.FxTools,
self.FxTools,
self.UCRTLibraries,
self.UCRTLibraries,
self.NetFxSDKLibraries]),
self.NetFxSDKLibraries],
exists),
libpath=self._build_paths('
libpath
',
libpath=self._build_paths('
libpath
',
[self.VCLibraries,
[self.VCLibraries,
self.FxTools,
self.FxTools,
self.VCStoreRefs,
self.VCStoreRefs,
self.OSLibpath]),
self.OSLibpath],
exists),
path=self._build_paths('
path
',
path=self._build_paths('
path
',
[self.VCTools,
[self.VCTools,
self.VSTools,
self.VSTools,
...
@@ -1063,13 +1080,14 @@ class EnvironmentInfo:
...
@@ -1063,13 +1080,14 @@ class EnvironmentInfo:
self.FxTools,
self.FxTools,
self.MSBuild,
self.MSBuild,
self.HTMLHelpWorkshop,
self.HTMLHelpWorkshop,
self.FSharp]),
self.FSharp],
exists),
)
)
if self.vcver >= 14 and os.path.isfile(self.VCRuntimeRedist):
if self.vcver >= 14 and os.path.isfile(self.VCRuntimeRedist):
env['
py_vcruntime_redist
'] = self.VCRuntimeRedist
env['
py_vcruntime_redist
'] = self.VCRuntimeRedist
return env
return env
def _build_paths(self, name, spec_path_lists):
def _build_paths(self, name, spec_path_lists
, exists
):
"""
"""
Given an environment variable name and specified paths,
Given an environment variable name and specified paths,
return a pathsep-separated string of paths containing
return a pathsep-separated string of paths containing
...
@@ -1081,7 +1099,7 @@ class EnvironmentInfo:
...
@@ -1081,7 +1099,7 @@ class EnvironmentInfo:
spec_paths = itertools.chain.from_iterable(spec_path_lists)
spec_paths = itertools.chain.from_iterable(spec_path_lists)
env_paths = os.environ.get(name, '').split(os.pathsep)
env_paths = os.environ.get(name, '').split(os.pathsep)
paths = itertools.chain(spec_paths, env_paths)
paths = itertools.chain(spec_paths, env_paths)
extant_paths = list(filter(os.path.isdir, paths))
extant_paths = list(filter(os.path.isdir, paths))
if exists else paths
if not extant_paths:
if not extant_paths:
msg = "%s environment variable is empty" % name.upper()
msg = "%s environment variable is empty" % name.upper()
raise distutils.errors.DistutilsPlatformError(msg)
raise distutils.errors.DistutilsPlatformError(msg)
...
...
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