Construct is a Python library for the construction and deconstruction of data structures in a declarative fashion. In this context, construction, or building, refers to the process of converting a programmatic object into a binary representation. Deconstruction, or parsing, refers to the opposite process of converting binary data into a programmatic object. Being declarative means that user code defines the data structure, instead of the convention of writing procedural code to accomplish the goal. Construct can work seamlessly with bit- and byte-level data granularity and various byte-ordering. Using declarative code has many benefits. For example, the same code that can parse can also build, debugging and testing are much simpler, creating new constructs is easy, and many more. If one is familiar with the C, one can think of constructs as casting from char * to structfoo * and vice versa, rather than writing code that unpacks the data.
Example
The following example show how a TCP/IP protocol stack might be defined using Construct; some code is omitted for brevity and simplicity. Also note that the following code is just Python code that creates objects. First, the Ethernet header : ethernet = Struct, Bytes, Enum, )
Next, the IP header : ip = Struct, ), BitStruct, Flag, Flag, Flag, Flag, Padding, ), UBInt16, #... )
And finally, the TCP header : tcp = Struct, UBInt16, UBInt32, UBInt32, #... )
Now define the hierarchy of the protocol stack. The following code "binds" each pair of adjacent protocols into a separate unit. Each such unit will "select" the proper next layer based on its contained protocol. layer4tcp = Struct layer3ip = Struct, Switch, ) layer2ethernet = Struct, Switch, )
At this point, the code can parse captured TCP/IP frames into "packet" objects and build these packet objects back into binary representation. tcpip_stack = layer2ethernet pkt = tcpip_stack.parse raw_data = tcpip_stack.build
is a CPAN module that originated as a port of Construct to the Perl programming language.. Since the initial version, some parts of the original API have been deprecated.
Java
A port to Java is available on . Examples in Java, the Ethernetheader : Construct ethernet_header = Struct, MacAddress, Enum);