wsba-hockey 1.0.2__py3-none-any.whl → 1.0.4__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (130) hide show
  1. wsba_hockey/data_pipelines.py +183 -0
  2. wsba_hockey/evidence/weakside-breakout/node_modules/duckdb/vendor.py +146 -0
  3. wsba_hockey/evidence/weakside-breakout/node_modules/flatted/python/flatted.py +149 -0
  4. wsba_hockey/evidence/weakside-breakout/node_modules/flatted/python/test.py +63 -0
  5. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/gyp_main.py +45 -0
  6. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSNew.py +367 -0
  7. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSProject.py +206 -0
  8. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings.py +1270 -0
  9. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings_test.py +1547 -0
  10. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSToolFile.py +59 -0
  11. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSUserFile.py +153 -0
  12. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSUtil.py +271 -0
  13. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +574 -0
  14. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +690 -0
  15. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/common.py +661 -0
  16. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/common_test.py +78 -0
  17. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/easy_xml.py +165 -0
  18. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/easy_xml_test.py +109 -0
  19. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/flock_tool.py +55 -0
  20. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/__init__.py +0 -0
  21. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/analyzer.py +808 -0
  22. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/android.py +1173 -0
  23. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/cmake.py +1321 -0
  24. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/compile_commands_json.py +120 -0
  25. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/dump_dependency_json.py +103 -0
  26. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/eclipse.py +464 -0
  27. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/gypd.py +89 -0
  28. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/gypsh.py +58 -0
  29. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/make.py +2714 -0
  30. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +3981 -0
  31. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs_test.py +44 -0
  32. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +2936 -0
  33. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +55 -0
  34. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode.py +1394 -0
  35. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode_test.py +25 -0
  36. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/input.py +3130 -0
  37. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/input_test.py +98 -0
  38. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +771 -0
  39. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +1271 -0
  40. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/ninja_syntax.py +174 -0
  41. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +61 -0
  42. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/win_tool.py +374 -0
  43. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation.py +1939 -0
  44. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/xcode_ninja.py +302 -0
  45. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +3197 -0
  46. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/pylib/gyp/xml_fix.py +65 -0
  47. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/test_gyp.py +261 -0
  48. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/tools/graphviz.py +102 -0
  49. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/tools/pretty_gyp.py +156 -0
  50. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/tools/pretty_sln.py +181 -0
  51. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/gyp/tools/pretty_vcproj.py +339 -0
  52. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/test/fixtures/test-charmap.py +31 -0
  53. wsba_hockey/evidence/weakside-breakout/node_modules/node-gyp/update-gyp.py +64 -0
  54. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/gyp_main.py +45 -0
  55. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSNew.py +367 -0
  56. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSProject.py +206 -0
  57. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings.py +1270 -0
  58. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings_test.py +1547 -0
  59. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSToolFile.py +59 -0
  60. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSUserFile.py +153 -0
  61. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSUtil.py +271 -0
  62. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +574 -0
  63. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +666 -0
  64. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/common.py +654 -0
  65. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/common_test.py +78 -0
  66. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/easy_xml.py +165 -0
  67. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/easy_xml_test.py +109 -0
  68. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/flock_tool.py +55 -0
  69. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/__init__.py +0 -0
  70. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/analyzer.py +808 -0
  71. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/android.py +1173 -0
  72. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/cmake.py +1321 -0
  73. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/compile_commands_json.py +120 -0
  74. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/dump_dependency_json.py +103 -0
  75. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/eclipse.py +464 -0
  76. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/gypd.py +89 -0
  77. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/gypsh.py +58 -0
  78. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/make.py +2518 -0
  79. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +3978 -0
  80. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs_test.py +44 -0
  81. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +2936 -0
  82. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +55 -0
  83. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode.py +1394 -0
  84. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode_test.py +25 -0
  85. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/input.py +3137 -0
  86. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/input_test.py +98 -0
  87. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +771 -0
  88. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +1271 -0
  89. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/ninja_syntax.py +174 -0
  90. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +61 -0
  91. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/win_tool.py +374 -0
  92. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation.py +1939 -0
  93. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/xcode_ninja.py +302 -0
  94. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +3197 -0
  95. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/pylib/gyp/xml_fix.py +65 -0
  96. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/setup.py +42 -0
  97. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/test_gyp.py +260 -0
  98. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/tools/graphviz.py +102 -0
  99. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/tools/pretty_gyp.py +156 -0
  100. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/tools/pretty_sln.py +181 -0
  101. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/gyp/tools/pretty_vcproj.py +339 -0
  102. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/test/fixtures/test-charmap.py +31 -0
  103. wsba_hockey/evidence/weakside-breakout/node_modules/sqlite3/node_modules/node-gyp/update-gyp.py +46 -0
  104. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/game_stats/app.py +401 -0
  105. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/game_stats/name_fix.py +47 -0
  106. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/heatmaps/app.py +108 -0
  107. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/heatmaps/plot.py +93 -0
  108. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/heatmaps/rink_plot.py +245 -0
  109. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/matchups/app.py +145 -0
  110. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/matchups/plot.py +77 -0
  111. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/matchups/rink_plot.py +245 -0
  112. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/pbp/app.py +389 -0
  113. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/pbp/plot.py +70 -0
  114. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/pbp/rink_plot.py +245 -0
  115. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/skater/app.py +110 -0
  116. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/skater/plot.py +58 -0
  117. wsba_hockey/evidence/weakside-breakout/wsba_nhl_apps/wsba_nhl_apps/skater/rink_plot.py +245 -0
  118. wsba_hockey/tools/agg.py +242 -53
  119. wsba_hockey/tools/plotting.py +15 -20
  120. wsba_hockey/tools/scraping.py +149 -258
  121. wsba_hockey/tools/xg_model.py +370 -298
  122. wsba_hockey/workspace.py +22 -101
  123. wsba_hockey/wsba_main.py +494 -147
  124. {wsba_hockey-1.0.2.dist-info → wsba_hockey-1.0.4.dist-info}/METADATA +2 -2
  125. wsba_hockey-1.0.4.dist-info/RECORD +135 -0
  126. {wsba_hockey-1.0.2.dist-info → wsba_hockey-1.0.4.dist-info}/WHEEL +1 -1
  127. wsba_hockey/stats/calculate_viz/shot_impact.py +0 -2
  128. wsba_hockey-1.0.2.dist-info/RECORD +0 -19
  129. {wsba_hockey-1.0.2.dist-info → wsba_hockey-1.0.4.dist-info}/licenses/LICENSE +0 -0
  130. {wsba_hockey-1.0.2.dist-info → wsba_hockey-1.0.4.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,574 @@
1
+ # Copyright (c) 2013 Google Inc. All rights reserved.
2
+ # Use of this source code is governed by a BSD-style license that can be
3
+ # found in the LICENSE file.
4
+
5
+ """Handle version information related to Visual Stuio."""
6
+
7
+ import errno
8
+ import os
9
+ import re
10
+ import subprocess
11
+ import sys
12
+ import glob
13
+
14
+
15
+ def JoinPath(*args):
16
+ return os.path.normpath(os.path.join(*args))
17
+
18
+
19
+ class VisualStudioVersion:
20
+ """Information regarding a version of Visual Studio."""
21
+
22
+ def __init__(
23
+ self,
24
+ short_name,
25
+ description,
26
+ solution_version,
27
+ project_version,
28
+ flat_sln,
29
+ uses_vcxproj,
30
+ path,
31
+ sdk_based,
32
+ default_toolset=None,
33
+ compatible_sdks=None,
34
+ ):
35
+ self.short_name = short_name
36
+ self.description = description
37
+ self.solution_version = solution_version
38
+ self.project_version = project_version
39
+ self.flat_sln = flat_sln
40
+ self.uses_vcxproj = uses_vcxproj
41
+ self.path = path
42
+ self.sdk_based = sdk_based
43
+ self.default_toolset = default_toolset
44
+ compatible_sdks = compatible_sdks or []
45
+ compatible_sdks.sort(key=lambda v: float(v.replace("v", "")), reverse=True)
46
+ self.compatible_sdks = compatible_sdks
47
+
48
+ def ShortName(self):
49
+ return self.short_name
50
+
51
+ def Description(self):
52
+ """Get the full description of the version."""
53
+ return self.description
54
+
55
+ def SolutionVersion(self):
56
+ """Get the version number of the sln files."""
57
+ return self.solution_version
58
+
59
+ def ProjectVersion(self):
60
+ """Get the version number of the vcproj or vcxproj files."""
61
+ return self.project_version
62
+
63
+ def FlatSolution(self):
64
+ return self.flat_sln
65
+
66
+ def UsesVcxproj(self):
67
+ """Returns true if this version uses a vcxproj file."""
68
+ return self.uses_vcxproj
69
+
70
+ def ProjectExtension(self):
71
+ """Returns the file extension for the project."""
72
+ return self.uses_vcxproj and ".vcxproj" or ".vcproj"
73
+
74
+ def Path(self):
75
+ """Returns the path to Visual Studio installation."""
76
+ return self.path
77
+
78
+ def ToolPath(self, tool):
79
+ """Returns the path to a given compiler tool. """
80
+ return os.path.normpath(os.path.join(self.path, "VC/bin", tool))
81
+
82
+ def DefaultToolset(self):
83
+ """Returns the msbuild toolset version that will be used in the absence
84
+ of a user override."""
85
+ return self.default_toolset
86
+
87
+ def _SetupScriptInternal(self, target_arch):
88
+ """Returns a command (with arguments) to be used to set up the
89
+ environment."""
90
+ assert target_arch in ("x86", "x64"), "target_arch not supported"
91
+ # If WindowsSDKDir is set and SetEnv.Cmd exists then we are using the
92
+ # depot_tools build tools and should run SetEnv.Cmd to set up the
93
+ # environment. The check for WindowsSDKDir alone is not sufficient because
94
+ # this is set by running vcvarsall.bat.
95
+ sdk_dir = os.environ.get("WindowsSDKDir", "")
96
+ setup_path = JoinPath(sdk_dir, "Bin", "SetEnv.Cmd")
97
+ if self.sdk_based and sdk_dir and os.path.exists(setup_path):
98
+ return [setup_path, "/" + target_arch]
99
+
100
+ is_host_arch_x64 = (
101
+ os.environ.get("PROCESSOR_ARCHITECTURE") == "AMD64"
102
+ or os.environ.get("PROCESSOR_ARCHITEW6432") == "AMD64"
103
+ )
104
+
105
+ # For VS2017 (and newer) it's fairly easy
106
+ if self.short_name >= "2017":
107
+ script_path = JoinPath(
108
+ self.path, "VC", "Auxiliary", "Build", "vcvarsall.bat"
109
+ )
110
+
111
+ # Always use a native executable, cross-compiling if necessary.
112
+ host_arch = "amd64" if is_host_arch_x64 else "x86"
113
+ msvc_target_arch = "amd64" if target_arch == "x64" else "x86"
114
+ arg = host_arch
115
+ if host_arch != msvc_target_arch:
116
+ arg += "_" + msvc_target_arch
117
+
118
+ return [script_path, arg]
119
+
120
+ # We try to find the best version of the env setup batch.
121
+ vcvarsall = JoinPath(self.path, "VC", "vcvarsall.bat")
122
+ if target_arch == "x86":
123
+ if (
124
+ self.short_name >= "2013"
125
+ and self.short_name[-1] != "e"
126
+ and is_host_arch_x64
127
+ ):
128
+ # VS2013 and later, non-Express have a x64-x86 cross that we want
129
+ # to prefer.
130
+ return [vcvarsall, "amd64_x86"]
131
+ else:
132
+ # Otherwise, the standard x86 compiler. We don't use VC/vcvarsall.bat
133
+ # for x86 because vcvarsall calls vcvars32, which it can only find if
134
+ # VS??COMNTOOLS is set, which isn't guaranteed.
135
+ return [JoinPath(self.path, "Common7", "Tools", "vsvars32.bat")]
136
+ elif target_arch == "x64":
137
+ arg = "x86_amd64"
138
+ # Use the 64-on-64 compiler if we're not using an express edition and
139
+ # we're running on a 64bit OS.
140
+ if self.short_name[-1] != "e" and is_host_arch_x64:
141
+ arg = "amd64"
142
+ return [vcvarsall, arg]
143
+
144
+ def SetupScript(self, target_arch):
145
+ script_data = self._SetupScriptInternal(target_arch)
146
+ script_path = script_data[0]
147
+ if not os.path.exists(script_path):
148
+ raise Exception(
149
+ "%s is missing - make sure VC++ tools are installed." % script_path
150
+ )
151
+ return script_data
152
+
153
+
154
+ def _RegistryQueryBase(sysdir, key, value):
155
+ """Use reg.exe to read a particular key.
156
+
157
+ While ideally we might use the win32 module, we would like gyp to be
158
+ python neutral, so for instance cygwin python lacks this module.
159
+
160
+ Arguments:
161
+ sysdir: The system subdirectory to attempt to launch reg.exe from.
162
+ key: The registry key to read from.
163
+ value: The particular value to read.
164
+ Return:
165
+ stdout from reg.exe, or None for failure.
166
+ """
167
+ # Skip if not on Windows or Python Win32 setup issue
168
+ if sys.platform not in ("win32", "cygwin"):
169
+ return None
170
+ # Setup params to pass to and attempt to launch reg.exe
171
+ cmd = [os.path.join(os.environ.get("WINDIR", ""), sysdir, "reg.exe"), "query", key]
172
+ if value:
173
+ cmd.extend(["/v", value])
174
+ p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
175
+ # Obtain the stdout from reg.exe, reading to the end so p.returncode is valid
176
+ # Note that the error text may be in [1] in some cases
177
+ text = p.communicate()[0].decode("utf-8")
178
+ # Check return code from reg.exe; officially 0==success and 1==error
179
+ if p.returncode:
180
+ return None
181
+ return text
182
+
183
+
184
+ def _RegistryQuery(key, value=None):
185
+ r"""Use reg.exe to read a particular key through _RegistryQueryBase.
186
+
187
+ First tries to launch from %WinDir%\Sysnative to avoid WoW64 redirection. If
188
+ that fails, it falls back to System32. Sysnative is available on Vista and
189
+ up and available on Windows Server 2003 and XP through KB patch 942589. Note
190
+ that Sysnative will always fail if using 64-bit python due to it being a
191
+ virtual directory and System32 will work correctly in the first place.
192
+
193
+ KB 942589 - http://support.microsoft.com/kb/942589/en-us.
194
+
195
+ Arguments:
196
+ key: The registry key.
197
+ value: The particular registry value to read (optional).
198
+ Return:
199
+ stdout from reg.exe, or None for failure.
200
+ """
201
+ text = None
202
+ try:
203
+ text = _RegistryQueryBase("Sysnative", key, value)
204
+ except OSError as e:
205
+ if e.errno == errno.ENOENT:
206
+ text = _RegistryQueryBase("System32", key, value)
207
+ else:
208
+ raise
209
+ return text
210
+
211
+
212
+ def _RegistryGetValueUsingWinReg(key, value):
213
+ """Use the _winreg module to obtain the value of a registry key.
214
+
215
+ Args:
216
+ key: The registry key.
217
+ value: The particular registry value to read.
218
+ Return:
219
+ contents of the registry key's value, or None on failure. Throws
220
+ ImportError if winreg is unavailable.
221
+ """
222
+ from winreg import HKEY_LOCAL_MACHINE, OpenKey, QueryValueEx
223
+ try:
224
+ root, subkey = key.split("\\", 1)
225
+ assert root == "HKLM" # Only need HKLM for now.
226
+ with OpenKey(HKEY_LOCAL_MACHINE, subkey) as hkey:
227
+ return QueryValueEx(hkey, value)[0]
228
+ except OSError:
229
+ return None
230
+
231
+
232
+ def _RegistryGetValue(key, value):
233
+ """Use _winreg or reg.exe to obtain the value of a registry key.
234
+
235
+ Using _winreg is preferable because it solves an issue on some corporate
236
+ environments where access to reg.exe is locked down. However, we still need
237
+ to fallback to reg.exe for the case where the _winreg module is not available
238
+ (for example in cygwin python).
239
+
240
+ Args:
241
+ key: The registry key.
242
+ value: The particular registry value to read.
243
+ Return:
244
+ contents of the registry key's value, or None on failure.
245
+ """
246
+ try:
247
+ return _RegistryGetValueUsingWinReg(key, value)
248
+ except ImportError:
249
+ pass
250
+
251
+ # Fallback to reg.exe if we fail to import _winreg.
252
+ text = _RegistryQuery(key, value)
253
+ if not text:
254
+ return None
255
+ # Extract value.
256
+ match = re.search(r"REG_\w+\s+([^\r]+)\r\n", text)
257
+ if not match:
258
+ return None
259
+ return match.group(1)
260
+
261
+
262
+ def _CreateVersion(name, path, sdk_based=False):
263
+ """Sets up MSVS project generation.
264
+
265
+ Setup is based off the GYP_MSVS_VERSION environment variable or whatever is
266
+ autodetected if GYP_MSVS_VERSION is not explicitly specified. If a version is
267
+ passed in that doesn't match a value in versions python will throw a error.
268
+ """
269
+ if path:
270
+ path = os.path.normpath(path)
271
+ versions = {
272
+ "2022": VisualStudioVersion(
273
+ "2022",
274
+ "Visual Studio 2022",
275
+ solution_version="12.00",
276
+ project_version="17.0",
277
+ flat_sln=False,
278
+ uses_vcxproj=True,
279
+ path=path,
280
+ sdk_based=sdk_based,
281
+ default_toolset="v143",
282
+ compatible_sdks=["v8.1", "v10.0"],
283
+ ),
284
+ "2019": VisualStudioVersion(
285
+ "2019",
286
+ "Visual Studio 2019",
287
+ solution_version="12.00",
288
+ project_version="16.0",
289
+ flat_sln=False,
290
+ uses_vcxproj=True,
291
+ path=path,
292
+ sdk_based=sdk_based,
293
+ default_toolset="v142",
294
+ compatible_sdks=["v8.1", "v10.0"],
295
+ ),
296
+ "2017": VisualStudioVersion(
297
+ "2017",
298
+ "Visual Studio 2017",
299
+ solution_version="12.00",
300
+ project_version="15.0",
301
+ flat_sln=False,
302
+ uses_vcxproj=True,
303
+ path=path,
304
+ sdk_based=sdk_based,
305
+ default_toolset="v141",
306
+ compatible_sdks=["v8.1", "v10.0"],
307
+ ),
308
+ "2015": VisualStudioVersion(
309
+ "2015",
310
+ "Visual Studio 2015",
311
+ solution_version="12.00",
312
+ project_version="14.0",
313
+ flat_sln=False,
314
+ uses_vcxproj=True,
315
+ path=path,
316
+ sdk_based=sdk_based,
317
+ default_toolset="v140",
318
+ ),
319
+ "2013": VisualStudioVersion(
320
+ "2013",
321
+ "Visual Studio 2013",
322
+ solution_version="13.00",
323
+ project_version="12.0",
324
+ flat_sln=False,
325
+ uses_vcxproj=True,
326
+ path=path,
327
+ sdk_based=sdk_based,
328
+ default_toolset="v120",
329
+ ),
330
+ "2013e": VisualStudioVersion(
331
+ "2013e",
332
+ "Visual Studio 2013",
333
+ solution_version="13.00",
334
+ project_version="12.0",
335
+ flat_sln=True,
336
+ uses_vcxproj=True,
337
+ path=path,
338
+ sdk_based=sdk_based,
339
+ default_toolset="v120",
340
+ ),
341
+ "2012": VisualStudioVersion(
342
+ "2012",
343
+ "Visual Studio 2012",
344
+ solution_version="12.00",
345
+ project_version="4.0",
346
+ flat_sln=False,
347
+ uses_vcxproj=True,
348
+ path=path,
349
+ sdk_based=sdk_based,
350
+ default_toolset="v110",
351
+ ),
352
+ "2012e": VisualStudioVersion(
353
+ "2012e",
354
+ "Visual Studio 2012",
355
+ solution_version="12.00",
356
+ project_version="4.0",
357
+ flat_sln=True,
358
+ uses_vcxproj=True,
359
+ path=path,
360
+ sdk_based=sdk_based,
361
+ default_toolset="v110",
362
+ ),
363
+ "2010": VisualStudioVersion(
364
+ "2010",
365
+ "Visual Studio 2010",
366
+ solution_version="11.00",
367
+ project_version="4.0",
368
+ flat_sln=False,
369
+ uses_vcxproj=True,
370
+ path=path,
371
+ sdk_based=sdk_based,
372
+ ),
373
+ "2010e": VisualStudioVersion(
374
+ "2010e",
375
+ "Visual C++ Express 2010",
376
+ solution_version="11.00",
377
+ project_version="4.0",
378
+ flat_sln=True,
379
+ uses_vcxproj=True,
380
+ path=path,
381
+ sdk_based=sdk_based,
382
+ ),
383
+ "2008": VisualStudioVersion(
384
+ "2008",
385
+ "Visual Studio 2008",
386
+ solution_version="10.00",
387
+ project_version="9.00",
388
+ flat_sln=False,
389
+ uses_vcxproj=False,
390
+ path=path,
391
+ sdk_based=sdk_based,
392
+ ),
393
+ "2008e": VisualStudioVersion(
394
+ "2008e",
395
+ "Visual Studio 2008",
396
+ solution_version="10.00",
397
+ project_version="9.00",
398
+ flat_sln=True,
399
+ uses_vcxproj=False,
400
+ path=path,
401
+ sdk_based=sdk_based,
402
+ ),
403
+ "2005": VisualStudioVersion(
404
+ "2005",
405
+ "Visual Studio 2005",
406
+ solution_version="9.00",
407
+ project_version="8.00",
408
+ flat_sln=False,
409
+ uses_vcxproj=False,
410
+ path=path,
411
+ sdk_based=sdk_based,
412
+ ),
413
+ "2005e": VisualStudioVersion(
414
+ "2005e",
415
+ "Visual Studio 2005",
416
+ solution_version="9.00",
417
+ project_version="8.00",
418
+ flat_sln=True,
419
+ uses_vcxproj=False,
420
+ path=path,
421
+ sdk_based=sdk_based,
422
+ ),
423
+ }
424
+ return versions[str(name)]
425
+
426
+
427
+ def _ConvertToCygpath(path):
428
+ """Convert to cygwin path if we are using cygwin."""
429
+ if sys.platform == "cygwin":
430
+ p = subprocess.Popen(["cygpath", path], stdout=subprocess.PIPE)
431
+ path = p.communicate()[0].decode("utf-8").strip()
432
+ return path
433
+
434
+
435
+ def _DetectVisualStudioVersions(versions_to_check, force_express):
436
+ """Collect the list of installed visual studio versions.
437
+
438
+ Returns:
439
+ A list of visual studio versions installed in descending order of
440
+ usage preference.
441
+ Base this on the registry and a quick check if devenv.exe exists.
442
+ Possibilities are:
443
+ 2005(e) - Visual Studio 2005 (8)
444
+ 2008(e) - Visual Studio 2008 (9)
445
+ 2010(e) - Visual Studio 2010 (10)
446
+ 2012(e) - Visual Studio 2012 (11)
447
+ 2013(e) - Visual Studio 2013 (12)
448
+ 2015 - Visual Studio 2015 (14)
449
+ 2017 - Visual Studio 2017 (15)
450
+ 2019 - Visual Studio 2019 (16)
451
+ 2022 - Visual Studio 2022 (17)
452
+ Where (e) is e for express editions of MSVS and blank otherwise.
453
+ """
454
+ version_to_year = {
455
+ "8.0": "2005",
456
+ "9.0": "2008",
457
+ "10.0": "2010",
458
+ "11.0": "2012",
459
+ "12.0": "2013",
460
+ "14.0": "2015",
461
+ "15.0": "2017",
462
+ "16.0": "2019",
463
+ "17.0": "2022",
464
+ }
465
+ versions = []
466
+ for version in versions_to_check:
467
+ # Old method of searching for which VS version is installed
468
+ # We don't use the 2010-encouraged-way because we also want to get the
469
+ # path to the binaries, which it doesn't offer.
470
+ keys = [
471
+ r"HKLM\Software\Microsoft\VisualStudio\%s" % version,
472
+ r"HKLM\Software\Wow6432Node\Microsoft\VisualStudio\%s" % version,
473
+ r"HKLM\Software\Microsoft\VCExpress\%s" % version,
474
+ r"HKLM\Software\Wow6432Node\Microsoft\VCExpress\%s" % version,
475
+ ]
476
+ for index in range(len(keys)):
477
+ path = _RegistryGetValue(keys[index], "InstallDir")
478
+ if not path:
479
+ continue
480
+ path = _ConvertToCygpath(path)
481
+ # Check for full.
482
+ full_path = os.path.join(path, "devenv.exe")
483
+ express_path = os.path.join(path, "*express.exe")
484
+ if not force_express and os.path.exists(full_path):
485
+ # Add this one.
486
+ versions.append(
487
+ _CreateVersion(
488
+ version_to_year[version], os.path.join(path, "..", "..")
489
+ )
490
+ )
491
+ # Check for express.
492
+ elif glob.glob(express_path):
493
+ # Add this one.
494
+ versions.append(
495
+ _CreateVersion(
496
+ version_to_year[version] + "e", os.path.join(path, "..", "..")
497
+ )
498
+ )
499
+
500
+ # The old method above does not work when only SDK is installed.
501
+ keys = [
502
+ r"HKLM\Software\Microsoft\VisualStudio\SxS\VC7",
503
+ r"HKLM\Software\Wow6432Node\Microsoft\VisualStudio\SxS\VC7",
504
+ r"HKLM\Software\Microsoft\VisualStudio\SxS\VS7",
505
+ r"HKLM\Software\Wow6432Node\Microsoft\VisualStudio\SxS\VS7",
506
+ ]
507
+ for index in range(len(keys)):
508
+ path = _RegistryGetValue(keys[index], version)
509
+ if not path:
510
+ continue
511
+ path = _ConvertToCygpath(path)
512
+ if version == "15.0":
513
+ if os.path.exists(path):
514
+ versions.append(_CreateVersion("2017", path))
515
+ elif version != "14.0": # There is no Express edition for 2015.
516
+ versions.append(
517
+ _CreateVersion(
518
+ version_to_year[version] + "e",
519
+ os.path.join(path, ".."),
520
+ sdk_based=True,
521
+ )
522
+ )
523
+
524
+ return versions
525
+
526
+
527
+ def SelectVisualStudioVersion(version="auto", allow_fallback=True):
528
+ """Select which version of Visual Studio projects to generate.
529
+
530
+ Arguments:
531
+ version: Hook to allow caller to force a particular version (vs auto).
532
+ Returns:
533
+ An object representing a visual studio project format version.
534
+ """
535
+ # In auto mode, check environment variable for override.
536
+ if version == "auto":
537
+ version = os.environ.get("GYP_MSVS_VERSION", "auto")
538
+ version_map = {
539
+ "auto": ("17.0", "16.0", "15.0", "14.0", "12.0", "10.0", "9.0", "8.0", "11.0"),
540
+ "2005": ("8.0",),
541
+ "2005e": ("8.0",),
542
+ "2008": ("9.0",),
543
+ "2008e": ("9.0",),
544
+ "2010": ("10.0",),
545
+ "2010e": ("10.0",),
546
+ "2012": ("11.0",),
547
+ "2012e": ("11.0",),
548
+ "2013": ("12.0",),
549
+ "2013e": ("12.0",),
550
+ "2015": ("14.0",),
551
+ "2017": ("15.0",),
552
+ "2019": ("16.0",),
553
+ "2022": ("17.0",),
554
+ }
555
+ override_path = os.environ.get("GYP_MSVS_OVERRIDE_PATH")
556
+ if override_path:
557
+ msvs_version = os.environ.get("GYP_MSVS_VERSION")
558
+ if not msvs_version:
559
+ raise ValueError(
560
+ "GYP_MSVS_OVERRIDE_PATH requires GYP_MSVS_VERSION to be "
561
+ "set to a particular version (e.g. 2010e)."
562
+ )
563
+ return _CreateVersion(msvs_version, override_path, sdk_based=True)
564
+ version = str(version)
565
+ versions = _DetectVisualStudioVersions(version_map[version], "e" in version)
566
+ if not versions:
567
+ if not allow_fallback:
568
+ raise ValueError("Could not locate Visual Studio installation.")
569
+ if version == "auto":
570
+ # Default to 2005 if we couldn't find anything
571
+ return _CreateVersion("2005", None)
572
+ else:
573
+ return _CreateVersion(version, None)
574
+ return versions[0]