Fix / Improve with-foreign-pointer-as-string in manual
[cffi.git] / doc / cffi-manual.texinfo
blob9b58a3ccb57a46ab7d8ab9804a54bc8f309d3425
1 \input texinfo   @c -*- Mode: Texinfo; Mode: auto-fill -*-
2 @c %**start of header
3 @setfilename cffi.info
4 @settitle CFFI User Manual
5 @exampleindent 2
7 @c @documentencoding utf-8
9 @c Style notes:
11 @c * The reference section names and "See Also" list are roman, not
12 @c   @code.  This is to follow the format of CLHS.
14 @c * How it looks in HTML is the priority.
16 @c ============================= Macros =============================
17 @c The following macros are used throughout this manual.
19 @macro Function {args}
20 @defun \args\
21 @end defun
22 @end macro
24 @macro Macro {args}
25 @defmac \args\
26 @end defmac
27 @end macro
29 @macro Accessor {args}
30 @deffn {Accessor} \args\
31 @end deffn
32 @end macro
34 @macro GenericFunction {args}
35 @deffn {Generic Function} \args\
36 @end deffn
37 @end macro
39 @macro ForeignType {args}
40 @deftp {Foreign Type} \args\
41 @end deftp
42 @end macro
44 @macro Variable {args}
45 @defvr {Special Variable} \args\
46 @end defvr
47 @end macro
49 @macro Condition {args}
50 @deftp {Condition Type} \args\
51 @end deftp
52 @end macro
54 @macro cffi
55 @acronym{CFFI}
56 @end macro
58 @macro impnote {text}
59 @quotation
60 @strong{Implementor's note:} @emph{\text\}
61 @end quotation
62 @end macro
64 @c Info "requires" that x-refs end in a period or comma, or ) in the
65 @c case of @pxref.  So the following implements that requirement for
66 @c the "See also" subheadings that permeate this manual, but only in
67 @c Info mode.
68 @ifinfo
69 @macro seealso {name}
70 @ref{\name\}.
71 @end macro
72 @end ifinfo
74 @ifnotinfo
75 @alias seealso = ref
76 @end ifnotinfo
78 @c Typeset comments in roman font for the TeX output.
79 @iftex
80 @alias lispcmt = r
81 @end iftex
82 @ifnottex
83 @alias lispcmt = asis
84 @end ifnottex
86 @alias res = result
88 @c ============================= Macros =============================
91 @c Show types, functions, and concepts in the same index.
92 @syncodeindex tp cp
93 @syncodeindex fn cp
95 @copying
96 Copyright @copyright{} 2005 James Bielman <jamesjb at jamesjb.com> @*
97 Copyright @copyright{} 2005-2015 Lu@'{@dotless{i}}s Oliveira
98   <loliveira at common-lisp.net> @*
99 Copyright @copyright{} 2005-2006 Dan Knapp <danka at accela.net> @*
100 Copyright @copyright{} 2005-2006 Emily Backes <lucca at accela.net> @*
101 Copyright @copyright{} 2006 Stephen Compall <s11 at member.fsf.org>
103 @quotation
104 Permission is hereby granted, free of charge, to any person obtaining
105 a copy of this software and associated documentation files (the
106 ``Software''), to deal in the Software without restriction, including
107 without limitation the rights to use, copy, modify, merge, publish,
108 distribute, sublicense, and/or sell copies of the Software, and to
109 permit persons to whom the Software is furnished to do so, subject to
110 the following conditions:
112 The above copyright notice and this permission notice shall be
113 included in all copies or substantial portions of the Software.
115 @sc{The software is provided ``as is'', without warranty of any kind,
116 express or implied, including but not limited to the warranties of
117 merchantability, fitness for a particular purpose and noninfringement.
118 In no event shall the authors or copyright holders be liable for any
119 claim, damages or other liability, whether in an action of contract,
120 tort or otherwise, arising from, out of or in connection with the
121 software or the use or other dealings in the software.}
122 @end quotation
123 @end copying
124 @c %**end of header
126 @dircategory Software development
127 @direntry
128 * CFFI Manual: (cffi-manual).           CFFI Manual.
129 @end direntry
131 @titlepage
132 @title CFFI User Manual
133 @c @subtitle Version X.X
134 @c @author James Bielman
136 @page
137 @vskip 0pt plus 1filll
138 @insertcopying
139 @end titlepage
141 @contents
143 @ifnottex
144 @node Top, Introduction, (dir), (dir)
145 @top cffi
146 @insertcopying
147 @end ifnottex
149 @menu
150 * Introduction::                What is CFFI?
151 * Installation::
152 * Implementation Support::
153 * Tutorial::                    Interactive intro to using CFFI.
154 * Wrapper generators::          CFFI forms from munging C source code.
155 * Foreign Types::
156 * Pointers::
157 * Strings::
158 * Variables::
159 * Functions::
160 * Libraries::
161 * Callbacks::
162 * The Groveller::
163 * Static Linking::
164 * Limitations::
165 * Platform-specific features::  Details about the underlying system.
166 * Glossary::                    List of CFFI-specific terms and meanings.
167 * Comprehensive Index::
169 @detailmenu
170  --- Dictionary ---
172 Foreign Types
174 * convert-from-foreign::        Outside interface to backward type translator.
175 * convert-to-foreign::          Outside interface to forward type translator.
176 * defbitfield::                 Defines a bitfield.
177 * defcstruct::                  Defines a C structure type.
178 * defcunion::                   Defines a C union type.
179 * defctype::                    Defines a foreign typedef.
180 * defcenum::                    Defines a C enumeration.
181 * define-foreign-type::         Defines a foreign type specifier.
182 * define-parse-method::         Specifies how a type should be parsed.
183 @c * explain-foreign-slot-value::  <unimplemented>
184 * foreign-bitfield-symbols::    Returns a list of symbols for a bitfield type.
185 * foreign-bitfield-value::      Calculates a value for a bitfield type.
186 * foreign-enum-keyword::        Finds a keyword in an enum type.
187 * foreign-enum-value::          Finds a value in an enum type.
188 * foreign-slot-names::          Returns a list of slot names in a foreign struct.
189 * foreign-slot-offset::         Returns the offset of a slot in a foreign struct.
190 * foreign-slot-pointer::        Returns a pointer to a slot in a foreign struct.
191 * foreign-slot-value::          Returns the value of a slot in a foreign struct.
192 * foreign-type-alignment::      Returns the alignment of a foreign type.
193 * foreign-type-size::           Returns the size of a foreign type.
194 * free-converted-object::       Outside interface to typed object deallocators.
195 * free-translated-object::      Defines how to free a oreign object.
196 * translate-from-foreign::      Defines a foreign-to-Lisp object translation.
197 * translate-to-foreign::        Defines a Lisp-to-foreign object translation.
198 * with-foreign-object::         Allocates a foreign object with dynamic extent.
199 * with-foreign-objects::        Plural form of @code{with-foreign-object}.
200 * with-foreign-slots::          Accesses the slots of a foreign structure.
202 Pointers
204 * foreign-free::                Deallocates memory.
205 * foreign-alloc::               Allocates memory.
206 * foreign-symbol-pointer::      Returns a pointer to a foreign symbol.
207 * inc-pointer::                 Increments the address held by a pointer.
208 * incf-pointer::                Increments the pointer address in a place.
209 * make-pointer::                Returns a pointer to a given address.
210 * mem-aptr::                    The pointer to an element of an array.
211 * mem-aref::                    Accesses the value of an index in an array.
212 * mem-ref::                     Dereferences a pointer.
213 * null-pointer::                Returns a NULL pointer.
214 * null-pointer-p::              Tests a pointer for NULL value.
215 * pointerp::                    Tests whether an object is a pointer or not.
216 * pointer-address::             Returns the address pointed to by a pointer.
217 * pointer-eq::                  Tests if two pointers point to the same address.
218 * with-foreign-pointer::        Allocates memory with dynamic extent.
220 Strings
222 * *default-foreign-encoding*::  Default encoding for the string types.
223 * foreign-string-alloc::        Converts a Lisp string to a foreign string.
224 * foreign-string-free::         Deallocates memory used by a foreign string.
225 * foreign-string-to-lisp::      Converts a foreign string to a Lisp string.
226 * lisp-string-to-foreign::      Copies a Lisp string into a foreign string.
227 * with-foreign-string::         Allocates a foreign string with dynamic extent.
228 * with-foreign-strings::        Plural form of @code{with-foreign-string}.
229 * with-foreign-pointer-as-string::  Similar to CL's with-output-to-string.
231 Variables
233 * defcvar::                     Defines a C global variable.
234 * get-var-pointer::             Returns a pointer to a defined global variable.
236 Functions
238 * defcfun::                     Defines a foreign function.
239 * foreign-funcall::             Performs a call to a foreign function.
240 * foreign-funcall-pointer::     Performs a call through a foreign pointer.
241 * translate-camelcase-name::    Converts a camelCase foreign name to/from a Lisp name.
242 * translate-name-from-foreign::  Converts a foreign name to a Lisp name.
243 * translate-name-to-foreign::   Converts a Lisp name to a foreign name.
244 * translate-underscore-separated-name::  Converts an underscore_separated foreign name to/from a Lisp name.
246 Libraries
248 * close-foreign-library::       Closes a foreign library.
249 * *darwin-framework-directories*::  Search path for Darwin frameworks.
250 * define-foreign-library::      Explain how to load a foreign library.
251 * *foreign-library-directories*::  Search path for shared libraries.
252 * load-foreign-library::        Load a foreign library.
253 * load-foreign-library-error::  Signalled on failure of its namesake.
254 @c * reload-foreign-libraries::    Reload foreign libraries.
255 * use-foreign-library::         Load a foreign library when needed.
257 Callbacks
259 * callback::                    Returns a pointer to a defined callback.
260 * defcallback::                 Defines a Lisp callback.
261 * get-callback::                Returns a pointer to a defined callback.
263 @end detailmenu
264 @end menu
269 @c ===================================================================
270 @c CHAPTER: Introduction
272 @node Introduction, Installation, Top, Top
273 @chapter Introduction
275 @cffi{} is the Common Foreign Function Interface for @acronym{ANSI}
276 Common Lisp systems.  By @dfn{foreign function} we mean a function
277 written in another programming language and having different data and
278 calling conventions than Common Lisp, namely, C.  @cffi{} allows you
279 to call foreign functions and access foreign variables, all without
280 leaving the Lisp image.
282 We consider this manual ever a work in progress.  If you have
283 difficulty with anything @cffi{}-specific presented in the manual,
284 please contact @email{cffi-devel@@common-lisp.net,the developers} with
285 details.
288 @heading Motivation
290 @xref{Tutorial-Comparison,, What makes Lisp different}, for
291 an argument in favor of @acronym{FFI} in general.
293 @cffi{}'s primary role in any image is to mediate between Lisp
294 developers and the widely varying @acronym{FFI}s present in the
295 various Lisp implementations it supports.  With @cffi{}, you can
296 define foreign function interfaces while still maintaining portability
297 between implementations.  It is not the first Common Lisp package with
298 this objective; however, it is meant to be a more malleable framework
299 than similar packages.
302 @heading Design Philosophy
304 @itemize
305 @item
306 Pointers do not carry around type information. Instead, type
307 information is supplied when pointers are dereferenced.
309 @item
310 A type safe pointer interface can be developed on top of an
311 untyped one.  It is difficult to do the opposite.
313 @item
314 Functions are better than macros.  When a macro could be used
315 for performance, use a compiler-macro instead.
316 @end itemize
319 @c ===================================================================
320 @c CHAPTER: Installation
322 @node Installation, Implementation Support, Introduction, Top
323 @chapter Installation
325 @cffi{} can be obtained through one of the following means available
326 through its @uref{http://common-lisp.net/project/cffi/,,website}:
328 @itemize
329 @item
330 @uref{http://common-lisp.net/project/cffi/releases/?M=D,,official release
331 tarballs}
333 @item
334 @uref{http://common-lisp.net/gitweb?p=projects/cffi/cffi.git,,git
335 repository}
337 @c snapshots have been disabled as of
338 @c @item
339 @c @uref{http://common-lisp.net/project/cffi/tarballs/?M=D,,nightly-generated
340 @c snapshots}
342 @end itemize
344 In addition, you will need to obtain and install the following
345 dependencies:
347 @itemize
348 @item
349 @uref{http://common-lisp.net/project/babel/,,Babel}, a charset
350 encoding/decoding library.
352 @item
353 @uref{http://common-lisp.net/project/alexandria/,,Alexandria}, a
354 collection of portable public-domain utilities.
356 @item
357 @uref{http://www.cliki.net/trivial-features,,trivial-features}, a
358 portability layer that ensures consistent @code{*features*} across
359 multiple Common Lisp implementations.
361 @end itemize
363 Furthermore, if you wish to run the testsuite,
364 @uref{http://www.cliki.net/rt,,RT} is required.
366 You may find mechanisms such as
367 @uref{https://www.quicklisp.org/beta/,Quicklisp} (recommended)
368 or @uref{http://common-lisp.net/project/clbuild/,,clbuild} (for advanced
369 uses) helpful in getting and managing @cffi{} and its
370 dependencies.
373 @c ===================================================================
374 @c CHAPTER: Implementation Support
376 @node Implementation Support, Tutorial, Installation, Top
377 @chapter Implementation Support
379 @cffi{} supports various free and commercial Lisp implementations:
380 @acronym{ABCL}, Allegro CL, Clasp, @sc{clisp}, Clozure CL,
381 @acronym{CMUCL}, Corman CL, @acronym{ECL}, @acronym{GCL}, LispWorks,
382 @acronym{MCL}, @acronym{SBCL} and the Scieneer CL.
384 In general, you should work with the latest versions of each
385 implementation since those will usually be tested against recent
386 versions of CFFI more often and might include necessary features or
387 bug fixes. Reasonable patches for compatibility with earlier versions
388 are welcome nevertheless.
390 @section Limitations
392 Some features are not supported in all implementations.
393 @c TODO: describe these features here.
394 @c       flat-namespace too
396 @subheading Allegro CL
398 @itemize
399 @item
400 Does not support the @code{:long-long} type natively.
401 @item
402 Unicode support is limited to the Basic Multilingual Plane (16-bit
403 code points).
404 @end itemize
406 @subheading Clasp
408 @itemize
409 @item
410 Only supports a flat namespace.
411 @end itemize
413 @subheading CMUCL
415 @itemize
416 @item
417 No Unicode support. (8-bit code points)
418 @end itemize
420 @subheading Corman CL
422 @itemize
423 @item
424 Does not support @code{foreign-funcall}.
425 @end itemize
427 @subheading @acronym{ECL}
429 @itemize
430 @item
431 On platforms where ECL's dynamic FFI is not supported (ie. when
432 @code{:dffi} is not present in @code{*features*}),
433 @code{cffi:load-foreign-library} does not work and you must use ECL's
434 own @code{ffi:load-foreign-library} with a constant string argument.
435 @end itemize
437 @subheading Lispworks
439 @itemize
440 @item
441 Does not completely support the @code{:long-long} type natively in
442 32-bit platforms.
443 @item
444 Unicode support is limited to the Basic Multilingual Plane (16-bit
445 code points).
446 @end itemize
448 @subheading @acronym{SBCL}
450 @itemize
451 @item
452 Not all platforms support callbacks.
454 @end itemize
457 @c ===================================================================
458 @c CHAPTER: An Introduction to Foreign Interfaces and CFFI
460 @c This macro is merely a marker that I don't think I'll use after
461 @c all.
462 @macro tutorialsource {text}
463 @c \text\
464 @end macro
466 @c because I don't want to type this over and over
467 @macro clikicffi
468 http://www.cliki.net/CFFI
469 @end macro
470 @c TeX puts spurious newlines in when you use the above macro
471 @c in @examples &c.  So it is expanded below in some places.
474 @node Tutorial, Wrapper generators, Implementation Support, Top
475 @chapter An Introduction to Foreign Interfaces and @acronym{CFFI}
477 @c Above, I don't use the cffi macro because it breaks TeX.
479 @cindex tutorial, @cffi{}
480 Users of many popular languages bearing semantic similarity to Lisp,
481 such as Perl and Python, are accustomed to having access to popular C
482 libraries, such as @acronym{GTK}, by way of ``bindings''.  In Lisp, we
483 do something similar, but take a fundamentally different approach.
484 This tutorial first explains this difference, then explains how you
485 can use @cffi{}, a powerful system for calling out to C and C++ and
486 access C data from many Common Lisp implementations.
488 @cindex foreign functions and data
489 The concept can be generalized to other languages; at the time of
490 writing, only @cffi{}'s C support is fairly complete. Therefore, we
491 will interchangeably refer to @dfn{foreign functions} and @dfn{foreign
492 data}, and ``C functions'' and ``C data''.  At no time will the word
493 ``foreign'' carry its usual, non-programming meaning.
495 This tutorial expects you to have a working understanding of both
496 Common Lisp and C, including the Common Lisp macro system.
498 @menu
499 * Tutorial-Comparison::         Why FFI?
500 * Tutorial-Getting a URL::      An FFI use case.
501 * Tutorial-Loading::            Load libcurl.so.
502 * Tutorial-Initializing::       Call a function in libcurl.so.
503 * Tutorial-easy_setopt::        An advanced libcurl function.
504 * Tutorial-Abstraction::        Why breaking it is necessary.
505 * Tutorial-Lisp easy_setopt::   Semi-Lispy option interface.
506 * Tutorial-Memory::             In C, you collect the garbage.
507 * Tutorial-Callbacks::          Make useful C function pointers.
508 * Tutorial-Completion::         Minimal get-url functionality.
509 * Tutorial-Types::              Defining new foreign types.
510 * Tutorial-Conclusion::         What's next?
511 @end menu
514 @node Tutorial-Comparison, Tutorial-Getting a URL, Tutorial, Tutorial
515 @section What makes Lisp different
517 The following sums up how bindings to foreign libraries are usually
518 implemented in other languages, then in Common Lisp:
520 @table @asis
521 @item Perl, Python, Java, other one-implementation languages
522 @cindex @acronym{SWIG}
523 @cindex Perl
524 @cindex Python
525 Bindings are implemented as shared objects written in C.  In some
526 cases, the C code is generated by a tool, such as @acronym{SWIG}, but
527 the result is the same: a new C library that manually translates
528 between the language implementation's objects, such as @code{PyObject}
529 in Python, and whatever C object is called for, often using C
530 functions provided by the implementation.  It also translates between
531 the calling conventions of the language and C.
533 @item Common Lisp
534 @cindex @acronym{SLIME}
535 Bindings are written in Lisp.  They can be created at-will by Lisp
536 programs.  Lisp programmers can write new bindings and add them to the
537 image, using a listener such as @acronym{SLIME}, as easily as with
538 regular Lisp definitions.  The only foreign library to load is the one
539 being wrapped---the one with the pure C interface; no C or other
540 non-Lisp compilation is required.
541 @end table
543 @cindex advantages of @acronym{FFI}
544 @cindex benefits of @acronym{FFI}
545 We believe the advantages of the Common Lisp approach far outweigh any
546 disadvantages.  Incremental development with a listener can be as
547 productive for C binding development as it is with other Lisp
548 development.  Keeping it ``in the [Lisp] family'', as it were, makes
549 it much easier for you and other Lisp programmers to load and use the
550 bindings.  Common Lisp implementations such as @acronym{CMUCL}, freed
551 from having to provide a C interface to their own objects, are thus
552 freed to be implemented in another language (as @acronym{CMUCL} is)
553 while still allowing programmers to call foreign functions.
555 @cindex minimal bindings
556 Perhaps the greatest advantage is that using an @acronym{FFI} doesn't
557 obligate you to become a professional binding developer.  Writers of
558 bindings for other languages usually end up maintaining or failing to
559 maintain complete bindings to the foreign library.  Using an
560 @acronym{FFI}, however, means if you only need one or two functions,
561 you can write bindings for only those functions, and be assured that
562 you can just as easily add to the bindings if need be.
564 @cindex C abstractions
565 @cindex abstractions in C
566 The removal of the C compiler, or C interpretation of any kind,
567 creates the main disadvantage: some of C's ``abstractions'' are not
568 available, violating information encapsulation.  For example,
569 @code{struct}s that must be passed on the stack, or used as return
570 values, without corresponding functional abstractions to create and
571 manage the @code{struct}s, must be declared explicitly in Lisp.  This
572 is fine for structs whose contents are ``public'', but is not so
573 pleasant when a struct is supposed to be ``opaque'' by convention,
574 even though it is not so defined.@footnote{Admittedly, this is an
575 advanced issue, and we encourage you to leave this text until you are
576 more familiar with how @cffi{} works.}
578 Without an abstraction to create the struct, Lisp needs to be able to
579 lay out the struct in memory, so must know its internal details.
581 @cindex workaround for C
582 In these cases, you can create a minimal C library to provide the
583 missing abstractions, without destroying all the advantages of the
584 Common Lisp approach discussed above.  In the case of @code{struct}s,
585 you can write simple, pure C functions that tell you how many bytes a
586 struct requires or allocate new structs, read and write fields of the
587 struct, or whatever operations are supposed to be
588 public.@footnote{This does not apply to structs whose contents are
589 intended to be part of the public library interface.  In those cases,
590 a pure Lisp struct definition is always preferred.  In fact, many
591 prefer to stay in Lisp and break the encapsulation anyway, placing the
592 burden of correct library interface definition on the library.}
593 @ref{The Groveller} automates this and other processes.
595 Another disadvantage appears when you would rather use the foreign
596 language than Lisp.  However, someone who prefers C to Lisp is not a
597 likely candidate for developing a Lisp interface to a C library.
600 @node Tutorial-Getting a URL, Tutorial-Loading, Tutorial-Comparison, Tutorial
601 @section Getting a @acronym{URL}
603 @cindex c@acronym{URL}
604 The widely available @code{libcurl} is a library for downloading files
605 over protocols like @acronym{HTTP}.  We will use @code{libcurl} with
606 @cffi{} to download a web page.
608 Please note that there are many other ways to download files from the
609 web, not least the @sc{cl-curl} project to provide bindings to
610 @code{libcurl} via a similar @acronym{FFI}.@footnote{Specifically,
611 @acronym{UFFI}, an older @acronym{FFI} that takes a somewhat different
612 approach compared to @cffi{}.  I believe that these days (December
613 2005) @cffi{} is more portable and actively developed, though not as
614 mature yet.  Consensus in the free @sc{unix} Common Lisp community
615 seems to be that @cffi{} is preferred for new development, though
616 @acronym{UFFI} will likely go on for quite some time as many projects
617 already use it.  @cffi{} includes the @code{UFFI-COMPAT} package for
618 complete compatibility with @acronym{UFFI}.}
620 @uref{http://curl.haxx.se/libcurl/c/libcurl-tutorial.html,,libcurl-tutorial(3)}
621 is a tutorial for @code{libcurl} programming in C.  We will follow
622 that to develop a binding to download a file.  We will also use
623 @file{curl.h}, @file{easy.h}, and the @command{man} pages for the
624 @code{libcurl} function, all available in the @samp{curl-dev} package
625 or equivalent for your system, or in the c@acronym{URL} source code
626 package.  If you have the development package, the headers should be
627 installed in @file{/usr/include/curl/}, and the @command{man} pages
628 may be accessed through your favorite @command{man} facility.
631 @node Tutorial-Loading, Tutorial-Initializing, Tutorial-Getting a URL, Tutorial
632 @section Loading foreign libraries
634 @cindex loading @cffi{}
635 @cindex requiring @cffi{}
636 First of all, we will create a package to work in.  You can save these
637 forms in a file, or just send them to the listener as they are.  If
638 creating bindings for an @acronym{ASDF} package of yours, you will
639 want to add @code{:cffi} to the @code{:depends-on} list in your
640 @file{.asd} file.  Otherwise, just use the @code{asdf:load-system} function to
641 load @cffi{}.
643 @tutorialsource{Initialization}
644 @lisp
645 (asdf:load-system :cffi)
647 ;;; @lispcmt{Nothing special about the "CFFI-USER" package.  We're just}
648 ;;; @lispcmt{using it as a substitute for your own CL package.}
649 (defpackage :cffi-user
650   (:use :common-lisp :cffi))
652 (in-package :cffi-user)
654 (define-foreign-library libcurl
655   (:darwin (:or "libcurl.3.dylib" "libcurl.dylib"))
656   (:unix (:or "libcurl.so.3" "libcurl.so"))
657   (t (:default "libcurl")))
659 (use-foreign-library libcurl)
660 @end lisp
662 @cindex foreign library load
663 @cindex library, foreign
664 Using @code{define-foreign-library} and @code{use-foreign-library}, we
665 have loaded @code{libcurl} into Lisp, much as the linker does when you
666 start a C program, or @code{common-lisp:load} does with a Lisp source
667 file or @acronym{FASL} file.  We special-cased for @sc{unix} machines
668 to always load a particular version, the one this tutorial was tested
669 with; for those who don't care, the @code{define-foreign-library}
670 clause @code{(t (:default "libcurl"))} should be satisfactory, and
671 will adapt to various operating systems.
674 @node Tutorial-Initializing, Tutorial-easy_setopt, Tutorial-Loading, Tutorial
675 @section Initializing @code{libcurl}
677 @cindex function definition
678 After the introductory matter, the tutorial goes on to present the
679 first function you should use.
681 @example
682 CURLcode curl_global_init(long flags);
683 @end example
685 @noindent
686 Let's pick this apart into appropriate Lisp code:
688 @tutorialsource{First CURLcode}
689 @lisp
690 ;;; @lispcmt{A CURLcode is the universal error code.  curl/curl.h says}
691 ;;; @lispcmt{no return code will ever be removed, and new ones will be}
692 ;;; @lispcmt{added to the end.}
693 (defctype curl-code :int)
695 ;;; @lispcmt{Initialize libcurl with FLAGS.}
696 (defcfun "curl_global_init" curl-code
697   (flags :long))
698 @end lisp
700 @impnote{By default, CFFI assumes the UNIX viewpoint that there is one
701 C symbol namespace, containing all symbols in all loaded objects.
702 This is not so on Windows and Darwin, but we emulate UNIX's behaviour
703 there.  @ref{defcfun} for more details.}
705 Note the parallels with the original C declaration.  We've defined
706 @code{curl-code} as a wrapping type for @code{:int}; right now, it
707 only marks it as special, but later we will do something more
708 interesting with it.  The point is that we don't have to do it yet.
710 @cindex calling foreign functions
711 Looking at @file{curl.h}, @code{CURL_GLOBAL_NOTHING}, a possible value
712 for @code{flags} above, is defined as @samp{0}.  So we can now call
713 the function:
715 @example
716 @sc{cffi-user>} (curl-global-init 0)
717 @result{} 0
718 @end example
720 @cindex looks like it worked
721 Looking at @file{curl.h} again, @code{0} means @code{CURLE_OK}, so it
722 looks like the call succeeded.  Note that @cffi{} converted the
723 function name to a Lisp-friendly name.  You can specify your own name
724 if you want; use @code{("curl_global_init" @var{your-name-here})} as
725 the @var{name} argument to @code{defcfun}.
727 The tutorial goes on to have us allocate a handle.  For good measure,
728 we should also include the deallocator.  Let's look at these
729 functions:
731 @example
732 CURL *curl_easy_init( );
733 void curl_easy_cleanup(CURL *handle);
734 @end example
736 Advanced users may want to define special pointer types; we will
737 explore this possibility later.  For now, just treat every pointer as
738 the same:
740 @tutorialsource{curl_easy handles}
741 @lisp
742 (defcfun "curl_easy_init" :pointer)
744 (defcfun "curl_easy_cleanup" :void
745   (easy-handle :pointer))
746 @end lisp
748 Now we can continue with the tutorial:
750 @example
751 @sc{cffi-user>} (defparameter *easy-handle* (curl-easy-init))
752 @result{} *EASY-HANDLE*
753 @sc{cffi-user>} *easy-handle*
754 @result{} #<FOREIGN-ADDRESS #x09844EE0>
755 @end example
757 @cindex pointers in Lisp
758 Note the print representation of a pointer.  It changes depending on
759 what Lisp you are using, but that doesn't make any difference to
760 @cffi{}.
763 @node Tutorial-easy_setopt, Tutorial-Abstraction, Tutorial-Initializing, Tutorial
764 @section Setting download options
766 The @code{libcurl} tutorial says we'll want to set many options before
767 performing any download actions.  This is done through
768 @code{curl_easy_setopt}:
770 @c That is literally ..., not an ellipsis.
771 @example
772 CURLcode curl_easy_setopt(CURL *curl, CURLoption option, ...);
773 @end example
775 @cindex varargs
776 @cindex foreign arguments
777 We've introduced a new twist: variable arguments.  There is no obvious
778 translation to the @code{defcfun} form, particularly as there are four
779 possible argument types.  Because of the way C works, we could define
780 four wrappers around @code{curl_easy_setopt}, one for each type; in
781 this case, however, we'll use the general-purpose macro
782 @code{foreign-funcall} to call this function.
784 @cindex enumeration, C
785 To make things easier on ourselves, we'll create an enumeration of the
786 kinds of options we want to set.  The @code{enum CURLoption} isn't the
787 most straightforward, but reading the @code{CINIT} C macro definition
788 should be enlightening.
790 @tutorialsource{CURLoption enumeration}
791 @lisp
792 (defmacro define-curl-options (name type-offsets &rest enum-args)
793   "As with CFFI:DEFCENUM, except each of ENUM-ARGS is as follows:
795     (NAME TYPE NUMBER)
797 Where the arguments are as they are with the CINIT macro defined
798 in curl.h, except NAME is a keyword.
800 TYPE-OFFSETS is a plist of TYPEs to their integer offsets, as
801 defined by the CURLOPTTYPE_LONG et al constants in curl.h."
802   (flet ((enumerated-value (type offset)
803            (+ (getf type-offsets type) offset)))
804     `(progn
805        (defcenum ,name
806          ,@@(loop for (name type number) in enum-args
807               collect (list name (enumerated-value type number))))
808        ',name)))                ;@lispcmt{for REPL users' sanity}
810 (define-curl-options curl-option
811     (long 0 objectpoint 10000 functionpoint 20000 off-t 30000)
812   (:noprogress long 43)
813   (:nosignal long 99)
814   (:errorbuffer objectpoint 10)
815   (:url objectpoint 2))
816 @end lisp
818 With some well-placed Emacs @code{query-replace-regexp}s, you could
819 probably similarly define the entire @code{CURLoption} enumeration.  I
820 have selected to transcribe a few that we will use in this tutorial.
822 If you're having trouble following the macrology, just macroexpand the
823 @code{curl-option} definition, or see the following macroexpansion,
824 conveniently downcased and reformatted:
826 @tutorialsource{DEFINE-CURL-OPTIONS macroexpansion}
827 @lisp
828 (progn
829   (defcenum curl-option
830     (:noprogress 43)
831     (:nosignal 99)
832     (:errorbuffer 10010)
833     (:url 10002))
834   'curl-option)
835 @end lisp
837 @noindent
838 That seems more than reasonable.  You may notice that we only use the
839 @var{type} to compute the real enumeration offset; we will also need
840 the type information later.
842 First, however, let's make sure a simple call to the foreign function
843 works:
845 @example
846 @sc{cffi-user>} (foreign-funcall "curl_easy_setopt"
847                :pointer *easy-handle*
848                curl-option :nosignal :long 1 curl-code)
849 @result{} 0
850 @end example
852 @code{foreign-funcall}, despite its surface simplicity, can be used to
853 call any C function.  Its first argument is a string, naming the
854 function to be called.  Next, for each argument, we pass the name of
855 the C type, which is the same as in @code{defcfun}, followed by a Lisp
856 object representing the data to be passed as the argument.  The final
857 argument is the return type, for which we use the @code{curl-code}
858 type defined earlier.
860 @code{defcfun} just puts a convenient fa@,cade on
861 @code{foreign-funcall}.@footnote{This isn't entirely true; some Lisps
862 don't support @code{foreign-funcall}, so @code{defcfun} is implemented
863 without it.  @code{defcfun} may also perform optimizations that
864 @code{foreign-funcall} cannot.}  Our earlier call to
865 @code{curl-global-init} could have been written as follows:
867 @example
868 @sc{cffi-user>} (foreign-funcall "curl_global_init" :long 0
869                             curl-code)
870 @result{} 0
871 @end example
873 Before we continue, we will take a look at what @cffi{} can and can't
874 do, and why this is so.
877 @node Tutorial-Abstraction, Tutorial-Lisp easy_setopt, Tutorial-easy_setopt, Tutorial
878 @section Breaking the abstraction
880 @cindex breaking the abstraction
881 @cindex abstraction breaking
882 In @ref{Tutorial-Comparison,, What makes Lisp different}, we mentioned
883 that writing an @acronym{FFI} sometimes requires depending on
884 information not provided as part of the interface.  The easy option
885 @code{CURLOPT_WRITEDATA}, which we will not provide as part of the
886 Lisp interface, illustrates this issue.
888 Strictly speaking, the @code{curl-option} enumeration is not
889 necessary; we could have used @code{:int 99} instead of
890 @code{curl-option :nosignal} in our call to @code{curl_easy_setopt}
891 above.  We defined it anyway, in part to hide the fact that we are
892 breaking the abstraction that the C @code{enum} provides.  If the
893 c@acronym{URL} developers decide to change those numbers later, we
894 must change the Lisp enumeration, because enumeration values are not
895 provided in the compiled C library, @code{libcurl.so.3}.
897 @cffi{} works because the most useful things in C libraries ---
898 non-static functions and non-static variables --- are included
899 accessibly in @code{libcurl.so.3}.  A C compiler that violated this
900 would be considered a worthless compiler.
902 The other thing @code{define-curl-options} does is give the ``type''
903 of the third argument passed to @code{curl_easy_setopt}.  Using this
904 information, we can tell that the @code{:nosignal} option should
905 accept a long integer argument.  We can implicitly assume @code{t}
906 @equiv{} 1 and @code{nil} @equiv{} 0, as it is in C, which takes care
907 of the fact that @code{CURLOPT_NOSIGNAL} is really asking for a
908 boolean.
910 The ``type'' of @code{CURLOPT_WRITEDATA} is @code{objectpoint}.
911 However, it is really looking for a @code{FILE*}.
912 @code{CURLOPT_ERRORBUFFER} is looking for a @code{char*}, so there is
913 no obvious @cffi{} type but @code{:pointer}.
915 The first thing to note is that nowhere in the C interface includes
916 this information; it can only be found in the manual.  We could
917 disjoin these clearly different types ourselves, by splitting
918 @code{objectpoint} into @code{filepoint} and @code{charpoint}, but we
919 are still breaking the abstraction, because we have to augment the
920 entire enumeration form with this additional
921 information.@footnote{Another possibility is to allow the caller to
922 specify the desired C type of the third argument.  This is essentially
923 what happens in a call to the function written in C.}
925 @cindex streams and C
926 @cindex @sc{file}* and streams
927 The second is that the @code{CURLOPT_WRITEDATA} argument is completely
928 incompatible with the desired Lisp data, a
929 stream.@footnote{@xref{Other Kinds of Streams,,, libc, GNU C Library
930 Reference}, for a @acronym{GNU}-only way to extend the @code{FILE*}
931 type.  You could use this to convert Lisp streams to the needed C
932 data.  This would be quite involved and far outside the scope of this
933 tutorial.}  It is probably acceptable if we are controlling every file
934 we might want to use as this argument, in which case we can just call
935 the foreign function @code{fopen}.  Regardless, though, we can't write
936 to arbitrary streams, which is exactly what we want to do for this
937 application.
939 Finally, note that the @code{curl_easy_setopt} interface itself is a
940 hack, intended to work around some of the drawbacks of C.  The
941 definition of @code{Curl_setopt}, while long, is far less cluttered
942 than the equivalent disjoint-function set would be; in addition,
943 setting a new option in an old @code{libcurl} can generate a run-time
944 error rather than breaking the compile.  Lisp can just as concisely
945 generate functions as compare values, and the ``undefined function''
946 error is just as useful as any explicit error we could define here
947 might be.
950 @node Tutorial-Lisp easy_setopt, Tutorial-Memory, Tutorial-Abstraction, Tutorial
951 @section Option functions in Lisp
953 We could use @code{foreign-funcall} directly every time we wanted to
954 call @code{curl_easy_setopt}.  However, we can encapsulate some of the
955 necessary information with the following.
957 @lisp
958 ;;; @lispcmt{We will use this type later in a more creative way.  For}
959 ;;; @lispcmt{now, just consider it a marker that this isn't just any}
960 ;;; @lispcmt{pointer.}
961 (defctype easy-handle :pointer)
963 (defmacro curl-easy-setopt (easy-handle enumerated-name
964                             value-type new-value)
965   "Call `curl_easy_setopt' on EASY-HANDLE, using ENUMERATED-NAME
966 as the OPTION.  VALUE-TYPE is the CFFI foreign type of the third
967 argument, and NEW-VALUE is the Lisp data to be translated to the
968 third argument.  VALUE-TYPE is not evaluated."
969   `(foreign-funcall "curl_easy_setopt" easy-handle ,easy-handle
970                     curl-option ,enumerated-name
971                     ,value-type ,new-value curl-code))
972 @end lisp
974 Now we define a function for each kind of argument that encodes the
975 correct @code{value-type} in the above.  This can be done reasonably
976 in the @code{define-curl-options} macroexpansion; after all, that is
977 where the different options are listed!
979 @cindex Lispy C functions
980 We could make @code{cl:defun} forms in the expansion that simply call
981 @code{curl-easy-setopt}; however, it is probably easier and clearer to
982 use @code{defcfun}.  @code{define-curl-options} was becoming unwieldy,
983 so I defined some helpers in this new definition.
985 @smalllisp
986 (defun curry-curl-option-setter (function-name option-keyword)
987   "Wrap the function named by FUNCTION-NAME with a version that
988 curries the second argument as OPTION-KEYWORD.
990 This function is intended for use in DEFINE-CURL-OPTION-SETTER."
991   (setf (symbol-function function-name)
992           (let ((c-function (symbol-function function-name)))
993             (lambda (easy-handle new-value)
994               (funcall c-function easy-handle option-keyword
995                        new-value)))))
997 (defmacro define-curl-option-setter (name option-type
998                                      option-value foreign-type)
999   "Define (with DEFCFUN) a function NAME that calls
1000 curl_easy_setopt.  OPTION-TYPE and OPTION-VALUE are the CFFI
1001 foreign type and value to be passed as the second argument to
1002 easy_setopt, and FOREIGN-TYPE is the CFFI foreign type to be used
1003 for the resultant function's third argument.
1005 This macro is intended for use in DEFINE-CURL-OPTIONS."
1006   `(progn
1007      (defcfun ("curl_easy_setopt" ,name) curl-code
1008        (easy-handle easy-handle)
1009        (option ,option-type)
1010        (new-value ,foreign-type))
1011      (curry-curl-option-setter ',name ',option-value)))
1013 (defmacro define-curl-options (type-name type-offsets &rest enum-args)
1014   "As with CFFI:DEFCENUM, except each of ENUM-ARGS is as follows:
1016     (NAME TYPE NUMBER)
1018 Where the arguments are as they are with the CINIT macro defined
1019 in curl.h, except NAME is a keyword.
1021 TYPE-OFFSETS is a plist of TYPEs to their integer offsets, as
1022 defined by the CURLOPTTYPE_LONG et al constants in curl.h.
1024 Also, define functions for each option named
1025 set-`TYPE-NAME'-`OPTION-NAME', where OPTION-NAME is the NAME from
1026 the above destructuring."
1027   (flet ((enumerated-value (type offset)
1028            (+ (getf type-offsets type) offset))
1029          ;; @lispcmt{map PROCEDURE, destructuring each of ENUM-ARGS}
1030          (map-enum-args (procedure)
1031            (mapcar (lambda (arg) (apply procedure arg)) enum-args))
1032          ;; @lispcmt{build a name like SET-CURL-OPTION-NOSIGNAL}
1033          (make-setter-name (option-name)
1034            (intern (concatenate
1035                     'string "SET-" (symbol-name type-name)
1036                     "-" (symbol-name option-name)))))
1037     `(progn
1038        (defcenum ,type-name
1039          ,@@(map-enum-args
1040             (lambda (name type number)
1041               (list name (enumerated-value type number)))))
1042        ,@@(map-enum-args
1043           (lambda (name type number)
1044             (declare (ignore number))
1045             `(define-curl-option-setter ,(make-setter-name name)
1046                ,type-name ,name ,(ecase type
1047                                    (long :long)
1048                                    (objectpoint :pointer)
1049                                    (functionpoint :pointer)
1050                                    (off-t :long)))))
1051        ',type-name)))
1052 @end smalllisp
1054 @noindent
1055 Macroexpanding our @code{define-curl-options} form once more, we
1056 see something different:
1058 @lisp
1059 (progn
1060   (defcenum curl-option
1061     (:noprogress 43)
1062     (:nosignal 99)
1063     (:errorbuffer 10010)
1064     (:url 10002))
1065   (define-curl-option-setter set-curl-option-noprogress
1066     curl-option :noprogress :long)
1067   (define-curl-option-setter set-curl-option-nosignal
1068     curl-option :nosignal :long)
1069   (define-curl-option-setter set-curl-option-errorbuffer
1070     curl-option :errorbuffer :pointer)
1071   (define-curl-option-setter set-curl-option-url
1072     curl-option :url :pointer)
1073   'curl-option)
1074 @end lisp
1076 @noindent
1077 Macroexpanding one of the new @code{define-curl-option-setter}
1078 forms yields the following:
1080 @lisp
1081 (progn
1082   (defcfun ("curl_easy_setopt" set-curl-option-nosignal) curl-code
1083     (easy-handle easy-handle)
1084     (option curl-option)
1085     (new-value :long))
1086   (curry-curl-option-setter 'set-curl-option-nosignal ':nosignal))
1087 @end lisp
1089 @noindent
1090 Finally, let's try this out:
1092 @example
1093 @sc{cffi-user>} (set-curl-option-nosignal *easy-handle* 1)
1094 @result{} 0
1095 @end example
1097 @noindent
1098 Looks like it works just as well.  This interface is now reasonably
1099 high-level to wash out some of the ugliness of the thinnest possible
1100 @code{curl_easy_setopt} @acronym{FFI}, without obscuring the remaining
1101 C bookkeeping details we will explore.
1104 @node Tutorial-Memory, Tutorial-Callbacks, Tutorial-Lisp easy_setopt, Tutorial
1105 @section Memory management
1107 According to the documentation for @code{curl_easy_setopt}, the type
1108 of the third argument when @var{option} is @code{CURLOPT_ERRORBUFFER}
1109 is @code{char*}.  Above, we've defined
1110 @code{set-curl-option-errorbuffer} to accept a @code{:pointer} as the
1111 new option value.  However, there is a @cffi{} type @code{:string},
1112 which translates Lisp strings to C strings when passed as arguments to
1113 foreign function calls.  Why not, then, use @code{:string} as the
1114 @cffi{} type of the third argument?  There are two reasons, both
1115 related to the necessity of breaking abstraction described in
1116 @ref{Tutorial-Abstraction,, Breaking the abstraction}.
1118 The first reason also applies to @code{CURLOPT_URL}, which we will use
1119 to illustrate the point.  Assuming we have changed the type of the
1120 third argument underlying @code{set-curl-option-url} to
1121 @code{:string}, look at these two equivalent forms.
1123 @lisp
1124 (set-curl-option-url *easy-handle* "http://www.cliki.net/CFFI")
1126 @equiv{} (with-foreign-string (url "http://www.cliki.net/CFFI")
1127      (foreign-funcall "curl_easy_setopt" easy-handle *easy-handle*
1128                       curl-option :url :pointer url curl-code))
1129 @end lisp
1131 @noindent
1132 The latter, in fact, is mostly equivalent to what a foreign function
1133 call's macroexpansion actually does.  As you can see, the Lisp string
1134 @code{"@clikicffi{}"} is copied into a @code{char} array and
1135 null-terminated; the pointer to beginning of this array, now a C
1136 string, is passed as a @cffi{} @code{:pointer} to the foreign
1137 function.
1139 @cindex dynamic extent
1140 @cindex foreign values with dynamic extent
1141 Unfortunately, the C abstraction has failed us, and we must break it.
1142 While @code{:string} works well for many @code{char*} arguments, it
1143 does not for cases like this.  As the @code{curl_easy_setopt}
1144 documentation explains, ``The string must remain present until curl no
1145 longer needs it, as it doesn't copy the string.''  The C string
1146 created by @code{with-foreign-string}, however, only has dynamic
1147 extent: it is ``deallocated'' when the body (above containing the
1148 @code{foreign-funcall} form) exits.
1150 @cindex premature deallocation
1151 If we are supposed to keep the C string around, but it goes away, what
1152 happens when some @code{libcurl} function tries to access the
1153 @acronym{URL} string?  We have reentered the dreaded world of C
1154 ``undefined behavior''.  In some Lisps, it will probably get a chunk
1155 of the Lisp/C stack.  You may segfault.  You may get some random piece
1156 of other data from the heap.  Maybe, in a world where ``dynamic
1157 extent'' is defined to be ``infinite extent'', everything will turn
1158 out fine.  Regardless, results are likely to be almost universally
1159 unpleasant.@footnote{``@i{But I thought Lisp was supposed to protect
1160 me from all that buggy C crap!}''  Before asking a question like that,
1161 remember that you are a stranger in a foreign land, whose residents
1162 have a completely different set of values.}
1164 Returning to the current @code{set-curl-option-url} interface, here is
1165 what we must do:
1167 @lisp
1168 (let (easy-handle)
1169   (unwind-protect
1170     (with-foreign-string (url "http://www.cliki.net/CFFI")
1171       (setf easy-handle (curl-easy-init))
1172       (set-curl-option-url easy-handle url)
1173       #|@lispcmt{do more with the easy-handle, like actually get the URL}|#)
1174     (when easy-handle
1175       (curl-easy-cleanup easy-handle))))
1176 @end lisp
1178 @c old comment to luis: I go on to say that this isn't obviously
1179 @c extensible to new option settings that require C strings to stick
1180 @c around, as it would involve re-evaluating the unwind-protect form
1181 @c with more dynamic memory allocation.  So I plan to show how to
1182 @c write something similar to ObjC's NSAutoreleasePool, to be managed
1183 @c with a simple unwind-protect form.
1185 @noindent
1186 That is fine for the single string defined here, but for every string
1187 option we want to pass, we have to surround the body of
1188 @code{with-foreign-string} with another @code{with-foreign-string}
1189 wrapper, or else do some extremely error-prone pointer manipulation
1190 and size calculation in advance.  We could alleviate some of the pain
1191 with a recursively expanding macro, but this would not remove the need
1192 to modify the block every time we want to add an option, anathema as
1193 it is to a modular interface.
1195 Before modifying the code to account for this case, consider the other
1196 reason we can't simply use @code{:string} as the foreign type.  In C,
1197 a @code{char *} is a @code{char *}, not necessarily a string.  The
1198 option @code{CURLOPT_ERRORBUFFER} accepts a @code{char *}, but does
1199 not expect anything about the data there.  However, it does expect
1200 that some @code{libcurl} function we call later can write a C string
1201 of up to 255 characters there.  We, the callers of the function, are
1202 expected to read the C string at a later time, exactly the opposite of
1203 what @code{:string} implies.
1205 With the semantics for an input string in mind --- namely, that the
1206 string should be kept around until we @code{curl_easy_cleanup} the
1207 easy handle --- we are ready to extend the Lisp interface:
1209 @lisp
1210 (defvar *easy-handle-cstrings* (make-hash-table)
1211   "Hashtable of easy handles to lists of C strings that may be
1212 safely freed after the handle is freed.")
1214 (defun make-easy-handle ()
1215   "Answer a new CURL easy interface handle, to which the lifetime
1216 of C strings may be tied.  See `add-curl-handle-cstring'."
1217   (let ((easy-handle (curl-easy-init)))
1218     (setf (gethash easy-handle *easy-handle-cstrings*) '())
1219     easy-handle))
1221 (defun free-easy-handle (handle)
1222   "Free CURL easy interface HANDLE and any C strings created to
1223 be its options."
1224   (curl-easy-cleanup handle)
1225   (mapc #'foreign-string-free
1226         (gethash handle *easy-handle-cstrings*))
1227   (remhash handle *easy-handle-cstrings*))
1229 (defun add-curl-handle-cstring (handle cstring)
1230   "Add CSTRING to be freed when HANDLE is, answering CSTRING."
1231   (car (push cstring (gethash handle *easy-handle-cstrings*))))
1232 @end lisp
1234 @noindent
1235 Here we have redefined the interface to create and free handles, to
1236 associate a list of allocated C strings with each handle while it
1237 exists.  The strategy of using different function names to wrap around
1238 simple foreign functions is more common than the solution implemented
1239 earlier with @code{curry-curl-option-setter}, which was to modify the
1240 function name's function slot.@footnote{There are advantages and
1241 disadvantages to each approach; I chose to @code{(setf
1242 symbol-function)} earlier because it entailed generating fewer magic
1243 function names.}
1245 Incidentally, the next step is to redefine
1246 @code{curry-curl-option-setter} to allocate C strings for the
1247 appropriate length of time, given a Lisp string as the
1248 @code{new-value} argument:
1250 @lisp
1251 (defun curry-curl-option-setter (function-name option-keyword)
1252   "Wrap the function named by FUNCTION-NAME with a version that
1253 curries the second argument as OPTION-KEYWORD.
1255 This function is intended for use in DEFINE-CURL-OPTION-SETTER."
1256   (setf (symbol-function function-name)
1257           (let ((c-function (symbol-function function-name)))
1258             (lambda (easy-handle new-value)
1259               (funcall c-function easy-handle option-keyword
1260                        (if (stringp new-value)
1261                          (add-curl-handle-cstring
1262                           easy-handle
1263                           (foreign-string-alloc new-value))
1264                          new-value))))))
1265 @end lisp
1267 @noindent
1268 A quick analysis of the code shows that you need only reevaluate the
1269 @code{curl-option} enumeration definition to take advantage of these
1270 new semantics.  Now, for good measure, let's reallocate the handle
1271 with the new functions we just defined, and set its @acronym{URL}:
1273 @example
1274 @sc{cffi-user>} (curl-easy-cleanup *easy-handle*)
1275 @result{} NIL
1276 @sc{cffi-user>} (setf *easy-handle* (make-easy-handle))
1277 @result{} #<FOREIGN-ADDRESS #x09844EE0>
1278 @sc{cffi-user>} (set-curl-option-nosignal *easy-handle* 1)
1279 @result{} 0
1280 @sc{cffi-user>} (set-curl-option-url *easy-handle*
1281                                 "http://www.cliki.net/CFFI")
1282 @result{} 0
1283 @end example
1285 @cindex strings
1286 For fun, let's inspect the Lisp value of the C string that was created
1287 to hold @code{"@clikicffi{}"}.  By virtue of the implementation of
1288 @code{add-curl-handle-cstring}, it should be accessible through the
1289 hash table defined:
1291 @example
1292 @sc{cffi-user>} (foreign-string-to-lisp
1293             (car (gethash *easy-handle* *easy-handle-cstrings*)))
1294 @result{} "http://www.cliki.net/CFFI"
1295 @end example
1297 @noindent
1298 Looks like that worked, and @code{libcurl} now knows what
1299 @acronym{URL} we want to retrieve.
1301 Finally, we turn back to the @code{:errorbuffer} option mentioned at
1302 the beginning of this section.  Whereas the abstraction added to
1303 support string inputs works fine for cases like @code{CURLOPT_URL}, it
1304 hides the detail of keeping the C string; for @code{:errorbuffer},
1305 however, we need that C string.
1307 In a moment, we'll define something slightly cleaner, but for now,
1308 remember that you can always hack around anything.  We're modifying
1309 handle creation, so make sure you free the old handle before
1310 redefining @code{free-easy-handle}.
1312 @smalllisp
1313 (defvar *easy-handle-errorbuffers* (make-hash-table)
1314   "Hashtable of easy handles to C strings serving as error
1315 writeback buffers.")
1317 ;;; @lispcmt{An extra byte is very little to pay for peace of mind.}
1318 (defparameter *curl-error-size* 257
1319   "Minimum char[] size used by cURL to report errors.")
1321 (defun make-easy-handle ()
1322   "Answer a new CURL easy interface handle, to which the lifetime
1323 of C strings may be tied.  See `add-curl-handle-cstring'."
1324   (let ((easy-handle (curl-easy-init)))
1325     (setf (gethash easy-handle *easy-handle-cstrings*) '())
1326     (setf (gethash easy-handle *easy-handle-errorbuffers*)
1327             (foreign-alloc :char :count *curl-error-size*
1328                            :initial-element 0))
1329     easy-handle))
1331 (defun free-easy-handle (handle)
1332   "Free CURL easy interface HANDLE and any C strings created to
1333 be its options."
1334   (curl-easy-cleanup handle)
1335   (foreign-free (gethash handle *easy-handle-errorbuffers*))
1336   (remhash handle *easy-handle-errorbuffers*)
1337   (mapc #'foreign-string-free
1338         (gethash handle *easy-handle-cstrings*))
1339   (remhash handle *easy-handle-cstrings*))
1341 (defun get-easy-handle-error (handle)
1342   "Answer a string containing HANDLE's current error message."
1343   (foreign-string-to-lisp
1344    (gethash handle *easy-handle-errorbuffers*)))
1345 @end smalllisp
1347 Be sure to once again set the options we've set thus far.  You may
1348 wish to define yet another wrapper function to do this.
1351 @node Tutorial-Callbacks, Tutorial-Completion, Tutorial-Memory, Tutorial
1352 @section Calling Lisp from C
1354 If you have been reading
1355 @uref{http://curl.haxx.se/libcurl/c/curl_easy_setopt.html,,
1356 @code{curl_easy_setopt(3)}}, you should have noticed that some options
1357 accept a function pointer.  In particular, we need one function
1358 pointer to set as @code{CURLOPT_WRITEFUNCTION}, to be called by
1359 @code{libcurl} rather than the reverse, in order to receive data as it
1360 is downloaded.
1362 A binding writer without the aid of @acronym{FFI} usually approaches
1363 this problem by writing a C function that accepts C data, converts to
1364 the language's internal objects, and calls the callback provided by
1365 the user, again in a reverse of usual practices.
1367 The @cffi{} approach to callbacks precisely mirrors its differences
1368 with the non-@acronym{FFI} approach on the ``calling C from Lisp''
1369 side, which we have dealt with exclusively up to now.  That is, you
1370 define a callback function in Lisp using @code{defcallback}, and
1371 @cffi{} effectively creates a C function to be passed as a function
1372 pointer.
1374 @impnote{This is much trickier than calling C functions from Lisp, as
1375 it literally involves somehow generating a new C function that is as
1376 good as any created by the compiler.  Therefore, not all Lisps support
1377 them.  @xref{Implementation Support}, for information about @cffi{}
1378 support issues in this and other areas.  You may want to consider
1379 changing to a Lisp that supports callbacks in order to continue with
1380 this tutorial.}
1382 @cindex callback definition
1383 @cindex defining callbacks
1384 Defining a callback is very similar to defining a callout; the main
1385 difference is that we must provide some Lisp forms to be evaluated as
1386 part of the callback.  Here is the signature for the function the
1387 @code{:writefunction} option takes:
1389 @example
1390 size_t
1391 @var{function}(void *ptr, size_t size, size_t nmemb, void *stream);
1392 @end example
1394 @impnote{size_t is almost always an unsigned int.  You can get this
1395 and many other types using feature tests for your system by using
1396 cffi-grovel.}
1398 The above signature trivially translates into a @cffi{}
1399 @code{defcallback} form, as follows.
1401 @lisp
1402 ;;; @lispcmt{Alias in case size_t changes.}
1403 (defctype size :unsigned-int)
1405 ;;; @lispcmt{To be set as the CURLOPT_WRITEFUNCTION of every easy handle.}
1406 (defcallback easy-write size ((ptr :pointer) (size size)
1407                               (nmemb size) (stream :pointer))
1408   (let ((data-size (* size nmemb)))
1409     (handler-case
1410       ;; @lispcmt{We use the dynamically-bound *easy-write-procedure* to}
1411       ;; @lispcmt{call a closure with useful lexical context.}
1412       (progn (funcall (symbol-value '*easy-write-procedure*)
1413                       (foreign-string-to-lisp ptr :count data-size))
1414              data-size)         ;@lispcmt{indicates success}
1415       ;; @lispcmt{The WRITEFUNCTION should return something other than the}
1416       ;; @lispcmt{#bytes available to signal an error.}
1417       (error () (if (zerop data-size) 1 0)))))
1418 @end lisp
1420 First, note the correlation of the first few forms, used to declare
1421 the C function's signature, with the signature in C syntax.  We
1422 provide a Lisp name for the function, its return type, and a name and
1423 type for each argument.
1425 In the body, we call the dynamically-bound
1426 @code{*easy-write-procedure*} with a ``finished'' translation, of
1427 pulling together the raw data and size into a Lisp string, rather than
1428 deal with the data directly.  As part of calling
1429 @code{curl_easy_perform} later, we'll bind that variable to a closure
1430 with more useful lexical bindings than the top-level
1431 @code{defcallback} form.
1433 Finally, we make a halfhearted effort to prevent non-local exits from
1434 unwinding the C stack, covering the most likely case with an
1435 @code{error} handler, which is usually triggered
1436 unexpectedly.@footnote{Unfortunately, we can't protect against
1437 @emph{all} non-local exits, such as @code{return}s and @code{throw}s,
1438 because @code{unwind-protect} cannot be used to ``short-circuit'' a
1439 non-local exit in Common Lisp, due to proposal @code{minimal} in
1440 @uref{http://www.lisp.org/HyperSpec/Issues/iss152-writeup.html,
1441 @acronym{ANSI} issue @sc{Exit-Extent}}.  Furthermore, binding an
1442 @code{error} handler prevents higher-up code from invoking restarts
1443 that may be provided under the callback's dynamic context.  Such is
1444 the way of compromise.}  The reason is that most C code is written to
1445 understand its own idiosyncratic error condition, implemented above in
1446 the case of @code{curl_easy_perform}, and more ``undefined behavior''
1447 can result if we just wipe C stack frames without allowing them to
1448 execute whatever cleanup actions as they like.
1450 Using the @code{CURLoption} enumeration in @file{curl.h} once more, we
1451 can describe the new option by modifying and reevaluating
1452 @code{define-curl-options}.
1454 @lisp
1455 (define-curl-options curl-option
1456     (long 0 objectpoint 10000 functionpoint 20000 off-t 30000)
1457   (:noprogress long 43)
1458   (:nosignal long 99)
1459   (:errorbuffer objectpoint 10)
1460   (:url objectpoint 2)
1461   (:writefunction functionpoint 11)) ;@lispcmt{new item here}
1462 @end lisp
1464 Finally, we can use the defined callback and the new
1465 @code{set-curl-option-writefunction} to finish configuring the easy
1466 handle, using the @code{callback} macro to retrieve a @cffi{}
1467 @code{:pointer}, which works like a function pointer in C code.
1469 @example
1470 @sc{cffi-user>} (set-curl-option-writefunction
1471             *easy-handle* (callback easy-write))
1472 @result{} 0
1473 @end example
1476 @node Tutorial-Completion, Tutorial-Types, Tutorial-Callbacks, Tutorial
1477 @section A complete @acronym{FFI}?
1479 @c TeX goes insane on @uref{@clikicffi{}}
1481 With all options finally set and a medium-level interface developed,
1482 we can finish the definition and retrieve
1483 @uref{http://www.cliki.net/CFFI}, as is done in the tutorial.
1485 @lisp
1486 (defcfun "curl_easy_perform" curl-code
1487   (handle easy-handle))
1488 @end lisp
1490 @example
1491 @sc{cffi-user>} (with-output-to-string (contents)
1492              (let ((*easy-write-procedure*
1493                      (lambda (string)
1494                        (write-string string contents))))
1495                (declare (special *easy-write-procedure*))
1496                (curl-easy-perform *easy-handle*)))
1497 @result{} "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01//EN\"
1498 @enddots{}
1499 Now fear, comprehensively</P>
1501 @end example
1503 Of course, that itself is slightly unwieldy, so you may want to define
1504 a function around it that simply retrieves a @acronym{URL}.  I will
1505 leave synthesis of all the relevant @acronym{REPL} forms presented
1506 thus far into a single function as an exercise for the reader.
1508 The remaining sections of this tutorial explore some advanced features
1509 of @cffi{}; the definition of new types will receive special
1510 attention.  Some of these features are essential for particular
1511 foreign function calls; some are very helpful when trying to develop a
1512 Lispy interface to C.
1515 @node Tutorial-Types, Tutorial-Conclusion, Tutorial-Completion, Tutorial
1516 @section Defining new types
1518 We've occasionally used the @code{defctype} macro in previous sections
1519 as a kind of documentation, much what you'd use @code{typedef} for in
1520 C.  We also tried one special kind of type definition, the
1521 @code{defcenum} type.  @xref{defcstruct}, for a definition macro that
1522 may come in handy if you need to use C @code{struct}s as data.
1524 @cindex type definition
1525 @cindex data in Lisp and C
1526 @cindex translating types
1527 However, all of these are mostly sugar for the powerful underlying
1528 foreign type interface called @dfn{type translators}.  You can easily
1529 define new translators for any simple named foreign type.  Since we've
1530 defined the new type @code{curl-code} to use as the return type for
1531 various @code{libcurl} functions, we can use that to directly convert
1532 c@acronym{URL} errors to Lisp errors.
1534 @code{defctype}'s purpose is to define simple @code{typedef}-like
1535 aliases.  In order to use @dfn{type translators} we must use the
1536 @code{define-foreign-type} macro.  So let's redefine @code{curl-code}
1537 using it.
1539 @lisp
1540 (define-foreign-type curl-code-type ()
1541   ()
1542   (:actual-type :int)
1543   (:simple-parser curl-code))
1544 @end lisp
1546 @code{define-foreign-type} is a thin wrapper around @code{defclass}.
1547 For now, all you need to know in the context of this example is that
1548 it does what @code{(defctype curl-code :int)} would do and,
1549 additionally, defines a new class @code{curl-code-type} which we will
1550 take advantage of shortly.
1552 The @code{CURLcode} enumeration seems to follow the typical error code
1553 convention of @samp{0} meaning all is well, and each non-zero integer
1554 indicating a different kind of error.  We can apply that trivially to
1555 differentiate between normal exits and error exits.
1557 @lisp
1558 (define-condition curl-code-error (error)
1559   (($code :initarg :curl-code :reader curl-error-code))
1560   (:report (lambda (c stream)
1561              (format stream "libcurl function returned error ~A"
1562                             (curl-error-code c))))
1563   (:documentation "Signalled when a libcurl function answers
1564 a code other than CURLE_OK."))
1566 (defmethod translate-from-foreign (value (type curl-code-type))
1567   "Raise a CURL-CODE-ERROR if VALUE, a curl-code, is non-zero."
1568   (if (zerop value)
1569       :curle-ok
1570       (error 'curl-code-error :curl-code value)))
1571 @end lisp
1573 @noindent
1574 The heart of this translator is new method
1575 @code{translate-from-foreign}.  By specializing the @var{type}
1576 parameter on @code{curl-code-type}, we immediately modify the behavior
1577 of every function that returns a @code{curl-code} to pass the result
1578 through this new method.
1580 To see the translator in action, try invoking a function that returns
1581 a @code{curl-code}.  You need to reevaluate the respective
1582 @code{defcfun} form so that it picks up the new @code{curl-code}
1583 definition.
1585 @example
1586 @sc{cffi-user>} (set-curl-option-nosignal *easy-handle* 1)
1587 @result{} :CURLE-OK
1588 @end example
1590 @noindent
1591 As the result was @samp{0}, the new method returned @code{:curle-ok},
1592 just as specified.@footnote{It might be better to return
1593 @code{(values)} than @code{:curle-ok} in real code, but this is good
1594 for illustration.}  I will leave disjoining the separate
1595 @code{CURLcode}s into condition types and improving the @code{:report}
1596 function as an exercise for you.
1598 The creation of @code{*easy-handle-cstrings*} and
1599 @code{*easy-handle-errorbuffers*} as properties of @code{easy-handle}s
1600 is a kluge.  What we really want is a Lisp structure that stores these
1601 properties along with the C pointer.  Unfortunately,
1602 @code{easy-handle} is currently just a fancy name for the foreign type
1603 @code{:pointer}; the actual pointer object varies from Common Lisp
1604 implementation to implementation, needing only to satisfy
1605 @code{pointerp} and be returned from @code{make-pointer} and friends.
1607 One solution that would allow us to define a new Lisp structure to
1608 represent @code{easy-handle}s would be to write a wrapper around every
1609 function that currently takes an @code{easy-handle}; the wrapper would
1610 extract the pointer and pass it to the foreign function.  However, we
1611 can use type translators to more elegantly integrate this
1612 ``translation'' into the foreign function calling framework, using
1613 @code{translate-to-foreign}.
1615 @smalllisp
1616 (defclass easy-handle ()
1617   ((pointer :initform (curl-easy-init)
1618             :documentation "Foreign pointer from curl_easy_init")
1619    (error-buffer
1620     :initform (foreign-alloc :char :count *curl-error-size*
1621                              :initial-element 0)
1622     :documentation "C string describing last error")
1623    (c-strings :initform '()
1624               :documentation "C strings set as options"))
1625   (:documentation "I am a parameterization you may pass to
1626 curl-easy-perform to perform a cURL network protocol request."))
1628 (defmethod initialize-instance :after ((self easy-handle) &key)
1629   (set-curl-option-errorbuffer self (slot-value self 'error-buffer)))
1631 (defun add-curl-handle-cstring (handle cstring)
1632   "Add CSTRING to be freed when HANDLE is, answering CSTRING."
1633   (car (push cstring (slot-value handle 'c-strings))))
1635 (defun get-easy-handle-error (handle)
1636   "Answer a string containing HANDLE's current error message."
1637   (foreign-string-to-lisp
1638    (slot-value handle 'error-buffer)))
1640 (defun free-easy-handle (handle)
1641   "Free CURL easy interface HANDLE and any C strings created to
1642 be its options."
1643   (with-slots (pointer error-buffer c-strings) handle
1644     (curl-easy-cleanup pointer)
1645     (foreign-free error-buffer)
1646     (mapc #'foreign-string-free c-strings)))
1648 (define-foreign-type easy-handle-type ()
1649   ()
1650   (:actual-type :pointer)
1651   (:simple-parser easy-handle))
1653 (defmethod translate-to-foreign (handle (type easy-handle-type))
1654   "Extract the pointer from an easy-HANDLE."
1655   (slot-value handle 'pointer))
1656 @end smalllisp
1658 While we changed some of the Lisp functions defined earlier to use
1659 @acronym{CLOS} slots rather than hash tables, the foreign functions
1660 work just as well as they did before.
1662 @cindex limitations of type translators
1663 The greatest strength, and the greatest limitation, of the type
1664 translator comes from its generalized interface.  As stated
1665 previously, we could define all foreign function calls in terms of the
1666 primitive foreign types provided by @cffi{}.  The type translator
1667 interface allows us to cleanly specify the relationship between Lisp
1668 and C data, independent of where it appears in a function call.  This
1669 independence comes at a price; for example, it cannot be used to
1670 modify translation semantics based on other arguments to a function
1671 call.  In these cases, you should rely on other features of Lisp,
1672 rather than the powerful, yet domain-specific, type translator
1673 interface.
1676 @node Tutorial-Conclusion,  , Tutorial-Types, Tutorial
1677 @section What's next?
1679 @cffi{} provides a rich and powerful foundation for communicating with
1680 foreign libraries; as we have seen, it is up to you to make that
1681 experience a pleasantly Lispy one.  This tutorial does not cover all
1682 the features of @cffi{}; please see the rest of the manual for
1683 details.  In particular, if something seems obviously missing, it is
1684 likely that either code or a good reason for lack of code is already
1685 present.
1687 @impnote{There are some other things in @cffi{} that might deserve
1688 tutorial sections, such as free-translated-object, or structs.  Let us
1689 know which ones you care about.}
1692 @c ===================================================================
1693 @c CHAPTER: Wrapper generators
1695 @node Wrapper generators, Foreign Types, Tutorial, Top
1696 @chapter Wrapper generators
1698 @cffi{}'s interface is designed for human programmers, being aimed at
1699 aesthetic as well as technical sophistication.  However, there are a
1700 few programs aimed at translating C and C++ header files, or
1701 approximations thereof, into @cffi{} forms constituting a foreign
1702 interface to the symbols in those files.
1704 These wrapper generators are known to support output of @cffi{} forms.
1706 @table @asis
1707 @item @uref{http://www.cliki.net/Verrazano,Verrazano}
1708 Designed specifically for Common Lisp.  Uses @acronym{GCC}'s parser
1709 output in @acronym{XML} format to discover functions, variables, and
1710 other header file data.  This means you need @acronym{GCC} to generate
1711 forms; on the other hand, the parser employed is mostly compliant with
1712 @acronym{ANSI} C.
1714 @item @uref{http://www.cliki.net/SWIG,SWIG}
1715 A foreign interface generator originally designed to generate Python
1716 bindings, it has been ported to many other systems, including @cffi{}
1717 in version 1.3.28.  Includes its own C declaration munger, not
1718 intended to be fully-compliant with @acronym{ANSI} C.
1719 @end table
1721 First, this manual does not describe use of these other programs; they
1722 have documentation of their own.  If you have problems using a
1723 generated interface, please look at the output @cffi{} forms and
1724 verify that they are a correct @cffi{} interface to the library in
1725 question; if they are correct, contact @cffi{} developers with
1726 details, keeping in mind that they communicate in terms of those forms
1727 rather than any particular wrapper generator.  Otherwise, contact the
1728 maintainers of the wrapper generator you are using, provided you can
1729 reasonably expect more accuracy from the generator.
1731 When is more accuracy an unreasonable expectation?  As described in
1732 the tutorial (@pxref{Tutorial-Abstraction,, Breaking the
1733 abstraction}), the information in C declarations is insufficient to
1734 completely describe every interface.  In fact, it is quite common to
1735 run into an interface that cannot be handled automatically, and
1736 generators should be excused from generating a complete interface in
1737 these cases.
1739 As further described in the tutorial, the thinnest Lisp interface to a
1740 C function is not always the most pleasant one.  In many cases, you
1741 will want to manually write a Lispier interface to the C functions
1742 that interest you.
1744 Wrapper generators should be treated as time-savers, not complete
1745 automation of the full foreign interface writing job.  Reports of the
1746 amount of work done by generators vary from 30% to 90%.  The
1747 incremental development style enabled by @cffi{} generally reduces
1748 this proportion below that for languages like Python.
1750 @c Where I got the above 30-90% figures:
1751 @c 30%: lemonodor's post about SWIG
1752 @c 90%: Balooga on #lisp.  He said 99%, but that's probably an
1753 @c      exaggeration (leave it to me to pass judgement :)
1754 @c -stephen
1757 @c ===================================================================
1758 @c CHAPTER: Foreign Types
1760 @node Foreign Types, Pointers, Wrapper generators, Top
1761 @chapter Foreign Types
1763 Foreign types describe how data is translated back and forth between C
1764 and Lisp. @cffi{} provides various built-in types and allows the user to
1765 define new types.
1767 @menu
1768 * Built-In Types::
1769 * Other Types::
1770 * Defining Foreign Types::
1771 * Foreign Type Translators::
1772 * Optimizing Type Translators::
1773 * Foreign Structure Types::
1774 * Allocating Foreign Objects::
1776 Dictionary
1778 * convert-from-foreign::
1779 * convert-to-foreign::
1780 * defbitfield::
1781 * defcstruct::
1782 * defcunion::
1783 * defctype::
1784 * defcenum::
1785 @c * define-type-spec-parser::
1786 * define-foreign-type::
1787 * define-parse-method::
1788 @c * explain-foreign-slot-value:
1789 * foreign-bitfield-symbols::
1790 * foreign-bitfield-value::
1791 * foreign-enum-keyword::
1792 * foreign-enum-value::
1793 * foreign-slot-names::
1794 * foreign-slot-offset::
1795 * foreign-slot-pointer::
1796 * foreign-slot-value::
1797 * foreign-type-alignment::
1798 * foreign-type-size::
1799 * free-converted-object::
1800 * free-translated-object::
1801 * translate-from-foreign::
1802 * translate-to-foreign::
1803 * translate-into-foreign-memory::
1804 * with-foreign-slots::
1805 @end menu
1807 @node Built-In Types, Other Types, Foreign Types, Foreign Types
1808 @section Built-In Types
1810 @ForeignType{:char}
1811 @ForeignType{:unsigned-char}
1812 @ForeignType{:short}
1813 @ForeignType{:unsigned-short}
1814 @ForeignType{:int}
1815 @ForeignType{:unsigned-int}
1816 @ForeignType{:long}
1817 @ForeignType{:unsigned-long}
1818 @ForeignType{:long-long}
1819 @ForeignType{:unsigned-long-long}
1821 These types correspond to the native C integer types according to the
1822 @acronym{ABI} of the Lisp implementation's host system.
1824 @code{:long-long} and @code{:unsigned-long-long} are not supported
1825 natively on all implementations. However, they are emulated by
1826 @code{mem-ref} and @code{mem-set}.
1828 When those types are @strong{not} available, the symbol
1829 @code{cffi-sys::no-long-long} is pushed into @code{*features*}.
1831 @ForeignType{:uchar}
1832 @ForeignType{:ushort}
1833 @ForeignType{:uint}
1834 @ForeignType{:ulong}
1835 @ForeignType{:llong}
1836 @ForeignType{:ullong}
1838 For convenience, the above types are provided as shortcuts for
1839 @code{unsigned-char}, @code{unsigned-short}, @code{unsigned-int},
1840 @code{unsigned-long}, @code{long-long} and @code{unsigned-long-long},
1841 respectively.
1843 @ForeignType{:int8}
1844 @ForeignType{:uint8}
1845 @ForeignType{:int16}
1846 @ForeignType{:uint16}
1847 @ForeignType{:int32}
1848 @ForeignType{:uint32}
1849 @ForeignType{:int64}
1850 @ForeignType{:uint64}
1851 @ForeignType{:size}
1852 @ForeignType{:ssize}
1853 @ForeignType{:intptr}
1854 @ForeignType{:uintptr}
1855 @ForeignType{:ptrdiff}
1856 @ForeignType{:offset}
1858 Foreign integer types of specific sizes, corresponding to the C types
1859 defined in @code{stdint.h}.
1861 @c @ForeignType{:time}
1863 @c Foreign integer types corresponding to the standard C types (without
1864 @c the @code{_t} suffix).
1866 @c @impnote{These are not implemented yet. --luis}
1868 @c @impnote{I'm sure there are more of these that could be useful, let's
1869 @c add any types that can't be defined portably to this list as
1870 @c necessary. --james}
1872 @ForeignType{:float}
1873 @ForeignType{:double}
1875 On all systems, the @code{:float} and @code{:double} types represent a
1876 C @code{float} and @code{double}, respectively. On most but not all
1877 systems, @code{:float} and @code{:double} represent a Lisp
1878 @code{single-float} and @code{double-float}, respectively. It is not
1879 so useful to consider the relationship between Lisp types and C types
1880 as isomorphic, as simply to recognize the relationship, and relative
1881 precision, among each respective category.
1883 @ForeignType{:long-double}
1885 This type is only supported on SCL.
1887 @ForeignType{:pointer &optional type}
1889 A foreign pointer to an object of any type, corresponding to
1890 @code{void *}.  You can optionally specify type of pointer
1891 (e.g. @code{(:pointer :char)}).  Although @cffi{} won't do anything
1892 with that information yet, it is useful for documentation purposes.
1894 @ForeignType{:void}
1896 No type at all. Only valid as the return type of a function.
1898 @node Other Types, Defining Foreign Types, Built-In Types, Foreign Types
1899 @section Other Types
1901 @cffi{} also provides a few useful types that aren't built-in C
1902 types.
1904 @ForeignType{:string}
1906 The @code{:string} type performs automatic conversion between Lisp and
1907 C strings. Note that, in the case of functions the converted C string
1908 will have dynamic extent (i.e.@: it will be automatically freed after
1909 the foreign function returns).
1911 In addition to Lisp strings, this type will accept foreign pointers
1912 and pass them unmodified.
1914 A method for @ref{free-translated-object} is specialized for this
1915 type. So, for example, foreign strings allocated by this type and
1916 passed to a foreign function will be freed after the function
1917 returns.
1919 @lisp
1920 CFFI> (foreign-funcall "getenv" :string "SHELL" :string)
1921 @result{} "/bin/bash"
1923 CFFI> (with-foreign-string (str "abcdef")
1924         (foreign-funcall "strlen" :string str :int))
1925 @result{} 6
1926 @end lisp
1928 @ForeignType{:string+ptr}
1930 Like @code{:string} but returns a list with two values when convert
1931 from C to Lisp: a Lisp string and the C string's foreign pointer.
1933 @lisp
1934 CFFI> (foreign-funcall "getenv" :string "SHELL" :string+ptr)
1935 @result{} ("/bin/bash" #.(SB-SYS:INT-SAP #XBFFFFC6F))
1936 @end lisp
1938 @ForeignType{:boolean &optional (base-type :int)}
1940 The @code{:boolean} type converts between a Lisp boolean and a C
1941 boolean. It canonicalizes to @var{base-type} which is @code{:int} by
1942 default.
1944 @lisp
1945 (convert-to-foreign nil :boolean) @result{} 0
1946 (convert-to-foreign t :boolean) @result{} 1
1947 (convert-from-foreign 0 :boolean) @result{} nil
1948 (convert-from-foreign 1 :boolean) @result{} t
1949 @end lisp
1951 @ForeignType{:bool}
1953 The @code{:bool} type represents the C99 @code{_Bool} or C++
1954 @code{bool}. Its size is usually 1 byte except on OSX where it's an
1955 @code{int}.
1957 @ForeignType{:wrapper base-type &key to-c from-c}
1959 The @code{:wrapper} type stores two symbols passed to the @var{to-c}
1960 and @var{from-c} arguments. When a value is being translated to or
1961 from C, this type @code{funcall}s the respective symbol.
1963 @code{:wrapper} types will be typedefs for @var{base-type} and will
1964 inherit its translators, if any.
1966 Here's an example of how the @code{:boolean} type could be defined in
1967 terms of @code{:wrapper}.
1969 @lisp
1970 (defun bool-c-to-lisp (value)
1971   (not (zerop value)))
1973 (defun bool-lisp-to-c (value)
1974   (if value 1 0))
1976 (defctype my-bool (:wrapper :int :from-c bool-c-to-lisp
1977                                  :to-c bool-lisp-to-c))
1979 (convert-to-foreign nil 'my-bool) @result{} 0
1980 (convert-from-foreign 1 'my-bool) @result{} t
1981 @end lisp
1983 @node Defining Foreign Types, Foreign Type Translators, Other Types, Foreign Types
1984 @section Defining Foreign Types
1986 You can define simple C-like @code{typedef}s through the
1987 @code{defctype} macro. Defining a typedef is as simple as giving
1988 @code{defctype} a new name and the name of the type to be wrapped.
1990 @lisp
1991 ;;; @lispcmt{Define MY-INT as an alias for the built-in type :INT.}
1992 (defctype my-int :int)
1993 @end lisp
1995 With this type definition, one can, for instance, declare arguments to
1996 foreign functions as having the type @code{my-int}, and they will be
1997 passed as integers.
1999 @subheading More complex types
2001 @cffi{} offers another way to define types through
2002 @code{define-foreign-type}, a thin wrapper macro around
2003 @code{defclass}. As an example, let's go through the steps needed to
2004 define a @code{(my-string &key encoding)} type. First, we need to
2005 define our type class:
2007 @lisp
2008 (define-foreign-type my-string-type ()
2009   ((encoding :reader string-type-encoding :initarg :encoding))
2010   (:actual-type :pointer))
2011 @end lisp
2013 The @code{:actual-type} class option tells CFFI that this type will
2014 ultimately be passed to and received from foreign code as a
2015 @code{:pointer}. Now you need to tell CFFI how to parse a type
2016 specification such as @code{(my-string :encoding :utf8)} into an
2017 instance of @code{my-string-type}.  We do that with
2018 @code{define-parse-method}:
2020 @lisp
2021 (define-parse-method my-string (&key (encoding :utf-8))
2022   (make-instance 'my-string-type :encoding encoding))
2023 @end lisp
2025 The next section describes how make this type actually translate
2026 between C and Lisp strings.
2028 @node Foreign Type Translators, Optimizing Type Translators, Defining Foreign Types, Foreign Types
2029 @section Foreign Type Translators
2031 Type translators are used to automatically convert Lisp values to or
2032 from foreign values.  For example, using type translators, one can
2033 take the @code{my-string} type defined in the previous section and
2034 specify that it should:
2036 @itemize
2037 @item
2038 convert C strings to Lisp strings;
2039 @item
2040 convert Lisp strings to newly allocated C strings;
2041 @item
2042 free said C strings when they are no longer needed.
2043 @end itemize
2045 In order to tell @cffi{} how to automatically convert Lisp values to
2046 foreign values, define a specialized method for the
2047 @code{translate-to-foreign} generic function:
2049 @lisp
2050 ;;; @lispcmt{Define a method that converts Lisp strings to C strings.}
2051 (defmethod translate-to-foreign (string (type my-string-type))
2052   (foreign-string-alloc string :encoding (string-type-encoding type)))
2053 @end lisp
2055 @noindent
2056 From now on, whenever an object is passed as a @code{my-string} to a
2057 foreign function, this method will be invoked to convert the Lisp
2058 value. To perform the inverse operation, which is needed for functions
2059 that return a @code{my-string}, specialize the
2060 @code{translate-from-foreign} generic function in the same manner:
2062 @lisp
2063 ;;; @lispcmt{Define a method that converts C strings to Lisp strings.}
2064 (defmethod translate-from-foreign (pointer (type my-string-type))
2065   (foreign-string-to-lisp pointer :encoding (string-type-encoding type)))
2066 @end lisp
2068 @noindent
2069 When a @code{translate-to-foreign} method requires allocation of
2070 foreign memory, you must also define a @code{free-translated-object}
2071 method to free the memory once the foreign object is no longer needed,
2072 otherwise you'll be faced with memory leaks.  This generic function is
2073 called automatically by @cffi{} when passing objects to foreign
2074 functions. Let's do that:
2076 @lisp
2077 ;;; @lispcmt{Free strings allocated by translate-to-foreign.}
2078 (defmethod free-translated-object (pointer (type my-string-type) param)
2079   (declare (ignore param))
2080   (foreign-string-free pointer))
2081 @end lisp
2083 @noindent
2084 In this specific example, we don't need the @var{param} argument, so
2085 we ignore it. See @ref{free-translated-object}, for an explanation of
2086 its purpose and how you can use it.
2088 A type translator does not necessarily need to convert the value.  For
2089 example, one could define a typedef for @code{:pointer} that ensures,
2090 in the @code{translate-to-foreign} method, that the value is not a
2091 null pointer, signalling an error if a null pointer is passed.  This
2092 would prevent some pointer errors when calling foreign functions that
2093 cannot handle null pointers.
2095 @strong{Please note:} these methods are meant as extensible hooks
2096 only, and you should not call them directly.  Use
2097 @code{convert-to-foreign}, @code{convert-from-foreign} and
2098 @code{free-converted-object} instead.
2100 @xref{Tutorial-Types,, Defining new types}, for another example of
2101 type translators.
2103 @node Optimizing Type Translators, Foreign Structure Types, Foreign Type Translators, Foreign Types
2104 @section Optimizing Type Translators
2106 @cindex type translators, optimizing
2107 @cindex compiler macros for type translation
2108 @cindex defining type-translation compiler macros
2109 Being based on generic functions, the type translation mechanism
2110 described above can add a bit of overhead.  This is usually not
2111 significant, but we nevertheless provide a way of getting rid of the
2112 overhead for the cases where it matters.
2114 A good way to understand this issue is to look at the code generated
2115 by @code{defcfun}. Consider the following example using the previously
2116 defined @code{my-string} type:
2118 @lisp
2119 CFFI> (macroexpand-1 '(defcfun foo my-string (x my-string)))
2120 ;; @lispcmt{(simplified, downcased, etc...)}
2121 (defun foo (x)
2122   (multiple-value-bind (#:G2019 #:PARAM3149)
2123       (translate-to-foreign x #<MY-STRING-TYPE @{11ED5A79@}>)
2124     (unwind-protect
2125         (translate-from-foreign
2126          (foreign-funcall "foo" :pointer #:G2019 :pointer)
2127          #<MY-STRING-TYPE @{11ED5659@}>)
2128       (free-translated-object #:G2019 #<MY-STRING-TYPE @{11ED51A79@}>
2129                               #:PARAM3149))))
2130 @end lisp
2132 @noindent
2133 In order to get rid of those generic function calls, @cffi{} has
2134 another set of extensible generic functions that provide functionality
2135 similar to @acronym{CL}'s compiler macros:
2136 @code{expand-to-foreign-dyn}, @code{expand-to-foreign} and
2137 @code{expand-from-foreign}. Here's how one could define a
2138 @code{my-boolean} with them:
2140 @lisp
2141 (define-foreign-type my-boolean-type ()
2142   ()
2143   (:actual-type :int)
2144   (:simple-parser my-boolean))
2146 (defmethod expand-to-foreign (value (type my-boolean-type))
2147   `(if ,value 1 0))
2149 (defmethod expand-from-foreign (value (type my-boolean-type))
2150   `(not (zerop ,value)))
2151 @end lisp
2153 @noindent
2154 And here's what the macroexpansion of a function using this type would
2155 look like:
2157 @lisp
2158 CFFI> (macroexpand-1 '(defcfun bar my-boolean (x my-boolean)))
2159 ;; @lispcmt{(simplified, downcased, etc...)}
2160 (defun bar (x)
2161   (let ((#:g3182 (if x 1 0)))
2162     (not (zerop (foreign-funcall "bar" :int #:g3182 :int)))))
2163 @end lisp
2165 @noindent
2166 No generic function overhead.
2168 Let's go back to our @code{my-string} type.  The expansion interface
2169 has no equivalent of @code{free-translated-object}; you must instead
2170 define a method on @code{expand-to-foreign-dyn}, the third generic
2171 function in this interface.  This is especially useful when you can
2172 allocate something much more efficiently if you know the object has
2173 dynamic extent, as is the case with function calls that don't save the
2174 relevant allocated arguments.
2176 This exactly what we need for the @code{my-string} type:
2178 @lisp
2179 (defmethod expand-from-foreign (form (type my-string-type))
2180   `(foreign-string-to-lisp ,form))
2182 (defmethod expand-to-foreign-dyn (value var body (type my-string-type))
2183   (let ((encoding (string-type-encoding type)))
2184     `(with-foreign-string (,var ,value :encoding ',encoding)
2185        ,@@body)))
2186 @end lisp
2188 @noindent
2189 So let's look at the macro expansion:
2191 @lisp
2192 CFFI> (macroexpand-1 '(defcfun foo my-string (x my-string)))
2193 ;; @lispcmt{(simplified, downcased, etc...)}
2194 (defun foo (x)
2195   (with-foreign-string (#:G2021 X :encoding ':utf-8)
2196     (foreign-string-to-lisp
2197      (foreign-funcall "foo" :pointer #:g2021 :pointer))))
2198 @end lisp
2200 @noindent
2201 Again, no generic function overhead.
2203 @subheading Other details
2205 To short-circuit expansion and use the @code{translate-*} functions
2206 instead, simply call the next method.  Return its result in cases
2207 where your method cannot generate an appropriate replacement for it.
2208 This analogous to the @code{&whole form} mechanism compiler macros
2209 provide.
2211 The @code{expand-*} methods have precedence over their
2212 @code{translate-*} counterparts and are guaranteed to be used in
2213 @code{defcfun}, @code{foreign-funcall}, @code{defcvar} and
2214 @code{defcallback}.  If you define a method on each of the
2215 @code{expand-*} generic functions, you are guaranteed to have full
2216 control over the expressions generated for type translation in these
2217 macros.
2219 They may or may not be used in other @cffi{} operators that need to
2220 translate between Lisp and C data; you may only assume that
2221 @code{expand-*} methods will probably only be called during Lisp
2222 compilation.
2224 @code{expand-to-foreign-dyn} has precedence over
2225 @code{expand-to-foreign} and is only used in @code{defcfun} and
2226 @code{foreign-funcall}, only making sense in those contexts.
2228 @strong{Important note:} this set of generic functions is called at
2229 macroexpansion time.  Methods are defined when loaded or evaluated,
2230 not compiled.  You are responsible for ensuring that your
2231 @code{expand-*} methods are defined when the @code{foreign-funcall} or
2232 other forms that use them are compiled.  One way to do this is to put
2233 the method definitions earlier in the file and inside an appropriate
2234 @code{eval-when} form; another way is to always load a separate Lisp
2235 or @acronym{FASL} file containing your @code{expand-*} definitions
2236 before compiling files with forms that ought to use them.  Otherwise,
2237 they will not be found and the runtime translators will be used
2238 instead.
2240 @node Foreign Structure Types, Allocating Foreign Objects, Optimizing Type Translators, Foreign Types
2241 @section Foreign Structure Types
2243 For more involved C types than simple aliases to built-in types, such
2244 as you can make with @code{defctype}, @cffi{} allows declaration of
2245 structures and unions with @code{defcstruct} and @code{defcunion}.
2247 For example, consider this fictional C structure declaration holding
2248 some personal information:
2250 @example
2251 struct person @{
2252   int number;
2253   char* reason;
2255 @end example
2257 @noindent
2258 The equivalent @code{defcstruct} form follows:
2260 @lisp
2261 (defcstruct person
2262   (number :int)
2263   (reason :string))
2264 @end lisp
2266 @c LMH structure translation
2267 By default, @ref{convert-from-foreign} (and also @ref{mem-ref}) will
2268 make a plist with slot names as keys, and @ref{convert-to-foreign} will
2269 translate such a plist to a foreign structure.  A user wishing to define
2270 other translations should use the @code{:class} argument to
2271 @ref{defcstruct}, and then define methods for
2272 @ref{translate-from-foreign} and
2273 @ref{translate-into-foreign-memory} that specialize on this class,
2274 possibly calling @code{call-next-method} to translate from and to the
2275 plists rather than provide a direct interface to the foreign object.
2276 The macro @code{translation-forms-for-class} will generate the forms
2277 necessary to translate a Lisp class into a foreign structure and vice
2278 versa.
2279 @c Write separate function doc section for translation-forms-for-class?
2280 @c Examples, perhaps taken from the tests?
2282 Please note that this interface is only for those that must know about
2283 the values contained in a relevant struct.  If the library you are
2284 interfacing returns an opaque pointer that needs only be passed to
2285 other C library functions, by all means just use @code{:pointer} or a
2286 type-safe definition munged together with @code{defctype} and type
2287 translation.  To pass or return a structure by value to a function, load
2288 the cffi-libffi system and specify the structure as @code{(:struct
2289 @var{structure-name})}.  To pass or return the pointer, you can use
2290 either @code{:pointer} or @code{(:pointer (:struct
2291 @var{structure-name}))}.
2293 @subheading Optimizing translate-into-foreign-memory
2295 Just like how @ref{translate-from-foreign} had
2296 @code{expand-from-foreign} to optimize away the generic function call
2297 and @ref{translate-to-foreign} had the same in
2298 @code{expand-to-foreign}, @ref{translate-into-foreign-memory} has
2299 @code{expand-into-foreign-memory}.
2301 Let's use our @code{person} struct in an example. However, we are
2302 going to spice it up by using a lisp struct rather than a plist to
2303 represent the person in lisp.
2305 First we redefine @code{person} very slightly.
2307 @lisp
2308 (defcstruct (person :class c-person)
2309   (number :int)
2310   (reason :string))
2311 @end lisp
2313 By adding @code{:class} we can specialize the @code{translate-*}
2314 methods on the type @code{c-person}.
2316 Next we define a lisp struct to use instead of the plists.
2318 @lisp
2319 (defstruct lisp-person
2320   (number 0 :type integer)
2321   (reason "" :type string))
2322 @end lisp
2324 And now let's define the type translators we know already:
2326 @lisp
2327 (defmethod translate-from-foreign (ptr (type c-person))
2328   (with-foreign-slots ((number reason) ptr (:struct person))
2329     (make-lisp-person :number number :reason reason)))
2331 (defmethod expand-from-foreign (ptr (type c-person))
2332   `(with-foreign-slots ((number reason) ,ptr (:struct person))
2333      (make-lisp-person :number number :reason reason)))
2335 (defmethod translate-into-foreign-memory (value (type c-person) ptr)
2336   (with-foreign-slots ((number reason) ptr (:struct person))
2337     (setf number (lisp-person-number value)
2338           reason (lisp-person-reason value))))
2339 @end lisp
2341 At this point everything works, we can convert to and from our
2342 @code{lisp-person} and foreign @code{person}. If we macroexpand
2344 @lisp
2345 (setf (mem-aref ptr '(:struct person)) x)
2346 @end lisp
2348 we get something like:
2350 @lisp
2351 (let ((#:store879 x))
2352   (translate-into-foreign-memory #:store879 #<c-person person>
2353                                  (inc-pointer ptr 0))
2354   #:store879)
2355 @end lisp
2357 Which is good, but now we can do better and get rid of that generic
2358 function call to @code{translate-into-foreign-memory}.
2360 @lisp
2361 (defmethod expand-into-foreign-memory (value (type c-person) ptr)
2362   `(with-foreign-slots ((number reason) ,ptr (:struct person))
2363      (setf number (lisp-person-number ,value)
2364            reason (lisp-person-reason ,value))))
2365 @end lisp
2367 Now we can expand again so see the changes:
2369 @lisp
2370 ;; this:
2371 (setf (mem-aref ptr '(:struct person)) x)
2373 ;; expands to this
2374 ;; (simplified, downcased, etc..)
2375 (let ((#:store887 x))
2376   (with-foreign-slots ((number reason) (inc-pointer ptr 0) (:struct person))
2377     (setf number (lisp-person-number #:store887)
2378           reason (lisp-person-reason #:store887))) #:store887)
2379 @end lisp
2381 And there we are, no generic function overhead.
2383 @subheading Compatibility note
2385 Previous versions of CFFI accepted the
2386 ``bare'' @var{structure-name} as a type specification, which was
2387 interpreted as a pointer to the structure.  This is deprecated and
2388 produces a style warning.  Using this deprecated form means that
2389 @ref{mem-aref} retains its prior meaning and returns a pointer.  Using
2390 the @code{(:struct @var{structure-name})} form for the type,
2391 @ref{mem-aref} provides a Lisp object translated from the
2392 structure (by default a plist).  Thus the semantics are consistent with all
2393 types in returning the object as represented in Lisp, and not a pointer,
2394 with the exception of the ``bare'' structure compatibility retained.
2395 In order to obtain the pointer, you should use the function @ref{mem-aptr}.
2397 See @ref{defcstruct} for more details.
2399 @node Allocating Foreign Objects, convert-from-foreign, Foreign Structure Types, Foreign Types
2400 @section Allocating Foreign Objects
2402 @c I moved this because I moved with-foreign-object to the Pointers
2403 @c chapter, where foreign-alloc is.
2405 @xref{Allocating Foreign Memory}.
2408 @c ===================================================================
2409 @c CONVERT-FROM-FOREIGN
2411 @page
2412 @node convert-from-foreign, convert-to-foreign, Allocating Foreign Objects, Foreign Types
2413 @heading convert-from-foreign
2414 @subheading Syntax
2415 @Function{convert-from-foreign foreign-value type @res{} value}
2417 @subheading Arguments and Values
2419 @table @var
2420 @item foreign-value
2421 The primitive C value as returned from a primitive foreign function or
2422 from @code{convert-to-foreign}.
2424 @item type
2425 A @cffi{} type specifier.
2427 @item value
2428 The Lisp value translated from @var{foreign-value}.
2429 @end table
2431 @subheading Description
2433 This is an external interface to the type translation facility.  In
2434 the implementation, all foreign functions are ultimately defined as
2435 type translation wrappers around primitive foreign function
2436 invocations.
2438 This function is available mostly for inspection of the type
2439 translation process, and possibly optimization of special cases of
2440 your foreign function calls.
2442 Its behavior is better described under @code{translate-from-foreign}'s
2443 documentation.
2445 @subheading Examples
2447 @lisp
2448 CFFI-USER> (convert-to-foreign "a boat" :string)
2449 @result{} #<FOREIGN-ADDRESS #x097ACDC0>
2450 @result{} T
2451 CFFI-USER> (convert-from-foreign * :string)
2452 @result{} "a boat"
2453 @end lisp
2455 @subheading See Also
2456 @seealso{convert-to-foreign} @*
2457 @seealso{free-converted-object} @*
2458 @seealso{translate-from-foreign}
2461 @c ===================================================================
2462 @c CONVERT-TO-FOREIGN
2464 @page
2465 @node convert-to-foreign, defbitfield, convert-from-foreign, Foreign Types
2466 @heading convert-to-foreign
2467 @subheading Syntax
2468 @Function{convert-to-foreign value type @res{} foreign-value, alloc-params}
2470 @subheading Arguments and Values
2472 @table @var
2473 @item value
2474 The Lisp object to be translated to a foreign object.
2476 @item type
2477 A @cffi{} type specifier.
2479 @item foreign-value
2480 The primitive C value, ready to be passed to a primitive foreign
2481 function.
2483 @item alloc-params
2484 Something of a translation state; you must pass it to
2485 @code{free-converted-object} along with the foreign value for that to
2486 work.
2487 @end table
2489 @subheading Description
2491 This is an external interface to the type translation facility.  In
2492 the implementation, all foreign functions are ultimately defined as
2493 type translation wrappers around primitive foreign function
2494 invocations.
2496 This function is available mostly for inspection of the type
2497 translation process, and possibly optimization of special cases of
2498 your foreign function calls.
2500 Its behavior is better described under @code{translate-to-foreign}'s
2501 documentation.
2503 @subheading Examples
2505 @lisp
2506 CFFI-USER> (convert-to-foreign t :boolean)
2507 @result{} 1
2508 @result{} NIL
2509 CFFI-USER> (convert-to-foreign "hello, world" :string)
2510 @result{} #<FOREIGN-ADDRESS #x097C5F80>
2511 @result{} T
2512 CFFI-USER> (code-char (mem-aref * :char 5))
2513 @result{} #\,
2514 @end lisp
2516 @subheading See Also
2517 @seealso{convert-from-foreign} @*
2518 @seealso{free-converted-object} @*
2519 @seealso{translate-to-foreign}
2522 @c ===================================================================
2523 @c DEFBITFIELD
2525 @page
2526 @node defbitfield, defcstruct, convert-to-foreign, Foreign Types
2527 @heading defbitfield
2528 @subheading Syntax
2529 @Macro{defbitfield name-and-options &body masks}
2531 masks ::= [docstring] @{ (symbol value) @}* @*
2532 name-and-options ::= name | (name &optional (base-type :int)) @*
2534 @subheading Arguments and Values
2536 @table @var
2537 @item name
2538 The name of the new bitfield type.
2540 @item docstring
2541 A documentation string, ignored.
2543 @item base-type
2544 A symbol denoting a foreign type.
2546 @item symbol
2547 A Lisp symbol.
2549 @item value
2550 An integer representing a bitmask.
2551 @end table
2553 @subheading Description
2554 The @code{defbitfield} macro is used to define foreign types that map
2555 lists of symbols to integer values.
2557 If @var{value} is omitted, it will be computed as follows: find the
2558 greatest @var{value} previously used, including those so computed,
2559 with only a single 1-bit in its binary representation (that is, powers
2560 of two), and left-shift it by one.  This rule guarantees that a
2561 computed @var{value} cannot clash with previous values, but may clash
2562 with future explicitly specified values.
2564 Symbol lists will be automatically converted to values and vice versa
2565 when being passed as arguments to or returned from foreign functions,
2566 respectively. The same applies to any other situations where an object
2567 of a bitfield type is expected.
2569 Types defined with @code{defbitfield} canonicalize to @var{base-type}
2570 which is @code{:int} by default.
2572 @subheading Examples
2573 @lisp
2574 (defbitfield open-flags
2575   (:rdonly #x0000)
2576   :wronly               ;@lispcmt{#x0001}
2577   :rdwr                 ;@lispcmt{@dots{}}
2578   :nonblock
2579   :append
2580   (:creat  #x0200))
2581   ;; @lispcmt{etc@dots{}}
2583 CFFI> (foreign-bitfield-symbols 'open-flags #b1101)
2584 @result{} (:WRONLY :NONBLOCK :APPEND)
2586 CFFI> (foreign-bitfield-value 'open-flags '(:rdwr :creat))
2587 @result{} 514   ; #x0202
2589 (defcfun ("open" unix-open) :int
2590   (path :string)
2591   (flags open-flags)
2592   (mode :uint16)) ; unportable
2594 CFFI> (unix-open "/tmp/foo" '(:wronly :creat) #o644)
2595 @result{} #<an fd>
2597 ;;; @lispcmt{Consider also the following lispier wrapper around open()}
2598 (defun lispier-open (path mode &rest flags)
2599   (unix-open path flags mode))
2600 @end lisp
2602 @subheading See Also
2603 @seealso{foreign-bitfield-value} @*
2604 @seealso{foreign-bitfield-symbols}
2607 @c ===================================================================
2608 @c DEFCSTRUCT
2610 @page
2611 @node defcstruct, defcunion, defbitfield, Foreign Types
2612 @heading defcstruct
2613 @subheading Syntax
2614 @Macro{defcstruct name-and-options &body doc-and-slots @res{} name}
2616 name-and-options ::= structure-name | (structure-name &key size) @*
2617 doc-and-slots ::= [docstring] @{ (slot-name slot-type &key count offset) @}*
2619 @subheading Arguments and Values
2621 @table @var
2622 @item structure-name
2623 The name of new structure type.
2625 @item docstring
2626 A documentation string, ignored.
2628 @item slot-name
2629 A symbol naming the slot.  It must be unique among slot names in this
2630 structure.
2632 @item size
2633 Use this option to override the size (in bytes) of the struct.
2635 @item slot-type
2636 The type specifier for the slot.
2638 @item count
2639 Used to declare an array of size @var{count} inside the
2640 structure.  Defaults to @code{1} as such an array and a single element
2641 are semantically equivalent.
2643 @item offset
2644 Overrides the slot's offset. The next slot's offset is calculated
2645 based on this one.
2646 @end table
2648 @subheading Description
2649 This defines a new @cffi{} aggregate type akin to C @code{struct}s.
2650 In other words, it specifies that foreign objects of the type
2651 @var{structure-name} are groups of different pieces of data, or
2652 ``slots'', of the @var{slot-type}s, distinguished from each other by
2653 the @var{slot-name}s.  Each structure is located in memory at a
2654 position, and the slots are allocated sequentially beginning at that
2655 point in memory (with some padding allowances as defined by the C
2656 @acronym{ABI}, unless otherwise requested by specifying an
2657 @var{offset} from the beginning of the structure (offset 0).
2659 In other words, it is isomorphic to the C @code{struct}, giving
2660 several extra features.
2662 There are two kinds of slots, for the two kinds of @cffi{} types:
2664 @table @dfn
2665 @item Simple
2666 Contain a single instance of a type that canonicalizes to a built-in
2667 type, such as @code{:long} or @code{:pointer}.  Used for simple
2668 @cffi{} types.
2670 @item Aggregate
2671 Contain an embedded structure or union, or an array of objects.  Used
2672 for aggregate @cffi{} types.
2673 @end table
2675 The use of @acronym{CLOS} terminology for the structure-related
2676 features is intentional; structure definitions are very much like
2677 classes with (far) fewer features.
2679 @subheading Examples
2680 @lisp
2681 (defcstruct point
2682   "Point structure."
2683   (x :int)
2684   (y :int))
2686 CFFI> (with-foreign-object (ptr 'point)
2687         ;; @lispcmt{Initialize the slots}
2688         (setf (foreign-slot-value ptr 'point 'x) 42
2689               (foreign-slot-value ptr 'point 'y) 42)
2690         ;; @lispcmt{Return a list with the coordinates}
2691         (with-foreign-slots ((x y) ptr point)
2692           (list x y)))
2693 @result{} (42 42)
2694 @end lisp
2696 @lisp
2697 ;; @lispcmt{Using the :size and :offset options to define a partial structure.}
2698 ;; @lispcmt{(this is useful when you are interested in only a few slots}
2699 ;; @lispcmt{of a big foreign structure)}
2701 (defcstruct (foo :size 32)
2702   "Some struct with 32 bytes."
2703                         ; @lispcmt{<16 bytes we don't care about>}
2704   (x :int :offset 16)   ; @lispcmt{an int at offset 16}
2705   (y :int)              ; @lispcmt{another int at offset 16+sizeof(int)}
2706                         ; @lispcmt{<a couple more bytes we don't care about>}
2707   (z :char :offset 24)) ; @lispcmt{a char at offset 24}
2708                         ; @lispcmt{<7 more bytes ignored (since size is 32)>}
2710 CFFI> (foreign-type-size 'foo)
2711 @result{} 32
2712 @end lisp
2714 @lisp
2715 ;;; @lispcmt{Using :count to define arrays inside of a struct.}
2716 (defcstruct video_tuner
2717   (name :char :count 32))
2718 @end lisp
2720 @subheading See Also
2721 @seealso{foreign-slot-pointer} @*
2722 @seealso{foreign-slot-value} @*
2723 @seealso{with-foreign-slots}
2726 @c ===================================================================
2727 @c DEFCUNION
2729 @page
2730 @node defcunion, defctype, defcstruct, Foreign Types
2731 @heading defcunion
2732 @subheading Syntax
2733 @Macro{defcunion name &body doc-and-slots @res{} name}
2735 doc-and-slots ::= [docstring] @{ (slot-name slot-type &key count) @}*
2737 @subheading Arguments and Values
2739 @table @var
2740 @item name
2741 The name of new union type.
2743 @item docstring
2744 A documentation string, ignored.
2746 @item slot-name
2747 A symbol naming the slot.
2749 @item slot-type
2750 The type specifier for the slot.
2752 @item count
2753 Used to declare an array of size @var{count} inside the
2754 structure.
2755 @end table
2757 @subheading Description
2758 A union is a structure in which all slots have an offset of zero.  It
2759 is isomorphic to the C @code{union}.  Therefore, you should use the
2760 usual foreign structure operations for accessing a union's slots.
2762 @subheading Examples
2763 @lisp
2764 (defcunion uint32-bytes
2765   (int-value :unsigned-int)
2766   (bytes :unsigned-char :count 4))
2767 @end lisp
2769 @subheading See Also
2770 @seealso{foreign-slot-pointer} @*
2771 @seealso{foreign-slot-value}
2774 @c ===================================================================
2775 @c DEFCTYPE
2777 @page
2778 @node defctype, defcenum, defcunion, Foreign Types
2779 @heading defctype
2780 @subheading Syntax
2781 @Macro{defctype name base-type &optional documentation}
2783 @subheading Arguments and Values
2785 @table @var
2786 @item name
2787 The name of the new foreign type.
2789 @item base-type
2790 A symbol or a list defining the new type.
2792 @item documentation
2793 A documentation string, currently ignored.
2794 @end table
2796 @subheading Description
2797 The @code{defctype} macro provides a mechanism similar to C's
2798 @code{typedef} to define new types. The new type inherits
2799 @var{base-type}'s translators, if any. There is no way to define
2800 translations for types defined with @code{defctype}.  For that,
2801 you should use @ref{define-foreign-type}.
2803 @subheading Examples
2804 @lisp
2805 (defctype my-string :string
2806   "My own string type.")
2808 (defctype long-bools (:boolean :long)
2809   "Booleans that map to C longs.")
2810 @end lisp
2812 @subheading See Also
2813 @seealso{define-foreign-type}
2816 @c ===================================================================
2817 @c DEFCENUM
2819 @page
2820 @node defcenum, define-foreign-type, defctype, Foreign Types
2821 @heading defcenum
2822 @subheading Syntax
2823 @Macro{defcenum name-and-options &body enum-list}
2825 enum-list ::= [docstring] @{ keyword | (keyword value) @}* @*
2826 name-and-options ::= name | (name &optional (base-type :int) &key allow-undeclared-values) @*
2828 @subheading Arguments and Values
2830 @table @var
2831 @item name
2832 The name of the new enum type.
2834 @item docstring
2835 A documentation string, ignored.
2837 @item base-type
2838 A symbol denoting a foreign type.
2840 @item allow-undeclared-values
2841 Whether to pass through integer values that were not explicitly declared
2842 in the enum when translating from foreign memory.
2844 @item keyword
2845 A keyword symbol.
2847 @item value
2848 An index value for a keyword.
2849 @end table
2851 @subheading Description
2852 The @code{defcenum} macro is used to define foreign types that map
2853 keyword symbols to integer values, similar to the C @code{enum} type.
2855 If @var{value} is omitted its value will either be 0, if it's the
2856 first entry, or it it will continue the progression from the last
2857 specified value.
2859 Keywords will be automatically converted to values and vice-versa when
2860 being passed as arguments to or returned from foreign functions,
2861 respectively. The same applies to any other situations where an object
2862 of an @code{enum} type is expected.
2864 If a value should be translated to lisp that is not declared in the
2865 enum, an error will be signalled. You can elide this error and instead
2866 make it pass the original enum value by specifying
2867 @var{allow-undeclared-values}. This can be useful for very large
2868 enumerations of which we only care about a subset of values, or for
2869 enumerations that should allow for client or vendor extensions that we
2870 cannot know about.
2872 Types defined with @code{defcenum} canonicalize to @var{base-type}
2873 which is @code{:int} by default.
2875 @subheading Examples
2876 @lisp
2877 (defcenum boolean
2878   :no
2879   :yes)
2881 CFFI> (foreign-enum-value 'boolean :no)
2882 @result{} 0
2883 @end lisp
2885 @lisp
2886 (defcenum numbers
2887   (:one 1)
2888   :two
2889   (:four 4))
2891 CFFI> (foreign-enum-keyword 'numbers 2)
2892 @result{} :TWO
2893 @end lisp
2895 @subheading See Also
2896 @seealso{foreign-enum-value} @*
2897 @seealso{foreign-enum-keyword}
2900 @c ===================================================================
2901 @c DEFINE-FOREIGN-TYPE
2903 @page
2904 @node define-foreign-type, define-parse-method, defcenum, Foreign Types
2905 @heading define-foreign-type
2906 @subheading Syntax
2907 @Macro{define-foreign-type class-name supers slots &rest options @res{} class-name}
2909 options ::= (@code{:actual-type} @var{type}) | @
2910     (@code{:simple-parser} @var{symbol}) | @
2911     @emph{regular defclass option}
2913 @subheading Arguments and Values
2915 @table @var
2916 @item class-name
2917 A symbol naming the new foreign type class.
2919 @item supers
2920 A list of symbols naming the super classes.
2922 @item slots
2923 A list of slot definitions, passed to @code{defclass}.
2924 @end table
2926 @subheading Description
2928 @c TODO rewrite
2930 The macro @code{define-foreign-type} defines a new class
2931 @var{class-name}. It is a thin wrapper around @code{defclass}. Among
2932 other things, it ensures that @var{class-name} becomes a subclass of
2933 @var{foreign-type}, what you need to know about that is that there's
2934 an initarg @code{:actual-type} which serves the same purpose as
2935 @code{defctype}'s @var{base-type} argument.
2937 @c TODO mention the type translators here
2938 @c FIX FIX
2940 @subheading Examples
2941 Taken from @cffi{}'s @code{:boolean} type definition:
2943 @lisp
2944 (define-foreign-type :boolean (&optional (base-type :int))
2945   "Boolean type. Maps to an :int by default. Only accepts integer types."
2946   (ecase base-type
2947     ((:char
2948       :unsigned-char
2949       :int
2950       :unsigned-int
2951       :long
2952       :unsigned-long) base-type)))
2954 CFFI> (canonicalize-foreign-type :boolean)
2955 @result{} :INT
2956 CFFI> (canonicalize-foreign-type '(:boolean :long))
2957 @result{} :LONG
2958 CFFI> (canonicalize-foreign-type '(:boolean :float))
2959 ;; @lispcmt{@error{} signalled by ECASE.}
2960 @end lisp
2962 @subheading See Also
2963 @seealso{defctype} @*
2964 @seealso{define-parse-method}
2967 @c ===================================================================
2968 @c DEFINE-PARSE-METHOD
2970 @page
2971 @node define-parse-method, foreign-bitfield-symbols, define-foreign-type, Foreign Types
2972 @heading define-parse-method
2973 @subheading Syntax
2974 @Macro{define-parse-method name lambda-list &body body @res{} name}
2976 @subheading Arguments and Values
2978 @table @var
2979 @item type-name
2980 A symbol naming the new foreign type.
2982 @item lambda-list
2983 A lambda list which is the argument list of the new foreign type.
2985 @item body
2986 One or more forms that provide a definition of the new foreign type.
2987 @end table
2989 @subheading Description
2992 @c TODO: update example. The boolean type is probably a good choice.
2994 @subheading Examples
2995 Taken from @cffi{}'s @code{:boolean} type definition:
2997 @lisp
2998 (define-foreign-type :boolean (&optional (base-type :int))
2999   "Boolean type. Maps to an :int by default. Only accepts integer types."
3000   (ecase base-type
3001     ((:char
3002       :unsigned-char
3003       :int
3004       :unsigned-int
3005       :long
3006       :unsigned-long) base-type)))
3008 CFFI> (canonicalize-foreign-type :boolean)
3009 @result{} :INT
3010 CFFI> (canonicalize-foreign-type '(:boolean :long))
3011 @result{} :LONG
3012 CFFI> (canonicalize-foreign-type '(:boolean :float))
3013 ;; @lispcmt{@error{} signalled by ECASE.}
3014 @end lisp
3016 @subheading See Also
3017 @seealso{define-foreign-type}
3020 @c ===================================================================
3021 @c EXPLAIN-FOREIGN-SLOT-VALUE
3023 @c @node explain-foreign-slot-value
3024 @c @heading explain-foreign-slot-value
3025 @c @subheading Syntax
3026 @c @Macro{explain-foreign-slot-value ptr type &rest slot-names}
3028 @c @subheading Arguments and Values
3030 @c @table @var
3031 @c @item ptr
3032 @c ...
3034 @c @item type
3035 @c ...
3037 @c @item slot-names
3038 @c ...
3039 @c @end table
3041 @c @subheading Description
3042 @c This macro translates the slot access that would occur by calling
3043 @c @code{foreign-slot-value} with the same arguments into an equivalent
3044 @c expression in C and prints it to @code{*standard-output*}.
3046 @c @emph{Note: this is not implemented yet.}
3048 @c @subheading Examples
3049 @c @lisp
3050 @c CFFI> (explain-foreign-slot-value ptr 'timeval 'tv-secs)
3051 @c @result{} ptr->tv_secs
3053 @c CFFI> (explain-foreign-slot-value emp 'employee 'hire-date 'tv-usecs)
3054 @c @result{} emp->hire_date.tv_usecs
3055 @c @end lisp
3057 @c @subheading See Also
3060 @c ===================================================================
3061 @c FOREIGN-BITFIELD-SYMBOLS
3063 @page
3064 @node foreign-bitfield-symbols, foreign-bitfield-value, define-parse-method, Foreign Types
3065 @heading foreign-bitfield-symbols
3066 @subheading Syntax
3067 @Function{foreign-bitfield-symbols type value @res{} symbols}
3069 @subheading Arguments and Values
3071 @table @var
3072 @item type
3073 A bitfield type.
3075 @item value
3076 An integer.
3078 @item symbols
3079 A potentially shared list of symbols.
3080 @code{nil}.
3081 @end table
3083 @subheading Description
3084 The function @code{foreign-bitfield-symbols} returns a possibly shared
3085 list of symbols that correspond to @var{value} in @var{type}.
3087 @subheading Examples
3088 @lisp
3089 (defbitfield flags
3090   (flag-a 1)
3091   (flag-b 2)
3092   (flag-c 4))
3094 CFFI> (foreign-bitfield-symbols 'flags #b101)
3095 @result{} (FLAG-A FLAG-C)
3096 @end lisp
3098 @subheading See Also
3099 @seealso{defbitfield} @*
3100 @seealso{foreign-bitfield-value}
3103 @c ===================================================================
3104 @c FOREIGN-BITFIELD-VALUE
3106 @page
3107 @node foreign-bitfield-value, foreign-enum-keyword, foreign-bitfield-symbols, Foreign Types
3108 @heading foreign-bitfield-value
3109 @subheading Syntax
3110 @Function{foreign-bitfield-value type symbols @res{} value}
3112 @subheading Arguments and Values
3114 @table @var
3115 @item type
3116 A @code{bitfield} type.
3118 @item symbol
3119 A Lisp symbol.
3121 @item value
3122 An integer.
3123 @end table
3125 @subheading Description
3126 The function @code{foreign-bitfield-value} returns the @var{value} that
3127 corresponds to the symbols in the @var{symbols} list.
3129 @subheading Examples
3130 @lisp
3131 (defbitfield flags
3132   (flag-a 1)
3133   (flag-b 2)
3134   (flag-c 4))
3136 CFFI> (foreign-bitfield-value 'flags '(flag-a flag-c))
3137 @result{} 5  ; #b101
3138 @end lisp
3140 @subheading See Also
3141 @seealso{defbitfield} @*
3142 @seealso{foreign-bitfield-symbols}
3145 @c ===================================================================
3146 @c FOREIGN-ENUM-KEYWORD
3148 @page
3149 @node foreign-enum-keyword, foreign-enum-value, foreign-bitfield-value, Foreign Types
3150 @heading foreign-enum-keyword
3151 @subheading Syntax
3152 @Function{foreign-enum-keyword type value &key errorp @res{} keyword}
3154 @subheading Arguments and Values
3156 @table @var
3157 @item type
3158 An @code{enum} type.
3160 @item value
3161 An integer.
3163 @item errorp
3164 If true (the default), signal an error if @var{value} is not defined
3165 in @var{type}.  If false, @code{foreign-enum-keyword} returns
3166 @code{nil}.
3168 @item keyword
3169 A keyword symbol.
3170 @end table
3172 @subheading Description
3173 The function @code{foreign-enum-keyword} returns the keyword symbol
3174 that corresponds to @var{value} in @var{type}.
3176 An error is signaled if @var{type} doesn't contain such @var{value}
3177 and @var{errorp} is true.
3179 @subheading Examples
3180 @lisp
3181 (defcenum boolean
3182   :no
3183   :yes)
3185 CFFI> (foreign-enum-keyword 'boolean 1)
3186 @result{} :YES
3187 @end lisp
3189 @subheading See Also
3190 @seealso{defcenum} @*
3191 @seealso{foreign-enum-value}
3194 @c ===================================================================
3195 @c FOREIGN-ENUM-VALUE
3197 @page
3198 @node foreign-enum-value, foreign-slot-names, foreign-enum-keyword, Foreign Types
3199 @heading foreign-enum-value
3200 @subheading Syntax
3201 @Function{foreign-enum-value type keyword &key errorp @res{} value}
3203 @subheading Arguments and Values
3205 @table @var
3206 @item type
3207 An @code{enum} type.
3209 @item keyword
3210 A keyword symbol.
3212 @item errorp
3213 If true (the default), signal an error if @var{keyword} is not
3214 defined in @var{type}.  If false, @code{foreign-enum-value} returns
3215 @code{nil}.
3217 @item value
3218 An integer.
3219 @end table
3221 @subheading Description
3222 The function @code{foreign-enum-value} returns the @var{value} that
3223 corresponds to @var{keyword} in @var{type}.
3225 An error is signaled if @var{type} doesn't contain such
3226 @var{keyword}, and @var{errorp} is true.
3228 @subheading Examples
3229 @lisp
3230 (defcenum boolean
3231   :no
3232   :yes)
3234 CFFI> (foreign-enum-value 'boolean :yes)
3235 @result{} 1
3236 @end lisp
3238 @subheading See Also
3239 @seealso{defcenum} @*
3240 @seealso{foreign-enum-keyword}
3243 @c ===================================================================
3244 @c FOREIGN-SLOT-NAMES
3246 @page
3247 @node foreign-slot-names, foreign-slot-offset, foreign-enum-value, Foreign Types
3248 @heading foreign-slot-names
3249 @subheading Syntax
3250 @Function{foreign-slot-names type @res{} names}
3252 @subheading Arguments and Values
3254 @table @var
3255 @item type
3256 A foreign struct type.
3258 @item names
3259 A list.
3260 @end table
3262 @subheading Description
3263 The function @code{foreign-slot-names} returns a potentially shared
3264 list of slot @var{names} for the given structure @var{type}. This list
3265 has no particular order.
3267 @subheading Examples
3268 @lisp
3269 (defcstruct timeval
3270   (tv-secs :long)
3271   (tv-usecs :long))
3273 CFFI> (foreign-slot-names '(:struct timeval))
3274 @result{} (TV-SECS TV-USECS)
3275 @end lisp
3277 @subheading See Also
3278 @seealso{defcstruct} @*
3279 @seealso{foreign-slot-offset} @*
3280 @seealso{foreign-slot-value} @*
3281 @seealso{foreign-slot-pointer}
3284 @c ===================================================================
3285 @c FOREIGN-SLOT-OFFSET
3287 @page
3288 @node foreign-slot-offset, foreign-slot-pointer, foreign-slot-names, Foreign Types
3289 @heading foreign-slot-offset
3290 @subheading Syntax
3291 @Function{foreign-slot-offset type slot-name @res{} offset}
3293 @subheading Arguments and Values
3295 @table @var
3296 @item type
3297 A foreign struct type.
3299 @item slot-name
3300 A symbol.
3302 @item offset
3303 An integer.
3304 @end table
3306 @subheading Description
3307 The function @code{foreign-slot-offset} returns the @var{offset} in
3308 bytes of a slot in a foreign struct type.
3310 @subheading Examples
3311 @lisp
3312 (defcstruct timeval
3313   (tv-secs :long)
3314   (tv-usecs :long))
3316 CFFI> (foreign-slot-offset '(:struct timeval) 'tv-secs)
3317 @result{} 0
3318 CFFI> (foreign-slot-offset '(:struct timeval) 'tv-usecs)
3319 @result{} 4
3320 @end lisp
3322 @subheading See Also
3323 @seealso{defcstruct} @*
3324 @seealso{foreign-slot-names} @*
3325 @seealso{foreign-slot-pointer} @*
3326 @seealso{foreign-slot-value}
3329 @c ===================================================================
3330 @c FOREIGN-SLOT-POINTER
3332 @page
3333 @node foreign-slot-pointer, foreign-slot-value, foreign-slot-offset, Foreign Types
3334 @heading foreign-slot-pointer
3335 @subheading Syntax
3336 @Function{foreign-slot-pointer ptr type slot-name @res{} pointer}
3338 @subheading Arguments and Values
3340 @table @var
3341 @item ptr
3342 A pointer to a structure.
3344 @item type
3345 A foreign structure type.
3347 @item slot-names
3348 A slot name in the @var{type}.
3350 @item pointer
3351 A pointer to the slot @var{slot-name}.
3352 @end table
3354 @subheading Description
3355 Returns a pointer to the location of the slot @var{slot-name} in a
3356 foreign object of type @var{type} at @var{ptr}. The returned pointer
3357 points inside the structure. Both the pointer and the memory it points
3358 to have the same extent as @var{ptr}.
3360 For aggregate slots, this is the same value returned by
3361 @code{foreign-slot-value}.
3363 @subheading Examples
3364 @lisp
3365 (defcstruct point
3366   "Pointer structure."
3367   (x :int)
3368   (y :int))
3370 CFFI> (with-foreign-object (ptr '(:struct point))
3371         (foreign-slot-pointer ptr '(:struct point) 'x))
3372 @result{} #<FOREIGN-ADDRESS #xBFFF6E60>
3373 ;; @lispcmt{Note: the exact pointer representation varies from lisp to lisp.}
3374 @end lisp
3376 @subheading See Also
3377 @seealso{defcstruct} @*
3378 @seealso{foreign-slot-value} @*
3379 @seealso{foreign-slot-names} @*
3380 @seealso{foreign-slot-offset}
3383 @c ===================================================================
3384 @c FOREIGN-SLOT-VALUE
3386 @page
3387 @node foreign-slot-value, foreign-type-alignment, foreign-slot-pointer, Foreign Types
3388 @heading foreign-slot-value
3389 @subheading Syntax
3390 @Accessor{foreign-slot-value ptr type slot-name @res{} object}
3392 @subheading Arguments and Values
3394 @table @var
3395 @item ptr
3396 A pointer to a structure.
3398 @item type
3399 A foreign structure type.
3401 @item slot-name
3402 A symbol naming a slot in the structure type.
3404 @item object
3405 The object contained in the slot specified by @var{slot-name}.
3406 @end table
3408 @subheading Description
3409 For simple slots, @code{foreign-slot-value} returns the value of the
3410 object, such as a Lisp integer or pointer. In C, this would be
3411 expressed as @code{ptr->slot}.
3413 For aggregate slots, a pointer inside the structure to the beginning
3414 of the slot's data is returned. In C, this would be expressed as
3415 @code{&ptr->slot}. This pointer and the memory it points to have the
3416 same extent as @var{ptr}.
3418 There are compiler macros for @code{foreign-slot-value} and its
3419 @code{setf} expansion that open code the memory access when
3420 @var{type} and @var{slot-names} are constant at compile-time.
3422 @subheading Examples
3423 @lisp
3424 (defcstruct point
3425   "Pointer structure."
3426   (x :int)
3427   (y :int))
3429 CFFI> (with-foreign-object (ptr '(:struct point))
3430         ;; @lispcmt{Initialize the slots}
3431         (setf (foreign-slot-value ptr '(:struct point) 'x) 42
3432               (foreign-slot-value ptr '(:struct point) 'y) 42)
3433         ;; @lispcmt{Return a list with the coordinates}
3434         (with-foreign-slots ((x y) ptr (:struct point))
3435           (list x y)))
3436 @result{} (42 42)
3437 @end lisp
3439 @subheading See Also
3440 @seealso{defcstruct} @*
3441 @seealso{foreign-slot-names} @*
3442 @seealso{foreign-slot-offset} @*
3443 @seealso{foreign-slot-pointer} @*
3444 @seealso{with-foreign-slots}
3447 @c ===================================================================
3448 @c FOREIGN-TYPE-ALIGNMENT
3450 @page
3451 @node foreign-type-alignment, foreign-type-size, foreign-slot-value, Foreign Types
3452 @heading foreign-type-alignment
3453 @subheading Syntax
3454 @c XXX: This is actually a generic function.
3455 @Function{foreign-type-alignment type @res{} alignment}
3457 @subheading Arguments and Values
3459 @table @var
3460 @item type
3461 A foreign type.
3463 @item alignment
3464 An integer.
3465 @end table
3467 @subheading Description
3468 The function @code{foreign-type-alignment} returns the
3469 @var{alignment} of @var{type} in bytes.
3471 @subheading Examples
3472 @lisp
3473 CFFI> (foreign-type-alignment :char)
3474 @result{} 1
3475 CFFI> (foreign-type-alignment :short)
3476 @result{} 2
3477 CFFI> (foreign-type-alignment :int)
3478 @result{} 4
3479 @end lisp
3481 @lisp
3482 (defcstruct foo
3483   (a :char))
3485 CFFI> (foreign-type-alignment '(:struct foo))
3486 @result{} 1
3487 @end lisp
3489 @subheading See Also
3490 @seealso{foreign-type-size}
3493 @c ===================================================================
3494 @c FOREIGN-TYPE-SIZE
3496 @page
3497 @node foreign-type-size, free-converted-object, foreign-type-alignment, Foreign Types
3498 @heading foreign-type-size
3499 @subheading Syntax
3500 @c XXX: this is actually a generic function.
3501 @Function{foreign-type-size type @res{} size}
3503 @subheading Arguments and Values
3505 @table @var
3506 @item type
3507 A foreign type.
3509 @item size
3510 An integer.
3511 @end table
3513 @subheading Description
3514 The function @code{foreign-type-size} return the @var{size} of
3515 @var{type} in bytes.  This includes any padding within and following
3516 the in-memory representation as needed to create an array of
3517 @var{type} objects.
3519 @subheading Examples
3520 @lisp
3521 (defcstruct foo
3522   (a :double)
3523   (c :char))
3525 CFFI> (foreign-type-size :double)
3526 @result{} 8
3527 CFFI> (foreign-type-size :char)
3528 @result{} 1
3529 CFFI> (foreign-type-size '(:struct foo))
3530 @result{} 16
3531 @end lisp
3533 @subheading See Also
3534 @seealso{foreign-type-alignment}
3537 @c ===================================================================
3538 @c FREE-CONVERTED-OBJECT
3540 @page
3541 @node free-converted-object, free-translated-object, foreign-type-size, Foreign Types
3542 @heading free-converted-object
3543 @subheading Syntax
3544 @Function{free-converted-object foreign-value type params}
3546 @subheading Arguments and Values
3548 @table @var
3549 @item foreign-value
3550 The C object to be freed.
3552 @item type
3553 A @cffi{} type specifier.
3555 @item params
3556 The state returned as the second value from @code{convert-to-foreign};
3557 used to implement the third argument to @code{free-translated-object}.
3558 @end table
3560 @subheading Description
3562 The return value is unspecified.
3564 This is an external interface to the type translation facility.  In
3565 the implementation, all foreign functions are ultimately defined as
3566 type translation wrappers around primitive foreign function
3567 invocations.
3569 This function is available mostly for inspection of the type
3570 translation process, and possibly optimization of special cases of
3571 your foreign function calls.
3573 Its behavior is better described under @code{free-translated-object}'s
3574 documentation.
3576 @subheading Examples
3578 @lisp
3579 CFFI-USER> (convert-to-foreign "a boat" :string)
3580 @result{} #<FOREIGN-ADDRESS #x097ACDC0>
3581 @result{} T
3582 CFFI-USER> (free-converted-object * :string t)
3583 @result{} NIL
3584 @end lisp
3586 @subheading See Also
3587 @seealso{convert-from-foreign} @*
3588 @seealso{convert-to-foreign} @*
3589 @seealso{free-translated-object}
3592 @c ===================================================================
3593 @c FREE-TRANSLATED-OBJECT
3595 @c TODO: update
3597 @page
3598 @node free-translated-object, translate-from-foreign, free-converted-object, Foreign Types
3599 @heading free-translated-object
3600 @subheading Syntax
3601 @GenericFunction{free-translated-object value type-name param}
3603 @subheading Arguments and Values
3605 @table @var
3606 @item pointer
3607 The foreign value returned by @code{translate-to-foreign}.
3609 @item type-name
3610 A symbol naming a foreign type defined by @code{defctype}.
3612 @item param
3613 The second value, if any, returned by @code{translate-to-foreign}.
3614 @end table
3616 @subheading Description
3617 This generic function may be specialized by user code to perform
3618 automatic deallocation of foreign objects as they are passed to C
3619 functions.
3621 Any methods defined on this generic function must EQL-specialize the
3622 @var{type-name} parameter on a symbol defined as a foreign type by
3623 the @code{defctype} macro.
3625 @subheading See Also
3626 @seealso{Foreign Type Translators} @*
3627 @seealso{translate-to-foreign}
3630 @c ===================================================================
3631 @c TRANSLATE-FROM-FOREIGN
3633 @c TODO: update
3635 @page
3636 @node translate-from-foreign, translate-to-foreign, free-translated-object, Foreign Types
3637 @heading translate-from-foreign
3638 @subheading Syntax
3639 @GenericFunction{translate-from-foreign foreign-value type-name @
3640                                         @res{} lisp-value}
3642 @subheading Arguments and Values
3644 @table @var
3645 @item foreign-value
3646 The foreign value to convert to a Lisp object.
3648 @item type-name
3649 A symbol naming a foreign type defined by @code{defctype}.
3651 @item lisp-value
3652 The lisp value to pass in place of @code{foreign-value} to Lisp code.
3653 @end table
3655 @subheading Description
3656 This generic function is invoked by @cffi{} to convert a foreign value to
3657 a Lisp value, such as when returning from a foreign function, passing
3658 arguments to a callback function, or accessing a foreign variable.
3660 To extend the @cffi{} type system by performing custom translations, this
3661 method may be specialized by @sc{eql}-specializing @code{type-name} on a
3662 symbol naming a foreign type defined with @code{defctype}.  This
3663 method should return the appropriate Lisp value to use in place of the
3664 foreign value.
3666 The results are undefined if the @code{type-name} parameter is
3667 specialized in any way except an @sc{eql} specializer on a foreign type
3668 defined with @code{defctype}.  Specifically, translations may not be
3669 defined for built-in types.
3671 @subheading See Also
3672 @seealso{Foreign Type Translators} @*
3673 @seealso{translate-to-foreign} @*
3674 @seealso{free-translated-object}
3677 @c ===================================================================
3678 @c TRANSLATE-TO-FOREIGN
3680 @c TODO: update
3682 @page
3683 @node translate-to-foreign, translate-into-foreign-memory, translate-from-foreign, Foreign Types
3684 @heading translate-to-foreign
3685 @subheading Syntax
3686 @GenericFunction{translate-to-foreign lisp-value type-name @
3687                                       @res{} foreign-value, alloc-param}
3689 @subheading Arguments and Values
3691 @table @var
3692 @item lisp-value
3693 The Lisp value to convert to foreign representation.
3695 @item type-name
3696 A symbol naming a foreign type defined by @code{defctype}.
3698 @item foreign-value
3699 The foreign value to pass in place of @code{lisp-value} to foreign code.
3701 @item alloc-param
3702 If present, this value will be passed to
3703 @code{free-translated-object}.
3704 @end table
3706 @subheading Description
3707 This generic function is invoked by @cffi{} to convert a Lisp value to a
3708 foreign value, such as when passing arguments to a foreign function,
3709 returning a value from a callback, or setting a foreign variable.  A
3710 ``foreign value'' is one appropriate for passing to the next-lowest
3711 translator, including the low-level translators that are ultimately
3712 invoked invisibly with @cffi{}.
3714 To extend the @cffi{} type system by performing custom translations, this
3715 method may be specialized by @sc{eql}-specializing @code{type-name} on a
3716 symbol naming a foreign type defined with @code{defctype}.  This
3717 method should return the appropriate foreign value to use in place of
3718 the Lisp value.
3720 In cases where @cffi{} can determine the lifetime of the foreign object
3721 returned by this method, it will invoke @code{free-translated-object}
3722 on the foreign object at the appropriate time.  If
3723 @code{translate-to-foreign} returns a second value, it will be passed
3724 as the @code{param} argument to @code{free-translated-object}.  This
3725 can be used to establish communication between the allocation and
3726 deallocation methods.
3728 The results are undefined if the @code{type-name} parameter is
3729 specialized in any way except an @sc{eql} specializer on a foreign type
3730 defined with @code{defctype}.  Specifically, translations may not be
3731 defined for built-in types.
3733 @subheading See Also
3734 @seealso{Foreign Type Translators} @*
3735 @seealso{translate-from-foreign} @*
3736 @seealso{free-translated-object}
3739 @c ===================================================================
3740 @c TRANSLATE-INTO-FOREIGN-MEMORY
3742 @page
3743 @node translate-into-foreign-memory, with-foreign-slots, translate-to-foreign, Foreign Types
3744 @heading translate-into-foreign-memory
3745 @subheading Syntax
3746 @GenericFunction{translate-into-foreign-memory lisp-value type-name pointer}
3748 @subheading Arguments and Values
3750 @table @var
3751 @item lisp-value
3752 The Lisp value to convert to foreign representation.
3754 @item type-name
3755 A symbol or list @code{(:struct @var{structure-name})} naming a foreign type defined by @code{defctype}.
3757 @item pointer
3758 The foreign pointer where the translated object should be stored.
3759 @end table
3761 @subheading Description
3762 Translate the Lisp value into the foreign memory location given by
3763 pointer.  The return value is not used.
3765 @c ===================================================================
3766 @c WITH-FOREIGN-SLOTS
3768 @page
3769 @node with-foreign-slots,  , translate-into-foreign-memory, Foreign Types
3770 @heading with-foreign-slots
3771 @subheading Syntax
3772 @Macro{with-foreign-slots (vars ptr type) &body body}
3774 @subheading Arguments and Values
3776 @table @var
3777 @item vars
3778 A list with binding descriptors; each is either a symbol, or list with
3779 up to 3 elements: an optional new name to bind, an optional symbol 
3780 @code{:pointer} and finally the required slot symbol.
3782 @item ptr
3783 A foreign pointer to a structure.
3785 @item type
3786 A structure type.
3788 @item body
3789 A list of forms to be executed.
3790 @end table
3792 @subheading Description
3793 The @code{with-foreign-slots} macro establishes a lexical environment for
3794 referring to the foreign slots of @var{type} addressed by @var{ptr}.
3795 Like Common Lisp's @code{with-slots} macro, each var in @var{vars} may
3796 be a symbol naming a slot, or a list @code{(name slot)} which creates a 
3797 binding to a slot with a different name.
3798 Prefixing the slot name with @code{:pointer} creates a binding to a
3799 foreign pointer that addresses the slot rather than its value.  Both
3800 @code{(:pointer slot)} and @code{(name :pointer slot)} are acceptable.
3802 @subheading Examples
3803 @lisp
3804 (defcstruct tm
3805   (sec :int)
3806   (min :int)
3807   (hour :int)
3808   (mday :int)
3809   (mon  :int)
3810   (year :int)
3811   (wday :int)
3812   (yday :int)
3813   (isdst  :boolean)
3814   (zone   :string)
3815   (gmtoff :long))
3817 CFFI> (with-foreign-object (time :int)
3818         (setf (mem-ref time :int)
3819               (foreign-funcall "time" :pointer (null-pointer) :int))
3820         (foreign-funcall "gmtime" :pointer time (:pointer (:struct tm))))
3821 @result{} #<A Mac Pointer #x102A30>
3822 CFFI> (with-foreign-slots ((sec min hour (day-of-month mday) mon year) * (:struct tm))
3823         (format nil "~A:~A:~A, ~A/~A/~A"
3824                 hour min sec (+ 1900 year) mon day-of-month))
3825 @result{} "7:22:47, 2005/8/2"
3826 @end lisp
3828 @subheading See Also
3829 @seealso{defcstruct} @*
3830 @seealso{defcunion} @*
3831 @seealso{foreign-slot-value}
3834 @c ===================================================================
3835 @c CHAPTER: Pointers
3837 @node Pointers, Strings, Foreign Types, Top
3838 @chapter Pointers
3840 All C data in @cffi{} is referenced through pointers.  This includes
3841 defined C variables that hold immediate values, and integers.
3843 To see why this is, consider the case of the C integer.  It is not
3844 only an arbitrary representation for an integer, congruent to Lisp's
3845 fixnums; the C integer has a specific bit pattern in memory defined by
3846 the C @acronym{ABI}.  Lisp has no such constraint on its fixnums;
3847 therefore, it only makes sense to think of fixnums as C integers if
3848 you assume that @cffi{} converts them when necessary, such as when
3849 storing one for use in a C function call, or as the value of a C
3850 variable.  This requires defining an area of memory@footnote{The
3851 definition of @dfn{memory} includes the @acronym{CPU} registers.},
3852 represented through an effective address, and storing it there.
3854 Due to this compartmentalization, it only makes sense to manipulate
3855 raw C data in Lisp through pointers to it.  For example, while there
3856 may be a Lisp representation of a @code{struct} that is converted to C
3857 at store time, you may only manipulate its raw data through a pointer.
3858 The C compiler does this also, albeit informally.
3860 @menu
3861 * Basic Pointer Operations::
3862 * Allocating Foreign Memory::
3863 * Accessing Foreign Memory::
3865 Dictionary
3867 * foreign-free::
3868 * foreign-alloc::
3869 * foreign-symbol-pointer::
3870 * inc-pointer::
3871 * incf-pointer::
3872 * make-pointer::
3873 * mem-aptr::
3874 * mem-aref::
3875 * mem-ref::
3876 * null-pointer::
3877 * null-pointer-p::
3878 * pointerp::
3879 * pointer-address::
3880 * pointer-eq::
3881 * with-foreign-object::
3882 * with-foreign-objects::
3883 * with-foreign-pointer::
3884 @end menu
3886 @node Basic Pointer Operations, Allocating Foreign Memory, Pointers, Pointers
3887 @section Basic Pointer Operations
3889 Manipulating pointers proper can be accomplished through most of the
3890 other operations defined in the Pointers dictionary, such as
3891 @code{make-pointer}, @code{pointer-address}, and @code{pointer-eq}.
3892 When using them, keep in mind that they merely manipulate the Lisp
3893 representation of pointers, not the values they point to.
3895 @deftp {Lisp Type} foreign-pointer
3896 The pointers' representations differ from implementation to
3897 implementation and have different types.  @code{foreign-pointer}
3898 provides a portable type alias to each of these types.
3899 @end deftp
3902 @node Allocating Foreign Memory, Accessing Foreign Memory, Basic Pointer Operations, Pointers
3903 @section Allocating Foreign Memory
3905 @cffi{} provides support for stack and heap C memory allocation.
3906 Stack allocation, done with @code{with-foreign-object}, is sometimes
3907 called ``dynamic'' allocation in Lisp, because memory allocated as
3908 such has dynamic extent, much as with @code{let} bindings of special
3909 variables.
3911 This should not be confused with what C calls ``dynamic'' allocation,
3912 or that done with @code{malloc} and friends.  This sort of heap
3913 allocation is done with @code{foreign-alloc}, creating objects that
3914 exist until freed with @code{foreign-free}.
3917 @node Accessing Foreign Memory, foreign-free, Allocating Foreign Memory, Pointers
3918 @section Accessing Foreign Memory
3920 When manipulating raw C data, consider that all pointers are pointing
3921 to an array.  When you only want one C value, such as a single
3922 @code{struct}, this array only has one such value.  It is worthwhile
3923 to remember that everything is an array, though, because this is also
3924 the semantic that C imposes natively.
3926 C values are accessed as the @code{setf}-able places defined by
3927 @code{mem-aref} and @code{mem-ref}.  Given a pointer and a @cffi{}
3928 type (@pxref{Foreign Types}), either of these will dereference the
3929 pointer, translate the C data there back to Lisp, and return the
3930 result of said translation, performing the reverse operation when
3931 @code{setf}-ing.  To decide which one to use, consider whether you
3932 would use the array index operator @code{[@var{n}]} or the pointer
3933 dereference @code{*} in C; use @code{mem-aref} for array indexing and
3934 @code{mem-ref} for pointer dereferencing.
3937 @c ===================================================================
3938 @c FOREIGN-FREE
3940 @page
3941 @node foreign-free, foreign-alloc, Accessing Foreign Memory, Pointers
3942 @heading foreign-free
3943 @subheading Syntax
3944 @Function{foreign-free ptr @res{} undefined}
3946 @subheading Arguments and Values
3948 @table @var
3949 @item ptr
3950 A foreign pointer.
3951 @end table
3953 @subheading Description
3954 The @code{foreign-free} function frees a @code{ptr} previously
3955 allocated by @code{foreign-alloc}. The consequences of freeing a given
3956 pointer twice are undefined.
3958 @subheading Examples
3960 @lisp
3961 CFFI> (foreign-alloc :int)
3962 @result{} #<A Mac Pointer #x1022E0>
3963 CFFI> (foreign-free *)
3964 @result{} NIL
3965 @end lisp
3967 @subheading See Also
3968 @seealso{foreign-alloc} @*
3969 @seealso{with-foreign-pointer}
3972 @c ===================================================================
3973 @c FOREIGN-ALLOC
3975 @page
3976 @node foreign-alloc, foreign-symbol-pointer, foreign-free, Pointers
3977 @heading foreign-alloc
3978 @subheading Syntax
3979 @Function{foreign-alloc type &key initial-element initial-contents (count 1) @
3980                         null-terminated-p @res{} pointer}
3982 @subheading Arguments and Values
3984 @table @var
3985 @item type
3986 A foreign type.
3988 @item initial-element
3989 A Lisp object.
3991 @item initial-contents
3992 A sequence.
3994 @item count
3995 An integer. Defaults to 1 or the length of @var{initial-contents} if
3996 supplied.
3998 @item null-terminated-p
3999 A boolean, false by default.
4001 @item pointer
4002 A foreign pointer to the newly allocated memory.
4003 @end table
4005 @subheading Description
4006 The @code{foreign-alloc} function allocates enough memory to hold
4007 @var{count} objects of type @var{type} and returns a
4008 @var{pointer}. This memory must be explicitly freed using
4009 @code{foreign-free} once it is no longer needed.
4011 If @var{initial-element} is supplied, it is used to initialize the
4012 @var{count} objects the newly allocated memory holds.
4014 If an @var{initial-contents} sequence is supplied, it must have a
4015 length less than or equal to @var{count} and each of its elements
4016 will be used to initialize the contents of the newly allocated
4017 memory.
4019 If @var{count} is omitted and @var{initial-contents} is specified, it
4020 will default to @code{(length @var{initial-contents})}.
4022 @var{initial-element} and @var{initial-contents} are mutually
4023 exclusive.
4025 When @var{null-terminated-p} is true,
4026 @code{(1+ (max @var{count} (length @var{initial-contents})))} elements
4027 are allocated and the last one is set to @code{NULL}. Note that in
4028 this case @var{type} must be a pointer type (ie. a type that
4029 canonicalizes to @code{:pointer}), otherwise an error is signaled.
4031 @subheading Examples
4032 @lisp
4033 CFFI> (foreign-alloc :char)
4034 @result{} #<A Mac Pointer #x102D80>     ; @lispcmt{A pointer to 1 byte of memory.}
4036 CFFI> (foreign-alloc :char :count 20)
4037 @result{} #<A Mac Pointer #x1024A0>     ; @lispcmt{A pointer to 20 bytes of memory.}
4039 CFFI> (foreign-alloc :int :initial-element 12)
4040 @result{} #<A Mac Pointer #x1028B0>
4041 CFFI> (mem-ref * :int)
4042 @result{} 12
4044 CFFI> (foreign-alloc :int :initial-contents '(1 2 3))
4045 @result{} #<A Mac Pointer #x102950>
4046 CFFI> (loop for i from 0 below 3
4047             collect (mem-aref * :int i))
4048 @result{} (1 2 3)
4050 CFFI> (foreign-alloc :int :initial-contents #(1 2 3))
4051 @result{} #<A Mac Pointer #x102960>
4052 CFFI> (loop for i from 0 below 3
4053             collect (mem-aref * :int i))
4054 @result{} (1 2 3)
4056 ;;; @lispcmt{Allocate a char** pointer that points to newly allocated memory}
4057 ;;; @lispcmt{by the :string type translator for the string "foo".}
4058 CFFI> (foreign-alloc :string :initial-element "foo")
4059 @result{} #<A Mac Pointer #x102C40>
4060 @end lisp
4062 @lisp
4063 ;;; @lispcmt{Allocate a null-terminated array of strings.}
4064 ;;; @lispcmt{(Note: FOREIGN-STRING-TO-LISP returns NIL when passed a null pointer)}
4065 CFFI> (foreign-alloc :string
4066                      :initial-contents '("foo" "bar" "baz")
4067                      :null-terminated-p t)
4068 @result{} #<A Mac Pointer #x102D20>
4069 CFFI> (loop for i from 0 below 4
4070             collect (mem-aref * :string i))
4071 @result{} ("foo" "bar" "baz" NIL)
4072 CFFI> (progn
4073         (dotimes (i 3)
4074           (foreign-free (mem-aref ** :pointer i)))
4075         (foreign-free **))
4076 @result{} nil
4077 @end lisp
4079 @subheading See Also
4080 @seealso{foreign-free} @*
4081 @seealso{with-foreign-object} @*
4082 @seealso{with-foreign-pointer}
4085 @c ===================================================================
4086 @c FOREIGN-SYMBOL-POINTER
4088 @page
4089 @node foreign-symbol-pointer, inc-pointer, foreign-alloc, Pointers
4090 @heading foreign-symbol-pointer
4091 @subheading Syntax
4092 @Function{foreign-symbol-pointer foreign-name &key library @res{} pointer}
4094 @subheading Arguments and Values
4096 @table @var
4097 @item foreign-name
4098 A string.
4100 @item pointer
4101 A foreign pointer, or @code{nil}.
4103 @item library
4104 A Lisp symbol or an instance of @code{foreign-library}.
4105 @end table
4107 @subheading Description
4108 The function @code{foreign-symbol-pointer} will return a foreign
4109 pointer corresponding to the foreign symbol denoted by the string
4110 @var{foreign-name}.  If a foreign symbol named @var{foreign-name}
4111 doesn't exist, @code{nil} is returned.
4113 ABI name manglings will be performed on @var{foreign-name} by
4114 @code{foreign-symbol-pointer} if necessary. (eg: adding a leading
4115 underscore on darwin/ppc)
4117 @var{library} should name a foreign library as defined by
4118 @code{define-foreign-library}, @code{:default} (which is the default)
4119 or an instance of @code{foreign-library} as returned by
4120 @code{load-foreign-library}.
4122 @strong{Important note:} do not keep these pointers across saved Lisp
4123 cores as the foreign-library may move across sessions.
4125 @subheading Examples
4127 @lisp
4128 CFFI> (foreign-symbol-pointer "errno")
4129 @result{} #<A Mac Pointer #xA0008130>
4130 CFFI> (foreign-symbol-pointer "strerror")
4131 @result{} #<A Mac Pointer #x9002D0F8>
4132 CFFI> (foreign-funcall-pointer * () :int (mem-ref ** :int) :string)
4133 @result{} "No such file or directory"
4135 CFFI> (foreign-symbol-pointer "inexistent symbol")
4136 @result{} NIL
4137 @end lisp
4139 @subheading See Also
4140 @seealso{defcvar}
4143 @c ===================================================================
4144 @c INC-POINTER
4146 @page
4147 @node inc-pointer, incf-pointer, foreign-symbol-pointer, Pointers
4148 @heading inc-pointer
4149 @subheading Syntax
4150 @Function{inc-pointer pointer offset @res{} new-pointer}
4152 @subheading Arguments and Values
4154 @table @var
4155 @item pointer
4156 @itemx new-pointer
4157 A foreign pointer.
4159 @item offset
4160 An integer.
4161 @end table
4163 @subheading Description
4164 The function @code{inc-pointer} will return a @var{new-pointer} pointing
4165 @var{offset} bytes past @var{pointer}.
4167 @subheading Examples
4169 @lisp
4170 CFFI> (foreign-string-alloc "Common Lisp")
4171 @result{} #<A Mac Pointer #x102EA0>
4172 CFFI> (inc-pointer * 7)
4173 @result{} #<A Mac Pointer #x102EA7>
4174 CFFI> (foreign-string-to-lisp *)
4175 @result{} "Lisp"
4176 @end lisp
4178 @subheading See Also
4179 @seealso{incf-pointer} @*
4180 @seealso{make-pointer} @*
4181 @seealso{pointerp} @*
4182 @seealso{null-pointer} @*
4183 @seealso{null-pointer-p}
4186 @c ===================================================================
4187 @c INCF-POINTER
4189 @page
4190 @node incf-pointer, make-pointer, inc-pointer, Pointers
4191 @heading incf-pointer
4192 @subheading Syntax
4193 @Macro{incf-pointer place &optional (offset 1) @res{} new-pointer}
4195 @subheading Arguments and Values
4197 @table @var
4198 @item place
4199 A @code{setf} place.
4201 @item new-pointer
4202 A foreign pointer.
4204 @item offset
4205 An integer.
4206 @end table
4208 @subheading Description
4209 The @code{incf-pointer} macro takes the foreign pointer from
4210 @var{place} and creates a @var{new-pointer} incremented by
4211 @var{offset} bytes and which is stored in @var{place}.
4213 @subheading Examples
4215 @lisp
4216 CFFI> (defparameter *two-words* (foreign-string-alloc "Common Lisp"))
4217 @result{} *TWO-WORDS*
4218 CFFI> (defparameter *one-word* *two-words*)
4219 @result{} *ONE-WORD*
4220 CFFI> (incf-pointer *one-word* 7)
4221 @result{} #.(SB-SYS:INT-SAP #X00600457)
4222 CFFI> (foreign-string-to-lisp *one-word*)
4223 @result{} "Lisp"
4224 CFFI> (foreign-string-to-lisp *two-words*)
4225 @result{} "Common Lisp"
4226 @end lisp
4228 @subheading See Also
4229 @seealso{inc-pointer} @*
4230 @seealso{make-pointer} @*
4231 @seealso{pointerp} @*
4232 @seealso{null-pointer} @*
4233 @seealso{null-pointer-p}
4236 @c ===================================================================
4237 @c MAKE-POINTER
4239 @page
4240 @node make-pointer, mem-aptr, incf-pointer, Pointers
4241 @heading make-pointer
4242 @subheading Syntax
4243 @Function{make-pointer address @res{} ptr}
4245 @subheading Arguments and Values
4247 @table @var
4248 @item address
4249 An integer.
4251 @item ptr
4252 A foreign pointer.
4253 @end table
4255 @subheading Description
4256 The function @code{make-pointer} will return a foreign pointer
4257 pointing to @var{address}.
4259 @subheading Examples
4261 @lisp
4262 CFFI> (make-pointer 42)
4263 @result{} #<FOREIGN-ADDRESS #x0000002A>
4264 CFFI> (pointerp *)
4265 @result{} T
4266 CFFI> (pointer-address **)
4267 @result{} 42
4268 CFFI> (inc-pointer *** -42)
4269 @result{} #<FOREIGN-ADDRESS #x00000000>
4270 CFFI> (null-pointer-p *)
4271 @result{} T
4272 CFFI> (typep ** 'foreign-pointer)
4273 @result{} T
4274 @end lisp
4276 @subheading See Also
4277 @seealso{inc-pointer} @*
4278 @seealso{null-pointer} @*
4279 @seealso{null-pointer-p} @*
4280 @seealso{pointerp} @*
4281 @seealso{pointer-address} @*
4282 @seealso{pointer-eq} @*
4283 @seealso{mem-ref}
4286 @c ===================================================================
4287 @c MEM-APTR
4289 @page
4290 @node mem-aptr, mem-aref, make-pointer, Pointers
4291 @heading mem-aptr
4292 @subheading Syntax
4293 @Accessor{mem-aptr ptr type &optional (index 0)}
4295 @subheading Arguments and Values
4297 @table @var
4298 @item ptr
4299 A foreign pointer.
4301 @item type
4302 A foreign type.
4304 @item index
4305 An integer.
4307 @item new-value
4308 A Lisp value compatible with @var{type}.
4309 @end table
4311 @subheading Description
4312 The @code{mem-aptr} function finds the pointer to an element of the array.
4314 @lisp
4315 (mem-aptr ptr type n)
4317 ;; @lispcmt{is identical to:}
4319 (inc-pointer ptr (* n (foreign-type-size type)))
4320 @end lisp
4322 @subheading Examples
4324 @lisp
4325 CFFI> (with-foreign-string (str "Hello, foreign world!")
4326         (mem-aptr str :char 6))
4327 @result{} #.(SB-SYS:INT-SAP #X0063D4B6)
4328 @end lisp
4330 @c ===================================================================
4331 @c MEM-AREF
4333 @page
4334 @node mem-aref, mem-ref, mem-aptr, Pointers
4335 @heading mem-aref
4336 @subheading Syntax
4337 @Accessor{mem-aref ptr type &optional (index 0)}
4339 (setf (@strong{mem-aref} @emph{ptr type &optional (index 0)) new-value})
4341 @subheading Arguments and Values
4343 @table @var
4344 @item ptr
4345 A foreign pointer.
4347 @item type
4348 A foreign type.
4350 @item index
4351 An integer.
4353 @item new-value
4354 A Lisp value compatible with @var{type}.
4355 @end table
4357 @subheading Description
4358 The @code{mem-aref} function is similar to @code{mem-ref} but will
4359 automatically calculate the offset from an @var{index}.
4361 @lisp
4362 (mem-aref ptr type n)
4364 ;; @lispcmt{is identical to:}
4366 (mem-ref ptr type (* n (foreign-type-size type)))
4367 @end lisp
4369 @subheading Examples
4371 @lisp
4372 CFFI> (with-foreign-string (str "Hello, foreign world!")
4373         (mem-aref str :char 6))
4374 @result{} 32
4375 CFFI> (code-char *)
4376 @result{} #\Space
4378 CFFI> (with-foreign-object (array :int 10)
4379         (loop for i below 10
4380               do (setf (mem-aref array :int i) (random 100)))
4381         (loop for i below 10 collect (mem-aref array :int i)))
4382 @result{} (22 7 22 52 69 1 46 93 90 65)
4383 @end lisp
4385 @subheading Compatibility Note
4387 For compatibility with older versions of CFFI, @ref{mem-aref} will
4388 produce a pointer for the deprecated bare structure specification, but
4389 it is consistent with other types for the current specification form
4390 @code{(:struct @var{structure-name})} and provides a Lisp object
4391 translated from the structure (by default a plist).  In order to obtain
4392 the pointer, you should use the new function @ref{mem-aptr}.
4394 @subheading See Also
4395 @seealso{mem-ref} @*
4396 @seealso{mem-aptr}
4398 @c ===================================================================
4399 @c MEM-REF
4401 @page
4402 @node mem-ref, null-pointer, mem-aref, Pointers
4403 @heading mem-ref
4404 @subheading Syntax
4405 @Accessor{mem-ref ptr type &optional offset @res{} object}
4407 @subheading Arguments and Values
4409 @table @var
4410 @item ptr
4411 A pointer.
4413 @item type
4414 A foreign type.
4416 @item offset
4417 An integer (in byte units).
4419 @item object
4420 The value @var{ptr} points to.
4421 @end table
4423 @subheading Description
4424 @subheading Examples
4426 @lisp
4427 CFFI> (with-foreign-string (ptr "Saluton")
4428         (setf (mem-ref ptr :char 3) (char-code #\a))
4429         (loop for i from 0 below 8
4430               collect (code-char (mem-ref ptr :char i))))
4431 @result{} (#\S #\a #\l #\a #\t #\o #\n #\Null)
4432 CFFI> (setq ptr-to-int (foreign-alloc :int))
4433 @result{} #<A Mac Pointer #x1047D0>
4434 CFFI> (mem-ref ptr-to-int :int)
4435 @result{} 1054619
4436 CFFI> (setf (mem-ref ptr-to-int :int) 1984)
4437 @result{} 1984
4438 CFFI> (mem-ref ptr-to-int :int)
4439 @result{} 1984
4440 @end lisp
4442 @subheading See Also
4443 @seealso{mem-aref}
4446 @c ===================================================================
4447 @c NULL-POINTER
4449 @page
4450 @node null-pointer, null-pointer-p, mem-ref, Pointers
4451 @heading null-pointer
4452 @subheading Syntax
4453 @Function{null-pointer @res{} pointer}
4455 @subheading Arguments and Values
4457 @table @var
4458 @item pointer
4459 A @code{NULL} pointer.
4460 @end table
4462 @subheading Description
4463 The function @code{null-pointer} returns a null pointer.
4465 @subheading Examples
4467 @lisp
4468 CFFI> (null-pointer)
4469 @result{} #<A Null Mac Pointer>
4470 CFFI> (pointerp *)
4471 @result{} T
4472 @end lisp
4474 @subheading See Also
4475 @seealso{null-pointer-p} @*
4476 @seealso{make-pointer}
4479 @c ===================================================================
4480 @c NULL-POINTER-P
4482 @page
4483 @node null-pointer-p, pointerp, null-pointer, Pointers
4484 @heading null-pointer-p
4485 @subheading Syntax
4486 @Function{null-pointer-p ptr @res{} boolean}
4488 @subheading Arguments and Values
4490 @table @var
4491 @item ptr
4492 A foreign pointer that may be a null pointer.
4494 @item boolean
4495 @code{T} or @code{NIL}.
4496 @end table
4498 @subheading Description
4499 The function @code{null-pointer-p} returns true if @var{ptr} is a null
4500 pointer and false otherwise.
4502 @subheading Examples
4504 @lisp
4505 CFFI> (null-pointer-p (null-pointer))
4506 @result{} T
4507 @end lisp
4509 @lisp
4510 (defun contains-str-p (big little)
4511   (not (null-pointer-p
4512         (foreign-funcall "strstr" :string big :string little :pointer))))
4514 CFFI> (contains-str-p "Popcorns" "corn")
4515 @result{} T
4516 CFFI> (contains-str-p "Popcorns" "salt")
4517 @result{} NIL
4518 @end lisp
4520 @subheading See Also
4521 @seealso{null-pointer} @*
4522 @seealso{pointerp}
4525 @c ===================================================================
4526 @c POINTERP
4528 @page
4529 @node pointerp, pointer-address, null-pointer-p, Pointers
4530 @heading pointerp
4531 @subheading Syntax
4532 @Function{pointerp ptr @res{} boolean}
4534 @subheading Arguments and Values
4536 @table @var
4537 @item ptr
4538 An object that may be a foreign pointer.
4540 @item boolean
4541 @code{T} or @code{NIL}.
4542 @end table
4544 @subheading Description
4545 The function @code{pointerp} returns true if @var{ptr} is a foreign
4546 pointer and false otherwise.
4548 @subheading Implementation-specific Notes
4549 In Allegro CL, foreign pointers are integers thus in this
4550 implementation @code{pointerp} will return true for any ordinary integer.
4552 @subheading Examples
4554 @lisp
4555 CFFI> (foreign-alloc 32)
4556 @result{} #<A Mac Pointer #x102D20>
4557 CFFI> (pointerp *)
4558 @result{} T
4559 CFFI> (pointerp "this is not a pointer")
4560 @result{} NIL
4561 @end lisp
4563 @subheading See Also
4564 @seealso{make-pointer}
4565 @seealso{null-pointer-p}
4568 @c ===================================================================
4569 @c POINTER-ADDRESS
4571 @page
4572 @node pointer-address, pointer-eq, pointerp, Pointers
4573 @heading pointer-address
4574 @subheading Syntax
4575 @Function{pointer-address ptr @res{} address}
4577 @subheading Arguments and Values
4579 @table @var
4580 @item ptr
4581 A foreign pointer.
4583 @item address
4584 An integer.
4585 @end table
4587 @subheading Description
4588 The function @code{pointer-address} will return the @var{address} of
4589 a foreign pointer @var{ptr}.
4591 @subheading Examples
4593 @lisp
4594 CFFI> (pointer-address (null-pointer))
4595 @result{} 0
4596 CFFI> (pointer-address (make-pointer 123))
4597 @result{} 123
4598 @end lisp
4600 @subheading See Also
4601 @seealso{make-pointer} @*
4602 @seealso{inc-pointer} @*
4603 @seealso{null-pointer} @*
4604 @seealso{null-pointer-p} @*
4605 @seealso{pointerp} @*
4606 @seealso{pointer-eq} @*
4607 @seealso{mem-ref}
4610 @c ===================================================================
4611 @c POINTER-EQ
4613 @page
4614 @node pointer-eq, with-foreign-object, pointer-address, Pointers
4615 @heading pointer-eq
4616 @subheading Syntax
4617 @Function{pointer-eq ptr1 ptr2 @res{} boolean}
4619 @subheading Arguments and Values
4621 @table @var
4622 @item ptr1
4623 @itemx ptr2
4624 A foreign pointer.
4626 @item boolean
4627 @code{T} or @code{NIL}.
4628 @end table
4630 @subheading Description
4631 The function @code{pointer-eq} returns true if @var{ptr1} and
4632 @var{ptr2} point to the same memory address and false otherwise.
4634 @subheading Implementation-specific Notes
4635 The representation of foreign pointers varies across the various Lisp
4636 implementations as does the behaviour of the built-in Common Lisp
4637 equality predicates. Comparing two pointers that point to the same
4638 address with @code{EQ} Lisps will return true on some Lisps, others require
4639 more general predicates like @code{EQL} or @code{EQUALP} and finally
4640 some will return false using any of these predicates. Therefore, for
4641 portability, you should use @code{POINTER-EQ}.
4643 @subheading Examples
4644 This is an example using @acronym{SBCL}, see the
4645 implementation-specific notes above.
4647 @lisp
4648 CFFI> (eql (null-pointer) (null-pointer))
4649 @result{} NIL
4650 CFFI> (pointer-eq (null-pointer) (null-pointer))
4651 @result{} T
4652 @end lisp
4654 @subheading See Also
4655 @seealso{inc-pointer}
4658 @c ===================================================================
4659 @c WITH-FOREIGN-OBJECT
4661 @page
4662 @node with-foreign-object, with-foreign-pointer, pointer-eq, Pointers
4663 @heading with-foreign-object, with-foreign-objects
4664 @subheading Syntax
4665 @Macro{with-foreign-object (var type &optional count) &body body}
4667 @anchor{with-foreign-objects}
4668 @Macro{with-foreign-objects (bindings) &body body}
4670 bindings ::= @{(var type &optional count)@}* @*
4672 @subheading Arguments and Values
4674 @table @var
4675 @item var
4676 A symbol.
4678 @item type
4679 A foreign type, evaluated.
4681 @item count
4682 An integer.
4683 @end table
4685 @subheading Description
4686 The macros @code{with-foreign-object} and @code{with-foreign-objects}
4687 bind @var{var} to a pointer to @var{count} newly allocated objects
4688 of type @var{type} during @var{body}. The buffer has dynamic extent
4689 and may be stack allocated if supported by the host Lisp.
4691 @subheading Examples
4693 @lisp
4694 CFFI> (with-foreign-object (array :int 10)
4695         (dotimes (i 10)
4696           (setf (mem-aref array :int i) (random 100)))
4697         (loop for i below 10
4698               collect (mem-aref array :int i)))
4699 @result{} (22 7 22 52 69 1 46 93 90 65)
4700 @end lisp
4702 @subheading See Also
4703 @seealso{foreign-alloc}
4706 @c ===================================================================
4707 @c WITH-FOREIGN-POINTER
4709 @page
4710 @node with-foreign-pointer,  , with-foreign-object, Pointers
4711 @heading with-foreign-pointer
4712 @subheading Syntax
4713 @Macro{with-foreign-pointer (var size &optional size-var) &body body}
4715 @subheading Arguments and Values
4717 @table @var
4718 @item var
4719 @itemx size-var
4720 A symbol.
4722 @item size
4723 An integer.
4725 @item body
4726 A list of forms to be executed.
4727 @end table
4729 @subheading Description
4730 The @code{with-foreign-pointer} macro, binds @var{var} to @var{size}
4731 bytes of foreign memory during @var{body}. The pointer in @var{var}
4732 is invalid beyond the dynamic extend of @var{body} and may be
4733 stack-allocated if supported by the implementation.
4735 If @var{size-var} is supplied, it will be bound to @var{size} during
4736 @var{body}.
4738 @subheading Examples
4740 @lisp
4741 CFFI> (with-foreign-pointer (string 4 size)
4742         (setf (mem-ref string :char (1- size)) 0)
4743         (lisp-string-to-foreign "Popcorns" string size)
4744         (loop for i from 0 below size
4745               collect (code-char (mem-ref string :char i))))
4746 @result{} (#\P #\o #\p #\Null)
4747 @end lisp
4749 @subheading See Also
4750 @seealso{foreign-alloc} @*
4751 @seealso{foreign-free}
4754 @c ===================================================================
4755 @c CHAPTER: Strings
4757 @node Strings, Variables, Pointers, Top
4758 @chapter Strings
4760 As with many languages, Lisp and C have special support for logical
4761 arrays of characters, going so far as to give them a special name,
4762 ``strings''.  In that spirit, @cffi{} provides special support for
4763 translating between Lisp and C strings.
4765 The @code{:string} type and the symbols related below also serve as an
4766 example of what you can do portably with @cffi{}; were it not
4767 included, you could write an equally functional @file{strings.lisp}
4768 without referring to any implementation-specific symbols.
4770 @menu
4771 Dictionary
4773 * *default-foreign-encoding*::
4774 * foreign-string-alloc::
4775 * foreign-string-free::
4776 * foreign-string-to-lisp::
4777 * lisp-string-to-foreign::
4778 * with-foreign-string::
4779 * with-foreign-strings::
4780 * with-foreign-pointer-as-string::
4781 @end menu
4784 @c ===================================================================
4785 @c *DEFAULT-FOREIGN-ENCODING*
4787 @page
4788 @node *default-foreign-encoding*, foreign-string-alloc, Strings, Strings
4789 @heading *default-foreign-encoding*
4790 @subheading Syntax
4792 @Variable{*default-foreign-encoding*}
4794 @subheading Value type
4796 A keyword.
4798 @subheading Initial value
4800 @code{:utf-8}
4802 @subheading Description
4804 This special variable holds the default foreign encoding.
4806 @subheading Examples
4808 @lisp
4809 CFFI> *default-foreign-encoding*
4810 :utf-8
4811 CFFI> (foreign-funcall "strdup" (:string :encoding :utf-16) "foo" :string)
4813 CFFI> (let ((*default-foreign-encoding* :utf-16))
4814         (foreign-funcall "strdup" (:string :encoding :utf-16) "foo" :string))
4815 "foo"
4816 @end lisp
4818 @subheading See also
4820 @seealso{Other Types} (@code{:string} type) @*
4821 @seealso{foreign-string-alloc} @*
4822 @seealso{foreign-string-to-lisp} @*
4823 @seealso{lisp-string-to-foreign} @*
4824 @seealso{with-foreign-string} @*
4825 @seealso{with-foreign-pointer-as-string}
4828 @c ===================================================================
4829 @c FOREIGN-STRING-ALLOC
4831 @page
4832 @node foreign-string-alloc, foreign-string-free, *default-foreign-encoding*, Strings
4833 @heading foreign-string-alloc
4834 @subheading Syntax
4835 @Function{foreign-string-alloc string &key encoding null-terminated-p @
4836                                start end @res{} pointer}
4838 @subheading Arguments and Values
4840 @table @emph
4841 @item @var{string}
4842 A Lisp string.
4844 @item @var{encoding}
4845 Foreign encoding. Defaults to @code{*default-foreign-encoding*}.
4847 @item @var{null-terminated-p}
4848 Boolean, defaults to true.
4850 @item @var{start}, @var{end}
4851 Bounding index designators of @var{string}. 0 and @code{nil}, by
4852 default.
4854 @item @var{pointer}
4855 A pointer to the newly allocated foreign string.
4856 @end table
4858 @subheading Description
4859 The @code{foreign-string-alloc} function allocates foreign memory
4860 holding a copy of @var{string} converted using the specified
4861 @var{encoding}. @var{Start} specifies an offset into @var{string} and
4862 @var{end} marks the position following the last element of the foreign
4863 string.
4865 This string must be freed with @code{foreign-string-free}.
4867 If @var{null-terminated-p} is false, the string will not be
4868 null-terminated.
4870 @subheading Examples
4872 @lisp
4873 CFFI> (defparameter *str* (foreign-string-alloc "Hello, foreign world!"))
4874 @result{} #<FOREIGN-ADDRESS #x00400560>
4875 CFFI> (foreign-funcall "strlen" :pointer *str* :int)
4876 @result{} 21
4877 @end lisp
4879 @subheading See Also
4880 @seealso{foreign-string-free} @*
4881 @seealso{with-foreign-string}
4882 @c @seealso{:string}
4885 @c ===================================================================
4886 @c FOREIGN-STRING-FREE
4888 @page
4889 @node foreign-string-free, foreign-string-to-lisp, foreign-string-alloc, Strings
4890 @heading foreign-string-free
4891 @subheading Syntax
4892 @Function{foreign-string-free pointer}
4894 @subheading Arguments and Values
4896 @table @var
4897 @item pointer
4898 A pointer to a string allocated by @code{foreign-string-alloc}.
4899 @end table
4901 @subheading Description
4902 The @code{foreign-string-free} function frees a foreign string
4903 allocated by @code{foreign-string-alloc}.
4905 @subheading Examples
4907 @subheading See Also
4908 @seealso{foreign-string-alloc}
4911 @c ===================================================================
4912 @c FOREIGN-STRING-TO-LISP
4914 @page
4915 @node foreign-string-to-lisp, lisp-string-to-foreign, foreign-string-free, Strings
4916 @heading foreign-string-to-lisp
4917 @subheading Syntax
4918 @Function{foreign-string-to-lisp ptr &key offset count max-chars @
4919                                  encoding @res{} string}
4921 @subheading Arguments and Values
4923 @table @var
4924 @item ptr
4925 A pointer.
4927 @item offset
4928 An integer greater than or equal to 0. Defauls to 0.
4930 @item count
4931 Either @code{nil} (the default), or an integer greater than or equal to 0.
4933 @item max-chars
4934 An integer greater than or equal to 0.
4935 @code{(1- array-total-size-limit)}, by default.
4937 @item encoding
4938 Foreign encoding. Defaults to @code{*default-foreign-encoding*}.
4940 @item string
4941 A Lisp string.
4942 @end table
4944 @subheading Description
4945 The @code{foreign-string-to-lisp} function converts at most
4946 @var{count} octets from @var{ptr} into a Lisp string, using the
4947 defined @var{encoding}.
4949 If @var{count} is @code{nil} (the default), characters are copied
4950 until @var{max-chars} is reached or a @code{NULL} character is found.
4952 If @var{ptr} is a null pointer, returns @code{nil}.
4954 Note that the @code{:string} type will automatically convert between
4955 Lisp strings and foreign strings.
4957 @subheading Examples
4959 @lisp
4960 CFFI> (foreign-funcall "getenv" :string "HOME" :pointer)
4961 @result{} #<FOREIGN-ADDRESS #xBFFFFFD5>
4962 CFFI> (foreign-string-to-lisp *)
4963 @result{} "/Users/luis"
4964 @end lisp
4966 @subheading See Also
4967 @seealso{lisp-string-to-foreign} @*
4968 @seealso{foreign-string-alloc}
4969 @c @seealso{:string}
4972 @c ===================================================================
4973 @c LISP-STRING-TO-FOREIGN
4975 @page
4976 @node lisp-string-to-foreign, with-foreign-string, foreign-string-to-lisp, Strings
4977 @heading lisp-string-to-foreign
4978 @subheading Syntax
4979 @Function{lisp-string-to-foreign string buffer bufsize &key start @
4980                                  end offset encoding @res{} buffer}
4982 @subheading Arguments and Values
4984 @table @emph
4985 @item @var{string}
4986 A Lisp string.
4988 @item @var{buffer}
4989 A foreign pointer.
4991 @item @var{bufsize}
4992 An integer.
4994 @item @var{start}, @var{end}
4995 Bounding index designators of @var{string}. 0 and @code{nil}, by
4996 default.
4998 @item @var{offset}
4999 An integer greater than or equal to 0. Defauls to 0.
5001 @item @var{encoding}
5002 Foreign encoding. Defaults to @code{*default-foreign-encoding*}.
5003 @end table
5005 @subheading Description
5006 The @code{lisp-string-to-foreign} function copies at most
5007 @var{bufsize}-1 octets from a Lisp @var{string} using the specified
5008 @var{encoding} into @var{buffer}+@var{offset}. The foreign string will
5009 be null-terminated.
5011 @var{Start} specifies an offset into @var{string} and
5012 @var{end} marks the position following the last element of the foreign
5013 string.
5015 @subheading Examples
5017 @lisp
5018 CFFI> (with-foreign-pointer-as-string (str 255)
5019         (lisp-string-to-foreign "Hello, foreign world!" str 6))
5020 @result{} "Hello"
5021 @end lisp
5023 @subheading See Also
5024 @seealso{foreign-string-alloc} @*
5025 @seealso{foreign-string-to-lisp} @*
5026 @seealso{with-foreign-pointer-as-string}
5029 @c ===================================================================
5030 @c WITH-FOREIGN-STRING
5032 @page
5033 @node with-foreign-string, with-foreign-pointer-as-string, lisp-string-to-foreign, Strings
5034 @heading with-foreign-string, with-foreign-strings
5035 @subheading Syntax
5036 @Macro{with-foreign-string (var-or-vars string &rest args) &body body}
5038 @anchor{with-foreign-strings}
5039 @Macro{with-foreign-strings (bindings) &body body}
5041 var-or-vars ::= var | (var &optional octet-size-var) @*
5042 bindings ::= @{(var-or-vars string &rest args)@}*
5044 @subheading Arguments and Values
5046 @table @emph
5047 @item @var{var}, @var{byte-size-var}
5048 A symbol.
5050 @item @var{string}
5051 A Lisp string.
5053 @item @var{body}
5054 A list of forms to be executed.
5055 @end table
5057 @subheading Description
5058 The @code{with-foreign-string} macro will bind @var{var} to a newly
5059 allocated foreign string containing @var{string}. @var{Args} is passed
5060 to the underlying @code{foreign-string-alloc} call.
5062 If @var{octet-size-var} is provided, it will be bound the length of
5063 foreign string in octets including the null terminator.
5065 @subheading Examples
5067 @lisp
5068 CFFI> (with-foreign-string (foo "12345")
5069         (foreign-funcall "strlen" :pointer foo :int))
5070 @result{} 5
5071 @end lisp
5073 @subheading See Also
5074 @seealso{foreign-string-alloc} @*
5075 @seealso{with-foreign-pointer-as-string}
5078 @c ===================================================================
5079 @c WITH-FOREIGN-POINTER-AS-STRING
5081 @page
5082 @node with-foreign-pointer-as-string,  , with-foreign-string, Strings
5083 @heading with-foreign-pointer-as-string
5084 @subheading Syntax
5085 @Macro{with-foreign-pointer-as-string (var-or-vars size @
5086                                       &rest args) &body body @res{} string}
5088 @var{var-or-vars} ::= var | (var &optional size-var)
5089 @subheading Arguments and Values
5091 @table @var
5092 @item var
5093 @itemx size-var
5094 A symbol.
5096 @item size
5097 An integer
5099 @item args
5100 Arguments to be passed to @code{foreign-string-to-lisp} to create the returned string.
5102 @item body
5103 List of forms to be executed.
5105 @item string
5106 A Lisp string.
5107 @end table
5109 @subheading Description
5110 The @code{with-foreign-pointer-as-string} macro is similar to
5111 @code{with-foreign-pointer} except that the allocated buffer is
5112 transformed into a lisp string and returned once @code{body} has
5113 finished executing.
5115 A foreign buffer of size @code{size} is bound to @code{var} during the
5116 execution of @code{body}. If @code{size-var} is specified, it is bound
5117 to the value of @code{size}. The return value is constructed by
5118 transforming the foreign buffer into a lisp string using
5119 @code{foreign-string-to-lisp}, which is given @code{args} as
5120 arguments.
5122 @subheading Examples
5124 @lisp
5125 CFFI> (with-foreign-pointer-as-string ((str str-size) 6 :encoding :ascii)
5126         (lisp-string-to-foreign "Hello, foreign world!" str str-size))
5127 @result{} "Hello"
5128 @end lisp
5130 @subheading See Also
5131 @seealso{foreign-string-alloc} @*
5132 @seealso{with-foreign-string} @*
5133 @seealso{with-foreign-pointer}
5136 @c ===================================================================
5137 @c CHAPTER: Variables
5139 @node Variables, Functions, Strings, Top
5140 @chapter Variables
5142 @menu
5143 Dictionary
5145 * defcvar::
5146 * get-var-pointer::
5147 @end menu
5150 @c ===================================================================
5151 @c DEFCVAR
5153 @page
5154 @node defcvar, get-var-pointer, Variables, Variables
5155 @heading defcvar
5156 @subheading Syntax
5157 @Macro{defcvar name-and-options type &optional documentation @res{} lisp-name}
5159 @var{name-and-options} ::= name | (name &key read-only (library :default)) @*
5160 @var{name} ::= lisp-name [foreign-name] | foreign-name [lisp-name] @*
5162 @subheading Arguments and Values
5164 @table @var
5165 @item foreign-name
5166 A string denoting a foreign function.
5168 @item lisp-name
5169 A symbol naming the Lisp function to be created.
5171 @item type
5172 A foreign type.
5174 @item read-only
5175 A boolean.
5177 @item documentation
5178 A Lisp string; not evaluated.
5179 @end table
5181 @subheading Description
5182 The @code{defcvar} macro defines a symbol macro @var{lisp-name} that looks
5183 up @var{foreign-name} and dereferences it acording to @var{type}.  It
5184 can also be @code{setf}ed, unless @var{read-only} is true, in which
5185 case an error will be signaled.
5187 When one of @var{lisp-name} or @var{foreign-name} is omitted, the
5188 other is automatically derived using the following rules:
5190 @itemize
5191 @item
5192 Foreign names are converted to Lisp names by uppercasing, replacing
5193 underscores with hyphens, and wrapping around asterisks.
5194 @item
5195 Lisp names are converted to foreign names by lowercasing, replacing
5196 hyphens with underscores, and removing asterisks, if any.
5197 @end itemize
5199 @subheading Examples
5201 @lisp
5202 CFFI> (defcvar "errno" :int)
5203 @result{} *ERRNO*
5204 CFFI> (foreign-funcall "strerror" :int *errno* :string)
5205 @result{} "Inappropriate ioctl for device"
5206 CFFI> (setf *errno* 1)
5207 @result{} 1
5208 CFFI> (foreign-funcall "strerror" :int *errno* :string)
5209 @result{} "Operation not permitted"
5210 @end lisp
5212 Trying to modify a read-only foreign variable:
5214 @lisp
5215 CFFI> (defcvar ("errno" +error-number+ :read-only t) :int)
5216 @result{} +ERROR-NUMBER+
5217 CFFI> (setf +error-number+ 12)
5218 ;; @lispcmt{@error{} Trying to modify read-only foreign var: +ERROR-NUMBER+.}
5219 @end lisp
5221 @emph{Note that accessing @code{errno} this way won't work with every
5222 implementation of the C standard library.}
5224 @subheading See Also
5225 @seealso{get-var-pointer}
5228 @c ===================================================================
5229 @c GET-VAR-POINTER
5231 @page
5232 @node get-var-pointer,  , defcvar, Variables
5233 @heading get-var-pointer
5234 @subheading Syntax
5235 @Function{get-var-pointer symbol @res{} pointer}
5237 @subheading Arguments and Values
5239 @table @var
5240 @item symbol
5241 A symbol denoting a foreign variable defined with @code{defcvar}.
5243 @item pointer
5244 A foreign pointer.
5245 @end table
5247 @subheading Description
5248 The function @code{get-var-pointer} will return a @var{pointer} to the
5249 foreign global variable @var{symbol} previously defined with
5250 @code{defcvar}.
5252 @subheading Examples
5254 @lisp
5255 CFFI> (defcvar "errno" :int :read-only t)
5256 @result{} *ERRNO*
5257 CFFI> *errno*
5258 @result{} 25
5259 CFFI> (get-var-pointer '*errno*)
5260 @result{} #<A Mac Pointer #xA0008130>
5261 CFFI> (mem-ref * :int)
5262 @result{} 25
5263 @end lisp
5265 @subheading See Also
5266 @seealso{defcvar}
5269 @c ===================================================================
5270 @c CHAPTER: Functions
5272 @node Functions, Libraries, Variables, Top
5273 @chapter Functions
5275 @menu
5276 @c * Defining Foreign Functions::
5277 @c * Calling Foreign Functions::
5279 Dictionary
5281 * defcfun::
5282 * foreign-funcall::
5283 * foreign-funcall-pointer::
5284 * foreign-funcall-varargs::
5285 * foreign-funcall-pointer-varargs::
5286 * translate-camelcase-name::
5287 * translate-name-from-foreign::
5288 * translate-name-to-foreign::
5289 * translate-underscore-separated-name::
5290 @end menu
5292 @c @node Calling Foreign Functions
5293 @c @section Calling Foreign Functions
5295 @c @node Defining Foreign Functions
5296 @c @section Defining Foreign Functions
5299 @c ===================================================================
5300 @c DEFCFUN
5302 @page
5303 @node defcfun, foreign-funcall, Functions, Functions
5304 @heading defcfun
5305 @subheading Syntax
5306 @Macro{defcfun name-and-options return-type &body [docstring] arguments [&rest] @
5307                @res{} lisp-name}
5309 @var{name-and-options} ::= @var{name} | (@var{name} &key @var{library} @var{convention}) @*
5310 @var{name} ::= @var{lisp-name} [@var{foreign-name}] | @var{foreign-name} [@var{lisp-name}] @*
5311 @var{arguments} ::= @{ (@var{arg-name} @var{arg-type}) @}* @*
5313 @subheading Arguments and Values
5315 @table @var
5316 @item foreign-name
5317 A string denoting a foreign function.
5319 @item lisp-name
5320 A symbol naming the Lisp function to be created.
5322 @item arg-name
5323 A symbol.
5325 @item return-type
5326 @itemx arg-type
5327 A foreign type.
5329 @item convention
5330 One of @code{:cdecl} (default) or @code{:stdcall}.
5332 @item library
5333 A symbol designating a foreign library.
5335 @item docstring
5336 A documentation string.
5337 @end table
5339 @subheading Description
5340 The @code{defcfun} macro provides a declarative interface for defining
5341 Lisp functions that call foreign functions.
5343 When one of @var{lisp-name} or @var{foreign-name} is omitted, the
5344 other is automatically derived using the following rules:
5346 @itemize
5347 @item
5348 Foreign names are converted to Lisp names by uppercasing and replacing
5349 underscores with hyphens.
5350 @item
5351 Lisp names are converted to foreign names by lowercasing and replacing
5352 hyphens with underscores.
5353 @end itemize
5355 If you place the symbol @code{&rest} in the end of the argument list
5356 after the fixed arguments, @code{defcfun} will treat the foreign
5357 function as a @strong{variadic function}. The variadic arguments
5358 should be passed in a way similar to what @code{foreign-funcall} would
5359 expect. Unlike @code{foreign-funcall} though, @code{defcfun} will take
5360 care of doing argument promotion. Note that in this case
5361 @code{defcfun} will generate a Lisp @emph{macro} instead of a
5362 function and will only work for Lisps that support
5363 @code{foreign-funcall.}
5365 If a foreign structure is to be passed or returned by value (that is,
5366 the type is of the form @code{(:struct ...)}), then the cffi-libffi system
5367 must be loaded, which in turn depends on
5368 @uref{http://sourceware.org/libffi/,libffi}, including the header files.
5369 Failure to load that system will result in an error.
5370 Variadic functions cannot at present accept or return structures by
5371 value.
5373 @subheading Examples
5375 @lisp
5376 (defcfun "strlen" :int
5377   "Calculate the length of a string."
5378   (n :string))
5380 CFFI> (strlen "123")
5381 @result{} 3
5382 @end lisp
5384 @lisp
5385 (defcfun ("abs" c-abs) :int (n :int))
5387 CFFI> (c-abs -42)
5388 @result{} 42
5389 @end lisp
5391 Function without arguments:
5393 @lisp
5394 (defcfun "rand" :int)
5396 CFFI> (rand)
5397 @result{} 1804289383
5398 @end lisp
5400 Variadic function example:
5402 @lisp
5403 (defcfun "sprintf" :int
5404   (str :pointer)
5405   (control :string)
5406   &rest)
5408 CFFI> (with-foreign-pointer-as-string (s 100)
5409         (sprintf s "%c %d %.2f %s" :char 90 :short 42 :float pi
5410                  :string "super-locrian"))
5411 @result{} "A 42 3.14 super-locrian"
5412 @end lisp
5414 @subheading See Also
5415 @seealso{foreign-funcall} @*
5416 @seealso{foreign-funcall-pointer} @*
5417 @seealso{foreign-funcall-varargs} @*
5418 @seealso{foreign-funcall-pointer-varargs}
5421 @c ===================================================================
5422 @c FOREIGN-FUNCALL
5424 @page
5425 @node foreign-funcall, foreign-funcall-pointer, defcfun, Functions
5426 @heading foreign-funcall
5427 @subheading Syntax
5428 @Macro{foreign-funcall name-and-options &rest arguments @res{} return-value}
5430 @var{arguments} ::= @{ @var{arg-type} @var{arg} @}* [@var{return-type}] @*
5431 @var{name-and-options} ::= @var{name} | (@var{name} &key @var{library} @var{convention}) @*
5433 @subheading Arguments and Values
5435 @table @var
5436 @item name
5437 A Lisp string.
5439 @item arg-type
5440 A foreign type.
5442 @item arg
5443 An argument of type @var{arg-type}.
5445 @item return-type
5446 A foreign type, @code{:void} by default.
5448 @item return-value
5449 A lisp object.
5451 @item library
5452 A lisp symbol; not evaluated.
5454 @item convention
5455 One of @code{:cdecl} (default) or @code{:stdcall}.
5456 @end table
5458 @subheading Description
5459 The @code{foreign-funcall} macro is the main primitive for calling
5460 foreign functions.
5462 If a foreign structure is to be passed or returned by value (that is,
5463 the type is of the form @code{(:struct ...)}), then the cffi-libffi system
5464 must be loaded, which in turn depends on
5465 @uref{http://sourceware.org/libffi/,libffi}, including the header files.
5466 Failure to load that system will result in an error.
5467 Variadic functions cannot at present accept or return structures by
5468 value.
5470 @emph{Note: The return value of foreign-funcall on functions with a
5471 :void return type is still undefined.}
5473 @subheading Implementation-specific Notes
5474 @itemize
5475 @item
5476 Corman Lisp does not support @code{foreign-funcall}. On
5477 implementations that @strong{don't} support @code{foreign-funcall}
5478 @code{cffi-sys::no-foreign-funcall} will be present in
5479 @code{*features*}. Note: in these Lisps you can still use the
5480 @code{defcfun} interface.
5481 @end itemize
5483 @subheading Examples
5485 @lisp
5486 CFFI> (foreign-funcall "strlen" :string "foo" :int)
5487 @result{} 3
5488 @end lisp
5490 Given the C code:
5492 @example
5493 void print_number(int n)
5495     printf("N: %d\n", n);
5497 @end example
5499 @lisp
5500 CFFI> (foreign-funcall "print_number" :int 123456)
5501 @print{} N: 123456
5502 @result{} NIL
5503 @end lisp
5505 @noindent
5506 Or, equivalently:
5508 @lisp
5509 CFFI> (foreign-funcall "print_number" :int 123456 :void)
5510 @print{} N: 123456
5511 @result{} NIL
5512 @end lisp
5514 @lisp
5515 CFFI> (foreign-funcall "printf" :string (format nil "%s: %d.~%")
5516                        :string "So long and thanks for all the fish"
5517                        :int 42 :int)
5518 @print{} So long and thanks for all the fish: 42.
5519 @result{} 41
5520 @end lisp
5522 @subheading See Also
5523 @seealso{defcfun} @*
5524 @seealso{foreign-funcall-pointer}
5527 @c ===================================================================
5528 @c FOREIGN-FUNCALL-POINTER
5530 @page
5531 @node foreign-funcall-pointer, foreign-funcall-varargs, foreign-funcall, Functions
5532 @heading foreign-funcall-pointer
5533 @subheading Syntax
5534 @Macro{foreign-funcall-pointer pointer options &rest arguments @res{} return-value}
5536 @var{arguments} ::= @{ @var{arg-type} @var{arg} @}* [@var{return-type}] @*
5537 @var{options} ::= (&key @var{convention}) @*
5539 @subheading Arguments and Values
5541 @table @var
5542 @item pointer
5543 A foreign pointer.
5545 @item arg-type
5546 A foreign type.
5548 @item arg
5549 An argument of type @var{arg-type}.
5551 @item return-type
5552 A foreign type, @code{:void} by default.
5554 @item return-value
5555 A lisp object.
5557 @item convention
5558 One of @code{:cdecl} (default) or @code{:stdcall}.
5559 @end table
5561 @subheading Description
5562 The @code{foreign-funcall} macro is the main primitive for calling
5563 foreign functions.
5565 @emph{Note: The return value of foreign-funcall on functions with a
5566 :void return type is still undefined.}
5568 @subheading Implementation-specific Notes
5569 @itemize
5570 @item
5571 Corman Lisp does not support @code{foreign-funcall}. On
5572 implementations that @strong{don't} support @code{foreign-funcall}
5573 @code{cffi-sys::no-foreign-funcall} will be present in
5574 @code{*features*}. Note: in these Lisps you can still use the
5575 @code{defcfun} interface.
5576 @end itemize
5578 @subheading Examples
5580 @lisp
5581 CFFI> (foreign-funcall-pointer (foreign-symbol-pointer "abs") ()
5582                                :int -42 :int)
5583 @result{} 42
5584 @end lisp
5586 @subheading See Also
5587 @seealso{defcfun} @*
5588 @seealso{foreign-funcall}
5591 @c ===================================================================
5592 @c FOREIGN-FUNCALL-VARARGS
5594 @page
5595 @node foreign-funcall-varargs, foreign-funcall-pointer-varargs, foreign-funcall-pointer, Functions
5596 @heading foreign-funcall-varargs
5597 @subheading Syntax
5598 @Macro{foreign-funcall-varargs name-and-options (fixed-arguments) &rest arguments @res{} return-value}
5600 @var{fixed-arguments} ::= @{ @var{arg-type} @var{arg} @}* [@var{return-type}] @*
5601 @var{arguments} ::= @{ @var{arg-type} @var{arg} @}* [@var{return-type}] @*
5602 @var{name-and-options} ::= @var{name} | (@var{name} &key @var{library} @var{convention}) @*
5604 @subheading Arguments and Values
5606 @table @var
5607 @item name
5608 A Lisp string.
5610 @item arg-type
5611 A foreign type.
5613 @item arg
5614 An argument of type @var{arg-type}.
5616 @item return-type
5617 A foreign type, @code{:void} by default.
5619 @item return-value
5620 A lisp object.
5622 @item library
5623 A lisp symbol; not evaluated.
5625 @item convention
5626 One of @code{:cdecl} (default) or @code{:stdcall}.
5627 @end table
5629 @subheading Description
5630 The @code{foreign-funcall-varargs} macro is the main primitive for
5631 calling foreign variadic functions. It behaves similarily to
5632 @code{foreign-funcall} except @code{fixed-arguments} are distinguished
5633 from the remaining arguments.
5635 @subheading Examples
5637 @lisp
5638 CFFI> (with-foreign-pointer-as-string (s 100)
5639         (setf (mem-ref s :char) 0)
5640         (foreign-funcall-varargs
5641          "sprintf" (:pointer s :string) "%.2f")
5642          :double (coerce pi 'double-float) :int))
5643 @result{} 3.14
5644 @end lisp
5647 @c ===================================================================
5648 @c FOREIGN-FUNCALL-POINTER-VARARGS
5650 @page
5651 @node foreign-funcall-pointer-varargs, translate-camelcase-name, foreign-funcall-varargs, Functions
5652 @heading foreign-funcall-pointer-varargs
5653 @subheading Syntax
5654 @Macro{foreign-funcall-pointer-varargs pointer options (fixed-arguments) &rest arguments @res{} return-value}
5656 @var{fixed-arguments} ::= @{ @var{arg-type} @var{arg} @}* [@var{return-type}] @*
5657 @var{arguments} ::= @{ @var{arg-type} @var{arg} @}* [@var{return-type}] @*
5658 @var{options} ::= (&key @var{convention}) @*
5660 @subheading Arguments and Values
5662 @table @var
5663 @item pointer
5664 A foreign pointer.
5666 @item arg-type
5667 A foreign type.
5669 @item arg
5670 An argument of type @var{arg-type}.
5672 @item return-type
5673 A foreign type, @code{:void} by default.
5675 @item return-value
5676 A lisp object.
5678 @item convention
5679 One of @code{:cdecl} (default) or @code{:stdcall}.
5680 @end table
5682 @subheading Description
5683 The @code{foreign-funcall-pointer-varargs} macro is the main primitive
5684 for calling foreign variadic functions. It behaves similarily to
5685 @code{foreign-funcall-pointer} except @code{fixed-arguments} are
5686 distinguished from the remaining arguments.
5688 @subheading Examples
5690 @lisp
5691 CFFI> (with-foreign-pointer-as-string (s 100)
5692         (setf (mem-ref s :char) 0)
5693         (foreign-funcall-pointer-varargs
5694          (foreign-symbol-pointer "sprintf") () (:pointer s :string "%.2f")
5695          :double (coerce pi 'double-float) :int))
5696 @result{} 3.14
5697 @end lisp
5700 @c ===================================================================
5701 @c TRANSLATE-CAMELCASE-NAME
5703 @page
5704 @node translate-camelcase-name, translate-name-from-foreign, foreign-funcall-pointer-varargs, Functions
5705 @heading translate-camelcase-name
5706 @subheading Syntax
5707 @Function{translate-camelcase-name name &key upper-initial-p special-words @res{} return-value}
5709 @subheading Arguments and Values
5711 @table @var
5712 @item name
5713 Either a symbol or a string.
5715 @item upper-initial-p
5716 A generalized boolean.
5718 @item special words
5719 A list of strings.
5721 @item return-value
5722 If @var{name} is a symbol, this is a string, and vice versa.
5723 @end table
5725 @subheading Description
5726 @code{translate-camelcase-name} is a helper function for
5727 specializations of @code{translate-name-from-foreign} and
5728 @code{translate-name-to-foreign}. It handles the common case of
5729 converting between foreign camelCase names and lisp
5730 names. @var{upper-initial-p} indicates whether the first letter of the
5731 foreign name should be uppercase. @var{special-words} is a list of
5732 strings that should be treated atomically in translation. This list is
5733 case-sensitive.
5735 @subheading Examples
5737 @lisp
5738 CFFI> (translate-camelcase-name some-xml-function)
5739 @result{} "someXmlFunction"
5740 CFFI> (translate-camelcase-name some-xml-function :upper-initial-p t)
5741 @result{} "SomeXmlFunction"
5742 CFFI> (translate-camelcase-name some-xml-function :special-words '("XML"))
5743 @result{} "someXMLFunction"
5744 CFFI> (translate-camelcase-name "someXMLFunction")
5745 @result{} SOME-X-M-L-FUNCTION
5746 CFFI> (translate-camelcase-name "someXMLFunction" :special-words '("XML"))
5747 @result{} SOME-XML-FUNCTION
5748 @end lisp
5750 @subheading See Also
5751 @seealso{translate-name-from-foreign} @*
5752 @seealso{translate-name-to-foreign} @*
5753 @seealso{translate-underscore-separated-name}
5756 @c ===================================================================
5757 @c TRANSLATE-NAME-FROM-FOREIGN
5759 @page
5760 @node translate-name-from-foreign, translate-name-to-foreign, translate-camelcase-name, Functions
5761 @heading translate-name-from-foreign
5762 @subheading Syntax
5763 @Function{translate-name-from-foreign foreign-name package &optional varp @res{} symbol}
5765 @subheading Arguments and Values
5767 @table @var
5768 @item foreign-name
5769 A string denoting a foreign function.
5771 @item package
5772 A Lisp package
5774 @item varp
5775 A generalized boolean.
5777 @item symbol
5778 The Lisp symbol to be used a function name.
5779 @end table
5781 @subheading Description
5782 @code{translate-name-from-foreign} is used by @ref{defcfun} to handle
5783 the conversion of foreign names to lisp names. By default, it
5784 translates using @ref{translate-underscore-separated-name}. However,
5785 you can create specialized methods on this function to make
5786 translating more closely match the foreign library's naming
5787 conventions.
5789 Specialize @var{package} on some package. This allows other packages
5790 to load libraries with different naming conventions.
5792 @subheading Examples
5794 @lisp
5795 CFFI> (defcfun "someXmlFunction" ...)
5796 @result{} SOMEXMLFUNCTION
5797 CFFI> (defmethod translate-name-from-foreign ((spec string)
5798                                               (package (eql *package*))
5799                                               &optional varp)
5800         (let ((name (translate-camelcase-name spec)))
5801           (if varp (intern (format nil "*~a*" name)) name)))
5802 @result{} #<STANDARD-METHOD TRANSLATE-NAME-FROM-FOREIGN (STRING (EQL #<Package "SOME-PACKAGE">))>
5803 CFFI> (defcfun "someXmlFunction" ...)
5804 @result{} SOME-XML-FUNCTION
5805 @end lisp
5807 @subheading See Also
5808 @seealso{defcfun} @*
5809 @seealso{translate-camelcase-name} @*
5810 @seealso{translate-name-to-foreign} @*
5811 @seealso{translate-underscore-separated-name}
5814 @c ===================================================================
5815 @c TRANSLATE-NAME-TO-FOREIGN
5817 @page
5818 @node translate-name-to-foreign, translate-underscore-separated-name, translate-name-from-foreign, Functions
5819 @heading translate-name-to-foreign
5820 @subheading Syntax
5821 @Function{translate-name-to-foreign lisp-name package &optional varp @res{} string}
5823 @subheading Arguments and Values
5825 @table @var
5826 @item lisp-name
5827 A symbol naming the Lisp function to be created.
5829 @item package
5830 A Lisp package
5832 @item varp
5833 A generalized boolean.
5835 @item string
5836 The string representing the foreign function name.
5837 @end table
5839 @subheading Description
5840 @code{translate-name-to-foreign} is used by @ref{defcfun} to handle
5841 the conversion of lisp names to foreign names. By default, it
5842 translates using @ref{translate-underscore-separated-name}. However,
5843 you can create specialized methods on this function to make
5844 translating more closely match the foreign library's naming
5845 conventions.
5847 Specialize @var{package} on some package. This allows other packages
5848 to load libraries with different naming conventions.
5850 @subheading Examples
5852 @lisp
5853 CFFI> (defcfun some-xml-function ...)
5854 @result{} "some_xml_function"
5855 CFFI> (defmethod translate-name-to-foreign ((spec symbol)
5856                                             (package (eql *package*))
5857                                             &optional varp)
5858         (let ((name (translate-camelcase-name spec)))
5859           (if varp (subseq name 1 (1- (length name))) name)))
5860 @result{} #<STANDARD-METHOD TRANSLATE-NAME-TO-FOREIGN (STRING (EQL #<Package "SOME-PACKAGE">))>
5861 CFFI> (defcfun some-xml-function ...)
5862 @result{} "someXmlFunction"
5863 @end lisp
5865 @subheading See Also
5866 @seealso{defcfun} @*
5867 @seealso{translate-camelcase-name} @*
5868 @seealso{translate-name-from-foreign} @*
5869 @seealso{translate-underscore-separated-name}
5872 @c ===================================================================
5873 @c TRANSLATE-UNDERSCORE-SEPARATED-NAME
5875 @page
5876 @node translate-underscore-separated-name,  , translate-name-to-foreign, Functions
5877 @heading translate-underscore-separated-name
5878 @subheading Syntax
5879 @Function{translate-underscore-separated-name name @res{} return-value}
5881 @subheading Arguments and Values
5883 @table @var
5884 @item name
5885 Either a symbol or a string.
5887 @item return-value
5888 If @var{name} is a symbol, this is a string, and vice versa.
5889 @end table
5891 @subheading Description
5892 @code{translate-underscore-separated-name} is a helper function for
5893 specializations of @ref{translate-name-from-foreign} and
5894 @ref{translate-name-to-foreign}. It handles the common case of
5895 converting between foreign underscore_separated names and lisp names.
5897 @subheading Examples
5899 @lisp
5900 CFFI> (translate-underscore-separated-name some-xml-function)
5901 @result{} "some_xml_function"
5902 CFFI> (translate-camelcase-name "some_xml_function")
5903 @result{} SOME-XML-FUNCTION
5904 @end lisp
5906 @subheading See Also
5907 @seealso{translate-name-from-foreign} @*
5908 @seealso{translate-name-to-foreign} @*
5909 @seealso{translate-camelcase-name}
5912 @c ===================================================================
5913 @c CHAPTER: Libraries
5915 @node Libraries, Callbacks, Functions, Top
5916 @chapter Libraries
5918 @menu
5919 * Defining a library::
5920 * Library definition style::
5922 Dictionary
5924 * close-foreign-library::       Close a foreign library.
5925 * *darwin-framework-directories*::  Search path for Darwin frameworks.
5926 * define-foreign-library::      Explain how to load a foreign library.
5927 * *foreign-library-directories*::  Search path for shared libraries.
5928 * load-foreign-library::        Load a foreign library.
5929 * load-foreign-library-error::  Signalled on failure of its namesake.
5930 * use-foreign-library::         Load a foreign library when needed.
5931 @end menu
5934 @node Defining a library, Library definition style, Libraries, Libraries
5935 @section Defining a library
5937 Almost all foreign code you might want to access exists in some kind
5938 of shared library.  The meaning of @dfn{shared library} varies among
5939 platforms, but for our purposes, we will consider it to include
5940 @file{.so} files on @sc{unix}, frameworks on Darwin (and derivatives
5941 like Mac @acronym{OS X}), and @file{.dll} files on Windows.
5943 Bringing one of these libraries into the Lisp image is normally a
5944 two-step process.
5946 @enumerate
5947 @item
5948 Describe to @cffi{} how to load the library at some future point,
5949 depending on platform and other factors, with a
5950 @code{define-foreign-library} top-level form.
5952 @item
5953 Load the library so defined with either a top-level
5954 @code{use-foreign-library} form or by calling the function
5955 @code{load-foreign-library}.
5956 @end enumerate
5958 @xref{Tutorial-Loading,, Loading foreign libraries}, for a working
5959 example of the above two steps.
5962 @node Library definition style, close-foreign-library, Defining a library, Libraries
5963 @section Library definition style
5965 Looking at the @code{libcurl} library definition presented earlier,
5966 you may ask why we did not simply do this:
5968 @lisp
5969 (define-foreign-library libcurl
5970   (t (:default "libcurl")))
5971 @end lisp
5973 @noindent
5974 Indeed, this would work just as well on the computer on which I tested
5975 the tutorial.  There are a couple of good reasons to provide the
5976 @file{.so}'s current version number, however.  Namely, the versionless
5977 @file{.so} is not packaged on most @sc{unix} systems along with the
5978 actual, fully-versioned library; instead, it is included in the
5979 ``development'' package along with C headers and static @file{.a}
5980 libraries.
5982 The reason @cffi{} does not try to account for this lies in the
5983 meaning of the version numbers.  A full treatment of shared library
5984 versions is beyond this manual's scope; see @ref{Versioning,, Library
5985 interface versions, libtool, @acronym{GNU} Libtool}, for helpful
5986 information for the unfamiliar.  For our purposes, consider that a
5987 mismatch between the library version with which you tested and the
5988 installed library version may cause undefined
5989 behavior.@footnote{Windows programmers may chafe at adding a
5990 @sc{unix}-specific clause to @code{define-foreign-library}.  Instead,
5991 ask why the Windows solution to library incompatibility is ``include
5992 your own version of every library you use with every program''.}
5994 @impnote{Maybe some notes should go here about OS X, which I know
5995 little about.  --stephen}
5998 @c ===================================================================
5999 @c CLOSE-FOREIGN-LIBRARY
6001 @page
6002 @node close-foreign-library, *darwin-framework-directories*, Library definition style, Libraries
6003 @heading close-foreign-library
6004 @subheading Syntax
6005 @Function{close-foreign-library library @res{} success}
6007 @subheading Arguments and Values
6009 @table @var
6010 @item library
6011 A symbol or an instance of @code{foreign-library}.
6013 @item success
6014 A Lisp boolean.
6015 @end table
6017 @subheading Description
6019 Closes @var{library} which can be a symbol designating a library
6020 define through @code{define-foreign-library} or an instance of
6021 @code{foreign-library} as returned by @code{load-foreign-library}.
6023 @c @subheading Examples
6024 @c @xref{Tutorial-Loading,, Loading foreign libraries}.
6026 @subheading See Also
6028 @seealso{define-foreign-library} @*
6029 @seealso{load-foreign-library} @*
6030 @seealso{use-foreign-library}
6033 @c ===================================================================
6034 @c *DARWIN-FRAMEWORK-DIRECTORIES*
6036 @page
6037 @node *darwin-framework-directories*, define-foreign-library, close-foreign-library, Libraries
6038 @heading *darwin-framework-directories*
6039 @subheading Syntax
6041 @Variable{*darwin-framework-directories*}
6043 @subheading Value type
6045 A list, in which each element is a string, a pathname, or a simple
6046 Lisp expression.
6048 @subheading Initial value
6050 A list containing the following, in order: an expression corresponding
6051 to Darwin path @file{~/Library/Frameworks/},
6052 @code{#P"/Library/Frameworks/"}, and
6053 @code{#P"/System/Library/Frameworks/"}.
6055 @subheading Description
6057 The meaning of ``simple Lisp expression'' is explained in
6058 @ref{*foreign-library-directories*}.  In contrast to that variable,
6059 this is not a fallback search path; the default value described above
6060 is intended to be a reasonably complete search path on Darwin systems.
6062 @subheading Examples
6064 @lisp
6065 CFFI> (let ((lib (load-foreign-library '(:framework "OpenGL"))))
6066         (foreign-library-pathname lib))
6067 @result{} #P"/System/Library/Frameworks/OpenGL.framework/OpenGL"
6068 @end lisp
6070 @subheading See also
6072 @seealso{*foreign-library-directories*} @*
6073 @seealso{define-foreign-library}
6076 @c ===================================================================
6077 @c DEFINE-FOREIGN-LIBRARY
6079 @page
6080 @node define-foreign-library, *foreign-library-directories*, *darwin-framework-directories*, Libraries
6081 @heading define-foreign-library
6083 @subheading Syntax
6085 @Macro{define-foreign-library name-and-options @{ load-clause @}* @res{} name}
6087 name-and-options ::= name | (name &key canary convention search-path) @*
6088 load-clause ::= (feature library &key convention search-path) @*
6090 @subheading Arguments and Values
6092 @table @var
6093 @item name
6094 A symbol.
6096 @item feature
6097 A feature expression.
6099 @item library
6100 A library designator.
6102 @item canary
6103 A string denoting a foreign symbol that will be searched in core
6104 before attempting to load the library. If that symbol is found, the
6105 library is assumed to be preloaded (either statically or dynamically
6106 linked) and @code{load-foreign-library} only marks the library as
6107 loaded.
6109 Some implementations (Clisp, ECL, SBCL) natively support static
6110 linking, sometimes referred to as a @emph{link kit}.
6112 @item convention
6113 One of @code{:cdecl} (default) or @code{:stdcall}
6115 @item search-path
6116 A path or list of paths where the library will be searched if not found in
6117 system-global directories. Paths specified in a load clause take priority over
6118 paths specified as library option, with *foreign-library-directories* having
6119 lowest priority.
6120 @end table
6122 @subheading Description
6124 Creates a new library designator called @var{name}.  The
6125 @var{load-clause}s describe how to load that designator when passed to
6126 @code{load-foreign-library} or @code{use-foreign-library}.
6128 When trying to load the library @var{name}, the relevant function
6129 searches the @var{load-clause}s in order for the first one where
6130 @var{feature} evaluates to true.  That happens for any of the
6131 following situations:
6133 @enumerate 1
6134 @item
6135 If @var{feature} is a symbol present in @code{common-lisp:*features*}.
6137 @item
6138 If @var{feature} is a list, depending on @code{(first @var{feature})},
6139 a keyword:
6141 @table @code
6142 @item :and
6143 All of the feature expressions in @code{(rest @var{feature})} are
6144 true.
6146 @item :or
6147 At least one of the feature expressions in @code{(rest @var{feature})}
6148 is true.
6150 @item :not
6151 The feature expression @code{(second @var{feature})} is not true.
6152 @end table
6154 @item
6155 Finally, if @var{feature} is @code{t}, this @var{load-clause} is
6156 picked unconditionally.
6157 @end enumerate
6159 Upon finding the first true @var{feature}, the library loader then
6160 loads the @var{library}.  The meaning of ``library designator'' is
6161 described in @ref{load-foreign-library}.
6163 Functions associated to a library defined by
6164 @code{define-foreign-library} (e.g. through @code{defcfun}'s
6165 @code{:library} option, will inherit the library's options.  The
6166 precedence is as follows:
6168 @enumerate 1
6169 @item
6170 @code{defcfun}/@code{foreign-funcall} specific options;
6172 @item
6173 @var{load-clause} options;
6175 @item
6176 global library options (the @var{name-and-options} argument)
6177 @end enumerate
6180 @subheading Examples
6182 @xref{Tutorial-Loading,, Loading foreign libraries}.
6185 @subheading See Also
6187 @seealso{close-foreign-library} @*
6188 @seealso{load-foreign-library}
6191 @c ===================================================================
6192 @c *FOREIGN-LIBRARY-DIRECTORIES*
6194 @page
6195 @node *foreign-library-directories*, load-foreign-library, define-foreign-library, Libraries
6196 @heading *foreign-library-directories*
6197 @subheading Syntax
6199 @Variable{*foreign-library-directories*}
6201 @subheading Value type
6203 A list, in which each element is a string, a pathname, or a simple
6204 Lisp expression.
6206 @subheading Initial value
6208 The empty list.
6210 @subheading Description
6212 You should not have to use this variable.
6214 Most, if not all, Lisps supported by @cffi{} have a reasonable default
6215 search algorithm for foreign libraries.  For example, Lisps for
6216 @sc{unix} usually call
6217 @uref{http://www.opengroup.org/onlinepubs/009695399/functions/dlopen.html,,
6218 @code{dlopen(3)}}, which in turn looks in the system library
6219 directories.  Only if that fails does @cffi{} look for the named
6220 library file in these directories, and load it from there if found.
6222 Thus, this is intended to be a @cffi{}-only fallback to the library
6223 search configuration provided by your operating system.  For example,
6224 if you distribute a foreign library with your Lisp package, you can
6225 add the library's containing directory to this list and portably
6226 expect @cffi{} to find it.
6228 A @dfn{simple Lisp expression} is intended to provide functionality
6229 commonly used in search paths such as
6230 @acronym{ASDF}'s@footnote{@xref{Using asdf to load systems,,, asdf,
6231 asdf: another system definition facility}, for information on
6232 @code{asdf:*central-registry*}.}, and is defined recursively as
6233 follows:@footnote{See @code{mini-eval} in @file{libraries.lisp} for
6234 the source of this definition.  As is always the case with a Lisp
6235 @code{eval}, it's easier to understand the Lisp definition than the
6236 english.}
6238 @enumerate
6239 @item
6240 A list, whose @samp{first} is a function designator, and whose
6241 @samp{rest} is a list of simple Lisp expressions to be evaluated and
6242 passed to the so-designated function.  The result is the result of the
6243 function call.
6245 @item
6246 A symbol, whose result is its symbol value.
6248 @item
6249 Anything else evaluates to itself.
6250 @end enumerate
6252 The result of evaluating the @dfn{simple Lisp expression} should yield
6253 a @emph{designator} for a @emph{list} of @emph{pathname designators}.
6255 @strong{Note}: in Common Lisp, @code{#p"/foo/bar"} designates the
6256 @emph{bar} file within the @emph{/foo} directory whereas
6257 @code{#p"/foo/bar/"} designates the @emph{/foo/bar} directory. Keep
6258 that in mind when customising the value of
6259 @code{*foreign-library-directories*}.
6262 @subheading Examples
6264 @example
6265 $ ls
6266 @print{} liblibli.so    libli.lisp
6267 @end example
6269 @noindent
6270 In @file{libli.lisp}:
6272 @lisp
6273 (pushnew #P"/home/sirian/lisp/libli/" *foreign-library-directories*
6274          :test #'equal)
6276 (load-foreign-library '(:default "liblibli"))
6277 @end lisp
6279 @noindent
6280 The following example would achieve the same effect:
6282 @lisp
6283 (pushnew '(merge-pathnames #p"lisp/libli/" (user-homedir-pathname))
6284           *foreign-library-directories*
6285           :test #'equal)
6286 @result{} ((MERGE-PATHNAMES #P"lisp/libli/" (USER-HOMEDIR-PATHNAME)))
6288 (load-foreign-library '(:default "liblibli"))
6289 @end lisp
6291 @subheading See also
6293 @seealso{*darwin-framework-directories*} @*
6294 @seealso{define-foreign-library}
6297 @c ===================================================================
6298 @c LOAD-FOREIGN-LIBRARY
6300 @page
6301 @node load-foreign-library, load-foreign-library-error, *foreign-library-directories*, Libraries
6302 @heading load-foreign-library
6303 @subheading Syntax
6304 @Function{load-foreign-library library-designator @res{} library}
6306 @subheading Arguments and Values
6308 @table @var
6309 @item library-designator
6310 A library designator.
6312 @item library-designator
6313 An instance of @code{foreign-library}.
6314 @end table
6316 @subheading Description
6318 Load the library indicated by @var{library-designator}. A @dfn{library
6319 designator} is defined as follows:
6321 @enumerate
6322 @item
6323 If a symbol, is considered a name previously defined with
6324 @code{define-foreign-library}.
6326 @item
6327 If a string or pathname, passed as a namestring directly to the
6328 implementation's foreign library loader.  If that fails, search the
6329 directories in @code{*foreign-library-directories*} with
6330 @code{cl:probe-file}; if found, the absolute path is passed to the
6331 implementation's loader.
6333 @item
6334 If a list, the meaning depends on @code{(first @var{library})}:
6336 @table @code
6337 @item :framework
6338 The second list element is taken to be a Darwin framework name, which
6339 is then searched in @code{*darwin-framework-directories*}, and loaded
6340 when found.
6342 @item :or
6343 Each remaining list element, itself a @dfn{library designator}, is loaded in
6344 order, until one succeeds.
6346 @item :default
6347 The name is transformed according to the platform's naming convention
6348 to shared libraries, and the resultant string is loaded as a @dfn{library
6349 designator}.  For example, on @sc{unix}, the name is suffixed with
6350 @file{.so}.
6351 @end table
6352 @end enumerate
6354 If the library is already loaded it will be reloaded.
6356 If the load fails, signal a @code{load-foreign-library-error}.
6358 @strong{Please note:} For system libraries, you should not need to
6359 specify the directory containing the library.  Each operating system
6360 has its own idea of a default search path, and you should rely on it
6361 when it is reasonable.
6363 @subheading Implementation-specific Notes
6364 On ECL platforms where its dynamic FFI is not supported (ie. when
6365 @code{:dffi} is not present in @code{*features*}),
6366 @code{cffi:load-foreign-library} does not work and you must use ECL's
6367 own @code{ffi:load-foreign-library} with a constant string argument.
6369 @subheading Examples
6371 @xref{Tutorial-Loading,, Loading foreign libraries}.
6373 @subheading See Also
6375 @seealso{close-foreign-library} @*
6376 @seealso{*darwin-framework-directories*} @*
6377 @seealso{define-foreign-library} @*
6378 @seealso{*foreign-library-directories*} @*
6379 @seealso{load-foreign-library-error} @*
6380 @seealso{use-foreign-library}
6383 @c ===================================================================
6384 @c LOAD-FOREIGN-LIBRARY-ERROR
6386 @page
6387 @node load-foreign-library-error, use-foreign-library, load-foreign-library, Libraries
6388 @heading load-foreign-library-error
6390 @subheading Syntax
6392 @Condition{load-foreign-library-error}
6394 @subheading Class precedence list
6396 @code{load-foreign-library-error}, @code{error},
6397 @code{serious-condition}, @code{condition}, @code{t}
6399 @subheading Description
6401 Signalled when a foreign library load completely fails.  The exact
6402 meaning of this varies depending on the real conditions at work, but
6403 almost universally, the implementation's error message is useless.
6404 However, @cffi{} does provide the useful restarts @code{retry} and
6405 @code{use-value}; invoke the @code{retry} restart to try loading the
6406 foreign library again, or the @code{use-value} restart to try loading
6407 a different foreign library designator.
6409 @subheading See also
6411 @seealso{load-foreign-library}
6414 @c ===================================================================
6415 @c USE-FOREIGN-LIBRARY
6417 @page
6418 @node use-foreign-library,  , load-foreign-library-error, Libraries
6419 @heading use-foreign-library
6421 @subheading Syntax
6423 @Macro{use-foreign-library name}
6425 @subheading Arguments and values
6427 @table @var
6428 @item name
6429 A library designator; unevaluated.
6430 @end table
6433 @subheading Description
6435 @xref{load-foreign-library}, for the meaning of ``library
6436 designator''.  This is intended to be the top-level form used
6437 idiomatically after a @code{define-foreign-library} form to go ahead
6438 and load the library. @c ; it also sets the ``current foreign library''.
6439 Finally, on implementations where the regular evaluation rule is
6440 insufficient for foreign library loading, it loads it at the required
6441 time.@footnote{Namely, @acronym{CMUCL}.  See
6442 @code{use-foreign-library} in @file{libraries.lisp} for details.}
6444 @c current foreign library is a concept created a few hours ago as of
6445 @c this writing.  It is not actually used yet, but probably will be.
6447 @subheading Examples
6449 @xref{Tutorial-Loading,, Loading foreign libraries}.
6452 @subheading See also
6454 @seealso{load-foreign-library}
6457 @c ===================================================================
6458 @c CHAPTER: Callbacks
6460 @node Callbacks, The Groveller, Libraries, Top
6461 @chapter Callbacks
6463 @menu
6464 Dictionary
6466 * callback::
6467 * defcallback::
6468 * get-callback::
6469 @end menu
6472 @c ===================================================================
6473 @c CALLBACK
6475 @page
6476 @node callback, defcallback, Callbacks, Callbacks
6477 @heading callback
6478 @subheading Syntax
6479 @Macro{callback symbol @res{} pointer}
6481 @subheading Arguments and Values
6483 @table @var
6484 @item symbol
6485 A symbol denoting a callback.
6487 @item pointer
6488 @itemx new-value
6489 A pointer.
6490 @end table
6492 @subheading Description
6493 The @code{callback} macro is analogous to the standard CL special
6494 operator @code{function} and will return a pointer to the callback
6495 denoted by the symbol @var{name}.
6497 @subheading Examples
6499 @lisp
6500 CFFI> (defcallback sum :int ((a :int) (b :int))
6501         (+ a b))
6502 @result{} SUM
6503 CFFI> (callback sum)
6504 @result{} #<A Mac Pointer #x102350>
6505 @end lisp
6507 @subheading See Also
6508 @seealso{get-callback} @*
6509 @seealso{defcallback}
6512 @c ===================================================================
6513 @c DEFCALLBACK
6515 @page
6516 @node defcallback, get-callback, callback, Callbacks
6517 @heading defcallback
6518 @subheading Syntax
6519 @Macro{defcallback name-and-options return-type arguments &body body @res{} name}
6521 name-and-options ::= name | (name &key convention) @*
6522 arguments ::= (@{ (arg-name arg-type) @}*) @*
6524 @subheading Arguments and Values
6526 @table @var
6527 @item name
6528 A symbol naming the callback created.
6530 @item return-type
6531 The foreign type for the callback's return value.
6533 @item arg-name
6534 A symbol.
6536 @item arg-type
6537 A foreign type.
6539 @item convention
6540 One of @code{:cdecl} (default) or @code{:stdcall}.
6541 @end table
6543 @subheading Description
6544 The @code{defcallback} macro defines a Lisp function that can be called
6545 from C. The arguments passed to this function will be converted to the
6546 appropriate Lisp representation and its return value will be converted
6547 to its C representation.
6549 This Lisp function can be accessed by the @code{callback} macro or the
6550 @code{get-callback} function.
6552 @strong{Portability note:} @code{defcallback} will not work correctly
6553 on some Lisps if it's not a top-level form.
6555 @subheading Examples
6557 @lisp
6558 (defcfun "qsort" :void
6559   (base :pointer)
6560   (nmemb :int)
6561   (size :int)
6562   (fun-compar :pointer))
6564 (defcallback < :int ((a :pointer) (b :pointer))
6565   (let ((x (mem-ref a :int))
6566         (y (mem-ref b :int)))
6567     (cond ((> x y) 1)
6568           ((< x y) -1)
6569           (t 0))))
6571 CFFI> (with-foreign-object (array :int 10)
6572         ;; @lispcmt{Initialize array.}
6573         (loop for i from 0 and n in '(7 2 10 4 3 5 1 6 9 8)
6574               do (setf (mem-aref array :int i) n))
6575         ;; @lispcmt{Sort it.}
6576         (qsort array 10 (foreign-type-size :int) (callback <))
6577         ;; @lispcmt{Return it as a list.}
6578         (loop for i from 0 below 10
6579               collect (mem-aref array :int i)))
6580 @result{} (1 2 3 4 5 6 7 8 9 10)
6581 @end lisp
6583 @subheading See Also
6584 @seealso{callback} @*
6585 @seealso{get-callback}
6588 @c ===================================================================
6589 @c GET-CALLBACK
6591 @page
6592 @node get-callback,  , defcallback, Callbacks
6593 @heading get-callback
6594 @subheading Syntax
6595 @Accessor{get-callback symbol @res{} pointer}
6597 @subheading Arguments and Values
6599 @table @var
6600 @item symbol
6601 A symbol denoting a callback.
6603 @item pointer
6604 A pointer.
6605 @end table
6607 @subheading Description
6608 This is the functional version of the @code{callback} macro. It
6609 returns a pointer to the callback named by @var{symbol} suitable, for
6610 example, to pass as arguments to foreign functions.
6612 @subheading Examples
6614 @lisp
6615 CFFI> (defcallback sum :int ((a :int) (b :int))
6616         (+ a b))
6617 @result{} SUM
6618 CFFI> (get-callback 'sum)
6619 @result{} #<A Mac Pointer #x102350>
6620 @end lisp
6622 @subheading See Also
6623 @seealso{callback} @*
6624 @seealso{defcallback}
6627 @c ===================================================================
6628 @c CHAPTER: The Groveller
6630 @node The Groveller, Limitations, Callbacks, Top
6631 @chapter The Groveller
6633 @cffi{}-Grovel is a tool which makes it easier to write @cffi{}
6634 declarations for libraries that are implemented in C.  That is, it
6635 grovels through the system headers, getting information about types
6636 and structures, so you don't have to.  This is especially important
6637 for libraries which are implemented in different ways by different
6638 vendors, such as the @sc{unix}/@sc{posix} functions.  The @cffi{}
6639 declarations are usually quite different from platform to platform,
6640 but the information you give to @cffi{}-Grovel is the same.  Hence,
6641 much less work is required!
6643 If you use @acronym{ASDF}, @cffi{}-Grovel is integrated, so that it
6644 will run automatically when your system is building.  This feature was
6645 inspired by SB-Grovel, a similar @acronym{SBCL}-specific project.
6646 @cffi{}-Grovel can also be used without @acronym{ASDF}.
6648 @section Building FFIs with CFFI-Grovel
6650 @cffi{}-Grovel uses a specification file (*.lisp) describing the
6651 features that need groveling.  The C compiler is used to retrieve this
6652 data and write a Lisp file (*.cffi.lisp) which contains the necessary
6653 @cffi{} definitions to access the variables, structures, constants, and
6654 enums mentioned in the specification.
6656 @c This is most similar to the SB-Grovel package, upon which it is
6657 @c based.  Unlike SB-Grovel, we do not currently support defining
6658 @c regular foreign functions in the specification file; those are best
6659 @c defined in normal Lisp code.
6661 @cffi{}-Grovel provides an @acronym{ASDF} component for handling the
6662 necessary calls to the C compiler and resulting file management.
6664 @c See the included CFFI-Unix package for an example of how to
6665 @c integrate a specification file with ASDF-built packages.
6667 @menu
6668 * Groveller Syntax::            How grovel files should look like.
6669 * Groveller ASDF Integration::  ASDF components for grovel files.
6670 * Groveller Implementation Notes:: Implementation notes.
6671 * Wrapper for Inline/Static Functions and Macros:: Wrapper
6672 @end menu
6674 @node Groveller Syntax, Groveller ASDF Integration, The Groveller, The Groveller
6675 @section Specification File Syntax
6677 The specification files are read by the normal Lisp reader, so they
6678 have syntax very similar to normal Lisp code.  In particular,
6679 semicolon-comments and reader-macros will work as expected.
6681 There are several forms recognized by @cffi{}-Grovel:
6683 @deffn {Grovel Form} progn &rest forms
6685 Processes a list of forms. Useful for conditionalizing several
6686 forms. For example:
6687 @end deffn
6689 @lisp
6690 #+freebsd
6691 (progn
6692   (constant (ev-enable "EV_ENABLE"))
6693   (constant (ev-disable "EV_DISABLE")))
6694 @end lisp
6696 @deffn {Grovel Form} include &rest files
6698 Include the specified files (specified as strings) in the generated C
6699 source code.
6700 @end deffn
6702 @deffn {Grovel Form} in-package symbol
6704 Set the package to be used for the final Lisp output.
6705 @end deffn
6707 @deffn {Grovel Form} ctype lisp-name size-designator
6709 Define a @cffi{} foreign type for the string in @var{size-designator},
6710 e.g. @code{(ctype :pid "pid_t")}.
6711 @end deffn
6713 @deffn {Grovel Form} constant (lisp-name &rest c-names) &key type documentation optional
6715 Search for the constant named by the first @var{c-name} string found
6716 to be known to the C preprocessor and define it as @var{lisp-name}.
6718 The @var{type} keyword argument specifies how to grovel the constant:
6719 either @code{integer} (the default) or @code{double-float}. If
6720 @var{optional} is true, no error will be raised if all the
6721 @var{c-names} are unknown. If @var{lisp-name} is a keyword, the actual
6722 constant will be a symbol of the same name interned in the current
6723 package.
6724 @end deffn
6726 @deffn {Grovel Form} feature lisp-feature-name c-name &key feature-list
6728 Adds @var{lisp-feature-name} to the list @var{feature-list} if the @var{c-name}
6729 string is known to the C preprocessor. @var{feature-list} defaults
6730 to @code{cl:*features*}.
6731 @end deffn
6733 @deffn {Grovel Form} define name &optional value
6735 Defines an additional C preprocessor symbol, which is useful for
6736 altering the behavior of included system headers.
6737 @end deffn
6739 @deffn {Grovel Form} cc-flags &rest flags
6741 Adds @var{cc-flags} to the command line arguments used for the C compiler
6742 invocation.
6743 @end deffn
6745 @deffn {Grovel Form} pkg-config-cflags pkg &key optional
6747 Adds @var{pkg} to the command line arguments for the external program
6748 @code{pkg-config} and runs it to retrieve the relevant include flags
6749 used for the C compiler invocation. This syntax can be used instead of
6750 hard-coding paths using @code{cc-flags}, and ensures that include
6751 flags are added correctly on the build system. Assumes
6752 @code{pkg-config} is installed and working.  @var{pkg} is a string
6753 that identifies an installed @code{pkg-config} package. See the
6754 pkg-config manual for more information. If @var{optional} is true,
6755 failure to execute @code{pkg-config} does @emph{not} abort
6756 compilation.
6757 @end deffn
6759 @deffn {Grovel Form} cstruct lisp-name c-name slots
6761 Define a @cffi{} foreign struct with the slot data specfied.  Slots
6762 are of the form @code{(lisp-name c-name &key type count (signed t))}.
6763 @end deffn
6765 @deffn {Grovel Form} cunion lisp-name c-name slots
6767 Identical to @code{cstruct}, but defines a @cffi{} foreign union.
6768 @end deffn
6770 @deffn {Grovel Form} cstruct-and-class c-name slots
6772 Defines a @cffi{} foreign struct, as with @code{cstruct} and defines a
6773 @acronym{CLOS} class to be used with it.  This is useful for mapping
6774 foreign structures to application-layer code that shouldn't need to
6775 worry about memory allocation issues.
6776 @end deffn
6778 @deffn {Grovel Form} cvar namespec type &key read-only
6780 Defines a foreign variable of the specified type, even if that
6781 variable is potentially a C preprocessor pseudo-variable.  e.g.
6782 @code{(cvar ("errno" errno) errno-values)}, assuming that errno-values
6783 is an enum or equivalent to type @code{:int}.
6785 The @var{namespec} is similar to the one used in @ref{defcvar}.
6786 @end deffn
6788 @deffn {Grovel Form} cenum name-and-opts &rest elements
6790 Defines a true C enum, with elements specified as @code{((lisp-name
6791 &rest c-names) &key optional documentation)}.
6792 @var{name-and-opts} can be either a symbol as name, or a list
6793 @code{(name &key base-type define-constants)}. If @var{define-constants}
6794 is non-null, a Lisp constant will be defined for each enum member.
6795 @end deffn
6797 @deffn {Grovel Form} constantenum name-and-opts &rest elements
6799 Defines an enumeration of pre-processor constants, with elements
6800 specified as @code{((lisp-name &rest c-names) &key optional
6801 documentation)}.
6802 @var{name-and-opts} can be either a symbol as name, or a list
6803 @code{(name &key base-type define-constants)}. If @var{define-constants}
6804 is non-null, a Lisp constant will be defined for each enum member.
6806 This example defines @code{:af-inet} to represent the value held by
6807 @code{AF_INET} or @code{PF_INET}, whichever the pre-processor finds
6808 first.  Similarly for @code{:af-packet}, but no error will be
6809 signalled if the platform supports neither @code{AF_PACKET} nor
6810 @code{PF_PACKET}.
6811 @end deffn
6813 @lisp
6814 (constantenum address-family
6815   ((:af-inet "AF_INET" "PF_INET")
6816    :documentation "IPv4 Protocol family")
6817   ((:af-local "AF_UNIX" "AF_LOCAL" "PF_UNIX" "PF_LOCAL")
6818    :documentation "File domain sockets")
6819   ((:af-inet6 "AF_INET6" "PF_INET6")
6820    :documentation "IPv6 Protocol family")
6821   ((:af-packet "AF_PACKET" "PF_PACKET")
6822    :documentation "Raw packet access"
6823    :optional t))
6824 @end lisp
6826 @deffn {Grovel Form} bitfield name-and-opts &rest elements
6828 Defines a bitfield, with elements specified as @code{((lisp-name &rest
6829 c-names) &key optional documentation)}.  @var{name-and-opts} can be either a
6830 symbol as name, or a list @code{(name &key base-type)}.  For example:
6831 @end deffn
6833 @lisp
6834 (bitfield flags-ctype
6835   ((:flag-a "FLAG_A")
6836     :documentation "DOCU_A")
6837   ((:flag-b "FLAG_B" "FLAG_B_ALT")
6838     :documentation "DOCU_B")
6839   ((:flag-c "FLAG_C")
6840     :documentation "DOCU_C"
6841     :optional t))
6842 @end lisp
6845 @c ===================================================================
6846 @c SECTION: Groveller ASDF Integration
6848 @node Groveller ASDF Integration, Groveller Implementation Notes, Groveller Syntax, The Groveller
6849 @section ASDF Integration
6851 An example software project might contain four files; an
6852 @acronym{ASDF} file, a package definition file, an implementation
6853 file, and a @cffi{}-Grovel specification file.
6855 The @acronym{ASDF} file defines the system and its dependencies.
6856 Notice the use of @code{eval-when} to ensure @cffi{}-Grovel is present
6857 and the use of @code{(cffi-grovel:grovel-file name &key cc-flags)}
6858 instead of @code{(:file name)}.
6860 The @file{example-software.asd} file would look like that:
6862 @lisp
6863 ;;; @lispcmt{CFFI-Grovel is needed for processing grovel-file components}
6864 (defsystem "example-software"
6865   :defsystem-depends-on ("cffi-grovel")
6866   :depends-on ("cffi")
6867   :serial t
6868   :components
6869   ((:file "package")
6870    (:cffi-grovel-file "example-grovelling")
6871    (:cffi-wrapper-file "example-wrappers")
6872    (:file "example")))
6873 @end lisp
6875 The @file{package.lisp} file would contain one or several
6876 @code{defpackage} forms, to remove circular dependencies and make
6877 building the project easier.  Note that you may or may not want to
6878 @code{:use} your internal package.
6880 @impnote{Note that it's a not a good idea to @code{:use} when names may
6881 clash with, say, CL symbols.
6882 Or you could use @code{uiop:define-package} and its @code{:mix} option.}
6884 @lisp
6885 (defpackage #:example-internal
6886   (:use)
6887   (:nicknames #:exampleint))
6889 (defpackage #:example-software
6890   (:export ...)
6891   (:use #:cl #:cffi #:exampleint))
6892 @end lisp
6894 The internal package is created by Lisp code output from the C program
6895 written by @cffi{}-Grovel; if your specification file is
6896 @file{exampleint.lisp}, the @file{exampleint.cffi.lisp} file will contain the
6897 @cffi{} definitions needed by the rest of your project.
6898 @xref{Groveller Syntax}.
6900 @node Groveller Implementation Notes,  Wrapper for Inline/Static Functions and Macros, Groveller ASDF Integration, The Groveller
6901 @section Implementation Notes
6903 @cffi{}-Grovel will generate many files that not only architecture-specific,
6904 but also implementation-specific, and should not be distributed.
6905 ASDF will generate these files in its output cache;
6906 if you build with multiple architectures (e.g. with NFS/AFS home
6907 directories) or implementations, it is critical for avoiding clashes
6908 to keep this cache in an implementation-dependent directory (as is the
6909 default).
6911 For @code{foo-internal.lisp}, the resulting @code{foo-internal.c},
6912 @code{foo-internal}, and @code{foo-internal.cffi.lisp} are all
6913 platform-specific, either because of possible reader-macros in
6914 foo-internal.lisp, or because of varying C environments on the host
6915 system.  For this reason, it is not helpful to distribute any of those
6916 files; end users building @cffi{}-Grovel based software will need
6917 @code{cffi}-Grovel anyway.
6919 @impnote{For now, after some experimentation with @sc{clisp} having no
6920 long-long, it seems appropriate to assert that the generated @code{.c}
6921 files are architecture and operating-system dependent, but
6922 lisp-implementation independent.  This way the same @code{.c} file
6923 (and so the same @code{.grovel-tmp.lisp} file) will be shareable
6924 between the implementations running on a given system.}
6926 @c TODO: document the new wrapper stuff.
6928 @node Wrapper for Inline/Static Functions and Macros,  , Groveller Implementation Notes, The Groveller
6929 @section Wrapper for Inline/Static Functions and Macros
6931 In a shared library, information in static/inlined functions and
6932 macros are already removed during the compilation.  Wrapper file
6933 enables to write an uninlined function wrapping the call to them.
6935 A wrapper file compilation/loading proceeds as follows: 
6936 Unlike groveller which generates C code that emits lisp files
6937 containing cffi definitions, it generates C code, compiles it as a
6938 shared library, loads the library, generate the cffi definitions (as
6939 lisp code) and then loads the lisp code.
6941 It has asdf integration similar to groveller. 
6943 @lisp
6944 (defsystem "example-software"
6945   :defsystem-depends-on ("cffi-grovel")
6946   :depends-on ("cffi")
6947   :serial t
6948   :components
6949   ((:file "package")
6950    (:cffi-grovel-file "example-grovelling")
6951    (:cffi-wrapper-file "example-wrappers")  ;; <<--- this part
6952    (:file "example")))
6953 @end lisp
6955 @deffn {Wrapper Form} defwrapper name-and-options return-type &rest args
6956 @end deffn
6958 @example
6959 static inline int foo(int i) @{
6960   return 1+i;
6962 #define bar(i) (1+(i))
6963 @end example
6965 @lisp
6966 (in-package :mypackage)
6967 (defwrapper ("foo" foo) :int
6968   (i :int))
6969 (defwrapper ("bar" bar) :int
6970   (i :int))
6971 @end lisp
6973 Other forms are similar to grovel files.
6975 @deffn {Wrapper Form} progn &rest forms
6977 Processes a list of forms. Useful for conditionalizing several
6978 forms. For example:
6979 @end deffn
6981 @lisp
6982 #+freebsd
6983 (progn
6984   (constant (ev-enable "EV_ENABLE"))
6985   (constant (ev-disable "EV_DISABLE")))
6986 @end lisp
6988 @deffn {Wrapper Form} include &rest files
6990 Include the specified files (specified as strings) in the generated C
6991 source code.
6992 @end deffn
6994 @deffn {Wrapper Form} in-package symbol
6996 Set the package to be used for the final Lisp output.
6997 @end deffn
6999 @deffn {Wrapper Form} flags &rest flags
7001 Adds @var{cc-flags} to the command line arguments used for the C compiler
7002 invocation.
7003 @end deffn
7005 @deffn {Wrapper Form} proclaim &rest proclaimations
7006 @end deffn
7007 @deffn {Wrapper Form} declaim &rest declaimations
7008 @end deffn
7012 @c ===================================================================
7013 @c CHAPTER: Static Linking
7015 @node Static Linking, Limitations, The Groveller, Top
7016 @chapter Static Linking
7018 On recent enough versions of supported implementations (currently, GNU
7019 CLISP 2.49 or later, CMUCL 2015-11 or later, and SBCL 1.2.17 or later,
7020 except SBCL 2.0.4), and with a recent enough ASDF (3.1.2 or later),
7021 you can create a statically linked Lisp executable image (or a
7022 standalone application executable) that includes all the C extensions
7023 defined via @ref{The Groveller}'s @code{:cffi-wrapper-file} ASDF
7024 components (and any other such objects output by
7025 @code{asdf:compile-op}), as well as those defined by @code{:c-file} or
7026 @code{:o-file} ASDF components, and your Lisp code.  This makes it
7027 easier to deliver your code as a single file.
7029 Note that the resulting binary will typically still depend on any
7030 shared libraries loaded via @xref{load-foreign-library} or
7031 @xref{use-foreign-library} as well as core libraries such as
7032 @code{libc}.
7034 To dump a statically linked executable image, use:
7036 @lisp
7037 (asdf:load-system :cffi-grovel)
7038 (asdf:operate :static-image-op :example-software)
7039 @end lisp
7041 To dump a statically linked executable standalone application, use:
7043 @lisp
7044 (asdf:load-system :cffi-grovel)
7045 (asdf:operate :static-program-op :example-software)
7046 @end lisp
7048 See @uref{https://common-lisp.net/project/asdf/,,the ASDF
7049 manual} for documentation about @code{image-op} and @code{program-op}
7050 which are the parent operation classes that behave similarly except
7051 they don't statically link C code.
7053 @impnote{There is also an operation @code{:static-runtime-op} to create the
7054 statically linked runtime alone, but it's admittedly not very useful
7055 except as an intermediate step dependency towards building
7056 @code{:static-image-op} or @code{:static-program-op}.}
7060 @c ===================================================================
7061 @c CHAPTER: Limitations
7063 @node Limitations, Platform-specific features, The Groveller, Top
7064 @chapter Limitations
7066 These are @cffi{}'s limitations across all platforms; for information
7067 on the warts on particular Lisp implementations, see
7068 @ref{Implementation Support}.
7070 @itemize @bullet
7071 @item
7072 The tutorial includes a treatment of the primary, intractable
7073 limitation of @cffi{}, or any @acronym{FFI}: that the abstractions
7074 commonly used by C are insufficiently expressive.
7075 @xref{Tutorial-Abstraction,, Breaking the abstraction}, for more
7076 details.
7078 @end itemize
7081 @node Platform-specific features, Glossary, Limitations, Top
7082 @appendix Platform-specific features
7084 Whenever a backend doesn't support one of @cffi{}'s features, a
7085 specific symbol is pushed onto @code{common-lisp:*features*}.  The
7086 meanings of these symbols follow.
7088 @table @var
7089 @item cffi-sys::flat-namespace
7090 This Lisp has a flat namespace for foreign symbols meaning that you
7091 won't be able to load two different libraries with homograph functions
7092 and successfully differentiate them through the @code{:library}
7093 option to @code{defcfun}, @code{defcvar}, etc@dots{}
7095 @item cffi-sys::no-foreign-funcall
7096 The macro @code{foreign-funcall} is @strong{not} available.  On such
7097 platforms, the only way to call a foreign function is through
7098 @code{defcfun}.  @xref{foreign-funcall}, and @ref{defcfun}.
7100 @item cffi-sys::no-long-long
7101 The C @code{long long} type is @strong{not} available as a foreign
7102 type.
7104 However, on such platforms @cffi{} provides its own implementation of
7105 the @code{long long} type for all of operations in chapters
7106 @ref{Foreign Types}, @ref{Pointers} and @ref{Variables}. The
7107 functionality described in @ref{Functions} and @ref{Callbacks} will
7108 not be available.
7110 32-bit Lispworks 5.0+ is an exception. In addition to the @cffi{}
7111 implementation described above, Lispworks itself implements the
7112 @code{long long} type for @ref{Functions}. @ref{Callbacks} are still
7113 missing @code{long long} support, though.
7115 @item cffi-sys::no-stdcall
7116 This Lisp doesn't support the @code{stdcall} calling convention.  Note
7117 that it only makes sense to support @code{stdcall} on (32-bit) x86
7118 platforms.
7120 @end table
7123 @node Glossary, Comprehensive Index, Platform-specific features, Top
7124 @appendix Glossary
7126 @table @dfn
7127 @item aggregate type
7128 A @cffi{} type for C data defined as an organization of data of simple
7129 type; in structures and unions, which are themselves aggregate types,
7130 they are represented by value.
7132 @item foreign value
7133 This has two meanings; in any context, only one makes sense.
7135 When using type translators, the foreign value is the lower-level Lisp
7136 value derived from the object passed to @code{translate-to-foreign}
7137 (@pxref{translate-to-foreign}).  This value should be a Lisp number or
7138 a pointer (satisfies @code{pointerp}), and it can be treated like any
7139 general Lisp object; it only completes the transformation to a true
7140 foreign value when passed through low-level code in the Lisp
7141 implementation, such as the foreign function caller or indirect memory
7142 addressing combined with a data move.
7144 In other contexts, this refers to a value accessible by C, but which
7145 may only be accessed through @cffi{} functions.  The closest you can
7146 get to such a foreign value is through a pointer Lisp object, which
7147 itself counts as a foreign value in only the previous sense.
7149 @item simple type
7150 A @cffi{} type that is ultimately represented as a builtin type;
7151 @cffi{} only provides extra semantics for Lisp that are invisible to C
7152 code or data.
7153 @end table
7155 @node Comprehensive Index,  , Glossary, Top
7156 @unnumbered Index
7157 @printindex cp
7159 @bye