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
@@ -1,277 +0,0 @@
|
|
1
|
-
# copyright 2003-2011 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
|
2
|
-
# contact http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
3
|
-
#
|
4
|
-
# This file is part of logilab-common.
|
5
|
-
#
|
6
|
-
# logilab-common is free software: you can redistribute it and/or modify it under
|
7
|
-
# the terms of the GNU Lesser General Public License as published by the Free
|
8
|
-
# Software Foundation, either version 2.1 of the License, or (at your option) any
|
9
|
-
# later version.
|
10
|
-
#
|
11
|
-
# logilab-common is distributed in the hope that it will be useful, but WITHOUT
|
12
|
-
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
13
|
-
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
|
14
|
-
# details.
|
15
|
-
#
|
16
|
-
# You should have received a copy of the GNU Lesser General Public License along
|
17
|
-
# with logilab-common. If not, see <http://www.gnu.org/licenses/>.
|
18
|
-
"""module providing:
|
19
|
-
* process information (linux specific: rely on /proc)
|
20
|
-
* a class for resource control (memory / time / cpu time)
|
21
|
-
|
22
|
-
This module doesn't work on windows platforms (only tested on linux)
|
23
|
-
|
24
|
-
:organization: Logilab
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
"""
|
29
|
-
__docformat__ = "restructuredtext en"
|
30
|
-
|
31
|
-
import os
|
32
|
-
import stat
|
33
|
-
from resource import getrlimit, setrlimit, RLIMIT_CPU, RLIMIT_AS
|
34
|
-
from signal import signal, SIGXCPU, SIGKILL, SIGUSR2, SIGUSR1
|
35
|
-
from threading import Timer, currentThread, Thread, Event
|
36
|
-
from time import time
|
37
|
-
|
38
|
-
from logilab.common.tree import Node
|
39
|
-
|
40
|
-
class NoSuchProcess(Exception): pass
|
41
|
-
|
42
|
-
def proc_exists(pid):
|
43
|
-
"""check the a pid is registered in /proc
|
44
|
-
raise NoSuchProcess exception if not
|
45
|
-
"""
|
46
|
-
if not os.path.exists('/proc/%s' % pid):
|
47
|
-
raise NoSuchProcess()
|
48
|
-
|
49
|
-
PPID = 3
|
50
|
-
UTIME = 13
|
51
|
-
STIME = 14
|
52
|
-
CUTIME = 15
|
53
|
-
CSTIME = 16
|
54
|
-
VSIZE = 22
|
55
|
-
|
56
|
-
class ProcInfo(Node):
|
57
|
-
"""provide access to process information found in /proc"""
|
58
|
-
|
59
|
-
def __init__(self, pid):
|
60
|
-
self.pid = int(pid)
|
61
|
-
Node.__init__(self, self.pid)
|
62
|
-
proc_exists(self.pid)
|
63
|
-
self.file = '/proc/%s/stat' % self.pid
|
64
|
-
self.ppid = int(self.status()[PPID])
|
65
|
-
|
66
|
-
def memory_usage(self):
|
67
|
-
"""return the memory usage of the process in Ko"""
|
68
|
-
try :
|
69
|
-
return int(self.status()[VSIZE])
|
70
|
-
except IOError:
|
71
|
-
return 0
|
72
|
-
|
73
|
-
def lineage_memory_usage(self):
|
74
|
-
return self.memory_usage() + sum([child.lineage_memory_usage()
|
75
|
-
for child in self.children])
|
76
|
-
|
77
|
-
def time(self, children=0):
|
78
|
-
"""return the number of jiffies that this process has been scheduled
|
79
|
-
in user and kernel mode"""
|
80
|
-
status = self.status()
|
81
|
-
time = int(status[UTIME]) + int(status[STIME])
|
82
|
-
if children:
|
83
|
-
time += int(status[CUTIME]) + int(status[CSTIME])
|
84
|
-
return time
|
85
|
-
|
86
|
-
def status(self):
|
87
|
-
"""return the list of fields found in /proc/<pid>/stat"""
|
88
|
-
return open(self.file).read().split()
|
89
|
-
|
90
|
-
def name(self):
|
91
|
-
"""return the process name found in /proc/<pid>/stat
|
92
|
-
"""
|
93
|
-
return self.status()[1].strip('()')
|
94
|
-
|
95
|
-
def age(self):
|
96
|
-
"""return the age of the process
|
97
|
-
"""
|
98
|
-
return os.stat(self.file)[stat.ST_MTIME]
|
99
|
-
|
100
|
-
class ProcInfoLoader:
|
101
|
-
"""manage process information"""
|
102
|
-
|
103
|
-
def __init__(self):
|
104
|
-
self._loaded = {}
|
105
|
-
|
106
|
-
def list_pids(self):
|
107
|
-
"""return a list of existent process ids"""
|
108
|
-
for subdir in os.listdir('/proc'):
|
109
|
-
if subdir.isdigit():
|
110
|
-
yield int(subdir)
|
111
|
-
|
112
|
-
def load(self, pid):
|
113
|
-
"""get a ProcInfo object for a given pid"""
|
114
|
-
pid = int(pid)
|
115
|
-
try:
|
116
|
-
return self._loaded[pid]
|
117
|
-
except KeyError:
|
118
|
-
procinfo = ProcInfo(pid)
|
119
|
-
procinfo.manager = self
|
120
|
-
self._loaded[pid] = procinfo
|
121
|
-
return procinfo
|
122
|
-
|
123
|
-
|
124
|
-
def load_all(self):
|
125
|
-
"""load all processes information"""
|
126
|
-
for pid in self.list_pids():
|
127
|
-
try:
|
128
|
-
procinfo = self.load(pid)
|
129
|
-
if procinfo.parent is None and procinfo.ppid:
|
130
|
-
pprocinfo = self.load(procinfo.ppid)
|
131
|
-
pprocinfo.append(procinfo)
|
132
|
-
except NoSuchProcess:
|
133
|
-
pass
|
134
|
-
|
135
|
-
|
136
|
-
try:
|
137
|
-
class ResourceError(BaseException):
|
138
|
-
"""Error raise when resource limit is reached"""
|
139
|
-
limit = "Unknown Resource Limit"
|
140
|
-
except NameError:
|
141
|
-
class ResourceError(Exception):
|
142
|
-
"""Error raise when resource limit is reached"""
|
143
|
-
limit = "Unknown Resource Limit"
|
144
|
-
|
145
|
-
|
146
|
-
class XCPUError(ResourceError):
|
147
|
-
"""Error raised when CPU Time limit is reached"""
|
148
|
-
limit = "CPU Time"
|
149
|
-
|
150
|
-
class LineageMemoryError(ResourceError):
|
151
|
-
"""Error raised when the total amount of memory used by a process and
|
152
|
-
it's child is reached"""
|
153
|
-
limit = "Lineage total Memory"
|
154
|
-
|
155
|
-
class TimeoutError(ResourceError):
|
156
|
-
"""Error raised when the process is running for to much time"""
|
157
|
-
limit = "Real Time"
|
158
|
-
|
159
|
-
# Can't use subclass because the StandardError MemoryError raised
|
160
|
-
RESOURCE_LIMIT_EXCEPTION = (ResourceError, MemoryError)
|
161
|
-
|
162
|
-
|
163
|
-
class MemorySentinel(Thread):
|
164
|
-
"""A class checking a process don't use too much memory in a separated
|
165
|
-
daemonic thread
|
166
|
-
"""
|
167
|
-
def __init__(self, interval, memory_limit, gpid=os.getpid()):
|
168
|
-
Thread.__init__(self, target=self._run, name="Test.Sentinel")
|
169
|
-
self.memory_limit = memory_limit
|
170
|
-
self._stop = Event()
|
171
|
-
self.interval = interval
|
172
|
-
self.setDaemon(True)
|
173
|
-
self.gpid = gpid
|
174
|
-
|
175
|
-
def stop(self):
|
176
|
-
"""stop ap"""
|
177
|
-
self._stop.set()
|
178
|
-
|
179
|
-
def _run(self):
|
180
|
-
pil = ProcInfoLoader()
|
181
|
-
while not self._stop.isSet():
|
182
|
-
if self.memory_limit <= pil.load(self.gpid).lineage_memory_usage():
|
183
|
-
os.killpg(self.gpid, SIGUSR1)
|
184
|
-
self._stop.wait(self.interval)
|
185
|
-
|
186
|
-
|
187
|
-
class ResourceController:
|
188
|
-
|
189
|
-
def __init__(self, max_cpu_time=None, max_time=None, max_memory=None,
|
190
|
-
max_reprieve=60):
|
191
|
-
if SIGXCPU == -1:
|
192
|
-
raise RuntimeError("Unsupported platform")
|
193
|
-
self.max_time = max_time
|
194
|
-
self.max_memory = max_memory
|
195
|
-
self.max_cpu_time = max_cpu_time
|
196
|
-
self._reprieve = max_reprieve
|
197
|
-
self._timer = None
|
198
|
-
self._msentinel = None
|
199
|
-
self._old_max_memory = None
|
200
|
-
self._old_usr1_hdlr = None
|
201
|
-
self._old_max_cpu_time = None
|
202
|
-
self._old_usr2_hdlr = None
|
203
|
-
self._old_sigxcpu_hdlr = None
|
204
|
-
self._limit_set = 0
|
205
|
-
self._abort_try = 0
|
206
|
-
self._start_time = None
|
207
|
-
self._elapse_time = 0
|
208
|
-
|
209
|
-
def _hangle_sig_timeout(self, sig, frame):
|
210
|
-
raise TimeoutError()
|
211
|
-
|
212
|
-
def _hangle_sig_memory(self, sig, frame):
|
213
|
-
if self._abort_try < self._reprieve:
|
214
|
-
self._abort_try += 1
|
215
|
-
raise LineageMemoryError("Memory limit reached")
|
216
|
-
else:
|
217
|
-
os.killpg(os.getpid(), SIGKILL)
|
218
|
-
|
219
|
-
def _handle_sigxcpu(self, sig, frame):
|
220
|
-
if self._abort_try < self._reprieve:
|
221
|
-
self._abort_try += 1
|
222
|
-
raise XCPUError("Soft CPU time limit reached")
|
223
|
-
else:
|
224
|
-
os.killpg(os.getpid(), SIGKILL)
|
225
|
-
|
226
|
-
def _time_out(self):
|
227
|
-
if self._abort_try < self._reprieve:
|
228
|
-
self._abort_try += 1
|
229
|
-
os.killpg(os.getpid(), SIGUSR2)
|
230
|
-
if self._limit_set > 0:
|
231
|
-
self._timer = Timer(1, self._time_out)
|
232
|
-
self._timer.start()
|
233
|
-
else:
|
234
|
-
os.killpg(os.getpid(), SIGKILL)
|
235
|
-
|
236
|
-
def setup_limit(self):
|
237
|
-
"""set up the process limit"""
|
238
|
-
assert currentThread().getName() == 'MainThread'
|
239
|
-
os.setpgrp()
|
240
|
-
if self._limit_set <= 0:
|
241
|
-
if self.max_time is not None:
|
242
|
-
self._old_usr2_hdlr = signal(SIGUSR2, self._hangle_sig_timeout)
|
243
|
-
self._timer = Timer(max(1, int(self.max_time) - self._elapse_time),
|
244
|
-
self._time_out)
|
245
|
-
self._start_time = int(time())
|
246
|
-
self._timer.start()
|
247
|
-
if self.max_cpu_time is not None:
|
248
|
-
self._old_max_cpu_time = getrlimit(RLIMIT_CPU)
|
249
|
-
cpu_limit = (int(self.max_cpu_time), self._old_max_cpu_time[1])
|
250
|
-
self._old_sigxcpu_hdlr = signal(SIGXCPU, self._handle_sigxcpu)
|
251
|
-
setrlimit(RLIMIT_CPU, cpu_limit)
|
252
|
-
if self.max_memory is not None:
|
253
|
-
self._msentinel = MemorySentinel(1, int(self.max_memory) )
|
254
|
-
self._old_max_memory = getrlimit(RLIMIT_AS)
|
255
|
-
self._old_usr1_hdlr = signal(SIGUSR1, self._hangle_sig_memory)
|
256
|
-
as_limit = (int(self.max_memory), self._old_max_memory[1])
|
257
|
-
setrlimit(RLIMIT_AS, as_limit)
|
258
|
-
self._msentinel.start()
|
259
|
-
self._limit_set += 1
|
260
|
-
|
261
|
-
def clean_limit(self):
|
262
|
-
"""reinstall the old process limit"""
|
263
|
-
if self._limit_set > 0:
|
264
|
-
if self.max_time is not None:
|
265
|
-
self._timer.cancel()
|
266
|
-
self._elapse_time += int(time())-self._start_time
|
267
|
-
self._timer = None
|
268
|
-
signal(SIGUSR2, self._old_usr2_hdlr)
|
269
|
-
if self.max_cpu_time is not None:
|
270
|
-
setrlimit(RLIMIT_CPU, self._old_max_cpu_time)
|
271
|
-
signal(SIGXCPU, self._old_sigxcpu_hdlr)
|
272
|
-
if self.max_memory is not None:
|
273
|
-
self._msentinel.stop()
|
274
|
-
self._msentinel = None
|
275
|
-
setrlimit(RLIMIT_AS, self._old_max_memory)
|
276
|
-
signal(SIGUSR1, self._old_usr1_hdlr)
|
277
|
-
self._limit_set -= 1
|
@@ -1,180 +0,0 @@
|
|
1
|
-
# copyright 2003-2011 LOGILAB S.A. (Paris, FRANCE), all rights reserved.
|
2
|
-
# contact http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
3
|
-
#
|
4
|
-
# This file is part of logilab-common.
|
5
|
-
#
|
6
|
-
# logilab-common is free software: you can redistribute it and/or modify it under
|
7
|
-
# the terms of the GNU Lesser General Public License as published by the Free
|
8
|
-
# Software Foundation, either version 2.1 of the License, or (at your option) any
|
9
|
-
# later version.
|
10
|
-
#
|
11
|
-
# logilab-common is distributed in the hope that it will be useful, but WITHOUT
|
12
|
-
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
13
|
-
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
|
14
|
-
# details.
|
15
|
-
#
|
16
|
-
# You should have received a copy of the GNU Lesser General Public License along
|
17
|
-
# with logilab-common. If not, see <http://www.gnu.org/licenses/>.
|
18
|
-
"""Python Remote Object utilities
|
19
|
-
|
20
|
-
Main functions available:
|
21
|
-
|
22
|
-
* `register_object` to expose arbitrary object through pyro using delegation
|
23
|
-
approach and register it in the nameserver.
|
24
|
-
* `ns_unregister` unregister an object identifier from the nameserver.
|
25
|
-
* `ns_get_proxy` get a pyro proxy from a nameserver object identifier.
|
26
|
-
"""
|
27
|
-
|
28
|
-
__docformat__ = "restructuredtext en"
|
29
|
-
|
30
|
-
import logging
|
31
|
-
import tempfile
|
32
|
-
|
33
|
-
from Pyro import core, naming, errors, util, config
|
34
|
-
|
35
|
-
_LOGGER = logging.getLogger('pyro')
|
36
|
-
_MARKER = object()
|
37
|
-
|
38
|
-
config.PYRO_STORAGE = tempfile.gettempdir()
|
39
|
-
|
40
|
-
def ns_group_and_id(idstr, defaultnsgroup=_MARKER):
|
41
|
-
try:
|
42
|
-
nsgroup, nsid = idstr.rsplit('.', 1)
|
43
|
-
except ValueError:
|
44
|
-
if defaultnsgroup is _MARKER:
|
45
|
-
nsgroup = config.PYRO_NS_DEFAULTGROUP
|
46
|
-
else:
|
47
|
-
nsgroup = defaultnsgroup
|
48
|
-
nsid = idstr
|
49
|
-
if nsgroup is not None and not nsgroup.startswith(':'):
|
50
|
-
nsgroup = ':' + nsgroup
|
51
|
-
return nsgroup, nsid
|
52
|
-
|
53
|
-
def host_and_port(hoststr):
|
54
|
-
if not hoststr:
|
55
|
-
return None, None
|
56
|
-
try:
|
57
|
-
hoststr, port = hoststr.split(':')
|
58
|
-
except ValueError:
|
59
|
-
port = None
|
60
|
-
else:
|
61
|
-
port = int(port)
|
62
|
-
return hoststr, port
|
63
|
-
|
64
|
-
_DAEMONS = {}
|
65
|
-
_PYRO_OBJS = {}
|
66
|
-
def _get_daemon(daemonhost, start=True):
|
67
|
-
if not daemonhost in _DAEMONS:
|
68
|
-
if not start:
|
69
|
-
raise Exception('no daemon for %s' % daemonhost)
|
70
|
-
if not _DAEMONS:
|
71
|
-
core.initServer(banner=0)
|
72
|
-
host, port = host_and_port(daemonhost)
|
73
|
-
daemon = core.Daemon(host=host, port=port)
|
74
|
-
_DAEMONS[daemonhost] = daemon
|
75
|
-
return _DAEMONS[daemonhost]
|
76
|
-
|
77
|
-
|
78
|
-
def locate_ns(nshost):
|
79
|
-
"""locate and return the pyro name server to the daemon"""
|
80
|
-
core.initClient(banner=False)
|
81
|
-
return naming.NameServerLocator().getNS(*host_and_port(nshost))
|
82
|
-
|
83
|
-
|
84
|
-
def register_object(object, nsid, defaultnsgroup=_MARKER,
|
85
|
-
daemonhost=None, nshost=None, use_pyrons=True):
|
86
|
-
"""expose the object as a pyro object and register it in the name-server
|
87
|
-
|
88
|
-
if use_pyrons is False, then the object is exposed, but no
|
89
|
-
attempt to register it to a pyro nameserver is made.
|
90
|
-
|
91
|
-
return the pyro daemon object
|
92
|
-
"""
|
93
|
-
nsgroup, nsid = ns_group_and_id(nsid, defaultnsgroup)
|
94
|
-
daemon = _get_daemon(daemonhost)
|
95
|
-
if use_pyrons:
|
96
|
-
nsd = locate_ns(nshost)
|
97
|
-
# make sure our namespace group exists
|
98
|
-
try:
|
99
|
-
nsd.createGroup(nsgroup)
|
100
|
-
except errors.NamingError:
|
101
|
-
pass
|
102
|
-
daemon.useNameServer(nsd)
|
103
|
-
# use Delegation approach
|
104
|
-
impl = core.ObjBase()
|
105
|
-
impl.delegateTo(object)
|
106
|
-
qnsid = '%s.%s' % (nsgroup, nsid)
|
107
|
-
uri = daemon.connect(impl, qnsid)
|
108
|
-
_PYRO_OBJS[qnsid] = str(uri)
|
109
|
-
_LOGGER.info('registered %s a pyro object using group %s and id %s',
|
110
|
-
object, nsgroup, nsid)
|
111
|
-
return daemon
|
112
|
-
|
113
|
-
def get_object_uri(qnsid):
|
114
|
-
return _PYRO_OBJS[qnsid]
|
115
|
-
|
116
|
-
def ns_unregister(nsid, defaultnsgroup=_MARKER, nshost=None):
|
117
|
-
"""unregister the object with the given nsid from the pyro name server"""
|
118
|
-
nsgroup, nsid = ns_group_and_id(nsid, defaultnsgroup)
|
119
|
-
try:
|
120
|
-
nsd = locate_ns(nshost)
|
121
|
-
except errors.PyroError as ex:
|
122
|
-
# name server not responding
|
123
|
-
_LOGGER.error('can\'t locate pyro name server: %s', ex)
|
124
|
-
else:
|
125
|
-
try:
|
126
|
-
nsd.unregister('%s.%s' % (nsgroup, nsid))
|
127
|
-
_LOGGER.info('%s unregistered from pyro name server', nsid)
|
128
|
-
except errors.NamingError:
|
129
|
-
_LOGGER.warning('%s not registered in pyro name server', nsid)
|
130
|
-
|
131
|
-
|
132
|
-
def ns_reregister(nsid, defaultnsgroup=_MARKER, nshost=None):
|
133
|
-
"""reregister a pyro object into the name server. You only have to specify
|
134
|
-
the name-server id of the object (though you MUST have gone through
|
135
|
-
`register_object` for the given object previously).
|
136
|
-
|
137
|
-
This is especially useful for long running server while the name server may
|
138
|
-
have been restarted, and its records lost.
|
139
|
-
"""
|
140
|
-
nsgroup, nsid = ns_group_and_id(nsid, defaultnsgroup)
|
141
|
-
qnsid = '%s.%s' % (nsgroup, nsid)
|
142
|
-
nsd = locate_ns(nshost)
|
143
|
-
try:
|
144
|
-
nsd.unregister(qnsid)
|
145
|
-
except errors.NamingError:
|
146
|
-
# make sure our namespace group exists
|
147
|
-
try:
|
148
|
-
nsd.createGroup(nsgroup)
|
149
|
-
except errors.NamingError:
|
150
|
-
pass
|
151
|
-
nsd.register(qnsid, _PYRO_OBJS[qnsid])
|
152
|
-
|
153
|
-
def ns_get_proxy(nsid, defaultnsgroup=_MARKER, nshost=None):
|
154
|
-
"""
|
155
|
-
if nshost is None, the nameserver is found by a broadcast.
|
156
|
-
"""
|
157
|
-
# resolve the Pyro object
|
158
|
-
nsgroup, nsid = ns_group_and_id(nsid, defaultnsgroup)
|
159
|
-
try:
|
160
|
-
nsd = locate_ns(nshost)
|
161
|
-
pyrouri = nsd.resolve('%s.%s' % (nsgroup, nsid))
|
162
|
-
except errors.ProtocolError as ex:
|
163
|
-
raise errors.PyroError(
|
164
|
-
'Could not connect to the Pyro name server (host: %s)' % nshost)
|
165
|
-
except errors.NamingError:
|
166
|
-
raise errors.PyroError(
|
167
|
-
'Could not get proxy for %s (not registered in Pyro), '
|
168
|
-
'you may have to restart your server-side application' % nsid)
|
169
|
-
return core.getProxyForURI(pyrouri)
|
170
|
-
|
171
|
-
def get_proxy(pyro_uri):
|
172
|
-
"""get a proxy for the passed pyro uri without using a nameserver
|
173
|
-
"""
|
174
|
-
return core.getProxyForURI(pyro_uri)
|
175
|
-
|
176
|
-
def set_pyro_log_threshold(level):
|
177
|
-
pyrologger = logging.getLogger('Pyro.%s' % str(id(util.Log)))
|
178
|
-
# remove handlers so only the root handler is used
|
179
|
-
pyrologger.handlers = []
|
180
|
-
pyrologger.setLevel(level)
|