libv8 6.7.288.46.1 → 7.3.492.27.0beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (408) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +3 -0
  3. data/CHANGELOG.md +4 -0
  4. data/README.md +2 -0
  5. data/ext/libv8/builder.rb +6 -2
  6. data/lib/libv8/version.rb +1 -1
  7. data/vendor/depot_tools/.gitattributes +1 -0
  8. data/vendor/depot_tools/.gitignore +7 -0
  9. data/vendor/depot_tools/CROS_OWNERS +5 -0
  10. data/vendor/depot_tools/OWNERS +12 -1
  11. data/vendor/depot_tools/PRESUBMIT.py +16 -9
  12. data/vendor/depot_tools/README.md +9 -2
  13. data/vendor/depot_tools/autoninja +14 -6
  14. data/vendor/depot_tools/autoninja.bat +11 -1
  15. data/vendor/depot_tools/autoninja.py +40 -18
  16. data/vendor/depot_tools/bb +12 -0
  17. data/vendor/depot_tools/bb.bat +7 -0
  18. data/vendor/depot_tools/bootstrap/win/manifest.txt +1 -1
  19. data/vendor/depot_tools/bootstrap/win/manifest_bleeding_edge.txt +1 -1
  20. data/vendor/depot_tools/bootstrap/win/win_tools.py +2 -1
  21. data/vendor/depot_tools/buildbucket.py +57 -4
  22. data/vendor/depot_tools/cipd +157 -44
  23. data/vendor/depot_tools/cipd.bat +51 -14
  24. data/vendor/depot_tools/cipd.ps1 +104 -42
  25. data/vendor/depot_tools/cipd_client_version +1 -1
  26. data/vendor/depot_tools/cipd_client_version.digests +21 -0
  27. data/vendor/depot_tools/cipd_manifest.txt +19 -6
  28. data/vendor/depot_tools/cipd_manifest.versions +318 -0
  29. data/vendor/depot_tools/clang_format.py +4 -4
  30. data/vendor/depot_tools/cpplint.py +44 -199
  31. data/vendor/depot_tools/dart_format.py +2 -2
  32. data/vendor/depot_tools/detect_host_arch.py +8 -3
  33. data/vendor/depot_tools/download_from_google_storage.py +47 -39
  34. data/vendor/depot_tools/fetch.py +30 -18
  35. data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
  36. data/vendor/depot_tools/fetch_configs/chromium.py +18 -1
  37. data/vendor/depot_tools/fetch_configs/config_util.py +4 -2
  38. data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
  39. data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
  40. data/vendor/depot_tools/fix_encoding.py +3 -3
  41. data/vendor/depot_tools/gclient +1 -1
  42. data/vendor/depot_tools/gclient.py +415 -198
  43. data/vendor/depot_tools/gclient_eval.py +220 -171
  44. data/vendor/depot_tools/gclient_paths.py +142 -0
  45. data/vendor/depot_tools/gclient_scm.py +200 -51
  46. data/vendor/depot_tools/gclient_utils.py +88 -191
  47. data/vendor/depot_tools/gerrit_client.py +13 -0
  48. data/vendor/depot_tools/gerrit_util.py +158 -23
  49. data/vendor/depot_tools/git-nav-upstream +1 -1
  50. data/vendor/depot_tools/git_cache.py +77 -24
  51. data/vendor/depot_tools/git_cl.py +705 -1099
  52. data/vendor/depot_tools/git_common.py +9 -6
  53. data/vendor/depot_tools/git_map_branches.py +19 -2
  54. data/vendor/depot_tools/git_nav_downstream.py +3 -4
  55. data/vendor/depot_tools/git_rebase_update.py +14 -0
  56. data/vendor/depot_tools/git_reparent_branch.py +8 -2
  57. data/vendor/depot_tools/gn.py +38 -3
  58. data/vendor/depot_tools/gsutil.py +8 -3
  59. data/vendor/depot_tools/gsutil.py.bat +15 -0
  60. data/vendor/depot_tools/gsutil.vpython +16 -0
  61. data/vendor/depot_tools/infra/config/OWNERS +0 -1
  62. data/vendor/depot_tools/infra/config/recipes.cfg +3 -2
  63. data/vendor/depot_tools/lucicfg +12 -0
  64. data/vendor/depot_tools/lucicfg.bat +7 -0
  65. data/vendor/depot_tools/man/html/git-map-branches.html +34 -2
  66. data/vendor/depot_tools/man/html/git-new-branch.html +40 -32
  67. data/vendor/depot_tools/man/man1/git-map-branches.1 +24 -5
  68. data/vendor/depot_tools/man/man1/git-new-branch.1 +35 -27
  69. data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +1 -0
  70. data/vendor/depot_tools/man/src/git-map-branches.txt +10 -0
  71. data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +9 -4
  72. data/vendor/depot_tools/man/src/git-new-branch.txt +1 -1
  73. data/vendor/depot_tools/metrics.README.md +98 -0
  74. data/vendor/depot_tools/metrics.py +296 -0
  75. data/vendor/depot_tools/metrics_utils.py +303 -0
  76. data/vendor/depot_tools/my_activity.py +91 -29
  77. data/vendor/depot_tools/ninja +1 -1
  78. data/vendor/depot_tools/ninjalog.README.md +64 -0
  79. data/vendor/depot_tools/ninjalog_uploader.py +232 -0
  80. data/vendor/depot_tools/ninjalog_uploader_wrapper.py +116 -0
  81. data/vendor/depot_tools/owners.py +30 -13
  82. data/vendor/depot_tools/owners_finder.py +5 -2
  83. data/vendor/depot_tools/presubmit_canned_checks.py +188 -29
  84. data/vendor/depot_tools/presubmit_support.py +18 -41
  85. data/vendor/depot_tools/pylintrc +23 -19
  86. data/vendor/depot_tools/recipes/OWNERS +2 -0
  87. data/vendor/depot_tools/recipes/README.recipes.md +344 -151
  88. data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
  89. data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +2 -16
  90. data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +141 -99
  91. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +5 -8
  92. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +5 -8
  93. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +6 -98
  94. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +4 -9
  95. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +45 -5
  96. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +4 -9
  97. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +4 -9
  98. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob.json → input_commit_with_id_without_repo.json} +6 -11
  99. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob_empty_revision.json → multiple_patch_refs.json} +8 -9
  100. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +19 -29
  101. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{trychange.json → refs.json} +4 -9
  102. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +4 -9
  103. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +51 -6
  104. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +50 -6
  105. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +51 -6
  106. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +17 -25
  107. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +17 -25
  108. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +18 -26
  109. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +18 -26
  110. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +26 -28
  111. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +45 -5
  112. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +17 -25
  113. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +13 -0
  114. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name.json +13 -152
  115. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +4 -9
  116. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +185 -202
  117. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +52 -157
  118. data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +5 -14
  119. data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +34 -0
  120. data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +14 -2
  121. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +4 -5
  122. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +4 -5
  123. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +7 -5
  124. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +4 -5
  125. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +4 -5
  126. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +9 -3
  127. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +9 -3
  128. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +9 -3
  129. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +4 -5
  130. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +2 -3
  131. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +2 -3
  132. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +2 -3
  133. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +2 -3
  134. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +2 -3
  135. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +2 -3
  136. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +2 -3
  137. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +2 -3
  138. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +2 -3
  139. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +2 -3
  140. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +13 -8
  141. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +18 -12
  142. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +18 -12
  143. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +18 -12
  144. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +3 -0
  145. data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +1 -0
  146. data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +58 -46
  147. data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +65 -22
  148. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +20 -21
  149. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/buildbot.json +20 -21
  150. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +20 -21
  151. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +20 -21
  152. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +5 -2
  153. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +62 -14
  154. data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +24 -38
  155. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +56 -50
  156. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +15 -9
  157. data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +4 -1
  158. data/vendor/depot_tools/recipes/recipe_modules/git/api.py +34 -22
  159. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +5 -6
  160. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +5 -6
  161. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +5 -6
  162. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +5 -6
  163. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_luci.json +222 -0
  164. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +5 -6
  165. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +5 -6
  166. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +224 -0
  167. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +10 -6
  168. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +5 -7
  169. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +5 -6
  170. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +5 -6
  171. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +5 -7
  172. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +5 -6
  173. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +10 -5
  174. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +5 -6
  175. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +8 -9
  176. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +5 -6
  177. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +12 -8
  178. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +5 -6
  179. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +5 -6
  180. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +27 -11
  181. data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +1 -1
  182. data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +12 -13
  183. data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +5 -0
  184. data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +120 -5
  185. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +45 -3
  186. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +25 -0
  187. data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +56 -4
  188. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +6 -0
  189. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
  190. data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +24 -13
  191. data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +13 -14
  192. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/basic.json +2 -3
  193. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_linux.json +2 -3
  194. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_mac.json +2 -3
  195. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_win.json +2 -3
  196. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_linux.json +2 -3
  197. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_mac.json +2 -3
  198. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_win.json +2 -3
  199. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_linux.json +2 -3
  200. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_mac.json +2 -3
  201. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_win.json +2 -3
  202. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/path_config.py +1 -2
  203. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +35 -0
  204. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +116 -0
  205. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +22 -0
  206. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +82 -0
  207. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +22 -0
  208. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +23 -0
  209. data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +1 -0
  210. data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +2 -7
  211. data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +7 -6
  212. data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +1 -0
  213. data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +117 -8
  214. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +4 -5
  215. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/set_failure_hash_with_no_steps.json +7 -4
  216. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +98 -7
  217. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +147 -0
  218. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch.json +8 -5
  219. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch_luci.json +8 -5
  220. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +9 -6
  221. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +9 -6
  222. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +27 -2
  223. data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -0
  224. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/__init__.py +25 -0
  225. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/api.py +137 -0
  226. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/linux.json +22 -0
  227. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +22 -0
  228. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +107 -0
  229. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +26 -0
  230. data/vendor/depot_tools/recipes/recipes.py +37 -27
  231. data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +7 -10
  232. data/vendor/depot_tools/repo +34 -8
  233. data/vendor/depot_tools/roll_dep.py +52 -49
  234. data/vendor/depot_tools/scm.py +38 -23
  235. data/vendor/depot_tools/setup_color.py +4 -2
  236. data/vendor/depot_tools/split_cl.py +32 -4
  237. data/vendor/depot_tools/subprocess2.py +22 -4
  238. data/vendor/depot_tools/third_party/httplib2/README.chromium +2 -2
  239. data/vendor/depot_tools/third_party/httplib2/__init__.py +242 -158
  240. data/vendor/depot_tools/third_party/httplib2/cacerts.txt +57 -44
  241. data/vendor/depot_tools/third_party/httplib2/socks.py +15 -5
  242. data/vendor/depot_tools/third_party/logilab/README.chromium +2 -4
  243. data/vendor/depot_tools/third_party/logilab/astroid/README.chromium +2 -1
  244. data/vendor/depot_tools/third_party/logilab/astroid/__init__.py +10 -5
  245. data/vendor/depot_tools/third_party/logilab/astroid/__pkginfo__.py +5 -5
  246. data/vendor/depot_tools/third_party/logilab/astroid/arguments.py +233 -0
  247. data/vendor/depot_tools/third_party/logilab/astroid/as_string.py +82 -33
  248. data/vendor/depot_tools/third_party/logilab/astroid/bases.py +137 -153
  249. data/vendor/depot_tools/third_party/logilab/astroid/brain/{builtin_inference.py → brain_builtin_inference.py} +117 -26
  250. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_dateutil.py +15 -0
  251. data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2gi.py → brain_gi.py} +48 -8
  252. data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2mechanize.py → brain_mechanize.py} +0 -0
  253. data/vendor/depot_tools/third_party/logilab/astroid/brain/{pynose.py → brain_nose.py} +4 -1
  254. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_numpy.py +62 -0
  255. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_pytest.py +76 -0
  256. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_qt.py +44 -0
  257. data/vendor/depot_tools/third_party/logilab/astroid/brain/{pysix_moves.py → brain_six.py} +28 -1
  258. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_ssl.py +65 -0
  259. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_stdlib.py +473 -0
  260. data/vendor/depot_tools/third_party/logilab/astroid/builder.py +104 -81
  261. data/vendor/depot_tools/third_party/logilab/astroid/context.py +81 -0
  262. data/vendor/depot_tools/third_party/logilab/astroid/decorators.py +75 -0
  263. data/vendor/depot_tools/third_party/logilab/astroid/exceptions.py +20 -0
  264. data/vendor/depot_tools/third_party/logilab/astroid/inference.py +137 -183
  265. data/vendor/depot_tools/third_party/logilab/astroid/manager.py +45 -169
  266. data/vendor/depot_tools/third_party/logilab/astroid/mixins.py +37 -14
  267. data/vendor/depot_tools/third_party/logilab/astroid/modutils.py +112 -41
  268. data/vendor/depot_tools/third_party/logilab/astroid/node_classes.py +243 -156
  269. data/vendor/depot_tools/third_party/logilab/astroid/nodes.py +35 -22
  270. data/vendor/depot_tools/third_party/logilab/astroid/objects.py +186 -0
  271. data/vendor/depot_tools/third_party/logilab/astroid/protocols.py +157 -102
  272. data/vendor/depot_tools/third_party/logilab/astroid/raw_building.py +32 -8
  273. data/vendor/depot_tools/third_party/logilab/astroid/rebuilder.py +372 -309
  274. data/vendor/depot_tools/third_party/logilab/astroid/scoped_nodes.py +652 -420
  275. data/vendor/depot_tools/third_party/logilab/astroid/test_utils.py +4 -21
  276. data/vendor/depot_tools/third_party/logilab/astroid/transforms.py +96 -0
  277. data/vendor/depot_tools/third_party/logilab/astroid/util.py +89 -0
  278. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/LICENSE +19 -0
  279. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/README.chromium +11 -0
  280. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/__init__.py +20 -0
  281. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/cext.c +1421 -0
  282. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/compat.py +9 -0
  283. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/simple.py +246 -0
  284. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/slots.py +414 -0
  285. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/utils.py +13 -0
  286. data/vendor/depot_tools/third_party/logilab/wrapt/LICENSE +24 -0
  287. data/vendor/depot_tools/third_party/logilab/wrapt/README.chromium +11 -0
  288. data/vendor/depot_tools/third_party/logilab/wrapt/__init__.py +19 -0
  289. data/vendor/depot_tools/third_party/logilab/wrapt/_wrappers.c +2729 -0
  290. data/vendor/depot_tools/third_party/logilab/wrapt/arguments.py +96 -0
  291. data/vendor/depot_tools/third_party/logilab/wrapt/decorators.py +512 -0
  292. data/vendor/depot_tools/third_party/logilab/wrapt/importer.py +228 -0
  293. data/vendor/depot_tools/third_party/logilab/wrapt/wrappers.py +901 -0
  294. data/vendor/depot_tools/third_party/pylint/README.chromium +2 -25
  295. data/vendor/depot_tools/third_party/pylint/__pkginfo__.py +13 -3
  296. data/vendor/depot_tools/third_party/pylint/checkers/__init__.py +1 -2
  297. data/vendor/depot_tools/third_party/pylint/checkers/async.py +82 -0
  298. data/vendor/depot_tools/third_party/pylint/checkers/base.py +893 -119
  299. data/vendor/depot_tools/third_party/pylint/checkers/classes.py +342 -204
  300. data/vendor/depot_tools/third_party/pylint/checkers/design_analysis.py +51 -34
  301. data/vendor/depot_tools/third_party/pylint/checkers/exceptions.py +84 -47
  302. data/vendor/depot_tools/third_party/pylint/checkers/format.py +55 -30
  303. data/vendor/depot_tools/third_party/pylint/checkers/imports.py +314 -73
  304. data/vendor/depot_tools/third_party/pylint/checkers/logging.py +10 -8
  305. data/vendor/depot_tools/third_party/pylint/checkers/misc.py +2 -1
  306. data/vendor/depot_tools/third_party/pylint/checkers/newstyle.py +45 -48
  307. data/vendor/depot_tools/third_party/pylint/checkers/python3.py +31 -21
  308. data/vendor/depot_tools/third_party/pylint/checkers/raw_metrics.py +3 -3
  309. data/vendor/depot_tools/third_party/pylint/checkers/similar.py +4 -5
  310. data/vendor/depot_tools/third_party/pylint/checkers/spelling.py +24 -10
  311. data/vendor/depot_tools/third_party/pylint/checkers/stdlib.py +120 -56
  312. data/vendor/depot_tools/third_party/pylint/checkers/strings.py +38 -35
  313. data/vendor/depot_tools/third_party/pylint/checkers/typecheck.py +485 -138
  314. data/vendor/depot_tools/third_party/pylint/checkers/utils.py +319 -142
  315. data/vendor/depot_tools/third_party/pylint/checkers/variables.py +329 -207
  316. data/vendor/depot_tools/third_party/pylint/config.py +739 -76
  317. data/vendor/depot_tools/third_party/pylint/epylint.py +9 -5
  318. data/vendor/depot_tools/third_party/pylint/extensions/__init__.py +0 -0
  319. data/vendor/depot_tools/third_party/pylint/extensions/check_docs.py +311 -0
  320. data/vendor/depot_tools/third_party/pylint/extensions/check_elif.py +62 -0
  321. data/vendor/depot_tools/third_party/{logilab/common → pylint}/graph.py +30 -133
  322. data/vendor/depot_tools/third_party/pylint/gui.py +2 -2
  323. data/vendor/depot_tools/third_party/pylint/interfaces.py +21 -3
  324. data/vendor/depot_tools/third_party/pylint/lint.py +123 -140
  325. data/vendor/depot_tools/third_party/pylint/pyreverse/diadefslib.py +10 -13
  326. data/vendor/depot_tools/third_party/pylint/pyreverse/diagrams.py +15 -4
  327. data/vendor/depot_tools/third_party/pylint/pyreverse/inspector.py +372 -0
  328. data/vendor/depot_tools/third_party/pylint/pyreverse/main.py +30 -7
  329. data/vendor/depot_tools/third_party/pylint/pyreverse/utils.py +80 -2
  330. data/vendor/depot_tools/third_party/{logilab/common → pylint/pyreverse}/vcgutils.py +19 -37
  331. data/vendor/depot_tools/third_party/pylint/pyreverse/writer.py +3 -4
  332. data/vendor/depot_tools/third_party/pylint/reporters/__init__.py +34 -18
  333. data/vendor/depot_tools/third_party/pylint/reporters/guireporter.py +1 -1
  334. data/vendor/depot_tools/third_party/pylint/reporters/html.py +10 -3
  335. data/vendor/depot_tools/third_party/pylint/reporters/json.py +10 -4
  336. data/vendor/depot_tools/third_party/pylint/reporters/text.py +94 -3
  337. data/vendor/depot_tools/third_party/pylint/reporters/ureports/__init__.py +106 -0
  338. data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/html_writer.py +17 -57
  339. data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/nodes.py +52 -74
  340. data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/text_writer.py +14 -60
  341. data/vendor/depot_tools/third_party/pylint/testutils.py +22 -20
  342. data/vendor/depot_tools/third_party/pylint/utils.py +268 -44
  343. data/vendor/depot_tools/third_party/repo/progress.py +42 -0
  344. data/vendor/depot_tools/update_depot_tools +1 -1
  345. data/vendor/depot_tools/upload_metrics.py +25 -0
  346. data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +45 -15
  347. data/vendor/depot_tools/win_toolchain/package_from_installed.py +71 -24
  348. data/vendor/depot_tools/yapf +1 -1
  349. data/vendor/depot_tools/yapf.bat +1 -1
  350. metadata +92 -77
  351. data/vendor/depot_tools/git-crsync +0 -3
  352. data/vendor/depot_tools/infra/config/cq.cfg +0 -32
  353. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref.json +0 -29
  354. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref_custom.json +0 -29
  355. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/buildbot.json +0 -105
  356. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/shallow.json +0 -195
  357. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle_deprecated.json +0 -248
  358. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8.json +0 -248
  359. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name_no_patch.json +0 -105
  360. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/apply_gerrit.py +0 -33
  361. data/vendor/depot_tools/third_party/logilab/astroid/brain/py2pytest.py +0 -31
  362. data/vendor/depot_tools/third_party/logilab/astroid/brain/py2qt4.py +0 -22
  363. data/vendor/depot_tools/third_party/logilab/astroid/brain/py2stdlib.py +0 -334
  364. data/vendor/depot_tools/third_party/logilab/astroid/inspector.py +0 -273
  365. data/vendor/depot_tools/third_party/logilab/astroid/utils.py +0 -239
  366. data/vendor/depot_tools/third_party/logilab/common/LICENSE.txt +0 -339
  367. data/vendor/depot_tools/third_party/logilab/common/README.chromium +0 -11
  368. data/vendor/depot_tools/third_party/logilab/common/__init__.py +0 -175
  369. data/vendor/depot_tools/third_party/logilab/common/__pkginfo__.py +0 -57
  370. data/vendor/depot_tools/third_party/logilab/common/cache.py +0 -114
  371. data/vendor/depot_tools/third_party/logilab/common/changelog.py +0 -238
  372. data/vendor/depot_tools/third_party/logilab/common/clcommands.py +0 -334
  373. data/vendor/depot_tools/third_party/logilab/common/cli.py +0 -211
  374. data/vendor/depot_tools/third_party/logilab/common/compat.py +0 -78
  375. data/vendor/depot_tools/third_party/logilab/common/configuration.py +0 -1105
  376. data/vendor/depot_tools/third_party/logilab/common/contexts.py +0 -5
  377. data/vendor/depot_tools/third_party/logilab/common/corbautils.py +0 -117
  378. data/vendor/depot_tools/third_party/logilab/common/daemon.py +0 -101
  379. data/vendor/depot_tools/third_party/logilab/common/date.py +0 -335
  380. data/vendor/depot_tools/third_party/logilab/common/dbf.py +0 -231
  381. data/vendor/depot_tools/third_party/logilab/common/debugger.py +0 -214
  382. data/vendor/depot_tools/third_party/logilab/common/decorators.py +0 -281
  383. data/vendor/depot_tools/third_party/logilab/common/deprecation.py +0 -189
  384. data/vendor/depot_tools/third_party/logilab/common/fileutils.py +0 -404
  385. data/vendor/depot_tools/third_party/logilab/common/interface.py +0 -71
  386. data/vendor/depot_tools/third_party/logilab/common/logging_ext.py +0 -195
  387. data/vendor/depot_tools/third_party/logilab/common/modutils.py +0 -702
  388. data/vendor/depot_tools/third_party/logilab/common/optik_ext.py +0 -392
  389. data/vendor/depot_tools/third_party/logilab/common/optparser.py +0 -92
  390. data/vendor/depot_tools/third_party/logilab/common/proc.py +0 -277
  391. data/vendor/depot_tools/third_party/logilab/common/pyro_ext.py +0 -180
  392. data/vendor/depot_tools/third_party/logilab/common/pytest.py +0 -1199
  393. data/vendor/depot_tools/third_party/logilab/common/registry.py +0 -1119
  394. data/vendor/depot_tools/third_party/logilab/common/shellutils.py +0 -462
  395. data/vendor/depot_tools/third_party/logilab/common/sphinx_ext.py +0 -87
  396. data/vendor/depot_tools/third_party/logilab/common/sphinxutils.py +0 -122
  397. data/vendor/depot_tools/third_party/logilab/common/table.py +0 -929
  398. data/vendor/depot_tools/third_party/logilab/common/tasksqueue.py +0 -101
  399. data/vendor/depot_tools/third_party/logilab/common/testlib.py +0 -1392
  400. data/vendor/depot_tools/third_party/logilab/common/textutils.py +0 -537
  401. data/vendor/depot_tools/third_party/logilab/common/tree.py +0 -369
  402. data/vendor/depot_tools/third_party/logilab/common/umessage.py +0 -194
  403. data/vendor/depot_tools/third_party/logilab/common/ureports/__init__.py +0 -172
  404. data/vendor/depot_tools/third_party/logilab/common/ureports/docbook_writer.py +0 -140
  405. data/vendor/depot_tools/third_party/logilab/common/urllib2ext.py +0 -89
  406. data/vendor/depot_tools/third_party/logilab/common/visitor.py +0 -109
  407. data/vendor/depot_tools/third_party/logilab/common/xmlrpcutils.py +0 -131
  408. data/vendor/depot_tools/third_party/logilab/common/xmlutils.py +0 -61
