Allocates memory for an instance of a foreign object within the scope of a with-dynamic-foreign-objects
macro.
allocate-dynamic-foreign-object &key type pointer-type
initial-element initial-contents
nelems => pointer
An FLI type specifying the type of the object to be allocated. If type is supplied, pointer-type must not be supplied.
An FLI pointer type specifying the type of the pointer object to be allocated. If pointer-type is supplied, type must not be supplied.
A keyword setting the initial value of every element in the newly allocated object to initial-element .
A list of forms which initialize the contents of each element in the newly allocated object.
An integer specifying how many copies of the object should be allocated. The default value is 1.
The function allocate-dynamic-foreign-object
allocates memory for a new instance of an object of type type or an instance of a pointer object of type pointer-type within the scope of the body of the macro with-dynamic-foreign-object
. Once this macro has executed, the memory allocated using allocate-dynamic-foreign-object
is therefore automatically freed for other uses.
A full example using with-dynamic-foreign-objects
and allocate-dynamic-foreign-object
is given in An example of dynamic memory allocation.