The c-call
package exports these type-equivalents to the C type
of the same name: char
, short
, int
, long
,
signed-char
, unsigned-char
, unsigned-short
, unsigned-int
,
unsigned-long
, float
, double
. Note that
char
and signed-char
are the same type, i.e, both are
signed characters. c-call
also
exports these types:
This type is used in function types to declare that no useful value
is returned. Evaluation of an alien-funcall
form will return
zero values.
This type is similar to (* char)
, but is interpreted as a
null-terminated string, and is automatically converted into a Lisp
string when accessed. If the pointer is C NULL
(or 0), then
accessing gives Lisp nil
.
With Unicode, a Lisp string is not the same as a C string since a
Lisp string uses two bytes for each character. In this case, a
C string is converted to a Lisp string by taking each byte of the
C-string and applying code-char
to create each character of
the Lisp string.
Similarly, a Lisp string is converted to a C string by taking the
low 8 bits of the char-code
of each character and assigning
that to each byte of the C string.
In either case, string-encode
and string-decode
may be
useful to convert Unicode Lisp strings to or from C strings.
Assigning a Lisp string to a c-string
structure field or
variable stores the contents of the string to the memory already
pointed to by that variable. When an Alien of type (* char)
is assigned to a c-string
, then the c-string
pointer
is assigned to. This allows c-string
pointers to be
initialized. For example:
(def-alien-type nil (struct foo (str c-string))) (defun make-foo (str) (let ((my-foo (make-alien (struct foo)))) (setf (slot my-foo 'str) (make-alien char (length str))) (setf (slot my-foo 'str) str) my-foo))
Storing Lisp nil
writes C NULL
to the c-string
pointer.