1.3 KiB
Memory Model
This document provides an overview of the memory model of libCwtch. Callers should consult this document to ensure that they are properly handling pointers passed to-and-from libCwtch.
Pointer Parameters
All pointers passed into functions in this library, except c_FreePointer
, are assumed to be owned by the caller.
libCwtch will not modifying the underlying memory, nor attempt to free or otherwise modify these pointers.
This is realized by copying the underlying memory using C.GoStringN
. libCwtch guarantees that it will not depend
on the underlying memory of these pointers being available after returning from this function.
Callers are responsible for freeing these pointers after the call has been completed.
Returned Pointers
All pointers returned by functions in libCwtch should be assumed to owned by libCwtch
Callers must not modifying the underlying memory of these pointers, nor attempt to free or otherwise modify these pointers through any method other than the one provided below.
Calling functions must copy the contents of the memory into their own memory space and then call c_FreePointer
providing
the returned pointer as a parameter.
libCwtch guarantees that it will not modify or free the underlying memory of these pointers prior to a call to c_FreePointer
.