@@ -6,34 +6,31 @@
6
6
 
7
7
  set -e -o pipefail
8
8
 
9
- CYGWIN=false
10
9
  MYPATH=$(dirname "${BASH_SOURCE[0]}")
11
-
12
- : ${CIPD_CLIENT_VER:=`cat $MYPATH/cipd_client_version`}
13
- : ${CIPD_CLIENT_SRV:='https://chrome-infra-packages.appspot.com'}
10
+ CYGWIN=false
14
11
 
15
12
  UNAME=`uname -s | tr '[:upper:]' '[:lower:]'`
16
- case $UNAME in
13
+ case "${UNAME}" in
17
14
  linux)
18
- PLAT=linux
15
+ OS=linux
19
16
  ;;
20
17
  cygwin*)
21
- PLAT=windows
18
+ OS=windows
22
19
  CYGWIN=true
23
20
  ;;
24
21
  msys*|mingw*)
25
- PLAT=windows
22
+ OS=windows
26
23
  ;;
27
24
  darwin)
28
- PLAT=mac
25
+ OS=mac
29
26
  ;;
30
27
  *)
31
- echo "cipd not supported on $UNAME"
28
+ >&2 echo "CIPD not supported on ${UNAME}"
32
29
  exit 1
33
30
  esac
34
31
 
