libv8 7.8.279.23.0beta1 → 8.4.255.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (719) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/.travis.yml +11 -14
  4. data/CHANGELOG.md +7 -1
  5. data/README.md +10 -11
  6. data/Rakefile +30 -36
  7. data/ext/libv8/builder.rb +2 -1
  8. data/lib/libv8/version.rb +1 -1
  9. data/libv8.gemspec +1 -3
  10. data/vendor/depot_tools/{cipd.ps1 → .cipd_impl.ps1} +0 -0
  11. data/vendor/depot_tools/.gitattributes +1 -1
  12. data/vendor/depot_tools/.gitignore +3 -1
  13. data/vendor/depot_tools/.style.yapf +3 -1
  14. data/vendor/depot_tools/.vpython +55 -0
  15. data/vendor/depot_tools/.vpython3 +23 -0
  16. data/vendor/depot_tools/CROS_OWNERS +3 -1
  17. data/vendor/depot_tools/GOMA_OWNERS +9 -0
  18. data/vendor/depot_tools/LUCI_OWNERS +5 -0
  19. data/vendor/depot_tools/OWNERS +21 -6
  20. data/vendor/depot_tools/PRESUBMIT.py +35 -18
  21. data/vendor/depot_tools/README.git-cl.md +0 -14
  22. data/vendor/depot_tools/README.md +1 -1
  23. data/vendor/depot_tools/WATCHLISTS +2 -2
  24. data/vendor/depot_tools/auth.py +60 -772
  25. data/vendor/depot_tools/autoninja +12 -6
  26. data/vendor/depot_tools/autoninja.bat +6 -6
  27. data/vendor/depot_tools/autoninja.py +64 -27
  28. data/vendor/depot_tools/bb +1 -1
  29. data/vendor/depot_tools/bootstrap/{win/README.md → README.md} +28 -14
  30. data/vendor/depot_tools/bootstrap/{win/win_tools.py → bootstrap.py} +60 -43
  31. data/vendor/depot_tools/bootstrap/{win/git-bash.template.sh → git-bash.template.sh} +1 -1
  32. data/vendor/depot_tools/bootstrap/{win/git.template.bat → git.template.bat} +0 -0
  33. data/vendor/depot_tools/bootstrap/manifest.txt +27 -0
  34. data/vendor/depot_tools/bootstrap/manifest_bleeding_edge.txt +27 -0
  35. data/vendor/depot_tools/bootstrap/{win/profile.d.python.sh → profile.d.python.sh} +0 -0
  36. data/vendor/depot_tools/bootstrap/{win/python27.bleeding_edge.bat → python27.bat} +0 -0
  37. data/vendor/depot_tools/bootstrap/{win/python27.new.bat → python3.bat} +3 -3
  38. data/vendor/depot_tools/bootstrap/{win/win_tools.bat → win_tools.bat} +21 -16
  39. data/vendor/depot_tools/bootstrap_python3 +35 -0
  40. data/vendor/depot_tools/cbuildbot +1 -1
  41. data/vendor/depot_tools/chrome_set_ver +1 -1
  42. data/vendor/depot_tools/cipd +43 -39
  43. data/vendor/depot_tools/cipd.bat +2 -2
  44. data/vendor/depot_tools/cipd_client_version +1 -1
  45. data/vendor/depot_tools/cipd_client_version.digests +15 -14
  46. data/vendor/depot_tools/cipd_manifest.txt +31 -8
  47. data/vendor/depot_tools/cipd_manifest.versions +278 -158
  48. data/vendor/depot_tools/cit.py +9 -7
  49. data/vendor/depot_tools/clang_format.py +4 -1
  50. data/vendor/depot_tools/clang_format_merge_driver.py +10 -8
  51. data/vendor/depot_tools/compile_single_file.py +7 -2
  52. data/vendor/depot_tools/cpplint.py +51 -45
  53. data/vendor/depot_tools/cros +87 -0
  54. data/vendor/depot_tools/cros_sdk +1 -1
  55. data/vendor/depot_tools/crosjobs +13 -0
  56. data/vendor/depot_tools/detect_host_arch.py +0 -1
  57. data/vendor/depot_tools/dirmd +12 -0
  58. data/vendor/depot_tools/dirmd.bat +7 -0
  59. data/vendor/depot_tools/download_from_google_storage.py +47 -27
  60. data/vendor/depot_tools/ensure_bootstrap +14 -0
  61. data/vendor/depot_tools/fetch +14 -1
  62. data/vendor/depot_tools/fetch.bat +14 -1
  63. data/vendor/depot_tools/fetch.py +5 -7
  64. data/vendor/depot_tools/fetch_configs/chromium.py +6 -4
  65. data/vendor/depot_tools/fetch_configs/devtools-frontend.py +44 -0
  66. data/vendor/depot_tools/fetch_configs/ios_internal.py +10 -19
  67. data/vendor/depot_tools/fix_encoding.py +19 -5
  68. data/vendor/depot_tools/gclient +28 -12
  69. data/vendor/depot_tools/gclient-new-workdir.py +2 -0
  70. data/vendor/depot_tools/gclient.bat +18 -1
  71. data/vendor/depot_tools/gclient.py +156 -118
  72. data/vendor/depot_tools/gclient_eval.py +119 -107
  73. data/vendor/depot_tools/gclient_paths.py +67 -57
  74. data/vendor/depot_tools/gclient_scm.py +180 -169
  75. data/vendor/depot_tools/gclient_utils.py +177 -124
  76. data/vendor/depot_tools/gerrit_client.py +21 -13
  77. data/vendor/depot_tools/gerrit_util.py +188 -228
  78. data/vendor/depot_tools/git-cache +1 -1
  79. data/vendor/depot_tools/git-cl +1 -1
  80. data/vendor/depot_tools/git-drover +1 -1
  81. data/vendor/depot_tools/git-find-releases +1 -1
  82. data/vendor/depot_tools/git-footers +1 -1
  83. data/vendor/depot_tools/git-freeze +1 -1
  84. data/vendor/depot_tools/git-hyper-blame +1 -1
  85. data/vendor/depot_tools/git-map +1 -1
  86. data/vendor/depot_tools/git-map-branches +1 -1
  87. data/vendor/depot_tools/git-mark-merge-base +1 -1
  88. data/vendor/depot_tools/git-nav-downstream +1 -1
  89. data/vendor/depot_tools/git-new-branch +1 -1
  90. data/vendor/depot_tools/git-number +1 -1
  91. data/vendor/depot_tools/git-rebase-update +1 -1
  92. data/vendor/depot_tools/git-rename-branch +1 -1
  93. data/vendor/depot_tools/git-reparent-branch +1 -1
  94. data/vendor/depot_tools/git-retry +1 -1
  95. data/vendor/depot_tools/git-squash-branch +1 -1
  96. data/vendor/depot_tools/git-thaw +1 -1
  97. data/vendor/depot_tools/git-upstream-diff +1 -1
  98. data/vendor/depot_tools/git_cache.py +195 -281
  99. data/vendor/depot_tools/git_cl.py +1506 -2075
  100. data/vendor/depot_tools/git_cl_completion.sh +16 -2
  101. data/vendor/depot_tools/git_common.py +77 -32
  102. data/vendor/depot_tools/git_drover.py +17 -8
  103. data/vendor/depot_tools/git_find_releases.py +11 -9
  104. data/vendor/depot_tools/git_footers.py +13 -9
  105. data/vendor/depot_tools/git_freezer.py +3 -1
  106. data/vendor/depot_tools/git_hyper_blame.py +25 -32
  107. data/vendor/depot_tools/git_map.py +115 -93
  108. data/vendor/depot_tools/git_map_branches.py +11 -10
  109. data/vendor/depot_tools/git_mark_merge_base.py +8 -6
  110. data/vendor/depot_tools/git_nav_downstream.py +9 -6
  111. data/vendor/depot_tools/git_new_branch.py +39 -33
  112. data/vendor/depot_tools/git_number.py +28 -17
  113. data/vendor/depot_tools/git_rebase_update.py +50 -49
  114. data/vendor/depot_tools/git_rename_branch.py +2 -2
  115. data/vendor/depot_tools/git_reparent_branch.py +8 -6
  116. data/vendor/depot_tools/git_upstream_diff.py +4 -2
  117. data/vendor/depot_tools/gn.py +6 -4
  118. data/vendor/depot_tools/goma_auth +12 -0
  119. data/vendor/depot_tools/goma_auth.bat +8 -0
  120. data/vendor/depot_tools/goma_ctl +12 -0
  121. data/vendor/depot_tools/goma_ctl.bat +8 -0
  122. data/vendor/depot_tools/gsutil.py +5 -2
  123. data/vendor/depot_tools/gsutil.py.bat +8 -0
  124. data/vendor/depot_tools/gsutil.vpython +3 -1
  125. data/vendor/depot_tools/infra/config/OWNERS +2 -2
  126. data/vendor/depot_tools/infra/config/recipes.cfg +3 -2
  127. data/vendor/depot_tools/led +1 -1
  128. data/vendor/depot_tools/lockfile.py +116 -0
  129. data/vendor/depot_tools/luci-auth +1 -1
  130. data/vendor/depot_tools/lucicfg +1 -1
  131. data/vendor/depot_tools/mac_toolchain +1 -1
  132. data/vendor/depot_tools/man/html/depot_tools.html +1 -1
  133. data/vendor/depot_tools/man/html/depot_tools_tutorial.html +31 -25
  134. data/vendor/depot_tools/man/html/git-cl.html +1 -1
  135. data/vendor/depot_tools/man/html/git-drover.html +18 -18
  136. data/vendor/depot_tools/man/html/git-footers.html +1 -1
  137. data/vendor/depot_tools/man/html/git-freeze.html +3 -3
  138. data/vendor/depot_tools/man/html/git-hyper-blame.html +1 -1
  139. data/vendor/depot_tools/man/html/git-map-branches.html +2 -2
  140. data/vendor/depot_tools/man/html/git-map.html +1 -1
  141. data/vendor/depot_tools/man/html/git-mark-merge-base.html +1 -1
  142. data/vendor/depot_tools/man/html/git-nav-downstream.html +3 -3
  143. data/vendor/depot_tools/man/html/git-nav-upstream.html +12 -6
  144. data/vendor/depot_tools/man/html/git-new-branch.html +1 -1
  145. data/vendor/depot_tools/man/html/git-rebase-update.html +20 -1
  146. data/vendor/depot_tools/man/html/git-rename-branch.html +1 -1
  147. data/vendor/depot_tools/man/html/git-reparent-branch.html +1 -1
  148. data/vendor/depot_tools/man/html/git-retry.html +1 -1
  149. data/vendor/depot_tools/man/html/git-squash-branch.html +1 -1
  150. data/vendor/depot_tools/man/html/git-thaw.html +1 -1
  151. data/vendor/depot_tools/man/html/git-upstream-diff.html +10 -6
  152. data/vendor/depot_tools/man/man1/git-cl.1 +4 -4
  153. data/vendor/depot_tools/man/man1/git-drover.1 +21 -21
  154. data/vendor/depot_tools/man/man1/git-footers.1 +4 -4
  155. data/vendor/depot_tools/man/man1/git-freeze.1 +6 -6
  156. data/vendor/depot_tools/man/man1/git-hyper-blame.1 +4 -4
  157. data/vendor/depot_tools/man/man1/git-map-branches.1 +4 -4
  158. data/vendor/depot_tools/man/man1/git-map.1 +4 -4
  159. data/vendor/depot_tools/man/man1/git-mark-merge-base.1 +4 -4
  160. data/vendor/depot_tools/man/man1/git-nav-downstream.1 +6 -6
  161. data/vendor/depot_tools/man/man1/git-nav-upstream.1 +15 -9
  162. data/vendor/depot_tools/man/man1/git-new-branch.1 +3 -3
  163. data/vendor/depot_tools/man/man1/git-rebase-update.1 +14 -4
  164. data/vendor/depot_tools/man/man1/git-rename-branch.1 +4 -4
  165. data/vendor/depot_tools/man/man1/git-reparent-branch.1 +4 -4
  166. data/vendor/depot_tools/man/man1/git-retry.1 +4 -4
  167. data/vendor/depot_tools/man/man1/git-squash-branch.1 +4 -4
  168. data/vendor/depot_tools/man/man1/git-thaw.1 +4 -4
  169. data/vendor/depot_tools/man/man1/git-upstream-diff.1 +7 -13
  170. data/vendor/depot_tools/man/man7/depot_tools.7 +4 -4
  171. data/vendor/depot_tools/man/man7/depot_tools_tutorial.7 +31 -25
  172. data/vendor/depot_tools/man/src/common_demo_functions.sh +2 -2
  173. data/vendor/depot_tools/man/src/depot_tools_tutorial.txt +3 -3
  174. data/vendor/depot_tools/man/src/filter_demo_output.py +3 -1
  175. data/vendor/depot_tools/man/src/git-new-branch.txt +2 -1
  176. data/vendor/depot_tools/man/src/git-rebase-update.txt +8 -1
  177. data/vendor/depot_tools/metrics.README.md +5 -2
  178. data/vendor/depot_tools/metrics.py +4 -4
  179. data/vendor/depot_tools/metrics_utils.py +3 -3
  180. data/vendor/depot_tools/my_activity.py +85 -251
  181. data/vendor/depot_tools/ninja +1 -0
  182. data/vendor/depot_tools/ninja-mac +0 -0
  183. data/vendor/depot_tools/ninjalog_uploader.py +146 -145
  184. data/vendor/depot_tools/ninjalog_uploader_wrapper.py +69 -60
  185. data/vendor/depot_tools/owners.py +57 -21
  186. data/vendor/depot_tools/owners_finder.py +28 -14
  187. data/vendor/depot_tools/post_build_ninja_summary.py +76 -48
  188. data/vendor/depot_tools/presubmit_canned_checks.py +293 -106
  189. data/vendor/depot_tools/presubmit_support.py +527 -333
  190. data/vendor/depot_tools/prpc +1 -1
  191. data/vendor/depot_tools/pylint +2 -12
  192. data/vendor/depot_tools/pylint-1.5 +78 -0
  193. data/vendor/depot_tools/pylint-1.6 +78 -0
  194. data/vendor/depot_tools/pylint-1.7 +78 -0
  195. data/vendor/depot_tools/pylint-1.8 +78 -0
  196. data/vendor/depot_tools/pylint-1.9 +78 -0
  197. data/vendor/depot_tools/{depot-tools-auth.bat → pylint.bat} +2 -2
  198. data/vendor/depot_tools/pylint_main.py +45 -0
  199. data/vendor/depot_tools/pylintrc +14 -1
  200. data/vendor/depot_tools/python-bin/python3 +7 -0
  201. data/vendor/depot_tools/python_runner.sh +13 -8
  202. data/vendor/depot_tools/rdb +12 -0
  203. data/vendor/depot_tools/rdb.bat +7 -0
  204. data/vendor/depot_tools/recipes/OWNERS +0 -1
  205. data/vendor/depot_tools/recipes/README.recipes.md +215 -151
  206. data/vendor/depot_tools/recipes/recipe_modules/OWNERS +1 -1
  207. data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +17 -17
  208. data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +65 -32
  209. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +12 -4
  210. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +11 -3
  211. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +12 -4
  212. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +22 -8
  213. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +27 -9
  214. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +22 -8
  215. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +22 -8
  216. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/input_commit_with_id_without_repo.json +22 -8
  217. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/multiple_patch_refs.json +22 -8
  218. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +27 -9
  219. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_HEAD.json +12 -4
  220. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_branch_head.json +10 -4
  221. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_specific_commit.json +12 -4
  222. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_master.json +10 -4
  223. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/refs.json +22 -8
  224. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +22 -8
  225. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/resolve_chromium_fixed_version.json +117 -0
  226. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +16 -10
  227. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +34 -10
  228. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +16 -10
  229. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +27 -9
  230. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +27 -9
  231. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +27 -9
  232. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +27 -9
  233. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +27 -9
  234. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +27 -9
  235. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +27 -9
  236. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +0 -5
  237. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +22 -8
  238. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +7 -23
  239. data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +187 -114
  240. data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +2 -2
  241. data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py +42 -0
  242. data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +1 -0
  243. data/vendor/depot_tools/recipes/recipe_modules/cipd/__init__.py +0 -1
  244. data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +2 -2
  245. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +0 -1
  246. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +0 -1
  247. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +2 -4
  248. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +0 -1
  249. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +0 -1
  250. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +26 -6
  251. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +23 -5
  252. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +23 -5
  253. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +0 -1
  254. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +0 -1
  255. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +0 -1
  256. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +0 -1
  257. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +0 -1
  258. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +0 -1
  259. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +0 -1
  260. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +0 -1
  261. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +0 -1
  262. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +0 -1
  263. data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +0 -1
  264. data/vendor/depot_tools/recipes/recipe_modules/cipd/test_api.py +1 -1
  265. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +4 -1
  266. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +4 -2
  267. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +3 -1
  268. data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +4 -2
  269. data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +2 -1
  270. data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +82 -13
  271. data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +21 -9
  272. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +3 -4
  273. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +3 -6
  274. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +3 -4
  275. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +7 -7
  276. data/vendor/depot_tools/recipes/recipe_modules/gclient/resources/diff_deps.py +16 -0
  277. data/vendor/depot_tools/recipes/recipe_modules/gclient/test_api.py +4 -0
  278. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/basic.json +55 -0
  279. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/dont have revision yet.json +84 -0
  280. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/no change, exception.json +83 -0
  281. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/windows.json +55 -0
  282. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.py +88 -0
  283. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +9 -21
  284. data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/sync_failure.py +24 -0
  285. data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +2 -1
  286. data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +7 -12
  287. data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +0 -2
  288. data/vendor/depot_tools/recipes/recipe_modules/git/api.py +9 -17
  289. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +2 -8
  290. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +2 -8
  291. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +2 -8
  292. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +2 -8
  293. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +2 -8
  294. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +2 -8
  295. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +2 -8
  296. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +3 -13
  297. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +2 -8
  298. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +4 -12
  299. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +2 -10
  300. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +1 -7
  301. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +1 -7
  302. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +0 -8
  303. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +3 -10
  304. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +3 -11
  305. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +2 -8
  306. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +3 -13
  307. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +2 -8
  308. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +2 -8
  309. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +0 -5
  310. data/vendor/depot_tools/recipes/recipe_modules/git_cl/__init__.py +1 -1
  311. data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +7 -13
  312. data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +21 -16
  313. data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.py +1 -2
  314. data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +1 -1
  315. data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +0 -1
  316. data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +2 -2
  317. data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +0 -1
  318. data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +23 -8
  319. data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +52 -1
  320. data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.py +15 -0
  321. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +1 -0
  322. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +32 -8
  323. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/ancient_version.json +83 -0
  324. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/automatic_version.json +83 -0
  325. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/explicit_version.json +83 -0
  326. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +0 -1
  327. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +5 -4
  328. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +0 -1
  329. data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +21 -2
  330. data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +20 -0
  331. data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +235 -3
  332. data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +13 -5
  333. data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.py +5 -1
  334. data/vendor/depot_tools/recipes/recipe_modules/presubmit/properties.proto +14 -0
  335. data/vendor/depot_tools/recipes/recipe_modules/presubmit/test_api.py +19 -0
  336. data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/execute.py +247 -0
  337. data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/prepare.py +49 -0
  338. data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +33 -45
  339. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +0 -1
  340. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +64 -21
  341. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +64 -21
  342. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +1 -22
  343. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +1 -22
  344. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +5 -32
  345. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py +29 -0
  346. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.expected/basic.json +5 -0
  347. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py +22 -0
  348. data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py +32 -0
  349. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/linux.json +0 -1
  350. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +0 -1
  351. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +2 -1
  352. data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +1 -6
  353. data/vendor/depot_tools/recipes/recipes.py +49 -28
  354. data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +11 -6
  355. data/vendor/depot_tools/repo +698 -540
  356. data/vendor/depot_tools/roll-dep +14 -1
  357. data/vendor/depot_tools/roll-dep.bat +10 -1
  358. data/vendor/depot_tools/roll_dep.py +15 -10
  359. data/vendor/depot_tools/scm.py +94 -74
  360. data/vendor/depot_tools/setup_color.py +36 -2
  361. data/vendor/depot_tools/split_cl.py +44 -32
  362. data/vendor/depot_tools/subcommand.py +6 -6
  363. data/vendor/depot_tools/subprocess2.py +38 -322
  364. data/vendor/depot_tools/third_party/colorama/LICENSE.txt +0 -1
  365. data/vendor/depot_tools/third_party/colorama/README.chromium +4 -5
  366. data/vendor/depot_tools/third_party/colorama/README.rst +346 -0
  367. data/vendor/depot_tools/third_party/colorama/__init__.py +3 -4
  368. data/vendor/depot_tools/third_party/colorama/ansi.py +82 -30
  369. data/vendor/depot_tools/third_party/colorama/ansitowin32.py +105 -37
  370. data/vendor/depot_tools/third_party/colorama/initialise.py +39 -15
  371. data/vendor/depot_tools/third_party/colorama/win32.py +46 -28
  372. data/vendor/depot_tools/third_party/colorama/winterm.py +80 -31
  373. data/vendor/depot_tools/update_depot_tools +18 -8
  374. data/vendor/depot_tools/update_depot_tools.bat +19 -15
  375. data/vendor/depot_tools/upload_metrics.py +7 -6
  376. data/vendor/depot_tools/upload_to_google_storage.py +22 -15
  377. data/vendor/depot_tools/vpython +4 -4
  378. data/vendor/depot_tools/vpython.bat +1 -1
  379. data/vendor/depot_tools/vpython3 +55 -0
  380. data/vendor/depot_tools/vpython3.bat +12 -0
  381. data/vendor/depot_tools/watchlists.py +14 -11
  382. data/vendor/depot_tools/weekly +4 -2
  383. data/vendor/depot_tools/win32imports.py +61 -0
  384. data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +49 -41
  385. data/vendor/depot_tools/win_toolchain/package_from_installed.py +142 -149
  386. data/vendor/depot_tools/wtf +5 -3
  387. data/vendor/depot_tools/yapf +5 -1
  388. metadata +66 -345
  389. data/vendor/depot_tools/README.testing +0 -23
  390. data/vendor/depot_tools/annotated_gclient.py +0 -89
  391. data/vendor/depot_tools/appengine_mapper.py +0 -23
  392. data/vendor/depot_tools/bootstrap/win/manifest.txt +0 -20
  393. data/vendor/depot_tools/bootstrap/win/manifest_bleeding_edge.txt +0 -20
  394. data/vendor/depot_tools/bootstrap/win/pylint.new.bat +0 -7
  395. data/vendor/depot_tools/buildbucket.py +0 -186
  396. data/vendor/depot_tools/checkout.py +0 -431
  397. data/vendor/depot_tools/cros +0 -1
  398. data/vendor/depot_tools/dart_format.py +0 -58
  399. data/vendor/depot_tools/depot-tools-auth +0 -8
  400. data/vendor/depot_tools/depot-tools-auth.py +0 -102
  401. data/vendor/depot_tools/my_reviews.py +0 -396
  402. data/vendor/depot_tools/patch.py +0 -548
  403. data/vendor/depot_tools/pylint.py +0 -30
  404. data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name.json +0 -48
  405. data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/buildbot.json +0 -239
  406. data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_luci.json +0 -222
  407. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/__init__.py +0 -4
  408. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/api.py +0 -29
  409. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/basic.json +0 -15
  410. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_linux.json +0 -15
  411. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_mac.json +0 -15
  412. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_win.json +0 -15
  413. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_linux.json +0 -15
  414. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_mac.json +0 -15
  415. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_win.json +0 -15
  416. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_linux.json +0 -15
  417. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_mac.json +0 -15
  418. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_win.json +0 -15
  419. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.py +0 -33
  420. data/vendor/depot_tools/recipes/recipe_modules/infra_paths/path_config.py +0 -66
  421. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/set_failure_hash_with_no_steps.json +0 -11
  422. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch.json +0 -45
  423. data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch_luci.json +0 -45
  424. data/vendor/depot_tools/rietveld.py +0 -779
  425. data/vendor/depot_tools/roll-dep-svn +0 -8
  426. data/vendor/depot_tools/roll-dep-svn.bat +0 -12
  427. data/vendor/depot_tools/roll_dep_svn.py +0 -430
  428. data/vendor/depot_tools/support/chromite_wrapper +0 -96
  429. data/vendor/depot_tools/third_party/boto/LICENSE +0 -18
  430. data/vendor/depot_tools/third_party/boto/README.chromium +0 -43
  431. data/vendor/depot_tools/third_party/boto/README.rst +0 -163
  432. data/vendor/depot_tools/third_party/boto/__init__.py +0 -793
  433. data/vendor/depot_tools/third_party/boto/auth.py +0 -682
  434. data/vendor/depot_tools/third_party/boto/auth_handler.py +0 -58
  435. data/vendor/depot_tools/third_party/boto/cacerts/__init__.py +0 -22
  436. data/vendor/depot_tools/third_party/boto/cacerts/cacerts.txt +0 -2183
  437. data/vendor/depot_tools/third_party/boto/compat.py +0 -28
  438. data/vendor/depot_tools/third_party/boto/connection.py +0 -1081
  439. data/vendor/depot_tools/third_party/boto/contrib/__init__.py +0 -22
  440. data/vendor/depot_tools/third_party/boto/contrib/ymlmessage.py +0 -52
  441. data/vendor/depot_tools/third_party/boto/core/README +0 -58
  442. data/vendor/depot_tools/third_party/boto/core/__init__.py +0 -23
  443. data/vendor/depot_tools/third_party/boto/core/auth.py +0 -78
  444. data/vendor/depot_tools/third_party/boto/core/credentials.py +0 -154
  445. data/vendor/depot_tools/third_party/boto/core/dictresponse.py +0 -178
  446. data/vendor/depot_tools/third_party/boto/core/service.py +0 -67
  447. data/vendor/depot_tools/third_party/boto/datapipeline/__init__.py +0 -0
  448. data/vendor/depot_tools/third_party/boto/datapipeline/exceptions.py +0 -42
  449. data/vendor/depot_tools/third_party/boto/datapipeline/layer1.py +0 -546
  450. data/vendor/depot_tools/third_party/boto/ecs/__init__.py +0 -90
  451. data/vendor/depot_tools/third_party/boto/ecs/item.py +0 -153
  452. data/vendor/depot_tools/third_party/boto/exception.py +0 -476
  453. data/vendor/depot_tools/third_party/boto/file/README +0 -49
  454. data/vendor/depot_tools/third_party/boto/file/__init__.py +0 -28
  455. data/vendor/depot_tools/third_party/boto/file/bucket.py +0 -112
  456. data/vendor/depot_tools/third_party/boto/file/connection.py +0 -33
  457. data/vendor/depot_tools/third_party/boto/file/key.py +0 -199
  458. data/vendor/depot_tools/third_party/boto/file/simpleresultset.py +0 -30
  459. data/vendor/depot_tools/third_party/boto/fps/__init__.py +0 -21
  460. data/vendor/depot_tools/third_party/boto/fps/connection.py +0 -369
  461. data/vendor/depot_tools/third_party/boto/fps/exception.py +0 -344
  462. data/vendor/depot_tools/third_party/boto/fps/response.py +0 -175
  463. data/vendor/depot_tools/third_party/boto/gs/__init__.py +0 -22
  464. data/vendor/depot_tools/third_party/boto/gs/acl.py +0 -304
  465. data/vendor/depot_tools/third_party/boto/gs/bucket.py +0 -870
  466. data/vendor/depot_tools/third_party/boto/gs/bucketlistresultset.py +0 -64
  467. data/vendor/depot_tools/third_party/boto/gs/connection.py +0 -103
  468. data/vendor/depot_tools/third_party/boto/gs/cors.py +0 -169
  469. data/vendor/depot_tools/third_party/boto/gs/key.py +0 -704
  470. data/vendor/depot_tools/third_party/boto/gs/resumable_upload_handler.py +0 -659
  471. data/vendor/depot_tools/third_party/boto/gs/user.py +0 -54
  472. data/vendor/depot_tools/third_party/boto/handler.py +0 -44
  473. data/vendor/depot_tools/third_party/boto/https_connection.py +0 -124
  474. data/vendor/depot_tools/third_party/boto/jsonresponse.py +0 -163
  475. data/vendor/depot_tools/third_party/boto/manage/__init__.py +0 -23
  476. data/vendor/depot_tools/third_party/boto/manage/cmdshell.py +0 -241
  477. data/vendor/depot_tools/third_party/boto/manage/propget.py +0 -64
  478. data/vendor/depot_tools/third_party/boto/manage/server.py +0 -556
  479. data/vendor/depot_tools/third_party/boto/manage/task.py +0 -175
  480. data/vendor/depot_tools/third_party/boto/manage/test_manage.py +0 -34
  481. data/vendor/depot_tools/third_party/boto/manage/volume.py +0 -420
  482. data/vendor/depot_tools/third_party/boto/mashups/__init__.py +0 -23
  483. data/vendor/depot_tools/third_party/boto/mashups/interactive.py +0 -97
  484. data/vendor/depot_tools/third_party/boto/mashups/iobject.py +0 -115
  485. data/vendor/depot_tools/third_party/boto/mashups/order.py +0 -211
  486. data/vendor/depot_tools/third_party/boto/mashups/server.py +0 -395
  487. data/vendor/depot_tools/third_party/boto/plugin.py +0 -90
  488. data/vendor/depot_tools/third_party/boto/provider.py +0 -337
  489. data/vendor/depot_tools/third_party/boto/pyami/__init__.py +0 -22
  490. data/vendor/depot_tools/third_party/boto/pyami/bootstrap.py +0 -134
  491. data/vendor/depot_tools/third_party/boto/pyami/config.py +0 -229
  492. data/vendor/depot_tools/third_party/boto/pyami/copybot.cfg +0 -60
  493. data/vendor/depot_tools/third_party/boto/pyami/copybot.py +0 -97
  494. data/vendor/depot_tools/third_party/boto/pyami/helloworld.py +0 -28
  495. data/vendor/depot_tools/third_party/boto/pyami/launch_ami.py +0 -178
  496. data/vendor/depot_tools/third_party/boto/pyami/scriptbase.py +0 -44
  497. data/vendor/depot_tools/third_party/boto/pyami/startup.py +0 -60
  498. data/vendor/depot_tools/third_party/boto/regioninfo.py +0 -63
  499. data/vendor/depot_tools/third_party/boto/resultset.py +0 -169
  500. data/vendor/depot_tools/third_party/boto/roboto/__init__.py +0 -1
  501. data/vendor/depot_tools/third_party/boto/roboto/awsqueryrequest.py +0 -504
  502. data/vendor/depot_tools/third_party/boto/roboto/awsqueryservice.py +0 -121
  503. data/vendor/depot_tools/third_party/boto/roboto/param.py +0 -147
  504. data/vendor/depot_tools/third_party/boto/s3/__init__.py +0 -84
  505. data/vendor/depot_tools/third_party/boto/s3/acl.py +0 -164
  506. data/vendor/depot_tools/third_party/boto/s3/bucket.py +0 -1634
  507. data/vendor/depot_tools/third_party/boto/s3/bucketlistresultset.py +0 -139
  508. data/vendor/depot_tools/third_party/boto/s3/bucketlogging.py +0 -83
  509. data/vendor/depot_tools/third_party/boto/s3/connection.py +0 -540
  510. data/vendor/depot_tools/third_party/boto/s3/cors.py +0 -210
  511. data/vendor/depot_tools/third_party/boto/s3/deletemarker.py +0 -55
  512. data/vendor/depot_tools/third_party/boto/s3/key.py +0 -1712
  513. data/vendor/depot_tools/third_party/boto/s3/keyfile.py +0 -134
  514. data/vendor/depot_tools/third_party/boto/s3/lifecycle.py +0 -231
  515. data/vendor/depot_tools/third_party/boto/s3/multidelete.py +0 -138
  516. data/vendor/depot_tools/third_party/boto/s3/multipart.py +0 -315
  517. data/vendor/depot_tools/third_party/boto/s3/prefix.py +0 -42
  518. data/vendor/depot_tools/third_party/boto/s3/resumable_download_handler.py +0 -339
  519. data/vendor/depot_tools/third_party/boto/s3/tagging.py +0 -71
  520. data/vendor/depot_tools/third_party/boto/s3/user.py +0 -49
  521. data/vendor/depot_tools/third_party/boto/s3/website.py +0 -237
  522. data/vendor/depot_tools/third_party/boto/services/__init__.py +0 -23
  523. data/vendor/depot_tools/third_party/boto/services/bs.py +0 -179
  524. data/vendor/depot_tools/third_party/boto/services/message.py +0 -58
  525. data/vendor/depot_tools/third_party/boto/services/result.py +0 -136
  526. data/vendor/depot_tools/third_party/boto/services/service.py +0 -161
  527. data/vendor/depot_tools/third_party/boto/services/servicedef.py +0 -91
  528. data/vendor/depot_tools/third_party/boto/services/sonofmmm.cfg +0 -43
  529. data/vendor/depot_tools/third_party/boto/services/sonofmmm.py +0 -81
  530. data/vendor/depot_tools/third_party/boto/services/submit.py +0 -88
  531. data/vendor/depot_tools/third_party/boto/ses/__init__.py +0 -54
  532. data/vendor/depot_tools/third_party/boto/ses/connection.py +0 -521
  533. data/vendor/depot_tools/third_party/boto/ses/exceptions.py +0 -77
  534. data/vendor/depot_tools/third_party/boto/storage_uri.py +0 -835
  535. data/vendor/depot_tools/third_party/boto/sts/__init__.py +0 -55
  536. data/vendor/depot_tools/third_party/boto/sts/connection.py +0 -207
  537. data/vendor/depot_tools/third_party/boto/sts/credentials.py +0 -215
  538. data/vendor/depot_tools/third_party/boto/utils.py +0 -927
  539. data/vendor/depot_tools/third_party/colorama/README.txt +0 -304
  540. data/vendor/depot_tools/third_party/fancy_urllib/README +0 -22
  541. data/vendor/depot_tools/third_party/fancy_urllib/__init__.py +0 -460
  542. data/vendor/depot_tools/third_party/logilab/README.chromium +0 -6
  543. data/vendor/depot_tools/third_party/logilab/__init__.py +0 -0
  544. data/vendor/depot_tools/third_party/logilab/astroid/LICENSE.txt +0 -340
  545. data/vendor/depot_tools/third_party/logilab/astroid/README.chromium +0 -11
  546. data/vendor/depot_tools/third_party/logilab/astroid/__init__.py +0 -136
  547. data/vendor/depot_tools/third_party/logilab/astroid/__pkginfo__.py +0 -42
  548. data/vendor/depot_tools/third_party/logilab/astroid/arguments.py +0 -233
  549. data/vendor/depot_tools/third_party/logilab/astroid/as_string.py +0 -548
  550. data/vendor/depot_tools/third_party/logilab/astroid/astpeephole.py +0 -86
  551. data/vendor/depot_tools/third_party/logilab/astroid/bases.py +0 -636
  552. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_builtin_inference.py +0 -336
  553. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_dateutil.py +0 -15
  554. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_gi.py +0 -195
  555. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_mechanize.py +0 -18
  556. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_nose.py +0 -82
  557. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_numpy.py +0 -62
  558. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_pytest.py +0 -76
  559. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_qt.py +0 -44
  560. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_six.py +0 -288
  561. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_ssl.py +0 -65
  562. data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_stdlib.py +0 -473
  563. data/vendor/depot_tools/third_party/logilab/astroid/builder.py +0 -263
  564. data/vendor/depot_tools/third_party/logilab/astroid/context.py +0 -81
  565. data/vendor/depot_tools/third_party/logilab/astroid/decorators.py +0 -75
  566. data/vendor/depot_tools/third_party/logilab/astroid/exceptions.py +0 -71
  567. data/vendor/depot_tools/third_party/logilab/astroid/inference.py +0 -359
  568. data/vendor/depot_tools/third_party/logilab/astroid/manager.py +0 -267
  569. data/vendor/depot_tools/third_party/logilab/astroid/mixins.py +0 -147
  570. data/vendor/depot_tools/third_party/logilab/astroid/modutils.py +0 -741
  571. data/vendor/depot_tools/third_party/logilab/astroid/node_classes.py +0 -1053
  572. data/vendor/depot_tools/third_party/logilab/astroid/nodes.py +0 -87
  573. data/vendor/depot_tools/third_party/logilab/astroid/objects.py +0 -186
  574. data/vendor/depot_tools/third_party/logilab/astroid/protocols.py +0 -470
  575. data/vendor/depot_tools/third_party/logilab/astroid/raw_building.py +0 -390
  576. data/vendor/depot_tools/third_party/logilab/astroid/rebuilder.py +0 -989
  577. data/vendor/depot_tools/third_party/logilab/astroid/scoped_nodes.py +0 -1716
  578. data/vendor/depot_tools/third_party/logilab/astroid/test_utils.py +0 -201
  579. data/vendor/depot_tools/third_party/logilab/astroid/transforms.py +0 -96
  580. data/vendor/depot_tools/third_party/logilab/astroid/util.py +0 -89
  581. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/LICENSE +0 -19
  582. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/README.chromium +0 -11
  583. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/__init__.py +0 -20
  584. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/cext.c +0 -1421
  585. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/compat.py +0 -9
  586. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/simple.py +0 -246
  587. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/slots.py +0 -414
  588. data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/utils.py +0 -13
  589. data/vendor/depot_tools/third_party/logilab/wrapt/LICENSE +0 -24
  590. data/vendor/depot_tools/third_party/logilab/wrapt/README.chromium +0 -11
  591. data/vendor/depot_tools/third_party/logilab/wrapt/__init__.py +0 -19
  592. data/vendor/depot_tools/third_party/logilab/wrapt/_wrappers.c +0 -2729
  593. data/vendor/depot_tools/third_party/logilab/wrapt/arguments.py +0 -96
  594. data/vendor/depot_tools/third_party/logilab/wrapt/decorators.py +0 -512
  595. data/vendor/depot_tools/third_party/logilab/wrapt/importer.py +0 -228
  596. data/vendor/depot_tools/third_party/logilab/wrapt/wrappers.py +0 -901
  597. data/vendor/depot_tools/third_party/mock/LICENSE.txt +0 -26
  598. data/vendor/depot_tools/third_party/mock/README.chromium +0 -24
  599. data/vendor/depot_tools/third_party/mock/__init__.py +0 -2366
  600. data/vendor/depot_tools/third_party/oauth2client/LICENSE +0 -202
  601. data/vendor/depot_tools/third_party/oauth2client/MODIFICATIONS.diff +0 -66
  602. data/vendor/depot_tools/third_party/oauth2client/README.chromium +0 -15
  603. data/vendor/depot_tools/third_party/oauth2client/__init__.py +0 -5
  604. data/vendor/depot_tools/third_party/oauth2client/anyjson.py +0 -32
  605. data/vendor/depot_tools/third_party/oauth2client/appengine.py +0 -963
  606. data/vendor/depot_tools/third_party/oauth2client/client.py +0 -1363
  607. data/vendor/depot_tools/third_party/oauth2client/clientsecrets.py +0 -153
  608. data/vendor/depot_tools/third_party/oauth2client/crypt.py +0 -377
  609. data/vendor/depot_tools/third_party/oauth2client/django_orm.py +0 -134
  610. data/vendor/depot_tools/third_party/oauth2client/file.py +0 -124
  611. data/vendor/depot_tools/third_party/oauth2client/gce.py +0 -90
  612. data/vendor/depot_tools/third_party/oauth2client/keyring_storage.py +0 -109
  613. data/vendor/depot_tools/third_party/oauth2client/locked_file.py +0 -373
  614. data/vendor/depot_tools/third_party/oauth2client/multistore_file.py +0 -465
  615. data/vendor/depot_tools/third_party/oauth2client/old_run.py +0 -160
  616. data/vendor/depot_tools/third_party/oauth2client/tools.py +0 -243
  617. data/vendor/depot_tools/third_party/oauth2client/util.py +0 -196
  618. data/vendor/depot_tools/third_party/oauth2client/xsrfutil.py +0 -113
  619. data/vendor/depot_tools/third_party/protobuf26/README.chromium +0 -23
  620. data/vendor/depot_tools/third_party/protobuf26/__init__.py +0 -0
  621. data/vendor/depot_tools/third_party/protobuf26/compiler/__init__.py +0 -0
  622. data/vendor/depot_tools/third_party/protobuf26/compiler/plugin_pb2.py +0 -184
  623. data/vendor/depot_tools/third_party/protobuf26/descriptor.py +0 -849
  624. data/vendor/depot_tools/third_party/protobuf26/descriptor_database.py +0 -137
  625. data/vendor/depot_tools/third_party/protobuf26/descriptor_pb2.py +0 -1522
  626. data/vendor/depot_tools/third_party/protobuf26/descriptor_pool.py +0 -643
  627. data/vendor/depot_tools/third_party/protobuf26/internal/__init__.py +0 -0
  628. data/vendor/depot_tools/third_party/protobuf26/internal/api_implementation.py +0 -89
  629. data/vendor/depot_tools/third_party/protobuf26/internal/containers.py +0 -269
  630. data/vendor/depot_tools/third_party/protobuf26/internal/cpp_message.py +0 -663
  631. data/vendor/depot_tools/third_party/protobuf26/internal/decoder.py +0 -831
  632. data/vendor/depot_tools/third_party/protobuf26/internal/encoder.py +0 -788
  633. data/vendor/depot_tools/third_party/protobuf26/internal/enum_type_wrapper.py +0 -89
  634. data/vendor/depot_tools/third_party/protobuf26/internal/message_listener.py +0 -78
  635. data/vendor/depot_tools/third_party/protobuf26/internal/python_message.py +0 -1247
  636. data/vendor/depot_tools/third_party/protobuf26/internal/type_checkers.py +0 -328
  637. data/vendor/depot_tools/third_party/protobuf26/internal/wire_format.py +0 -268
  638. data/vendor/depot_tools/third_party/protobuf26/message.py +0 -284
  639. data/vendor/depot_tools/third_party/protobuf26/message_factory.py +0 -155
  640. data/vendor/depot_tools/third_party/protobuf26/reflection.py +0 -205
  641. data/vendor/depot_tools/third_party/protobuf26/service.py +0 -226
  642. data/vendor/depot_tools/third_party/protobuf26/service_reflection.py +0 -284
  643. data/vendor/depot_tools/third_party/protobuf26/symbol_database.py +0 -185
  644. data/vendor/depot_tools/third_party/protobuf26/text_encoding.py +0 -110
  645. data/vendor/depot_tools/third_party/protobuf26/text_format.py +0 -873
  646. data/vendor/depot_tools/third_party/pylint.py +0 -37
  647. data/vendor/depot_tools/third_party/pylint/LICENSE.txt +0 -340
  648. data/vendor/depot_tools/third_party/pylint/README.chromium +0 -30
  649. data/vendor/depot_tools/third_party/pylint/__init__.py +0 -46
  650. data/vendor/depot_tools/third_party/pylint/__main__.py +0 -3
  651. data/vendor/depot_tools/third_party/pylint/__pkginfo__.py +0 -80
  652. data/vendor/depot_tools/third_party/pylint/checkers/__init__.py +0 -123
  653. data/vendor/depot_tools/third_party/pylint/checkers/async.py +0 -82
  654. data/vendor/depot_tools/third_party/pylint/checkers/base.py +0 -2010
  655. data/vendor/depot_tools/third_party/pylint/checkers/classes.py +0 -1120
  656. data/vendor/depot_tools/third_party/pylint/checkers/design_analysis.py +0 -348
  657. data/vendor/depot_tools/third_party/pylint/checkers/exceptions.py +0 -369
  658. data/vendor/depot_tools/third_party/pylint/checkers/format.py +0 -993
  659. data/vendor/depot_tools/third_party/pylint/checkers/imports.py +0 -654
  660. data/vendor/depot_tools/third_party/pylint/checkers/logging.py +0 -258
  661. data/vendor/depot_tools/third_party/pylint/checkers/misc.py +0 -105
  662. data/vendor/depot_tools/third_party/pylint/checkers/newstyle.py +0 -169
  663. data/vendor/depot_tools/third_party/pylint/checkers/python3.py +0 -591
  664. data/vendor/depot_tools/third_party/pylint/checkers/raw_metrics.py +0 -129
  665. data/vendor/depot_tools/third_party/pylint/checkers/similar.py +0 -371
  666. data/vendor/depot_tools/third_party/pylint/checkers/spelling.py +0 -264
  667. data/vendor/depot_tools/third_party/pylint/checkers/stdlib.py +0 -280
  668. data/vendor/depot_tools/third_party/pylint/checkers/strings.py +0 -618
  669. data/vendor/depot_tools/third_party/pylint/checkers/typecheck.py +0 -974
  670. data/vendor/depot_tools/third_party/pylint/checkers/utils.py +0 -741
  671. data/vendor/depot_tools/third_party/pylint/checkers/variables.py +0 -1191
  672. data/vendor/depot_tools/third_party/pylint/config.py +0 -820
  673. data/vendor/depot_tools/third_party/pylint/epylint.py +0 -181
  674. data/vendor/depot_tools/third_party/pylint/extensions/__init__.py +0 -0
  675. data/vendor/depot_tools/third_party/pylint/extensions/check_docs.py +0 -311
  676. data/vendor/depot_tools/third_party/pylint/extensions/check_elif.py +0 -62
  677. data/vendor/depot_tools/third_party/pylint/graph.py +0 -179
  678. data/vendor/depot_tools/third_party/pylint/gui.py +0 -531
  679. data/vendor/depot_tools/third_party/pylint/interfaces.py +0 -102
  680. data/vendor/depot_tools/third_party/pylint/lint.py +0 -1381
  681. data/vendor/depot_tools/third_party/pylint/pyreverse/__init__.py +0 -5
  682. data/vendor/depot_tools/third_party/pylint/pyreverse/diadefslib.py +0 -230
  683. data/vendor/depot_tools/third_party/pylint/pyreverse/diagrams.py +0 -258
  684. data/vendor/depot_tools/third_party/pylint/pyreverse/inspector.py +0 -372
  685. data/vendor/depot_tools/third_party/pylint/pyreverse/main.py +0 -147
  686. data/vendor/depot_tools/third_party/pylint/pyreverse/utils.py +0 -210
  687. data/vendor/depot_tools/third_party/pylint/pyreverse/vcgutils.py +0 -198
  688. data/vendor/depot_tools/third_party/pylint/pyreverse/writer.py +0 -198
  689. data/vendor/depot_tools/third_party/pylint/reporters/__init__.py +0 -149
  690. data/vendor/depot_tools/third_party/pylint/reporters/guireporter.py +0 -27
  691. data/vendor/depot_tools/third_party/pylint/reporters/html.py +0 -108
  692. data/vendor/depot_tools/third_party/pylint/reporters/json.py +0 -64
  693. data/vendor/depot_tools/third_party/pylint/reporters/text.py +0 -237
  694. data/vendor/depot_tools/third_party/pylint/reporters/ureports/__init__.py +0 -106
  695. data/vendor/depot_tools/third_party/pylint/reporters/ureports/html_writer.py +0 -93
  696. data/vendor/depot_tools/third_party/pylint/reporters/ureports/nodes.py +0 -181
  697. data/vendor/depot_tools/third_party/pylint/reporters/ureports/text_writer.py +0 -99
  698. data/vendor/depot_tools/third_party/pylint/testutils.py +0 -414
  699. data/vendor/depot_tools/third_party/pylint/utils.py +0 -1148
  700. data/vendor/depot_tools/third_party/pymox/COPYING +0 -202
  701. data/vendor/depot_tools/third_party/pymox/MANIFEST.in +0 -5
  702. data/vendor/depot_tools/third_party/pymox/README +0 -56
  703. data/vendor/depot_tools/third_party/pymox/__init__.py +0 -0
  704. data/vendor/depot_tools/third_party/pymox/mox.py +0 -1643
  705. data/vendor/depot_tools/third_party/pymox/mox_test.py +0 -1708
  706. data/vendor/depot_tools/third_party/pymox/mox_test_helper.py +0 -76
  707. data/vendor/depot_tools/third_party/pymox/setup.py +0 -14
  708. data/vendor/depot_tools/third_party/pymox/stubout.py +0 -142
  709. data/vendor/depot_tools/third_party/pymox/stubout_test.py +0 -47
  710. data/vendor/depot_tools/third_party/pymox/stubout_testee.py +0 -2
  711. data/vendor/depot_tools/third_party/simplejson/LICENSE.txt +0 -19
  712. data/vendor/depot_tools/third_party/simplejson/PKG-INFO +0 -29
  713. data/vendor/depot_tools/third_party/simplejson/__init__.py +0 -437
  714. data/vendor/depot_tools/third_party/simplejson/decoder.py +0 -421
  715. data/vendor/depot_tools/third_party/simplejson/encoder.py +0 -501
  716. data/vendor/depot_tools/third_party/simplejson/ordered_dict.py +0 -119
  717. data/vendor/depot_tools/third_party/simplejson/scanner.py +0 -77
  718. data/vendor/depot_tools/third_party/simplejson/tool.py +0 -39
  719. data/vendor/depot_tools/third_party/upload.py +0 -2565
