This file is indexed.

/usr/share/pyshared/allmydata/util/abbreviate.py is in tahoe-lafs 1.9.2-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import re

HOUR = 3600
DAY = 24*3600
WEEK = 7*DAY
MONTH = 30*DAY
YEAR = 365*DAY

def abbreviate_time(s):
    def _plural(count, unit):
        count = int(count)
        if count == 1:
            return "%d %s" % (count, unit)
        return "%d %ss" % (count, unit)
    if s is None:
        return "unknown"
    if s < 120:
        return _plural(s, "second")
    if s < 3*HOUR:
        return _plural(s/60, "minute")
    if s < 2*DAY:
        return _plural(s/HOUR, "hour")
    if s < 2*MONTH:
        return _plural(s/DAY, "day")
    if s < 4*YEAR:
        return _plural(s/MONTH, "month")
    return _plural(s/YEAR, "year")

def abbreviate_space(s, SI=True):
    if s is None:
        return "unknown"
    if SI:
        U = 1000.0
        isuffix = "B"
    else:
        U = 1024.0
        isuffix = "iB"
    def r(count, suffix):
        return "%.2f %s%s" % (count, suffix, isuffix)

    if s < 1024: # 1000-1023 get emitted as bytes, even in SI mode
        return "%d B" % s
    if s < U*U:
        return r(s/U, "k")
    if s < U*U*U:
        return r(s/(U*U), "M")
    if s < U*U*U*U:
        return r(s/(U*U*U), "G")
    if s < U*U*U*U*U:
        return r(s/(U*U*U*U), "T")
    return r(s/(U*U*U*U*U), "P")

def abbreviate_space_both(s):
    return "(%s, %s)" % (abbreviate_space(s, True),
                         abbreviate_space(s, False))

def parse_abbreviated_size(s):
    if s is None or s == "":
        return None
    m = re.match(r"^(\d+)([kKmMgG]?[iB]?[bB]?)$", s)
    if not m:
        raise ValueError("unparseable value %s" % s)
    number, suffix = m.groups()
    suffix = suffix.upper()
    if suffix.endswith("B"):
        suffix = suffix[:-1]
    multiplier = {"": 1,
                  "I": 1,
                  "K": 1000,
                  "M": 1000 * 1000,
                  "G": 1000 * 1000 * 1000,
                  "KI": 1024,
                  "MI": 1024*1024,
                  "GI": 1024*1024*1024,
                  }[suffix]
    return int(number) * multiplier