35
32
  UNAME=`uname -m | tr '[:upper:]' '[:lower:]'`
36
- case $UNAME in
33
+ case "${UNAME}" in
37
34
  x86_64|amd64)
38
35
  ARCH=amd64
39
36
  ;;
@@ -53,68 +50,184 @@ case $UNAME in
53
50
  ARCH=armv6l
54
51
  ;;
55
52
  arm*)
56
- ARCH=$UNAME
53
+ ARCH="${UNAME}"
57
54
  ;;
58
55
  *86)
59
56
  ARCH=386
60
57
  ;;
58
+ mips*)
59
+ # detect mips64le vs mips64.
60
+ ARCH="${UNAME}"
61
+ if lscpu | grep -q "Little Endian"; then
62
+ ARCH+=le
63
+ fi
64
+ ;;
61
65
  *)
62
- echo "UNKNOWN Machine architecture: $UNAME"
66
+ >&2 echo "UNKNOWN Machine architecture: ${UNAME}"
63
67
  exit 1
64
68
  esac
65
69
 
66
- URL="$CIPD_CLIENT_SRV/client?platform=${PLAT}-${ARCH}&version=$CIPD_CLIENT_VER"
67
- CLIENT="$MYPATH/.cipd_client"
70
+ # CIPD_BACKEND can be changed to ...-dev for manual testing.
71
+ CIPD_BACKEND="https://chrome-infra-packages.appspot.com"
72
+ VERSION_FILE="${MYPATH}/cipd_client_version"
73
+
74
+ CLIENT="${MYPATH}/.cipd_client"
75
+ VERSION=`cat "${VERSION_FILE}"`
76
+ PLATFORM="${OS}-${ARCH}"
77
+
78
+ URL="${CIPD_BACKEND}/client?platform=${PLATFORM}&version=${VERSION}"
79
+ USER_AGENT="depot_tools/$(git -C ${MYPATH} rev-parse HEAD 2>/dev/null || echo "???")"
80
+
81
+
82
+ # calc_sha256 is "portable" variant of sha256sum. It uses sha256sum when
83
+ # available (most Linuxes and cygwin) and 'shasum -a 256' otherwise (for OSX).
84
+ #
85
+ # Args:
86
+ # Path to a file.
87
+ # Stdout:
88
+ # Lowercase SHA256 hex digest of the file.
89
+ function calc_sha256() {
90
+ if hash sha256sum 2> /dev/null ; then
91
+ sha256sum "$1" | cut -d' ' -f1
92
+ elif hash shasum 2> /dev/null ; then
93
+ shasum -a 256 "$1" | cut -d' ' -f1
94
+ else
95
+ >&2 echo -n ""
96
+ >&2 echo -n "Don't know how to calculate SHA256 on your platform. "
97
+ >&2 echo -n "Please use your package manager to install one before continuing:"
98
+ >&2 echo
99
+ >&2 echo " sha256sum"
100
+ >&2 echo -n " shasum"
101
+ >&2 echo ""
102
+ return 1
103
+ fi
104
+ }
105
+
106
+
107
+ # expected_sha256 reads the expected SHA256 hex digest from *.digests file.
108
+ #
109
+ # Args:
110
+ # Name of the platform to get client's digest for.
111
+ # Stdout:
112
+ # Lowercase SHA256 hex digest.
113
+ function expected_sha256() {
114
+ local line
115
+ while read -r line; do
116
+ if [[ "${line}" =~ ^([0-9a-z\-]+)[[:blank:]]+sha256[[:blank:]]+([0-9a-f]+)$ ]] ; then
117
+ local plat="${BASH_REMATCH[1]}"
118
+ local hash="${BASH_REMATCH[2]}"
119
+ if [ "${plat}" == "$1" ]; then
120
+ echo "${hash}"
121
+ return 0
122
+ fi
123
+ fi
124
+ done < "${VERSION_FILE}.digests"
125
+
126
+ >&2 echo -n ""
127
+ >&2 echo -n "Platform $1 is not supported by the CIPD client bootstrap: "
128
+ >&2 echo -n "there's no pinned SHA256 hash for it in the *.digests file."
129
+ >&2 echo ""
130
+
131
+ return 1
132
+ }
68
133
 
