##// END OF EJS Templates
nodemap: also use persistent nodemap for manifest...
nodemap: also use persistent nodemap for manifest The manifest as a different usage pattern than the changelog. First, while the lookup in changelog are not garanteed to match, the lookup in the manifest nodemap come from changelog and will exist in the manifest. In addition, looking up a manifest almost always result in unpacking a manifest an operation that rarely come cheap. Nevertheless, using a persistent nodemap provide a significant gain for some operations. For our measurementw, we use `hg cat --rev REV FILE` on the our reference mozilla-try. On this repository the persistent nodemap cache is about 29 MB in side for a total store side of 11,988 MB File with large history (file: b2g/config/gaia.json, revision: 195a1146daa0) no optimisation: 0.358s using mmap for index: 0.297s (-0.061s) persistent nodemap for changelog only: 0.275s (-0.024s) persistent nodemap for manifest too: 0.258s (-0.017s) File with small history (file: .hgignore, revision: 195a1146daa0) no optimisation: 0.377s using mmap for index: 0.296s (-0.061s) persistent nodemap for changelog only: 0.274s (-0.022s) persistent nodemap for manifest too: 0.257s (-0.017s) Same file but using a revision (8ba995b74e18) with a smaller manifest (3944829 bytes vs 10 bytes) no optimisation: 0.192s (-0.185s) using mmap for index: 0.131s (-0.061s) persistent nodemap for changelog only: 0.106s (-0.025s) persistent nodemap for manifest too: 0.087s (-0.019s) Differential Revision: https://phab.mercurial-scm.org/D8410

File last commit:

r37195:68ee6182 default
r45290:640d5b3b default
Show More
mapping.py
128 lines | 3.4 KiB | text/x-python | PythonLexer
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 ##############################################################################
#
# Copyright (c) 2001, 2002 Zope Foundation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
"""Mapping Interfaces
"""
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
from __future__ import absolute_import
from .. import Interface
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193
class IItemMapping(Interface):
"""Simplest readable mapping object
"""
def __getitem__(key):
"""Get a value for a key
A KeyError is raised if there is no value for the key.
"""
class IReadMapping(IItemMapping):
"""Basic mapping interface
"""
def get(key, default=None):
"""Get a value for a key
The default is returned if there is no value for the key.
"""
def __contains__(key):
"""Tell if a key exists in the mapping."""
class IWriteMapping(Interface):
"""Mapping methods for changing data"""
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def __delitem__(key):
"""Delete a value from the mapping using the key."""
def __setitem__(key, value):
"""Set a new item in the mapping."""
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193
class IEnumerableMapping(IReadMapping):
"""Mapping objects whose items can be enumerated.
"""
def keys():
"""Return the keys of the mapping object.
"""
def __iter__():
"""Return an iterator for the keys of the mapping object.
"""
def values():
"""Return the values of the mapping object.
"""
def items():
"""Return the items of the mapping object.
"""
def __len__():
"""Return the number of items.
"""
class IMapping(IWriteMapping, IEnumerableMapping):
''' Simple mapping interface '''
class IIterableMapping(IEnumerableMapping):
def iterkeys():
"iterate over keys; equivalent to __iter__"
def itervalues():
"iterate over values"
def iteritems():
"iterate over items"
class IClonableMapping(Interface):
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def copy():
"return copy of dict"
class IExtendedReadMapping(IIterableMapping):
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def has_key(key):
"""Tell if a key exists in the mapping; equivalent to __contains__"""
class IExtendedWriteMapping(IWriteMapping):
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def clear():
"delete all items"
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def update(d):
" Update D from E: for k in E.keys(): D[k] = E[k]"
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def setdefault(key, default=None):
"D.setdefault(k[,d]) -> D.get(k,d), also set D[k]=d if k not in D"
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def pop(k, *args):
"""remove specified key and return the corresponding value
*args may contain a single default value, or may not be supplied.
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195 If key is not found, default is returned if given, otherwise
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 KeyError is raised"""
Gregory Szorc
thirdparty: port zope.interface to relative imports...
r37195
Gregory Szorc
thirdparty: vendor zope.interface 4.4.3...
r37193 def popitem():
"""remove and return some (key, value) pair as a
2-tuple; but raise KeyError if mapping is empty"""
class IFullMapping(
IExtendedReadMapping, IExtendedWriteMapping, IClonableMapping, IMapping):
''' Full mapping interface ''' # IMapping included so tests for IMapping
# succeed with IFullMapping