libv8 6.7.288.46.1 → 7.3.492.27.0beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +3 -0
- data/CHANGELOG.md +4 -0
- data/README.md +2 -0
- data/ext/libv8/builder.rb +6 -2
- data/lib/libv8/version.rb +1 -1
- data/vendor/depot_tools/.gitattributes +1 -0
- data/vendor/depot_tools/.gitignore +7 -0
- data/vendor/depot_tools/CROS_OWNERS +5 -0
- data/vendor/depot_tools/OWNERS +12 -1
- data/vendor/depot_tools/PRESUBMIT.py +16 -9
- data/vendor/depot_tools/README.md +9 -2
- data/vendor/depot_tools/autoninja +14 -6
- data/vendor/depot_tools/autoninja.bat +11 -1
- data/vendor/depot_tools/autoninja.py +40 -18
- data/vendor/depot_tools/bb +12 -0
- data/vendor/depot_tools/bb.bat +7 -0
- data/vendor/depot_tools/bootstrap/win/manifest.txt +1 -1
- data/vendor/depot_tools/bootstrap/win/manifest_bleeding_edge.txt +1 -1
- data/vendor/depot_tools/bootstrap/win/win_tools.py +2 -1
- data/vendor/depot_tools/buildbucket.py +57 -4
- data/vendor/depot_tools/cipd +157 -44
- data/vendor/depot_tools/cipd.bat +51 -14
- data/vendor/depot_tools/cipd.ps1 +104 -42
- data/vendor/depot_tools/cipd_client_version +1 -1
- data/vendor/depot_tools/cipd_client_version.digests +21 -0
- data/vendor/depot_tools/cipd_manifest.txt +19 -6
- data/vendor/depot_tools/cipd_manifest.versions +318 -0
- data/vendor/depot_tools/clang_format.py +4 -4
- data/vendor/depot_tools/cpplint.py +44 -199
- data/vendor/depot_tools/dart_format.py +2 -2
- data/vendor/depot_tools/detect_host_arch.py +8 -3
- data/vendor/depot_tools/download_from_google_storage.py +47 -39
- data/vendor/depot_tools/fetch.py +30 -18
- data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
- data/vendor/depot_tools/fetch_configs/chromium.py +18 -1
- data/vendor/depot_tools/fetch_configs/config_util.py +4 -2
- data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
- data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
- data/vendor/depot_tools/fix_encoding.py +3 -3
- data/vendor/depot_tools/gclient +1 -1
- data/vendor/depot_tools/gclient.py +415 -198
- data/vendor/depot_tools/gclient_eval.py +220 -171
- data/vendor/depot_tools/gclient_paths.py +142 -0
- data/vendor/depot_tools/gclient_scm.py +200 -51
- data/vendor/depot_tools/gclient_utils.py +88 -191
- data/vendor/depot_tools/gerrit_client.py +13 -0
- data/vendor/depot_tools/gerrit_util.py +158 -23
- data/vendor/depot_tools/git-nav-upstream +1 -1
- data/vendor/depot_tools/git_cache.py +77 -24
- data/vendor/depot_tools/git_cl.py +705 -1099
- data/vendor/depot_tools/git_common.py +9 -6
- data/vendor/depot_tools/git_map_branches.py +19 -2
- data/vendor/depot_tools/git_nav_downstream.py +3 -4
- data/vendor/depot_tools/git_rebase_update.py +14 -0
- data/vendor/depot_tools/git_reparent_branch.py +8 -2
- data/vendor/depot_tools/gn.py +38 -3
- data/vendor/depot_tools/gsutil.py +8 -3
- data/vendor/depot_tools/gsutil.py.bat +15 -0
- data/vendor/depot_tools/gsutil.vpython +16 -0
- data/vendor/depot_tools/infra/config/OWNERS +0 -1
- data/vendor/depot_tools/infra/config/recipes.cfg +3 -2
- data/vendor/depot_tools/lucicfg +12 -0
- data/vendor/depot_tools/lucicfg.bat +7 -0
- data/vendor/depot_tools/man/html/git-map-branches.html +34 -2
- data/vendor/depot_tools/man/html/git-new-branch.html +40 -32
- data/vendor/depot_tools/man/man1/git-map-branches.1 +24 -5
- data/vendor/depot_tools/man/man1/git-new-branch.1 +35 -27
- data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +1 -0
- data/vendor/depot_tools/man/src/git-map-branches.txt +10 -0
- data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +9 -4
- data/vendor/depot_tools/man/src/git-new-branch.txt +1 -1
- data/vendor/depot_tools/metrics.README.md +98 -0
- data/vendor/depot_tools/metrics.py +296 -0
- data/vendor/depot_tools/metrics_utils.py +303 -0
- data/vendor/depot_tools/my_activity.py +91 -29
- data/vendor/depot_tools/ninja +1 -1
- data/vendor/depot_tools/ninjalog.README.md +64 -0
- data/vendor/depot_tools/ninjalog_uploader.py +232 -0
- data/vendor/depot_tools/ninjalog_uploader_wrapper.py +116 -0
- data/vendor/depot_tools/owners.py +30 -13
- data/vendor/depot_tools/owners_finder.py +5 -2
- data/vendor/depot_tools/presubmit_canned_checks.py +188 -29
- data/vendor/depot_tools/presubmit_support.py +18 -41
- data/vendor/depot_tools/pylintrc +23 -19
- data/vendor/depot_tools/recipes/OWNERS +2 -0
- data/vendor/depot_tools/recipes/README.recipes.md +344 -151
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +2 -16
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +141 -99
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +5 -8
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +5 -8
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +6 -98
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +45 -5
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob.json → input_commit_with_id_without_repo.json} +6 -11
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{tryjob_empty_revision.json → multiple_patch_refs.json} +8 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +19 -29
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/{trychange.json → refs.json} +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +51 -6
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +50 -6
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +51 -6
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +17 -25
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +17 -25
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +18 -26
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +18 -26
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +26 -28
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +45 -5
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +17 -25
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +13 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name.json +13 -152
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +4 -9
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +185 -202
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +52 -157
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +5 -14
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +34 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +14 -2
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +7 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +9 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +9 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +9 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +13 -8
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +18 -12
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +18 -12
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +18 -12
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +3 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +58 -46
- data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +65 -22
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/buildbot.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +20 -21
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +5 -2
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +62 -14
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +24 -38
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +56 -50
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +15 -9
- data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +4 -1
- data/vendor/depot_tools/recipes/recipe_modules/git/api.py +34 -22
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_luci.json +222 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +224 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +10 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +5 -7
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +5 -7
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +10 -5
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +8 -9
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +12 -8
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +5 -6
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +27 -11
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +1 -1
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +12 -13
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +120 -5
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +45 -3
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +25 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +56 -4
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +6 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +24 -13
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +13 -14
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/basic.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_linux.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_mac.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_buildbot_win.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_linux.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_mac.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_generic_win.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_linux.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_mac.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/examples/full.expected/paths_kitchen_win.json +2 -3
- data/vendor/depot_tools/recipes/recipe_modules/infra_paths/path_config.py +1 -2
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +35 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +116 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +82 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +23 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +2 -7
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +7 -6
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +117 -8
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +4 -5
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/set_failure_hash_with_no_steps.json +7 -4
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +98 -7
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +147 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch.json +8 -5
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_git_patch_luci.json +8 -5
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +9 -6
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +9 -6
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +27 -2
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/__init__.py +25 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/api.py +137 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/linux.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +107 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +26 -0
- data/vendor/depot_tools/recipes/recipes.py +37 -27
- data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +7 -10
- data/vendor/depot_tools/repo +34 -8
- data/vendor/depot_tools/roll_dep.py +52 -49
- data/vendor/depot_tools/scm.py +38 -23
- data/vendor/depot_tools/setup_color.py +4 -2
- data/vendor/depot_tools/split_cl.py +32 -4
- data/vendor/depot_tools/subprocess2.py +22 -4
- data/vendor/depot_tools/third_party/httplib2/README.chromium +2 -2
- data/vendor/depot_tools/third_party/httplib2/__init__.py +242 -158
- data/vendor/depot_tools/third_party/httplib2/cacerts.txt +57 -44
- data/vendor/depot_tools/third_party/httplib2/socks.py +15 -5
- data/vendor/depot_tools/third_party/logilab/README.chromium +2 -4
- data/vendor/depot_tools/third_party/logilab/astroid/README.chromium +2 -1
- data/vendor/depot_tools/third_party/logilab/astroid/__init__.py +10 -5
- data/vendor/depot_tools/third_party/logilab/astroid/__pkginfo__.py +5 -5
- data/vendor/depot_tools/third_party/logilab/astroid/arguments.py +233 -0
- data/vendor/depot_tools/third_party/logilab/astroid/as_string.py +82 -33
- data/vendor/depot_tools/third_party/logilab/astroid/bases.py +137 -153
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{builtin_inference.py → brain_builtin_inference.py} +117 -26
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_dateutil.py +15 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2gi.py → brain_gi.py} +48 -8
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{py2mechanize.py → brain_mechanize.py} +0 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{pynose.py → brain_nose.py} +4 -1
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_numpy.py +62 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_pytest.py +76 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_qt.py +44 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/{pysix_moves.py → brain_six.py} +28 -1
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_ssl.py +65 -0
- data/vendor/depot_tools/third_party/logilab/astroid/brain/brain_stdlib.py +473 -0
- data/vendor/depot_tools/third_party/logilab/astroid/builder.py +104 -81
- data/vendor/depot_tools/third_party/logilab/astroid/context.py +81 -0
- data/vendor/depot_tools/third_party/logilab/astroid/decorators.py +75 -0
- data/vendor/depot_tools/third_party/logilab/astroid/exceptions.py +20 -0
- data/vendor/depot_tools/third_party/logilab/astroid/inference.py +137 -183
- data/vendor/depot_tools/third_party/logilab/astroid/manager.py +45 -169
- data/vendor/depot_tools/third_party/logilab/astroid/mixins.py +37 -14
- data/vendor/depot_tools/third_party/logilab/astroid/modutils.py +112 -41
- data/vendor/depot_tools/third_party/logilab/astroid/node_classes.py +243 -156
- data/vendor/depot_tools/third_party/logilab/astroid/nodes.py +35 -22
- data/vendor/depot_tools/third_party/logilab/astroid/objects.py +186 -0
- data/vendor/depot_tools/third_party/logilab/astroid/protocols.py +157 -102
- data/vendor/depot_tools/third_party/logilab/astroid/raw_building.py +32 -8
- data/vendor/depot_tools/third_party/logilab/astroid/rebuilder.py +372 -309
- data/vendor/depot_tools/third_party/logilab/astroid/scoped_nodes.py +652 -420
- data/vendor/depot_tools/third_party/logilab/astroid/test_utils.py +4 -21
- data/vendor/depot_tools/third_party/logilab/astroid/transforms.py +96 -0
- data/vendor/depot_tools/third_party/logilab/astroid/util.py +89 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/LICENSE +19 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/README.chromium +11 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/__init__.py +20 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/cext.c +1421 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/compat.py +9 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/simple.py +246 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/slots.py +414 -0
- data/vendor/depot_tools/third_party/logilab/lazy_object_proxy/utils.py +13 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/LICENSE +24 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/README.chromium +11 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/__init__.py +19 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/_wrappers.c +2729 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/arguments.py +96 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/decorators.py +512 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/importer.py +228 -0
- data/vendor/depot_tools/third_party/logilab/wrapt/wrappers.py +901 -0
- data/vendor/depot_tools/third_party/pylint/README.chromium +2 -25
- data/vendor/depot_tools/third_party/pylint/__pkginfo__.py +13 -3
- data/vendor/depot_tools/third_party/pylint/checkers/__init__.py +1 -2
- data/vendor/depot_tools/third_party/pylint/checkers/async.py +82 -0
- data/vendor/depot_tools/third_party/pylint/checkers/base.py +893 -119
- data/vendor/depot_tools/third_party/pylint/checkers/classes.py +342 -204
- data/vendor/depot_tools/third_party/pylint/checkers/design_analysis.py +51 -34
- data/vendor/depot_tools/third_party/pylint/checkers/exceptions.py +84 -47
- data/vendor/depot_tools/third_party/pylint/checkers/format.py +55 -30
- data/vendor/depot_tools/third_party/pylint/checkers/imports.py +314 -73
- data/vendor/depot_tools/third_party/pylint/checkers/logging.py +10 -8
- data/vendor/depot_tools/third_party/pylint/checkers/misc.py +2 -1
- data/vendor/depot_tools/third_party/pylint/checkers/newstyle.py +45 -48
- data/vendor/depot_tools/third_party/pylint/checkers/python3.py +31 -21
- data/vendor/depot_tools/third_party/pylint/checkers/raw_metrics.py +3 -3
- data/vendor/depot_tools/third_party/pylint/checkers/similar.py +4 -5
- data/vendor/depot_tools/third_party/pylint/checkers/spelling.py +24 -10
- data/vendor/depot_tools/third_party/pylint/checkers/stdlib.py +120 -56
- data/vendor/depot_tools/third_party/pylint/checkers/strings.py +38 -35
- data/vendor/depot_tools/third_party/pylint/checkers/typecheck.py +485 -138
- data/vendor/depot_tools/third_party/pylint/checkers/utils.py +319 -142
- data/vendor/depot_tools/third_party/pylint/checkers/variables.py +329 -207
- data/vendor/depot_tools/third_party/pylint/config.py +739 -76
- data/vendor/depot_tools/third_party/pylint/epylint.py +9 -5
- data/vendor/depot_tools/third_party/pylint/extensions/__init__.py +0 -0
- data/vendor/depot_tools/third_party/pylint/extensions/check_docs.py +311 -0
- data/vendor/depot_tools/third_party/pylint/extensions/check_elif.py +62 -0
- data/vendor/depot_tools/third_party/{logilab/common → pylint}/graph.py +30 -133
- data/vendor/depot_tools/third_party/pylint/gui.py +2 -2
- data/vendor/depot_tools/third_party/pylint/interfaces.py +21 -3
- data/vendor/depot_tools/third_party/pylint/lint.py +123 -140
- data/vendor/depot_tools/third_party/pylint/pyreverse/diadefslib.py +10 -13
- data/vendor/depot_tools/third_party/pylint/pyreverse/diagrams.py +15 -4
- data/vendor/depot_tools/third_party/pylint/pyreverse/inspector.py +372 -0
- data/vendor/depot_tools/third_party/pylint/pyreverse/main.py +30 -7
- data/vendor/depot_tools/third_party/pylint/pyreverse/utils.py +80 -2
- data/vendor/depot_tools/third_party/{logilab/common → pylint/pyreverse}/vcgutils.py +19 -37
- data/vendor/depot_tools/third_party/pylint/pyreverse/writer.py +3 -4
- data/vendor/depot_tools/third_party/pylint/reporters/__init__.py +34 -18
- data/vendor/depot_tools/third_party/pylint/reporters/guireporter.py +1 -1
- data/vendor/depot_tools/third_party/pylint/reporters/html.py +10 -3
- data/vendor/depot_tools/third_party/pylint/reporters/json.py +10 -4
- data/vendor/depot_tools/third_party/pylint/reporters/text.py +94 -3
- data/vendor/depot_tools/third_party/pylint/reporters/ureports/__init__.py +106 -0
- data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/html_writer.py +17 -57
- data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/nodes.py +52 -74
- data/vendor/depot_tools/third_party/{logilab/common → pylint/reporters}/ureports/text_writer.py +14 -60
- data/vendor/depot_tools/third_party/pylint/testutils.py +22 -20
- data/vendor/depot_tools/third_party/pylint/utils.py +268 -44
- data/vendor/depot_tools/third_party/repo/progress.py +42 -0
- data/vendor/depot_tools/update_depot_tools +1 -1
- data/vendor/depot_tools/upload_metrics.py +25 -0
- data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +45 -15
- data/vendor/depot_tools/win_toolchain/package_from_installed.py +71 -24
- data/vendor/depot_tools/yapf +1 -1
- data/vendor/depot_tools/yapf.bat +1 -1
- metadata +92 -77
- data/vendor/depot_tools/git-crsync +0 -3
- data/vendor/depot_tools/infra/config/cq.cfg +0 -32
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref.json +0 -29
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/apply_gerrit_ref_custom.json +0 -29
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/buildbot.json +0 -105
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/shallow.json +0 -195
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle_deprecated.json +0 -248
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8.json +0 -248
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_manifest_name_no_patch.json +0 -105
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/apply_gerrit.py +0 -33
- data/vendor/depot_tools/third_party/logilab/astroid/brain/py2pytest.py +0 -31
- data/vendor/depot_tools/third_party/logilab/astroid/brain/py2qt4.py +0 -22
- data/vendor/depot_tools/third_party/logilab/astroid/brain/py2stdlib.py +0 -334
- data/vendor/depot_tools/third_party/logilab/astroid/inspector.py +0 -273
- data/vendor/depot_tools/third_party/logilab/astroid/utils.py +0 -239
- data/vendor/depot_tools/third_party/logilab/common/LICENSE.txt +0 -339
- data/vendor/depot_tools/third_party/logilab/common/README.chromium +0 -11
- data/vendor/depot_tools/third_party/logilab/common/__init__.py +0 -175
- data/vendor/depot_tools/third_party/logilab/common/__pkginfo__.py +0 -57
- data/vendor/depot_tools/third_party/logilab/common/cache.py +0 -114
- data/vendor/depot_tools/third_party/logilab/common/changelog.py +0 -238
- data/vendor/depot_tools/third_party/logilab/common/clcommands.py +0 -334
- data/vendor/depot_tools/third_party/logilab/common/cli.py +0 -211
- data/vendor/depot_tools/third_party/logilab/common/compat.py +0 -78
- data/vendor/depot_tools/third_party/logilab/common/configuration.py +0 -1105
- data/vendor/depot_tools/third_party/logilab/common/contexts.py +0 -5
- data/vendor/depot_tools/third_party/logilab/common/corbautils.py +0 -117
- data/vendor/depot_tools/third_party/logilab/common/daemon.py +0 -101
- data/vendor/depot_tools/third_party/logilab/common/date.py +0 -335
- data/vendor/depot_tools/third_party/logilab/common/dbf.py +0 -231
- data/vendor/depot_tools/third_party/logilab/common/debugger.py +0 -214
- data/vendor/depot_tools/third_party/logilab/common/decorators.py +0 -281
- data/vendor/depot_tools/third_party/logilab/common/deprecation.py +0 -189
- data/vendor/depot_tools/third_party/logilab/common/fileutils.py +0 -404
- data/vendor/depot_tools/third_party/logilab/common/interface.py +0 -71
- data/vendor/depot_tools/third_party/logilab/common/logging_ext.py +0 -195
- data/vendor/depot_tools/third_party/logilab/common/modutils.py +0 -702
- data/vendor/depot_tools/third_party/logilab/common/optik_ext.py +0 -392
- data/vendor/depot_tools/third_party/logilab/common/optparser.py +0 -92
- data/vendor/depot_tools/third_party/logilab/common/proc.py +0 -277
- data/vendor/depot_tools/third_party/logilab/common/pyro_ext.py +0 -180
- data/vendor/depot_tools/third_party/logilab/common/pytest.py +0 -1199
- data/vendor/depot_tools/third_party/logilab/common/registry.py +0 -1119
- data/vendor/depot_tools/third_party/logilab/common/shellutils.py +0 -462
- data/vendor/depot_tools/third_party/logilab/common/sphinx_ext.py +0 -87
- data/vendor/depot_tools/third_party/logilab/common/sphinxutils.py +0 -122
- data/vendor/depot_tools/third_party/logilab/common/table.py +0 -929
- data/vendor/depot_tools/third_party/logilab/common/tasksqueue.py +0 -101
- data/vendor/depot_tools/third_party/logilab/common/testlib.py +0 -1392
- data/vendor/depot_tools/third_party/logilab/common/textutils.py +0 -537
- data/vendor/depot_tools/third_party/logilab/common/tree.py +0 -369
- data/vendor/depot_tools/third_party/logilab/common/umessage.py +0 -194
- data/vendor/depot_tools/third_party/logilab/common/ureports/__init__.py +0 -172
- data/vendor/depot_tools/third_party/logilab/common/ureports/docbook_writer.py +0 -140
- data/vendor/depot_tools/third_party/logilab/common/urllib2ext.py +0 -89
- data/vendor/depot_tools/third_party/logilab/common/visitor.py +0 -109
- data/vendor/depot_tools/third_party/logilab/common/xmlrpcutils.py +0 -131
- data/vendor/depot_tools/third_party/logilab/common/xmlutils.py +0 -61
@@ -16,12 +16,12 @@
|
|
16
16
|
"""handle diagram generation options for class diagram or default diagrams
|
17
17
|
"""
|
18
18
|
|
19
|
-
from
|
19
|
+
from six.moves import builtins
|
20
20
|
|
21
21
|
import astroid
|
22
|
-
from astroid.utils import LocalsVisitor
|
23
22
|
|
24
23
|
from pylint.pyreverse.diagrams import PackageDiagram, ClassDiagram
|
24
|
+
from pylint.pyreverse.utils import LocalsVisitor
|
25
25
|
|
26
26
|
BUILTINS_NAME = builtins.__name__
|
27
27
|
|
@@ -49,10 +49,7 @@ class DiaDefGenerator(object):
|
|
49
49
|
# if we have a class diagram, we want more information by default;
|
50
50
|
# so if the option is None, we return True
|
51
51
|
if option is None:
|
52
|
-
|
53
|
-
return True
|
54
|
-
else:
|
55
|
-
return False
|
52
|
+
return bool(self.config.classes)
|
56
53
|
return option
|
57
54
|
|
58
55
|
def _set_default_options(self):
|
@@ -104,7 +101,7 @@ class DiaDefGenerator(object):
|
|
104
101
|
for ass_node in ass_nodes:
|
105
102
|
if isinstance(ass_node, astroid.Instance):
|
106
103
|
ass_node = ass_node._proxied
|
107
|
-
if not (isinstance(ass_node, astroid.
|
104
|
+
if not (isinstance(ass_node, astroid.ClassDef)
|
108
105
|
and self.show_node(ass_node)):
|
109
106
|
continue
|
110
107
|
yield ass_node
|
@@ -134,7 +131,7 @@ class DefaultDiadefGenerator(LocalsVisitor, DiaDefGenerator):
|
|
134
131
|
LocalsVisitor.__init__(self)
|
135
132
|
|
136
133
|
def visit_project(self, node):
|
137
|
-
"""visit an
|
134
|
+
"""visit an pyreverse.utils.Project node
|
138
135
|
|
139
136
|
create a diagram definition for packages
|
140
137
|
"""
|
@@ -146,7 +143,7 @@ class DefaultDiadefGenerator(LocalsVisitor, DiaDefGenerator):
|
|
146
143
|
self.classdiagram = ClassDiagram('classes %s' % node.name, mode)
|
147
144
|
|
148
145
|
def leave_project(self, node): # pylint: disable=unused-argument
|
149
|
-
"""leave the
|
146
|
+
"""leave the pyreverse.utils.Project node
|
150
147
|
|
151
148
|
return the generated diagram definition
|
152
149
|
"""
|
@@ -163,7 +160,7 @@ class DefaultDiadefGenerator(LocalsVisitor, DiaDefGenerator):
|
|
163
160
|
self.linker.visit(node)
|
164
161
|
self.pkgdiagram.add_object(node.name, node)
|
165
162
|
|
166
|
-
def
|
163
|
+
def visit_classdef(self, node):
|
167
164
|
"""visit an astroid.Class node
|
168
165
|
|
169
166
|
add this class to the class diagram definition
|
@@ -171,7 +168,7 @@ class DefaultDiadefGenerator(LocalsVisitor, DiaDefGenerator):
|
|
171
168
|
anc_level, ass_level = self._get_levels()
|
172
169
|
self.extract_classes(node, anc_level, ass_level)
|
173
170
|
|
174
|
-
def
|
171
|
+
def visit_importfrom(self, node):
|
175
172
|
"""visit astroid.From and catch modules for package diagram
|
176
173
|
"""
|
177
174
|
if self.pkgdiagram:
|
@@ -217,8 +214,8 @@ class DiadefsHandler(object):
|
|
217
214
|
|
218
215
|
def get_diadefs(self, project, linker):
|
219
216
|
"""get the diagrams configuration data
|
220
|
-
:param linker:
|
221
|
-
:param project:
|
217
|
+
:param linker: pyreverse.inspector.Linker(IdGeneratorMixIn, LocalsVisitor)
|
218
|
+
:param project: pyreverse.utils.Project
|
222
219
|
"""
|
223
220
|
|
224
221
|
# read and interpret diagram definitions (Diadefs)
|
@@ -18,10 +18,13 @@
|
|
18
18
|
|
19
19
|
import astroid
|
20
20
|
from pylint.pyreverse.utils import is_interface, FilterMixIn
|
21
|
+
from pylint.checkers.utils import decorated_with_property
|
22
|
+
|
21
23
|
|
22
24
|
class Figure(object):
|
23
25
|
"""base class for counter handling"""
|
24
26
|
|
27
|
+
|
25
28
|
class Relationship(Figure):
|
26
29
|
"""a relation ship from an object in the diagram to another
|
27
30
|
"""
|
@@ -41,6 +44,7 @@ class DiagramEntity(Figure):
|
|
41
44
|
self.title = title
|
42
45
|
self.node = node
|
43
46
|
|
47
|
+
|
44
48
|
class ClassDiagram(Figure, FilterMixIn):
|
45
49
|
"""main class diagram handling
|
46
50
|
"""
|
@@ -77,8 +81,13 @@ class ClassDiagram(Figure, FilterMixIn):
|
|
77
81
|
def get_attrs(self, node):
|
78
82
|
"""return visible attributes, possibly with class name"""
|
79
83
|
attrs = []
|
84
|
+
properties = [
|
85
|
+
(n, m) for n, m in node.items()
|
86
|
+
if isinstance(m, astroid.FunctionDef)
|
87
|
+
and decorated_with_property(m)
|
88
|
+
]
|
80
89
|
for node_name, ass_nodes in list(node.instance_attrs_type.items()) + \
|
81
|
-
|
90
|
+
list(node.locals_type.items()) + properties:
|
82
91
|
if not self.show_attr(node_name):
|
83
92
|
continue
|
84
93
|
names = self.class_names(ass_nodes)
|
@@ -91,7 +100,9 @@ class ClassDiagram(Figure, FilterMixIn):
|
|
91
100
|
"""return visible methods"""
|
92
101
|
methods = [
|
93
102
|
m for m in node.values()
|
94
|
-
if isinstance(m, astroid.
|
103
|
+
if isinstance(m, astroid.FunctionDef)
|
104
|
+
and not decorated_with_property(m)
|
105
|
+
and self.show_attr(m.name)
|
95
106
|
]
|
96
107
|
return sorted(methods, key=lambda n: n.name)
|
97
108
|
|
@@ -109,7 +120,7 @@ class ClassDiagram(Figure, FilterMixIn):
|
|
109
120
|
for ass_node in nodes:
|
110
121
|
if isinstance(ass_node, astroid.Instance):
|
111
122
|
ass_node = ass_node._proxied
|
112
|
-
if isinstance(ass_node, astroid.
|
123
|
+
if isinstance(ass_node, astroid.ClassDef) \
|
113
124
|
and hasattr(ass_node, "name") and not self.has_node(ass_node):
|
114
125
|
if ass_node.name not in names:
|
115
126
|
ass_name = ass_node.name
|
@@ -133,7 +144,7 @@ class ClassDiagram(Figure, FilterMixIn):
|
|
133
144
|
|
134
145
|
def classes(self):
|
135
146
|
"""return all class nodes in the diagram"""
|
136
|
-
return [o for o in self.objects if isinstance(o.node, astroid.
|
147
|
+
return [o for o in self.objects if isinstance(o.node, astroid.ClassDef)]
|
137
148
|
|
138
149
|
def classe(self, name):
|
139
150
|
"""return a class by its name, raise KeyError if not found
|
@@ -0,0 +1,372 @@
|
|
1
|
+
# Copyright (c) 2003-2015 LOGILAB S.A. (Paris, FRANCE).
|
2
|
+
# http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
3
|
+
# Copyright (c) 2009-2010 Arista Networks, Inc.
|
4
|
+
#
|
5
|
+
# This program is free software; you can redistribute it and/or modify it under
|
6
|
+
# the terms of the GNU General Public License as published by the Free Software
|
7
|
+
# Foundation; either version 2 of the License, or (at your option) any later
|
8
|
+
# version.
|
9
|
+
#
|
10
|
+
# This program is distributed in the hope that it will be useful, but WITHOUT
|
11
|
+
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
12
|
+
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
13
|
+
#
|
14
|
+
# You should have received a copy of the GNU General Public License along with
|
15
|
+
# this program; if not, write to the Free Software Foundation, Inc.,
|
16
|
+
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
17
|
+
"""
|
18
|
+
Visitor doing some postprocessing on the astroid tree.
|
19
|
+
Try to resolve definitions (namespace) dictionary, relationship...
|
20
|
+
"""
|
21
|
+
from __future__ import print_function
|
22
|
+
|
23
|
+
import collections
|
24
|
+
import os
|
25
|
+
import traceback
|
26
|
+
|
27
|
+
import astroid
|
28
|
+
from astroid import bases
|
29
|
+
from astroid import exceptions
|
30
|
+
from astroid import manager
|
31
|
+
from astroid import modutils
|
32
|
+
from astroid import node_classes
|
33
|
+
|
34
|
+
|
35
|
+
from pylint.pyreverse import utils
|
36
|
+
|
37
|
+
|
38
|
+
def _iface_hdlr(_):
|
39
|
+
"""Handler used by interfaces to handle suspicious interface nodes."""
|
40
|
+
return True
|
41
|
+
|
42
|
+
|
43
|
+
def _astroid_wrapper(func, modname):
|
44
|
+
print('parsing %s...' % modname)
|
45
|
+
try:
|
46
|
+
return func(modname)
|
47
|
+
except exceptions.AstroidBuildingException as exc:
|
48
|
+
print(exc)
|
49
|
+
except Exception as exc: # pylint: disable=broad-except
|
50
|
+
traceback.print_exc()
|
51
|
+
|
52
|
+
|
53
|
+
def interfaces(node, herited=True, handler_func=_iface_hdlr):
|
54
|
+
"""Return an iterator on interfaces implemented by the given class node."""
|
55
|
+
# FIXME: what if __implements__ = (MyIFace, MyParent.__implements__)...
|
56
|
+
try:
|
57
|
+
implements = bases.Instance(node).getattr('__implements__')[0]
|
58
|
+
except exceptions.NotFoundError:
|
59
|
+
return
|
60
|
+
if not herited and implements.frame() is not node:
|
61
|
+
return
|
62
|
+
found = set()
|
63
|
+
missing = False
|
64
|
+
for iface in node_classes.unpack_infer(implements):
|
65
|
+
if iface is astroid.YES:
|
66
|
+
missing = True
|
67
|
+
continue
|
68
|
+
if iface not in found and handler_func(iface):
|
69
|
+
found.add(iface)
|
70
|
+
yield iface
|
71
|
+
if missing:
|
72
|
+
raise exceptions.InferenceError()
|
73
|
+
|
74
|
+
|
75
|
+
class IdGeneratorMixIn(object):
|
76
|
+
"""Mixin adding the ability to generate integer uid."""
|
77
|
+
|
78
|
+
def __init__(self, start_value=0):
|
79
|
+
self.id_count = start_value
|
80
|
+
|
81
|
+
def init_counter(self, start_value=0):
|
82
|
+
"""init the id counter
|
83
|
+
"""
|
84
|
+
self.id_count = start_value
|
85
|
+
|
86
|
+
def generate_id(self):
|
87
|
+
"""generate a new identifier
|
88
|
+
"""
|
89
|
+
self.id_count += 1
|
90
|
+
return self.id_count
|
91
|
+
|
92
|
+
|
93
|
+
class Linker(IdGeneratorMixIn, utils.LocalsVisitor):
|
94
|
+
"""Walk on the project tree and resolve relationships.
|
95
|
+
|
96
|
+
According to options the following attributes may be
|
97
|
+
added to visited nodes:
|
98
|
+
|
99
|
+
* uid,
|
100
|
+
a unique identifier for the node (on astroid.Project, astroid.Module,
|
101
|
+
astroid.Class and astroid.locals_type). Only if the linker
|
102
|
+
has been instantiated with tag=True parameter (False by default).
|
103
|
+
|
104
|
+
* Function
|
105
|
+
a mapping from locals names to their bounded value, which may be a
|
106
|
+
constant like a string or an integer, or an astroid node
|
107
|
+
(on astroid.Module, astroid.Class and astroid.Function).
|
108
|
+
|
109
|
+
* instance_attrs_type
|
110
|
+
as locals_type but for klass member attributes (only on astroid.Class)
|
111
|
+
|
112
|
+
* implements,
|
113
|
+
list of implemented interface _objects_ (only on astroid.Class nodes)
|
114
|
+
"""
|
115
|
+
|
116
|
+
def __init__(self, project, inherited_interfaces=0, tag=False):
|
117
|
+
IdGeneratorMixIn.__init__(self)
|
118
|
+
utils.LocalsVisitor.__init__(self)
|
119
|
+
# take inherited interface in consideration or not
|
120
|
+
self.inherited_interfaces = inherited_interfaces
|
121
|
+
# tag nodes or not
|
122
|
+
self.tag = tag
|
123
|
+
# visited project
|
124
|
+
self.project = project
|
125
|
+
|
126
|
+
def visit_project(self, node):
|
127
|
+
"""visit an pyreverse.utils.Project node
|
128
|
+
|
129
|
+
* optionally tag the node with a unique id
|
130
|
+
"""
|
131
|
+
if self.tag:
|
132
|
+
node.uid = self.generate_id()
|
133
|
+
for module in node.modules:
|
134
|
+
self.visit(module)
|
135
|
+
|
136
|
+
def visit_package(self, node):
|
137
|
+
"""visit an astroid.Package node
|
138
|
+
|
139
|
+
* optionally tag the node with a unique id
|
140
|
+
"""
|
141
|
+
if self.tag:
|
142
|
+
node.uid = self.generate_id()
|
143
|
+
for subelmt in node.values():
|
144
|
+
self.visit(subelmt)
|
145
|
+
|
146
|
+
def visit_module(self, node):
|
147
|
+
"""visit an astroid.Module node
|
148
|
+
|
149
|
+
* set the locals_type mapping
|
150
|
+
* set the depends mapping
|
151
|
+
* optionally tag the node with a unique id
|
152
|
+
"""
|
153
|
+
if hasattr(node, 'locals_type'):
|
154
|
+
return
|
155
|
+
node.locals_type = collections.defaultdict(list)
|
156
|
+
node.depends = []
|
157
|
+
if self.tag:
|
158
|
+
node.uid = self.generate_id()
|
159
|
+
|
160
|
+
def visit_classdef(self, node):
|
161
|
+
"""visit an astroid.Class node
|
162
|
+
|
163
|
+
* set the locals_type and instance_attrs_type mappings
|
164
|
+
* set the implements list and build it
|
165
|
+
* optionally tag the node with a unique id
|
166
|
+
"""
|
167
|
+
if hasattr(node, 'locals_type'):
|
168
|
+
return
|
169
|
+
node.locals_type = collections.defaultdict(list)
|
170
|
+
if self.tag:
|
171
|
+
node.uid = self.generate_id()
|
172
|
+
# resolve ancestors
|
173
|
+
for baseobj in node.ancestors(recurs=False):
|
174
|
+
specializations = getattr(baseobj, 'specializations', [])
|
175
|
+
specializations.append(node)
|
176
|
+
baseobj.specializations = specializations
|
177
|
+
# resolve instance attributes
|
178
|
+
node.instance_attrs_type = collections.defaultdict(list)
|
179
|
+
for assattrs in node.instance_attrs.values():
|
180
|
+
for assattr in assattrs:
|
181
|
+
self.handle_assattr_type(assattr, node)
|
182
|
+
# resolve implemented interface
|
183
|
+
try:
|
184
|
+
node.implements = list(interfaces(node, self.inherited_interfaces))
|
185
|
+
except astroid.InferenceError:
|
186
|
+
node.implements = ()
|
187
|
+
|
188
|
+
def visit_functiondef(self, node):
|
189
|
+
"""visit an astroid.Function node
|
190
|
+
|
191
|
+
* set the locals_type mapping
|
192
|
+
* optionally tag the node with a unique id
|
193
|
+
"""
|
194
|
+
if hasattr(node, 'locals_type'):
|
195
|
+
return
|
196
|
+
node.locals_type = collections.defaultdict(list)
|
197
|
+
if self.tag:
|
198
|
+
node.uid = self.generate_id()
|
199
|
+
|
200
|
+
link_project = visit_project
|
201
|
+
link_module = visit_module
|
202
|
+
link_class = visit_classdef
|
203
|
+
link_function = visit_functiondef
|
204
|
+
|
205
|
+
def visit_assignname(self, node):
|
206
|
+
"""visit an astroid.AssName node
|
207
|
+
|
208
|
+
handle locals_type
|
209
|
+
"""
|
210
|
+
# avoid double parsing done by different Linkers.visit
|
211
|
+
# running over the same project:
|
212
|
+
if hasattr(node, '_handled'):
|
213
|
+
return
|
214
|
+
node._handled = True
|
215
|
+
if node.name in node.frame():
|
216
|
+
frame = node.frame()
|
217
|
+
else:
|
218
|
+
# the name has been defined as 'global' in the frame and belongs
|
219
|
+
# there.
|
220
|
+
frame = node.root()
|
221
|
+
try:
|
222
|
+
if not hasattr(frame, 'locals_type'):
|
223
|
+
# If the frame doesn't have a locals_type yet,
|
224
|
+
# it means it wasn't yet visited. Visit it now
|
225
|
+
# to add what's missing from it.
|
226
|
+
if isinstance(frame, astroid.ClassDef):
|
227
|
+
self.visit_classdef(frame)
|
228
|
+
elif isinstance(frame, astroid.FunctionDef):
|
229
|
+
self.visit_functiondef(frame)
|
230
|
+
else:
|
231
|
+
self.visit_module(frame)
|
232
|
+
|
233
|
+
current = frame.locals_type[node.name]
|
234
|
+
values = set(node.infer())
|
235
|
+
frame.locals_type[node.name] = list(set(current) | values)
|
236
|
+
except astroid.InferenceError:
|
237
|
+
pass
|
238
|
+
|
239
|
+
@staticmethod
|
240
|
+
def handle_assattr_type(node, parent):
|
241
|
+
"""handle an astroid.AssAttr node
|
242
|
+
|
243
|
+
handle instance_attrs_type
|
244
|
+
"""
|
245
|
+
try:
|
246
|
+
values = set(node.infer())
|
247
|
+
current = set(parent.instance_attrs_type[node.attrname])
|
248
|
+
parent.instance_attrs_type[node.attrname] = list(current | values)
|
249
|
+
except astroid.InferenceError:
|
250
|
+
pass
|
251
|
+
|
252
|
+
def visit_import(self, node):
|
253
|
+
"""visit an astroid.Import node
|
254
|
+
|
255
|
+
resolve module dependencies
|
256
|
+
"""
|
257
|
+
context_file = node.root().file
|
258
|
+
for name in node.names:
|
259
|
+
relative = modutils.is_relative(name[0], context_file)
|
260
|
+
self._imported_module(node, name[0], relative)
|
261
|
+
|
262
|
+
def visit_importfrom(self, node):
|
263
|
+
"""visit an astroid.From node
|
264
|
+
|
265
|
+
resolve module dependencies
|
266
|
+
"""
|
267
|
+
basename = node.modname
|
268
|
+
context_file = node.root().file
|
269
|
+
if context_file is not None:
|
270
|
+
relative = modutils.is_relative(basename, context_file)
|
271
|
+
else:
|
272
|
+
relative = False
|
273
|
+
for name in node.names:
|
274
|
+
if name[0] == '*':
|
275
|
+
continue
|
276
|
+
# analyze dependencies
|
277
|
+
fullname = '%s.%s' % (basename, name[0])
|
278
|
+
if fullname.find('.') > -1:
|
279
|
+
try:
|
280
|
+
# TODO: don't use get_module_part,
|
281
|
+
# missing package precedence
|
282
|
+
fullname = modutils.get_module_part(fullname,
|
283
|
+
context_file)
|
284
|
+
except ImportError:
|
285
|
+
continue
|
286
|
+
if fullname != basename:
|
287
|
+
self._imported_module(node, fullname, relative)
|
288
|
+
|
289
|
+
def compute_module(self, context_name, mod_path):
|
290
|
+
"""return true if the module should be added to dependencies"""
|
291
|
+
package_dir = os.path.dirname(self.project.path)
|
292
|
+
if context_name == mod_path:
|
293
|
+
return 0
|
294
|
+
elif modutils.is_standard_module(mod_path, (package_dir,)):
|
295
|
+
return 1
|
296
|
+
return 0
|
297
|
+
|
298
|
+
def _imported_module(self, node, mod_path, relative):
|
299
|
+
"""Notify an imported module, used to analyze dependencies"""
|
300
|
+
module = node.root()
|
301
|
+
context_name = module.name
|
302
|
+
if relative:
|
303
|
+
mod_path = '%s.%s' % ('.'.join(context_name.split('.')[:-1]),
|
304
|
+
mod_path)
|
305
|
+
if self.compute_module(context_name, mod_path):
|
306
|
+
# handle dependencies
|
307
|
+
if not hasattr(module, 'depends'):
|
308
|
+
module.depends = []
|
309
|
+
mod_paths = module.depends
|
310
|
+
if mod_path not in mod_paths:
|
311
|
+
mod_paths.append(mod_path)
|
312
|
+
|
313
|
+
|
314
|
+
class Project(object):
|
315
|
+
"""a project handle a set of modules / packages"""
|
316
|
+
def __init__(self, name=''):
|
317
|
+
self.name = name
|
318
|
+
self.path = None
|
319
|
+
self.modules = []
|
320
|
+
self.locals = {}
|
321
|
+
self.__getitem__ = self.locals.__getitem__
|
322
|
+
self.__iter__ = self.locals.__iter__
|
323
|
+
self.values = self.locals.values
|
324
|
+
self.keys = self.locals.keys
|
325
|
+
self.items = self.locals.items
|
326
|
+
|
327
|
+
def add_module(self, node):
|
328
|
+
self.locals[node.name] = node
|
329
|
+
self.modules.append(node)
|
330
|
+
|
331
|
+
def get_module(self, name):
|
332
|
+
return self.locals[name]
|
333
|
+
|
334
|
+
def get_children(self):
|
335
|
+
return self.modules
|
336
|
+
|
337
|
+
def __repr__(self):
|
338
|
+
return '<Project %r at %s (%s modules)>' % (self.name, id(self),
|
339
|
+
len(self.modules))
|
340
|
+
|
341
|
+
|
342
|
+
def project_from_files(files, func_wrapper=_astroid_wrapper,
|
343
|
+
project_name="no name",
|
344
|
+
black_list=('CVS',)):
|
345
|
+
"""return a Project from a list of files or modules"""
|
346
|
+
# build the project representation
|
347
|
+
astroid_manager = manager.AstroidManager()
|
348
|
+
project = Project(project_name)
|
349
|
+
for something in files:
|
350
|
+
if not os.path.exists(something):
|
351
|
+
fpath = modutils.file_from_modpath(something.split('.'))
|
352
|
+
elif os.path.isdir(something):
|
353
|
+
fpath = os.path.join(something, '__init__.py')
|
354
|
+
else:
|
355
|
+
fpath = something
|
356
|
+
ast = func_wrapper(astroid_manager.ast_from_file, fpath)
|
357
|
+
if ast is None:
|
358
|
+
continue
|
359
|
+
# XXX why is first file defining the project.path ?
|
360
|
+
project.path = project.path or ast.file
|
361
|
+
project.add_module(ast)
|
362
|
+
base_name = ast.name
|
363
|
+
# recurse in package except if __init__ was explicitly given
|
364
|
+
if ast.package and something.find('__init__') == -1:
|
365
|
+
# recurse on others packages / modules if this is a package
|
366
|
+
for fpath in modutils.get_module_files(os.path.dirname(ast.file),
|
367
|
+
black_list):
|
368
|
+
ast = func_wrapper(astroid_manager.ast_from_file, fpath)
|
369
|
+
if ast is None or ast.name == base_name:
|
370
|
+
continue
|
371
|
+
project.add_module(ast)
|
372
|
+
return project
|