Utilitiesο
A small set of helpers exposed under PyMemoryEditor.util for advanced
callers that want to operate on bytes directly β convert between Python and
ctypes types, compile AOB patterns without a live process, or chunk an
arbitrary region for scanning.
from PyMemoryEditor.util import (
resolve_bufflength,
convert_from_byte_array,
value_to_bytes,
values_to_bytes,
get_c_type_of,
compile_pattern,
iter_region_chunks,
scan_memory,
scan_memory_for_exact_value,
PatternLike,
DEFAULT_MAX_REGION_CHUNK,
)
Type conversionο
- resolve_bufflength(pytype, bufflength)ο
Return a concrete buffer length: the caller-provided value, or the default for numeric
pytypewhenbufflengthisNone.- Raises:
ValueError β
bufflengthis required forpytype=str/pytype=bytes.
- convert_from_byte_array(byte_array, pytype, length)ο
Convert a ctypes byte array to a Python value of type
pytype. String decoding useserrors="replace".
- value_to_bytes(pytype, bufflength, value)ο
Encode a single value as fixed-width bytes using the same ctypes representation the backend compares against.
- values_to_bytes(pytype, bufflength, value)ο
Convert either a single value or a tuple of values (for
VALUE_BETWEEN/NOT_VALUE_BETWEEN) to the corresponding byte form.
- get_c_type_of(pytype, length)ο
Return the underlying ctypes object for the given Python type and width.
Pattern compilationο
- compile_pattern(pattern, *, byte_length=0)ο
Compile
patterninto a(re.Pattern[bytes], byte_length)pair.- Parameters:
pattern β an IDA-style hex string, a raw bytes regex, or a compiled
re.Pattern[bytes].byte_length (int) β required for regex / compiled patterns β the number of bytes one match consumes.
- Raises:
ValueError β malformed IDA-style token, or
byte_lengthomitted for a regex / pre-compiled pattern.
Exampleο
from PyMemoryEditor.util import compile_pattern
regex, byte_length = compile_pattern("48 8B ? 00 00")
print(regex.pattern) # b'\\x48\\x8B.\\x00\\x00'
print(byte_length) # 5
- PatternLikeο
Type alias:
Union[str, bytes, re.Pattern[bytes]]. The set of input formscompile_patternaccepts.
Region chunkingο
- DEFAULT_MAX_REGION_CHUNKο
Maximum chunk size used by
iter_region_chunks()(currently 256 MiB). Tunes the trade-off between syscall overhead (small chunks) and peak memory use (huge chunks).
- iter_region_chunks(region_size, target_value_size, max_chunk=DEFAULT_MAX_REGION_CHUNK)ο
Yield
(offset, chunk_size)pairs that walk a single memory region in bounded-size chunks. Regions up tomax_chunkyield a single chunk; larger ones are split into contiguous, non-overlapping chunks whose size is a multiple oftarget_value_sizeso a typed numeric scan never splits a value across a boundary. Boundary handling for patterns is done one level up by the scanner (it overlaps consecutive chunks bypattern_length - 1bytes); arbitrarystrmatches in a region larger thanmax_chunkmay still be missed at a chunk boundary β a documented limitation.
- scan_memory(...)ο
- scan_memory_for_exact_value(...)ο
Low-level scan kernels used by the backends. Public for advanced use only β the high-level
search_by_value()/search_by_pattern()methods are the recommended API.
Region predicatesο
The helpers in PyMemoryEditor.process.region operate on a raw platform
struct β the same struct field carried by a
MemoryRegion. Useful when youβve obtained a platform
descriptor outside the normal flow and want to compute the portable booleans
yourself.
from PyMemoryEditor.process.region import (
is_region_readable,
is_region_writable,
is_region_executable,
is_region_shared,
region_path,
make_region,
)
- is_region_readable(struct)ο
- is_region_writable(struct)ο
- is_region_executable(struct)ο
True/False from a platform descriptor (
MEMORY_BASIC_INFORMATIONon Windows/Linux; the VM struct on macOS). For a fully-populated region, prefer the boolean attributes onMemoryRegion(region.is_readable, etc.).
- region_path(struct)ο
Best-effort path of the file backing the region, or
""when unknown (Linux only β Windows/macOS would need extra syscalls).
- make_region(address, size, struct)ο
Build a fully-populated
MemoryRegionfrom a platform struct. The four boolean fields andpathare computed once via the predicates above. Backends call this once per region; user code rarely needs it.
See also