1
# Copyright (C) 2009 Canonical Ltd
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
# GNU General Public License for more details.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
"""Interface thunk for a StaticTuple implementation."""
19
from bzrlib import debug
22
from bzrlib._static_tuple_c import StaticTuple
23
except ImportError, e:
24
from bzrlib import osutils
25
osutils.failed_to_load_extension(e)
26
from bzrlib._static_tuple_py import StaticTuple
29
def expect_static_tuple(obj):
30
"""Check if the passed object is a StaticTuple.
32
Cast it if necessary, but if the 'static_tuple' debug flag is set, raise an
35
As apis are improved, we will probably eventually stop calling this as it
36
adds overhead we shouldn't need.
38
if 'static_tuple' not in debug.debug_flags:
39
return StaticTuple.from_sequence(obj)
40
if type(obj) is not StaticTuple:
41
raise TypeError('We expected a StaticTuple not a %s' % (type(obj),))
46
"""Ensure that the object and any referenced objects are plain tuples.
48
:param obj: a list, tuple or StaticTuple
49
:return: a plain tuple instance, with all children also being tuples.
53
if isinstance(item, (tuple, list, StaticTuple)):
54
item = as_tuples(item)