@@ -1,974 +0,0 @@
1
- # Copyright (c) 2006-2013 LOGILAB S.A. (Paris, FRANCE).
2
- # http://www.logilab.fr/ -- mailto:contact@logilab.fr
3
- #
4
- # This program is free software; you can redistribute it and/or modify it under
5
- # the terms of the GNU General Public License as published by the Free Software
6
- # Foundation; either version 2 of the License, or (at your option) any later
7
- # version.
8
- #
9
- # This program is distributed in the hope that it will be useful, but WITHOUT
10
- # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11
- # FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
12
- #
13
- # You should have received a copy of the GNU General Public License along with
14
- # this program; if not, write to the Free Software Foundation, Inc.,
15
- # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16
- """try to find more bugs in the code using astroid inference capabilities
17
- """
18
-
19
- import collections
20
- import fnmatch
21
- import re
22
- import shlex
23
- import sys
24
-
25
- import six
26
-
27
- import astroid
28
- import astroid.context
29
- import astroid.arguments
30
- from astroid import exceptions
31
- from astroid import objects
32
- from astroid import bases
33
-
34
- from pylint.interfaces import IAstroidChecker, INFERENCE, INFERENCE_FAILURE
35
- from pylint.checkers import BaseChecker
36
- from pylint.checkers.utils import (
37
- is_super, check_messages, decorated_with_property,
38
- decorated_with, node_ignores_exception,
39
- is_iterable, is_mapping, supports_membership_test,
40
- is_comprehension, is_inside_abstract_class,
41
- supports_subscript,
42
- safe_infer,
43
- has_known_bases)
44
- from pylint import utils
45
-
46
-
47
- _ZOPE_DEPRECATED = (
48
- "This option is deprecated. Use generated-members instead."
49
- )
50
- BUILTINS = six.moves.builtins.__name__
51
- STR_FORMAT = "%s.str.format" % BUILTINS
52
-
53
-
54
- def _unflatten(iterable):
55
- for index, elem in enumerate(iterable):
56
- if (isinstance(elem, collections.Sequence) and
57
- not isinstance(elem, six.string_types)):
58
- for elem in _unflatten(elem):
59
- yield elem
60
- elif elem and not index:
61
- # We're interested only in the first element.
62
- yield elem
63
-
64
-
65
- def _is_owner_ignored(owner, name, ignored_classes, ignored_modules):
66
- """Check if the given owner should be ignored
67
-
68
- This will verify if the owner's module is in *ignored_modules*
69
- or the owner's module fully qualified name is in *ignored_modules*
70
- or if the *ignored_modules* contains a pattern which catches
71
- the fully qualified name of the module.
72
-
73
- Also, similar checks are done for the owner itself, if its name
74
- matches any name from the *ignored_classes* or if its qualified
75
- name can be found in *ignored_classes*.
76
- """
77
- ignored_modules = set(ignored_modules)
78
- module_name = owner.root().name
79
- module_qname = owner.root().qname()
80
- if any(module_name in ignored_modules or
81
- module_qname in ignored_modules or
82
- fnmatch.fnmatch(module_qname, ignore) for ignore in ignored_modules):
83
- return True
84
-
85
- ignored_classes = set(ignored_classes)
86
- if hasattr(owner, 'qname'):
87
- qname = owner.qname()
88
- else:
89
- qname = ''
90
- return any(name == ignore or qname == ignore for ignore in ignored_classes)
91
-
92
-
93
- MSGS = {
94
- 'E1101': ('%s %r has no %r member',
95
- 'no-member',
96
- 'Used when a variable is accessed for an unexistent member.',
97
- {'old_names': [('E1103', 'maybe-no-member')]}),
98
- 'E1102': ('%s is not callable',
99
- 'not-callable',
100
- 'Used when an object being called has been inferred to a non \
101
- callable object'),
102
- 'E1111': ('Assigning to function call which doesn\'t return',
103
- 'assignment-from-no-return',
104
- 'Used when an assignment is done on a function call but the \
105
- inferred function doesn\'t return anything.'),
106
- 'E1120': ('No value for argument %s in %s call',
107
- 'no-value-for-parameter',
108
- 'Used when a function call passes too few arguments.'),
109
- 'E1121': ('Too many positional arguments for %s call',
110
- 'too-many-function-args',
111
- 'Used when a function call passes too many positional \
112
- arguments.'),
113
- 'E1123': ('Unexpected keyword argument %r in %s call',
114
- 'unexpected-keyword-arg',
115
- 'Used when a function call passes a keyword argument that \
116
- doesn\'t correspond to one of the function\'s parameter names.'),
117
- 'E1124': ('Argument %r passed by position and keyword in %s call',
118
- 'redundant-keyword-arg',
119
- 'Used when a function call would result in assigning multiple \
120
- values to a function parameter, one value from a positional \
121
- argument and one from a keyword argument.'),
122
- 'E1125': ('Missing mandatory keyword argument %r in %s call',
123
- 'missing-kwoa',
124
- ('Used when a function call does not pass a mandatory'
125
- ' keyword-only argument.'),
126
- {'minversion': (3, 0)}),
127
- 'E1126': ('Sequence index is not an int, slice, or instance with __index__',
128
- 'invalid-sequence-index',
129
- 'Used when a sequence type is indexed with an invalid type. '
130
- 'Valid types are ints, slices, and objects with an __index__ '
131
- 'method.'),
132
- 'E1127': ('Slice index is not an int, None, or instance with __index__',
133
- 'invalid-slice-index',
134
- 'Used when a slice index is not an integer, None, or an object \
135
- with an __index__ method.'),
136
- 'E1128': ('Assigning to function call which only returns None',
137
- 'assignment-from-none',
138
- 'Used when an assignment is done on a function call but the '
139
- 'inferred function returns nothing but None.',
140
- {'old_names': [('W1111', 'assignment-from-none')]}),
141
- 'E1129': ("Context manager '%s' doesn't implement __enter__ and __exit__.",
142
- 'not-context-manager',
143
- 'Used when an instance in a with statement doesn\'t implement '
144
- 'the context manager protocol(__enter__/__exit__).'),
145
- 'E1130': ('%s',
146
- 'invalid-unary-operand-type',
147
- 'Emitted when an unary operand is used on an object which does not '
148
- 'support this type of operation'),
149
- 'E1131': ('%s',
150
- 'unsupported-binary-operation',
151
- 'Emitted when a binary arithmetic operation between two '
152
- 'operands is not supported.'),
153
- 'E1132': ('Got multiple values for keyword argument %r in function call',
154
- 'repeated-keyword',
155
- 'Emitted when a function call got multiple values for a keyword.'),
156
- 'E1135': ("Value '%s' doesn't support membership test",
157
- 'unsupported-membership-test',
158
- 'Emitted when an instance in membership test expression doesn\'t'
159
- 'implement membership protocol (__contains__/__iter__/__getitem__)'),
160
- 'E1136': ("Value '%s' is unsubscriptable",
161
- 'unsubscriptable-object',
162
- "Emitted when a subscripted value doesn't support subscription"
163
- "(i.e. doesn't define __getitem__ method)"),
164
- }
165
-
166
- # builtin sequence types in Python 2 and 3.
167
- SEQUENCE_TYPES = set(['str', 'unicode', 'list', 'tuple', 'bytearray',
168
- 'xrange', 'range', 'bytes', 'memoryview'])
169
-
170
-
171
- def _emit_no_member(node, owner, owner_name, ignored_mixins):
172
- """Try to see if no-member should be emitted for the given owner.
173
-
174
- The following cases are ignored:
175
-
176
- * the owner is a function and it has decorators.
177
- * the owner is an instance and it has __getattr__, __getattribute__ implemented
178
- * the module is explicitly ignored from no-member checks
179
- * the owner is a class and the name can be found in its metaclass.
180
- * The access node is protected by an except handler, which handles
181
- AttributeError, Exception or bare except.
182
- """
183
- if node_ignores_exception(node, AttributeError):
184
- return False
185
- # skip None anyway
186
- if isinstance(owner, astroid.Const) and owner.value is None:
187
- return False
188
- if is_super(owner) or getattr(owner, 'type', None) == 'metaclass':
189
- return False
190
- if ignored_mixins and owner_name[-5:].lower() == 'mixin':
191
- return False
192
- if isinstance(owner, astroid.FunctionDef) and owner.decorators:
193
- return False
194
- if isinstance(owner, astroid.Instance):
195
- if owner.has_dynamic_getattr() or not has_known_bases(owner):
196
- return False
197
- if isinstance(owner, objects.Super):
198
- # Verify if we are dealing with an invalid Super object.
199
- # If it is invalid, then there's no point in checking that
200
- # it has the required attribute. Also, don't fail if the
201
- # MRO is invalid.
202
- try:
203
- owner.super_mro()
204
- except (exceptions.MroError, exceptions.SuperError):
205
- return False
206
- if not all(map(has_known_bases, owner.type.mro())):
207
- return False
208
- return True
209
-
210
-
211
- def _determine_callable(callable_obj):
212
- # Ordering is important, since BoundMethod is a subclass of UnboundMethod,
213
- # and Function inherits Lambda.
214
- if isinstance(callable_obj, astroid.BoundMethod):
215
- # Bound methods have an extra implicit 'self' argument.
216
- return callable_obj, 1, callable_obj.type
217
- elif isinstance(callable_obj, astroid.UnboundMethod):
218
- return callable_obj, 0, 'unbound method'
219
- elif isinstance(callable_obj, astroid.FunctionDef):
220
- return callable_obj, 0, callable_obj.type
221
- elif isinstance(callable_obj, astroid.Lambda):
222
- return callable_obj, 0, 'lambda'
223
- elif isinstance(callable_obj, astroid.ClassDef):
224
- # Class instantiation, lookup __new__ instead.
225
- # If we only find object.__new__, we can safely check __init__
226
- # instead. If __new__ belongs to builtins, then we look
227
- # again for __init__ in the locals, since we won't have
228
- # argument information for the builtin __new__ function.
229
- try:
230
- # Use the last definition of __new__.
231
- new = callable_obj.local_attr('__new__')[-1]
232
- except exceptions.NotFoundError:
233
- new = None
234
-
235
- from_object = new and new.parent.scope().name == 'object'
236
- from_builtins = new and new.root().name in sys.builtin_module_names
237
-
238
- if not new or from_object or from_builtins:
239
- try:
240
- # Use the last definition of __init__.
241
- callable_obj = callable_obj.local_attr('__init__')[-1]
242
- except exceptions.NotFoundError:
243
- # do nothing, covered by no-init.
244
- raise ValueError
245
- else:
246
- callable_obj = new
247
-
248
- if not isinstance(callable_obj, astroid.FunctionDef):
249
- raise ValueError
250
- # both have an extra implicit 'cls'/'self' argument.
251
- return callable_obj, 1, 'constructor'
252
- else:
253
- raise ValueError
254
-
255
- class TypeChecker(BaseChecker):
256
- """try to find bugs in the code using type inference
257
- """
258
-
259
- __implements__ = (IAstroidChecker,)
260
-
261
- # configuration section name
262
- name = 'typecheck'
263
- # messages
264
- msgs = MSGS
265
- priority = -1
266
- # configuration options
267
- options = (('ignore-mixin-members',
268
- {'default' : True, 'type' : 'yn', 'metavar': '<y_or_n>',
269
- 'help' : 'Tells whether missing members accessed in mixin \
270
- class should be ignored. A mixin class is detected if its name ends with \
271
- "mixin" (case insensitive).'}
272
- ),
273
- ('ignored-modules',
274
- {'default': (),
275
- 'type': 'csv',
276
- 'metavar': '<module names>',
277
- 'help': 'List of module names for which member attributes '
278
- 'should not be checked (useful for modules/projects '
279
- 'where namespaces are manipulated during runtime and '
280
- 'thus existing member attributes cannot be '
281
- 'deduced by static analysis. It supports qualified '
282
- 'module names, as well as Unix pattern matching.'}
283
- ),
284
- ('ignored-classes',
285
- {'default' : (),
286
- 'type' : 'csv',
287
- 'metavar' : '<members names>',
288
- 'help' : 'List of classes names for which member attributes '
289
- 'should not be checked (useful for classes with '
290
- 'attributes dynamically set). This supports '
291
- 'can work with qualified names.'}
292
- ),
293
-
294
- ('zope', utils.deprecated_option(opt_type='yn',
295
- help_msg=_ZOPE_DEPRECATED)),
296
-
297
- ('generated-members',
298
- {'default' : (),
299
- 'type' : 'string',
300
- 'metavar' : '<members names>',
301
- 'help' : 'List of members which are set dynamically and \
302
- missed by pylint inference system, and so shouldn\'t trigger E1101 when \
303
- accessed. Python regular expressions are accepted.'}
304
- ),
305
- )
306
-
307
- def open(self):
308
- # do this in open since config not fully initialized in __init__
309
- # generated_members may contain regular expressions
310
- # (surrounded by quote `"` and followed by a comma `,`)
311
- # REQUEST,aq_parent,"[a-zA-Z]+_set{1,2}"' =>
312
- # ('REQUEST', 'aq_parent', '[a-zA-Z]+_set{1,2}')
313
- if isinstance(self.config.generated_members, six.string_types):
314
- gen = shlex.shlex(self.config.generated_members)
315
- gen.whitespace += ','
316
- gen.wordchars += '[]-+'
317
- self.config.generated_members = tuple(tok.strip('"') for tok in gen)
318
-
319
- def visit_assignattr(self, node):
320
- if isinstance(node.assign_type(), astroid.AugAssign):
321
- self.visit_attribute(node)
322
-
323
- def visit_delattr(self, node):
324
- self.visit_attribute(node)
325
-
326
- @check_messages('no-member')
327
- def visit_attribute(self, node):
328
- """check that the accessed attribute exists
329
-
330
- to avoid too much false positives for now, we'll consider the code as
331
- correct if a single of the inferred nodes has the accessed attribute.
332
-
333
- function/method, super call and metaclasses are ignored
334
- """
335
- for pattern in self.config.generated_members:
336
- # attribute is marked as generated, stop here
337
- if re.match(pattern, node.attrname):
338
- return
339
-
340
- try:
341
- infered = list(node.expr.infer())
342
- except exceptions.InferenceError:
343
- return
344
- # list of (node, nodename) which are missing the attribute
345
- missingattr = set()
346
- inference_failure = False
347
- for owner in infered:
348
- # skip yes object
349
- if owner is astroid.YES:
350
- inference_failure = True
351
- continue
352
-
353
- name = getattr(owner, 'name', None)
354
- if _is_owner_ignored(owner, name, self.config.ignored_classes,
355
- self.config.ignored_modules):
356
- continue
357
-
358
- try:
359
- if not [n for n in owner.getattr(node.attrname)
360
- if not isinstance(n.statement(), astroid.AugAssign)]:
361
- missingattr.add((owner, name))
362
- continue
363
- except AttributeError:
364
- # XXX method / function
365
- continue
366
- except exceptions.NotFoundError:
367
- # This can't be moved before the actual .getattr call,
368
- # because there can be more values inferred and we are
369
- # stopping after the first one which has the attribute in question.
370
- # The problem is that if the first one has the attribute,
371
- # but we continue to the next values which doesn't have the
372
- # attribute, then we'll have a false positive.
373
- # So call this only after the call has been made.
374
- if not _emit_no_member(node, owner, name,
375
- self.config.ignore_mixin_members):
376
- continue
377
- missingattr.add((owner, name))
378
- continue
379
- # stop on the first found
380
- break
381
- else:
382
- # we have not found any node with the attributes, display the
383
- # message for infered nodes
384
- done = set()
385
- for owner, name in missingattr:
386
- if isinstance(owner, astroid.Instance):
387
- actual = owner._proxied
388
- else:
389
- actual = owner
390
- if actual in done:
391
- continue
392
- done.add(actual)
393
- confidence = INFERENCE if not inference_failure else INFERENCE_FAILURE
394
- self.add_message('no-member', node=node,
395
- args=(owner.display_type(), name,
396
- node.attrname),
397
- confidence=confidence)
398
-
399
- @check_messages('assignment-from-no-return', 'assignment-from-none')
400
- def visit_assign(self, node):
401
- """check that if assigning to a function call, the function is
402
- possibly returning something valuable
403
- """
404
- if not isinstance(node.value, astroid.Call):
405
- return
406
- function_node = safe_infer(node.value.func)
407
- # skip class, generator and incomplete function definition
408
- if not (isinstance(function_node, astroid.FunctionDef) and
409
- function_node.root().fully_defined()):
410
- return
411
- if function_node.is_generator() \
412
- or function_node.is_abstract(pass_is_abstract=False):
413
- return
414
- returns = list(function_node.nodes_of_class(astroid.Return,
415
- skip_klass=astroid.FunctionDef))
416
- if len(returns) == 0:
417
- self.add_message('assignment-from-no-return', node=node)
418
- else:
419
- for rnode in returns:
420
- if not (isinstance(rnode.value, astroid.Const)
421
- and rnode.value.value is None
422
- or rnode.value is None):
423
- break
424
- else:
425
- self.add_message('assignment-from-none', node=node)
426
-
427
- def _check_uninferable_callfunc(self, node):
428
- """
429
- Check that the given uninferable CallFunc node does not
430
- call an actual function.
431
- """
432
- if not isinstance(node.func, astroid.Attribute):
433
- return
434
-
435
- # Look for properties. First, obtain
436
- # the lhs of the Getattr node and search the attribute
437
- # there. If that attribute is a property or a subclass of properties,
438
- # then most likely it's not callable.
439
-
440
- # TODO: since astroid doesn't understand descriptors very well
441
- # we will not handle them here, right now.
442
-
443
- expr = node.func.expr
444
- klass = safe_infer(expr)
445
- if (klass is None or klass is astroid.YES or
446
- not isinstance(klass, astroid.Instance)):
447
- return
448
-
449
- try:
450
- attrs = klass._proxied.getattr(node.func.attrname)
451
- except exceptions.NotFoundError:
452
- return
453
-
454
- for attr in attrs:
455
- if attr is astroid.YES:
456
- continue
457
- if not isinstance(attr, astroid.FunctionDef):
458
- continue
459
-
460
- # Decorated, see if it is decorated with a property.
461
- # Also, check the returns and see if they are callable.
462
- if decorated_with_property(attr):
463
- if all(return_node.callable()
464
- for return_node in attr.infer_call_result(node)):
465
- continue
466
- else:
467
- self.add_message('not-callable', node=node,
468
- args=node.func.as_string())
469
- break
470
-
471
- @staticmethod
472
- def _no_context_variadic(node):
473
- """Verify if the given call node has variadic nodes without context
474
-
475
- This is a workaround for handling cases of nested call functions
476
- which don't have the specific call context at hand.
477
- Variadic arguments (variable positional arguments and variable
478
- keyword arguments) are inferred, inherently wrong, by astroid
479
- as a Tuple, respectively a Dict with empty elements.
480
- This can lead pylint to believe that a function call receives
481
- too few arguments.
482
- """
483
- for arg in node.args:
484
- if not isinstance(arg, astroid.Starred):
485
- continue
486
-
487
- inferred = safe_infer(arg.value)
488
- if isinstance(inferred, astroid.Tuple):
489
- length = len(inferred.elts)
490
- elif isinstance(inferred, astroid.Dict):
491
- length = len(inferred.items)
492
- else:
493
- return False
494
- if not length and isinstance(inferred.statement(), astroid.FunctionDef):
495
- return True
496
- return False
497
-
498
- @check_messages(*(list(MSGS.keys())))
499
- def visit_call(self, node):
500
- """check that called functions/methods are inferred to callable objects,
501
- and that the arguments passed to the function match the parameters in
502
- the inferred function's definition
503
- """
504
- # Build the set of keyword arguments, checking for duplicate keywords,
505
- # and count the positional arguments.
506
- call_site = astroid.arguments.CallSite.from_call(node)
507
- num_positional_args = len(call_site.positional_arguments)
508
- keyword_args = list(call_site.keyword_arguments.keys())
509
- no_context_variadic = self._no_context_variadic(node)
510
-
511
- called = safe_infer(node.func)
512
- # only function, generator and object defining __call__ are allowed
513
- if called is not None and not called.callable():
514
- self.add_message('not-callable', node=node,
515
- args=node.func.as_string())
516
-
517
- self._check_uninferable_callfunc(node)
518
-
519
- try:
520
- called, implicit_args, callable_name = _determine_callable(called)
521
- except ValueError:
522
- # Any error occurred during determining the function type, most of
523
- # those errors are handled by different warnings.
524
- return
525
-
526
- num_positional_args += implicit_args
527
- if called.args.args is None:
528
- # Built-in functions have no argument information.
529
- return
530
-
531
- if len(called.argnames()) != len(set(called.argnames())):
532
- # Duplicate parameter name (see duplicate-argument). We can't really
533
- # make sense of the function call in this case, so just return.
534
- return
535
-
536
- # Warn about duplicated keyword arguments, such as `f=24, **{'f': 24}`
537
- for keyword in call_site.duplicated_keywords:
538
- self.add_message('repeated-keyword',
539
- node=node, args=(keyword, ))
540
-
541
- if call_site.has_invalid_arguments() or call_site.has_invalid_keywords():
542
- # Can't make sense of this.
543
- return
544
-
545
- # Analyze the list of formal parameters.
546
- num_mandatory_parameters = len(called.args.args) - len(called.args.defaults)
547
- parameters = []
548
- parameter_name_to_index = {}
549
- for i, arg in enumerate(called.args.args):
550
- if isinstance(arg, astroid.Tuple):
551
- name = None
552
- # Don't store any parameter names within the tuple, since those
553
- # are not assignable from keyword arguments.
554
- else:
555
- assert isinstance(arg, astroid.AssignName)
556
- # This occurs with:
557
- # def f( (a), (b) ): pass
558
- name = arg.name
559
- parameter_name_to_index[name] = i
560
- if i >= num_mandatory_parameters:
561
- defval = called.args.defaults[i - num_mandatory_parameters]
562
- else:
563
- defval = None
564
- parameters.append([(name, defval), False])
565
-
566
- kwparams = {}
567
- for i, arg in enumerate(called.args.kwonlyargs):
568
- if isinstance(arg, astroid.Keyword):
569
- name = arg.arg
570
- else:
571
- assert isinstance(arg, astroid.AssignName)
572
- name = arg.name
573
- kwparams[name] = [called.args.kw_defaults[i], False]
574
-
575
- # Match the supplied arguments against the function parameters.
576
-
577
- # 1. Match the positional arguments.
578
- for i in range(num_positional_args):
579
- if i < len(parameters):
580
- parameters[i][1] = True
581
- elif called.args.vararg is not None:
582
- # The remaining positional arguments get assigned to the *args
583
- # parameter.
584
- break
585
- else:
586
- # Too many positional arguments.
587
- self.add_message('too-many-function-args',
588
- node=node, args=(callable_name,))
589
- break
590
-
591
- # 2. Match the keyword arguments.
592
- for keyword in keyword_args:
593
- if keyword in parameter_name_to_index:
594
- i = parameter_name_to_index[keyword]
595
- if parameters[i][1]:
596
- # Duplicate definition of function parameter.
597
-
598
- # Might be too hardcoded, but this can actually
599
- # happen when using str.format and `self` is passed
600
- # by keyword argument, as in `.format(self=self)`.
601
- # It's perfectly valid to so, so we're just skipping
602
- # it if that's the case.
603
- if not (keyword == 'self' and called.qname() == STR_FORMAT):
604
- self.add_message('redundant-keyword-arg',
605
- node=node, args=(keyword, callable_name))
606
- else:
607
- parameters[i][1] = True
608
- elif keyword in kwparams:
609
- if kwparams[keyword][1]: # XXX is that even possible?
610
- # Duplicate definition of function parameter.
611
- self.add_message('redundant-keyword-arg', node=node,
612
- args=(keyword, callable_name))
613
- else:
614
- kwparams[keyword][1] = True
615
- elif called.args.kwarg is not None:
616
- # The keyword argument gets assigned to the **kwargs parameter.
617
- pass
618
- else:
619
- # Unexpected keyword argument.
620
- self.add_message('unexpected-keyword-arg', node=node,
621
- args=(keyword, callable_name))
622
-
623
- # 3. Match the **kwargs, if any.
624
- if node.kwargs:
625
- for i, [(name, defval), assigned] in enumerate(parameters):
626
- # Assume that *kwargs provides values for all remaining
627
- # unassigned named parameters.
628
- if name is not None:
629
- parameters[i][1] = True
630
- else:
631
- # **kwargs can't assign to tuples.
632
- pass
633
-
634
- # Check that any parameters without a default have been assigned
635
- # values.
636
- for [(name, defval), assigned] in parameters:
637
- if (defval is None) and not assigned:
638
- if name is None:
639
- display_name = '<tuple>'
640
- else:
641
- display_name = repr(name)
642
- # TODO(cpopa): this should be removed after PyCQA/astroid/issues/177
643
- if not no_context_variadic:
644
- self.add_message('no-value-for-parameter', node=node,
645
- args=(display_name, callable_name))
646
-
647
- for name in kwparams:
648
- defval, assigned = kwparams[name]
649
- if defval is None and not assigned:
650
- self.add_message('missing-kwoa', node=node,
651
- args=(name, callable_name))
652
-
653
- @check_messages('invalid-sequence-index')
654
- def visit_extslice(self, node):
655
- # Check extended slice objects as if they were used as a sequence
656
- # index to check if the object being sliced can support them
657
- return self.visit_index(node)
658
-
659
- @check_messages('invalid-sequence-index')
660
- def visit_index(self, node):
661
- if not node.parent or not hasattr(node.parent, "value"):
662
- return
663
- # Look for index operations where the parent is a sequence type.
664
- # If the types can be determined, only allow indices to be int,
665
- # slice or instances with __index__.
666
- parent_type = safe_infer(node.parent.value)
667
- if not isinstance(parent_type, (astroid.ClassDef, astroid.Instance)):
668
- return
669
-
670
- # Determine what method on the parent this index will use
671
- # The parent of this node will be a Subscript, and the parent of that
672
- # node determines if the Subscript is a get, set, or delete operation.
673
- operation = node.parent.parent
674
- if isinstance(operation, astroid.Assign):
675
- methodname = '__setitem__'
676
- elif isinstance(operation, astroid.Delete):
677
- methodname = '__delitem__'
678
- else:
679
- methodname = '__getitem__'
680
-
681
- # Check if this instance's __getitem__, __setitem__, or __delitem__, as
682
- # appropriate to the statement, is implemented in a builtin sequence
683
- # type. This way we catch subclasses of sequence types but skip classes
684
- # that override __getitem__ and which may allow non-integer indices.
685
- try:
686
- methods = parent_type.getattr(methodname)
687
- if methods is astroid.YES:
688
- return
689
- itemmethod = methods[0]
690
- except (exceptions.NotFoundError, IndexError):
691
- return
692
- if not isinstance(itemmethod, astroid.FunctionDef):
693
- return
694
- if itemmethod.root().name != BUILTINS:
695
- return
696
- if not itemmethod.parent:
697
- return
698
- if itemmethod.parent.name not in SEQUENCE_TYPES:
699
- return
700
-
701
- # For ExtSlice objects coming from visit_extslice, no further
702
- # inference is necessary, since if we got this far the ExtSlice
703
- # is an error.
704
- if isinstance(node, astroid.ExtSlice):
705
- index_type = node
706
- else:
707
- index_type = safe_infer(node)
708
- if index_type is None or index_type is astroid.YES:
709
- return
710
- # Constants must be of type int
711
- if isinstance(index_type, astroid.Const):
712
- if isinstance(index_type.value, int):
713
- return
714
- # Instance values must be int, slice, or have an __index__ method
715
- elif isinstance(index_type, astroid.Instance):
716
- if index_type.pytype() in (BUILTINS + '.int', BUILTINS + '.slice'):
717
- return
718
- try:
719
- index_type.getattr('__index__')
720
- return
721
- except exceptions.NotFoundError:
722
- pass
723
- elif isinstance(index_type, astroid.Slice):
724
- # Delegate to visit_slice. A slice can be present
725
- # here after inferring the index node, which could
726
- # be a `slice(...)` call for instance.
727
- return self.visit_slice(index_type)
728
-
729
- # Anything else is an error
730
- self.add_message('invalid-sequence-index', node=node)
731
-
732
- @check_messages('invalid-slice-index')
733
- def visit_slice(self, node):
734
- # Check the type of each part of the slice
735
- for index in (node.lower, node.upper, node.step):
736
- if index is None:
737
- continue
738
-
739
- index_type = safe_infer(index)
740
- if index_type is None or index_type is astroid.YES:
741
- continue
742
-
743
- # Constants must of type int or None
744
- if isinstance(index_type, astroid.Const):
745
- if isinstance(index_type.value, (int, type(None))):
746
- continue
747
- # Instance values must be of type int, None or an object
748
- # with __index__
749
- elif isinstance(index_type, astroid.Instance):
750
- if index_type.pytype() in (BUILTINS + '.int',
751
- BUILTINS + '.NoneType'):
752
- continue
753
-
754
- try:
755
- index_type.getattr('__index__')
756
- return
757
- except exceptions.NotFoundError:
758
- pass
759
-
760
- # Anything else is an error
761
- self.add_message('invalid-slice-index', node=node)
762
-
763
- @check_messages('not-context-manager')
764
- def visit_with(self, node):
765
- for ctx_mgr, _ in node.items:
766
- context = astroid.context.InferenceContext()
767
- infered = safe_infer(ctx_mgr, context=context)
768
- if infered is None or infered is astroid.YES:
769
- continue
770
-
771
- if isinstance(infered, bases.Generator):
772
- # Check if we are dealing with a function decorated
773
- # with contextlib.contextmanager.
774
- if decorated_with(infered.parent, ['contextlib.contextmanager']):
775
- continue
776
- # If the parent of the generator is not the context manager itself,
777
- # that means that it could have been returned from another
778
- # function which was the real context manager.
779
- # The following approach is more of a hack rather than a real
780
- # solution: walk all the inferred statements for the
781
- # given *ctx_mgr* and if you find one function scope
782
- # which is decorated, consider it to be the real
783
- # manager and give up, otherwise emit not-context-manager.
784
- # See the test file for not_context_manager for a couple
785
- # of self explaining tests.
786
- for path in six.moves.filter(None, _unflatten(context.path)):
787
- scope = path.scope()
788
- if not isinstance(scope, astroid.FunctionDef):
789
- continue
790
- if decorated_with(scope, ['contextlib.contextmanager']):
791
- break
792
- else:
793
- self.add_message('not-context-manager',
794
- node=node, args=(infered.name, ))
795
- else:
796
- try:
797
- infered.getattr('__enter__')
798
- infered.getattr('__exit__')
799
- except exceptions.NotFoundError:
800
- if isinstance(infered, astroid.Instance):
801
- # If we do not know the bases of this class,
802
- # just skip it.
803
- if not has_known_bases(infered):
804
- continue
805
- # Just ignore mixin classes.
806
- if self.config.ignore_mixin_members:
807
- if infered.name[-5:].lower() == 'mixin':
808
- continue
809
-
810
- self.add_message('not-context-manager',
811
- node=node, args=(infered.name, ))
812
-
813
- # Disabled until we'll have a more capable astroid.
814
- @check_messages('invalid-unary-operand-type')
815
- def _visit_unaryop(self, node):
816
- """Detect TypeErrors for unary operands."""
817
-
818
- for error in node.type_errors():
819
- # Let the error customize its output.
820
- self.add_message('invalid-unary-operand-type',
821
- args=str(error), node=node)
822
-
823
- @check_messages('unsupported-binary-operation')
824
- def _visit_binop(self, node):
825
- """Detect TypeErrors for binary arithmetic operands."""
826
- self._check_binop_errors(node)
827
-
828
- @check_messages('unsupported-binary-operation')
829
- def _visit_augassign(self, node):
830
- """Detect TypeErrors for augmented binary arithmetic operands."""
831
- self._check_binop_errors(node)
832
-
833
- def _check_binop_errors(self, node):
834
- for error in node.type_errors():
835
- # Let the error customize its output.
836
- self.add_message('unsupported-binary-operation',
837
- args=str(error), node=node)
838
-
839
- def _check_membership_test(self, node):
840
- if is_inside_abstract_class(node):
841
- return
842
- if is_comprehension(node):
843
- return
844
- infered = safe_infer(node)
845
- if infered is None or infered is astroid.YES:
846
- return
847
- if not supports_membership_test(infered):
848
- self.add_message('unsupported-membership-test',
849
- args=node.as_string(),
850
- node=node)
851
-
852
- @check_messages('unsupported-membership-test')
853
- def visit_compare(self, node):
854
- if len(node.ops) != 1:
855
- return
856
- operator, right = node.ops[0]
857
- if operator in ['in', 'not in']:
858
- self._check_membership_test(right)
859
-
860
- @check_messages('unsubscriptable-object')
861
- def visit_subscript(self, node):
862
- if isinstance(node.value, (astroid.ListComp, astroid.DictComp)):
863
- return
864
- if isinstance(node.value, astroid.SetComp):
865
- self.add_message('unsubscriptable-object',
866
- args=node.value.as_string(),
867
- node=node.value)
868
- return
869
-
870
- infered = safe_infer(node.value)
871
- if infered is None or infered is astroid.YES:
872
- return
873
-
874
- if is_inside_abstract_class(node):
875
- return
876
-
877
- if not supports_subscript(infered):
878
- self.add_message('unsubscriptable-object',
879
- args=node.value.as_string(),
880
- node=node.value)
881
-
882
-
883
-
884
- class IterableChecker(BaseChecker):
885
- """
886
- Checks for non-iterables used in an iterable context.
887
- Contexts include:
888
- - for-statement
889
- - starargs in function call
890
- - `yield from`-statement
891
- - list, dict and set comprehensions
892
- - generator expressions
893
- Also checks for non-mappings in function call kwargs.
894
- """
895
-
896
- __implements__ = (IAstroidChecker,)
897
- name = 'iterable_check'
898
-
899
- msgs = {'E1133': ('Non-iterable value %s is used in an iterating context',
900
- 'not-an-iterable',
901
- 'Used when a non-iterable value is used in place where'
902
- 'iterable is expected'),
903
- 'E1134': ('Non-mapping value %s is used in a mapping context',
904
- 'not-a-mapping',
905
- 'Used when a non-mapping value is used in place where'
906
- 'mapping is expected'),
907
- }
908
-
909
- def _check_iterable(self, node):
910
- if is_inside_abstract_class(node):
911
- return
912
- if is_comprehension(node):
913
- return
914
- infered = safe_infer(node)
915
- if infered is None or infered is astroid.YES:
916
- return
917
- if not is_iterable(infered):
918
- self.add_message('not-an-iterable',
919
- args=node.as_string(),
920
- node=node)
921
-
922
- def _check_mapping(self, node):
923
- if is_inside_abstract_class(node):
924
- return
925
- if isinstance(node, astroid.DictComp):
926
- return
927
- infered = safe_infer(node)
928
- if infered is None or infered is astroid.YES:
929
- return
930
- if not is_mapping(infered):
931
- self.add_message('not-a-mapping',
932
- args=node.as_string(),
933
- node=node)
934
-
935
- @check_messages('not-an-iterable')
936
- def visit_for(self, node):
937
- self._check_iterable(node.iter)
938
-
939
- @check_messages('not-an-iterable')
940
- def visit_yieldfrom(self, node):
941
- self._check_iterable(node.value)
942
-
943
- @check_messages('not-an-iterable', 'not-a-mapping')
944
- def visit_call(self, node):
945
- for stararg in node.starargs:
946
- self._check_iterable(stararg.value)
947
- for kwarg in node.kwargs:
948
- self._check_mapping(kwarg.value)
949
-
950
- @check_messages('not-an-iterable')
951
- def visit_listcomp(self, node):
952
- for gen in node.generators:
953
- self._check_iterable(gen.iter)
954
-
955
- @check_messages('not-an-iterable')
956
- def visit_dictcomp(self, node):
957
- for gen in node.generators:
958
- self._check_iterable(gen.iter)
959
-
960
- @check_messages('not-an-iterable')
961
- def visit_setcomp(self, node):
962
- for gen in node.generators:
963
- self._check_iterable(gen.iter)
964
-
965
- @check_messages('not-an-iterable')
966
- def visit_generatorexp(self, node):
967
- for gen in node.generators:
968
- self._check_iterable(gen.iter)
969
-
970
-
971
- def register(linter):
972
- """required method to auto register this checker """
973
- linter.register_checker(TypeChecker(linter))
974
- linter.register_checker(IterableChecker(linter))