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,1120 +0,0 @@
1
- # Copyright (c) 2003-2014 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
- """classes checker for Python code
17
- """
18
- from __future__ import generators
19
-
20
- import sys
21
- from collections import defaultdict
22
-
23
- import six
24
-
25
- import astroid
26
- from astroid.bases import Generator, BUILTINS
27
- from astroid.exceptions import InconsistentMroError, DuplicateBasesError
28
- from astroid import objects
29
- from astroid.scoped_nodes import function_to_method
30
- from pylint.interfaces import IAstroidChecker
31
- from pylint.checkers import BaseChecker
32
- from pylint.checkers.utils import (
33
- PYMETHODS, SPECIAL_METHODS_PARAMS,
34
- overrides_a_method, check_messages, is_attr_private,
35
- is_attr_protected, node_frame_class, is_builtin_object,
36
- decorated_with_property, unimplemented_abstract_methods,
37
- decorated_with, class_is_abstract,
38
- safe_infer, has_known_bases)
39
- from pylint.utils import deprecated_option, get_global_option
40
-
41
-
42
- if sys.version_info >= (3, 0):
43
- NEXT_METHOD = '__next__'
44
- else:
45
- NEXT_METHOD = 'next'
46
- ITER_METHODS = ('__iter__', '__getitem__')
47
- INVALID_BASE_CLASSES = {'bool', 'range', 'slice', 'memoryview'}
48
-
49
-
50
- def _get_method_args(method):
51
- args = method.args.args
52
- if method.type in ('classmethod', 'method'):
53
- return len(args) - 1
54
- return len(args)
55
-
56
-
57
- def _is_invalid_base_class(cls):
58
- return cls.name in INVALID_BASE_CLASSES and is_builtin_object(cls)
59
-
60
-
61
- def _has_data_descriptor(cls, attr):
62
- attributes = cls.getattr(attr)
63
- for attribute in attributes:
64
- try:
65
- for inferred in attribute.infer():
66
- if isinstance(inferred, astroid.Instance):
67
- try:
68
- inferred.getattr('__get__')
69
- inferred.getattr('__set__')
70
- except astroid.NotFoundError:
71
- continue
72
- else:
73
- return True
74
- except astroid.InferenceError:
75
- # Can't infer, avoid emitting a false positive in this case.
76
- return True
77
- return False
78
-
79
-
80
- def _called_in_methods(func, klass, methods):
81
- """ Check if the func was called in any of the given methods,
82
- belonging to the *klass*. Returns True if so, False otherwise.
83
- """
84
- if not isinstance(func, astroid.FunctionDef):
85
- return False
86
- for method in methods:
87
- try:
88
- infered = klass.getattr(method)
89
- except astroid.NotFoundError:
90
- continue
91
- for infer_method in infered:
92
- for callfunc in infer_method.nodes_of_class(astroid.Call):
93
- try:
94
- bound = next(callfunc.func.infer())
95
- except (astroid.InferenceError, StopIteration):
96
- continue
97
- if not isinstance(bound, astroid.BoundMethod):
98
- continue
99
- func_obj = bound._proxied
100
- if isinstance(func_obj, astroid.UnboundMethod):
101
- func_obj = func_obj._proxied
102
- if func_obj.name == func.name:
103
- return True
104
- return False
105
-
106
-
107
- def _is_attribute_property(name, klass):
108
- """ Check if the given attribute *name* is a property
109
- in the given *klass*.
110
-
111
- It will look for `property` calls or for functions
112
- with the given name, decorated by `property` or `property`
113
- subclasses.
114
- Returns ``True`` if the name is a property in the given klass,
115
- ``False`` otherwise.
116
- """
117
-
118
- try:
119
- attributes = klass.getattr(name)
120
- except astroid.NotFoundError:
121
- return False
122
- property_name = "{0}.property".format(BUILTINS)
123
- for attr in attributes:
124
- try:
125
- infered = next(attr.infer())
126
- except astroid.InferenceError:
127
- continue
128
- if (isinstance(infered, astroid.FunctionDef) and
129
- decorated_with_property(infered)):
130
- return True
131
- if infered.pytype() == property_name:
132
- return True
133
- return False
134
-
135
- def _has_bare_super_call(fundef_node):
136
- for call in fundef_node.nodes_of_class(astroid.Call):
137
- func = call.func
138
- if (isinstance(func, astroid.Name) and
139
- func.name == 'super' and
140
- not call.args):
141
- return True
142
- return False
143
-
144
- def _safe_infer_call_result(node, caller, context=None):
145
- """
146
- Safely infer the return value of a function.
147
-
148
- Returns None if inference failed or if there is some ambiguity (more than
149
- one node has been inferred). Otherwise returns infered value.
150
- """
151
- try:
152
- inferit = node.infer_call_result(caller, context=context)
153
- value = next(inferit)
154
- except astroid.InferenceError:
155
- return # inference failed
156
- except StopIteration:
157
- return # no values infered
158
- try:
159
- next(inferit)
160
- return # there is ambiguity on the inferred node
161
- except astroid.InferenceError:
162
- return # there is some kind of ambiguity
163
- except StopIteration:
164
- return value
165
-
166
- MSGS = {
167
- 'F0202': ('Unable to check methods signature (%s / %s)',
168
- 'method-check-failed',
169
- 'Used when Pylint has been unable to check methods signature '
170
- 'compatibility for an unexpected reason. Please report this kind '
171
- 'if you don\'t make sense of it.'),
172
-
173
- 'E0202': ('An attribute defined in %s line %s hides this method',
174
- 'method-hidden',
175
- 'Used when a class defines a method which is hidden by an '
176
- 'instance attribute from an ancestor class or set by some '
177
- 'client code.'),
178
- 'E0203': ('Access to member %r before its definition line %s',
179
- 'access-member-before-definition',
180
- 'Used when an instance member is accessed before it\'s actually '
181
- 'assigned.'),
182
- 'W0201': ('Attribute %r defined outside __init__',
183
- 'attribute-defined-outside-init',
184
- 'Used when an instance attribute is defined outside the __init__ '
185
- 'method.'),
186
-
187
- 'W0212': ('Access to a protected member %s of a client class', # E0214
188
- 'protected-access',
189
- 'Used when a protected member (i.e. class member with a name '
190
- 'beginning with an underscore) is access outside the class or a '
191
- 'descendant of the class where it\'s defined.'),
192
-
193
- 'E0211': ('Method has no argument',
194
- 'no-method-argument',
195
- 'Used when a method which should have the bound instance as '
196
- 'first argument has no argument defined.'),
197
- 'E0213': ('Method should have "self" as first argument',
198
- 'no-self-argument',
199
- 'Used when a method has an attribute different the "self" as '
200
- 'first argument. This is considered as an error since this is '
201
- 'a so common convention that you shouldn\'t break it!'),
202
- 'C0202': ('Class method %s should have %s as first argument',
203
- 'bad-classmethod-argument',
204
- 'Used when a class method has a first argument named differently '
205
- 'than the value specified in valid-classmethod-first-arg option '
206
- '(default to "cls"), recommended to easily differentiate them '
207
- 'from regular instance methods.'),
208
- 'C0203': ('Metaclass method %s should have %s as first argument',
209
- 'bad-mcs-method-argument',
210
- 'Used when a metaclass method has a first agument named '
211
- 'differently than the value specified in valid-classmethod-first'
212
- '-arg option (default to "cls"), recommended to easily '
213
- 'differentiate them from regular instance methods.'),
214
- 'C0204': ('Metaclass class method %s should have %s as first argument',
215
- 'bad-mcs-classmethod-argument',
216
- 'Used when a metaclass class method has a first argument named '
217
- 'differently than the value specified in valid-metaclass-'
218
- 'classmethod-first-arg option (default to "mcs"), recommended to '
219
- 'easily differentiate them from regular instance methods.'),
220
-
221
- 'W0211': ('Static method with %r as first argument',
222
- 'bad-staticmethod-argument',
223
- 'Used when a static method has "self" or a value specified in '
224
- 'valid-classmethod-first-arg option or '
225
- 'valid-metaclass-classmethod-first-arg option as first argument.'
226
- ),
227
- 'R0201': ('Method could be a function',
228
- 'no-self-use',
229
- 'Used when a method doesn\'t use its bound instance, and so could '
230
- 'be written as a function.'
231
- ),
232
- 'W0221': ('Arguments number differs from %s %r method',
233
- 'arguments-differ',
234
- 'Used when a method has a different number of arguments than in '
235
- 'the implemented interface or in an overridden method.'),
236
- 'W0222': ('Signature differs from %s %r method',
237
- 'signature-differs',
238
- 'Used when a method signature is different than in the '
239
- 'implemented interface or in an overridden method.'),
240
- 'W0223': ('Method %r is abstract in class %r but is not overridden',
241
- 'abstract-method',
242
- 'Used when an abstract method (i.e. raise NotImplementedError) is '
243
- 'not overridden in concrete class.'
244
- ),
245
- 'W0231': ('__init__ method from base class %r is not called',
246
- 'super-init-not-called',
247
- 'Used when an ancestor class method has an __init__ method '
248
- 'which is not called by a derived class.'),
249
- 'W0232': ('Class has no __init__ method',
250
- 'no-init',
251
- 'Used when a class has no __init__ method, neither its parent '
252
- 'classes.'),
253
- 'W0233': ('__init__ method from a non direct base class %r is called',
254
- 'non-parent-init-called',
255
- 'Used when an __init__ method is called on a class which is not '
256
- 'in the direct ancestors for the analysed class.'),
257
- 'E0236': ('Invalid object %r in __slots__, must contain '
258
- 'only non empty strings',
259
- 'invalid-slots-object',
260
- 'Used when an invalid (non-string) object occurs in __slots__.'),
261
- 'E0237': ('Assigning to attribute %r not defined in class slots',
262
- 'assigning-non-slot',
263
- 'Used when assigning to an attribute not defined '
264
- 'in the class slots.'),
265
- 'E0238': ('Invalid __slots__ object',
266
- 'invalid-slots',
267
- 'Used when an invalid __slots__ is found in class. '
268
- 'Only a string, an iterable or a sequence is permitted.'),
269
- 'E0239': ('Inheriting %r, which is not a class.',
270
- 'inherit-non-class',
271
- 'Used when a class inherits from something which is not a '
272
- 'class.'),
273
- 'E0240': ('Inconsistent method resolution order for class %r',
274
- 'inconsistent-mro',
275
- 'Used when a class has an inconsistent method resolutin order.'),
276
- 'E0241': ('Duplicate bases for class %r',
277
- 'duplicate-bases',
278
- 'Used when a class has duplicate bases.'),
279
- 'R0202': ('Consider using a decorator instead of calling classmethod',
280
- 'no-classmethod-decorator',
281
- 'Used when a class method is defined without using the decorator '
282
- 'syntax.'),
283
- 'R0203': ('Consider using a decorator instead of calling staticmethod',
284
- 'no-staticmethod-decorator',
285
- 'Used when a static method is defined without using the decorator '
286
- 'syntax.'),
287
- }
288
-
289
-
290
- class ClassChecker(BaseChecker):
291
- """checks for :
292
- * methods without self as first argument
293
- * overridden methods signature
294
- * access only to existent members via self
295
- * attributes not defined in the __init__ method
296
- * unreachable code
297
- """
298
-
299
- __implements__ = (IAstroidChecker,)
300
-
301
- # configuration section name
302
- name = 'classes'
303
- # messages
304
- msgs = MSGS
305
- priority = -2
306
- # configuration options
307
- options = (('ignore-iface-methods',
308
- # TODO(cpopa): remove this in Pylint 1.6.
309
- deprecated_option(opt_type="csv",
310
- help_msg="This is deprecated, because "
311
- "it is not used anymore.")
312
- ),
313
- ('defining-attr-methods',
314
- {'default' : ('__init__', '__new__', 'setUp'),
315
- 'type' : 'csv',
316
- 'metavar' : '<method names>',
317
- 'help' : 'List of method names used to declare (i.e. assign) \
318
- instance attributes.'}
319
- ),
320
- ('valid-classmethod-first-arg',
321
- {'default' : ('cls',),
322
- 'type' : 'csv',
323
- 'metavar' : '<argument names>',
324
- 'help' : 'List of valid names for the first argument in \
325
- a class method.'}
326
- ),
327
- ('valid-metaclass-classmethod-first-arg',
328
- {'default' : ('mcs',),
329
- 'type' : 'csv',
330
- 'metavar' : '<argument names>',
331
- 'help' : 'List of valid names for the first argument in \
332
- a metaclass class method.'}
333
- ),
334
- ('exclude-protected',
335
- {
336
- 'default': (
337
- # namedtuple public API.
338
- '_asdict', '_fields', '_replace', '_source', '_make'),
339
- 'type': 'csv',
340
- 'metavar': '<protected access exclusions>',
341
- 'help': ('List of member names, which should be excluded '
342
- 'from the protected access warning.')}
343
- ))
344
-
345
- def __init__(self, linter=None):
346
- BaseChecker.__init__(self, linter)
347
- self._accessed = []
348
- self._first_attrs = []
349
- self._meth_could_be_func = None
350
-
351
- def visit_classdef(self, node):
352
- """init visit variable _accessed
353
- """
354
- self._accessed.append(defaultdict(list))
355
- self._check_bases_classes(node)
356
- # if not an exception or a metaclass
357
- if node.type == 'class' and has_known_bases(node):
358
- try:
359
- node.local_attr('__init__')
360
- except astroid.NotFoundError:
361
- self.add_message('no-init', args=node, node=node)
362
- self._check_slots(node)
363
- self._check_proper_bases(node)
364
- self._check_consistent_mro(node)
365
-
366
- def _check_consistent_mro(self, node):
367
- """Detect that a class has a consistent mro or duplicate bases."""
368
- try:
369
- node.mro()
370
- except InconsistentMroError:
371
- self.add_message('inconsistent-mro', args=node.name, node=node)
372
- except DuplicateBasesError:
373
- self.add_message('duplicate-bases', args=node.name, node=node)
374
- except NotImplementedError:
375
- # Old style class, there's no mro so don't do anything.
376
- pass
377
-
378
- def _check_proper_bases(self, node):
379
- """
380
- Detect that a class inherits something which is not
381
- a class or a type.
382
- """
383
- for base in node.bases:
384
- ancestor = safe_infer(base)
385
- if ancestor in (astroid.YES, None):
386
- continue
387
- if (isinstance(ancestor, astroid.Instance) and
388
- ancestor.is_subtype_of('%s.type' % (BUILTINS,))):
389
- continue
390
-
391
- if (not isinstance(ancestor, astroid.ClassDef) or
392
- _is_invalid_base_class(ancestor)):
393
- self.add_message('inherit-non-class',
394
- args=base.as_string(), node=node)
395
-
396
- def leave_classdef(self, cnode):
397
- """close a class node:
398
- check that instance attributes are defined in __init__ and check
399
- access to existent members
400
- """
401
- # check access to existent members on non metaclass classes
402
- ignore_mixins = get_global_option(self, 'ignore-mixin-members',
403
- default=True)
404
- if ignore_mixins and cnode.name[-5:].lower() == 'mixin':
405
- # We are in a mixin class. No need to try to figure out if
406
- # something is missing, since it is most likely that it will
407
- # miss.
408
- return
409
-
410
- accessed = self._accessed.pop()
411
- if cnode.type != 'metaclass':
412
- self._check_accessed_members(cnode, accessed)
413
- # checks attributes are defined in an allowed method such as __init__
414
- if not self.linter.is_message_enabled('attribute-defined-outside-init'):
415
- return
416
- defining_methods = self.config.defining_attr_methods
417
- current_module = cnode.root()
418
- for attr, nodes in six.iteritems(cnode.instance_attrs):
419
- # skip nodes which are not in the current module and it may screw up
420
- # the output, while it's not worth it
421
- nodes = [n for n in nodes if not
422
- isinstance(n.statement(), (astroid.Delete, astroid.AugAssign))
423
- and n.root() is current_module]
424
- if not nodes:
425
- continue # error detected by typechecking
426
- # check if any method attr is defined in is a defining method
427
- if any(node.frame().name in defining_methods
428
- for node in nodes):
429
- continue
430
-
431
- # check attribute is defined in a parent's __init__
432
- for parent in cnode.instance_attr_ancestors(attr):
433
- attr_defined = False
434
- # check if any parent method attr is defined in is a defining method
435
- for node in parent.instance_attrs[attr]:
436
- if node.frame().name in defining_methods:
437
- attr_defined = True
438
- if attr_defined:
439
- # we're done :)
440
- break
441
- else:
442
- # check attribute is defined as a class attribute
443
- try:
444
- cnode.local_attr(attr)
445
- except astroid.NotFoundError:
446
- for node in nodes:
447
- if node.frame().name not in defining_methods:
448
- # If the attribute was set by a callfunc in any
449
- # of the defining methods, then don't emit
450
- # the warning.
451
- if _called_in_methods(node.frame(), cnode,
452
- defining_methods):
453
- continue
454
- self.add_message('attribute-defined-outside-init',
455
- args=attr, node=node)
456
-
457
- def visit_functiondef(self, node):
458
- """check method arguments, overriding"""
459
- # ignore actual functions
460
- if not node.is_method():
461
- return
462
- klass = node.parent.frame()
463
- self._meth_could_be_func = True
464
- # check first argument is self if this is actually a method
465
- self._check_first_arg_for_type(node, klass.type == 'metaclass')
466
- if node.name == '__init__':
467
- self._check_init(node)
468
- return
469
- # check signature if the method overloads inherited method
470
- for overridden in klass.local_attr_ancestors(node.name):
471
- # get astroid for the searched method
472
- try:
473
- meth_node = overridden[node.name]
474
- except KeyError:
475
- # we have found the method but it's not in the local
476
- # dictionary.
477
- # This may happen with astroid build from living objects
478
- continue
479
- if not isinstance(meth_node, astroid.FunctionDef):
480
- continue
481
- self._check_signature(node, meth_node, 'overridden', klass)
482
- break
483
- if node.decorators:
484
- for decorator in node.decorators.nodes:
485
- if isinstance(decorator, astroid.Attribute) and \
486
- decorator.attrname in ('getter', 'setter', 'deleter'):
487
- # attribute affectation will call this method, not hiding it
488
- return
489
- if isinstance(decorator, astroid.Name) and decorator.name == 'property':
490
- # attribute affectation will either call a setter or raise
491
- # an attribute error, anyway not hiding the function
492
- return
493
- # check if the method is hidden by an attribute
494
- try:
495
- overridden = klass.instance_attr(node.name)[0] # XXX
496
- overridden_frame = overridden.frame()
497
- if (isinstance(overridden_frame, astroid.FunctionDef)
498
- and overridden_frame.type == 'method'):
499
- overridden_frame = overridden_frame.parent.frame()
500
- if (isinstance(overridden_frame, astroid.ClassDef)
501
- and klass.is_subtype_of(overridden_frame.qname())):
502
- args = (overridden.root().name, overridden.fromlineno)
503
- self.add_message('method-hidden', args=args, node=node)
504
- except astroid.NotFoundError:
505
- pass
506
-
507
- visit_asyncfunctiondef = visit_functiondef
508
-
509
- def _check_slots(self, node):
510
- if '__slots__' not in node.locals:
511
- return
512
- for slots in node.igetattr('__slots__'):
513
- # check if __slots__ is a valid type
514
- for meth in ITER_METHODS:
515
- try:
516
- slots.getattr(meth)
517
- break
518
- except astroid.NotFoundError:
519
- continue
520
- else:
521
- self.add_message('invalid-slots', node=node)
522
- continue
523
-
524
- if isinstance(slots, astroid.Const):
525
- # a string, ignore the following checks
526
- continue
527
- if not hasattr(slots, 'itered'):
528
- # we can't obtain the values, maybe a .deque?
529
- continue
530
-
531
- if isinstance(slots, astroid.Dict):
532
- values = [item[0] for item in slots.items]
533
- else:
534
- values = slots.itered()
535
- if values is astroid.YES:
536
- return
537
-
538
- for elt in values:
539
- try:
540
- self._check_slots_elt(elt)
541
- except astroid.InferenceError:
542
- continue
543
-
544
- def _check_slots_elt(self, elt):
545
- for infered in elt.infer():
546
- if infered is astroid.YES:
547
- continue
548
- if (not isinstance(infered, astroid.Const) or
549
- not isinstance(infered.value, six.string_types)):
550
- self.add_message('invalid-slots-object',
551
- args=infered.as_string(),
552
- node=elt)
553
- continue
554
- if not infered.value:
555
- self.add_message('invalid-slots-object',
556
- args=infered.as_string(),
557
- node=elt)
558
-
559
- def leave_functiondef(self, node):
560
- """on method node, check if this method couldn't be a function
561
-
562
- ignore class, static and abstract methods, initializer,
563
- methods overridden from a parent class.
564
- """
565
- if node.is_method():
566
- if node.args.args is not None:
567
- self._first_attrs.pop()
568
- if not self.linter.is_message_enabled('no-self-use'):
569
- return
570
- class_node = node.parent.frame()
571
- if (self._meth_could_be_func and node.type == 'method'
572
- and node.name not in PYMETHODS
573
- and not (node.is_abstract() or
574
- overrides_a_method(class_node, node.name) or
575
- decorated_with_property(node) or
576
- (six.PY3 and _has_bare_super_call(node)))):
577
- self.add_message('no-self-use', node=node)
578
-
579
- def visit_attribute(self, node):
580
- """check if the getattr is an access to a class member
581
- if so, register it. Also check for access to protected
582
- class member from outside its class (but ignore __special__
583
- methods)
584
- """
585
- attrname = node.attrname
586
- # Check self
587
- if self.is_first_attr(node):
588
- self._accessed[-1][attrname].append(node)
589
- return
590
- if not self.linter.is_message_enabled('protected-access'):
591
- return
592
-
593
- self._check_protected_attribute_access(node)
594
-
595
- def visit_assignattr(self, node):
596
- if isinstance(node.assign_type(), astroid.AugAssign) and self.is_first_attr(node):
597
- self._accessed[-1][node.attrname].append(node)
598
- self._check_in_slots(node)
599
-
600
- def _check_in_slots(self, node):
601
- """ Check that the given assattr node
602
- is defined in the class slots.
603
- """
604
- infered = safe_infer(node.expr)
605
- if infered and isinstance(infered, astroid.Instance):
606
- klass = infered._proxied
607
- if '__slots__' not in klass.locals or not klass.newstyle:
608
- return
609
-
610
- slots = klass.slots()
611
- if slots is None:
612
- return
613
- # If any ancestor doesn't use slots, the slots
614
- # defined for this class are superfluous.
615
- if any('__slots__' not in ancestor.locals and
616
- ancestor.name != 'object'
617
- for ancestor in klass.ancestors()):
618
- return
619
-
620
- if not any(slot.value == node.attrname for slot in slots):
621
- # If we have a '__dict__' in slots, then
622
- # assigning any name is valid.
623
- if not any(slot.value == '__dict__' for slot in slots):
624
- if _is_attribute_property(node.attrname, klass):
625
- # Properties circumvent the slots mechanism,
626
- # so we should not emit a warning for them.
627
- return
628
- if (node.attrname in klass.locals
629
- and _has_data_descriptor(klass, node.attrname)):
630
- # Descriptors circumvent the slots mechanism as well.
631
- return
632
- self.add_message('assigning-non-slot',
633
- args=(node.attrname, ), node=node)
634
-
635
- @check_messages('protected-access', 'no-classmethod-decorator',
636
- 'no-staticmethod-decorator')
637
- def visit_assign(self, assign_node):
638
- self._check_classmethod_declaration(assign_node)
639
- node = assign_node.targets[0]
640
- if not isinstance(node, astroid.AssignAttr):
641
- return
642
-
643
- if self.is_first_attr(node):
644
- return
645
- self._check_protected_attribute_access(node)
646
-
647
- def _check_classmethod_declaration(self, node):
648
- """Checks for uses of classmethod() or staticmethod()
649
-
650
- When a @classmethod or @staticmethod decorator should be used instead.
651
- A message will be emitted only if the assignment is at a class scope
652
- and only if the classmethod's argument belongs to the class where it
653
- is defined.
654
- `node` is an assign node.
655
- """
656
- if not isinstance(node.value, astroid.Call):
657
- return
658
-
659
- # check the function called is "classmethod" or "staticmethod"
660
- func = node.value.func
661
- if (not isinstance(func, astroid.Name) or
662
- func.name not in ('classmethod', 'staticmethod')):
663
- return
664
-
665
- msg = ('no-classmethod-decorator' if func.name == 'classmethod' else
666
- 'no-staticmethod-decorator')
667
- # assignment must be at a class scope
668
- parent_class = node.scope()
669
- if not isinstance(parent_class, astroid.ClassDef):
670
- return
671
-
672
- # Check if the arg passed to classmethod is a class member
673
- classmeth_arg = node.value.args[0]
674
- if not isinstance(classmeth_arg, astroid.Name):
675
- return
676
-
677
- method_name = classmeth_arg.name
678
- if any(method_name == member.name
679
- for member in parent_class.mymethods()):
680
- self.add_message(msg, node=node.targets[0])
681
-
682
- def _check_protected_attribute_access(self, node):
683
- '''Given an attribute access node (set or get), check if attribute
684
- access is legitimate. Call _check_first_attr with node before calling
685
- this method. Valid cases are:
686
- * self._attr in a method or cls._attr in a classmethod. Checked by
687
- _check_first_attr.
688
- * Klass._attr inside "Klass" class.
689
- * Klass2._attr inside "Klass" class when Klass2 is a base class of
690
- Klass.
691
- '''
692
- attrname = node.attrname
693
-
694
- if (is_attr_protected(attrname) and
695
- attrname not in self.config.exclude_protected):
696
-
697
- klass = node_frame_class(node)
698
-
699
- # XXX infer to be more safe and less dirty ??
700
- # in classes, check we are not getting a parent method
701
- # through the class object or through super
702
- callee = node.expr.as_string()
703
-
704
- # We are not in a class, no remaining valid case
705
- if klass is None:
706
- self.add_message('protected-access', node=node, args=attrname)
707
- return
708
-
709
- # If the expression begins with a call to super, that's ok.
710
- if isinstance(node.expr, astroid.Call) and \
711
- isinstance(node.expr.func, astroid.Name) and \
712
- node.expr.func.name == 'super':
713
- return
714
-
715
- # We are in a class, one remaining valid cases, Klass._attr inside
716
- # Klass
717
- if not (callee == klass.name or callee in klass.basenames):
718
- # Detect property assignments in the body of the class.
719
- # This is acceptable:
720
- #
721
- # class A:
722
- # b = property(lambda: self._b)
723
-
724
- stmt = node.parent.statement()
725
- if (isinstance(stmt, astroid.Assign)
726
- and len(stmt.targets) == 1
727
- and isinstance(stmt.targets[0], astroid.AssignName)):
728
- name = stmt.targets[0].name
729
- if _is_attribute_property(name, klass):
730
- return
731
-
732
- self.add_message('protected-access', node=node, args=attrname)
733
-
734
- def visit_name(self, node):
735
- """check if the name handle an access to a class member
736
- if so, register it
737
- """
738
- if self._first_attrs and (node.name == self._first_attrs[-1] or
739
- not self._first_attrs[-1]):
740
- self._meth_could_be_func = False
741
-
742
- def _check_accessed_members(self, node, accessed):
743
- """check that accessed members are defined"""
744
- # XXX refactor, probably much simpler now that E0201 is in type checker
745
- excs = ('AttributeError', 'Exception', 'BaseException')
746
- for attr, nodes in six.iteritems(accessed):
747
- try:
748
- # is it a class attribute ?
749
- node.local_attr(attr)
750
- # yes, stop here
751
- continue
752
- except astroid.NotFoundError:
753
- pass
754
- # is it an instance attribute of a parent class ?
755
- try:
756
- next(node.instance_attr_ancestors(attr))
757
- # yes, stop here
758
- continue
759
- except StopIteration:
760
- pass
761
- # is it an instance attribute ?
762
- try:
763
- defstmts = node.instance_attr(attr)
764
- except astroid.NotFoundError:
765
- pass
766
- else:
767
- # filter out augment assignment nodes
768
- defstmts = [stmt for stmt in defstmts if stmt not in nodes]
769
- if not defstmts:
770
- # only augment assignment for this node, no-member should be
771
- # triggered by the typecheck checker
772
- continue
773
- # filter defstmts to only pick the first one when there are
774
- # several assignments in the same scope
775
- scope = defstmts[0].scope()
776
- defstmts = [stmt for i, stmt in enumerate(defstmts)
777
- if i == 0 or stmt.scope() is not scope]
778
- # if there are still more than one, don't attempt to be smarter
779
- # than we can be
780
- if len(defstmts) == 1:
781
- defstmt = defstmts[0]
782
- # check that if the node is accessed in the same method as
783
- # it's defined, it's accessed after the initial assignment
784
- frame = defstmt.frame()
785
- lno = defstmt.fromlineno
786
- for _node in nodes:
787
- if _node.frame() is frame and _node.fromlineno < lno \
788
- and not astroid.are_exclusive(_node.statement(), defstmt, excs):
789
- self.add_message('access-member-before-definition',
790
- node=_node, args=(attr, lno))
791
-
792
- def _check_first_arg_for_type(self, node, metaclass=0):
793
- """check the name of first argument, expect:
794
-
795
- * 'self' for a regular method
796
- * 'cls' for a class method or a metaclass regular method (actually
797
- valid-classmethod-first-arg value)
798
- * 'mcs' for a metaclass class method (actually
799
- valid-metaclass-classmethod-first-arg)
800
- * not one of the above for a static method
801
- """
802
- # don't care about functions with unknown argument (builtins)
803
- if node.args.args is None:
804
- return
805
- first_arg = node.args.args and node.argnames()[0]
806
- self._first_attrs.append(first_arg)
807
- first = self._first_attrs[-1]
808
- # static method
809
- if node.type == 'staticmethod':
810
- if (first_arg == 'self' or
811
- first_arg in self.config.valid_classmethod_first_arg or
812
- first_arg in self.config.valid_metaclass_classmethod_first_arg):
813
- self.add_message('bad-staticmethod-argument', args=first, node=node)
814
- return
815
- self._first_attrs[-1] = None
816
- # class / regular method with no args
817
- elif not node.args.args:
818
- self.add_message('no-method-argument', node=node)
819
- # metaclass
820
- elif metaclass:
821
- # metaclass __new__ or classmethod
822
- if node.type == 'classmethod':
823
- self._check_first_arg_config(
824
- first,
825
- self.config.valid_metaclass_classmethod_first_arg, node,
826
- 'bad-mcs-classmethod-argument', node.name)
827
- # metaclass regular method
828
- else:
829
- self._check_first_arg_config(
830
- first,
831
- self.config.valid_classmethod_first_arg, node,
832
- 'bad-mcs-method-argument',
833
- node.name)
834
- # regular class
835
- else:
836
- # class method
837
- if node.type == 'classmethod':
838
- self._check_first_arg_config(
839
- first,
840
- self.config.valid_classmethod_first_arg, node,
841
- 'bad-classmethod-argument',
842
- node.name)
843
- # regular method without self as argument
844
- elif first != 'self':
845
- self.add_message('no-self-argument', node=node)
846
-
847
- def _check_first_arg_config(self, first, config, node, message,
848
- method_name):
849
- if first not in config:
850
- if len(config) == 1:
851
- valid = repr(config[0])
852
- else:
853
- valid = ', '.join(repr(v) for v in config[:-1])
854
- valid = '%s or %r' % (valid, config[-1])
855
- self.add_message(message, args=(method_name, valid), node=node)
856
-
857
- def _check_bases_classes(self, node):
858
- """check that the given class node implements abstract methods from
859
- base classes
860
- """
861
- def is_abstract(method):
862
- return method.is_abstract(pass_is_abstract=False)
863
-
864
- # check if this class abstract
865
- if class_is_abstract(node):
866
- return
867
-
868
- methods = sorted(
869
- unimplemented_abstract_methods(node, is_abstract).items(),
870
- key=lambda item: item[0],
871
- )
872
- for name, method in methods:
873
- owner = method.parent.frame()
874
- if owner is node:
875
- continue
876
- # owner is not this class, it must be a parent class
877
- # check that the ancestor's method is not abstract
878
- if name in node.locals:
879
- # it is redefined as an attribute or with a descriptor
880
- continue
881
- self.add_message('abstract-method', node=node,
882
- args=(name, owner.name))
883
-
884
- def _check_init(self, node):
885
- """check that the __init__ method call super or ancestors'__init__
886
- method
887
- """
888
- if (not self.linter.is_message_enabled('super-init-not-called') and
889
- not self.linter.is_message_enabled('non-parent-init-called')):
890
- return
891
- klass_node = node.parent.frame()
892
- to_call = _ancestors_to_call(klass_node)
893
- not_called_yet = dict(to_call)
894
- for stmt in node.nodes_of_class(astroid.Call):
895
- expr = stmt.func
896
- if not isinstance(expr, astroid.Attribute) \
897
- or expr.attrname != '__init__':
898
- continue
899
- # skip the test if using super
900
- if isinstance(expr.expr, astroid.Call) and \
901
- isinstance(expr.expr.func, astroid.Name) and \
902
- expr.expr.func.name == 'super':
903
- return
904
- try:
905
- for klass in expr.expr.infer():
906
- if klass is astroid.YES:
907
- continue
908
- # The infered klass can be super(), which was
909
- # assigned to a variable and the `__init__`
910
- # was called later.
911
- #
912
- # base = super()
913
- # base.__init__(...)
914
-
915
- if (isinstance(klass, astroid.Instance) and
916
- isinstance(klass._proxied, astroid.ClassDef) and
917
- is_builtin_object(klass._proxied) and
918
- klass._proxied.name == 'super'):
919
- return
920
- elif isinstance(klass, objects.Super):
921
- return
922
- try:
923
- del not_called_yet[klass]
924
- except KeyError:
925
- if klass not in to_call:
926
- self.add_message('non-parent-init-called',
927
- node=expr, args=klass.name)
928
- except astroid.InferenceError:
929
- continue
930
- for klass, method in six.iteritems(not_called_yet):
931
- if klass.name == 'object' or method.parent.name == 'object':
932
- continue
933
- self.add_message('super-init-not-called', args=klass.name, node=node)
934
-
935
- def _check_signature(self, method1, refmethod, class_type, cls):
936
- """check that the signature of the two given methods match
937
- """
938
- if not (isinstance(method1, astroid.FunctionDef)
939
- and isinstance(refmethod, astroid.FunctionDef)):
940
- self.add_message('method-check-failed',
941
- args=(method1, refmethod), node=method1)
942
- return
943
-
944
- instance = cls.instanciate_class()
945
- method1 = function_to_method(method1, instance)
946
- refmethod = function_to_method(refmethod, instance)
947
-
948
- # Don't care about functions with unknown argument (builtins).
949
- if method1.args.args is None or refmethod.args.args is None:
950
- return
951
- # If we use *args, **kwargs, skip the below checks.
952
- if method1.args.vararg or method1.args.kwarg:
953
- return
954
- # Ignore private to class methods.
955
- if is_attr_private(method1.name):
956
- return
957
- # Ignore setters, they have an implicit extra argument,
958
- # which shouldn't be taken in consideration.
959
- if method1.decorators:
960
- for decorator in method1.decorators.nodes:
961
- if (isinstance(decorator, astroid.Attribute) and
962
- decorator.attrname == 'setter'):
963
- return
964
-
965
- method1_args = _get_method_args(method1)
966
- refmethod_args = _get_method_args(refmethod)
967
- if method1_args != refmethod_args:
968
- self.add_message('arguments-differ',
969
- args=(class_type, method1.name),
970
- node=method1)
971
- elif len(method1.args.defaults) < len(refmethod.args.defaults):
972
- self.add_message('signature-differs',
973
- args=(class_type, method1.name),
974
- node=method1)
975
-
976
- def is_first_attr(self, node):
977
- """Check that attribute lookup name use first attribute variable name
978
- (self for method, cls for classmethod and mcs for metaclass).
979
- """
980
- return self._first_attrs and isinstance(node.expr, astroid.Name) and \
981
- node.expr.name == self._first_attrs[-1]
982
-
983
-
984
- class SpecialMethodsChecker(BaseChecker):
985
- """Checker which verifies that special methods
986
- are implemented correctly.
987
- """
988
- __implements__ = (IAstroidChecker, )
989
- name = 'classes'
990
- msgs = {
991
- 'E0301': ('__iter__ returns non-iterator',
992
- 'non-iterator-returned',
993
- 'Used when an __iter__ method returns something which is not an '
994
- 'iterable (i.e. has no `%s` method)' % NEXT_METHOD,
995
- {'old_names': [('W0234', 'non-iterator-returned'),
996
- ('E0234', 'non-iterator-returned')]}),
997
- 'E0302': ('The special method %r expects %s param(s), %d %s given',
998
- 'unexpected-special-method-signature',
999
- 'Emitted when a special method was defined with an '
1000
- 'invalid number of parameters. If it has too few or '
1001
- 'too many, it might not work at all.',
1002
- {'old_names': [('E0235', 'bad-context-manager')]}),
1003
- }
1004
- priority = -2
1005
-
1006
- @check_messages('unexpected-special-method-signature',
1007
- 'non-iterator-returned')
1008
- def visit_functiondef(self, node):
1009
- if not node.is_method():
1010
- return
1011
- if node.name == '__iter__':
1012
- self._check_iter(node)
1013
- if node.name in PYMETHODS:
1014
- self._check_unexpected_method_signature(node)
1015
-
1016
- visit_asyncfunctiondef = visit_functiondef
1017
-
1018
- def _check_unexpected_method_signature(self, node):
1019
- expected_params = SPECIAL_METHODS_PARAMS[node.name]
1020
-
1021
- if expected_params is None:
1022
- # This can support a variable number of parameters.
1023
- return
1024
- if not len(node.args.args) and not node.args.vararg:
1025
- # Method has no parameter, will be catched
1026
- # by no-method-argument.
1027
- return
1028
-
1029
- if decorated_with(node, [BUILTINS + ".staticmethod"]):
1030
- # We expect to not take in consideration self.
1031
- all_args = node.args.args
1032
- else:
1033
- all_args = node.args.args[1:]
1034
- mandatory = len(all_args) - len(node.args.defaults)
1035
- optional = len(node.args.defaults)
1036
- current_params = mandatory + optional
1037
-
1038
- if isinstance(expected_params, tuple):
1039
- # The expected number of parameters can be any value from this
1040
- # tuple, although the user should implement the method
1041
- # to take all of them in consideration.
1042
- emit = mandatory not in expected_params
1043
- expected_params = "between %d or %d" % expected_params
1044
- else:
1045
- # If the number of mandatory parameters doesn't
1046
- # suffice, the expected parameters for this
1047
- # function will be deduced from the optional
1048
- # parameters.
1049
- rest = expected_params - mandatory
1050
- if rest == 0:
1051
- emit = False
1052
- elif rest < 0:
1053
- emit = True
1054
- elif rest > 0:
1055
- emit = not ((optional - rest) >= 0 or node.args.vararg)
1056
-
1057
- if emit:
1058
- verb = "was" if current_params <= 1 else "were"
1059
- self.add_message('unexpected-special-method-signature',
1060
- args=(node.name, expected_params, current_params, verb),
1061
- node=node)
1062
-
1063
- @staticmethod
1064
- def _is_iterator(node):
1065
- if node is astroid.YES:
1066
- # Just ignore YES objects.
1067
- return True
1068
- if isinstance(node, Generator):
1069
- # Generators can be itered.
1070
- return True
1071
-
1072
- if isinstance(node, astroid.Instance):
1073
- try:
1074
- node.local_attr(NEXT_METHOD)
1075
- return True
1076
- except astroid.NotFoundError:
1077
- pass
1078
- elif isinstance(node, astroid.ClassDef):
1079
- metaclass = node.metaclass()
1080
- if metaclass and isinstance(metaclass, astroid.ClassDef):
1081
- try:
1082
- metaclass.local_attr(NEXT_METHOD)
1083
- return True
1084
- except astroid.NotFoundError:
1085
- pass
1086
- return False
1087
-
1088
- def _check_iter(self, node):
1089
- infered = _safe_infer_call_result(node, node)
1090
- if infered is not None:
1091
- if not self._is_iterator(infered):
1092
- self.add_message('non-iterator-returned', node=node)
1093
-
1094
-
1095
- def _ancestors_to_call(klass_node, method='__init__'):
1096
- """return a dictionary where keys are the list of base classes providing
1097
- the queried method, and so that should/may be called from the method node
1098
- """
1099
- to_call = {}
1100
- for base_node in klass_node.ancestors(recurs=False):
1101
- try:
1102
- to_call[base_node] = next(base_node.igetattr(method))
1103
- except astroid.InferenceError:
1104
- continue
1105
- return to_call
1106
-
1107
-
1108
- def node_method(node, method_name):
1109
- """get astroid for <method_name> on the given class node, ensuring it
1110
- is a Function node
1111
- """
1112
- for node_attr in node.local_attr(method_name):
1113
- if isinstance(node_attr, astroid.Function):
1114
- return node_attr
1115
- raise astroid.NotFoundError(method_name)
1116
-
1117
- def register(linter):
1118
- """required method to auto register this checker """
1119
- linter.register_checker(ClassChecker(linter))
1120
- linter.register_checker(SpecialMethodsChecker(linter))