libv8 8.4.255.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +19 -0
- data/.gitmodules +3 -0
- data/.rspec +3 -0
- data/.travis.yml +45 -0
- data/CHANGELOG.md +111 -0
- data/Gemfile +4 -0
- data/README.md +152 -0
- data/Rakefile +125 -0
- data/appveyor.yml.disabled +36 -0
- data/ext/libv8/arch.rb +20 -0
- data/ext/libv8/builder.rb +106 -0
- data/ext/libv8/extconf.rb +7 -0
- data/ext/libv8/location.rb +89 -0
- data/ext/libv8/paths.rb +28 -0
- data/lib/libv8.rb +9 -0
- data/lib/libv8/version.rb +3 -0
- data/libv8.gemspec +30 -0
- data/scaleway.png +0 -0
- data/spec/location_spec.rb +69 -0
- data/spec/spec_helper.rb +4 -0
- data/thefrontside.png +0 -0
- data/vendor/depot_tools/.cipd_impl.ps1 +129 -0
- data/vendor/depot_tools/.gitattributes +55 -0
- data/vendor/depot_tools/.gitignore +92 -0
- data/vendor/depot_tools/.style.yapf +4 -0
- data/vendor/depot_tools/.vpython +55 -0
- data/vendor/depot_tools/.vpython3 +23 -0
- data/vendor/depot_tools/CROS_OWNERS +7 -0
- data/vendor/depot_tools/GOMA_OWNERS +9 -0
- data/vendor/depot_tools/LICENSE +27 -0
- data/vendor/depot_tools/LUCI_OWNERS +5 -0
- data/vendor/depot_tools/OWNERS +39 -0
- data/vendor/depot_tools/PRESUBMIT.py +150 -0
- data/vendor/depot_tools/README.gclient.md +67 -0
- data/vendor/depot_tools/README.git-cl.md +99 -0
- data/vendor/depot_tools/README.md +78 -0
- data/vendor/depot_tools/WATCHLISTS +26 -0
- data/vendor/depot_tools/auth.py +163 -0
- data/vendor/depot_tools/autoninja +36 -0
- data/vendor/depot_tools/autoninja.bat +33 -0
- data/vendor/depot_tools/autoninja.py +148 -0
- data/vendor/depot_tools/bb +12 -0
- data/vendor/depot_tools/bb.bat +7 -0
- data/vendor/depot_tools/bootstrap/README.md +155 -0
- data/vendor/depot_tools/bootstrap/bootstrap.py +356 -0
- data/vendor/depot_tools/bootstrap/git-bash.template.sh +12 -0
- data/vendor/depot_tools/bootstrap/git.template.bat +5 -0
- data/vendor/depot_tools/bootstrap/manifest.txt +27 -0
- data/vendor/depot_tools/bootstrap/manifest_bleeding_edge.txt +27 -0
- data/vendor/depot_tools/bootstrap/profile.d.python.sh +20 -0
- data/vendor/depot_tools/bootstrap/python27.bat +46 -0
- data/vendor/depot_tools/bootstrap/python3.bat +46 -0
- data/vendor/depot_tools/bootstrap/win_tools.bat +79 -0
- data/vendor/depot_tools/bootstrap_python3 +35 -0
- data/vendor/depot_tools/breakpad.py +12 -0
- data/vendor/depot_tools/cbuildbot +1 -0
- data/vendor/depot_tools/chrome_set_ver +1 -0
- data/vendor/depot_tools/cipd +247 -0
- data/vendor/depot_tools/cipd.bat +67 -0
- data/vendor/depot_tools/cipd_bin_setup.bat +6 -0
- data/vendor/depot_tools/cipd_bin_setup.sh +22 -0
- data/vendor/depot_tools/cipd_client_version +1 -0
- data/vendor/depot_tools/cipd_client_version.digests +22 -0
- data/vendor/depot_tools/cipd_manifest.txt +63 -0
- data/vendor/depot_tools/cipd_manifest.versions +438 -0
- data/vendor/depot_tools/cit +8 -0
- data/vendor/depot_tools/cit.bat +12 -0
- data/vendor/depot_tools/cit.py +167 -0
- data/vendor/depot_tools/clang-format +8 -0
- data/vendor/depot_tools/clang-format.bat +12 -0
- data/vendor/depot_tools/clang_format.py +79 -0
- data/vendor/depot_tools/clang_format_merge_driver +8 -0
- data/vendor/depot_tools/clang_format_merge_driver.bat +12 -0
- data/vendor/depot_tools/clang_format_merge_driver.py +69 -0
- data/vendor/depot_tools/codereview.settings +6 -0
- data/vendor/depot_tools/compile_single_file +8 -0
- data/vendor/depot_tools/compile_single_file.bat +11 -0
- data/vendor/depot_tools/compile_single_file.py +79 -0
- data/vendor/depot_tools/cpplint.bat +11 -0
- data/vendor/depot_tools/cpplint.py +6097 -0
- data/vendor/depot_tools/cpplint_chromium.py +50 -0
- data/vendor/depot_tools/cros +87 -0
- data/vendor/depot_tools/cros_sdk +1 -0
- data/vendor/depot_tools/crosjobs +13 -0
- data/vendor/depot_tools/detect_host_arch.py +55 -0
- data/vendor/depot_tools/dirmd +12 -0
- data/vendor/depot_tools/dirmd.bat +7 -0
- data/vendor/depot_tools/download_from_google_storage +8 -0
- data/vendor/depot_tools/download_from_google_storage.bat +12 -0
- data/vendor/depot_tools/download_from_google_storage.py +634 -0
- data/vendor/depot_tools/ensure_bootstrap +53 -0
- data/vendor/depot_tools/fetch +21 -0
- data/vendor/depot_tools/fetch.bat +28 -0
- data/vendor/depot_tools/fetch.py +319 -0
- data/vendor/depot_tools/fetch_configs/android.py +34 -0
- data/vendor/depot_tools/fetch_configs/android_internal.py +34 -0
- data/vendor/depot_tools/fetch_configs/breakpad.py +44 -0
- data/vendor/depot_tools/fetch_configs/chromium.py +66 -0
- data/vendor/depot_tools/fetch_configs/config_util.py +52 -0
- data/vendor/depot_tools/fetch_configs/crashpad.py +41 -0
- data/vendor/depot_tools/fetch_configs/dart.py +45 -0
- data/vendor/depot_tools/fetch_configs/depot_tools.py +44 -0
- data/vendor/depot_tools/fetch_configs/devtools-frontend.py +44 -0
- data/vendor/depot_tools/fetch_configs/goma_client.py +41 -0
- data/vendor/depot_tools/fetch_configs/gyp.py +41 -0
- data/vendor/depot_tools/fetch_configs/infra.py +40 -0
- data/vendor/depot_tools/fetch_configs/infra_internal.py +45 -0
- data/vendor/depot_tools/fetch_configs/inspector_protocol.py +40 -0
- data/vendor/depot_tools/fetch_configs/ios.py +34 -0
- data/vendor/depot_tools/fetch_configs/ios_internal.py +39 -0
- data/vendor/depot_tools/fetch_configs/nacl.py +48 -0
- data/vendor/depot_tools/fetch_configs/naclports.py +47 -0
- data/vendor/depot_tools/fetch_configs/node-ci.py +41 -0
- data/vendor/depot_tools/fetch_configs/pdfium.py +40 -0
- data/vendor/depot_tools/fetch_configs/skia.py +41 -0
- data/vendor/depot_tools/fetch_configs/skia_buildbot.py +41 -0
- data/vendor/depot_tools/fetch_configs/syzygy.py +41 -0
- data/vendor/depot_tools/fetch_configs/v8.py +44 -0
- data/vendor/depot_tools/fetch_configs/webrtc.py +52 -0
- data/vendor/depot_tools/fetch_configs/webrtc_android.py +34 -0
- data/vendor/depot_tools/fetch_configs/webrtc_ios.py +34 -0
- data/vendor/depot_tools/fix_encoding.py +385 -0
- data/vendor/depot_tools/gclient +38 -0
- data/vendor/depot_tools/gclient-new-workdir.py +124 -0
- data/vendor/depot_tools/gclient.bat +32 -0
- data/vendor/depot_tools/gclient.py +3198 -0
- data/vendor/depot_tools/gclient_completion.sh +76 -0
- data/vendor/depot_tools/gclient_eval.py +891 -0
- data/vendor/depot_tools/gclient_paths.py +152 -0
- data/vendor/depot_tools/gclient_scm.py +1615 -0
- data/vendor/depot_tools/gclient_utils.py +1280 -0
- data/vendor/depot_tools/gerrit_client.py +151 -0
- data/vendor/depot_tools/gerrit_util.py +996 -0
- data/vendor/depot_tools/git-cache +6 -0
- data/vendor/depot_tools/git-cl +6 -0
- data/vendor/depot_tools/git-crrev-parse +53 -0
- data/vendor/depot_tools/git-drover +6 -0
- data/vendor/depot_tools/git-find-releases +6 -0
- data/vendor/depot_tools/git-footers +6 -0
- data/vendor/depot_tools/git-freeze +8 -0
- data/vendor/depot_tools/git-gs +9 -0
- data/vendor/depot_tools/git-hyper-blame +6 -0
- data/vendor/depot_tools/git-map +6 -0
- data/vendor/depot_tools/git-map-branches +6 -0
- data/vendor/depot_tools/git-mark-merge-base +6 -0
- data/vendor/depot_tools/git-nav-downstream +6 -0
- data/vendor/depot_tools/git-nav-upstream +6 -0
- data/vendor/depot_tools/git-new-branch +6 -0
- data/vendor/depot_tools/git-number +6 -0
- data/vendor/depot_tools/git-rebase-update +6 -0
- data/vendor/depot_tools/git-rename-branch +6 -0
- data/vendor/depot_tools/git-reparent-branch +6 -0
- data/vendor/depot_tools/git-retry +8 -0
- data/vendor/depot_tools/git-runhooks +23 -0
- data/vendor/depot_tools/git-squash-branch +6 -0
- data/vendor/depot_tools/git-templates/description +3 -0
- data/vendor/depot_tools/git-templates/hooks/applypatch-msg +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-applypatch +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-checkout +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-commit +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-merge +4 -0
- data/vendor/depot_tools/git-templates/hooks/post-update +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-applypatch +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-auto-gc +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-commit +4 -0
- data/vendor/depot_tools/git-templates/hooks/pre-rebase +4 -0
- data/vendor/depot_tools/git-templates/hooks/prepare-commit-msg +4 -0
- data/vendor/depot_tools/git-templates/info/exclude +6 -0
- data/vendor/depot_tools/git-thaw +13 -0
- data/vendor/depot_tools/git-upstream-diff +9 -0
- data/vendor/depot_tools/git_cache.py +786 -0
- data/vendor/depot_tools/git_cl.py +5158 -0
- data/vendor/depot_tools/git_cl_completion.sh +48 -0
- data/vendor/depot_tools/git_common.py +1101 -0
- data/vendor/depot_tools/git_dates.py +62 -0
- data/vendor/depot_tools/git_drover.py +469 -0
- data/vendor/depot_tools/git_find_releases.py +67 -0
- data/vendor/depot_tools/git_footers.py +261 -0
- data/vendor/depot_tools/git_freezer.py +40 -0
- data/vendor/depot_tools/git_hyper_blame.py +391 -0
- data/vendor/depot_tools/git_map.py +166 -0
- data/vendor/depot_tools/git_map_branches.py +354 -0
- data/vendor/depot_tools/git_mark_merge_base.py +73 -0
- data/vendor/depot_tools/git_nav_downstream.py +69 -0
- data/vendor/depot_tools/git_new_branch.py +82 -0
- data/vendor/depot_tools/git_number.py +301 -0
- data/vendor/depot_tools/git_rebase_update.py +351 -0
- data/vendor/depot_tools/git_rename_branch.py +55 -0
- data/vendor/depot_tools/git_reparent_branch.py +101 -0
- data/vendor/depot_tools/git_retry.py +181 -0
- data/vendor/depot_tools/git_squash_branch.py +28 -0
- data/vendor/depot_tools/git_upstream_diff.py +64 -0
- data/vendor/depot_tools/gn +8 -0
- data/vendor/depot_tools/gn.bat +12 -0
- data/vendor/depot_tools/gn.py +78 -0
- data/vendor/depot_tools/goma_auth +12 -0
- data/vendor/depot_tools/goma_auth.bat +8 -0
- data/vendor/depot_tools/goma_ctl +12 -0
- data/vendor/depot_tools/goma_ctl.bat +8 -0
- data/vendor/depot_tools/gsutil.py +190 -0
- data/vendor/depot_tools/gsutil.py.bat +23 -0
- data/vendor/depot_tools/gsutil.vpython +120 -0
- data/vendor/depot_tools/infra/README.md +1 -0
- data/vendor/depot_tools/infra/config/OWNERS +7 -0
- data/vendor/depot_tools/infra/config/README.md +1 -0
- data/vendor/depot_tools/infra/config/recipes.cfg +26 -0
- data/vendor/depot_tools/led +12 -0
- data/vendor/depot_tools/led.bat +7 -0
- data/vendor/depot_tools/lockfile.py +116 -0
- data/vendor/depot_tools/luci-auth +13 -0
- data/vendor/depot_tools/luci-auth.bat +8 -0
- data/vendor/depot_tools/lucicfg +12 -0
- data/vendor/depot_tools/lucicfg.bat +7 -0
- data/vendor/depot_tools/mac_toolchain +12 -0
- data/vendor/depot_tools/man/html/depot_tools.html +934 -0
- data/vendor/depot_tools/man/html/depot_tools_tutorial.html +1593 -0
- data/vendor/depot_tools/man/html/git-cl.html +1033 -0
- data/vendor/depot_tools/man/html/git-drover.html +1048 -0
- data/vendor/depot_tools/man/html/git-footers.html +878 -0
- data/vendor/depot_tools/man/html/git-freeze.html +859 -0
- data/vendor/depot_tools/man/html/git-hyper-blame.html +878 -0
- data/vendor/depot_tools/man/html/git-map-branches.html +904 -0
- data/vendor/depot_tools/man/html/git-map.html +887 -0
- data/vendor/depot_tools/man/html/git-mark-merge-base.html +826 -0
- data/vendor/depot_tools/man/html/git-nav-downstream.html +844 -0
- data/vendor/depot_tools/man/html/git-nav-upstream.html +853 -0
- data/vendor/depot_tools/man/html/git-new-branch.html +932 -0
- data/vendor/depot_tools/man/html/git-rebase-update.html +961 -0
- data/vendor/depot_tools/man/html/git-rename-branch.html +794 -0
- data/vendor/depot_tools/man/html/git-reparent-branch.html +847 -0
- data/vendor/depot_tools/man/html/git-retry.html +858 -0
- data/vendor/depot_tools/man/html/git-squash-branch.html +881 -0
- data/vendor/depot_tools/man/html/git-thaw.html +794 -0
- data/vendor/depot_tools/man/html/git-upstream-diff.html +923 -0
- data/vendor/depot_tools/man/man1/git-cl.1 +198 -0
- data/vendor/depot_tools/man/man1/git-drover.1 +330 -0
- data/vendor/depot_tools/man/man1/git-footers.1 +144 -0
- data/vendor/depot_tools/man/man1/git-freeze.1 +113 -0
- data/vendor/depot_tools/man/man1/git-hyper-blame.1 +128 -0
- data/vendor/depot_tools/man/man1/git-map-branches.1 +210 -0
- data/vendor/depot_tools/man/man1/git-map.1 +179 -0
- data/vendor/depot_tools/man/man1/git-mark-merge-base.1 +69 -0
- data/vendor/depot_tools/man/man1/git-nav-downstream.1 +112 -0
- data/vendor/depot_tools/man/man1/git-nav-upstream.1 +122 -0
- data/vendor/depot_tools/man/man1/git-new-branch.1 +176 -0
- data/vendor/depot_tools/man/man1/git-rebase-update.1 +177 -0
- data/vendor/depot_tools/man/man1/git-rename-branch.1 +53 -0
- data/vendor/depot_tools/man/man1/git-reparent-branch.1 +93 -0
- data/vendor/depot_tools/man/man1/git-retry.1 +108 -0
- data/vendor/depot_tools/man/man1/git-squash-branch.1 +129 -0
- data/vendor/depot_tools/man/man1/git-thaw.1 +54 -0
- data/vendor/depot_tools/man/man1/git-upstream-diff.1 +153 -0
- data/vendor/depot_tools/man/man7/depot_tools.7 +139 -0
- data/vendor/depot_tools/man/man7/depot_tools_tutorial.7 +1061 -0
- data/vendor/depot_tools/man/push_to_gs.sh +4 -0
- data/vendor/depot_tools/man/src/.gitignore +5 -0
- data/vendor/depot_tools/man/src/_aliases.txt +5 -0
- data/vendor/depot_tools/man/src/_footer.txt +8 -0
- data/vendor/depot_tools/man/src/_git-cl_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-drover_desc.helper.txt +2 -0
- data/vendor/depot_tools/man/src/_git-footers_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-freeze_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-hyper-blame_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-map-branches_desc.helper.txt +4 -0
- data/vendor/depot_tools/man/src/_git-map_desc.helper.txt +3 -0
- data/vendor/depot_tools/man/src/_git-mark-merge-base_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-nav-downstream_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-nav-upstream_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-new-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-rebase-update_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-rename-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-reparent-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-retry_desc.helper.txt +2 -0
- data/vendor/depot_tools/man/src/_git-squash-branch_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_git-thaw_desc.helper.txt +2 -0
- data/vendor/depot_tools/man/src/_git-upstream-diff_desc.helper.txt +1 -0
- data/vendor/depot_tools/man/src/_helper_prefix.txt +1 -0
- data/vendor/depot_tools/man/src/asciidoc-override.css +7 -0
- data/vendor/depot_tools/man/src/common_demo_functions.sh +84 -0
- data/vendor/depot_tools/man/src/demo_repo.sh +43 -0
- data/vendor/depot_tools/man/src/depot_tools.txt +28 -0
- data/vendor/depot_tools/man/src/depot_tools_tutorial.demo.walkthrough.sh +155 -0
- data/vendor/depot_tools/man/src/depot_tools_tutorial.txt +432 -0
- data/vendor/depot_tools/man/src/filter_demo_output.py +141 -0
- data/vendor/depot_tools/man/src/git-cl.txt +119 -0
- data/vendor/depot_tools/man/src/git-drover.demo.1.sh +22 -0
- data/vendor/depot_tools/man/src/git-drover.demo.2.sh +23 -0
- data/vendor/depot_tools/man/src/git-drover.demo.3.sh +27 -0
- data/vendor/depot_tools/man/src/git-drover.demo.4.sh +39 -0
- data/vendor/depot_tools/man/src/git-drover.demo.common.sh +19 -0
- data/vendor/depot_tools/man/src/git-drover.txt +102 -0
- data/vendor/depot_tools/man/src/git-footers.demo.1.sh +17 -0
- data/vendor/depot_tools/man/src/git-footers.txt +71 -0
- data/vendor/depot_tools/man/src/git-freeze.demo.1.sh +23 -0
- data/vendor/depot_tools/man/src/git-freeze.txt +54 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.demo.1.sh +3 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.demo.2.sh +4 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.demo.common.sh +57 -0
- data/vendor/depot_tools/man/src/git-hyper-blame.txt +85 -0
- data/vendor/depot_tools/man/src/git-map-branches.demo.1.sh +8 -0
- data/vendor/depot_tools/man/src/git-map-branches.txt +64 -0
- data/vendor/depot_tools/man/src/git-map.demo.1.sh +3 -0
- data/vendor/depot_tools/man/src/git-map.txt +67 -0
- data/vendor/depot_tools/man/src/git-mark-merge-base.txt +46 -0
- data/vendor/depot_tools/man/src/git-nav-downstream.demo.1.sh +12 -0
- data/vendor/depot_tools/man/src/git-nav-downstream.txt +40 -0
- data/vendor/depot_tools/man/src/git-nav-upstream.demo.1.sh +12 -0
- data/vendor/depot_tools/man/src/git-nav-upstream.txt +39 -0
- data/vendor/depot_tools/man/src/git-new-branch.demo.1.sh +17 -0
- data/vendor/depot_tools/man/src/git-new-branch.txt +82 -0
- data/vendor/depot_tools/man/src/git-rebase-update.txt +141 -0
- data/vendor/depot_tools/man/src/git-rename-branch.txt +28 -0
- data/vendor/depot_tools/man/src/git-reparent-branch.txt +61 -0
- data/vendor/depot_tools/man/src/git-retry.txt +67 -0
- data/vendor/depot_tools/man/src/git-squash-branch.demo.1.sh +12 -0
- data/vendor/depot_tools/man/src/git-squash-branch.txt +59 -0
- data/vendor/depot_tools/man/src/git-thaw.txt +29 -0
- data/vendor/depot_tools/man/src/git-upstream-diff.txt +107 -0
- data/vendor/depot_tools/man/src/make_docs.sh +260 -0
- data/vendor/depot_tools/man/src/prep_demo_repo.sh +103 -0
- data/vendor/depot_tools/metrics.README.md +101 -0
- data/vendor/depot_tools/metrics.py +297 -0
- data/vendor/depot_tools/metrics_utils.py +293 -0
- data/vendor/depot_tools/my_activity.py +971 -0
- data/vendor/depot_tools/ninja +44 -0
- data/vendor/depot_tools/ninja-linux32 +0 -0
- data/vendor/depot_tools/ninja-linux64 +0 -0
- data/vendor/depot_tools/ninja-mac +0 -0
- data/vendor/depot_tools/ninja.exe +0 -0
- data/vendor/depot_tools/ninjalog.README.md +64 -0
- data/vendor/depot_tools/ninjalog_uploader.py +233 -0
- data/vendor/depot_tools/ninjalog_uploader_wrapper.py +125 -0
- data/vendor/depot_tools/owners.py +641 -0
- data/vendor/depot_tools/owners_finder.py +385 -0
- data/vendor/depot_tools/post_build_ninja_summary.py +350 -0
- data/vendor/depot_tools/presubmit_canned_checks.py +1655 -0
- data/vendor/depot_tools/presubmit_support.py +1923 -0
- data/vendor/depot_tools/profile.xml +8 -0
- data/vendor/depot_tools/prpc +13 -0
- data/vendor/depot_tools/prpc.bat +8 -0
- data/vendor/depot_tools/pylint +9 -0
- data/vendor/depot_tools/pylint-1.5 +78 -0
- data/vendor/depot_tools/pylint-1.6 +78 -0
- data/vendor/depot_tools/pylint-1.7 +78 -0
- data/vendor/depot_tools/pylint-1.8 +78 -0
- data/vendor/depot_tools/pylint-1.9 +78 -0
- data/vendor/depot_tools/pylint.bat +12 -0
- data/vendor/depot_tools/pylint_main.py +45 -0
- data/vendor/depot_tools/pylintrc +349 -0
- data/vendor/depot_tools/python-bin/python3 +7 -0
- data/vendor/depot_tools/python_runner.sh +60 -0
- data/vendor/depot_tools/rdb +12 -0
- data/vendor/depot_tools/rdb.bat +7 -0
- data/vendor/depot_tools/recipes/OWNERS +4 -0
- data/vendor/depot_tools/recipes/README.recipes.md +1079 -0
- data/vendor/depot_tools/recipes/recipe_modules/OWNERS +1 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/OWNERS +2 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/__init__.py +38 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/api.py +516 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic.json +117 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_luci.json +117 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/basic_with_branch_heads.json +118 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/clobber.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/deprecated_got_revision_mapping.json +194 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_rebase_patch_ref.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/gerrit_no_reset.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/input_commit_with_id_without_repo.json +210 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/multiple_patch_refs.json +214 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_apply_patch_on_gclient.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_HEAD.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_branch_head.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_a_specific_commit.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/no_cp_checkout_master.json +65 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/refs.json +212 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/reset_root_solution_revision.json +210 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/resolve_chromium_fixed_version.json +117 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail.json +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch.json +209 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_fail_patch_download.json +193 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_angle.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_branch_heads.json +261 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_feature_branch.json +261 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_v8_feature_branch.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_gerrit_webrtc.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/tryjob_v8_head_by_default.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/unrecognized_commit_repo.json +8 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.expected/with_tags.json +211 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/examples/full.py +308 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/__init__.py +0 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/resources/bot_update.py +1258 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/test_api.py +93 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/do_not_retry_patch_failures_in_cq.py +42 -0
- data/vendor/depot_tools/recipes/recipe_modules/bot_update/tests/ensure_checkout.py +35 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/__init__.py +9 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/api.py +455 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/basic_pkg.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-failed.json +82 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/describe-many-instances.json +411 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/mac64.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_file.json +315 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_mode.json +313 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/pkg_bad_verfile.json +313 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.expected/win64.json +403 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/full.py +187 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk arch.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/junk bits.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_32.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_arm_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_32.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_intel_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/linux_mips_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/mac_intel_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_32.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.expected/win_intel_64.json +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/examples/platform_suffix.py +59 -0
- data/vendor/depot_tools/recipes/recipe_modules/cipd/test_api.py +93 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/__init__.py +9 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/api.py +75 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/basic_luci.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.expected/win.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/depot_tools/examples/full.py +55 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/__init__.py +13 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/api.py +428 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/config.py +462 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/basic.json +238 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/revision.json +240 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.expected/tryserver.json +238 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/examples/full.py +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/resources/diff_deps.py +16 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/test_api.py +36 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/basic.json +55 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/dont have revision yet.json +84 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/no change, exception.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.expected/windows.json +55 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/diff_deps.py +88 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/patch_project.py +92 -0
- data/vendor/depot_tools/recipes/recipe_modules/gclient/tests/sync_failure.py +24 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/__init__.py +8 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/api.py +178 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.expected/basic.json +284 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/examples/full.py +73 -0
- data/vendor/depot_tools/recipes/recipe_modules/gerrit/test_api.py +53 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/__init__.py +11 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/api.py +405 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_branch.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_file_name.json +219 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_hash.json +216 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_ref.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_submodule_update_force.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/basic_tags.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/can_fail_build.json +164 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cannot_fail_build.json +220 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/cat-file_test.json +239 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_delta.json +290 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_failed.json +220 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output.json +222 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/count-objects_with_bad_output_fails_build.json +111 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/curl_trace_file.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/git-cache-checkout.json +265 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/platform_win.json +217 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/rebase_failed.json +221 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/remote_not_origin.json +219 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.expected/set_got_revision.json +218 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/examples/full.py +170 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/resources/git_setup.py +52 -0
- data/vendor/depot_tools/recipes/recipe_modules/git/test_api.py +18 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/__init__.py +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/api.py +50 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/config.py +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.expected/basic.json +105 -0
- data/vendor/depot_tools/recipes/recipe_modules/git_cl/examples/full.py +47 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/OWNERS +2 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/__init__.py +12 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/api.py +257 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.expected/basic.json +596 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/examples/full.py +93 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/resources/gerrit_client.py +251 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/test_api.py +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.expected/basic.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/gitiles/tests/parse_repo_url.py +49 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/__init__.py +4 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/api.py +222 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.expected/basic.json +247 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/examples/full.py +92 -0
- data/vendor/depot_tools/recipes/recipe_modules/gsutil/resources/gsutil_smart_retry.py +69 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/__init__.py +36 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/api.py +140 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/ancient_version.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/automatic_version.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/explicit_version.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/linux.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/mac.json +83 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.expected/win.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/osx_sdk/examples/full.py +42 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/__init__.py +27 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/api.py +251 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.expected/basic.json +27 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/examples/full.py +19 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/properties.proto +14 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/test_api.py +19 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/execute.py +247 -0
- data/vendor/depot_tools/recipes/recipe_modules/presubmit/tests/prepare.py +49 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/__init__.py +18 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/api.py +264 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/basic_tags.json +57 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch.json +190 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_gerrit_patch_and_target_ref.json +190 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.expected/with_wrong_patch_new.json +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/examples/full.py +95 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/test_api.py +14 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_fetch_ref_timeout.py +29 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.expected/basic.json +5 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_owner.py +22 -0
- data/vendor/depot_tools/recipes/recipe_modules/tryserver/tests/gerrit_change_target_ref.py +32 -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 +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/mac.json +21 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.expected/win.json +108 -0
- data/vendor/depot_tools/recipes/recipe_modules/windows_sdk/examples/full.py +21 -0
- data/vendor/depot_tools/recipes/recipes.py +249 -0
- data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.expected/basic.json +175 -0
- data/vendor/depot_tools/recipes/recipes/fetch_end_to_end_test.py +56 -0
- data/vendor/depot_tools/recipes/trigger_recipe_roller.txt +13 -0
- data/vendor/depot_tools/repo +1194 -0
- data/vendor/depot_tools/roll-dep +21 -0
- data/vendor/depot_tools/roll-dep.bat +21 -0
- data/vendor/depot_tools/roll_dep.py +282 -0
- data/vendor/depot_tools/scm.py +415 -0
- data/vendor/depot_tools/setup_color.py +130 -0
- data/vendor/depot_tools/split_cl.py +263 -0
- data/vendor/depot_tools/subcommand.py +261 -0
- data/vendor/depot_tools/subprocess2.py +258 -0
- data/vendor/depot_tools/third_party/__init__.py +5 -0
- data/vendor/depot_tools/third_party/colorama/LICENSE.txt +27 -0
- data/vendor/depot_tools/third_party/colorama/README.chromium +12 -0
- data/vendor/depot_tools/third_party/colorama/README.rst +346 -0
- data/vendor/depot_tools/third_party/colorama/__init__.py +6 -0
- data/vendor/depot_tools/third_party/colorama/ansi.py +102 -0
- data/vendor/depot_tools/third_party/colorama/ansitowin32.py +257 -0
- data/vendor/depot_tools/third_party/colorama/initialise.py +80 -0
- data/vendor/depot_tools/third_party/colorama/win32.py +152 -0
- data/vendor/depot_tools/third_party/colorama/winterm.py +169 -0
- data/vendor/depot_tools/third_party/coverage/AUTHORS.txt +43 -0
- data/vendor/depot_tools/third_party/coverage/PKG-INFO +41 -0
- data/vendor/depot_tools/third_party/coverage/README.chromium +13 -0
- data/vendor/depot_tools/third_party/coverage/__init__.py +120 -0
- data/vendor/depot_tools/third_party/coverage/__main__.py +4 -0
- data/vendor/depot_tools/third_party/coverage/annotate.py +101 -0
- data/vendor/depot_tools/third_party/coverage/backward.py +184 -0
- data/vendor/depot_tools/third_party/coverage/bytecode.py +75 -0
- data/vendor/depot_tools/third_party/coverage/cmdline.py +740 -0
- data/vendor/depot_tools/third_party/coverage/codeunit.py +145 -0
- data/vendor/depot_tools/third_party/coverage/collector.py +353 -0
- data/vendor/depot_tools/third_party/coverage/config.py +213 -0
- data/vendor/depot_tools/third_party/coverage/control.py +776 -0
- data/vendor/depot_tools/third_party/coverage/data.py +278 -0
- data/vendor/depot_tools/third_party/coverage/debug.py +54 -0
- data/vendor/depot_tools/third_party/coverage/execfile.py +171 -0
- data/vendor/depot_tools/third_party/coverage/files.py +309 -0
- data/vendor/depot_tools/third_party/coverage/fullcoverage/encodings.py +57 -0
- data/vendor/depot_tools/third_party/coverage/html.py +387 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/coverage_html.js +376 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/index.html +104 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery-1.4.3.min.js +166 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.hotkeys.js +99 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.isonscreen.js +53 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.min.js +166 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/jquery.tablesorter.min.js +2 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/keybd_closed.png +0 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/keybd_open.png +0 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/pyfile.html +90 -0
- data/vendor/depot_tools/third_party/coverage/htmlfiles/style.css +300 -0
- data/vendor/depot_tools/third_party/coverage/misc.py +163 -0
- data/vendor/depot_tools/third_party/coverage/parser.py +666 -0
- data/vendor/depot_tools/third_party/coverage/phystokens.py +208 -0
- data/vendor/depot_tools/third_party/coverage/report.py +92 -0
- data/vendor/depot_tools/third_party/coverage/results.py +286 -0
- data/vendor/depot_tools/third_party/coverage/summary.py +86 -0
- data/vendor/depot_tools/third_party/coverage/templite.py +166 -0
- data/vendor/depot_tools/third_party/coverage/version.py +9 -0
- data/vendor/depot_tools/third_party/coverage/xmlreport.py +155 -0
- data/vendor/depot_tools/third_party/httplib2/LICENSE +1339 -0
- data/vendor/depot_tools/third_party/httplib2/README.chromium +15 -0
- data/vendor/depot_tools/third_party/httplib2/__init__.py +1780 -0
- data/vendor/depot_tools/third_party/httplib2/cacerts.txt +2196 -0
- data/vendor/depot_tools/third_party/httplib2/iri2uri.py +110 -0
- data/vendor/depot_tools/third_party/httplib2/socks.py +448 -0
- data/vendor/depot_tools/third_party/repo/COPYING +202 -0
- data/vendor/depot_tools/third_party/repo/README.chromium +4 -0
- data/vendor/depot_tools/third_party/repo/__init__.py +0 -0
- data/vendor/depot_tools/third_party/repo/progress.py +117 -0
- data/vendor/depot_tools/third_party/retry_decorator/LICENSE.google +30 -0
- data/vendor/depot_tools/third_party/retry_decorator/__init__.py +0 -0
- data/vendor/depot_tools/third_party/retry_decorator/decorators.py +45 -0
- data/vendor/depot_tools/third_party/schema/.editorconfig +15 -0
- data/vendor/depot_tools/third_party/schema/.gitignore +174 -0
- data/vendor/depot_tools/third_party/schema/.travis.yml +37 -0
- data/vendor/depot_tools/third_party/schema/LICENSE-MIT +19 -0
- data/vendor/depot_tools/third_party/schema/MANIFEST.in +1 -0
- data/vendor/depot_tools/third_party/schema/README.chromium +12 -0
- data/vendor/depot_tools/third_party/schema/README.rst +382 -0
- data/vendor/depot_tools/third_party/schema/__init__.py +1 -0
- data/vendor/depot_tools/third_party/schema/schema.py +338 -0
- data/vendor/depot_tools/third_party/schema/setup.cfg +5 -0
- data/vendor/depot_tools/third_party/schema/setup.py +30 -0
- data/vendor/depot_tools/third_party/schema/test_schema.py +556 -0
- data/vendor/depot_tools/third_party/schema/tox.ini +33 -0
- data/vendor/depot_tools/third_party/six/LICENSE.txt +18 -0
- data/vendor/depot_tools/third_party/six/README.chromium +10 -0
- data/vendor/depot_tools/third_party/six/__init__.py +762 -0
- data/vendor/depot_tools/update_depot_tools +138 -0
- data/vendor/depot_tools/update_depot_tools.bat +65 -0
- data/vendor/depot_tools/update_depot_tools_toggle.py +38 -0
- data/vendor/depot_tools/upload_metrics.py +26 -0
- data/vendor/depot_tools/upload_to_google_storage.py +306 -0
- data/vendor/depot_tools/vpython +42 -0
- data/vendor/depot_tools/vpython.bat +7 -0
- data/vendor/depot_tools/vpython3 +55 -0
- data/vendor/depot_tools/vpython3.bat +12 -0
- data/vendor/depot_tools/watchlists.py +141 -0
- data/vendor/depot_tools/weekly +54 -0
- data/vendor/depot_tools/win32imports.py +61 -0
- data/vendor/depot_tools/win_toolchain/OWNERS +2 -0
- data/vendor/depot_tools/win_toolchain/README.md +74 -0
- data/vendor/depot_tools/win_toolchain/get_toolchain_if_necessary.py +599 -0
- data/vendor/depot_tools/win_toolchain/package_from_installed.py +524 -0
- data/vendor/depot_tools/wtf +81 -0
- data/vendor/depot_tools/yapf +21 -0
- data/vendor/depot_tools/yapf.bat +12 -0
- data/vendor/depot_tools/zsh-goodies/README +6 -0
- data/vendor/depot_tools/zsh-goodies/_gclient +14 -0
- metadata +729 -0
@@ -0,0 +1,666 @@
|
|
1
|
+
"""Code parsing for Coverage."""
|
2
|
+
|
3
|
+
import dis, re, sys, token, tokenize
|
4
|
+
|
5
|
+
from coverage.backward import set, sorted, StringIO # pylint: disable=W0622
|
6
|
+
from coverage.backward import open_source, range # pylint: disable=W0622
|
7
|
+
from coverage.backward import reversed # pylint: disable=W0622
|
8
|
+
from coverage.backward import bytes_to_ints
|
9
|
+
from coverage.bytecode import ByteCodes, CodeObjects
|
10
|
+
from coverage.misc import nice_pair, expensive, join_regex
|
11
|
+
from coverage.misc import CoverageException, NoSource, NotPython
|
12
|
+
|
13
|
+
|
14
|
+
class CodeParser(object):
|
15
|
+
"""Parse code to find executable lines, excluded lines, etc."""
|
16
|
+
|
17
|
+
def __init__(self, text=None, filename=None, exclude=None):
|
18
|
+
"""
|
19
|
+
Source can be provided as `text`, the text itself, or `filename`, from
|
20
|
+
which the text will be read. Excluded lines are those that match
|
21
|
+
`exclude`, a regex.
|
22
|
+
|
23
|
+
"""
|
24
|
+
assert text or filename, "CodeParser needs either text or filename"
|
25
|
+
self.filename = filename or "<code>"
|
26
|
+
self.text = text
|
27
|
+
if not self.text:
|
28
|
+
try:
|
29
|
+
sourcef = open_source(self.filename)
|
30
|
+
try:
|
31
|
+
self.text = sourcef.read()
|
32
|
+
finally:
|
33
|
+
sourcef.close()
|
34
|
+
except IOError:
|
35
|
+
_, err, _ = sys.exc_info()
|
36
|
+
raise NoSource(
|
37
|
+
"No source for code: '%s': %s" % (self.filename, err)
|
38
|
+
)
|
39
|
+
|
40
|
+
# Scrap the BOM if it exists.
|
41
|
+
if self.text and ord(self.text[0]) == 0xfeff:
|
42
|
+
self.text = self.text[1:]
|
43
|
+
|
44
|
+
self.exclude = exclude
|
45
|
+
|
46
|
+
self.show_tokens = False
|
47
|
+
|
48
|
+
# The text lines of the parsed code.
|
49
|
+
self.lines = self.text.split('\n')
|
50
|
+
|
51
|
+
# The line numbers of excluded lines of code.
|
52
|
+
self.excluded = set()
|
53
|
+
|
54
|
+
# The line numbers of docstring lines.
|
55
|
+
self.docstrings = set()
|
56
|
+
|
57
|
+
# The line numbers of class definitions.
|
58
|
+
self.classdefs = set()
|
59
|
+
|
60
|
+
# A dict mapping line numbers to (lo,hi) for multi-line statements.
|
61
|
+
self.multiline = {}
|
62
|
+
|
63
|
+
# The line numbers that start statements.
|
64
|
+
self.statement_starts = set()
|
65
|
+
|
66
|
+
# Lazily-created ByteParser
|
67
|
+
self._byte_parser = None
|
68
|
+
|
69
|
+
def _get_byte_parser(self):
|
70
|
+
"""Create a ByteParser on demand."""
|
71
|
+
if not self._byte_parser:
|
72
|
+
self._byte_parser = \
|
73
|
+
ByteParser(text=self.text, filename=self.filename)
|
74
|
+
return self._byte_parser
|
75
|
+
byte_parser = property(_get_byte_parser)
|
76
|
+
|
77
|
+
def lines_matching(self, *regexes):
|
78
|
+
"""Find the lines matching one of a list of regexes.
|
79
|
+
|
80
|
+
Returns a set of line numbers, the lines that contain a match for one
|
81
|
+
of the regexes in `regexes`. The entire line needn't match, just a
|
82
|
+
part of it.
|
83
|
+
|
84
|
+
"""
|
85
|
+
regex_c = re.compile(join_regex(regexes))
|
86
|
+
matches = set()
|
87
|
+
for i, ltext in enumerate(self.lines):
|
88
|
+
if regex_c.search(ltext):
|
89
|
+
matches.add(i+1)
|
90
|
+
return matches
|
91
|
+
|
92
|
+
def _raw_parse(self):
|
93
|
+
"""Parse the source to find the interesting facts about its lines.
|
94
|
+
|
95
|
+
A handful of member fields are updated.
|
96
|
+
|
97
|
+
"""
|
98
|
+
# Find lines which match an exclusion pattern.
|
99
|
+
if self.exclude:
|
100
|
+
self.excluded = self.lines_matching(self.exclude)
|
101
|
+
|
102
|
+
# Tokenize, to find excluded suites, to find docstrings, and to find
|
103
|
+
# multi-line statements.
|
104
|
+
indent = 0
|
105
|
+
exclude_indent = 0
|
106
|
+
excluding = False
|
107
|
+
prev_toktype = token.INDENT
|
108
|
+
first_line = None
|
109
|
+
empty = True
|
110
|
+
|
111
|
+
tokgen = tokenize.generate_tokens(StringIO(self.text).readline)
|
112
|
+
for toktype, ttext, (slineno, _), (elineno, _), ltext in tokgen:
|
113
|
+
if self.show_tokens: # pragma: not covered
|
114
|
+
print("%10s %5s %-20r %r" % (
|
115
|
+
tokenize.tok_name.get(toktype, toktype),
|
116
|
+
nice_pair((slineno, elineno)), ttext, ltext
|
117
|
+
))
|
118
|
+
if toktype == token.INDENT:
|
119
|
+
indent += 1
|
120
|
+
elif toktype == token.DEDENT:
|
121
|
+
indent -= 1
|
122
|
+
elif toktype == token.NAME and ttext == 'class':
|
123
|
+
# Class definitions look like branches in the byte code, so
|
124
|
+
# we need to exclude them. The simplest way is to note the
|
125
|
+
# lines with the 'class' keyword.
|
126
|
+
self.classdefs.add(slineno)
|
127
|
+
elif toktype == token.OP and ttext == ':':
|
128
|
+
if not excluding and elineno in self.excluded:
|
129
|
+
# Start excluding a suite. We trigger off of the colon
|
130
|
+
# token so that the #pragma comment will be recognized on
|
131
|
+
# the same line as the colon.
|
132
|
+
exclude_indent = indent
|
133
|
+
excluding = True
|
134
|
+
elif toktype == token.STRING and prev_toktype == token.INDENT:
|
135
|
+
# Strings that are first on an indented line are docstrings.
|
136
|
+
# (a trick from trace.py in the stdlib.) This works for
|
137
|
+
# 99.9999% of cases. For the rest (!) see:
|
138
|
+
# http://stackoverflow.com/questions/1769332/x/1769794#1769794
|
139
|
+
self.docstrings.update(range(slineno, elineno+1))
|
140
|
+
elif toktype == token.NEWLINE:
|
141
|
+
if first_line is not None and elineno != first_line:
|
142
|
+
# We're at the end of a line, and we've ended on a
|
143
|
+
# different line than the first line of the statement,
|
144
|
+
# so record a multi-line range.
|
145
|
+
rng = (first_line, elineno)
|
146
|
+
for l in range(first_line, elineno+1):
|
147
|
+
self.multiline[l] = rng
|
148
|
+
first_line = None
|
149
|
+
|
150
|
+
if ttext.strip() and toktype != tokenize.COMMENT:
|
151
|
+
# A non-whitespace token.
|
152
|
+
empty = False
|
153
|
+
if first_line is None:
|
154
|
+
# The token is not whitespace, and is the first in a
|
155
|
+
# statement.
|
156
|
+
first_line = slineno
|
157
|
+
# Check whether to end an excluded suite.
|
158
|
+
if excluding and indent <= exclude_indent:
|
159
|
+
excluding = False
|
160
|
+
if excluding:
|
161
|
+
self.excluded.add(elineno)
|
162
|
+
|
163
|
+
prev_toktype = toktype
|
164
|
+
|
165
|
+
# Find the starts of the executable statements.
|
166
|
+
if not empty:
|
167
|
+
self.statement_starts.update(self.byte_parser._find_statements())
|
168
|
+
|
169
|
+
def first_line(self, line):
|
170
|
+
"""Return the first line number of the statement including `line`."""
|
171
|
+
rng = self.multiline.get(line)
|
172
|
+
if rng:
|
173
|
+
first_line = rng[0]
|
174
|
+
else:
|
175
|
+
first_line = line
|
176
|
+
return first_line
|
177
|
+
|
178
|
+
def first_lines(self, lines, ignore=None):
|
179
|
+
"""Map the line numbers in `lines` to the correct first line of the
|
180
|
+
statement.
|
181
|
+
|
182
|
+
Skip any line mentioned in `ignore`.
|
183
|
+
|
184
|
+
Returns a sorted list of the first lines.
|
185
|
+
|
186
|
+
"""
|
187
|
+
ignore = ignore or []
|
188
|
+
lset = set()
|
189
|
+
for l in lines:
|
190
|
+
if l in ignore:
|
191
|
+
continue
|
192
|
+
new_l = self.first_line(l)
|
193
|
+
if new_l not in ignore:
|
194
|
+
lset.add(new_l)
|
195
|
+
return sorted(lset)
|
196
|
+
|
197
|
+
def parse_source(self):
|
198
|
+
"""Parse source text to find executable lines, excluded lines, etc.
|
199
|
+
|
200
|
+
Return values are 1) a sorted list of executable line numbers, and
|
201
|
+
2) a sorted list of excluded line numbers.
|
202
|
+
|
203
|
+
Reported line numbers are normalized to the first line of multi-line
|
204
|
+
statements.
|
205
|
+
|
206
|
+
"""
|
207
|
+
try:
|
208
|
+
self._raw_parse()
|
209
|
+
except (tokenize.TokenError, IndentationError):
|
210
|
+
_, tokerr, _ = sys.exc_info()
|
211
|
+
msg, lineno = tokerr.args
|
212
|
+
raise NotPython(
|
213
|
+
"Couldn't parse '%s' as Python source: '%s' at %s" %
|
214
|
+
(self.filename, msg, lineno)
|
215
|
+
)
|
216
|
+
|
217
|
+
excluded_lines = self.first_lines(self.excluded)
|
218
|
+
ignore = excluded_lines + list(self.docstrings)
|
219
|
+
lines = self.first_lines(self.statement_starts, ignore)
|
220
|
+
|
221
|
+
return lines, excluded_lines
|
222
|
+
|
223
|
+
def arcs(self):
|
224
|
+
"""Get information about the arcs available in the code.
|
225
|
+
|
226
|
+
Returns a sorted list of line number pairs. Line numbers have been
|
227
|
+
normalized to the first line of multiline statements.
|
228
|
+
|
229
|
+
"""
|
230
|
+
all_arcs = []
|
231
|
+
for l1, l2 in self.byte_parser._all_arcs():
|
232
|
+
fl1 = self.first_line(l1)
|
233
|
+
fl2 = self.first_line(l2)
|
234
|
+
if fl1 != fl2:
|
235
|
+
all_arcs.append((fl1, fl2))
|
236
|
+
return sorted(all_arcs)
|
237
|
+
arcs = expensive(arcs)
|
238
|
+
|
239
|
+
def exit_counts(self):
|
240
|
+
"""Get a mapping from line numbers to count of exits from that line.
|
241
|
+
|
242
|
+
Excluded lines are excluded.
|
243
|
+
|
244
|
+
"""
|
245
|
+
excluded_lines = self.first_lines(self.excluded)
|
246
|
+
exit_counts = {}
|
247
|
+
for l1, l2 in self.arcs():
|
248
|
+
if l1 < 0:
|
249
|
+
# Don't ever report -1 as a line number
|
250
|
+
continue
|
251
|
+
if l1 in excluded_lines:
|
252
|
+
# Don't report excluded lines as line numbers.
|
253
|
+
continue
|
254
|
+
if l2 in excluded_lines:
|
255
|
+
# Arcs to excluded lines shouldn't count.
|
256
|
+
continue
|
257
|
+
if l1 not in exit_counts:
|
258
|
+
exit_counts[l1] = 0
|
259
|
+
exit_counts[l1] += 1
|
260
|
+
|
261
|
+
# Class definitions have one extra exit, so remove one for each:
|
262
|
+
for l in self.classdefs:
|
263
|
+
# Ensure key is there: classdefs can include excluded lines.
|
264
|
+
if l in exit_counts:
|
265
|
+
exit_counts[l] -= 1
|
266
|
+
|
267
|
+
return exit_counts
|
268
|
+
exit_counts = expensive(exit_counts)
|
269
|
+
|
270
|
+
|
271
|
+
## Opcodes that guide the ByteParser.
|
272
|
+
|
273
|
+
def _opcode(name):
|
274
|
+
"""Return the opcode by name from the dis module."""
|
275
|
+
return dis.opmap[name]
|
276
|
+
|
277
|
+
def _opcode_set(*names):
|
278
|
+
"""Return a set of opcodes by the names in `names`."""
|
279
|
+
s = set()
|
280
|
+
for name in names:
|
281
|
+
try:
|
282
|
+
s.add(_opcode(name))
|
283
|
+
except KeyError:
|
284
|
+
pass
|
285
|
+
return s
|
286
|
+
|
287
|
+
# Opcodes that leave the code object.
|
288
|
+
OPS_CODE_END = _opcode_set('RETURN_VALUE')
|
289
|
+
|
290
|
+
# Opcodes that unconditionally end the code chunk.
|
291
|
+
OPS_CHUNK_END = _opcode_set(
|
292
|
+
'JUMP_ABSOLUTE', 'JUMP_FORWARD', 'RETURN_VALUE', 'RAISE_VARARGS',
|
293
|
+
'BREAK_LOOP', 'CONTINUE_LOOP',
|
294
|
+
)
|
295
|
+
|
296
|
+
# Opcodes that unconditionally begin a new code chunk. By starting new chunks
|
297
|
+
# with unconditional jump instructions, we neatly deal with jumps to jumps
|
298
|
+
# properly.
|
299
|
+
OPS_CHUNK_BEGIN = _opcode_set('JUMP_ABSOLUTE', 'JUMP_FORWARD')
|
300
|
+
|
301
|
+
# Opcodes that push a block on the block stack.
|
302
|
+
OPS_PUSH_BLOCK = _opcode_set(
|
303
|
+
'SETUP_LOOP', 'SETUP_EXCEPT', 'SETUP_FINALLY', 'SETUP_WITH'
|
304
|
+
)
|
305
|
+
|
306
|
+
# Block types for exception handling.
|
307
|
+
OPS_EXCEPT_BLOCKS = _opcode_set('SETUP_EXCEPT', 'SETUP_FINALLY')
|
308
|
+
|
309
|
+
# Opcodes that pop a block from the block stack.
|
310
|
+
OPS_POP_BLOCK = _opcode_set('POP_BLOCK')
|
311
|
+
|
312
|
+
# Opcodes that have a jump destination, but aren't really a jump.
|
313
|
+
OPS_NO_JUMP = OPS_PUSH_BLOCK
|
314
|
+
|
315
|
+
# Individual opcodes we need below.
|
316
|
+
OP_BREAK_LOOP = _opcode('BREAK_LOOP')
|
317
|
+
OP_END_FINALLY = _opcode('END_FINALLY')
|
318
|
+
OP_COMPARE_OP = _opcode('COMPARE_OP')
|
319
|
+
COMPARE_EXCEPTION = 10 # just have to get this const from the code.
|
320
|
+
OP_LOAD_CONST = _opcode('LOAD_CONST')
|
321
|
+
OP_RETURN_VALUE = _opcode('RETURN_VALUE')
|
322
|
+
|
323
|
+
|
324
|
+
class ByteParser(object):
|
325
|
+
"""Parse byte codes to understand the structure of code."""
|
326
|
+
|
327
|
+
def __init__(self, code=None, text=None, filename=None):
|
328
|
+
if code:
|
329
|
+
self.code = code
|
330
|
+
self.text = text
|
331
|
+
else:
|
332
|
+
if not text:
|
333
|
+
assert filename, "If no code or text, need a filename"
|
334
|
+
sourcef = open_source(filename)
|
335
|
+
try:
|
336
|
+
text = sourcef.read()
|
337
|
+
finally:
|
338
|
+
sourcef.close()
|
339
|
+
self.text = text
|
340
|
+
|
341
|
+
try:
|
342
|
+
# Python 2.3 and 2.4 don't like partial last lines, so be sure
|
343
|
+
# the text ends nicely for them.
|
344
|
+
self.code = compile(text + '\n', filename, "exec")
|
345
|
+
except SyntaxError:
|
346
|
+
_, synerr, _ = sys.exc_info()
|
347
|
+
raise NotPython(
|
348
|
+
"Couldn't parse '%s' as Python source: '%s' at line %d" %
|
349
|
+
(filename, synerr.msg, synerr.lineno)
|
350
|
+
)
|
351
|
+
|
352
|
+
# Alternative Python implementations don't always provide all the
|
353
|
+
# attributes on code objects that we need to do the analysis.
|
354
|
+
for attr in ['co_lnotab', 'co_firstlineno', 'co_consts', 'co_code']:
|
355
|
+
if not hasattr(self.code, attr):
|
356
|
+
raise CoverageException(
|
357
|
+
"This implementation of Python doesn't support code "
|
358
|
+
"analysis.\n"
|
359
|
+
"Run coverage.py under CPython for this command."
|
360
|
+
)
|
361
|
+
|
362
|
+
def child_parsers(self):
|
363
|
+
"""Iterate over all the code objects nested within this one.
|
364
|
+
|
365
|
+
The iteration includes `self` as its first value.
|
366
|
+
|
367
|
+
"""
|
368
|
+
children = CodeObjects(self.code)
|
369
|
+
return [ByteParser(code=c, text=self.text) for c in children]
|
370
|
+
|
371
|
+
def _bytes_lines(self):
|
372
|
+
"""Map byte offsets to line numbers in `code`.
|
373
|
+
|
374
|
+
Uses co_lnotab described in Python/compile.c to map byte offsets to
|
375
|
+
line numbers. Produces a sequence: (b0, l0), (b1, l1), ...
|
376
|
+
|
377
|
+
Only byte offsets that correspond to line numbers are included in the
|
378
|
+
results.
|
379
|
+
|
380
|
+
"""
|
381
|
+
# Adapted from dis.py in the standard library.
|
382
|
+
byte_increments = bytes_to_ints(self.code.co_lnotab[0::2])
|
383
|
+
line_increments = bytes_to_ints(self.code.co_lnotab[1::2])
|
384
|
+
|
385
|
+
last_line_num = None
|
386
|
+
line_num = self.code.co_firstlineno
|
387
|
+
byte_num = 0
|
388
|
+
for byte_incr, line_incr in zip(byte_increments, line_increments):
|
389
|
+
if byte_incr:
|
390
|
+
if line_num != last_line_num:
|
391
|
+
yield (byte_num, line_num)
|
392
|
+
last_line_num = line_num
|
393
|
+
byte_num += byte_incr
|
394
|
+
line_num += line_incr
|
395
|
+
if line_num != last_line_num:
|
396
|
+
yield (byte_num, line_num)
|
397
|
+
|
398
|
+
def _find_statements(self):
|
399
|
+
"""Find the statements in `self.code`.
|
400
|
+
|
401
|
+
Produce a sequence of line numbers that start statements. Recurses
|
402
|
+
into all code objects reachable from `self.code`.
|
403
|
+
|
404
|
+
"""
|
405
|
+
for bp in self.child_parsers():
|
406
|
+
# Get all of the lineno information from this code.
|
407
|
+
for _, l in bp._bytes_lines():
|
408
|
+
yield l
|
409
|
+
|
410
|
+
def _block_stack_repr(self, block_stack):
|
411
|
+
"""Get a string version of `block_stack`, for debugging."""
|
412
|
+
blocks = ", ".join(
|
413
|
+
["(%s, %r)" % (dis.opname[b[0]], b[1]) for b in block_stack]
|
414
|
+
)
|
415
|
+
return "[" + blocks + "]"
|
416
|
+
|
417
|
+
def _split_into_chunks(self):
|
418
|
+
"""Split the code object into a list of `Chunk` objects.
|
419
|
+
|
420
|
+
Each chunk is only entered at its first instruction, though there can
|
421
|
+
be many exits from a chunk.
|
422
|
+
|
423
|
+
Returns a list of `Chunk` objects.
|
424
|
+
|
425
|
+
"""
|
426
|
+
# The list of chunks so far, and the one we're working on.
|
427
|
+
chunks = []
|
428
|
+
chunk = None
|
429
|
+
|
430
|
+
# A dict mapping byte offsets of line starts to the line numbers.
|
431
|
+
bytes_lines_map = dict(self._bytes_lines())
|
432
|
+
|
433
|
+
# The block stack: loops and try blocks get pushed here for the
|
434
|
+
# implicit jumps that can occur.
|
435
|
+
# Each entry is a tuple: (block type, destination)
|
436
|
+
block_stack = []
|
437
|
+
|
438
|
+
# Some op codes are followed by branches that should be ignored. This
|
439
|
+
# is a count of how many ignores are left.
|
440
|
+
ignore_branch = 0
|
441
|
+
|
442
|
+
# We have to handle the last two bytecodes specially.
|
443
|
+
ult = penult = None
|
444
|
+
|
445
|
+
# Get a set of all of the jump-to points.
|
446
|
+
jump_to = set()
|
447
|
+
for bc in ByteCodes(self.code.co_code):
|
448
|
+
if bc.jump_to >= 0:
|
449
|
+
jump_to.add(bc.jump_to)
|
450
|
+
|
451
|
+
chunk_lineno = 0
|
452
|
+
|
453
|
+
# Walk the byte codes building chunks.
|
454
|
+
for bc in ByteCodes(self.code.co_code):
|
455
|
+
# Maybe have to start a new chunk
|
456
|
+
start_new_chunk = False
|
457
|
+
first_chunk = False
|
458
|
+
if bc.offset in bytes_lines_map:
|
459
|
+
# Start a new chunk for each source line number.
|
460
|
+
start_new_chunk = True
|
461
|
+
chunk_lineno = bytes_lines_map[bc.offset]
|
462
|
+
first_chunk = True
|
463
|
+
elif bc.offset in jump_to:
|
464
|
+
# To make chunks have a single entrance, we have to make a new
|
465
|
+
# chunk when we get to a place some bytecode jumps to.
|
466
|
+
start_new_chunk = True
|
467
|
+
elif bc.op in OPS_CHUNK_BEGIN:
|
468
|
+
# Jumps deserve their own unnumbered chunk. This fixes
|
469
|
+
# problems with jumps to jumps getting confused.
|
470
|
+
start_new_chunk = True
|
471
|
+
|
472
|
+
if not chunk or start_new_chunk:
|
473
|
+
if chunk:
|
474
|
+
chunk.exits.add(bc.offset)
|
475
|
+
chunk = Chunk(bc.offset, chunk_lineno, first_chunk)
|
476
|
+
chunks.append(chunk)
|
477
|
+
|
478
|
+
# Look at the opcode
|
479
|
+
if bc.jump_to >= 0 and bc.op not in OPS_NO_JUMP:
|
480
|
+
if ignore_branch:
|
481
|
+
# Someone earlier wanted us to ignore this branch.
|
482
|
+
ignore_branch -= 1
|
483
|
+
else:
|
484
|
+
# The opcode has a jump, it's an exit for this chunk.
|
485
|
+
chunk.exits.add(bc.jump_to)
|
486
|
+
|
487
|
+
if bc.op in OPS_CODE_END:
|
488
|
+
# The opcode can exit the code object.
|
489
|
+
chunk.exits.add(-self.code.co_firstlineno)
|
490
|
+
if bc.op in OPS_PUSH_BLOCK:
|
491
|
+
# The opcode adds a block to the block_stack.
|
492
|
+
block_stack.append((bc.op, bc.jump_to))
|
493
|
+
if bc.op in OPS_POP_BLOCK:
|
494
|
+
# The opcode pops a block from the block stack.
|
495
|
+
block_stack.pop()
|
496
|
+
if bc.op in OPS_CHUNK_END:
|
497
|
+
# This opcode forces the end of the chunk.
|
498
|
+
if bc.op == OP_BREAK_LOOP:
|
499
|
+
# A break is implicit: jump where the top of the
|
500
|
+
# block_stack points.
|
501
|
+
chunk.exits.add(block_stack[-1][1])
|
502
|
+
chunk = None
|
503
|
+
if bc.op == OP_END_FINALLY:
|
504
|
+
# For the finally clause we need to find the closest exception
|
505
|
+
# block, and use its jump target as an exit.
|
506
|
+
for block in reversed(block_stack):
|
507
|
+
if block[0] in OPS_EXCEPT_BLOCKS:
|
508
|
+
chunk.exits.add(block[1])
|
509
|
+
break
|
510
|
+
if bc.op == OP_COMPARE_OP and bc.arg == COMPARE_EXCEPTION:
|
511
|
+
# This is an except clause. We want to overlook the next
|
512
|
+
# branch, so that except's don't count as branches.
|
513
|
+
ignore_branch += 1
|
514
|
+
|
515
|
+
penult = ult
|
516
|
+
ult = bc
|
517
|
+
|
518
|
+
if chunks:
|
519
|
+
# The last two bytecodes could be a dummy "return None" that
|
520
|
+
# shouldn't be counted as real code. Every Python code object seems
|
521
|
+
# to end with a return, and a "return None" is inserted if there
|
522
|
+
# isn't an explicit return in the source.
|
523
|
+
if ult and penult:
|
524
|
+
if penult.op == OP_LOAD_CONST and ult.op == OP_RETURN_VALUE:
|
525
|
+
if self.code.co_consts[penult.arg] is None:
|
526
|
+
# This is "return None", but is it dummy? A real line
|
527
|
+
# would be a last chunk all by itself.
|
528
|
+
if chunks[-1].byte != penult.offset:
|
529
|
+
ex = -self.code.co_firstlineno
|
530
|
+
# Split the last chunk
|
531
|
+
last_chunk = chunks[-1]
|
532
|
+
last_chunk.exits.remove(ex)
|
533
|
+
last_chunk.exits.add(penult.offset)
|
534
|
+
chunk = Chunk(
|
535
|
+
penult.offset, last_chunk.line, False
|
536
|
+
)
|
537
|
+
chunk.exits.add(ex)
|
538
|
+
chunks.append(chunk)
|
539
|
+
|
540
|
+
# Give all the chunks a length.
|
541
|
+
chunks[-1].length = bc.next_offset - chunks[-1].byte # pylint: disable=W0631,C0301
|
542
|
+
for i in range(len(chunks)-1):
|
543
|
+
chunks[i].length = chunks[i+1].byte - chunks[i].byte
|
544
|
+
|
545
|
+
#self.validate_chunks(chunks)
|
546
|
+
return chunks
|
547
|
+
|
548
|
+
def validate_chunks(self, chunks):
|
549
|
+
"""Validate the rule that chunks have a single entrance."""
|
550
|
+
# starts is the entrances to the chunks
|
551
|
+
starts = set([ch.byte for ch in chunks])
|
552
|
+
for ch in chunks:
|
553
|
+
assert all([(ex in starts or ex < 0) for ex in ch.exits])
|
554
|
+
|
555
|
+
def _arcs(self):
|
556
|
+
"""Find the executable arcs in the code.
|
557
|
+
|
558
|
+
Yields pairs: (from,to). From and to are integer line numbers. If
|
559
|
+
from is < 0, then the arc is an entrance into the code object. If to
|
560
|
+
is < 0, the arc is an exit from the code object.
|
561
|
+
|
562
|
+
"""
|
563
|
+
chunks = self._split_into_chunks()
|
564
|
+
|
565
|
+
# A map from byte offsets to chunks jumped into.
|
566
|
+
byte_chunks = dict([(c.byte, c) for c in chunks])
|
567
|
+
|
568
|
+
# There's always an entrance at the first chunk.
|
569
|
+
yield (-1, byte_chunks[0].line)
|
570
|
+
|
571
|
+
# Traverse from the first chunk in each line, and yield arcs where
|
572
|
+
# the trace function will be invoked.
|
573
|
+
for chunk in chunks:
|
574
|
+
if not chunk.first:
|
575
|
+
continue
|
576
|
+
|
577
|
+
chunks_considered = set()
|
578
|
+
chunks_to_consider = [chunk]
|
579
|
+
while chunks_to_consider:
|
580
|
+
# Get the chunk we're considering, and make sure we don't
|
581
|
+
# consider it again
|
582
|
+
this_chunk = chunks_to_consider.pop()
|
583
|
+
chunks_considered.add(this_chunk)
|
584
|
+
|
585
|
+
# For each exit, add the line number if the trace function
|
586
|
+
# would be triggered, or add the chunk to those being
|
587
|
+
# considered if not.
|
588
|
+
for ex in this_chunk.exits:
|
589
|
+
if ex < 0:
|
590
|
+
yield (chunk.line, ex)
|
591
|
+
else:
|
592
|
+
next_chunk = byte_chunks[ex]
|
593
|
+
if next_chunk in chunks_considered:
|
594
|
+
continue
|
595
|
+
|
596
|
+
# The trace function is invoked if visiting the first
|
597
|
+
# bytecode in a line, or if the transition is a
|
598
|
+
# backward jump.
|
599
|
+
backward_jump = next_chunk.byte < this_chunk.byte
|
600
|
+
if next_chunk.first or backward_jump:
|
601
|
+
if next_chunk.line != chunk.line:
|
602
|
+
yield (chunk.line, next_chunk.line)
|
603
|
+
else:
|
604
|
+
chunks_to_consider.append(next_chunk)
|
605
|
+
|
606
|
+
def _all_chunks(self):
|
607
|
+
"""Returns a list of `Chunk` objects for this code and its children.
|
608
|
+
|
609
|
+
See `_split_into_chunks` for details.
|
610
|
+
|
611
|
+
"""
|
612
|
+
chunks = []
|
613
|
+
for bp in self.child_parsers():
|
614
|
+
chunks.extend(bp._split_into_chunks())
|
615
|
+
|
616
|
+
return chunks
|
617
|
+
|
618
|
+
def _all_arcs(self):
|
619
|
+
"""Get the set of all arcs in this code object and its children.
|
620
|
+
|
621
|
+
See `_arcs` for details.
|
622
|
+
|
623
|
+
"""
|
624
|
+
arcs = set()
|
625
|
+
for bp in self.child_parsers():
|
626
|
+
arcs.update(bp._arcs())
|
627
|
+
|
628
|
+
return arcs
|
629
|
+
|
630
|
+
|
631
|
+
class Chunk(object):
|
632
|
+
"""A sequence of byte codes with a single entrance.
|
633
|
+
|
634
|
+
To analyze byte code, we have to divide it into chunks, sequences of byte
|
635
|
+
codes such that each chunk has only one entrance, the first instruction in
|
636
|
+
the block.
|
637
|
+
|
638
|
+
This is almost the CS concept of `basic block`_, except that we're willing
|
639
|
+
to have many exits from a chunk, and "basic block" is a more cumbersome
|
640
|
+
term.
|
641
|
+
|
642
|
+
.. _basic block: http://en.wikipedia.org/wiki/Basic_block
|
643
|
+
|
644
|
+
`line` is the source line number containing this chunk.
|
645
|
+
|
646
|
+
`first` is true if this is the first chunk in the source line.
|
647
|
+
|
648
|
+
An exit < 0 means the chunk can leave the code (return). The exit is
|
649
|
+
the negative of the starting line number of the code block.
|
650
|
+
|
651
|
+
"""
|
652
|
+
def __init__(self, byte, line, first):
|
653
|
+
self.byte = byte
|
654
|
+
self.line = line
|
655
|
+
self.first = first
|
656
|
+
self.length = 0
|
657
|
+
self.exits = set()
|
658
|
+
|
659
|
+
def __repr__(self):
|
660
|
+
if self.first:
|
661
|
+
bang = "!"
|
662
|
+
else:
|
663
|
+
bang = ""
|
664
|
+
return "<%d+%d @%d%s %r>" % (
|
665
|
+
self.byte, self.length, self.line, bang, list(self.exits)
|
666
|
+
)
|