pack(p1) public

Packs the contents of arr into a binary sequence according to the directives in aTemplateString (see the table below) Directives “A,” “a,” and “Z” may be followed by a count, which gives the width of the resulting field. The remaining directives also may take a count, indicating the number of array elements to convert. If the count is an asterisk (“*”), all remaining array elements will be converted. Any of the directives “sSiIlL” may be followed by an underscore (“_”) to use the underlying platform’s native size for the specified type; otherwise, they use a platform-independent size. Spaces are ignored in the template string. See also String#unpack.

a = [ "a", "b", "c" ]
n = [ 65, 66, 67 ]
a.pack("A3A3A3")   #=> "a  b  c  "
a.pack("a3a3a3")   #=> "a\000\000b\000\000c\000\000"
n.pack("ccc")      #=> "ABC"

Directives for pack.

Integer   | Array   |
Directive | Element | Meaning
------------------------------------------------------------------------
   C      | Integer | 8-bit unsigned integer (unsigned char)
   S      | Integer | 16-bit unsigned integer, native endian (uint16_t)
   L      | Integer | 32-bit unsigned integer, native endian (uint32_t)
   Q      | Integer | 64-bit unsigned integer, native endian (uint64_t)
          |         |
   c      | Integer | 8-bit signed integer (char)
   s      | Integer | 16-bit signed integer, native endian (int16_t)
   l      | Integer | 32-bit signed integer, native endian (int32_t)
   q      | Integer | 64-bit signed integer, native endian (int64_t)
          |         | 
   S_     | Integer | unsigned short, native endian
   I, I_  | Integer | unsigned int, native endian
   L_     | Integer | unsigned long, native endian
          |         |
   s_     | Integer | signed short, native endian
   i, i_  | Integer | signed int, native endian
   l_     | Integer | signed long, native endian
          |         |
   n      | Integer | 16-bit unsigned integer, network (big-endian) byte order
   N      | Integer | 32-bit unsigned integer, network (big-endian) byte order
   v      | Integer | 16-bit unsigned integer, VAX (little-endian) byte order
   V      | Integer | 32-bit unsigned integer, VAX (little-endian) byte order
          |         |
   U      | Integer | UTF-8 character
   w      | Integer | BER-compressed integer

Float     |         |
Directive |         | Meaning
------------------------------------------------------------------------
   D, d   | Float   | double-precision float, native format
   F, f   | Float   | single-precision float, native format
   E      | Float   | double-precision float, little-endian byte order
   e      | Float   | single-precision float, little-endian byte order
   G      | Float   | double-precision float, network (big-endian) byte order
   g      | Float   | single-precision float, network (big-endian) byte order

String    |         |
Directive |         | Meaning
------------------------------------------------------------------------
   A      | String  | arbitrary binary string (space padded, count is width)
   a      | String  | arbitrary binary string (null padded, count is width)
   Z      | String  | same as ``a'', except that null is added with *
   B      | String  | bit string (MSB first)
   b      | String  | bit string (LSB first)
   H      | String  | hex string (high nibble first)
   h      | String  | hex string (low nibble first)
   u      | String  | UU-encoded string
   M      | String  | quoted printable, MIME encoding (see RFC2045)
   m      | String  | base64 encoded string (see RFC 2045, count is width)
   P      | String  | pointer to a structure (fixed-length string)
   p      | String  | pointer to a null-terminated string

Misc.     |         |
Directive |         | Meaning
------------------------------------------------------------------------
   @      | ---     | moves to absolute position
   X      | ---     | back up a byte
   x      | ---     | null byte
Show source
Register or log in to add new notes.