~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/_static_tuple_py.py

  • Committer: John Arbash Meinel
  • Date: 2010-08-04 04:33:24 UTC
  • mto: This revision was merged to the branch mainline in revision 5390.
  • Revision ID: john@arbash-meinel.com-20100804043324-1ldc2v2w1kza7ox4
get into the nitty gritty for the _key_to_sha1 function.

It doesn't seem to help to op-out of the actual unhexlify call, so at least
that doesn't seem to be the performance overhead.
We get down to around 19.9us for _key_to_sha1 across 120 keys, which is
0.166us per key.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2009 Canonical Ltd
 
1
# Copyright (C) 2009, 2010 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
34
34
 
35
35
    def __init__(self, *args):
36
36
        """Create a new 'StaticTuple'"""
 
37
        num_keys = len(args)
 
38
        if num_keys < 0 or num_keys > 255:
 
39
            raise TypeError('StaticTuple(...) takes from 0 to 255 items')
37
40
        for bit in args:
38
41
            if type(bit) not in (str, StaticTuple, unicode, int, long, float,
39
42
                                 None.__class__, bool):
40
43
                raise TypeError('StaticTuple can only point to'
41
44
                    ' StaticTuple, str, unicode, int, long, float, bool, or'
42
45
                    ' None not %s' % (type(bit),))
43
 
        num_keys = len(args)
44
 
        if num_keys < 0 or num_keys > 255:
45
 
            raise ValueError('must have 1 => 256 key bits')
46
46
        # We don't need to pass args to tuple.__init__, because that was
47
47
        # already handled in __new__.
48
48
        tuple.__init__(self)