##// END OF EJS Templates
statichttprepo: fix `httprangereader.read()` for py3...
statichttprepo: fix `httprangereader.read()` for py3 It looks like there were a bunch of problems, not all of them py3 related: 1) The signature of BinaryIO.read() is -1, not None 2) The `end` variable can't be bytes and interpolate into str with "%s" 3) The `end` variable can't be an int and interpolate into str with "%s" 4) The result slicing could be out of bounds if more is requested than returned I guess if somebody would have called `read(-1)` (either directly or because a wrapper defaults to that), it wouldn't have been handled correctly. The fact that it is a valid value meaning to read everything requires some additional changes later in the method around when it slices the byte string that was read, but that seems to have already been broken.

File last commit:

r52756:f4733654 default
r52792:e26a0856 default
Show More
__init__.py
91 lines | 2.4 KiB | text/x-python | PythonLexer
revlog: introduce an explicit NodeMap class for pure code...
r43924 # mercurial.revlogutils -- basic utilities for revlog
#
# Copyright 2019 Pierre-Yves David <pierre-yves.david@octobus.net>
#
# This software may be used and distributed according to the terms of the
# GNU General Public License version 2 or any later version.
Matt Harbison
typing: add `from __future__ import annotations` to most files...
r52756 from __future__ import annotations
revlog: move `offset_type` to `revlogutils`...
r48186
Matt Harbison
typing: induce pytype to use the standard `attr` instead of the vendored copy...
r52622 import typing
revlog: move `revisioninfo` in `revlogutils`...
r48191 from ..thirdparty import attr
Matt Harbison
typing: induce pytype to use the standard `attr` instead of the vendored copy...
r52622
# Force pytype to use the non-vendored package
if typing.TYPE_CHECKING:
# noinspection PyPackageRequirements
import attr
revlog: move `offset_type` to `revlogutils`...
r48186 from ..interfaces import repository
revlog: add a function to build index entry tuple...
r48187 # See mercurial.revlogutils.constants for doc
COMP_MODE_INLINE = 2
rank: add a "rank" value to the revlog-entry tuple...
r49330 RANK_UNKNOWN = -1
revlog: add a function to build index entry tuple...
r48187
revlog: move `offset_type` to `revlogutils`...
r48186
def offset_type(offset, type):
if (type & ~repository.REVISION_FLAGS_KNOWN) != 0:
raise ValueError(b'unknown revlog index flags: %d' % type)
return int(int(offset) << 16 | type)
revlog: add a function to build index entry tuple...
r48187
def entry(
data_offset,
data_compressed_length,
data_delta_base,
link_rev,
parent_rev_1,
parent_rev_2,
node_id,
flags=0,
data_uncompressed_length=-1,
data_compression_mode=COMP_MODE_INLINE,
sidedata_offset=0,
sidedata_compressed_length=0,
sidedata_compression_mode=COMP_MODE_INLINE,
rank: add a "rank" value to the revlog-entry tuple...
r49330 rank=RANK_UNKNOWN,
revlog: add a function to build index entry tuple...
r48187 ):
"""Build one entry from symbolic name
This is useful to abstract the actual detail of how we build the entry
tuple for caller who don't care about it.
This should always be called using keyword arguments. Some arguments have
default value, this match the value used by index version that does not store such data.
"""
return (
offset_type(data_offset, flags),
data_compressed_length,
data_uncompressed_length,
data_delta_base,
link_rev,
parent_rev_1,
parent_rev_2,
node_id,
sidedata_offset,
sidedata_compressed_length,
data_compression_mode,
sidedata_compression_mode,
rank: add a "rank" value to the revlog-entry tuple...
r49330 rank,
revlog: add a function to build index entry tuple...
r48187 )
revlog: move `revisioninfo` in `revlogutils`...
r48191
@attr.s(slots=True, frozen=True)
Gregory Szorc
py3: use class X: instead of class X(object):...
r49801 class revisioninfo:
revlog: move `revisioninfo` in `revlogutils`...
r48191 """Information about a revision that allows building its fulltext
node: expected hash of the revision
delta-find: clarify that revisioninfo.p1/p2 constains nodeid...
r52222 p1, p2: parent revs of the revision (as node)
revlog: move `revisioninfo` in `revlogutils`...
r48191 btext: built text cache consisting of a one-element list
find-delta: pass the cache-delta usage policy alongside the cache-delta...
r50572 cachedelta: (baserev, uncompressed_delta, usage_mode) or None
revlog: move `revisioninfo` in `revlogutils`...
r48191 flags: flags associated to the revision storage
One of btext[0] or cachedelta must be set.
"""
node = attr.ib()
p1 = attr.ib()
p2 = attr.ib()
btext = attr.ib()
textlen = attr.ib()
cachedelta = attr.ib()
flags = attr.ib()