69
- USER_AGENT="depot_tools/$(git -C $MYPATH rev-parse HEAD 2>/dev/null || echo "???")"
70
134
 
71
- if [ ! -e "$CLIENT" ]; then
72
- echo "Bootstrapping cipd client for ${PLAT}-${ARCH} from ${URL}..."
135
+ # clean_bootstrap bootstraps the client from scratch using 'curl' or 'wget'.
136
+ #
137
+ # It checks that the SHA256 of the downloaded file is known. Exits the script
138
+ # if the client can't be downloaded or its hash doesn't match the expected one.
139
+ function clean_bootstrap() {
140
+ local expected_hash=$(expected_sha256 "${PLATFORM}")
141
+ if [ -z "${expected_hash}" ] ; then
142
+ exit 1
143
+ fi
73
144
 
74
- # Download the client into a temporary file, then move it into the final
75
- # location atomically.
145
+ # Download the client into a temporary file, check its hash, then move it into
146
+ # the final location.
76
147
  #
77
148
  # This wonky tempdir method works on Linux and Mac.
78
- CIPD_CLIENT_TMP=$(\
79
- mktemp -p "$MYPATH" 2>/dev/null || \
80
- mktemp "$MYPATH/.cipd_client.XXXXXXX")
149
+ local CIPD_CLIENT_TMP=$(\
150
+ mktemp -p "${MYPATH}" 2>/dev/null || \
151
+ mktemp "${MYPATH}/.cipd_client.XXXXXXX")
81
152
 
82
153
  if hash curl 2> /dev/null ; then
83
- curl "$URL" -s --show-error -f -A "$USER_AGENT" -L -o "$CIPD_CLIENT_TMP"
154
+ curl "${URL}" -s --show-error -f -A "${USER_AGENT}" -L -o "${CIPD_CLIENT_TMP}"
84
155
  elif hash wget 2> /dev/null ; then
85
- wget "$URL" -q -U "${USER_AGENT}" -O "${CIPD_CLIENT_TMP}"
156
+ wget "${URL}" -q -U "${USER_AGENT}" -O "${CIPD_CLIENT_TMP}"
86
157
  else
87
- echo Your platform is missing a supported fetch command. Please use your package
88
- echo manager to install one before continuing:
89
- echo
90
- echo curl
91
- echo wget
92
- echo
93
- echo Alternately, manually download:
94
- echo "$URL"
95
- echo To $CLIENT, and then re-run this command.
158
+ >&2 echo -n ""
159
+ >&2 echo -n "Your platform is missing a supported fetch command. "
160
+ >&2 echo "Please use your package manager to install one before continuing:"
161
+ >&2 echo
162
+ >&2 echo " curl"
163
+ >&2 echo " wget"
164
+ >&2 echo
165
+ >&2 echo "Alternately, manually download:"
166
+ >&2 echo " ${URL}"
167
+ >&2 echo -n "To ${CLIENT}, and then re-run this command."
168
+ >&2 echo ""
96
169
  rm "${CIPD_CLIENT_TMP}"
97
170
  exit 1
98
171
  fi
99
172
 
100
- chmod +x "$CIPD_CLIENT_TMP"
173
+ local actual_hash=$(calc_sha256 "${CIPD_CLIENT_TMP}")
174
+ if [ -z "${actual_hash}" ] ; then
175
+ rm "${CIPD_CLIENT_TMP}"
176
+ exit 1
177
+ fi
178
+
179
+ if [ "${actual_hash}" != "${expected_hash}" ]; then
180
+ >&2 echo -n ""
181
+ >&2 echo "SHA256 digest of the downloaded CIPD client is incorrect:"
182
+ >&2 echo " Expecting ${expected_hash}"
183
+ >&2 echo " Got ${actual_hash}"
184
+ >&2 echo -n "Refusing to run it. Check that *.digests file is up-to-date."
185
+ >&2 echo ""
186
+ rm "${CIPD_CLIENT_TMP}"
187
+ exit 1
188
+ fi
101
189
 
102
190
  set +e
103
- mv "$CIPD_CLIENT_TMP" "$CLIENT"
191
+ chmod +x "${CIPD_CLIENT_TMP}"
192
+ mv "${CIPD_CLIENT_TMP}" "${CLIENT}"
104
193
  set -e
194
+ }
195
+
196
+
197
+ # self_update launches CIPD client's built-in selfupdate mechanism.
198
+ #
199
+ # It is more efficient that redownloading the binary all the time.
200
+ function self_update() {
201
+ "${CLIENT}" selfupdate -version-file "${VERSION_FILE}" -service-url "${CIPD_BACKEND}"
202
+ }
203
+
204
+
205
+ if [ ! -x "${CLIENT}" ]; then
206
+ clean_bootstrap
105
207
  fi
