blob: 07c21bf9bc3f019f077aff04f7f017ef4cb48bca [file] [log] [blame]
Bob Ippolito232f3c92006-05-23 19:12:41 +00001"""
2Functions to convert between Python values and C structs.
3Python strings are used to hold the data representing the C struct
4and also as format strings to describe the layout of data in the C struct.
5
6The optional first format char indicates byte order, size and alignment:
7 @: native order, size & alignment (default)
8 =: native order, std. size & alignment
9 <: little-endian, std. size & alignment
10 >: big-endian, std. size & alignment
11 !: same as >
12
13The remaining chars indicate types of args and must match exactly;
14these can be preceded by a decimal repeat count:
15 x: pad byte (no data); c:char; b:signed byte; B:unsigned byte;
16 h:short; H:unsigned short; i:int; I:unsigned int;
17 l:long; L:unsigned long; f:float; d:double.
18Special cases (preceding decimal count indicates length):
19 s:string (array of char); p: pascal string (with count byte).
20Special case (only available in native format):
21 P:an integer type that is wide enough to hold a pointer.
22Special case (not in native mode unless 'long long' in platform C):
23 q:long long; Q:unsigned long long
24Whitespace between formats is ignored.
25
26The variable struct.error is an exception raised on errors.
27"""
28__version__ = '0.1'
29
30from _struct import Struct, error
31
32_MAXCACHE = 100
33_cache = {}
34
35def _compile(fmt):
36 # Internal: compile struct pattern
37 if len(_cache) >= _MAXCACHE:
38 _cache.clear()
39 s = Struct(fmt)
40 _cache[fmt] = s
41 return s
42
43def calcsize(fmt):
44 """
45 Return size of C struct described by format string fmt.
46 See struct.__doc__ for more on format strings.
47 """
48 try:
49 o = _cache[fmt]
50 except KeyError:
51 o = _compile(fmt)
52 return o.size
Tim Peters211219a2006-05-23 21:54:23 +000053
Bob Ippolito232f3c92006-05-23 19:12:41 +000054def pack(fmt, *args):
55 """
56 Return string containing values v1, v2, ... packed according to fmt.
57 See struct.__doc__ for more on format strings.
58 """
59 try:
60 o = _cache[fmt]
61 except KeyError:
62 o = _compile(fmt)
63 return o.pack(*args)
64
Martin Blaisaf2ae722006-06-04 13:49:49 +000065def pack_into(fmt, buf, offset, *args):
Bob Ippolito1fcdc232006-05-27 12:11:36 +000066 """
George Yoshida499b0e62006-07-30 16:41:30 +000067 Pack the values v1, v2, ... according to fmt, write
Bob Ippolito1fcdc232006-05-27 12:11:36 +000068 the packed bytes into the writable buffer buf starting at offset.
69 See struct.__doc__ for more on format strings.
70 """
71 try:
72 o = _cache[fmt]
73 except KeyError:
74 o = _compile(fmt)
Martin Blaisaf2ae722006-06-04 13:49:49 +000075 return o.pack_into(buf, offset, *args)
Bob Ippolito1fcdc232006-05-27 12:11:36 +000076
Bob Ippolito232f3c92006-05-23 19:12:41 +000077def unpack(fmt, s):
78 """
79 Unpack the string, containing packed C structure data, according
80 to fmt. Requires len(string)==calcsize(fmt).
81 See struct.__doc__ for more on format strings.
82 """
83 try:
84 o = _cache[fmt]
85 except KeyError:
86 o = _compile(fmt)
87 return o.unpack(s)
Tim Petersf47b1cd2006-05-24 20:29:44 +000088
Bob Ippolitoeb621272006-05-24 15:32:06 +000089def unpack_from(fmt, buf, offset=0):
90 """
91 Unpack the buffer, containing packed C structure data, according to
92 fmt starting at offset. Requires len(buffer[offset:]) >= calcsize(fmt).
93 See struct.__doc__ for more on format strings.
94 """
95 try:
96 o = _cache[fmt]
97 except KeyError:
98 o = _compile(fmt)
Tim Petersf47b1cd2006-05-24 20:29:44 +000099 return o.unpack_from(buf, offset)