source: trunk/TouchOSC_LC/struct.py @ 11

Revision 11, 3.0 KB checked in by st8, 13 months ago (diff)

Added prelim TouchOSC script

Line 
1"""
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
53
54def 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
65def pack_into(fmt, buf, offset, *args):
66    """
67    Pack the values v1, v2, ... according to fmt, write
68    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)
75    return o.pack_into(buf, offset, *args)
76
77def 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)
88
89def 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)
99    return o.unpack_from(buf, offset)
Note: See TracBrowser for help on using the repository browser.