106
208
 
107
- export CIPD_HTTP_USER_AGENT_PREFIX=$USER_AGENT
108
- if ! "$CLIENT" selfupdate -version "$CIPD_CLIENT_VER" ; then
109
- echo -n "selfupdate failed: " 1>&2
110
- echo "run \`CIPD_HTTP_USER_AGENT_PREFIX=$USER_AGENT/manual $CLIENT selfupdate -version '$CIPD_CLIENT_VER'\` to diagnose" 1>&2
111
- echo "" 1>&2
209
+ export CIPD_HTTP_USER_AGENT_PREFIX="${USER_AGENT}"
210
+ if ! self_update 2> /dev/null ; then
211
+ >&2 echo -n ""
212
+ >&2 echo -n "CIPD selfupdate failed. "
213
+ >&2 echo -n "Trying to bootstrap the CIPD client from scratch..."
214
+ >&2 echo ""
215
+ clean_bootstrap
216
+ if ! self_update ; then # need to run it again to setup .cipd_version file
217
+ >&2 echo -n ""
218
+ >&2 echo -n "Bootstrap from scratch failed, something is seriously broken. "
219
+ >&2 echo "Run the following commands to diagnose if this is repeating:"
220
+ >&2 echo " export CIPD_HTTP_USER_AGENT_PREFIX=${USER_AGENT}/manual"
221
+ >&2 echo -n " ${CLIENT} selfupdate -version-file ${VERSION_FILE}"
222
+ >&2 echo ""
223
+ exit 1
224
+ fi
112
225
  fi
