mirror of
https://github.com/facebook/sapling.git
synced 2024-10-12 01:39:21 +03:00
584656dff3
Summary: Turned on the auto formatter. Ran `arc lint --apply-patches --take BLACK **/*.py`. Then run `arc lint` again so some other autofixers like spellchecker etc. looked at the code base. Manually accept the changes whenever they make sense, or use a workaround (ex. changing "dict()" to "dict constructor") where autofix is false positive. Disabled linters on files that are hard (i18n/polib.py) to fix, or less interesting to fix (hgsubversion tests), or cannot be fixed without breaking OSS build (FBPYTHON4). Conflicted linters (test-check-module-imports.t, part of test-check-code.t, test-check-pyflakes.t) are removed or disabled. Duplicated linters (test-check-pyflakes.t, test-check-pylint.t) are removed. An issue of the auto-formatter is lines are no longer guarnateed to be <= 80 chars. But that seems less important comparing with the benefit auto-formatter provides. As we're here, also remove test-check-py3-compat.t, as it is currently broken if `PYTHON3=/bin/python3` is set. Reviewed By: wez, phillco, simpkins, pkaush, singhsrb Differential Revision: D8173629 fbshipit-source-id: 90e248ae0c5e6eaadbe25520a6ee42d32005621b
65 lines
1.8 KiB
Python
65 lines
1.8 KiB
Python
# age.py
|
|
#
|
|
# Copyright 2017 Facebook, Inc.
|
|
#
|
|
# This software may be used and distributed according to the terms of the
|
|
# GNU General Public License version 2 or any later version.
|
|
"""
|
|
a revset predicate for filtering by changeset age.
|
|
|
|
Adds the `age()` revset predicate.
|
|
|
|
This revset predicate differs from the built-in `date` by providing a more
|
|
granular way of considering relative time rather than absolute time.
|
|
|
|
The built-in `date()` predicate does provide full day resolution, so
|
|
`age("<Xd")` is equivalent to `date("-X")`.
|
|
"""
|
|
|
|
from __future__ import absolute_import
|
|
|
|
import re
|
|
import time
|
|
|
|
from mercurial import error, registrar, revsetlang
|
|
|
|
|
|
revsetpredicate = registrar.revsetpredicate()
|
|
|
|
_rangeparser = re.compile(r"^([<>])(?:(\d+)d)?(?:(\d+)h)?(?:(\d+)m)?(?:(\d+)s?)?$")
|
|
|
|
|
|
@revsetpredicate("age(string)")
|
|
def age(repo, subset, x):
|
|
"""Changesets that are older or newer than a specific age.
|
|
|
|
The age range can be specified in days, hours, minutes or seconds:
|
|
|
|
- ``<30d`` : Newer than 30 days old
|
|
- ``>4h30m``: Older than 4 hours 30 minutes old
|
|
- ``<15s`` : Newer than 15 seconds old
|
|
|
|
If no unit is specified, seconds are assumed.
|
|
"""
|
|
agerange = revsetlang.getstring(x, "age requires an age range")
|
|
m = _rangeparser.match(agerange)
|
|
if not m:
|
|
raise error.ParseError("invalid age range for age predicate")
|
|
dirn, days, hours, minutes, seconds = m.groups()
|
|
cutoff = time.time()
|
|
cutoff -= int(days or 0) * 60 * 60 * 24
|
|
cutoff -= int(hours or 0) * 60 * 60
|
|
cutoff -= int(minutes or 0) * 60
|
|
cutoff -= int(seconds or 0)
|
|
|
|
def newer(x):
|
|
return repo[x].date()[0] > cutoff
|
|
|
|
def older(x):
|
|
return repo[x].date()[0] < cutoff
|
|
|
|
if dirn == "<":
|
|
return subset.filter(newer, condrepr=("<age %r>", agerange))
|
|
else:
|
|
return subset.filter(older, condrepr=("<age %r>", agerange))
|