|  | Home | Libraries | People | FAQ | More | 
The binary native endianness generators described in this section are used to emit binary byte streams laid out conforming to the native endianness (byte order) of the target architecture.
// forwards to <boost/spirit/home/karma/binary.hpp> #include <boost/spirit/include/karma_binary.hpp>
Also, see Include Structure.
| Name | 
|---|
| 
                       | 
| 
                       | 
| 
                       | 
| 
                       | 
| 
                       | 
| 
                       | 
| ![[Note]](../../../../images/note.png) | Note | 
|---|---|
| 
              The generators  | 
Notation
bA single byte (8 bit binary value) or a Lazy Argument that evaluates to a single byte
wA 16 bit binary value or a Lazy Argument that evaluates to a 16 bit binary value. This value is always interpreted using native endianness.
dwA 32 bit binary value or a Lazy Argument that evaluates to a 32 bit binary value. This value is always interpreted using native endianness.
qwA 64 bit binary value or a Lazy Argument that evaluates to a 64 bit binary value. This value is always interpreted using native endianness.
fA float binary value or a Lazy Argument that evaluates to a float binary value. This value is always interpreted using native endianness.
dA double binary value or a Lazy Argument that evaluates to a double binary value. This value is always interpreted using native endianness.
            Semantics of an expression is defined only where it differs from, or
            is not defined in PrimitiveGenerator.
          
| Expression | Description | 
|---|---|
| 
                       | Output the binary representation of the least significant byte of the mandatory attribute. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant 16 bits of the mandatory attribute in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant 32 bits of the mandatory attribute in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant 64 bits of the mandatory attribute in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the mandatory float attribute in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the mandatory double attribute in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant byte of the immediate parameter. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant 16 bits of the immediate parameter in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant 32 bits of the immediate parameter in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the least significant 64 bits of the immediate parameter in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the immediate float parameter in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| 
                       | Output the binary representation of the immediate double parameter in native endian representation. This generator never fails (unless the underlying output stream reports an error). | 
| Expression | Attribute | 
|---|---|
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| 
                       | 
                       | 
| ![[Note]](../../../../images/note.png) | Note | 
|---|---|
| 
              In addition to their usual attribute of type  | 
O(N), where N is the number of bytes emitted by the binary generator
| ![[Note]](../../../../images/note.png) | Note | 
|---|---|
| The test harness for the example(s) below is presented in the Basics Examples section. | 
Some includes:
#include <boost/spirit/include/karma.hpp> #include <boost/spirit/include/support_utree.hpp> #include <boost/phoenix/core.hpp> #include <boost/phoenix/operator.hpp> #include <boost/fusion/include/std_pair.hpp> #include <boost/proto/deep_copy.hpp> #include <iostream> #include <string>
Some using declarations:
using boost::spirit::karma::byte_; using boost::spirit::karma::word; using boost::spirit::karma::dword; using boost::spirit::karma::qword;
Basic usage of the native binary generators with some results for little endian platforms:
test_binary_generator("\x01", 1, byte_(0x01)); test_binary_generator("\x01\x02", 2, word(0x0201)); test_binary_generator("\x01\x02\x03\x04", 4, dword(0x04030201)); test_binary_generator("\x01\x02\x03\x04\x05\x06\x07\x08", 8, qword(0x0807060504030201LL)); test_binary_generator_attr("\x01", 1, byte_, 0x01); test_binary_generator_attr("\x01\x02", 2, word, 0x0201); test_binary_generator_attr("\x01\x02\x03\x04", 4, dword, 0x04030201); test_binary_generator_attr("\x01\x02\x03\x04\x05\x06\x07\x08", 8, qword, 0x0807060504030201LL);
Basic usage of the native binary generators with some results for big endian platforms:
test_binary_generator("\x01", 1, byte_(0x01)); test_binary_generator("\x02\x01", 2, word(0x0201)); test_binary_generator("\x04\x03\x02\x01", 4, dword(0x04030201)); test_binary_generator("\x08\x07\x06\x05\x04\x03\x02\x01", 8, qword(0x0807060504030201LL)); test_binary_generator_attr("\x01", 1, byte_, 0x01); test_binary_generator_attr("\x02\x01", 2, word, 0x0201); test_binary_generator_attr("\x04\x03\x02\x01", 4, dword, 0x04030201); test_binary_generator_attr("\x08\x07\x06\x05\x04\x03\x02\x01", 8, qword, 0x0807060504030201LL);