113
226
 
114
227
  # CygWin requires changing absolute paths to Windows form. Relative paths
115
228
  # are typically okay as Windows generally accepts both forward and back
116
229
  # slashes. This could possibly be constrained to only /tmp/ and /cygdrive/.
117
- if $CYGWIN; then
230
+ if ${CYGWIN}; then
118
231
  args=("$@")
119
232
  for i in `seq 2 $#`; do
120
233
  arg="${@:$i:1}"
@@ -124,7 +237,7 @@ if $CYGWIN; then
124
237
  set -- "${@:1:$last}" `cygpath -w "$arg"` "${@:$next}"
125
238
  fi
126
239
  done
127
- echo "$CLIENT" "${@}"
240
+ echo "${CLIENT}" "${@}"
128
241
  fi
129
242
 
130
- exec "$CLIENT" "${@}"
243
+ exec "${CLIENT}" "${@}"
@@ -5,26 +5,63 @@
5
5
 
6
6
  setlocal
7
7
 
8
- :: To allow this powershell script to run if it was a byproduct of downloading
9
- :: and unzipping the depot_tools.zip distribution, we clear the Zone.Identifier
10
- :: alternate data stream. This is equivalent to clicking the "Unblock" button
11
- :: in the file's properties dialog.
12
- set errorlevel=
13
- if not exist "%~dp0.cipd_client.exe" (
14
- echo.>%~dp0cipd.ps1:Zone.Identifier
8
+ set CIPD_BACKEND=https://chrome-infra-packages.appspot.com
9
+ set VERSION_FILE="%~dp0cipd_client_version"
10
+ set CIPD_BINARY="%~dp0.cipd_client.exe"
11
+
12
+ if not exist %CIPD_BINARY% (
13
+ call :CLEAN_BOOTSTRAP
14
+ goto :EXEC_CIPD
15
+ )
15
16
 
16
- powershell -NoProfile -ExecutionPolicy RemoteSigned -Command "%~dp0cipd.ps1" < nul
17
- if not errorlevel 0 goto :END
17
+ call :SELF_UPDATE >nul 2>&1
18
+ if %ERRORLEVEL% neq 0 (
19
+ echo CIPD client self-update failed, trying to bootstrap it from scratch... 1>&2
20
+ call :CLEAN_BOOTSTRAP
18
21
  )
19
22
 
20
- for /f %%i in (%~dp0cipd_client_version) do set CIPD_CLIENT_VER=%%i
21
- "%~dp0.cipd_client.exe" selfupdate -version "%CIPD_CLIENT_VER%"
22
- if not errorlevel 0 goto :END
23
+ :EXEC_CIPD
23
24
 
24
- "%~dp0.cipd_client.exe" %*
25
+ if %ERRORLEVEL% neq 0 (
26
+ echo Failed to bootstrap or update CIPD client 1>&2
27
+ )
28
+ if %ERRORLEVEL% equ 0 (
29
+ "%CIPD_BINARY%" %*
30
+ )
25
31
 
26
- :END
27
32
  endlocal & (
28
33
  set EXPORT_ERRORLEVEL=%ERRORLEVEL%
29
34
  )
30
35
  exit /b %EXPORT_ERRORLEVEL%
36
+
37
+
38
+ :: Functions below.
39
+ ::
40
+ :: See http://steve-jansen.github.io/guides/windows-batch-scripting/part-7-functions.html
41
+ :: if you are unfamiliar with this madness.
42
+
43
+
44
+ :CLEAN_BOOTSTRAP
45
+ :: To allow this powershell script to run if it was a byproduct of downloading
46
+ :: and unzipping the depot_tools.zip distribution, we clear the Zone.Identifier
47
+ :: alternate data stream. This is equivalent to clicking the "Unblock" button
48
+ :: in the file's properties dialog.
49
+ echo.>%~dp0cipd.ps1:Zone.Identifier
50
+ powershell -NoProfile -ExecutionPolicy RemoteSigned ^
51
+ -Command "%~dp0cipd.ps1" ^
52
+ -CipdBinary "%CIPD_BINARY%" ^
53
+ -BackendURL "%CIPD_BACKEND%" ^
54
+ -VersionFile "%VERSION_FILE%" ^
55
+ <nul
56
+ if %ERRORLEVEL% equ 0 (
57
+ :: Need to call SELF_UPDATE to setup .cipd_version file.
58
+ call :SELF_UPDATE
59
+ )
60
+ exit /B %ERRORLEVEL%
61
+
62
+
63
+ :SELF_UPDATE
64
+ "%CIPD_BINARY%" selfupdate ^
65
+ -version-file "%VERSION_FILE%" ^
66
+ -service-url "%CIPD_BACKEND%"
67
+ exit /B %ERRORLEVEL%
@@ -2,66 +2,128 @@
2
2
  # Use of this source code is governed by a BSD-style license that can be
3
3
  # found in the LICENSE file.
4
4
 
5
- $myPath = Split-Path $MyInvocation.MyCommand.Path -Parent
5
+ # Note: to run this on e.g. OSX for adhoc testing or debugging in case Windows
6
+ # is not around:
7
+ #
8
+ # pwsh cipd.ps1 \
9
+ # -CipdBinary _cipd.exe \
10
+ # -BackendURL https://chrome-infra-packages.appspot.com \
11
+ # -VersionFile ./cipd_client_version
12
+ # file _cipd.exe
6
13
 
7
- function GetEnvVar([string] $key, [scriptblock] $defaultFn) {
8
- if (Test-Path "Env:\$key") {
9
- return Get-ChildItem $Env $key
10
- }
11
- return $defaultFn.Invoke()
12
- }
14
+ Param(
15
+ # Path to download the CIPD binary to.
16
+ [parameter(Mandatory=$true)][string]$CipdBinary,
17
+ # E.g. "https://chrome-infra-packages.appspot.com".
18
+ [parameter(Mandatory=$true)][string]$BackendURL,
19
+ # Path to the cipd_client_version file with the client version.
20
+ [parameter(Mandatory=$true)][string]$VersionFile
21
+ )
13
22
 
14
- $cipdClientVer = GetEnvVar "CIPD_CLIENT_VER" {
15
- Get-Content (Join-Path $myPath -ChildPath 'cipd_client_version') -TotalCount 1
16
- }
17
- $cipdClientSrv = GetEnvVar "CIPD_CLIENT_SRV" {
18
- "https://chrome-infra-packages.appspot.com"
19
- }
23
+ $DepotToolsPath = Split-Path $MyInvocation.MyCommand.Path -Parent
20
24
 
21
- $plat="windows"
22
- if ([environment]::Is64BitOperatingSystem) {
23
- $arch="amd64"
25
+ if ([System.IntPtr]::Size -eq 8) {
26
+ $Platform = "windows-amd64"
24
27
  } else {
25
- $arch="386"
28
+ $Platform = "windows-386"
26
29
  }
27
30
 
28
- $url = "$cipdClientSrv/client?platform=$plat-$arch&version=$cipdClientVer"
29
- $client = Join-Path $myPath -ChildPath ".cipd_client.exe"
30
-
31
+ # Put depot_tool's git revision into the user agent string.
31
32
  try {
32
- $depot_tools_version = &git -C $myPath rev-parse HEAD 2>&1
33
+ $DepotToolsVersion = &git -C $DepotToolsPath rev-parse HEAD 2>&1
33
34
  if ($LastExitCode -eq 0) {
34
- $user_agent = "depot_tools/$depot_tools_version"
35
+ $UserAgent = "depot_tools/$DepotToolsVersion"
35
36
  } else {
36
- $user_agent = "depot_tools/???"
37
+ $UserAgent = "depot_tools/???"
37
38
  }
38
39
  } catch [System.Management.Automation.CommandNotFoundException] {
39
- $user_agent = "depot_tools/no_git/???"
40
+ $UserAgent = "depot_tools/no_git/???"
40
41
  }
42
+ $Env:CIPD_HTTP_USER_AGENT_PREFIX = $UserAgent
41
43
 
42
- $Env:CIPD_HTTP_USER_AGENT_PREFIX = $user_agent
43
44
 
44
- # Use a lock fle to prevent simultaneous processes from stepping on each other.
45
- $cipd_lock = Join-Path $myPath -ChildPath '.cipd_client.lock'
46
- while ($true) {
47
- $cipd_lock_file = $false
45
+ # Tries to delete the file, ignoring errors. Used for best-effort cleanups.
46
+ function Delete-If-Possible($path) {
48
47
  try {
49
- $cipd_lock_file = [IO.File]::OpenWrite($cipd_lock)
48
+ [System.IO.File]::Delete($path)
49
+ } catch {
50
+ $err = $_.Exception.Message
51
+ echo "Warning: error when deleting $path - $err. Ignoring."
52
+ }
53
+ }
50
54
 
51
- if (!(Test-Path $client)) {
52
- echo "Bootstrapping cipd client for $plat-$arch from $url..."
53
55
 
54
- $wc = (New-Object System.Net.WebClient)
55
- $wc.Headers.add('User-Agent', $user_agent)
56
- $wc.DownloadFile($url, $client)
56
+ # Returns the expected SHA256 hex digest for the given platform reading it from
57
+ # *.digests file.
58
+ function Get-Expected-SHA256($platform) {
59
+ $digestsFile = $VersionFile+".digests"
60
+ foreach ($line in Get-Content $digestsFile) {
61
+ if ($line -match "^([0-9a-z\-]+)\s+sha256\s+([0-9a-f]+)$") {
62
+ if ($Matches[1] -eq $platform) {
63
+ return $Matches[2]
57
64
  }
58
- break
59
- } catch {
60
- echo "CIPD lock is held, trying again after delay..."
61
- Start-Sleep -s 1
65
+ }
66
+ }
67
+ throw "No SHA256 digests for $platform in $digestsFile"
68
+ }
69
+
70
+
71
+ # Returns SHA256 hex digest of a binary file at the given path.
72
+ function Get-Actual-SHA256($path) {
73
+ # Note: we don't use Get-FileHash to be compatible with PowerShell v3.0
74
+ $file = [System.IO.File]::Open($path, [System.IO.FileMode]::Open)
75
+ try {
76
+ $algo = New-Object System.Security.Cryptography.SHA256Managed
77
+ $hash = $algo.ComputeHash($file)
62
78
  } finally {
63
- if ($cipd_lock_file) {
64
- $cipd_lock_file.close()
65
- }
79
+ $file.Close()
80
+ }
81
+ $hex = ""
82
+ foreach ($byte in $hash) {
83
+ $hex += $byte.ToString("x2")
66
84
  }
85
+ return $hex
86
+ }
87
+
88
+
89
+ $ExpectedSHA256 = Get-Expected-SHA256 $Platform
90
+ $Version = (Get-Content $VersionFile).Trim()
91
+ $URL = "$BackendURL/client?platform=$Platform&version=$Version"
92
+
93
+
94
+ # Grab a lock to prevent simultaneous processes from stepping on each other.
95
+ # This depends on "exclusive write" file sharing mode used by OpenWrite.
96
+ $CipdLockPath = Join-Path $DepotToolsPath -ChildPath ".cipd_client.lock"
97
+ $CipdLockFile = $null
98
+ while ($CipdLockFile -eq $null) {
99
+ try {
100
+ $CipdLockFile = [System.IO.File]::OpenWrite($CipdLockPath)
101
+ } catch [System.IO.IOException] {
102
+ echo "CIPD bootstrap lock is held, trying again after delay..."
103
+ Start-Sleep -s 1
104
+ }
105
+ }
106
+
107
+ # Fetch the binary now that the lock is ours.
108
+ $TmpPath = $CipdBinary + ".tmp"
109
+ try {
110
+ echo "Downloading CIPD client for $Platform from $URL..."
111
+ $wc = (New-Object System.Net.WebClient)
112
+ $wc.Headers.Add("User-Agent", $UserAgent)
113
+ try {
114
+ $wc.DownloadFile($URL, $TmpPath)
115
+ } catch {
116
+ throw "Failed to download the file, check your network connection"
117
+ }
118
+
119
+ $ActualSHA256 = Get-Actual-SHA256 $TmpPath
120
+ if ($ActualSHA256 -ne $ExpectedSHA256) {
121
+ throw "Invalid SHA256 digest: $ActualSHA256 != $ExpectedSHA256"
122
+ }
123
+
124
+ Move-Item -LiteralPath $TmpPath -Destination $CipdBinary -Force
125
+ } finally {
126
+ $CipdLockFile.Close()
127
+ Delete-If-Possible $CipdLockPath
128
+ Delete-If-Possible $TmpPath
67
129
  }