A downloadable asset pack

Download NowName your own price

[INFO]

This asset is composed by a set of buffer functions that allow for complex buffer parsing. Functions allow to seek and match patterns, copy regions (using read format and padding) and read into array everything at byte level.

[FUNCTIONS]

buffer_pattern_create(str);

This function allow to create seeking and matching patterns. Allows hexadecimal input and wild bytes. A pattern example is "F6 3C 3D ?? ?? 77" this will allow to seek/match bytes that match the pattern were ?? are wild bytes (can be any byte).

buffer_block_format_create(str);

This function allow to create block format for copying. Allows FF/00 inputs where FF bytes are copied and 00 are jumped over. A format example is "FF 00 FF FF 00" this will copy an input example of "6B D0 8A FF 25" as "6B 8A FF" (ignoring 2nd and 5th bytes).

buffer_copy_until(src, pattern, dest, offset);

This function will copy a buffer from the current point up until the specified pattern is found into a destination buffer with a given offset position. The offset is optional (buffer_grow/buffer_wrap only) and defaults to the end of the destination buffer. Returns false if there is no final pattern match.

buffer_copy_until_ext(src, pattern, format, pad, dest, offset);

This function is similar to the previous one but allows for specifying a block format and also a padding between blocks. Note that this function will only copy entire blocks, if the last block ends middle way that block won't be copied. Returns false if there is no final pattern match.

buffer_seek_pattern(buffer, pattern, after, step);

This function will step through the buffer until it matches a given pattern. The optional parameters allow for specifying if the cursor should be left after or before the match, and the step is the number of bytes that should be jumped when the match doesn't occur. Returns false if there is no match.

buffer_check_pattern(buffer, pattern, after);

This function will check the next bytes for the given pattern. The optional parameters allow for specifying if the cursor should be left after or before the match. Returns false if there is no match.

buffer_read_bytes(buffer, amount);

This function reads a given amount of bytes (default to 1) from the buffer and returns a byte array with each read byte.

[EXTRA FUNCTIONS]

These are functions that are included as bonus.

byte_to_hex(_value);

This function will convert a byte value to the corresponding hexadecimal string format. The input value can be both an array or a single value, it always returns an array of converted strings.

[SAMPLE PROJECT]

Included is a sample project that consists of a code example completely documented where some functionality is being used. This code is inside a test room creation code.

[COMPATIBILITY]

The asset is fully compatible with 2.3+ and is purely written in GML making it compatible with all exports available.

[TERMS OF PURCHASE]

  • You will receive free updates as they release on this website. 
  • The price may vary based on the marketplace.
  • Support, bug fix will be handled on a case-by-case basis at earliest possible.
  •  No parts of your purchase may be re-distributed, re-sold, or bundled with existing assets.

Download

Download NowName your own price

Click download now to get access to the following files:

xBufferFunctions.yymps 296 kB

Leave a comment

Log in with itch.io to leave a comment.