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,462 +0,0 @@
|
|
1
|
-
# copyright 2003-2014 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
|
-
"""shell/term utilities, useful to write some python scripts instead of shell
|
19
|
-
scripts.
|
20
|
-
"""
|
21
|
-
|
22
|
-
from __future__ import print_function
|
23
|
-
|
24
|
-
__docformat__ = "restructuredtext en"
|
25
|
-
|
26
|
-
import os
|
27
|
-
import glob
|
28
|
-
import shutil
|
29
|
-
import stat
|
30
|
-
import sys
|
31
|
-
import tempfile
|
32
|
-
import time
|
33
|
-
import fnmatch
|
34
|
-
import errno
|
35
|
-
import string
|
36
|
-
import random
|
37
|
-
import subprocess
|
38
|
-
from os.path import exists, isdir, islink, basename, join
|
39
|
-
|
40
|
-
from six import string_types
|
41
|
-
from six.moves import range, input as raw_input
|
42
|
-
|
43
|
-
from logilab.common import STD_BLACKLIST, _handle_blacklist
|
44
|
-
from logilab.common.compat import str_to_bytes
|
45
|
-
from logilab.common.deprecation import deprecated
|
46
|
-
|
47
|
-
try:
|
48
|
-
from logilab.common.proc import ProcInfo, NoSuchProcess
|
49
|
-
except ImportError:
|
50
|
-
# windows platform
|
51
|
-
class NoSuchProcess(Exception): pass
|
52
|
-
|
53
|
-
def ProcInfo(pid):
|
54
|
-
raise NoSuchProcess()
|
55
|
-
|
56
|
-
|
57
|
-
class tempdir(object):
|
58
|
-
|
59
|
-
def __enter__(self):
|
60
|
-
self.path = tempfile.mkdtemp()
|
61
|
-
return self.path
|
62
|
-
|
63
|
-
def __exit__(self, exctype, value, traceback):
|
64
|
-
# rmtree in all cases
|
65
|
-
shutil.rmtree(self.path)
|
66
|
-
return traceback is None
|
67
|
-
|
68
|
-
|
69
|
-
class pushd(object):
|
70
|
-
def __init__(self, directory):
|
71
|
-
self.directory = directory
|
72
|
-
|
73
|
-
def __enter__(self):
|
74
|
-
self.cwd = os.getcwd()
|
75
|
-
os.chdir(self.directory)
|
76
|
-
return self.directory
|
77
|
-
|
78
|
-
def __exit__(self, exctype, value, traceback):
|
79
|
-
os.chdir(self.cwd)
|
80
|
-
|
81
|
-
|
82
|
-
def chown(path, login=None, group=None):
|
83
|
-
"""Same as `os.chown` function but accepting user login or group name as
|
84
|
-
argument. If login or group is omitted, it's left unchanged.
|
85
|
-
|
86
|
-
Note: you must own the file to chown it (or be root). Otherwise OSError is raised.
|
87
|
-
"""
|
88
|
-
if login is None:
|
89
|
-
uid = -1
|
90
|
-
else:
|
91
|
-
try:
|
92
|
-
uid = int(login)
|
93
|
-
except ValueError:
|
94
|
-
import pwd # Platforms: Unix
|
95
|
-
uid = pwd.getpwnam(login).pw_uid
|
96
|
-
if group is None:
|
97
|
-
gid = -1
|
98
|
-
else:
|
99
|
-
try:
|
100
|
-
gid = int(group)
|
101
|
-
except ValueError:
|
102
|
-
import grp
|
103
|
-
gid = grp.getgrnam(group).gr_gid
|
104
|
-
os.chown(path, uid, gid)
|
105
|
-
|
106
|
-
def mv(source, destination, _action=shutil.move):
|
107
|
-
"""A shell-like mv, supporting wildcards.
|
108
|
-
"""
|
109
|
-
sources = glob.glob(source)
|
110
|
-
if len(sources) > 1:
|
111
|
-
assert isdir(destination)
|
112
|
-
for filename in sources:
|
113
|
-
_action(filename, join(destination, basename(filename)))
|
114
|
-
else:
|
115
|
-
try:
|
116
|
-
source = sources[0]
|
117
|
-
except IndexError:
|
118
|
-
raise OSError('No file matching %s' % source)
|
119
|
-
if isdir(destination) and exists(destination):
|
120
|
-
destination = join(destination, basename(source))
|
121
|
-
try:
|
122
|
-
_action(source, destination)
|
123
|
-
except OSError as ex:
|
124
|
-
raise OSError('Unable to move %r to %r (%s)' % (
|
125
|
-
source, destination, ex))
|
126
|
-
|
127
|
-
def rm(*files):
|
128
|
-
"""A shell-like rm, supporting wildcards.
|
129
|
-
"""
|
130
|
-
for wfile in files:
|
131
|
-
for filename in glob.glob(wfile):
|
132
|
-
if islink(filename):
|
133
|
-
os.remove(filename)
|
134
|
-
elif isdir(filename):
|
135
|
-
shutil.rmtree(filename)
|
136
|
-
else:
|
137
|
-
os.remove(filename)
|
138
|
-
|
139
|
-
def cp(source, destination):
|
140
|
-
"""A shell-like cp, supporting wildcards.
|
141
|
-
"""
|
142
|
-
mv(source, destination, _action=shutil.copy)
|
143
|
-
|
144
|
-
def find(directory, exts, exclude=False, blacklist=STD_BLACKLIST):
|
145
|
-
"""Recursively find files ending with the given extensions from the directory.
|
146
|
-
|
147
|
-
:type directory: str
|
148
|
-
:param directory:
|
149
|
-
directory where the search should start
|
150
|
-
|
151
|
-
:type exts: basestring or list or tuple
|
152
|
-
:param exts:
|
153
|
-
extensions or lists or extensions to search
|
154
|
-
|
155
|
-
:type exclude: boolean
|
156
|
-
:param exts:
|
157
|
-
if this argument is True, returning files NOT ending with the given
|
158
|
-
extensions
|
159
|
-
|
160
|
-
:type blacklist: list or tuple
|
161
|
-
:param blacklist:
|
162
|
-
optional list of files or directory to ignore, default to the value of
|
163
|
-
`logilab.common.STD_BLACKLIST`
|
164
|
-
|
165
|
-
:rtype: list
|
166
|
-
:return:
|
167
|
-
the list of all matching files
|
168
|
-
"""
|
169
|
-
if isinstance(exts, string_types):
|
170
|
-
exts = (exts,)
|
171
|
-
if exclude:
|
172
|
-
def match(filename, exts):
|
173
|
-
for ext in exts:
|
174
|
-
if filename.endswith(ext):
|
175
|
-
return False
|
176
|
-
return True
|
177
|
-
else:
|
178
|
-
def match(filename, exts):
|
179
|
-
for ext in exts:
|
180
|
-
if filename.endswith(ext):
|
181
|
-
return True
|
182
|
-
return False
|
183
|
-
files = []
|
184
|
-
for dirpath, dirnames, filenames in os.walk(directory):
|
185
|
-
_handle_blacklist(blacklist, dirnames, filenames)
|
186
|
-
# don't append files if the directory is blacklisted
|
187
|
-
dirname = basename(dirpath)
|
188
|
-
if dirname in blacklist:
|
189
|
-
continue
|
190
|
-
files.extend([join(dirpath, f) for f in filenames if match(f, exts)])
|
191
|
-
return files
|
192
|
-
|
193
|
-
|
194
|
-
def globfind(directory, pattern, blacklist=STD_BLACKLIST):
|
195
|
-
"""Recursively finds files matching glob `pattern` under `directory`.
|
196
|
-
|
197
|
-
This is an alternative to `logilab.common.shellutils.find`.
|
198
|
-
|
199
|
-
:type directory: str
|
200
|
-
:param directory:
|
201
|
-
directory where the search should start
|
202
|
-
|
203
|
-
:type pattern: basestring
|
204
|
-
:param pattern:
|
205
|
-
the glob pattern (e.g *.py, foo*.py, etc.)
|
206
|
-
|
207
|
-
:type blacklist: list or tuple
|
208
|
-
:param blacklist:
|
209
|
-
optional list of files or directory to ignore, default to the value of
|
210
|
-
`logilab.common.STD_BLACKLIST`
|
211
|
-
|
212
|
-
:rtype: iterator
|
213
|
-
:return:
|
214
|
-
iterator over the list of all matching files
|
215
|
-
"""
|
216
|
-
for curdir, dirnames, filenames in os.walk(directory):
|
217
|
-
_handle_blacklist(blacklist, dirnames, filenames)
|
218
|
-
for fname in fnmatch.filter(filenames, pattern):
|
219
|
-
yield join(curdir, fname)
|
220
|
-
|
221
|
-
def unzip(archive, destdir):
|
222
|
-
import zipfile
|
223
|
-
if not exists(destdir):
|
224
|
-
os.mkdir(destdir)
|
225
|
-
zfobj = zipfile.ZipFile(archive)
|
226
|
-
for name in zfobj.namelist():
|
227
|
-
if name.endswith('/'):
|
228
|
-
os.mkdir(join(destdir, name))
|
229
|
-
else:
|
230
|
-
outfile = open(join(destdir, name), 'wb')
|
231
|
-
outfile.write(zfobj.read(name))
|
232
|
-
outfile.close()
|
233
|
-
|
234
|
-
|
235
|
-
class Execute:
|
236
|
-
"""This is a deadlock safe version of popen2 (no stdin), that returns
|
237
|
-
an object with errorlevel, out and err.
|
238
|
-
"""
|
239
|
-
|
240
|
-
def __init__(self, command):
|
241
|
-
cmd = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
242
|
-
self.out, self.err = cmd.communicate()
|
243
|
-
self.status = os.WEXITSTATUS(cmd.returncode)
|
244
|
-
|
245
|
-
Execute = deprecated('Use subprocess.Popen instead')(Execute)
|
246
|
-
|
247
|
-
|
248
|
-
def acquire_lock(lock_file, max_try=10, delay=10, max_delay=3600):
|
249
|
-
"""Acquire a lock represented by a file on the file system
|
250
|
-
|
251
|
-
If the process written in lock file doesn't exist anymore, we remove the
|
252
|
-
lock file immediately
|
253
|
-
If age of the lock_file is greater than max_delay, then we raise a UserWarning
|
254
|
-
"""
|
255
|
-
count = abs(max_try)
|
256
|
-
while count:
|
257
|
-
try:
|
258
|
-
fd = os.open(lock_file, os.O_EXCL | os.O_RDWR | os.O_CREAT)
|
259
|
-
os.write(fd, str_to_bytes(str(os.getpid())) )
|
260
|
-
os.close(fd)
|
261
|
-
return True
|
262
|
-
except OSError as e:
|
263
|
-
if e.errno == errno.EEXIST:
|
264
|
-
try:
|
265
|
-
fd = open(lock_file, "r")
|
266
|
-
pid = int(fd.readline())
|
267
|
-
pi = ProcInfo(pid)
|
268
|
-
age = (time.time() - os.stat(lock_file)[stat.ST_MTIME])
|
269
|
-
if age / max_delay > 1 :
|
270
|
-
raise UserWarning("Command '%s' (pid %s) has locked the "
|
271
|
-
"file '%s' for %s minutes"
|
272
|
-
% (pi.name(), pid, lock_file, age/60))
|
273
|
-
except UserWarning:
|
274
|
-
raise
|
275
|
-
except NoSuchProcess:
|
276
|
-
os.remove(lock_file)
|
277
|
-
except Exception:
|
278
|
-
# The try block is not essential. can be skipped.
|
279
|
-
# Note: ProcInfo object is only available for linux
|
280
|
-
# process information are not accessible...
|
281
|
-
# or lock_file is no more present...
|
282
|
-
pass
|
283
|
-
else:
|
284
|
-
raise
|
285
|
-
count -= 1
|
286
|
-
time.sleep(delay)
|
287
|
-
else:
|
288
|
-
raise Exception('Unable to acquire %s' % lock_file)
|
289
|
-
|
290
|
-
def release_lock(lock_file):
|
291
|
-
"""Release a lock represented by a file on the file system."""
|
292
|
-
os.remove(lock_file)
|
293
|
-
|
294
|
-
|
295
|
-
class ProgressBar(object):
|
296
|
-
"""A simple text progression bar."""
|
297
|
-
|
298
|
-
def __init__(self, nbops, size=20, stream=sys.stdout, title=''):
|
299
|
-
if title:
|
300
|
-
self._fstr = '\r%s [%%-%ss]' % (title, int(size))
|
301
|
-
else:
|
302
|
-
self._fstr = '\r[%%-%ss]' % int(size)
|
303
|
-
self._stream = stream
|
304
|
-
self._total = nbops
|
305
|
-
self._size = size
|
306
|
-
self._current = 0
|
307
|
-
self._progress = 0
|
308
|
-
self._current_text = None
|
309
|
-
self._last_text_write_size = 0
|
310
|
-
|
311
|
-
def _get_text(self):
|
312
|
-
return self._current_text
|
313
|
-
|
314
|
-
def _set_text(self, text=None):
|
315
|
-
if text != self._current_text:
|
316
|
-
self._current_text = text
|
317
|
-
self.refresh()
|
318
|
-
|
319
|
-
def _del_text(self):
|
320
|
-
self.text = None
|
321
|
-
|
322
|
-
text = property(_get_text, _set_text, _del_text)
|
323
|
-
|
324
|
-
def update(self, offset=1, exact=False):
|
325
|
-
"""Move FORWARD to new cursor position (cursor will never go backward).
|
326
|
-
|
327
|
-
:offset: fraction of ``size``
|
328
|
-
|
329
|
-
:exact:
|
330
|
-
|
331
|
-
- False: offset relative to current cursor position if True
|
332
|
-
- True: offset as an asbsolute position
|
333
|
-
|
334
|
-
"""
|
335
|
-
if exact:
|
336
|
-
self._current = offset
|
337
|
-
else:
|
338
|
-
self._current += offset
|
339
|
-
|
340
|
-
progress = int((float(self._current)/float(self._total))*self._size)
|
341
|
-
if progress > self._progress:
|
342
|
-
self._progress = progress
|
343
|
-
self.refresh()
|
344
|
-
|
345
|
-
def refresh(self):
|
346
|
-
"""Refresh the progression bar display."""
|
347
|
-
self._stream.write(self._fstr % ('=' * min(self._progress, self._size)) )
|
348
|
-
if self._last_text_write_size or self._current_text:
|
349
|
-
template = ' %%-%is' % (self._last_text_write_size)
|
350
|
-
text = self._current_text
|
351
|
-
if text is None:
|
352
|
-
text = ''
|
353
|
-
self._stream.write(template % text)
|
354
|
-
self._last_text_write_size = len(text.rstrip())
|
355
|
-
self._stream.flush()
|
356
|
-
|
357
|
-
def finish(self):
|
358
|
-
self._stream.write('\n')
|
359
|
-
self._stream.flush()
|
360
|
-
|
361
|
-
|
362
|
-
class DummyProgressBar(object):
|
363
|
-
__slot__ = ('text',)
|
364
|
-
|
365
|
-
def refresh(self):
|
366
|
-
pass
|
367
|
-
def update(self):
|
368
|
-
pass
|
369
|
-
def finish(self):
|
370
|
-
pass
|
371
|
-
|
372
|
-
|
373
|
-
_MARKER = object()
|
374
|
-
class progress(object):
|
375
|
-
|
376
|
-
def __init__(self, nbops=_MARKER, size=_MARKER, stream=_MARKER, title=_MARKER, enabled=True):
|
377
|
-
self.nbops = nbops
|
378
|
-
self.size = size
|
379
|
-
self.stream = stream
|
380
|
-
self.title = title
|
381
|
-
self.enabled = enabled
|
382
|
-
|
383
|
-
def __enter__(self):
|
384
|
-
if self.enabled:
|
385
|
-
kwargs = {}
|
386
|
-
for attr in ('nbops', 'size', 'stream', 'title'):
|
387
|
-
value = getattr(self, attr)
|
388
|
-
if value is not _MARKER:
|
389
|
-
kwargs[attr] = value
|
390
|
-
self.pb = ProgressBar(**kwargs)
|
391
|
-
else:
|
392
|
-
self.pb = DummyProgressBar()
|
393
|
-
return self.pb
|
394
|
-
|
395
|
-
def __exit__(self, exc_type, exc_val, exc_tb):
|
396
|
-
self.pb.finish()
|
397
|
-
|
398
|
-
class RawInput(object):
|
399
|
-
|
400
|
-
def __init__(self, input=None, printer=None):
|
401
|
-
self._input = input or raw_input
|
402
|
-
self._print = printer
|
403
|
-
|
404
|
-
def ask(self, question, options, default):
|
405
|
-
assert default in options
|
406
|
-
choices = []
|
407
|
-
for option in options:
|
408
|
-
if option == default:
|
409
|
-
label = option[0].upper()
|
410
|
-
else:
|
411
|
-
label = option[0].lower()
|
412
|
-
if len(option) > 1:
|
413
|
-
label += '(%s)' % option[1:].lower()
|
414
|
-
choices.append((option, label))
|
415
|
-
prompt = "%s [%s]: " % (question,
|
416
|
-
'/'.join([opt[1] for opt in choices]))
|
417
|
-
tries = 3
|
418
|
-
while tries > 0:
|
419
|
-
answer = self._input(prompt).strip().lower()
|
420
|
-
if not answer:
|
421
|
-
return default
|
422
|
-
possible = [option for option, label in choices
|
423
|
-
if option.lower().startswith(answer)]
|
424
|
-
if len(possible) == 1:
|
425
|
-
return possible[0]
|
426
|
-
elif len(possible) == 0:
|
427
|
-
msg = '%s is not an option.' % answer
|
428
|
-
else:
|
429
|
-
msg = ('%s is an ambiguous answer, do you mean %s ?' % (
|
430
|
-
answer, ' or '.join(possible)))
|
431
|
-
if self._print:
|
432
|
-
self._print(msg)
|
433
|
-
else:
|
434
|
-
print(msg)
|
435
|
-
tries -= 1
|
436
|
-
raise Exception('unable to get a sensible answer')
|
437
|
-
|
438
|
-
def confirm(self, question, default_is_yes=True):
|
439
|
-
default = default_is_yes and 'y' or 'n'
|
440
|
-
answer = self.ask(question, ('y', 'n'), default)
|
441
|
-
return answer == 'y'
|
442
|
-
|
443
|
-
ASK = RawInput()
|
444
|
-
|
445
|
-
|
446
|
-
def getlogin():
|
447
|
-
"""avoid using os.getlogin() because of strange tty / stdin problems
|
448
|
-
(man 3 getlogin)
|
449
|
-
Another solution would be to use $LOGNAME, $USER or $USERNAME
|
450
|
-
"""
|
451
|
-
if sys.platform != 'win32':
|
452
|
-
import pwd # Platforms: Unix
|
453
|
-
return pwd.getpwuid(os.getuid())[0]
|
454
|
-
else:
|
455
|
-
return os.environ['USERNAME']
|
456
|
-
|
457
|
-
def generate_password(length=8, vocab=string.ascii_letters + string.digits):
|
458
|
-
"""dumb password generation function"""
|
459
|
-
pwd = ''
|
460
|
-
for i in range(length):
|
461
|
-
pwd += random.choice(vocab)
|
462
|
-
return pwd
|