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,189 +0,0 @@
|
|
1
|
-
# copyright 2003-2012 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
|
-
"""Deprecation utilities."""
|
19
|
-
|
20
|
-
__docformat__ = "restructuredtext en"
|
21
|
-
|
22
|
-
import sys
|
23
|
-
from warnings import warn
|
24
|
-
|
25
|
-
from logilab.common.changelog import Version
|
26
|
-
|
27
|
-
|
28
|
-
class DeprecationWrapper(object):
|
29
|
-
"""proxy to print a warning on access to any attribute of the wrapped object
|
30
|
-
"""
|
31
|
-
def __init__(self, proxied, msg=None):
|
32
|
-
self._proxied = proxied
|
33
|
-
self._msg = msg
|
34
|
-
|
35
|
-
def __getattr__(self, attr):
|
36
|
-
warn(self._msg, DeprecationWarning, stacklevel=2)
|
37
|
-
return getattr(self._proxied, attr)
|
38
|
-
|
39
|
-
def __setattr__(self, attr, value):
|
40
|
-
if attr in ('_proxied', '_msg'):
|
41
|
-
self.__dict__[attr] = value
|
42
|
-
else:
|
43
|
-
warn(self._msg, DeprecationWarning, stacklevel=2)
|
44
|
-
setattr(self._proxied, attr, value)
|
45
|
-
|
46
|
-
|
47
|
-
class DeprecationManager(object):
|
48
|
-
"""Manage the deprecation message handling. Messages are dropped for
|
49
|
-
versions more recent than the 'compatible' version. Example::
|
50
|
-
|
51
|
-
deprecator = deprecation.DeprecationManager("module_name")
|
52
|
-
deprecator.compatibility('1.3')
|
53
|
-
|
54
|
-
deprecator.warn('1.2', "message.")
|
55
|
-
|
56
|
-
@deprecator.deprecated('1.2', 'Message')
|
57
|
-
def any_func():
|
58
|
-
pass
|
59
|
-
|
60
|
-
class AnyClass(object):
|
61
|
-
__metaclass__ = deprecator.class_deprecated('1.2')
|
62
|
-
"""
|
63
|
-
def __init__(self, module_name=None):
|
64
|
-
"""
|
65
|
-
"""
|
66
|
-
self.module_name = module_name
|
67
|
-
self.compatible_version = None
|
68
|
-
|
69
|
-
def compatibility(self, compatible_version):
|
70
|
-
"""Set the compatible version.
|
71
|
-
"""
|
72
|
-
self.compatible_version = Version(compatible_version)
|
73
|
-
|
74
|
-
def deprecated(self, version=None, reason=None, stacklevel=2, name=None, doc=None):
|
75
|
-
"""Display a deprecation message only if the version is older than the
|
76
|
-
compatible version.
|
77
|
-
"""
|
78
|
-
def decorator(func):
|
79
|
-
message = reason or 'The function "%s" is deprecated'
|
80
|
-
if '%s' in message:
|
81
|
-
message %= func.__name__
|
82
|
-
def wrapped(*args, **kwargs):
|
83
|
-
self.warn(version, message, stacklevel+1)
|
84
|
-
return func(*args, **kwargs)
|
85
|
-
return wrapped
|
86
|
-
return decorator
|
87
|
-
|
88
|
-
def class_deprecated(self, version=None):
|
89
|
-
class metaclass(type):
|
90
|
-
"""metaclass to print a warning on instantiation of a deprecated class"""
|
91
|
-
|
92
|
-
def __call__(cls, *args, **kwargs):
|
93
|
-
msg = getattr(cls, "__deprecation_warning__",
|
94
|
-
"%(cls)s is deprecated") % {'cls': cls.__name__}
|
95
|
-
self.warn(version, msg, stacklevel=3)
|
96
|
-
return type.__call__(cls, *args, **kwargs)
|
97
|
-
return metaclass
|
98
|
-
|
99
|
-
def moved(self, version, modpath, objname):
|
100
|
-
"""use to tell that a callable has been moved to a new module.
|
101
|
-
|
102
|
-
It returns a callable wrapper, so that when its called a warning is printed
|
103
|
-
telling where the object can be found, import is done (and not before) and
|
104
|
-
the actual object is called.
|
105
|
-
|
106
|
-
NOTE: the usage is somewhat limited on classes since it will fail if the
|
107
|
-
wrapper is use in a class ancestors list, use the `class_moved` function
|
108
|
-
instead (which has no lazy import feature though).
|
109
|
-
"""
|
110
|
-
def callnew(*args, **kwargs):
|
111
|
-
from logilab.common.modutils import load_module_from_name
|
112
|
-
message = "object %s has been moved to module %s" % (objname, modpath)
|
113
|
-
self.warn(version, message)
|
114
|
-
m = load_module_from_name(modpath)
|
115
|
-
return getattr(m, objname)(*args, **kwargs)
|
116
|
-
return callnew
|
117
|
-
|
118
|
-
def class_renamed(self, version, old_name, new_class, message=None):
|
119
|
-
clsdict = {}
|
120
|
-
if message is None:
|
121
|
-
message = '%s is deprecated, use %s' % (old_name, new_class.__name__)
|
122
|
-
clsdict['__deprecation_warning__'] = message
|
123
|
-
try:
|
124
|
-
# new-style class
|
125
|
-
return self.class_deprecated(version)(old_name, (new_class,), clsdict)
|
126
|
-
except (NameError, TypeError):
|
127
|
-
# old-style class
|
128
|
-
warn = self.warn
|
129
|
-
class DeprecatedClass(new_class):
|
130
|
-
"""FIXME: There might be a better way to handle old/new-style class
|
131
|
-
"""
|
132
|
-
def __init__(self, *args, **kwargs):
|
133
|
-
warn(version, message, stacklevel=3)
|
134
|
-
new_class.__init__(self, *args, **kwargs)
|
135
|
-
return DeprecatedClass
|
136
|
-
|
137
|
-
def class_moved(self, version, new_class, old_name=None, message=None):
|
138
|
-
"""nice wrapper around class_renamed when a class has been moved into
|
139
|
-
another module
|
140
|
-
"""
|
141
|
-
if old_name is None:
|
142
|
-
old_name = new_class.__name__
|
143
|
-
if message is None:
|
144
|
-
message = 'class %s is now available as %s.%s' % (
|
145
|
-
old_name, new_class.__module__, new_class.__name__)
|
146
|
-
return self.class_renamed(version, old_name, new_class, message)
|
147
|
-
|
148
|
-
def warn(self, version=None, reason="", stacklevel=2):
|
149
|
-
"""Display a deprecation message only if the version is older than the
|
150
|
-
compatible version.
|
151
|
-
"""
|
152
|
-
if (self.compatible_version is None
|
153
|
-
or version is None
|
154
|
-
or Version(version) < self.compatible_version):
|
155
|
-
if self.module_name and version:
|
156
|
-
reason = '[%s %s] %s' % (self.module_name, version, reason)
|
157
|
-
elif self.module_name:
|
158
|
-
reason = '[%s] %s' % (self.module_name, reason)
|
159
|
-
elif version:
|
160
|
-
reason = '[%s] %s' % (version, reason)
|
161
|
-
warn(reason, DeprecationWarning, stacklevel=stacklevel)
|
162
|
-
|
163
|
-
_defaultdeprecator = DeprecationManager()
|
164
|
-
|
165
|
-
def deprecated(reason=None, stacklevel=2, name=None, doc=None):
|
166
|
-
return _defaultdeprecator.deprecated(None, reason, stacklevel, name, doc)
|
167
|
-
|
168
|
-
class_deprecated = _defaultdeprecator.class_deprecated()
|
169
|
-
|
170
|
-
def moved(modpath, objname):
|
171
|
-
return _defaultdeprecator.moved(None, modpath, objname)
|
172
|
-
moved.__doc__ = _defaultdeprecator.moved.__doc__
|
173
|
-
|
174
|
-
def class_renamed(old_name, new_class, message=None):
|
175
|
-
"""automatically creates a class which fires a DeprecationWarning
|
176
|
-
when instantiated.
|
177
|
-
|
178
|
-
>>> Set = class_renamed('Set', set, 'Set is now replaced by set')
|
179
|
-
>>> s = Set()
|
180
|
-
sample.py:57: DeprecationWarning: Set is now replaced by set
|
181
|
-
s = Set()
|
182
|
-
>>>
|
183
|
-
"""
|
184
|
-
return _defaultdeprecator.class_renamed(None, old_name, new_class, message)
|
185
|
-
|
186
|
-
def class_moved(new_class, old_name=None, message=None):
|
187
|
-
return _defaultdeprecator.class_moved(None, new_class, old_name, message)
|
188
|
-
class_moved.__doc__ = _defaultdeprecator.class_moved.__doc__
|
189
|
-
|
@@ -1,404 +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
|
-
"""File and file-path manipulation utilities.
|
19
|
-
|
20
|
-
:group path manipulation: first_level_directory, relative_path, is_binary,\
|
21
|
-
get_by_ext, remove_dead_links
|
22
|
-
:group file manipulation: norm_read, norm_open, lines, stream_lines, lines,\
|
23
|
-
write_open_mode, ensure_fs_mode, export
|
24
|
-
:sort: path manipulation, file manipulation
|
25
|
-
"""
|
26
|
-
|
27
|
-
from __future__ import print_function
|
28
|
-
|
29
|
-
__docformat__ = "restructuredtext en"
|
30
|
-
|
31
|
-
import sys
|
32
|
-
import shutil
|
33
|
-
import mimetypes
|
34
|
-
from os.path import isabs, isdir, islink, split, exists, normpath, join
|
35
|
-
from os.path import abspath
|
36
|
-
from os import sep, mkdir, remove, listdir, stat, chmod, walk
|
37
|
-
from stat import ST_MODE, S_IWRITE
|
38
|
-
|
39
|
-
from logilab.common import STD_BLACKLIST as BASE_BLACKLIST, IGNORED_EXTENSIONS
|
40
|
-
from logilab.common.shellutils import find
|
41
|
-
from logilab.common.deprecation import deprecated
|
42
|
-
from logilab.common.compat import FileIO
|
43
|
-
|
44
|
-
def first_level_directory(path):
|
45
|
-
"""Return the first level directory of a path.
|
46
|
-
|
47
|
-
>>> first_level_directory('home/syt/work')
|
48
|
-
'home'
|
49
|
-
>>> first_level_directory('/home/syt/work')
|
50
|
-
'/'
|
51
|
-
>>> first_level_directory('work')
|
52
|
-
'work'
|
53
|
-
>>>
|
54
|
-
|
55
|
-
:type path: str
|
56
|
-
:param path: the path for which we want the first level directory
|
57
|
-
|
58
|
-
:rtype: str
|
59
|
-
:return: the first level directory appearing in `path`
|
60
|
-
"""
|
61
|
-
head, tail = split(path)
|
62
|
-
while head and tail:
|
63
|
-
head, tail = split(head)
|
64
|
-
if tail:
|
65
|
-
return tail
|
66
|
-
# path was absolute, head is the fs root
|
67
|
-
return head
|
68
|
-
|
69
|
-
def abspath_listdir(path):
|
70
|
-
"""Lists path's content using absolute paths.
|
71
|
-
|
72
|
-
>>> os.listdir('/home')
|
73
|
-
['adim', 'alf', 'arthur', 'auc']
|
74
|
-
>>> abspath_listdir('/home')
|
75
|
-
['/home/adim', '/home/alf', '/home/arthur', '/home/auc']
|
76
|
-
"""
|
77
|
-
path = abspath(path)
|
78
|
-
return [join(path, filename) for filename in listdir(path)]
|
79
|
-
|
80
|
-
|
81
|
-
def is_binary(filename):
|
82
|
-
"""Return true if filename may be a binary file, according to it's
|
83
|
-
extension.
|
84
|
-
|
85
|
-
:type filename: str
|
86
|
-
:param filename: the name of the file
|
87
|
-
|
88
|
-
:rtype: bool
|
89
|
-
:return:
|
90
|
-
true if the file is a binary file (actually if it's mime type
|
91
|
-
isn't beginning by text/)
|
92
|
-
"""
|
93
|
-
try:
|
94
|
-
return not mimetypes.guess_type(filename)[0].startswith('text')
|
95
|
-
except AttributeError:
|
96
|
-
return 1
|
97
|
-
|
98
|
-
|
99
|
-
def write_open_mode(filename):
|
100
|
-
"""Return the write mode that should used to open file.
|
101
|
-
|
102
|
-
:type filename: str
|
103
|
-
:param filename: the name of the file
|
104
|
-
|
105
|
-
:rtype: str
|
106
|
-
:return: the mode that should be use to open the file ('w' or 'wb')
|
107
|
-
"""
|
108
|
-
if is_binary(filename):
|
109
|
-
return 'wb'
|
110
|
-
return 'w'
|
111
|
-
|
112
|
-
|
113
|
-
def ensure_fs_mode(filepath, desired_mode=S_IWRITE):
|
114
|
-
"""Check that the given file has the given mode(s) set, else try to
|
115
|
-
set it.
|
116
|
-
|
117
|
-
:type filepath: str
|
118
|
-
:param filepath: path of the file
|
119
|
-
|
120
|
-
:type desired_mode: int
|
121
|
-
:param desired_mode:
|
122
|
-
ORed flags describing the desired mode. Use constants from the
|
123
|
-
`stat` module for file permission's modes
|
124
|
-
"""
|
125
|
-
mode = stat(filepath)[ST_MODE]
|
126
|
-
if not mode & desired_mode:
|
127
|
-
chmod(filepath, mode | desired_mode)
|
128
|
-
|
129
|
-
|
130
|
-
# XXX (syt) unused? kill?
|
131
|
-
class ProtectedFile(FileIO):
|
132
|
-
"""A special file-object class that automatically does a 'chmod +w' when
|
133
|
-
needed.
|
134
|
-
|
135
|
-
XXX: for now, the way it is done allows 'normal file-objects' to be
|
136
|
-
created during the ProtectedFile object lifetime.
|
137
|
-
One way to circumvent this would be to chmod / unchmod on each
|
138
|
-
write operation.
|
139
|
-
|
140
|
-
One other way would be to :
|
141
|
-
|
142
|
-
- catch the IOError in the __init__
|
143
|
-
|
144
|
-
- if IOError, then create a StringIO object
|
145
|
-
|
146
|
-
- each write operation writes in this StringIO object
|
147
|
-
|
148
|
-
- on close()/del(), write/append the StringIO content to the file and
|
149
|
-
do the chmod only once
|
150
|
-
"""
|
151
|
-
def __init__(self, filepath, mode):
|
152
|
-
self.original_mode = stat(filepath)[ST_MODE]
|
153
|
-
self.mode_changed = False
|
154
|
-
if mode in ('w', 'a', 'wb', 'ab'):
|
155
|
-
if not self.original_mode & S_IWRITE:
|
156
|
-
chmod(filepath, self.original_mode | S_IWRITE)
|
157
|
-
self.mode_changed = True
|
158
|
-
FileIO.__init__(self, filepath, mode)
|
159
|
-
|
160
|
-
def _restore_mode(self):
|
161
|
-
"""restores the original mode if needed"""
|
162
|
-
if self.mode_changed:
|
163
|
-
chmod(self.name, self.original_mode)
|
164
|
-
# Don't re-chmod in case of several restore
|
165
|
-
self.mode_changed = False
|
166
|
-
|
167
|
-
def close(self):
|
168
|
-
"""restore mode before closing"""
|
169
|
-
self._restore_mode()
|
170
|
-
FileIO.close(self)
|
171
|
-
|
172
|
-
def __del__(self):
|
173
|
-
if not self.closed:
|
174
|
-
self.close()
|
175
|
-
|
176
|
-
|
177
|
-
class UnresolvableError(Exception):
|
178
|
-
"""Exception raised by relative path when it's unable to compute relative
|
179
|
-
path between two paths.
|
180
|
-
"""
|
181
|
-
|
182
|
-
def relative_path(from_file, to_file):
|
183
|
-
"""Try to get a relative path from `from_file` to `to_file`
|
184
|
-
(path will be absolute if to_file is an absolute file). This function
|
185
|
-
is useful to create link in `from_file` to `to_file`. This typical use
|
186
|
-
case is used in this function description.
|
187
|
-
|
188
|
-
If both files are relative, they're expected to be relative to the same
|
189
|
-
directory.
|
190
|
-
|
191
|
-
>>> relative_path( from_file='toto/index.html', to_file='index.html')
|
192
|
-
'../index.html'
|
193
|
-
>>> relative_path( from_file='index.html', to_file='toto/index.html')
|
194
|
-
'toto/index.html'
|
195
|
-
>>> relative_path( from_file='tutu/index.html', to_file='toto/index.html')
|
196
|
-
'../toto/index.html'
|
197
|
-
>>> relative_path( from_file='toto/index.html', to_file='/index.html')
|
198
|
-
'/index.html'
|
199
|
-
>>> relative_path( from_file='/toto/index.html', to_file='/index.html')
|
200
|
-
'../index.html'
|
201
|
-
>>> relative_path( from_file='/toto/index.html', to_file='/toto/summary.html')
|
202
|
-
'summary.html'
|
203
|
-
>>> relative_path( from_file='index.html', to_file='index.html')
|
204
|
-
''
|
205
|
-
>>> relative_path( from_file='/index.html', to_file='toto/index.html')
|
206
|
-
Traceback (most recent call last):
|
207
|
-
File "<string>", line 1, in ?
|
208
|
-
File "<stdin>", line 37, in relative_path
|
209
|
-
UnresolvableError
|
210
|
-
>>> relative_path( from_file='/index.html', to_file='/index.html')
|
211
|
-
''
|
212
|
-
>>>
|
213
|
-
|
214
|
-
:type from_file: str
|
215
|
-
:param from_file: source file (where links will be inserted)
|
216
|
-
|
217
|
-
:type to_file: str
|
218
|
-
:param to_file: target file (on which links point)
|
219
|
-
|
220
|
-
:raise UnresolvableError: if it has been unable to guess a correct path
|
221
|
-
|
222
|
-
:rtype: str
|
223
|
-
:return: the relative path of `to_file` from `from_file`
|
224
|
-
"""
|
225
|
-
from_file = normpath(from_file)
|
226
|
-
to_file = normpath(to_file)
|
227
|
-
if from_file == to_file:
|
228
|
-
return ''
|
229
|
-
if isabs(to_file):
|
230
|
-
if not isabs(from_file):
|
231
|
-
return to_file
|
232
|
-
elif isabs(from_file):
|
233
|
-
raise UnresolvableError()
|
234
|
-
from_parts = from_file.split(sep)
|
235
|
-
to_parts = to_file.split(sep)
|
236
|
-
idem = 1
|
237
|
-
result = []
|
238
|
-
while len(from_parts) > 1:
|
239
|
-
dirname = from_parts.pop(0)
|
240
|
-
if idem and len(to_parts) > 1 and dirname == to_parts[0]:
|
241
|
-
to_parts.pop(0)
|
242
|
-
else:
|
243
|
-
idem = 0
|
244
|
-
result.append('..')
|
245
|
-
result += to_parts
|
246
|
-
return sep.join(result)
|
247
|
-
|
248
|
-
|
249
|
-
def norm_read(path):
|
250
|
-
"""Return the content of the file with normalized line feeds.
|
251
|
-
|
252
|
-
:type path: str
|
253
|
-
:param path: path to the file to read
|
254
|
-
|
255
|
-
:rtype: str
|
256
|
-
:return: the content of the file with normalized line feeds
|
257
|
-
"""
|
258
|
-
return open(path, 'U').read()
|
259
|
-
norm_read = deprecated("use \"open(path, 'U').read()\"")(norm_read)
|
260
|
-
|
261
|
-
def norm_open(path):
|
262
|
-
"""Return a stream for a file with content with normalized line feeds.
|
263
|
-
|
264
|
-
:type path: str
|
265
|
-
:param path: path to the file to open
|
266
|
-
|
267
|
-
:rtype: file or StringIO
|
268
|
-
:return: the opened file with normalized line feeds
|
269
|
-
"""
|
270
|
-
return open(path, 'U')
|
271
|
-
norm_open = deprecated("use \"open(path, 'U')\"")(norm_open)
|
272
|
-
|
273
|
-
def lines(path, comments=None):
|
274
|
-
"""Return a list of non empty lines in the file located at `path`.
|
275
|
-
|
276
|
-
:type path: str
|
277
|
-
:param path: path to the file
|
278
|
-
|
279
|
-
:type comments: str or None
|
280
|
-
:param comments:
|
281
|
-
optional string which can be used to comment a line in the file
|
282
|
-
(i.e. lines starting with this string won't be returned)
|
283
|
-
|
284
|
-
:rtype: list
|
285
|
-
:return:
|
286
|
-
a list of stripped line in the file, without empty and commented
|
287
|
-
lines
|
288
|
-
|
289
|
-
:warning: at some point this function will probably return an iterator
|
290
|
-
"""
|
291
|
-
stream = open(path, 'U')
|
292
|
-
result = stream_lines(stream, comments)
|
293
|
-
stream.close()
|
294
|
-
return result
|
295
|
-
|
296
|
-
|
297
|
-
def stream_lines(stream, comments=None):
|
298
|
-
"""Return a list of non empty lines in the given `stream`.
|
299
|
-
|
300
|
-
:type stream: object implementing 'xreadlines' or 'readlines'
|
301
|
-
:param stream: file like object
|
302
|
-
|
303
|
-
:type comments: str or None
|
304
|
-
:param comments:
|
305
|
-
optional string which can be used to comment a line in the file
|
306
|
-
(i.e. lines starting with this string won't be returned)
|
307
|
-
|
308
|
-
:rtype: list
|
309
|
-
:return:
|
310
|
-
a list of stripped line in the file, without empty and commented
|
311
|
-
lines
|
312
|
-
|
313
|
-
:warning: at some point this function will probably return an iterator
|
314
|
-
"""
|
315
|
-
try:
|
316
|
-
readlines = stream.xreadlines
|
317
|
-
except AttributeError:
|
318
|
-
readlines = stream.readlines
|
319
|
-
result = []
|
320
|
-
for line in readlines():
|
321
|
-
line = line.strip()
|
322
|
-
if line and (comments is None or not line.startswith(comments)):
|
323
|
-
result.append(line)
|
324
|
-
return result
|
325
|
-
|
326
|
-
|
327
|
-
def export(from_dir, to_dir,
|
328
|
-
blacklist=BASE_BLACKLIST, ignore_ext=IGNORED_EXTENSIONS,
|
329
|
-
verbose=0):
|
330
|
-
"""Make a mirror of `from_dir` in `to_dir`, omitting directories and
|
331
|
-
files listed in the black list or ending with one of the given
|
332
|
-
extensions.
|
333
|
-
|
334
|
-
:type from_dir: str
|
335
|
-
:param from_dir: directory to export
|
336
|
-
|
337
|
-
:type to_dir: str
|
338
|
-
:param to_dir: destination directory
|
339
|
-
|
340
|
-
:type blacklist: list or tuple
|
341
|
-
:param blacklist:
|
342
|
-
list of files or directories to ignore, default to the content of
|
343
|
-
`BASE_BLACKLIST`
|
344
|
-
|
345
|
-
:type ignore_ext: list or tuple
|
346
|
-
:param ignore_ext:
|
347
|
-
list of extensions to ignore, default to the content of
|
348
|
-
`IGNORED_EXTENSIONS`
|
349
|
-
|
350
|
-
:type verbose: bool
|
351
|
-
:param verbose:
|
352
|
-
flag indicating whether information about exported files should be
|
353
|
-
printed to stderr, default to False
|
354
|
-
"""
|
355
|
-
try:
|
356
|
-
mkdir(to_dir)
|
357
|
-
except OSError:
|
358
|
-
pass # FIXME we should use "exists" if the point is about existing dir
|
359
|
-
# else (permission problems?) shouldn't return / raise ?
|
360
|
-
for directory, dirnames, filenames in walk(from_dir):
|
361
|
-
for norecurs in blacklist:
|
362
|
-
try:
|
363
|
-
dirnames.remove(norecurs)
|
364
|
-
except ValueError:
|
365
|
-
continue
|
366
|
-
for dirname in dirnames:
|
367
|
-
src = join(directory, dirname)
|
368
|
-
dest = to_dir + src[len(from_dir):]
|
369
|
-
if isdir(src):
|
370
|
-
if not exists(dest):
|
371
|
-
mkdir(dest)
|
372
|
-
for filename in filenames:
|
373
|
-
# don't include binary files
|
374
|
-
# endswith does not accept tuple in 2.4
|
375
|
-
if any([filename.endswith(ext) for ext in ignore_ext]):
|
376
|
-
continue
|
377
|
-
src = join(directory, filename)
|
378
|
-
dest = to_dir + src[len(from_dir):]
|
379
|
-
if verbose:
|
380
|
-
print(src, '->', dest, file=sys.stderr)
|
381
|
-
if exists(dest):
|
382
|
-
remove(dest)
|
383
|
-
shutil.copy2(src, dest)
|
384
|
-
|
385
|
-
|
386
|
-
def remove_dead_links(directory, verbose=0):
|
387
|
-
"""Recursively traverse directory and remove all dead links.
|
388
|
-
|
389
|
-
:type directory: str
|
390
|
-
:param directory: directory to cleanup
|
391
|
-
|
392
|
-
:type verbose: bool
|
393
|
-
:param verbose:
|
394
|
-
flag indicating whether information about deleted links should be
|
395
|
-
printed to stderr, default to False
|
396
|
-
"""
|
397
|
-
for dirpath, dirname, filenames in walk(directory):
|
398
|
-
for filename in dirnames + filenames:
|
399
|
-
src = join(dirpath, filename)
|
400
|
-
if islink(src) and not exists(src):
|
401
|
-
if verbose:
|
402
|
-
print('remove dead link', src)
|
403
|
-
remove(src)
|
404
|
-
|