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
@@ -20,11 +20,12 @@
|
|
20
20
|
"""
|
21
21
|
from __future__ import print_function
|
22
22
|
|
23
|
-
import
|
24
|
-
|
25
|
-
|
26
|
-
from astroid.inspector import Linker
|
23
|
+
import os
|
24
|
+
import subprocess
|
25
|
+
import sys
|
27
26
|
|
27
|
+
from pylint.config import ConfigurationMixIn
|
28
|
+
from pylint.pyreverse.inspector import Linker, project_from_files
|
28
29
|
from pylint.pyreverse.diadefslib import DiadefsHandler
|
29
30
|
from pylint.pyreverse import writer
|
30
31
|
from pylint.pyreverse.utils import insert_default_options
|
@@ -79,11 +80,31 @@ this disables -f values")),
|
|
79
80
|
("output", dict(short="o", dest="output_format", action="store",
|
80
81
|
default="dot", metavar="<format>",
|
81
82
|
help="create a *.<format> output file if format available.")),
|
83
|
+
("ignore", {'type' : "csv", 'metavar' : "<file>",
|
84
|
+
'dest' : "black_list", "default" : ('CVS',),
|
85
|
+
'help' : "add <file> (may be a directory) to the black list. "
|
86
|
+
"It should be a base name, not a path. You may set "
|
87
|
+
"this option multiple times."}),
|
88
|
+
("project", {'default': "No Name", 'type' : 'string', 'short': 'p',
|
89
|
+
'metavar': '<project name>', 'help': 'set the project name.'}),
|
82
90
|
)
|
83
91
|
# FIXME : quiet mode
|
84
92
|
#( ('quiet',
|
85
93
|
#dict(help='run quietly', action='store_true', short='q')), )
|
86
94
|
|
95
|
+
def _check_graphviz_available(output_format):
|
96
|
+
"""check if we need graphviz for different output format"""
|
97
|
+
try:
|
98
|
+
subprocess.call(['dot', '-V'], stdout=subprocess.PIPE,
|
99
|
+
stderr=subprocess.PIPE)
|
100
|
+
except OSError:
|
101
|
+
print("The output format '%s' is currently not available.\n"
|
102
|
+
"Please install 'Graphviz' to have other output formats "
|
103
|
+
"than 'dot' or 'vcg'." % output_format)
|
104
|
+
sys.exit(32)
|
105
|
+
|
106
|
+
|
107
|
+
|
87
108
|
class Run(ConfigurationMixIn):
|
88
109
|
"""base class providing common behaviour for pyreverse commands"""
|
89
110
|
|
@@ -92,9 +113,10 @@ class Run(ConfigurationMixIn):
|
|
92
113
|
def __init__(self, args):
|
93
114
|
ConfigurationMixIn.__init__(self, usage=__doc__)
|
94
115
|
insert_default_options()
|
95
|
-
self.manager = AstroidManager()
|
96
|
-
self.register_options_provider(self.manager)
|
97
116
|
args = self.load_command_line_configuration()
|
117
|
+
if self.config.output_format not in ('dot', 'vcg'):
|
118
|
+
_check_graphviz_available(self.config.output_format)
|
119
|
+
|
98
120
|
sys.exit(self.run(args))
|
99
121
|
|
100
122
|
def run(self, args):
|
@@ -106,7 +128,8 @@ class Run(ConfigurationMixIn):
|
|
106
128
|
# dependencies to local modules even if cwd is not in the PYTHONPATH
|
107
129
|
sys.path.insert(0, os.getcwd())
|
108
130
|
try:
|
109
|
-
project = self.
|
131
|
+
project = project_from_files(args, project_name=self.config.project,
|
132
|
+
black_list=self.config.black_list)
|
110
133
|
linker = Linker(project, tag=True)
|
111
134
|
handler = DiadefsHandler(self.config)
|
112
135
|
diadefs = handler.get_diadefs(project, linker)
|
@@ -18,9 +18,9 @@ generic classes/functions for pyreverse core/extensions
|
|
18
18
|
"""
|
19
19
|
from __future__ import print_function
|
20
20
|
|
21
|
-
import sys
|
22
|
-
import re
|
23
21
|
import os
|
22
|
+
import re
|
23
|
+
import sys
|
24
24
|
|
25
25
|
########### pyreverse option utils ##############################
|
26
26
|
|
@@ -110,6 +110,7 @@ MODES = {
|
|
110
110
|
VIS_MOD = {'special': _SPECIAL, 'protected': _PROTECTED,
|
111
111
|
'private': _PRIVATE, 'public': 0}
|
112
112
|
|
113
|
+
|
113
114
|
class FilterMixIn(object):
|
114
115
|
"""filter nodes according to a mode and nodes' visibility
|
115
116
|
"""
|
@@ -130,3 +131,80 @@ class FilterMixIn(object):
|
|
130
131
|
visibility = get_visibility(getattr(node, 'name', node))
|
131
132
|
return not self.__mode & VIS_MOD[visibility]
|
132
133
|
|
134
|
+
|
135
|
+
class ASTWalker(object):
|
136
|
+
"""a walker visiting a tree in preorder, calling on the handler:
|
137
|
+
|
138
|
+
* visit_<class name> on entering a node, where class name is the class of
|
139
|
+
the node in lower case
|
140
|
+
|
141
|
+
* leave_<class name> on leaving a node, where class name is the class of
|
142
|
+
the node in lower case
|
143
|
+
"""
|
144
|
+
|
145
|
+
def __init__(self, handler):
|
146
|
+
self.handler = handler
|
147
|
+
self._cache = {}
|
148
|
+
|
149
|
+
def walk(self, node, _done=None):
|
150
|
+
"""walk on the tree from <node>, getting callbacks from handler"""
|
151
|
+
if _done is None:
|
152
|
+
_done = set()
|
153
|
+
if node in _done:
|
154
|
+
raise AssertionError((id(node), node, node.parent))
|
155
|
+
_done.add(node)
|
156
|
+
self.visit(node)
|
157
|
+
for child_node in node.get_children():
|
158
|
+
assert child_node is not node
|
159
|
+
self.walk(child_node, _done)
|
160
|
+
self.leave(node)
|
161
|
+
assert node.parent is not node
|
162
|
+
|
163
|
+
def get_callbacks(self, node):
|
164
|
+
"""get callbacks from handler for the visited node"""
|
165
|
+
klass = node.__class__
|
166
|
+
methods = self._cache.get(klass)
|
167
|
+
if methods is None:
|
168
|
+
handler = self.handler
|
169
|
+
kid = klass.__name__.lower()
|
170
|
+
e_method = getattr(handler, 'visit_%s' % kid,
|
171
|
+
getattr(handler, 'visit_default', None))
|
172
|
+
l_method = getattr(handler, 'leave_%s' % kid,
|
173
|
+
getattr(handler, 'leave_default', None))
|
174
|
+
self._cache[klass] = (e_method, l_method)
|
175
|
+
else:
|
176
|
+
e_method, l_method = methods
|
177
|
+
return e_method, l_method
|
178
|
+
|
179
|
+
def visit(self, node):
|
180
|
+
"""walk on the tree from <node>, getting callbacks from handler"""
|
181
|
+
method = self.get_callbacks(node)[0]
|
182
|
+
if method is not None:
|
183
|
+
method(node)
|
184
|
+
|
185
|
+
def leave(self, node):
|
186
|
+
"""walk on the tree from <node>, getting callbacks from handler"""
|
187
|
+
method = self.get_callbacks(node)[1]
|
188
|
+
if method is not None:
|
189
|
+
method(node)
|
190
|
+
|
191
|
+
|
192
|
+
class LocalsVisitor(ASTWalker):
|
193
|
+
"""visit a project by traversing the locals dictionary"""
|
194
|
+
def __init__(self):
|
195
|
+
ASTWalker.__init__(self, self)
|
196
|
+
self._visited = {}
|
197
|
+
|
198
|
+
def visit(self, node):
|
199
|
+
"""launch the visit starting from the given node"""
|
200
|
+
if node in self._visited:
|
201
|
+
return
|
202
|
+
self._visited[node] = 1 # FIXME: use set ?
|
203
|
+
methods = self.get_callbacks(node)
|
204
|
+
if methods[0] is not None:
|
205
|
+
methods[0](node)
|
206
|
+
if hasattr(node, 'locals'): # skip Instance and other proxy
|
207
|
+
for local_node in node.values():
|
208
|
+
self.visit(local_node)
|
209
|
+
if methods[1] is not None:
|
210
|
+
return methods[1](node)
|
@@ -1,20 +1,23 @@
|
|
1
|
-
#
|
2
|
-
#
|
3
|
-
#
|
4
|
-
# This file is part of logilab-common.
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
# Copyright (c) 2008-2013 LOGILAB S.A. (Paris, FRANCE).
|
3
|
+
# http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
5
4
|
#
|
6
|
-
#
|
7
|
-
# the terms of the GNU
|
8
|
-
#
|
9
|
-
#
|
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.
|
10
9
|
#
|
11
|
-
#
|
10
|
+
# This program is distributed in the hope that it will be useful, but WITHOUT
|
12
11
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
13
|
-
# FOR A PARTICULAR PURPOSE.
|
14
|
-
# details.
|
12
|
+
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
15
13
|
#
|
16
|
-
# You should have received a copy of the GNU
|
17
|
-
#
|
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
|
+
# This file was copied from logilab-common with the same license:
|
19
|
+
# copyright 2003-2011 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
|
20
|
+
|
18
21
|
"""Functions to generate files readable with Georg Sander's vcg
|
19
22
|
(Visualization of Compiler Graphs).
|
20
23
|
|
@@ -23,14 +26,7 @@ Note that vcg exists as a debian package.
|
|
23
26
|
|
24
27
|
See vcg's documentation for explanation about the different values that
|
25
28
|
maybe used for the functions parameters.
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
29
|
"""
|
31
|
-
__docformat__ = "restructuredtext en"
|
32
|
-
|
33
|
-
import string
|
34
30
|
|
35
31
|
ATTRS_VAL = {
|
36
32
|
'algos': ('dfs', 'tree', 'minbackward',
|
@@ -128,21 +124,7 @@ EDGE_ATTRS = {
|
|
128
124
|
|
129
125
|
# Misc utilities ###############################################################
|
130
126
|
|
131
|
-
|
132
|
-
"""Convert latin characters using vcg escape sequence.
|
133
|
-
"""
|
134
|
-
for char in st:
|
135
|
-
if char not in string.ascii_letters:
|
136
|
-
try:
|
137
|
-
num = ord(char)
|
138
|
-
if num >= 192:
|
139
|
-
st = st.replace(char, r'\fi%d'%ord(char))
|
140
|
-
except:
|
141
|
-
pass
|
142
|
-
return st
|
143
|
-
|
144
|
-
|
145
|
-
class VCGPrinter:
|
127
|
+
class VCGPrinter(object):
|
146
128
|
"""A vcg graph writer.
|
147
129
|
"""
|
148
130
|
|
@@ -177,7 +159,7 @@ class VCGPrinter:
|
|
177
159
|
"""
|
178
160
|
self._stream.write(
|
179
161
|
'%s%sedge: {sourcename:"%s" targetname:"%s"' % (
|
180
|
-
|
162
|
+
self._indent, edge_type, from_node, to_node))
|
181
163
|
self._write_attributes(EDGE_ATTRS, **args)
|
182
164
|
self._stream.write('}\n')
|
183
165
|
|
@@ -189,7 +171,7 @@ class VCGPrinter:
|
|
189
171
|
"""
|
190
172
|
for key, value in args.items():
|
191
173
|
try:
|
192
|
-
_type =
|
174
|
+
_type = attributes_dict[key]
|
193
175
|
except KeyError:
|
194
176
|
raise Exception('''no such attribute %s
|
195
177
|
possible attributes are %s''' % (key, attributes_dict.keys()))
|
@@ -16,10 +16,9 @@
|
|
16
16
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
17
17
|
"""Utilities for creating VCG and Dot diagrams"""
|
18
18
|
|
19
|
-
from logilab.common.vcgutils import VCGPrinter
|
20
|
-
from logilab.common.graph import DotBackend
|
21
|
-
|
22
19
|
from pylint.pyreverse.utils import is_exception
|
20
|
+
from pylint.pyreverse.vcgutils import VCGPrinter
|
21
|
+
from pylint.graph import DotBackend
|
23
22
|
|
24
23
|
class DiagramWriter(object):
|
25
24
|
"""base class for writing project diagrams
|
@@ -106,7 +105,7 @@ class DotWriter(DiagramWriter):
|
|
106
105
|
"""initialize DotWriter and add options for layout.
|
107
106
|
"""
|
108
107
|
layout = dict(rankdir="BT")
|
109
|
-
self.printer = DotBackend(basename,
|
108
|
+
self.printer = DotBackend(basename, additional_param=layout)
|
110
109
|
self.file_name = file_name
|
111
110
|
|
112
111
|
def get_title(self, obj):
|
@@ -17,9 +17,9 @@ from __future__ import print_function
|
|
17
17
|
import sys
|
18
18
|
import locale
|
19
19
|
import os
|
20
|
+
import warnings
|
20
21
|
|
21
|
-
|
22
|
-
from pylint import utils
|
22
|
+
import six
|
23
23
|
|
24
24
|
CMPS = ['=', '-', '+']
|
25
25
|
|
@@ -47,12 +47,9 @@ class BaseReporter(object):
|
|
47
47
|
|
48
48
|
def __init__(self, output=None):
|
49
49
|
self.linter = None
|
50
|
-
# self.include_ids = None # Deprecated
|
51
|
-
# self.symbols = None # Deprecated
|
52
50
|
self.section = 0
|
53
51
|
self.out = None
|
54
52
|
self.out_encoding = None
|
55
|
-
self.encode = None
|
56
53
|
self.set_output(output)
|
57
54
|
# Build the path prefix to strip to get relative paths
|
58
55
|
self.path_strip_prefix = os.getcwd() + os.sep
|
@@ -67,18 +64,20 @@ class BaseReporter(object):
|
|
67
64
|
|
68
65
|
def add_message(self, msg_id, location, msg):
|
69
66
|
"""Deprecated, do not use."""
|
70
|
-
|
67
|
+
# pylint: disable=no-self-use,unused-argument
|
68
|
+
msg = ("This method is deprecated, use handle_message instead. "
|
69
|
+
"It will be removed in Pylint 1.6.")
|
70
|
+
warnings.warn(msg, DeprecationWarning, stacklevel=2)
|
71
71
|
|
72
72
|
def set_output(self, output=None):
|
73
73
|
"""set output stream"""
|
74
74
|
self.out = output or sys.stdout
|
75
|
-
# py3k streams handle their encoding :
|
76
|
-
if sys.version_info >= (3, 0):
|
77
|
-
self.encode = lambda x: x
|
78
|
-
return
|
79
75
|
|
80
|
-
|
81
|
-
|
76
|
+
if six.PY3:
|
77
|
+
encode = lambda self, string: string
|
78
|
+
else:
|
79
|
+
def encode(self, string):
|
80
|
+
if not isinstance(string, six.text_type):
|
82
81
|
return string
|
83
82
|
encoding = (getattr(self.out, 'encoding', None) or
|
84
83
|
locale.getdefaultlocale()[1] or
|
@@ -87,32 +86,46 @@ class BaseReporter(object):
|
|
87
86
|
# source code line that can't be encoded with the current locale
|
88
87
|
# settings
|
89
88
|
return string.encode(encoding, 'replace')
|
90
|
-
self.encode = encode
|
91
89
|
|
92
90
|
def writeln(self, string=''):
|
93
91
|
"""write a line in the output buffer"""
|
94
92
|
print(self.encode(string), file=self.out)
|
95
93
|
|
96
|
-
def
|
94
|
+
def display_reports(self, layout):
|
97
95
|
"""display results encapsulated in the layout tree"""
|
98
96
|
self.section = 0
|
99
97
|
if hasattr(layout, 'report_id'):
|
100
98
|
layout.children[0].children[0].data += ' (%s)' % layout.report_id
|
101
99
|
self._display(layout)
|
102
100
|
|
101
|
+
def display_results(self, layout):
|
102
|
+
warnings.warn("display_results is deprecated, use display_reports instead. "
|
103
|
+
"The former will be removed in Pylint 2.0.",
|
104
|
+
DeprecationWarning)
|
105
|
+
self.display_reports(layout)
|
106
|
+
|
103
107
|
def _display(self, layout):
|
104
108
|
"""display the layout"""
|
105
109
|
raise NotImplementedError()
|
106
110
|
|
111
|
+
def display_messages(self, layout):
|
112
|
+
"""Hook for displaying the messages of the reporter
|
113
|
+
|
114
|
+
This will be called whenever the underlying messages
|
115
|
+
needs to be displayed. For some reporters, it probably
|
116
|
+
doesn't make sense to display messages as soon as they
|
117
|
+
are available, so some mechanism of storing them could be used.
|
118
|
+
This method can be implemented to display them after they've
|
119
|
+
been aggregated.
|
120
|
+
"""
|
121
|
+
|
107
122
|
# Event callbacks
|
108
123
|
|
109
124
|
def on_set_current_module(self, module, filepath):
|
110
|
-
"""
|
111
|
-
pass
|
125
|
+
"""Hook called when a module starts to be analysed."""
|
112
126
|
|
113
127
|
def on_close(self, stats, previous_stats):
|
114
|
-
"""
|
115
|
-
pass
|
128
|
+
"""Hook called when a module finished analyzing."""
|
116
129
|
|
117
130
|
|
118
131
|
class CollectingReporter(BaseReporter):
|
@@ -127,7 +140,10 @@ class CollectingReporter(BaseReporter):
|
|
127
140
|
def handle_message(self, msg):
|
128
141
|
self.messages.append(msg)
|
129
142
|
|
143
|
+
_display = None
|
144
|
+
|
130
145
|
|
131
146
|
def initialize(linter):
|
132
147
|
"""initialize linter with reporters in this package """
|
148
|
+
from pylint import utils
|
133
149
|
utils.register_plugins(linter, __path__[0])
|
@@ -17,10 +17,12 @@ import itertools
|
|
17
17
|
import string
|
18
18
|
import sys
|
19
19
|
|
20
|
-
|
20
|
+
import six
|
21
21
|
|
22
22
|
from pylint.interfaces import IReporter
|
23
23
|
from pylint.reporters import BaseReporter
|
24
|
+
from pylint.reporters.ureports.html_writer import HTMLWriter
|
25
|
+
from pylint.reporters.ureports.nodes import Section, Table
|
24
26
|
|
25
27
|
|
26
28
|
class HTMLReporter(BaseReporter):
|
@@ -67,7 +69,9 @@ class HTMLReporter(BaseReporter):
|
|
67
69
|
self._parse_template()
|
68
70
|
|
69
71
|
# We want to add the lines given by the template
|
70
|
-
|
72
|
+
values = [getattr(msg, field) for field in self.msgargs]
|
73
|
+
self.msgs += [value if isinstance(value, six.text_type) else str(value)
|
74
|
+
for value in values]
|
71
75
|
|
72
76
|
def set_output(self, output=None):
|
73
77
|
"""set output stream
|
@@ -84,6 +88,9 @@ class HTMLReporter(BaseReporter):
|
|
84
88
|
(in add_message, message is not displayed, just collected so it
|
85
89
|
can be displayed in an html table)
|
86
90
|
"""
|
91
|
+
HTMLWriter().format(layout, self.out)
|
92
|
+
|
93
|
+
def display_messages(self, layout):
|
87
94
|
if self.msgs:
|
88
95
|
# add stored messages to the layout
|
89
96
|
msgs = self.header
|
@@ -93,7 +100,7 @@ class HTMLReporter(BaseReporter):
|
|
93
100
|
layout.append(sect)
|
94
101
|
sect.append(Table(cols=cols, children=msgs, rheaders=1))
|
95
102
|
self.msgs = []
|
96
|
-
|
103
|
+
self._display(layout)
|
97
104
|
|
98
105
|
|
99
106
|
def register(linter):
|